@charset "utf-8";
/* CSS Document
外壁LP用
*/

html,
body {
    width: 100%;
    margin: 0 !important;
    padding: 0 !important;
    font-family: "sans-serif", Meiryo, "Hiragino Sans", "Hiragino Kaku Gothic ProN";
}
.container {
    width: 100%;
    max-width: 780px;
    margin: 0 auto;
    font-size: 18px;
    line-height: 1.6;
    overflow: hidden;
}
h2 {
    margin: 2em 0 1em 0;
    padding: 10px 20px;
    color: #ffffff;
    font-size: 30px;
    font-weight: bold;
    background-color:#4d5bd1;
}
h3 {
    margin: 0 0 1.5rem 0;
    font-size: 30px;
    font-weight: bold;
}
h3 strong {
    color: #ff0000;
    font-size: 1.5em;
    white-space: nowrap;
}
p {
    margin: 1em 0;
    line-height: 1.6;
}
img {
    vertical-align: bottom;
}
p > img {
    vertical-align: top;
}
.red {
    color: #ff0000;
}
strong {
    font-size: 1.1em;
    font-weight: bold;
}
button {
    cursor: pointer;
}
.marker {
    background: linear-gradient(rgba(255, 255, 255, 0) 50%, #ffff00 55%);
    background-repeat: no-repeat;
    background-size: 800px;
    background-position: -800px 0;
    transition-delay: 1s;
    transition-duration: 4s;
    overflow: hidden;
}
.marker.lazyloaded {
    background-position: 0 0;
}
.content {
    padding: 0 0 3.2rem 0;
}
.aligncenter {
    margin-left: auto;
    margin-right: auto;
}
@media only screen and (max-width: 680px) {
    p {
        padding-left: 20px;
        padding-right: 20px;
    }
    h3 {
        padding-left: 20px;
        padding-right: 20px;
    }
    .wp-block-image {
        padding-left: 20px;
        padding-right: 20px;
    }
}

#content01 {
    padding-bottom: 0;
}
#content01 .mainVisual {
    position: relative;
    min-height: 310px;
    background-image: url("../../../uploads/mainBg.png");
    background-position: left top;
    background-repeat: no-repeat;
    background-size: cover;
}
#content01 .mainVisual .headline {
    position: absolute;
    top:35px;
    left: 45px;
    font-size: 30px;
    font-weight: bold;
    line-height: 1.1;
    border-bottom: 5px solid #ff0000;
    text-shadow: 0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff;
    z-index: 3;
}
#content01 .mainVisual .headline .impact {
    font-size: 1.7em;
}
#content01 .mainVisual .headImg {
    width: 290px;
    margin: 0 0 0 auto;
    padding: 10px;
}
#content01 .mainVisual .headImg img {
    display: block;
    width: 100%;
    height: auto;
}
#content01 .mainVisual .headText {
    position: absolute;
    top: 0;
    left: -100%;
    max-width: 70%;
    padding: 15px;
    color: #ffffff;
    font-size: 20px;
    font-weight: bold;
    background-color: #f58412;
    border: 2px solid #000000;
    transform: rotate(5deg) scale(0.1);
    transition-duration: 1s;
    z-index: 2;
}
#content01 .mainVisual.lazyloaded .headText {
    top: 130px;
    left: 30px;
    transform: rotate(-10deg) scale(1);
}
#content01 .update {
    padding: 0.5rem 1rem;
    text-align: right;
}
@media only screen and (max-width: 780px) {
    #content01.content {
        padding-bottom: 5vw;
    }
    #content01 .mainVisual .headline {
        position: absolute;
        top:5vw;
        left: 5vw;
        font-size: 5vw;
    }
    #content01 .mainVisual .headImg {
        width: 60vw;
        margin-right: -12vw;
        padding-top: 8vw;
    }
    #content01 .mainVisual.lazyloaded .headText {
        top:30vw;
        max-width: 65%;
    }
}
@media only screen and (max-width: 640px) {
    #content01 .mainVisual {
        min-height: -webkit-calc(110px + 40vw);
        min-height: calc(110px + 40vw);
    }
    #content01 .mainVisual.lazyloaded .headText {
        top: 25vw;
        padding: 10px;
        transform: rotate(-7deg) scale(1);
    }
    #content01+h2 {
        margin-top: 0;
    }
}
@media only screen and (max-width: 440px) {
    #content01 .mainVisual .headline {
        font-size: 6vw;
    }
    #content01 .mainVisual {
        min-height: -webkit-calc(160px + 40vw);
        min-height: calc(160px + 40vw);
    }
    #content01 .mainVisual .headText {
        padding: 7px;
        transform: rotate(-5deg) scale(1);
    }
    #content01 .mainVisual.lazyloaded .headText {
        top:26vw;
        padding: 7px;
        transform: rotate(-7deg) scale(1);
    }
    #content01 .update {
        padding: 0.5em;
        font-size: 4.4vw;
    }
}
@media only screen and (max-width: 380px) {
    #content01 .mainVisual {
        min-height: -webkit-calc(220px + 35vw);
        min-height: calc(220px + 35vw);
    }
}
.catchFrame {
    width: 90%;
    margin: 2.5rem auto;
    background-color: #faffd4;
    padding: 40px;
    border: 6px double #000000;
}
.catchFrame .textButton {
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    appearance: none;
    margin: 0;
    padding: 0;
}
.catchFrame .textButton button {
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    appearance: none;
    display: inline;
    padding: 0;
    text-decoration: underline;
    color: #4d5bd1;
    border: none;
    background: none;
    text-align: left;
}
.catchFrame .textButton button:hover {
    opacity: 0.6;
}

