ul,
ol {
    list-style: none;
}

a {
    text-decoration: none;
    color: inherit;
}
section {
    overflow: hidden;
    width: 100%;
}

.main::after {
    width: 1vw;
    height: 0vw;
    position: absolute;
    top: 0;
    pointer-events: none;
    opacity: 0;
    pointer-events: none;
}
.clearfix::after,
.clearfix::before {
    display: block;
    clear: both;
    content: "";
}

@keyframes marqueeY {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(100%);
    }
}

@keyframes marquee {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-50%);
    }
}
@keyframes marquee2 {
    from {
        transform: translateX(-50%);
    }
    to {
        transform: translateX(0);
    }
}
@keyframes slick-circle {
    0% {
        left: 0;
    }
    100% {
        left: 99%;
    }
}
@keyframes soul_out {
    0% {
        opacity: 0.7;
    }
    100% {
        opacity: 0;
        transform: translateY(-50%);
    }
}
@keyframes ddm3 {
    0% {
        transform: scale(1);
    }
    50% {
        transform: rotate(-8deg);
    }
    65% {
        transform: scale(1.1);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes ddm4 {
    0% {
        transform: scale(1);
    }
    25% {
        transform: rotate(-2deg);
    }
    50% {
        transform: scale(1.05);
    }
    75% {
        transform: rotate(2deg);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes rotate_image1 {
    0% {
        transform: rotate(0);
    }
    100% {
        transform: rotate(360deg);
    }
}
@keyframes ani_scale {
    0% {
        transform: scale(1);
    }
    50% {
        transform: matrix(1.1, 0.01, 0.01, 1.2, 0, 0);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes zoom {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.02);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes blk {
    0% {
        opacity: 0;
    }
    30% {
        opacity: 0;
    }
    31% {
        opacity: 1;
    }
    99% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}
@keyframes blk2 {
    0% {
        opacity: 0;
    }
    49% {
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    99% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}
@keyframes blk3 {
    0% {
        opacity: 1;
    }
    24% {
        opacity: 1;
    }
    25% {
        opacity: 0;
    }
    99% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
@keyframes rotate_image {
    100% {
        transform: rotate(360deg);
    }
}
@keyframes scaleOpa {
    0% {
        transform: scale(0.5);
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        transform: scale(1);
        opacity: 0;
    }
}

@keyframes scaleOpa2 {
    0% {
        transform: scale(1);
        opacity: 0;
    }
    20% {
        opacity: 0.4;
    }
    100% {
        transform: scale(1.2);
        opacity: 0;
    }
}
@keyframes ball {
    0% {
        bottom: 0px;
    }
    100% {
        bottom: 20px;
    }
}
@keyframes ddm {
    0% {
        transform: scale(1);
    }
    50% {
        transform: matrix(1.05, 0.01, 0.01, 1.05, 0, -30);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes ddm_m {
    0% {
        transform: scale(1);
    }
    50% {
        transform: matrix(1.05, 0.01, 0.01, 1.05, 0, -15);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes ddm_m2 {
    0% {
        transform: scale(1);
    }
    50% {
        transform: matrix(1.15, 0.01, 0.01, 1.15, 0, 30);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes zoom2 {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.1);
    }
    100% {
        transform: scale(1);
    }
}
@keyframes rotate_imageY {
    0% {
        transform: rotateY(0);
    }
    100% {
        transform: rotateY(360deg);
    }
}

@keyframes ddm2 {
    0% {
        transform: scale(1);
    }
    50% {
        transform: translateY(20px);
    }
    75% {
        transform: scale(1.02);
        transform: translateY(10px);
    }
    100% {
        transform: scale(1);
        transform: translateY(0px);
    }
}
@keyframes ddm2X {
    0% {
        transform: scale(1);
    }
    50% {
        transform: translateX(-100%);
    }
    100% {
        transform: scale(1.02);
    }
}
@keyframes ddm2Xhalf {
    0% {
        transform: scale(1);
    }
    50% {
        transform: translateX(-50%);
    }
    100% {
        transform: scale(1.02);
    }
}

@keyframes scaleOpa3 {
    100% {
        transform: scale(1.3);
        opacity: 0;
    }
}
@keyframes uitLineMove {
    0% {
        stroke-dashoffset: 300.292;
    }
    100% {
        stroke-dashoffset: 110;
    }
}

@keyframes hand {
    0% {
        transform: translateY(-0.5%);
    }

    25% {
        transform: translateY(1%);
    }

    50% {
        transform: translate(0.5%, -1%);
    }

    75% {
        transform: translate(1%, 0.5%);
    }

    100% {
        transform: translate(1%, -1%);
    }
}

@keyframes hand2 {
    0% {
        transform: translateY(2%);
    }

    25% {
        transform: translateY(-1%);
    }

    50% {
        transform: translate(-1%, 2%);
    }

    75% {
        transform: translate(2%, 1%);
    }

    100% {
        transform: translateY(2%);
    }
}

@keyframes smoke {
    0% {
        transform: translate(0, 30%) rotate(0);
        opacity: 0.2;
    }
    25% {
        transform: translate(calc(random() * 100vw), 100vh) rotate(50deg) translateX(10px);
        opacity: 1;
    }
    50% {
        transform: translate(calc(random() * 100vw), 100vh) rotate(50deg) translateX(50px);
        opacity: 1;
    }
    75% {
        transform: translate(calc(random() * 100vw), 100vh) rotate(50deg) translateX(50px);
        opacity: 1;
    }
    100% {
        transform: translate(calc(random() * 100vw), 200vh) rotate(0) translateX(70px);
        opacity: 0.2;
    }
}

@keyframes light {
    0%,
    31%,
    34%,
    39%,
    42%,
    47% {
        opacity: 0;
    }
    5%,
    30%,
    35%,
    38%,
    43%,
    46% {
        opacity: 0.4;
    }
    50%,
    55%,
    60%,
    67%,
    51%,
    54%,
    68%,
    100% {
        opacity: 1;
    }
    70% {
        opacity: 0.2;
    }
}
@keyframes marqueeX {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-100%);
    }
}
@keyframes marqueeX_r {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(100%);
    }
}
@keyframes marqueeY {
    from {
        transform: translateY(0);
    }
    to {
        transform: translateY(-100%);
    }
}
@keyframes marqueeY_r {
    from {
        transform: translateY(0);
    }
    to {
        transform: translateY(100%);
    }
}
@keyframes fall {
    0% {
        top: -0%;
        opacity: 1;
        transform: rotateX(0deg) rotateY(0deg) (0deg);
        transform-origin: center center;
    }
    100% {
        transform: rotateX(240deg) rotateY(400deg) rotateZ(310deg);
        transform-origin: center center;
        top: 100%;
        opacity: 0;
    }
}
@keyframes fall2 {
    0% {
        top: -0%;
        opacity: 1;
        transform: rotateX(0deg) rotateY(0deg) (0deg);
        transform-origin: center center;
    }
    100% {
        transform: rotateX(-240deg) rotateY(-400deg) rotateZ(-310deg);
        transform-origin: center center;
        top: 100%;
        opacity: 0;
    }
}
@keyframes backgroundchange {
    0% {
        background: url(/images/con11_07.png) no-repeat center / contain;
    }

    25% {
        background: url(/images/con11_08.png) no-repeat center / contain;
    }

    50% {
        background: url(/images/con11_09.png) no-repeat center / contain;
    }

    75% {
        background: url(/images/con11_10.png) no-repeat center / contain;
    }

    100% {
        background: url(/images/con11_07.png) no-repeat center / contain;
    }
}
@keyframes opa {
    0% {
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}
@keyframes backgroundchange_2 {
    0% {
        background: url(/images/con08_07.png) no-repeat center / contain;
    }

    20% {
        background: url(/images/con08_08.png) no-repeat center / contain;
    }

    40% {
        background: url(/images/con08_09.png) no-repeat center / contain;
    }

    60% {
        background: url(/images/con08_10.png) no-repeat center / contain;
    }

    80% {
        background: url(/images/con08_11.png) no-repeat center / contain;
    }
    100% {
        background: url(/images/con08_07.png) no-repeat center / contain;
    }
}
@keyframes rotateAnimation {
    0% {
        transform: rotate(-1deg);
    }
    40% {
        transform: rotate(1deg);
    }
    60% {
        transform: rotate(2deg);
    }
    80% {
        transform: rotate(-1deg);
    }
    100% {
        transform: rotate(1deg);
    }
}
@keyframes shakeAndFall {
    0% {
        transform: translate(0, -50%) rotate(0);
        opacity: 0;
    }
}
@keyframes floating {
    0% {
        transform: translateY(-5%);
    }
    100% {
        transform: translateY(5%);
    }
}

.animate-blk {
    animation: blk 1s infinite ease-in-out;
}
.scaleOpa {
    animation: scaleOpa infinite 2s;
}
.scaleOpa2 {
    animation: scaleOpa2 infinite 2s;
}
.light {
    animation: light infinite 5s;
}
.rotate_img {
    animation: rotate_image 10s infinite linear;
}
.image_sd {
    animation: marqueeX 20s infinite linear;
}
.image_sd_r {
    animation: marqueeX_r 20s infinite linear;
}
.slide_y {
    animation: marqueeY 20s infinite linear;
}
.slide_y_r {
    animation: marqueeY_r 20s infinite linear;
}
.smoke {
    animation: smoke 5.5s infinite ease-out;
}
.floating_ani {
    animation: floating 2s ease-in-out infinite alternate;
}
.floating_ani2 {
    animation: floating 2s 1s ease-in-out infinite alternate;
}
/* ------------------------- 퍼블시작 ------------------------- */
/* ------------------------- vw rem 연동 ------------------------- */

body {
    font-family: "Pretendard Variable";
    font-size: 1.8rem;
    min-height: 0vw;
    letter-spacing: -0.04em;
    line-height: 1.5;
}

.c-secondary {
    color: var(--secondary);
}
.c-primary {
    color: var(--primary);
}

/* ------------------------- main start ------------------------- */
.main {
    background: url(/images/m_06.webp) no-repeat center/cover;
    padding-top: var(--headerH);

    height: 85rem;
    overflow: visible;
}

.main__text {
    color: #fff;
    z-index: 3;
    top: 19rem;

    .h1 {
        font-size: var(--titleS);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleL);
    }
    .subh {
        font-size: var(--bodyL);
    }
}

.m_01 {
    top: 10rem;
    right: 0rem;

    > img {
        animation: floating 2s infinite alternate;
    }
}

.m_02 {
    top: 46rem;
    left: 38rem;

    color: var(--primary);

    .bubble__head {
        color: #000;
        font-size: var(--bodyXL);
    }
    .bubble__body {
        font-size: var(--titleM);
        letter-spacing: -0.05em;
        > .per {
            font-size: 1.7rem;
            position: relative;
            z-index: 1;
            background-color: var(--primary);
            color: var(--secondary);
            padding: 0.3rem;
            border-radius: 99px;
            box-sizing: border-box;
            letter-spacing: 0;
            border: 2px solid var(--secondary);
            display: block;
            height: fit-content;
            margin-top: 2.8rem;
        }
    }

    .border {
        inset: 0 0 0 0;
        z-index: -1;
        border-radius: 999px;
        border: 1px solid var(--secondary);
    }
}

.m_03 {
    top: 47rem;
    clip-path: inset(-100% 0 19.7% 0);
}
.main01v {
    width: 94vw;
    height: 94%;
    top: 0;
    overflow: hidden;
    border-radius: 5rem;
    border: 2px solid var(--secondary);
    outline: 0rem solid var(--primary);
    background-color: #140800;

    will-change: width, height, transform, outline, border-radius;

    video {
        aspect-ratio: 16/9;
        filter: brightness(0.3);
        box-sizing: border-box;
    }

    .video_bg {
        inset: 0 0 0 0;
        background-color: var(--primary);
        z-index: -1;
    }
}

/* ----------------con01----------------------- */
.con01 {
    height: 85rem;
    background-color: var(--secondary);
}

.con01_border {
    background-color: var(--primary);
}

.con01 .border__top {
    inset: 5rem 0 auto 0;
    height: 1px;
}
.con01 .border__right {
    inset: 0 auto 0 5rem;
    width: 1px;
}
.con01 .border__bottom {
    inset: auto 0 5rem 0;
    height: 1px;
}
.con01 .border__left {
    inset: 0 5rem 0 auto;
    width: 1px;
}
.con01_04 {
    bottom: 5rem;
    left: 50%;
    transform: translate(-50%, 50%);
    background-color: var(--secondary);
    padding: 0 1rem;
}

.con01_01 {
    top: -5rem;
    left: 32rem;
}

.con01__text {
    bottom: 10rem;
    left: 24rem;

    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .h2-2 {
        color: var(--secondary);
        background-color: var(--primary);
        padding: 0 0.1em;
    }
    .h2-3 {
        color: var(--primary);
    }
    .p1,
    .p2 {
        font-size: var(--bodyM);
    }
}

/* ----------------con02---------------------*/
.con02 {
    background: url(/images/con_02_4.webp) no-repeat center/cover;
    color: #fff;
    padding: var(--paddingTop) 0;
}

.con02__text {
    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
}

.con02 .card {
    width: 43.1rem;
    height: 47.2rem;
    background-repeat: no-repeat;
    background-size: cover;
    transition: background 0.3s;
}

.con02 .card-1 {
    background-image: url(/images/con_02_1.webp);
}
.con02 .card-1.active {
    background-image: url(/images/con_02_1_2.webp);
}
.con02 .card-2 {
    background-image: url(/images/con_02_2.webp);
}
.con02 .card-2.active {
    background-image: url(/images/con_02_2_2.webp);
}
.con02 .card-3 {
    background-image: url(/images/con_02_3.webp);
}
.con02 .card-3.active {
    background-image: url(/images/con_02_3_2.webp);
}

/* -------------------------con03---------------------- */
.con03 {
    background: url(/images/con_03_22.webp) no-repeat center/cover;
    padding: var(--paddingTop) 0;
    color: #fff;
}

.con03__top,
.con03__bottom {
    max-width: 180rem;
    width: 100%;
    height: 85rem;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    box-sizing: border-box;
    padding: calc(var(--paddingTop) + 1rem) 0 0;
    overflow: hidden;
}

.con03__top {
    background: url(/images/con_03_11.webp) no-repeat center/cover;

    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
    .top__ct {
        align-items: baseline;
        font-size: 7rem;
    }
    .ct_bod-wrap {
        margin: 0 auto;
    }
    .p2 {
        font-size: var(--bodyM);
        margin-bottom: 1rem;
    }

    .ct-box {
        position: relative;
        width: 8rem;
        height: 10.5rem;
        background-color: #fff;
        border-radius: 1.2rem;
        text-align: center;
        color: #000;
        overflow: hidden;

        .ct-box-inner > span {
            height: 100%;
        }
    }

    .top__swiper {
        margin-top: 6rem;
    }

    .con03_03 {
        bottom: -12.5rem;
    }
    .con03_02 {
        top: 3rem;
        left: -2rem;
    }
    .con03_04 {
        top: -100%;
    }
}
.con03__bottom {
    background: url(/images/con_03_21.webp) no-repeat center/cover;

    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .bottom__ct {
        font-size: var(--titleM);
        width: 43rem;
    }
    .line {
        height: 1px;
        background-color: #fff;
        width: 50%;
        left: 0;
        top: 57.6%;
    }

    .con03_17 {
        top: 2rem;
        right: 2rem;
    }
    .con03_16 {
        mask: url(/images/con_03_16.webp) no-repeat center/cover;
    }
    .con03_15 {
        top: 11rem;
    }
    .con03_14 {
        top: 16rem;
    }
    .con03_14-2 {
        top: 44.7rem;
        left: 32rem;
        right: 1rem;

        >img {
            width: 100% !important;
        }
    }
    .currency {
        font-size: 3.5rem;
        transform: translateY(1rem);
    }
}

/* ---------------------con04------------------------- */
.con04 {
    background-color: var(--secondary);
    height: 103rem;
    box-sizing: border-box;
    padding: calc(var(--paddingTop) + 3rem) 0;
}
.con04_bg {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.con04 .h1 {
    font-size: var(--headM);
}
.con04 .h2 {
    font-size: var(--titleM);
}
.gsap_slide_container {
    width: fit-content;
    margin: 0 auto;
    height: 50rem;

    .gsap-slide {
        padding-bottom: 2.4rem;
    }
}
.con04_01_2 {
    top: 4.2rem;
    left: 43rem;
    color: #fff;
}

.con04 .p1 {
    font-size: var(--bodyM);
}
.con04 .con04_ct {
    font-size: var(--headL);
    letter-spacing: -0.07em;
}
.con04 .currency {
    font-size: 2.5rem;
    transform: translateY(0.5rem);
}
.con04 .bottom__text {
    font-size: var(--headS);
    .text-box {
        color: #fff;
        width: 14rem;
        height: 4.5rem;
    }
    .box-bg {
        inset: 0 0 0 0;
        background-color: var(--primary);
        z-index: 0;
    }
    .bt4 {
        font-size: var(--bodyXL);
    }
}
/* -----------------------con05----------------------- */
.con05 {
    padding: var(--paddingTop) 0 0;
}
.con05_01 {
    top: -19rem;
    right: 16rem;
}
.con05 .inner {
    width: 180rem;
    height: 87.4rem;
    margin: 0 auto;
    border-radius: 5rem;
    overflow: hidden;
}
.con05__text {
    color: #fff;

    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyXL);
    }
}
.con05_bg {
    inset: 0 0 0 0;

    video {
        aspect-ratio: 16/9;
    }
}
.con05_02_2 {
    top: 35%;
}
.con05_03 {
    bottom: 0;
}
.con05_04 {
    top: -100%;
}

/* ---------------------con06------------------------ */
.con06_06 {
    top: 27%;
}
.con06 {
    color: #fff;
}
.con06__head {
    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
}

.con06_card-wrap span {
    font-size: 5rem;
}

.con06 .card__inner {
    width: 42rem;
    height: 42rem;
    background-color: #000;
    border-radius: 999px;
    overflow: hidden;
    box-sizing: border-box;
    position: relative;
}

.con06 .chip {
    width: 8rem;
    height: 3.5rem;
    background-color: #fff;
    color: #000;
    border-radius: 50%;
    transform: translateY(-3rem);

    transition: transfrom 0.4s;
}

.con06 .card__title {
    font-size: var(--headM);
    padding: 0 8.6rem;
    opacity: 0;
    transition: opacity 0.4s;
}

.con06 .card__subtitle {
    font-size: var(--headM);
    margin-top: 1.6rem;
    transform: translateY(-3rem);

    transition:
        transform 0.4s,
        margin 0.4s,
        height 0.4s,
        opacity 0.4s;
}

.con06 .border {
    inset: 0 0 0 0;
    border: 1px solid #fff;
    border-radius: 999px;
    display: none;
}

.con06 .card__desc {
    font-size: var(--bodyM);
    padding: 0 7rem;
    word-break: keep-all;
    opacity: 0;

    transition: opacity 0.4s;
}
.con06 .card__img {
    bottom: -4rem;

    transition: filter 0.4s;
}

.con06 .card.hover {
    .chip {
        transform: translateY(0);
    }
    .card__title {
        opacity: 1;
    }
    .card__subtitle {
        /* display: none; */
        opacity: 0;
        height: 0;
        margin: 0;
        transform: translateY(0);
    }
    .card__desc {
        opacity: 1;
    }
    .card__img {
        filter: brightness(0.3);
    }
    .border {
        display: block;
    }
}

.con06__body {
    font-size: var(--bodyXL);
    .p2 {
        background-color: var(--secondary);
        padding: 0 0.2em;
    }
}

/* -------------------------con07--------------------------- */
.con07 {
    background: url(/images/con_07_8.webp) no-repeat center/cover;
    color: #fff;
}

.con07__head {
    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
        .expand {
            background-color: #fff;
            padding: 0 0.1em;
        }
    }
    .p1 {
        font-size: var(--bodyL);
    }
}
.con07 .card-wrap {
    background: url(/images/con_07_8.webp) no-repeat center/cover;
    padding: 2rem 0;
    margin-top: -4.2rem;
}
.top_line {
    height: 21rem;
    transform-origin: top;
}
.mid_line {
    height: 30rem;
    transform-origin: bottom;
}
.con07 .line {
    width: 1px;
    background-color: #fff;
    opacity: 0.3;
}
.con07_02 {
    top: 48rem;
    left: -19rem;
}

.con07 .review-wrapper {
    gap: 3rem;
}

.con07 .gsap-slide {
    flex-shrink: 0;
}

.con07 .review-left {
    top: -41rem;
    left: -68rem;
    transform: rotate(30deg);
    filter: brightness(0.5);
}
.con07 .review-right {
    top: -20rem;
    right: -9rem;
    transform: rotate(30deg);
    filter: brightness(0.5);
}

/* ----------------con08------------------------ */
.con08 {
    background: url(/images/con_08_10.webp) no-repeat center/cover;
    color: #fff;
    padding: var(--paddingTop) 0 18rem;
}

.con08__text {
    margin-left: 21rem;
    margin-top: 6rem;

    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
}

.con08_swiper {
    width: 107rem;
    height: 57rem;
    padding-left: 5rem;

    .swiper-slide {
        width: 44.3rem;
        transition: filter 0.3s;

        video {
            height: 50rem;
            border-radius: 2rem;
            overflow: hidden;
        }
    }
}
.con08 .swiper-slide-prev {
    filter: opacity(0);
}

.con08 .step_name {
    font-size: var(--bodyXL);
    opacity: 0.5;
    color: #000;
    font-weight: 500;

    transition: opacity 0.2s 0.1s;
}

.con08 .swiper-slide-active {
    .step_name {
        opacity: 1;
    }
}

.con08 .swiper-prev {
    top: 46%;
    left: 2rem;
    transform: scaleX(-1) translateY(-50%);
    transition: transform 0.2s;

    &:hover {
        transform: scaleX(-1) translateY(-50%) scale(1.1);
    }
}
.con08 .swiper-next {
    top: 46%;
    left: 47.6rem;
    transform: translateY(-50%);
    transition: transform 0.2s;

    &:hover {
        transform: translateY(-50%) scale(1.1);
    }
}
.con08_04 {
    top: 35rem;
    right: 0rem;
}

.con08_02 {
    bottom: -13.3rem;
    left: -21rem;
}

/* -------------------con09------------------------ */
.con09 {
    padding: var(--paddingTop) 0;
    /* background-color: var(--secondary); */
}

.con09__text {
    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
}

.con09 .card {
    position: relative;
    padding: 0 1rem;
    overflow: visible;
    > img {
        object-fit: contain;
    }
}

.con09 .card-1 {
    transform: translateY(5rem);
}
.con09 .card-3 {
    transform: translateY(5rem);
}

.con09_1_2 {
    top: -3.5rem;
}
.con09_2_2 {
    top: -3.5rem;
    transform: translateX(3rem);
}
.con09_3_2 {
    top: -3.5rem;
    transform: translateX(-4rem);
}

/* -------------------con10------------------ */
.con10 {
    background: url(/images/con_10_6.webp) no-repeat center/cover;
    padding: calc(var(--paddingTop) * 2) 0;
    height: 116.3rem;
    box-sizing: border-box;
}

.con10__head {
    color: #fff;
    .h1 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
}

.menu__container {
    background-color: #fff;
    max-width: 144rem;
    margin: 0 auto;
    padding: 0 0 5rem;
    border-radius: 3rem;
    margin-top: 6rem;

    .tab__wrap {
        border-bottom: 1px solid var(--primary);
        padding: 1rem 0;

        .inner {
            width: fit-content;
            margin: 0 auto;
        }
    }

    .line {
        width: 1px;
        background-color: var(--primary);
        height: 4rem;
        align-self: center;
        margin-left: -1px;
        margin-right: -1px;
    }

    .tab__bg {
        top: 0;
        left: 0;
        width: 18rem;
        height: 7rem;
        background-color: var(--primary);
        border-radius: 1.6rem;
        outline: 1px solid #fff;
        outline-offset: -5px;
    }

    .tab {
        position: relative;
        z-index: 1;
        font-size: var(--bodyXL);
        width: 18rem;
        height: 7rem;
        transition:
            font-weight 0.2s,
            color 0.2s;

        &.active {
            font-weight: 700;
            color: #fff;
        }
    }

    .menu__img > img {
        width: 100% !important;
        border-radius: 2rem;
    }
    .menu__name {
        margin-top: 3rem;
        padding: 0 3rem;
        box-sizing: border-box;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .menu__desc {
        margin-top: 1rem;
        height: 5.4rem;
        overflow: hidden;
        padding: 0 3rem;
        box-sizing: border-box;

        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

    .swiper-next {
        top: 14rem;
        right: -3rem;
        z-index: 1;
        user-select: none;
    }
    .swiper-prev {
        top: 14rem;
        left: -3rem;
        z-index: 1;
        transform: scaleX(-1);
        user-select: none;
    }

    .menu-box {
        display: none;

        &.active {
            display: block;
        }
    }
}

.con10 .swiper {
    width: 94%;
    margin: 0 auto;
    margin-top: 5rem;
}

/* ------------------con11-------------------- */
.con11 {
    background: url(/images/con_11_6.webp) no-repeat center/cover;
    color: #fff;
    box-sizing: border-box;
    padding: var(--paddingTop) 0;
}

.con11_inner {
    background: url(/images/con_11_5.webp) no-repeat center/cover;
    max-width: 180rem;
    margin: 0 auto;
    border-radius: 5rem;
    overflow: hidden;
    height: 83rem;
}

.con11 .line {
    height: 4rem;
    width: 1px;
    background-color: #fff;
    opacity: 0.5;
}

.con11__text {
    .h1 {
        font-size: var(--titleM);
    }
    .h1-1 {
        background-color: var(--secondary);
        padding: 0 0.1em;
        color: #000;
    }
    .h2 {
        font-size: var(--bodyXL);
    }
    .p1 {
        font-weight: 300;
        font-size: var(--bodyXL);
    }
}

.con11_01 {
    top: -20rem;
    right: -3rem;
}

.con11_02 {
    left: 0;
}
.con11_03 {
    bottom: -18rem;
    right: 20rem;
}

/* ------------------con12--------------------- */
.con12 {
    background-color: var(--secondary);
    padding: var(--paddingTop) 0 0;
}

.con12__text {
    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
}

.con12_swiper {
    width: 39rem;
    height: 53.5rem;
    margin: 0 auto -3rem !important;
    border-radius: 5rem;
    user-select: none;
}

.con12 .swiper-prev {
    bottom: 21rem;
    left: 71.4rem;
    transform: scaleX(-1);
    user-select: none;
}
.con12 .swiper-next {
    bottom: 21rem;
    right: 71.4rem;
    user-select: none;
}

.con12_07 {
    bottom: -4rem;
    > img {
        width: 41rem !important;
    }
}

.con12_bubble.b-1 {
    bottom: 10rem;
    left: 52rem;

    .con12_ct-1 {
        font-size: var(--titleM);
        letter-spacing: -0.07em;
    }

    span {
        margin-bottom: 0.1em;
        font-size: 3.5rem;
    }
}
.con12_bubble.b-2 {
    bottom: 10rem;
    right: 52rem;

    .con12_ct-2 {
        font-size: var(--titleM);
        letter-spacing: -0.07em;
    }

    span {
        margin-bottom: 0.1em;
        font-size: 3.5rem;
    }
}
.marquee-1 {
    top: 0;
    left: 5rem;
    overflow: hidden;

    .con12_08 {
        animation: marqueeY 20s infinite linear;
    }
}
.marquee-2 {
    top: 0;
    right: 5rem;
    overflow: hidden;
    flex-direction: column-reverse !important;

    .con12_09 {
        animation: marqueeY_r 20s infinite linear;
    }
}
.con12_02 {
    top: 29rem;
    left: 52.3rem;
}
.con12_03 {
    top: 35rem;
    right: 52rem;
}
.con12_17 {
    bottom: 0;
    left: 0;
}

/* ----------------------con13------------------------ */
.con13 {
    background: url(/images/con_13_8.webp) no-repeat center/cover;
    /* padding: var(--paddingTop) 0; */
    color: #fff;
    height: 85rem;
    box-sizing: border-box;
}

.con13__inner {
    max-width: 144rem;
    margin: 0 auto;
}

.con13__text {
    .h1 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyM);
        font-weight: 300;
    }
    .p2 {
        font-size: var(--bodyM);
        font-weight: 300;
    }
}

.gsap-slide-wrap {
    overflow: hidden;
}

/* ----------------------con14--------------------------- */
.con14 {
    padding: 4rem 0;
}

.con14__inner {
    background: url(/images/con_14_4.webp) no-repeat center/cover;
    height: 92.4rem;
    width: 182rem;
    margin: 0 auto;
    padding: var(--paddingTop) 0;
    box-sizing: border-box;
}

.con14 .h1 {
    font-size: var(--titleM);
}
.con14 .p1 {
    font-size: var(--bodyXL);
}
.con14_02 {
    top: 30.8rem;
    left: 94rem;
}
.con14_03 {
    top: 45.5rem;
    right: 39rem;
}
.con14 .line {
    display: block;
    height: 2px;
    background-color: var(--primary);
    width: 9.4rem;
    top: 32.6rem;
    left: 84rem;
}

/* ---------------------con15------------------------- */
.con15 {
    background: url(/images/con_15_6.webp) no-repeat center/cover;
    padding: calc(var(--paddingTop) + 5rem) 0 calc(var(--paddingTop) - 2rem);
}

.con15__text {
    color: #fff;

    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
}

.con15_swiper {
    width: calc(calc(43.2rem + 2rem) * 3);
    margin: 3rem auto !important;

    .swiper-wrapper {
        justify-content: space-between;
    }

    .swiper-slide {
        width: fit-content;
    }
}

.con15_swiper-bg {
    width: calc(calc(43.2rem + 2rem) * 3);
    height: 47.2rem;
    padding: 3rem;
    background-color: #fff;
    border-radius: 3rem;

    top: 32.6rem;
}

.con15_01 {
    top: -8rem;
    right: -15rem;
}

.con15 .bottom_text {
    /* margin-top: 1rem; */
    text-transform: uppercase;
    color: #fff;

    .line {
        flex: 1 1 0;
        height: 1rem;
        border-top: 1px solid #fff;
        border-bottom: 1px solid #fff;
        opacity: 0.9;
    }
}

/* -----------------------con16--------------------- */
.con16 {
    background-color: var(--secondary);
    padding: 13rem 0;
}

.con16__head {
    .h1 {
        font-size: var(--headM);
    }
    .h2 {
        font-size: var(--titleM);
    }
}

.con16 .map-wrap {
    width: 144rem;
    height: 60rem;
    margin: 0 auto;
}

.con16 .map {
    height: 100%;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
}

.con16 .mid_map_search {
    background: white;
    overflow: hidden;
    z-index: 2;
    width: 18.54vw;
    height: 100%;
    left: 0;
    top: 0;
    border-radius: 1.6vw 0 0 1.6vw;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
}

.con16 .mid_map_search_item_btns {
    margin-top: 1.6rem;
}
.con16 .fixed_popup {
    background: rgba(0, 0, 0, 0.1);

    .popup_img {
        width: 42rem;
        height: auto;
        border-radius: 1.2rem;
    }
    .popup {
        width: fit-content;
        height: fit-content;
        gap: 3rem;
        border-radius: 2rem;
        padding: 2rem;
        filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.2));
    }
    .popup_right {
        width: 28rem;
    }
    .popup_right_left_txt {
        width: fit-content;
        flex-shrink: 0;

        &::after {
            display: none;
        }
    }
    .popup_right > div > div:nth-child(2) {
        width: 100%;
        font-weight: 400;
        font-size: 0.85vw;
        color: #333;
    }
    .line {
        width: 100%;
        height: 1px;
        background-color: rgba(0, 0, 0, 0.5);
    }
    .popup_right_6th_left {
        display: flex;
        justify-content: center;
        align-items: center;
        color: #000;
        right: 20%;
        bottom: 16%;
    }
}

/* ---------------------con17------------------------ */
.con17 {
    background: url(/images/con_17_3.webp) no-repeat center/cover;
    height: 80rem;
}

.con17__inner {
    width: 144rem;
    margin: 0 auto;
}

.con17__text {
    color: #fff;
    .h1 {
        font-size: var(--headL);
        font-weight: 300;
    }
    .h2 {
        font-size: var(--titleM);
    }
    .p1 {
        font-size: var(--bodyL);
    }
}

.con17_call {
    margin-top: 2rem;
    width: fit-content;
}

.con17 .form_wrap {
    position: relative;
    background-color: #fff;
    width: 62.8rem;
    padding: 0 2rem;
    /* box-sizing: border-box; */

    &::after {
        content: "";
        display: block;
        position: absolute;
        left: 2rem;
        width: 1px;
        height: 100%;
        background-color: var(--primary);
        opacity: 0.7;
    }
    &::before {
        content: "";
        display: block;
        position: absolute;
        right: 2rem;
        width: 1px;
        height: 100%;
        background-color: var(--primary);
        opacity: 0.7;
    }

    .form__inner {
        padding: 0 6.5rem;
    }
    .form_margin_Agree_input {
        height: 6rem;
    }
    form {
        font-size: var(--bodyL);
    }

    .form_submit_div {
        height: 6rem;
        background-color: var(--primary);
        margin: 0 4rem;
        border-radius: 999px;
        color: #fff;
        font-size: var(--headM);
    }
    input[type="text"],
    input[type="email"],
    .form_check_wrap {
        width: 35rem;
        height: 6rem;
    }
    .form__line {
        height: 1px;
        background-color: #000;
        opacity: 0.5;
    }
    /* 체크 전 bg색상 */
    --input-bg-color: transparent;
    /* 체크시 bg */
    --checked-bg: var(--primary);
    /* 보더색상 */
    --input-border: #000;
    /* 보더 안쪽 구분선 색상 */
    --input-stroke: #fff;

    input[type="radio"] {
        border: 1px solid var(--input-border);
        &:checked {
            border: 1px solid var(--input-border);
            outline-offset: -3px;
            outline: 2px solid var(--input-stroke);
        }
    }
}
