@charset "utf-8";

.site_header {
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
}

.site_header.fade-in {
    opacity: 1;
}

.mv {
    width: 100%;
    height: 100vh !important;
    min-height: 750px;
    position: relative;
}

@media screen and (min-width: 600px) {
    .mv {
        height: min(216.74vw, 932px);
    }
}

@media screen and (min-width: 920px) {
    .mv {
        height: 56.25vw;
    }
}

.mv_slider,
.mv_slider .swiper,
.mv_slider .swiper-wrapper,
.mv_slider .swiper-slide {
    width: 100%;
    height: 100%;
}

.mv_slider {
    position: relative;
    overflow: hidden;
}

.mv_slider::before {
    content: "";
    position: absolute;
    background: rgb(4, 40, 59);
    background: linear-gradient(0deg, rgba(4, 40, 59, 1) 0%, rgba(255, 255, 255, 1) 100%);
    opacity: 0.44;
    mix-blend-mode: multiply;
    width: 100%;
    height: min(85.58vw, 368px);
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2;
}

@media screen and (min-width: 920px) {
    .mv_slider::before {
        content: none;
    }
}

.mv_slider::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: white;
    opacity: 0;
    z-index: 1;
    transition: opacity 0.5s ease-in-out;
    pointer-events: none;
}

.mv_slider .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: scale(1.2);
    /* 初期は120% */
    transition: transform 10s linear;
    /* 2秒かけて縮小 */
}

/* スライドの切り替え時に縮小 */
.mv_slider .swiper-slide-active img {
    transform: scale(1.0);
}

.mv_movie {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
    z-index: -1;
    position: fixed;
}

@media screen and (min-width: 600px) {
    .mv_movie {
        padding-top: 56.25%;
    }
}

@media screen and (min-width: 600px) {
    .mv_movie-sp {
        display: none;
    }
}

.mv_movie-pc {
    display: none;
}

@media screen and (min-width: 600px) {
    .mv_movie-pc {
        display: block;
    }
}

.mv_movie video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media screen and (min-width: 600px) {
    .mv_movie video {
        height: 100%;
        position: absolute;
        top: 0px;
        left: 0px;
        object-position: center;
    }
}

.mv_inr {
    display: flex;
    flex-direction: column;
    align-items: center;
    /* gap: 9.285714285714286vw; */
    /* gap: 122px; */
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 39.487179vw;
    width: 100%;
    opacity: 0;
    z-index: 100;
    transition: opacity 0.8s ease-in-out;
}


.mv_inr.fade-in {
    opacity: 1;
}

@media screen and (min-width: 920px) {
    .mv_inr {
        position: absolute;
        bottom: 8.142857142857144vw;
        width: 100%;
        gap: 122px;
    }
}

.mv_catch {
    /* display: block;
    width: min(30.46vw, 131px);
    height: min(88.37vw, 380px);
    position: absolute;
    z-index: 100;
    top: 14%;
    right: 50%;
    translate: 50% 0;
    opacity: 0; */
    transition: opacity 0.8s ease-in-out;
    margin-bottom: 24px;
}

@media screen and (min-width: 920px) {
    .mv_catch {
        margin-bottom: 0;
    }
}

.mv_catch.fade-in {
    opacity: 1;
}

.mv_catch_top {
    font-size: 22px;
    font-weight: 400;
    color: #fff;
    font-family: "EB Garamond", serif;
    text-align: center;
}

@media screen and (min-width: 920px) {
    .mv_catch_top {
        font-size: 24px;
    }
}

.mv_catch_bottom {
    font-size: 14px;
    font-weight: 400;
    color: #fff;
    font-family: "EB Garamond", serif;
    text-align: center;
    line-height: 1.75;
}

@media screen and (min-width: 920px) {
    .mv_catch_bottom {
        font-size: 16px;
    }
}

.mv_logo {
    width: fit-content;
    display: flex;
    flex-direction: column;
    align-items: center;
    /* position: absolute; */
    z-index: 100;
    /* opacity: 0; */
    transition: opacity 0.8s ease-in-out;
    margin-bottom: 124px;
}

@media screen and (min-width: 920px) {
    .mv_logo {
        margin-bottom: 0;
    }
}

.mv_logo_img {
    display: block;
    width: 324px;
}

@media screen and (min-width: 920px) {
    .mv_logo_img {
        width: 594px;
    }
}

.mv_logo_img img {
    width: 100%;
    height: 100%;
}