@media only screen and (max-width: 640px) {
    .catchFrame {
        padding: 20px;
    }
    h3 strong {
        color: #ff0000;
        font-size: 10vw;
    }
}
.contentFrame {
    width: 90%;
    margin: 2.5rem auto;
    padding: 20px;
    border: 2px solid #000000;
}
.contentFrame h3 {
    display: inline-block;
    margin: 0 0 1rem 0;
    font-size: 20px;
    font-weight: bold;
    border-bottom: 3px solid #4d5bd1;
}
.contentFrame ul {
    margin-top: 0;
    margin-bottom: 0;
}

#content05 .textArea.catch {
    font-size: 30px;
    font-weight: bold;
    text-align: center;
}
#content05 .textArea.catch .red {
    font-size: 1.5em;
    white-space: nowrap;
}

.buttonArea {
    margin: 2.5rem 0;
}
.buttonArea .submitButton {
    position: relative;
    display: block;
    width: 640px;
    height: 120px;
    margin: 0 auto;
    background: url("../../../uploads/button-1.png") no-repeat;
    background-size: cover;
    border-radius: 15px;
    box-shadow: -5px -5px 3px 0 rgba(0, 0, 0, 0.3) inset,
        5px 5px 5px 0 rgba(0, 0, 0, 0.3);
    cursor: pointer;
}
.buttonArea .submitButton.lazyloaded {
    animation: poyoyon 1s ease-in-out 3 forwards;
}
.buttonArea .submitButton.lazyloaded:hover {
    animation: none;
}
@keyframes poyoyon {
    0%  {
        transform: scale(1.0, 1.0) translate(0, 0);
    }
    15% {
        transform: scale(0.98, 0.9) translate(0, 5px);
    }
    30% {
        transform: scale(1.02, 1.0) translate(0, 8px);
    }
    50% {transform: scale(0.98, 1.05) translate(0, -8px);
    }
    70% {
        transform: scale(1.0, 0.9) translate(0, 5px);
    }
    100% {
        transform: scale(1.0, 1.0) translate(0, 0);
    }
    0%, 100% {
        opacity: 1;
    }
}
.buttonArea .submitButton .buttonText {
    position: absolute;
    top:6px;
    left:15px;
    color: #ffffff;
    font-size: 20px;
    font-weight: bold;
    text-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5);
}
.buttonArea .submitButton .buttonText .areaName {
    color: #ff0000;
    font-size: 1.5em;
    text-shadow: 0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        0 0 3px #ffffff,
        3px 3px 3px rgba(0, 0, 0, 0.5);
}
@media only screen and (max-width: 680px) {
    .buttonArea .submitButton {
        width: 84vw;
        height: 29.47vw;
        background: url("../../../uploads/buttonSp-1.png") no-repeat;
        background-size: cover;
    }
    .buttonArea .submitButton .buttonText {
        top:1vw;
        left:5vw;
        font-size: 5vw;
    }
    .buttonArea .submitButton .buttonText .areaName {
        font-size: 1.3em;
    }
}
.textButton .submitButton {
    text-decoration: underline;
    color: #4d5bd1;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
}
.textButton .submitButton:hover {
    opacity: 0.6;
}

.container footer {
    margin: 0;
    padding: 20px;
}
.container footer .copy {
    font-size: 14px;
    text-align: center;
}
@media only screen and (max-width: 680px) {
    .textButton {
        padding-left: 20px;
        padding-right: 20px;
    }
}
