@charset "UTF-8";

/* ---------------------------------------------------------
@extend (継承用)
--------------------------------------------------------- */
.montserrat {
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
}

.notoM {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
}

.notoB {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
}

.fv {
    position: relative;
    padding: 37px 0 17px;
    background: #fffbac;
}

.fv video {
    width: 100%;
    height: auto;
    border-radius: 0 70px 0 70px;
}

.fv .visual_video {
    position: relative;
    width: 100%;
    height: 56.25vw;
}

.fv .visual_video .video_frame {
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.fv .visual_video .video_frame video {
    position: absolute;
    z-index: -1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 177.77777778vh;
    /* 16:9 の幅→16 ÷ 9＝ 177.77% */
    height: 56.25vw;
    /* 16:9の幅 → 9 ÷ 16 = 56.25% */
    min-height: 100%;
    min-width: 100%;
}

@media all and (max-width: 768px) {
    .fv {
        padding-top: 80px;
    }
}

@media all and (max-width: 768px) {
    .fv {
        padding-top: 80px;
    }
}

.about {
    position: relative;
    padding-top: 128px;
    padding-bottom: 44px;
    background: #fffbac;
}

.about p {
    margin-bottom: 20px;
}

@media all and (max-width: 768px) {
    .about {
        padding: 60px 0 40px;
    }
}

@media all and (max-width: 768px) {
    .about {
        padding: 60px 0 40px;
    }
}

.service {
    position: relative;
    z-index: 2;
    padding-top: 180px;
    padding-bottom: 146px;
}

.service:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    padding-top: 11.335504886%;
    background: no-repeat 50%/cover url(../img/parts/wave1.svg);
}

.service:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: -1;
    width: 100%;
    padding-top: 11.335504886%;
    background: no-repeat 50%/cover url(../img/parts/wave2.svg);
}

.service h2 {
    margin-bottom: 59px;
}

.service h3 {
    margin-bottom: 70px;
    text-align: center;
}

.service .col {
    margin-bottom: 50px;
}

.service .item {
    text-align: center;
}

.service .item figure {
    max-width: 170px;
    margin: 0 auto 17px;
}

.service .item p {
    font-size: 18px;
    font-size: 1.125rem;
}

@media all and (max-width: 768px) {
    .service:before {
        padding-top: 27.2727272727%;
        background: no-repeat 50%/cover url(../img/parts/sp_wave1.svg);
    }

    .service:after {
        padding-top: 26.7379679144%;
        background: no-repeat 50%/cover url(../img/parts/sp_wave2.svg);
    }

    .service h2+p {
        padding: 0 0;
    }

    .service .media_box .photo_img {
        width: 100%;
    }

    .service .media_box .photo_img:before {
        padding-top: 127.1641791045%;
    }

    .service .media_box article {
        margin-bottom: 58px;
        padding-right: 0;
        width: 100%;
    }

    .service .media_box article p {
        font-size: 18px;
        font-size: 1.125rem;
    }
}

@media all and (max-width: 768px) {
    .service:before {
        padding-top: 27.2727272727%;
        background: no-repeat 50%/cover url(../img/parts/sp_wave1.svg);
    }

    .service:after {
        padding-top: 26.7379679144%;
        background: no-repeat 50%/cover url(../img/parts/sp_wave2.svg);
    }

    .service h2+p {
        padding: 0 0;
    }

    .service .media_box .photo_img {
        width: 100%;
    }

    .service .media_box .photo_img:before {
        padding-top: 127.1641791045%;
    }

    .service .media_box article {
        margin-bottom: 58px;
        padding-right: 0;
        width: 100%;
    }

    .service .media_box article p {
        font-size: 18px;
        font-size: 1.125rem;
    }
}

.voice {
    padding: 30px 0 82px;
    background: #fffbac;
}

.voice p {
    margin-bottom: 48px;
}

.voice .col {
    margin-left: 0;
    margin-bottom: 28px;
}

.voice .col>* {
    margin-left: 0;
    margin-bottom: 0;
    width: 33.3333%;
}

.voice .col>* img {
    display: block;
}

.voice .col>* img:before {
    padding-top: 100%;
}

.voice .col>*:first-child {
    order: 5;
}

.voice .col>*:nth-child(2) {
    order: 1;
}

.voice .col>*:nth-child(3) {
    order: 2;
}

.voice .col>*:nth-child(4) {
    order: 3;
}

.voice .col>*:nth-child(5) {
    order: 4;
}

.voice .col>*:nth-child(6) {
    order: 6;
}

.voice .col>*:nth-child(7) {
    order: 7;
}

.voice .col>*:nth-child(8) {
    order: 8;
}

.voice .col>*:nth-child(9) {
    order: 9;
}

.bnr {
    padding: 77px 0;
}

@media all and (max-width: 768px) {
    .bnr {
        padding: 20px 0;
    }
}

@media all and (max-width: 768px) {
    .bnr {
        padding: 20px 0;
    }
}

/*# sourceMappingURL=index.css.map */