.mv_logo_date {
    font-family: var(--font-catch);
    line-height: 1;
    letter-spacing: 0.08em;
    color: #ffffff;
}

@media screen and (min-width: 920px) {
    .mv_logo_date {
        font-size: 1.302vw;
    }
}

.mv_logo.fade-in {
    opacity: 1;
}



.play-btn {
    display: none;
}

@media screen and (min-width: 920px) {
    .play-btn {
        width: fit-content;
        height: auto;
        display: flex;
        align-items: center;
        gap: 9px;
        position: absolute;
        bottom: 13px;
        left: 19px;
        bottom: min(2.343vw, 45px);
        left: min(3.02083vw, 58px);
    }
}

.play-btn_circle {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #ffffff;
    border-radius: 4px;
}

.play-btn_circle_tri {
    width: 12px;
    height: 12px;
    display: flex;
    position: relative;
    margin-right: -2px;
}

.play-btn_circle_tri img {
    width: 100%;
    height: 100%;
}

.play-btn_text {
    font-family: "Lato", sans-serif;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #ffffff;
    margin-top: 2px;
}

@media screen and (min-width: 920px) {
    .play-btn_text {
        font-size: 14px;
    }
}

.play-btn_sp {
    width: fit-content;
    height: auto;
    display: flex;
    align-items: center;
    gap: 9px;
}

@media screen and (min-width: 920px) {
    .play-btn_sp {
        display: none;
    }
}



.introduction {
    width: 100%;
    height: auto;
    position: relative;
    padding: 203px 0 238px;
    margin-top: 200px;
    background: rgba(30, 30, 30, 0.8);
}

@media screen and (min-width: 920px) {
    .introduction_body {
        padding: 0 223px 0 142px;
    }
}



.introduction::before {
    position: absolute;
    content: "";
    background: url(../img/home/introduction_top.svg);
    left: 0;
    top: -200px;
    width: 100%;
    height: 200px;
}

.introduction_body {
    display: flex;
    flex-direction: column;
    padding: 0 20px;
}

@media screen and (min-width: 920px) {
    .introduction_body {
        padding: 0 min(15.928571428571429vw, 223px) 0 min(10.142857142857142vw, 142px);
        max-width: 1400px;
        margin: 0 auto;
        flex-direction: row;
        justify-content: space-between;
    }
}

.plan {
    background-color: #FFFFFF;
    padding: 131px 0 161px;
    overflow: hidden;
}

@media screen and (min-width: 920px) {
    .plan {

        padding: 173px 0 161px;
    }
}

