@charset "UTF-8";
.top_ttl{
    font-size: 30px;
    line-height: 1.2;
    font-weight: bold;
    text-align: center;
    color: #434343;
}
.top_ttl .icn {
    display: inline-block;
    position: relative;
    padding-left: 80px;
}
.top_ttl .icn:before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.top_ttl.ver1 .icn:before{
    width: 54px;
    height: 38px;
    background: url(../svg/icon-42.svg) no-repeat center;
    background-size: 100% auto;
}
.top_ttl.ver2 span,
.top_ttl.ver3 span{
    font-size: 16px;
    color: #E40146;
}
/*.top_ttl.ver2 .icn:before{
    width: 54px;
    height: 38px;
    background: url(../svg/icon-43.svg) no-repeat center;
    background-size: 100% auto;
}
.top_ttl.ver3 .icn:before{
    width: 38px;
    height: 40px;
    background: url(../svg/icon-44.svg) no-repeat center;
    background-size: 100% auto;
}*/
.what_wrap {
    padding: 80px 0 100px;
}
.what_cnt{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin: 0 0 68px;
}
.what_box{
    width: -webkit-calc(100% - 312px);
    width: calc(100% - 312px);
    box-sizing: border-box;
}
.what_box .ttl{
    padding: 0 0 24px;
    font-size: 26px;
    line-height: 1;
    font-weight: bold;
    color: #001F6B;
}
.what_box .txt{
    font-size: 18px;
    line-height: 1.8;
}
.what_lst{
    padding: 40px 0 0;
}
.what_lst .point{
    padding: 0 0 20px;
    font-size: 16px;
    line-height: 1;
    font-weight: bold;
    color: #e40146;
}
.what_lst .lst li{
    font-size: 22px;
    line-height: 1;
    font-weight: bold;
    color: #434343;
    margin-bottom: 16px;
    padding-left: 24px;
    position: relative;
}
.what_lst .lst li:last-child{
    margin-bottom: 0;
}
.what_lst .lst li:before {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background: #E40146;
    border-radius: 50%;
}
.plan_wrap{
    background: #f0f1f5;
    padding: 60px 0 80px;
}
.plan_img{
    background: #fff;
    margin-top: 30px;
    border-radius: 10px;
    text-align: center;
    padding: 45px 0;
}
.faq_wrap{
    padding: 80px 0;
}
.faq_box{
    margin-top: 50px;
}
.faq_box.ver2{
    margin-top: 100px;
}
.faq_q{
    font-size: 24px;
    line-height: 1;
    font-weight: bold;
    padding: 24px 56px;
    background: #FFF5D7;
    border-radius: 10px;
    margin-left: 164px;
    position: relative;
}
.faq_q:after {
    content: "";
    position: absolute;
    top: 50%;
    left: -28px;
    margin-top: -12px;
    border: 12px solid transparent;
    border-right: 16px solid #FFF5D7;
}
.faq_q:before {
    content: "";
    display: block;
    width: 120px;
    height: 120px;
    position: absolute;
    left: -164px;
    top: 50%;
    transform: translateY(-50%);
}
.faq_q.ver1:before{
    background: url(../img/faq_icn01.png?date=2) no-repeat center;
    background-size: 100% auto;
}
.faq_q.ver2:before{
    background: url(../img/faq_icn02.png?date=) no-repeat center;
    background-size: 100% auto;
}
.faq_q.ver3:before{
    background: url(../img/faq_icn01.png?date=) no-repeat center;
    background-size: 100% auto;
}
.faq_ans{
    margin-top: 60px;
    padding: 48px 40px 40px;
    background: #F0F1F5;
    border-radius: 10px;
    position: relative;
    box-sizing: border-box;
    margin-right: 170px;
}
.faq_ans:after {
    content: "";
    position: absolute;
    top: 50px;
    left: 100%;
    border: 12px solid transparent;
    border-left: 16px solid #F0F1F5;
}
.faq_ans:before {
    content: "";
    display: block;
    width: 120px;
    height: 120px;
    position: absolute;
    right: -170px;
    top: 0;
    background: url(../img/faq_icn03.png?date=2) no-repeat center;
    background-size: 100% auto;
}
.faq_ans .txt dt{
    font-size: 24px;
    line-height: 1;
    font-weight: bold;
    color: #e40046;
    margin-bottom: 20px;
}
.faq_ans .txt dd{
    font-size: 15px;
    line-height: 2;
    color: #434343;
    font-feature-settings: "palt";
    -webkit-font-feature-settings: "palt";
}
.faq_dtl{
    margin-top: 40px;
    border: 2px solid #001f6b;
    padding: 40px 54px;
}
.faq_dtl .mds{
    border-left: 6px solid #001f6b;
    padding-left: 20px;
    font-size: 26px;
    line-height: 1.4;
    font-weight: bold;
    color: #001f6b;
}
.faq_dtl .mds span {
    font-size: 14px;
    vertical-align: top;
    padding-left: .5em;
}
.faq_dtl .txt{
    font-size: 16px;
    line-height: 1.4;
    color: #001f6b;
    padding: 20px 0 50px;
}
.faq_dtl .img{
    margin: 25px 0 0;
    text-align: center;
}
.faq_dtl.ver2{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.faq_dtl.ver2 .box{
    width: 50%;
}
.faq_dtl.ver2 .box:last-child{
    width: 100%;
    margin-top: 50px;
}
.faq_dtl.ver3 .img{
    margin: 0 -54px;
    text-align: center;
}
.faq_add {
    margin-top: .5em;
}
.faq_add li{
    font-size: 14px;
    color: #434343;
    position: relative;
    padding-left: 2.5em;
}
.faq_add.ver2 li{
    padding-left: 1.5em;
}
.faq_add li span{
    position: absolute;
    top: 0;
    left: 0;
}
.what_movie {
    padding: 30px 0 68px;
}
.top_movie {
    padding: 82px 0 84px;
}
.gltdBtn_wrap{
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    max-width: 1110px;
    margin: 0 auto;
    box-sizing: border-box;
}
.gltdBtn-btn{
    width: 502px;
}
@media (min-width: 896px) {
    .gltdBtn-btn {
        margin-top: 40px;
        margin-right: 50px;
    }
    .gltdBtn-btn:nth-child(-n+2) {
        margin-top: 0;
    }
    .gltdBtn-btn:nth-child(2n) {
        margin-right: 0;
    }
    .faq_ans{
        min-height: 194px;
    }
    .mv_wrap {
        width: 1140px;
        margin: 0 auto;
    }
}
@media (max-width: 896px) {
    .top_ttl{
        font-size: 18px;
    }
    .top_ttl .icn{
        padding-left: 30px;
    }
    .top_ttl.ver2 span,
    .top_ttl.ver3 span {
        font-size: 12px;
        color: #E40146;
    }
    .top_ttl.ver1 .icn:before{
        width: 22px;
        height: 16px;
    }
    .what_wrap {
        padding: 35px 12px 40px;
    }
    .what_cnt{
        display: block;
        padding: 0;
        margin: 0 0 30px;
    }
    .what_box{
        width: 100%;
    }
    .what_box .ttl{
        padding: 0 0 15px;
        font-size: 18px;
    }
    .what_box .txt{
        font-size: 13px;
        line-height: 1.6;
        width: 100%;
        box-sizing: border-box;
        padding-top: 20px;
    }
    .what_box .box {
        display: block;
    }
    .what_box .img {
        text-align: center;
    }
    .what_lst{
        padding: 20px 0 0;
    }
    .what_lst .point{
        padding: 0 0 10px;
        font-size: 18px;
    }
    .what_lst .lst li{
        font-size: 13px;
        line-height: 1.2;
        padding-left: 20px;
        margin-bottom: 8px;
    }
    .what_lst .lst li:before {
        width: 10px;
        height: 10px;
        top: 8px;
    }
    .plan_wrap{
        padding: 40px 12px;
    }
    .plan_img{
        margin-top: 20px;
        border-radius: 5px;
        padding: 12px 10px 20px;
        text-align: center;
    }
    .faq_wrap{
        padding: 30px 12px;
    }
    .faq_box{
        margin-top: 20px;
    }
    .faq_box.ver2{
        margin-top: 60px;
    }
    .faq_q{
        font-size: 13px;
        line-height: 1.4;
        padding: 15px 12px;
        border-radius: 5px;
        margin-left: 95px;
    }
    .faq_q:after {
        left: -13px;
        margin-top: -6px;
        border: 6px solid transparent;
        border-right: 8px solid #FFF5D7;
    }
    .faq_q:before {
        width: 75px;
        height: 75px;
        left: -95px;
    }
    .faq_ans{
        margin-top: 30px;
        padding: 15px 12px;
        border-radius: 5px;
        background: #F0F1F5;
        margin-right: 92px;
    }
    .faq_ans:after {
        top: 44px;
        border: 6px solid transparent;
        border-left: 8px solid #F0F1F5;
    }
    .faq_ans:before {
        width: 75px;
        height: 75px;
        right: -92px;
        background: url(../img/sp/faq_icn03.png?date=2) no-repeat center;
        background-size: 100% auto;
    }
    .faq_ans .txt dt{
        font-size: 13px;
        line-height: 1.4;
        margin-bottom: 8px;
    }
    .faq_ans .txt dd{
        font-size: 13px;
        line-height: 1.4;
    }
    .faq_dtl{
        margin-top: 20px;
        border: 1px solid #001f6b;
        padding: 20px 10px;
    }
    .faq_dtl .mds{
        border-left: 3px solid #001f6b;
        padding-left: 12px;
        font-size: 15px;
        line-height: 1.4;
    }
    .faq_dtl .mds span {
        font-size: 10px;
    }
    .faq_dtl .txt{
        font-size: 13px;
        line-height: 1.4;
        padding: 14px 0 18px;
    }
    .faq_dtl .img{
        text-align: center;
    }
    .faq_dtl.ver2{
        display: block;
    }
    .faq_dtl.ver2 .box{
        width: 100%;
        margin-top: 30px;
    }
    .faq_dtl.ver2 .box:first-child{
        margin-top: 0;
    }
    .faq_dtl.ver2 .box:last-child{
        width: 100%;
        margin-top: 30px;
    }
    .faq_dtl.ver1 .img{
        margin: 15px 0 0;
    }
    .faq_dtl.ver2 .img{
        margin: 15px 0 0;
    }
    .faq_dtl.ver3 .img{
        margin: 0;
        text-align: center;
    }
    .faq_add {
        margin-top: .8em;
    }
    .faq_add li{
        font-size: 12px;
        color: #434343;
        position: relative;
        padding-left: 1.8em;
    }
    .faq_add.ver2 li{
        padding-left: 1.8em;
    }
    .what_movie {
        padding: 20px 0 30px;
    }
    .top_movie {
        padding: 40px 20px;
    }
    .gltdBtn-btn{
        width: 100%;
        max-width: 290px;
        margin: 0 auto;
        margin-top: 20px;
    }
    .gltdBtn-btn:first-child{
        margin-top: 0;
    }
    .last_btn {
        margin: 0 20px;
    }
}
@media (max-width: 374px) {
    .what_box .ttl {
        font-size: 16px;
    }
    .faq_dtl .mds {
        font-size: 16px;
    }
    .faq_ans .txt dt {
        font-size: 15px;
    }
    .plan_img source,
    .plan_img img {
        width: 100%;
        height: auto;
    }
    .faq_dtl .img source,
    .faq_dtl .img img{
        width: 100%;
        height: auto;
    }
}

/* 20240304 */
.fresh_pamphlet_img {
    position: relative;
    border: 1px solid #ccc;
    display: inline-block;
}

.fresh_pamphlet_img::after {
    position: absolute;
    content: "";
    background-image: url(../img/magnifying-glass_pc.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    width: 62px;
    height: 62px;
    display: block;
    bottom: 0;
    right: 0;
}

.faq_dtl_ver1_flex {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    flex-wrap: nowrap;
}

.faq_dtl_ver1_flex__txt {
    /* font-size: 130px; */
    font-size: clamp(60px, 9.02777vw, 130px);
    font-family: "Lato", sans-serif;
    font-weight: bold;
    line-height: 1;
    align-items: baseline;
    /* letter-spacing: -0.06em; */
    color: #e40046;
    display: flex;
    margin: 0;
    flex-wrap: nowrap;
    margin: 25px 0 0;
}

.faq_dtl_ver1_flex__txt span {
    /* font-size: 50px; */
    /* font-size: clamp(20px, 3.47222vw, 50px); */
    font-size:  min(2.77vw, 40px);
    font-weight: bold;
    font-family: ＭＳ Ｐゴシック, Osaka, ヒラギノ角ゴ Pro W3;
    color: #001f6b;
    display: flex;
    flex-wrap: nowrap !important;
    letter-spacing: -0.02em;
}

.faq_dtl_ver2__txt {
    /* font-size: 130px; */
    /* font-size: clamp(60px, 9.02777vw, 130px); */
    font-size:  min(7.22vw, 104px);
    font-family: "Lato", sans-serif;
    line-height: 1;
    font-weight: bold;
    color: #e40046;
    display: flex;
    align-items: baseline;
    margin: 0;
    flex-wrap: nowrap;
    margin: 25px 0 0;
}

.faq_dtl_ver2__txt span {
    /* font-size: 50px; */
    /* font-size: clamp(20px, 3.47222vw, 50px); */
    font-size:  min(2.77vw, 40px);
    font-family: ＭＳ Ｐゴシック, Osaka, ヒラギノ角ゴ Pro W3;
    color: #001f6b;
    display: block;
    flex-wrap: nowrap !important;
}

.faq_dtl_ver2__vertical {
    writing-mode: vertical-rl;
}

.fresh_wrap {
    padding-top: 40px;
}

.fresh_flex {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 20px;
}

.fresh_flex:nth-of-type(n + 2) {
    margin-top: 40px;
    padding-top: 40px;
    border-top: 2px solid #001F6B;
}

.fresh_flex__age {
    font-weight: 600;
    color: #001F6B;
    border: 2px solid #001F6B;
    border-radius: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    width: 170px;
    height: 36px;
}

.fresh_flex__age span {
    font-size: 24px;
    font-family: "Lato", sans-serif;
    line-height: 1;
    padding-right: 3px;
}

.fresh_flex__cost {
    font-size: 24px;
    font-weight: bold;
    color: #001F6B;
    line-height: 1;
    padding-top: 10px;
}

.fresh_flex__cost span {
    font-size: 40px;
    font-family: "Lato", sans-serif;
    color: #E40146;
}

.fresh_flex__cost small {
    font-size: 24px;
    padding-left: 5px;
}

.fresh_flex__dsc {
    font-weight: bold;
    color: #001F6B;
    padding-top: 5px;
}

.fresh_flex__dsc span {
    font-family: "Lato", sans-serif;
    color: #E40146;
}

.fresh_flex__txt {
    font-size: 22px;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
    letter-spacing: 0.02em;
    color: #fff;
    background: #E40146;
    border-radius: 5px;
    padding: 10px;
    margin-top: 10px;
}

@media (max-width: 896px) {

    .fresh_pamphlet_img {
        display: block;
        margin: 0 auto;
        width: 230px;
    }

    .fresh_pamphlet_img::after {
        background-image: url(../img/sp/magnifying-glass_sp.png);
    }

    .faq_dtl_ver1_flex {
        flex-direction: column;
        gap: 0;
    }

    .faq_dtl_ver1_flex__txt {
        /* font-size: 80px; */
        font-size: max(17.33vw, 65px);
        margin-top: 0;
        white-space: nowrap;
    }

    .faq_dtl_ver1_flex__txt span {
        /* font-size: 40px; */
        font-size: max(6.4vw, 24px);
    }

    .faq_dtl_ver2__txt {
        /* font-size: 80px; */
        font-size: max(14.66vw, 55px);
        justify-content: center;
    }

    .faq_dtl_ver2__txt span {
        /* font-size: 28px; */
        font-size: max(5.33vw, 20px);
    }

    .fresh_flex {
        gap: 10px;
    }

    .fresh_flex__age {
        width: 90px;
        height: 18px;
        font-size: 10px;
        padding-top: 2px;
        border: 1px solid #001F6B;
    }

    .fresh_flex__age span {
        font-size: 16px;
    }

    .fresh_flex__cost {
        font-size: 14px;
        padding-top: 4px;
    }

    .fresh_flex__cost span {
        font-size: 20px;
        letter-spacing: -0.02em;
    }

    .fresh_flex__cost small {
        font-size: 14px;
    }

    .fresh_flex__dsc {
        font-size: 10px;
        letter-spacing: -0.06em;
        padding-top: 3px;
    }

    .fresh_flex__dsc span {
        font-weight: bold;
    }

    .fresh_flex__txt {
        font-size: 11px;
        padding: 5px;
        margin-top: 5px;
    }

    .fresh_flex:nth-of-type(n + 2) {
        margin-top: 20px;
        padding-top: 20px;
        border-top: 1px solid #001F6B;
    }
}