.plan_text {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

@media screen and (min-width: 920px) {
    .plan_text {
        gap: 40px;
    }
}

.plan_text p {
    font-size: min(4.102564102564102vw, 16px);
    font-weight: 500;
    text-align: center;
    line-height: 2;
    letter-spacing: -0.065em;
}

@media screen and (min-width: 920px) {
    .plan_text p {
        font-size: 24px;
        letter-spacing: 0.05em;
    }
}

.plan_slider {
    margin: 58px 0 122px;
}

@media screen and (min-width: 920px) {
    .plan_slider {
        margin: 48px 0 162px;
    }
}

.plan_slider .swiper {
    overflow: visible;
}

.plan_slider .swiper-slide {
    width: 76.92307692307693vw;
}

@media screen and (min-width: 920px) {
    .plan_slider .swiper-slide {
        width: 61.42857142857143vw;
    }
}

.plan_slider_item {
    position: relative;
    display: block;
    overflow: hidden;
    width: 100%;
    height: auto;
}

/* .plan_slider_item_preparation {
    pointer-events: none;
} */

.plan_slider_img {
    width: 100%;
    height: auto;
}

.plan_slider_item img {
    transition: transform 0.3s ease;
}

.plan_slider_item:hover img {
    transform: scale(1.08);
}

.plan_slider_item_top {
    position: absolute;
    font-size: 32px;
    top: 24px;
    left: 20px;
    font-family: "EB Garamond", serif;
    line-height: 1.25;
    letter-spacing: -0.025em;
}

@media screen and (min-width: 920px) {
    .plan_slider_item_top {
        font-size: min(3vw, 42px);
        line-height: 1;
        top: 24px;
        left: 24px;
    }
}

.plan_slider_item_top.white {
    color: #fff;
}

.plan_slider_item_bottom {
    position: absolute;
    bottom: 64px;
    left: 20px;
}

@media screen and (min-width: 920px) {
    .plan_slider_item_bottom {
        bottom: 37px;
        left: 31px;
    }
}

.plan_slider_item_bottom_en {
    font-size: min(7.6923076923076925vw, 30px);
    color: #fff;
    font-family: "EB Garamond", serif;
    line-height: 1;
    margin-bottom: 6px;
    white-space: nowrap;
}

@media screen and (min-width: 920px) {
    .plan_slider_item_bottom_en {
        font-size: min(6.142857142857143vw, 86px);
    }
}

.plan_slider_item_bottom_ja {
    font-size: 20px;
    font-weight: 600;
    color: #fff;
    line-height: 1;
}

@media screen and (min-width: 920px) {
    .plan_slider_item_bottom_ja {
        font-size: min(2vw, 28px);
    }
}

.plan_slider_item_bottom_ja span {
    font-size: 28px;
}

@media screen and (min-width: 920px) {
    .plan_slider_item_bottom_ja span {
        font-size: min(2.857142857142857vw, 40px);
    }
}






.plan_slider_nav {
    display: none;
}

@media screen and (max-width: 920px) {
    .plan_slider_nav {
        display: flex;
        align-items: center;
        gap: 8px;
        margin-top: 22px;
    }

    .plan_slider_progress {
        flex-grow: 1;
        height: 4px;
        background-color: #e0e0e0;
        position: relative;
        overflow: hidden;
        border-radius: 2px;
        margin-right: 14px;
    }

    .plan_slider_progress::before {
        content: "";
        position: absolute;
        height: 100%;
        width: var(--progress-width, 0%);
        background-color: #000;
        transition: width 0.3s ease;
        border-radius: 2px;
    }

    .plan_slider_button_prev,
    .plan_slider_button_next {
        flex-shrink: 0;
        cursor: pointer;
        width: 40px;
        height: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .plan_slider_button_prev img,
    .plan_slider_button_next img {
        width: 100%;
        height: auto;
    }
}






.detail_box {
    position: absolute;
    bottom: 0;
    right: 0;
    background-color: #1E1E1E;
    padding: 9px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

@media screen and (min-width: 920px) {
    .detail_box {
        width: 198px;
        padding: 12px 16px;
    }
}

.detail_box span {
    color: #fff;
    font-size: 16px;
    font-weight: 600;
}

@media screen and (min-width: 920px) {
    .detail_box span {
        font-size: 18px;
    }
}

.cursor-stalker {
    display: none;
}

@media screen and (min-width: 920px) {
    .cursor-stalker {
        position: fixed;
        top: 0;
        left: 0;
        width: 120px;
        height: 120px;
        border-radius: 50%;
        backdrop-filter: blur(6px);
        pointer-events: none;
        transform: translate(-50%, -50%);
        z-index: 9999;
        opacity: 0;
        transition: opacity 0.5s ease;
        display: flex;
        gap: 10px;
        align-items: center;
        justify-content: center;
    }

    .cursor-stalker span {
        font-size: 16px;
        color: #fff;
    }
}

.point {
    margin-top: 100vh;
    padding: 82px 0 120px;
    background-color: #F2F2F2;
}

@media screen and (min-width: 920px) {
    .point {
        padding: 134px 0 240px;
    }
}

.introduction_body_catch {
    font-size: 24px;
    font-weight: 500;
    color: #fff;
    writing-mode: vertical-rl;
    width: fit-content;
    margin: 0 auto 108px;
    line-height: 1.65;
}

@media screen and (min-width: 920px) {
    .introduction_body_catch {
        font-size: min(2.571428571428571vw, 36px);
        writing-mode: unset;
        margin: 0;
    }
}

.introduction_body_text {
    padding: 0 10px;
}

@media screen and (min-width: 920px) {
    .introduction_body_text {
        padding: 0;
    }
}

.introduction_body_text_inr {
    font-size: min(4.102564102564102vw, 16px);
    font-weight: 500;
    color: #fff;
    margin-bottom: 78px;
    line-height: 2;
}

@media screen and (min-width: 920px) {
    .introduction_body_text_inr {
        font-size: min(1.2307692307692308vw, 16px);
    }
}

.introduction_body_text_inr:first-child {
    margin-bottom: 24px;
}

.introduction_body_text .innerLink {
    background-image: linear-gradient(to right, #fff, #fff);
    width: fit-content;
    margin: 0 auto;
    color: #fff;
    font-size: 18px;
    padding-bottom: 7px;
}

@media screen and (min-width: 920px) {
    .introduction_body_text .innerLink {
        background-image: linear-gradient(to right, #fff, #fff);
        width: fit-content;
        margin: 0 0 0 auto;
        font-size: min(1.6666666666666667vw, 20px);
        gap: 20px;

    }

}

.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.modal.show {
    opacity: 1;
    visibility: visible;
}

#modal .modal_text {
    line-height: 2;
    font-family: var(--font-serif);
}

.modal-content {
    background: rgba(255, 255, 255, 0.8);
    padding: 80px 50px 60px;
    border-radius: 8px;
    width: 100%;
    position: relative;
    max-width: 358px;
    height: 53vh;
}

@media screen and (min-width: 920px) {
    .modal-content {
        padding: 124px 146px 100px;
        position: relative;
        max-width: 791px;
        height: 61.979166666666664vh;
    }

}

.modal-content,
.no-scroll {
    height: auto;
}



.point_body {
    display: none;
}

@media screen and (min-width: 920px) {
    .point_body {
        display: flex;
        flex-direction: column;
        gap: 20px;
        margin-top: 40px;
    }
}

.point_body .point_body_item {
    overflow: hidden;
    border-radius: 8px;
    display: flex;
}

.point_body .point_body_item_text {
    background-color: #FFFFFF;
    padding: min(6.666666666666667vw, 80px) min(6.666666666666667vw, 80px) min(6.666666666666667vw, 80px) min(7.583333333333334vw, 91px);
    width: 58.82%;
}

.point_body .point_body_item_text_en {
    font-size: 80px;
    /* margin-bottom: 24px; */
    font-family: "EB Garamond", serif;
}

@media screen and (min-width: 920px) {
    .point_body .point_body_item_text_en {
        font-size: min(5.714285714285714vw, 80px);
    }
}

.point_body .point_body_item_text_top {
    font-size: min(2.3333333333333335vw, 28px);
    font-weight: 600;
    margin-bottom: 12px;
}

.point_body .point_body_item_text_bottom {
    font-size: min(1.8181818181818181vw, 20px);
    font-weight: 500;
}

.point_body .point_body_item_slide {
    overflow: hidden;
    height: 540px;
    width: 41.18%;
}

.point_body .point_body_item_slide .swiper-wrapper {
    transition-timing-function: linear;
}

.point_body .point_body_item_slide .swiper-slide {
    width: auto;
}

.point_body .point_body_item_slide .swiper-slide img {
    width: 100%;
}


.point_body_sp {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 60px;
    align-items: stretch;
}

@media screen and (min-width: 920px) {
    .point_body_sp {
        display: none;
    }
}

.point_body_sp .point_body_item {
    display: flex;
    align-items: flex-start;
}

.point_body_sp .point_body_item_top {
    font-size: 18px;
    font-weight: 600;
    padding: 30px 16px 17px;
    text-align: right;
}

.point_body_sp .point_body_item_text {
    font-size: 14px;
    font-weight: 500;
    padding: 20px 24px 51px 65px;
}

.point_body_sp .point_body_item_en {
    font-size: 52px;
    color: #000;
    writing-mode: vertical-rl;
    margin-right: -28px;
    line-height: 1;
    position: relative;
    z-index: 2;
    margin-top: 16px;
    letter-spacing: -0.025em;
}

.point_body_sp .point_body_item_inr {
    background-color: #fff;
    border-radius: 8px;
    overflow: hidden;
}

.point_body_sp .point_body_item_text_top {
    font-size: 20px;
    font-weight: 500;
    position: relative;
    z-index: 1;
}

.point_body_sp .point_body_item_slide {
    overflow: hidden;
    height: 200px;
}

.point_body_sp .point_body_item_slide .swiper-wrapper {
    transition-timing-function: linear;
}

.point_body_sp .point_body_item_slide .swiper-slide {
    width: auto;
}

.point_body_sp .point_body_item_slide .swiper-slide img {
    width: auto;
    height: 200px;
}











.explanation_btn {
    position: relative;
    overflow: hidden;
    display: block;
    width: 100%;
    padding: 40px 25px;
    color: white;
    text-decoration: none;
    z-index: 0;
}

@media screen and (min-width: 920px) {
    .explanation_btn {
        padding: 106px 140px;
    }
}

.explanation_btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url(../img/home/explanation_background-sp.jpg);
    background-image: image-set(url(../img/home/explanation_background-sp.jpg) 1x,
            url(../img/home/explanation_background-sp@2x.jpg) 2x);
    background-image: -webkit-image-set(url(../img/home/explanation_background-sp.jpg) 1x,
            url(../img/home/explanation_background-sp@2x.jpg) 2x);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    transition: transform 0.3s ease;
    z-index: 0;
}

@media screen and (min-width: 920px) {
    .explanation_btn::before {
        background-image: url(../img/home/explanation_background.jpg);
        background-image: image-set(url(../img/home/explanation_background.jpg) 1x,
                url(../img/home/explanation_background@2x.jpg) 2x);
        background-image: -webkit-image-set(url(../img/home/explanation_background.jpg) 1x,
                url(../img/home/explanation_background@2x.jpg) 2x);
    }
}

.explanation_btn_inr {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;
    position: relative;
    z-index: 1;
    margin: 0 auto;
}

@media screen and (min-width: 920px) {
    .explanation_btn_inr {
        gap: 32px;
        margin: 0;
    }
}

.explanation_btn_inr_wrap {
    max-width: 1400px;
    margin: 0 auto;
}

.explanation_btn_box {
    padding: 8px min(5.128205128205128vw, 20px) 12px;
    border: 1px solid #1E1E1E;
    width: 100%;
    text-align: center;
    margin-bottom: 18px;
}

@media screen and (min-width: 920px) {
    .explanation_btn_box {
        width: fit-content;
        padding: 22px 18px 17px;
        border: 1px solid #fff;
        margin-bottom: 0;
    }
}

.explanation_btn_box_en {
    font-size: min(5.128205128205128vw, 20px);
    font-weight: 600;
    color: #1E1E1E;
}

@media screen and (min-width: 920px) {
    .explanation_btn_box_en {
        color: #fff;
        font-size: 16px;
    }
}



.explanation_btn_box_ja {
    font-size: min(10.256410256410255vw, 40px);
    font-weight: 600;
    text-align-last: justify;
    color: #1E1E1E;
    line-height: 1;
    letter-spacing: -0.075em;
}

@media screen and (max-width: 385px) {
    .explanation_btn_box_ja {
        font-size: 32px;
        font-weight: 600;
        text-align-last: justify;
        color: #1E1E1E;
        line-height: 1;
        letter-spacing: -0.075em;
        /* white-space: nowrap; */

    }
}

@media screen and (min-width: 920px) {
    .explanation_btn_box_ja {
        font-size: 60px;
        letter-spacing: -0.15em;
        color: #fff;
        line-height: 1.2;
    }
}

.explanation_btn_text {
    text-align: center;
    font-size: 14px;
    font-weight: 400;
    color: #1E1E1E;
    line-height: 1.5;
    margin-bottom: 250px;
}

@media screen and (min-width: 920px) {
    .explanation_btn_text {
        font-size: 18px;
        color: #fff;
        margin-bottom: 0;
    }
}

.explanation_btn_circle {
    border-radius: 999px;
    background-color: #FFFFFF;
    padding: 9px 24px;
    transition: background-color 0.3s ease;
}

.explanation_btn_circle_text {
    font-size: 18px;
    transition: color 0.3s ease;
    color: #000000;
}

.explanation_btn:hover::before {
    transform: scale(1.08);
}

.explanation_btn:hover .explanation_btn_circle {
    background-color: #000000;
}

.explanation_btn:hover .explanation_btn_circle_text {
    color: #fff;
}

.cooperation {
    background-color: #F2F2F2;
    padding: 114px 0 120px;
}

@media screen and (min-width: 920px) {
    .cooperation {
        padding: 152px 0 162px;
    }
}

.cooperation_body {
    display: flex;
    flex-direction: column;
    gap: 80px;
}

@media screen and (min-width: 920px) {
    .cooperation_body {
        flex-direction: row;
        justify-content: space-between;
        max-width: 785px;
        margin: 0 auto;
    }
}

.cooperation_body_item_top {
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 14px;
}

@media screen and (min-width: 920px) {
    .cooperation_body_item_top {
        font-size: 20px;
        margin-bottom: 30px;
    }
}

.cooperation_body_item {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.cooperation_body_item .logo {
    margin-bottom: 6px;
}

@media screen and (min-width: 920px) {
    .cooperation_body_item .logo {
        margin-bottom: 26px;
    }
}

.cooperation_body_item .logo_margin {
    margin-bottom: 20px;
}

@media screen and (min-width: 920px) {
    .cooperation_body_item .logo_margin {
        margin-bottom: 26px;
    }
}

.cooperation_body_item .company {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 6px;
}

@media screen and (min-width: 920px) {
    .cooperation_body_item .company {
        font-size: 18px;
    }
}

.cooperation_body_item .address {
    font-size: 12px;
    font-weight: 300;
    text-align: center;
    font-family: "roboto", sans-serif;
    margin-bottom: 8px;
}

@media screen and (min-width: 920px) {
    .cooperation_body_item .address {
        font-size: 14px;
    }
}

.innerLink {
    background-image: linear-gradient(to right, #1E1E1E, #1E1E1E);
    background-size: 100% 1px;
    background-position: bottom left;
    background-repeat: no-repeat;
    padding-bottom: 0;
    font-size: 14px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 4px;
}

@media screen and (min-width: 920px) {
    .innerLink {
        font-size: 16px;
    }
}

.innerLink:hover {
    animation: linkLineReverse 0.5s ease forwards;
}



.modalArea {
    display: none;
    position: fixed;
    z-index: 6000;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.modalBg {
    width: 100%;
    height: 100%;
    background-color: rgba(30, 30, 30, 0.9);
}

.modalWrapper {
    width: 100%;
    height: 56.279vw;
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
}

@media screen and (min-width: 920px) {
    .modalWrapper {
        width: min(50vw, 960px);
        height: min(28.125vw, 540px);
    }
}

.modalContents,
.modalContents iframe {
    width: 100%;
    height: 100%;
}

.home_modal_title {
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    line-height: 1.25;
    margin-bottom: 30px;
    letter-spacing: -0.025em;
}

@media screen and (min-width: 920px) {
    .home_modal_title {
        font-size: 24px;
    }
}

.home_modal_top {
    font-size: 16px;
    text-align: center;
    margin-bottom: 12px;
    line-height: 1.75;
    font-weight: 500;
}

@media screen and (min-width: 920px) {
    .home_modal_top {
        font-size: 20px;
        margin-bottom: 16px;
        font-weight: 600;
    }
}

.closeModal {
    width: fit-content;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    position: absolute;
    top: min(4.348vw, 18.7px);
    right: min(4.651vw, 20px);
    cursor: pointer;
}

@media screen and (min-width: 920px) {
    .closeModal {
        flex-direction: row-reverse;
        gap: min(0.781vw, 15px);
        top: min(2.74vw, 52.7px);
        right: min(2.83vw, 54.4px);
    }
}

.closeModal_icon {
    width: min(5.348vw, 23px);
    height: min(5.348vw, 23px);
    display: flex;
    position: relative;
}

@media screen and (min-width: 920px) {
    .closeModal_icon {
        width: min(1.40625vw, 27px);
        height: min(1.40625vw, 27px);
    }
}

.closeModal_icon img {
    width: 100%;
    height: 100%;
}

.closeModal_catch {
    font-size: 9px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #ffffff;
}

@media screen and (min-width: 920px) {
    .closeModal_catch {
        font-size: 11px;
    }
}


.loader {
    width: 100%;
    height: 100vh;
    position: fixed;
    background-color: #000000;
    z-index: 99;
    top: 0;
    left: 0;
}

.fixed_btn {
    display: flex;
    border-radius: 4px;
    box-shadow: 0px 0px 12px 0px #0000004D;
    position: fixed;
    bottom: 24px;
    right: 50%;
    transform: translateX(50%);
    z-index: 50;
    overflow: hidden;
    width: 100%;
    max-width: 340px;
}

@media screen and (min-width: 600px) {
    .fixed_btn {
        display: inline-block;
        border-radius: 8px;
        box-shadow: 0px 0px 12px 0px #0000004D;
        position: fixed;
        bottom: 24px;
        right: 24px;
        z-index: 50;
        overflow: hidden;
        transform: none;
        width: fit-content;
    }
}

.fixed_btn_img img {
    transition: transform 0.3s ease;
    width: 100%;
}

.fixed_btn:hover .fixed_btn_img img {
    transform: scale(1.08);
}

.fixed_btn_img {
    overflow: hidden;
    margin-right: -1px;
}

@media screen and (min-width: 600px) {
    .fixed_btn_img {
        margin: 0;
    }
}


.fixed_btn_text {
    display: flex;
    align-items: center;
    background-color: #1E1E1E;
    padding: 4px 16px;
    width: 100%;
    max-width: 250px;
    justify-content: space-between;
}

@media screen and (min-width: 600px) {
    .fixed_btn_text {
        padding: 10px;
        max-width: none;
    }
}

.fixed_btn_text span {
    font-size: 18px;
    color: #fff;
    line-height: 1.5;
}

@media screen and (min-width: 600px) {
    .fixed_btn_text span {
        font-size: 16px;
        line-height: 1.5;
    }
}
