@import url("https://p.typekit.net/p.css?s=1&k=gxs4rxw&ht=tk&f=137.138.139.140.169.170.171.172.173.174.175.176.5474.5475.25136.25137.2005.2006.2009.2010.9938.9939.39002.39004.16353.37461.37466.37467.17398.17399.17400.17401.22618.22619.37478.37479.37484.37485.37509.37510.37511.37512.37513.37514.37515.37516.37517.37518.37519.37520.37521.37522.37523.37524.37525.37526&a=272690494&app=typekit&e=css");

/* proxima nova font start */
@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/846224/00000000000000007735e602/31/l?subset_id=2&fvd=n9&v=3") format("woff2"),
        url("https://use.typekit.net/af/846224/00000000000000007735e602/31/d?subset_id=2&fvd=n9&v=3") format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 900;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/a7a503/00000000000000007758cf7c/31/l?subset_id=2&fvd=i9&v=3") format("woff2"),
        url("https://use.typekit.net/af/a7a503/00000000000000007758cf7c/31/d?subset_id=2&fvd=i9&v=3") format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 900;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/5be242/00000000000000007735e603/31/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3")
            format("woff2"),
        url("https://use.typekit.net/af/5be242/00000000000000007735e603/31/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3")
            format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 700;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/38ea3a/00000000000000007758cf7d/31/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=i7&v=3")
            format("woff2"),
        url("https://use.typekit.net/af/38ea3a/00000000000000007758cf7d/31/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=i7&v=3")
            format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 700;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/99d25e/00000000000000007735e611/31/l?subset_id=2&fvd=n8&v=3") format("woff2"),
        url("https://use.typekit.net/af/99d25e/00000000000000007735e611/31/d?subset_id=2&fvd=n8&v=3") format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 800;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/57ba91/00000000000000007758cf8c/31/l?subset_id=2&fvd=i8&v=3") format("woff2"),
        url("https://use.typekit.net/af/57ba91/00000000000000007758cf8c/31/d?subset_id=2&fvd=i8&v=3") format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 800;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/4b22bb/00000000000000007735e601/31/l?subset_id=2&fvd=n1&v=3") format("woff2"),
        url("https://use.typekit.net/af/4b22bb/00000000000000007735e601/31/d?subset_id=2&fvd=n1&v=3") format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 100;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/da27c4/00000000000000007758cf8d/31/l?subset_id=2&fvd=i1&v=3") format("woff2"),
        url("https://use.typekit.net/af/da27c4/00000000000000007758cf8d/31/d?subset_id=2&fvd=i1&v=3") format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 100;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/e37e5a/00000000000000007735e60d/31/l?subset_id=2&fvd=n6&v=3") format("woff2"),
        url("https://use.typekit.net/af/e37e5a/00000000000000007735e60d/31/d?subset_id=2&fvd=n6&v=3") format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 600;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/0bd0af/00000000000000007758cf8e/31/l?subset_id=2&fvd=i6&v=3") format("woff2"),
        url("https://use.typekit.net/af/0bd0af/00000000000000007758cf8e/31/d?subset_id=2&fvd=i6&v=3") format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 600;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/d7ff92/00000000000000007735e609/31/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3")
            format("woff2"),
        url("https://use.typekit.net/af/d7ff92/00000000000000007735e609/31/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3")
            format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 400;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/6eb0e3/00000000000000007758cf8f/31/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=i4&v=3")
            format("woff2"),
        url("https://use.typekit.net/af/6eb0e3/00000000000000007758cf8f/31/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=i4&v=3")
            format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 400;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/3888dc/00000000000000007735e606/31/l?subset_id=2&fvd=n3&v=3") format("woff2"),
        url("https://use.typekit.net/af/3888dc/00000000000000007735e606/31/d?subset_id=2&fvd=n3&v=3") format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 300;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/0b8052/00000000000000007758cf90/31/l?subset_id=2&fvd=i3&v=3") format("woff2"),
        url("https://use.typekit.net/af/0b8052/00000000000000007758cf90/31/d?subset_id=2&fvd=i3&v=3") format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 300;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/26f7ec/00000000000000007735e605/31/l?subset_id=2&fvd=n5&v=3") format("woff2"),
        url("https://use.typekit.net/af/26f7ec/00000000000000007735e605/31/d?subset_id=2&fvd=n5&v=3") format("woff");
    font-display: auto;
    font-style: normal;
    font-weight: 500;
    font-stretch: normal;
}

@font-face {
    font-family: "proxima-nova";
    src:
        url("https://use.typekit.net/af/c7cac4/00000000000000007735e60e/31/l?subset_id=2&fvd=i5&v=3") format("woff2"),
        url("https://use.typekit.net/af/c7cac4/00000000000000007735e60e/31/d?subset_id=2&fvd=i5&v=3") format("woff");
    font-display: auto;
    font-style: italic;
    font-weight: 500;
    font-stretch: normal;
}
/* proxima nova font end */

/* 페이퍼로지 */
@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-1Thin.woff2") format("woff2");
    font-weight: 100;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-2ExtraLight.woff2") format("woff2");
    font-weight: 200;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-3Light.woff2") format("woff2");
    font-weight: 300;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-4Regular.woff2") format("woff2");
    font-weight: 400;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-5Medium.woff2") format("woff2");
    font-weight: 500;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-6SemiBold.woff2") format("woff2");
    font-weight: 600;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-7Bold.woff2") format("woff2");
    font-weight: 700;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-8ExtraBold.woff2") format("woff2");
    font-weight: 800;
    font-display: swap;
}

@font-face {
    font-family: "Paperozi";
    src: url("https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-9Black.woff2") format("woff2");
    font-weight: 900;
    font-display: swap;
}
/* 페이퍼로지 끝 */

* {
    padding: 0;
    margin: 0;
    box-sizing: unset;
}

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(./../_files/con11_07.webp) no-repeat center / contain;
    }

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

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

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

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

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

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

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

    80% {
        background: url(./../_files/con08_11.webp) no-repeat center / contain;
    }
    100% {
        background: url(./../_files/con08_07.webp) 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;
    }
}

/* ------------------------- 퍼블시작 ------------------------- */

body {
    font-family: "SUIT Variable", sans-serif;
    font-size: var(--bodyXS);
    min-height: 0vw;
    letter-spacing: -0.05em;
    line-height: 1.5;
    font-weight: 500;

    overflow-x: hidden;
    word-break: keep-all;
}

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

/* ------------------------- main start ------------------------- */
.main {
    padding-top: var(--headerH);
    padding-bottom: 3rem;
}

/* main swiper */
.main_swiper {
    height: 88rem;
    .swiper-slide .slide-bg {
        width: 100% !important;
    }
}
.main_swiper .main_bg03v {
    height: 100%;
    width: 100%;
    overflow: hidden;
    position: relative;
    background-color: #000;

    iframe {
        width: 100%;
        height: 100%;
        scale: 120%;
    }

    &::after {
        content: "";
        display: block;
        position: absolute;
        inset: 0 0 0 0;
        background: linear-gradient(to right, rgba(0, 0, 0, 0.9) 5%, transparent 70%);
    }
}
.main_prev,
.main_next {
    width: 4.2rem;
    height: 4.2rem;
    transition: transform 0.2s;

    &:hover {
        transform: scale(1.04);
    }
}

.main_swiper .pagination {
    font-size: var(--bodyM);
    font-weight: 800;
    line-height: 1;
    align-items: center;
    color: #fff;
    left: 18rem;
    top: 61rem;
    z-index: 1;

    /* progress bar */
    .bar {
        width: 29rem;
        height: 3px;
        background-color: rgba(255, 255, 255, 0.3);
    }

    .bar_inner {
        width: 25%;
        height: 100%;
        background-color: #fff;
        transition: transform 0.3s;
    }
}

.main_swiper .current_index {
    width: 2.5rem;
}

/* main swiper text */
.main_swiper_text {
    top: 24.2rem;
    left: 18rem;
    width: 100%;
    pointer-events: none;
}

.main_swiper_text .swiper-slide {
    align-items: start;
}

.main_swiper_text .t01 {
    font-size: var(--titleM);
    font-weight: 900;
    line-height: 1.2;
}
.main_swiper_text .t02 {
    font-size: var(--subhead);
    line-height: 1.3;
}

.main_swiper_text .swiper-slide.white {
    color: #fff;
}

.main_01 {
    bottom: 3rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
}
.main_02 {
    bottom: 0rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
}

/* ---------------------- con01 -------------------------- */
.con01_01 {
    top: 12.8rem;
    left: 5rem;
    z-index: 3;
}
.con01_02 {
    top: 89.2rem;
    left: 85rem;
    z-index: 3;
}

/* con01 main */
.con01 {
    padding: 8.8rem 0;
}
.con01_wrap {
    max-width: 164rem;
    margin: 0 auto;
    height: 97rem;
}
/* left video */
.con01 .con01v {
    flex: 1 1 0;
    max-width: 82rem;
    height: 100%;
    overflow: hidden;
    border-radius: 5rem;
}

/* right */
.con01 .text_wrap {
    flex: 1 1 0;
    max-width: 82rem;
    height: 100%;
    justify-content: center;
    box-sizing: border-box;
    padding: 11.4rem;
    overflow: hidden;
    border-radius: 5rem;
    font-weight: 500;
}
.con01__head {
    font-size: var(--titleL);
    letter-spacing: -0.06em;
}
.con01__desc {
    font-size: var(--bodyS);
    letter-spacing: -0.05em;
    line-height: 1.6;
}
.con01_04 {
    transform: rotate(-10deg);
    font-size: var(--headS);
    line-height: 1.2;

    top: 80rem;
    right: 10rem;
}

/* right bg */
.con01 .con01bg {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}

/* ----------------------- con02 -------------------- */
.con02 {
    height: calc(100svh - var(--footerH));
}

.con02 .cam_layout {
    width: 168rem;
    height: 70svh;
}

.con02 .con02_01 {
    top: 0;
    left: 0;
}
.con02 .con02_02 {
    top: 0;
    right: 0;
}
.con02 .con02_03 {
    bottom: 0;
    left: 0;
}
.con02 .con02_04 {
    bottom: 0;
    right: 0;
}

.con02_text {
    width: 100%;
    color: #301e16;
    font-family: "Paperlogy";
    font-size: 20rem;
    font-weight: 900;
    line-height: 1; /* 100% */
    letter-spacing: -0.03em;
    mix-blend-mode: soft-light;
    white-space: nowrap;

    top: 55%;
    transform: translateY(-50%);
}

.con02v {
    clip-path: inset(30rem 43rem 19.45rem round 99rem);
    height: 100%;
    width: 100%;
    position: relative;

    iframe {
        position: absolute;
        width: 300%;
        scale: 130%;
    }
}

.con02v .video_text {
    color: #fff;
    text-align: center;
    text-shadow: 0 0 13px rgba(0, 0, 0, 0.15);
    font-size: var(--titleM);
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: -0.05em;

    opacity: 0;
}

.con02__leftText {
    left: 11rem;
}

.con02__rightText {
    right: 11rem;
    text-align: end;
}

.con02 .chip {
    color: var(--primary);
    font-size: var(--bodyL);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.07em;
}

.con02 .head {
    font-size: var(--headM);
    font-weight: 800;
    line-height: 1.3;
    letter-spacing: -0.08em;
}

.con02 .desc {
    font-size: var(--bodyS);
    line-height: 1.6;
    letter-spacing: -0.07em;
}

/* con03 */
/* con04 */
.con04 {
    height: calc(100svh - var(--footerH));
    background: #f4f0e5;
    white-space: nowrap;
}

.con04_text {
    width: 100%;
    font-size: var(--titleM);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.05em;
    align-items: center;

    .text-4.orange {
        color: var(--primary);
    }
}

/* --------------------- con05 --------------------- */
.con05 {
    padding: 9rem 0;
    box-sizing: border-box;
}

.con05bg {
    inset: 0 0 0 0;
    z-index: -1;
}

.con05__main {
    max-width: 136.5rem;
    margin: 0 auto !important;
    justify-content: space-between;
}

/* con05 left */
.con05__left {
    justify-content: center;
}
.con05_head {
    color: #fff;
    font-family: "Impact";
    font-size: var(--titleL);
    font-style: normal;
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.005em;
}

.con05 .card-chip {
    width: 22rem;
    height: 6.8rem;
    background: #000;
    color: #fff;
    font-size: var(--headS);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.05em;
    border-radius: 9.9rem;
}

.con05 .card-text {
    color: #fff;
    font-size: var(--bodyM);
    font-weight: 500;
    line-height: 1.54;
    letter-spacing: -0.05em;
}

/* con05 right */
.con05__right {
    width: 35.4rem;
    justify-content: center;
}

.con05_06 {
    z-index: 2;
}

.con05v {
    top: 0.6rem;
    height: 67rem;
    aspect-ratio: 9/16;
    clip-path: inset(0 1.5rem round 5rem 5rem 0 0);
}

/* con05 stickers */
.con05_01 {
    top: 18.3rem;
    left: 115.4rem;
    z-index: 3;
}

/* character */
.con05 .c1 {
    top: 56.4rem;
    left: calc(66.66% - 104.3rem);
    z-index: 3;
}

.con05 .c2 {
    top: 34.3rem;
    right: calc(-37% - 5rem);
    z-index: 3;
}

.con05_03 {
    transform: translateX(-2rem);
}
.con05_02 {
    transform: translateX(2rem);
}

/* ------------------ con06 ----------------------- */
.con06 {
    padding: 20rem 0;
    background: var(--tertiary);
}

.con06 .card {
    overflow: hidden;
    border-radius: 5rem;
}

.con06 .card-1 {
    z-index: 1;
    transform: translateX(100%) scale(0.97);
}

.con06 .card-2 {
    z-index: 3;
}
.con06 .card-3 {
    z-index: 2;
    transform: translateX(-100%) scale(0.97);
}

.con06_04 {
    top: 62.5rem;
    left: 11.7rem;
    z-index: 5;
}

.con06_05 {
    top: 30rem;
    right: 12.5rem;
    z-index: 5;
}
.con06_fries {
    inset: 0 0 0 0;
    z-index: 1;
}

.con06 .fries {
    will-change: transform, top, left;
}

/* --------------------- con07 ---------------------- */
.con07 {
    background: linear-gradient(to bottom, #dcd0ca, #e4dbd6);
}

.con07__text {
    top: 25.6rem;
    right: 23.6rem;
    text-align: end;
}

.con07__head {
    font-size: var(--titleL);
    line-height: 1.1;
}

.con07__desc {
    font-size: var(--subhead);
    line-height: 1.46;
}

/* ---------------------- con08 --------------------- */

.con08 {
    padding: 13.5rem 0;
    transition: all 0.6s;
}

/* .con08:has(.s2.swiper-slide-active) {
    background-color: #e4e4e4;
} */

.con08__head {
    font-size: var(--bodyL);
    line-height: 1;
}

.con08 .text__head {
    font-size: var(--headL);
    line-height: 1.15;
}

.con08 .text__body {
    font-size: var(--bodyM);
    line-height: 1.45;
}

.con08 .swiper-slide {
    display: block;

    .inner {
        height: 100%;
        justify-content: center;
        width: 157rem;
        margin: 0 auto;
        background-image: linear-gradient(to left, #fae7dc 2px, transparent 2px), linear-gradient(to bottom, #fae7dc 2px, transparent 2px);
        background-size: 2.4rem 2.4rem;
        background-color: var(--bg-color);
        border-radius: 5rem;
        overflow: hidden;
        padding: 5rem 0;
        box-sizing: border-box;
    }

    .slide__topping {
        display: grid;
        gap: 2rem 1rem;
        box-sizing: border-box;
        padding: 4.8rem;
        background-color: #fff;
        border-radius: 5rem;
        height: 57rem;

        .grid-item {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;

            p {
                text-align: center;
            }
        }

        .con08_02_12 img {
            width: 4.7rem;
        }
    }
    .t1 {
        grid-template-columns: repeat(3, 1fr);

        .sticker_01 {
            top: 12.6rem;
            left: 11rem;
        }
        .sticker_02 {
            top: 29.2rem;
            left: 11rem;
        }
        .sticker_03 {
            top: 29.2rem;
            left: 37rem;
        }
        .sticker_new {
            top: 45.6rem;
            left: 23rem;
        }
    }
    .t2 {
        grid-template-columns: repeat(4, 1fr);
        min-width: 64.4rem;
        width: 64.4rem;
        .sticker_01 {
            top: 12.6rem;
            left: 11rem;
        }
        .sticker_02 {
            top: 12.6rem;
            left: 37.8rem;
        }
        .sticker_03 {
            top: 29.2rem;
            left: 52.2rem;
        }
        .sticker_new {
            top: 47.6rem;
            left: 37.8rem;
        }
        .sticker_new2 {
            top: 47.6rem;
            left: 55.2rem;
        }
    }

    .sticker {
        display: flex;
    }
}
.con08 .swiper-slide.s2 .t2 {
    display: flex;
    padding: 0;
    overflow: hidden;
}

.con08_01_00,
.con08_02_00,
.con08_03_00 {
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
}

.con08_08.prev {
    top: 50%;
    left: 12.8rem;
    transform: scaleX(-1) translate(0, -50%);
    &:hover {
        transform: scaleX(-1) translate(0, -50%) scale(1.1);
    }
}
.con08_08.next {
    top: 50%;
    right: 12.8rem;
    transform: translate(0, -50%);

    &:hover {
        transform: translate(0, -50%) scale(1.1);
    }
}
.con08_08 {
    transition: opacity 0.2s;
    cursor: pointer;
    z-index: 2;
    transition: all 0.2s;
}
.con08_08.swiper-button-disabled {
    opacity: 0;
    cursor: initial;
}

/* ---------------------- con09 --------------------- */

.con09 {
    background-image: url(./../_files/con09_bg.webp);
    background-repeat: no-repeat;
    color: #fff;
    padding: 10rem 0;
    background-size: cover;
}

.con09 .left {
    justify-content: center;
}
.con09 .wrap {
    justify-content: center;
    gap: 24rem;
}
.con09__head {
    font-size: var(--titleL);
    line-height: 1.1;
}

.con09__head .orange {
    color: var(--secondary);
}
.con09__text {
    font-size: var(--bodyL);
    line-height: 1.5;
}

.con09 .round {
    border-radius: 5rem;
    overflow: hidden;
}

.con09 .r1 {
    align-items: end;
}

.con09_03 {
    top: 77.6rem;
    left: 76.3rem;
}

.con09_04 {
    top: 13.1rem;
    right: 8.9rem;
}

/* ----------------------- con10 --------------------- */
.con10 {
    background-color: #ffd13b;
}

.con10 .wrap {
    align-items: end;
    padding: 16.2rem 36.1rem 0 0;
    height: 100rem;
    box-sizing: border-box;
    z-index: 3;
}

.con10__head {
    font-size: var(--titleL);
    line-height: 1.1;
    text-align: end;
}

.con10_bg_1 {
    top: 0;
    left: 0;
}
.con10_bg_2 {
    top: 0;
    right: 0;
}

.con10 .body__top {
    font-size: var(--headL);
    line-height: 1.16;
    text-align: end;
}
.con10 .box {
    padding: 2rem 3.4rem;
    background-color: #000;
    color: rgba(255, 255, 255, 0.2);
    width: fit-content;
    border-radius: 999px;
    font-size: var(--headS);
    line-height: 1;
    transition: all 0.3s;
}

.con10 .box.active {
    color: #fff;
}
.con10_01 {
    top: 13.6rem;
    left: 36rem;
    z-index: 2;
}

.con10v {
    top: 13.6rem;
    left: 36rem;
    width: 42rem;
    height: 75.5rem;
    object-fit: contain;
    overflow: hidden;
    border-radius: 7.3rem;
}

.con10_02 {
    top: 43rem;
    left: 90rem;
}

#con10_line {
    top: 47.2rem;
    left: 121rem;
    z-index: 2;
}

/* ---------------------- con11 ----------------------- */

.con11 {
    background-image: url(./../_files/con11_bg.webp);
    background-repeat: no-repeat;
    background-size: cover;
    color: #fff;
    padding: 16.8rem 0 0;
}

.con11 .wrap {
    padding-bottom: 15rem;
}

.con11__head {
    font-size: var(--titleM);
    line-height: 1;
    font-weight: 900;
}

.con11__subhead {
    font-size: var(--bodyL);
    line-height: 1;
}

.con11 .menu__tab {
    flex-wrap: wrap;
    max-width: 120rem;
    justify-content: center;
    row-gap: 3rem;
}

.con11 .tab__item {
    cursor: pointer;
}

.con11 .tab__item.active .checkbox {
    border-color: var(--secondary);

    .check_ico {
        opacity: 1;
    }
}

.con11 .menu__tab .desc {
    font-size: var(--bodyL);
    font-weight: 700;
    line-height: 1;
}
.con11 .menu__tab .checkbox {
    width: 2.4rem;
    height: 2.4rem;
    background-color: transparent;

    border: 2px solid #fff;
    transition: all 0.2s;

    .check_ico {
        top: -35%;
        left: 20%;
        opacity: 0;
        transition: all 0.2s;
    }
}

.con11_01 {
    top: 13.8rem;
    left: 59.4rem;
}
.con11_02 {
    top: 26.4rem;
    left: 67rem;
}

.con11 .menu {
    flex-wrap: wrap;
    width: calc(36rem * 3 + 4.8rem);
    text-align: center;
    display: none !important;
    overflow: hidden;
    padding-bottom: 10rem;
    justify-content: flex-start;
    align-items: flex-start;

    &.active {
        display: flex !important;
    }
}

.con11 .menu__item {
    width: 36rem;
    height: 28rem;
    box-sizing: border-box;
    padding: var(--size-12);
    border: 1px solid #fff;
    transition: all 0.2s;
    background: #c4221f;

    .item__img {
        height: 13.8rem;
        width: auto;
        max-width: 100%;

        > img {
            width: auto !important;
            height: 100%;
        }
    }

    .item__name {
        color: var(--secondary);
        line-height: 1;
        font-size: var(--bodyL);
        font-weight: 800;
    }

    .item__desc {
        font-size: var(--bodyXS);
        line-height: 1;
    }

    &:hover {
        border-color: var(--secondary);
        background-color: #af130f;
    }
}

.con11 .more-btn {
    padding: 1.6rem 5.2rem;
    border: 1px solid #fff;
    border-radius: 999px;
    cursor: pointer;
    bottom: 12rem;

    transition: all 0.3s;

    img {
        transition: filter 0.3s;
    }

    &:hover {
        background-color: #fff;
        color: #000;

        img {
            filter: invert(1);
        }
    }
}

.con11_06_01 {
    top: 0%;
    left: 19.4rem;
    transform: translateY(-50%);
}

.con11_06_02 {
    top: -4rem;
    left: 0rem;
}

.con11_06_03 {
    left: 0;
    top: 56rem;
}
.con11_06_12 {
    top: -7rem;
    right: 44rem;
}

.con11_06_05 {
    left: 0;
    bottom: 32rem;
}

.con11_06_06 {
    bottom: -15rem;
    z-index: 2;
}

.con11_06_07 {
    top: 31rem;
    right: -6rem;
}

.con11_06_08 {
    top: -13rem;
    right: 0rem;
}
.con11_06_09 {
    top: 44rem;
    right: 0rem;
}
.con11_06_10 {
    top: 73rem;
    right: 20.6rem;
}
.con11_06_11 {
    bottom: -20rem;
    right: -30rem;
    z-index: 2;
}

.con11_05.marquee {
    width: 100%;
    z-index: 1;
}
.con11_05 img {
    animation: marqueeX 20s infinite linear;
}

/* ---------------- con12 ----------------- */

.con12 .wrap {
    padding: 11.7rem 0;
}

.con12 .rect {
    background-color: var(--bg-color);
    width: 100%;
    height: 67.2rem;
    z-index: -1;
}

.con12__head {
    text-align: center;
    font-size: var(--headL);
    line-height: 1.3;
    font-weight: 900;
}

.con12 .video_wrap {
    max-width: 168rem;
    margin: 0 auto;
    gap: 2px;
    background-color: #fff;
}

.con12 .con12v {
    height: 58rem;
}

.con12 .video__text {
    align-items: center;

    color: #fff;

    .kr {
        font-size: 4.5rem;
        line-height: 1;
    }

    .en {
        font-size: 4rem;
        line-height: 1;
        font-style: italic;
    }
}

.con12 .box {
    flex: 1 1 0;
    transition: all 0.3s;
    overflow: hidden;

    &:hover {
        flex: 2 1 0;
    }
}

/* ----------------------- con13 --------------------- */

.con13 .text-wrap {
    font-size: var(--titleL);
    line-height: 1;

    .t {
        z-index: 2;
        display: block;
    }

    .line {
        top: 0;
        display: block;
        width: 120%;
        height: 106%;
        background-color: var(--primary);
        z-index: 1;
    }
}

.con13v {
    width: 100%;

    iframe {
        width: 100vw;
        height: 100svh;
        scale: 125%;
    }
}

/* --------------------- con14 -------------------------- */
.con14 {
    background-color: var(--bg-color);
}

.con14 .wrap {
    padding: 15rem 0;
}
.con14__head {
    font-size: var(--headL);
    font-weight: 900;
    line-height: 1;
}

.con14__body {
    font-size: var(--bodyL);
    line-height: 1.5;
    text-align: center;
}
.con14_swiper .swiper-slide {
    display: flex;
    width: fit-content;
    transition: opacity 0.4s, filter 0.4s;
    opacity: 0.45;
    filter: blur(5px);
}
.con14_swiper .swiper-slide-prev,
.con14_swiper .swiper-slide-next {
    opacity: 0.6;
    filter: blur(3px);
}
.con14_swiper .swiper-slide-active {
    opacity: 1;
    filter: none;
}
.con14_swiper_next {
    top: 50%;
    transform: translateY(-50%);
    right: 11rem;
    z-index: 2;
}
.con14_swiper_prev {
    top: 50%;
    transform: translateY(-50%);
    left: 11rem;
    z-index: 2;

    > img {
        transform: scaleX(-1);
    }
}

/* ------------------ con15 ------------------ */
.con15 {
    background-color: #000;
    cursor: none;
    padding: 14rem 0;
    color: #fff;
}

.head__subhead {
    font-size: var(--bodyL);
    line-height: 1;
}

.con15_swiper {
    padding: 7rem 0;
    color: #000;
}

.con15_swiper .swiper-wrapper {
    will-change: transform;
}

.con15_swiper .swiper-slide {
    position: relative;
    height: 60rem;
    width: 79rem;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    border-radius: 5rem;
    user-select: none;
    filter: blur(2px) brightness(0.5);
    /* pointer-events: none; */
    cursor: none;
    will-change: transform, filter;

    a {
        pointer-events: none;
    }

    &.swiper-slide-active {
        filter: none;
        cursor: pointer;
        pointer-events: auto;
        a {
            pointer-events: auto;
        }
    }
}

.con15_swiper iframe {
    width: 150%;
    height: 150%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border: none;
    position: absolute;
    transform: scale(0.9);
}

.con15 .swiper-slide .slide__text-wrap {
    text-align: center;
    bottom: 0;
    left: 0;
    z-index: 2;
    box-sizing: border-box;
    padding: 0 8rem;
    opacity: 0;
    height: 0;
    overflow: hidden;
    transition: all 0.3s;

    background-color: var(--secondary);
    .head {
        font-size: var(--bodyM);
        font-weight: 800;
        line-height: 1;
    }

    .text {
        font-size: var(--bodyXS);
        line-height: 1.3;
    }
}
.con15 .swiper-slide-active .slide__text-wrap {
    opacity: 1;
    height: 15rem;
}

/* pagination bullet */
.con15 .swiper-pagination-bullet {
    width: 1.6rem;
    height: 1.6rem;
    background: #777;
    opacity: 1;
    transition: background 0.3s;
}
.con15 .swiper-pagination-bullet-active {
    opacity: 1;
    background: var(--secondary);
}

.con15__pointer {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    pointer-events: none;
    user-select: none;
    opacity: 0;
}

/* ------------------- con16 ---------------------- */

.con16 {
    background: url(./../_files/con16_bg.webp) no-repeat center / cover;
    padding: 13rem 0;
    cursor: none;
}

.con16__head {
    font-size: var(--titleL);
    line-height: 1.1;
}

.con16_swiper {
    padding: 3rem 0 3rem;
}

.con16 .swiper-slide video {
    width: 31rem;
    height: 64rem;
    clip-path: inset(0 0 round 5rem);
}

.con16 .swiper-slide {
    display: block;
    width: fit-content;

    a {
        justify-content: center;
        user-select: none;
        pointer-events: none;

        backface-visibility: hidden;
        -webkit-backface-visibility: hidden;
        transform-style: preserve-3d;
        will-change: transform;
        transform: scale(0.8);

        transition: all 0.5s ease-out;
    }

    &:nth-of-type(2n) a {
        transform: translateY(-4rem) scale(0.8);
    }
    &:nth-of-type(2n-1) a {
        transform: translateY(3rem) scale(0.8);
    }

    &.swiper-slide-active {
        a {
            position: relative;
            transform: translateY(0) scale(1) !important;
            pointer-events: initial;

            &::after {
                content: "";
                display: block;
                position: absolute;
                inset: -2rem -2rem;
            }
        }
    }
}

.con16_01 {
    user-select: none;
    pointer-events: none;
}

/* --------------------- con17 ------------------- */
.con17 {
    background-color: #22140d;
    color: #fff;
    padding: 12.3rem 0 9rem;
}

.con17__head {
    font-size: var(--headL);
    font-weight: 900;
}

.con17_swiper {
    padding: 5rem 0;
}

.con17 .swiper-slide {
    --bt: 0.5;
    width: fit-content;
    user-select: none;
    > div {
        filter: brightness(var(--bt)) blur(3px);
        overflow: hidden;
        width: fit-content;
        border-radius: 5rem;
        display: flex;
        transition: all 0.3s;
        will-change: transform, filter;
    }
    &.swiper-slide-fully-visible {
        > div {
            filter: brightness(var(--bt)) blur(2px);
        }
    }

    &.swiper-slide-prev-prev-prev {
        > div {
            transform: scale(1.2) translateX(-2.6rem);
        }
    }
    &.swiper-slide-prev-prev {
        > div {
            transform: scale(0.95) translateX(6.8rem);
        }
    }
    &.swiper-slide-prev-prev {
        > div {
            transform: scale(0.97) translateX(5.8rem);
        }
    }
    &.swiper-slide-prev {
        > div {
            transform: scale(0.83) translateX(5rem);
        }
    }
    &.swiper-slide-next {
        > div {
            transform: scale(0.83) translateX(-5rem);
        }
    }
    &.swiper-slide-next-next {
        > div {
            transform: scale(0.97) translateX(-5.8rem);
        }
    }
    &.swiper-slide-next-next + .swiper-slide {
        > div {
            transform: scale(1.2) translateX(2.6rem);
        }
    }

    &.swiper-slide-active {
        > div {
            filter: brightness(1);
            /* transform: scale(1.1); */
        }
    }
}

/* swiper btn */
.con17_04 {
    transition: all 0.3s;
    transform-origin: center;
    user-select: none;
}

.con17 .btn-left {
    top: 50%;
    left: 71rem;
    z-index: 3;
    transform: translateY(-50%);
    cursor: pointer;

    &:hover {
        transform: translateY(-50%) scale(1.2);
    }
}
.con17 .btn-right {
    top: 50%;
    left: 114rem;
    z-index: 3;
    transform: scaleX(-1) translateY(-50%);
    cursor: pointer;

    &:hover {
        transform: scaleX(-1) translateY(-50%) scale(1.2);
    }
}

/* sticker */
.con17_02 {
    top: 21rem;
    left: 24.6rem;
}
.con17_03 {
    top: 76rem;
    left: 150.5rem;
}

/* ---------------- con18 ----------------- */
.con18 {
    background-color: #000;
    color: #fff;
}

.con18 .wrap-1 .inner {
    justify-content: center;
    z-index: 2;
}

.con18_01 {
    background-color: var(--secondary);
    padding: 2.4rem 0;
    justify-content: end;
    width: 100%;

    > img {
        animation: marqueeX_r 20s infinite linear;
    }
}

.con18 .line {
    width: 1px;
    height: 6.6rem;
    background-color: rgba(255, 255, 255, 0.3);
}

.con18v {
    top: 0;
    filter: brightness(0.3);
    width: 100%;
    height: 100%;
    overflow: hidden;

    iframe {
        width: 200vw;
        height: 95rem;
        scale: 125%;
    }
}

.con18 .text__head {
    font-size: var(--titleM);
    line-height: 1.2;
    font-weight: 900;
}

.con18 .text__body {
    font-size: var(--bodyL);
    line-height: 1.5;
}

/* wrap general */
.con18 .wrap {
    &:not(.wrap-1) {
        padding: 12.6rem 0 10.4rem;
    }
}
.con18__wrap-text {
    font-size: var(--bodyL);
    line-height: 1;
}

.con18 .wrap .swiper {
    max-width: 113.8rem;
    margin: 0 auto !important;
}

/* m3 carousel style swiper */
.con18_swiper-1,
.con18_swiper-2,
.con18_swiper-3 {
    height: 47.7rem;
    user-select: none;

    .swiper-slide {
        width: 68.6rem;
        display: flex;

        > div {
            overflow: hidden;
            border-radius: 5rem;
            height: 100%;
            width: 100%;
            filter: brightness(0.3);
            transition: all 0.3s;
            img {
                height: 100%;
            }
        }

        &.swiper-slide-active {
            > div {
                filter: brightness(1);
            }
        }

        &.swiper-slide-prev {
            > div {
                width: 9rem;
                overflow: hidden;
                transform: translateX(28rem);
            }
        }
        &.swiper-slide-prev-prev {
            > div {
                width: 9rem;
                overflow: hidden;
                transform: translateX(86rem);
            }
        }
        &.swiper-slide-next {
            > div {
                width: 9rem;
                overflow: hidden;
                transform: translateX(-28rem);
            }
        }
        &.swiper-slide-next-next {
            > div {
                width: 9rem;
                overflow: hidden;
                transform: translateX(-86rem);
            }
        }
    }
}

.con18 .wrap-2 {
    background-color: var(--primary);
}

.con18 .wrap-3 {
    background-color: #d92622;
}

.con18 .wrap-4 {
    background-color: var(--tertiary);
}

.con18 .swiper-btn {
    user-select: none;
    .con18_09 {
        z-index: 3;
        transition: all 0.2s;
        cursor: pointer;
    }
    .btn-left {
        top: 34rem;
        left: 31rem;

        &:hover {
            transform: scale(1.1);
        }
    }
    .btn-right {
        top: 34rem;
        right: 31rem;
        transform: scaleX(-1);

        &:hover {
            transform: scaleX(-1) scale(1.1);
        }
    }
}

/* ------------------ con19 --------------------- */
.con19 .typing {
    text-align: center;
    font-size: var(--headL);
    line-height: 1.3;
    font-weight: 900;
    background-color: #f4f0e5;
    padding: 12.3rem 0 13.7rem;
}

.con19__left,
.con19__right {
    flex: 1 1 0;
    min-width: 0;
    justify-content: center;
}

.con19 .wrap {
    padding: 11.7rem 0;
}

/* left */
.con19__left {
    align-items: end;
}

.con19 .gsap-rolling {
    width: 84rem;
    height: 80rem;
    overflow: hidden;
    border-radius: 5rem;
}

/* right */
.con19 .right__text {
    .text-head {
        font-size: var(--headM);
        line-height: 1;
        font-weight: 740;
    }
    .text-body {
        font-size: var(--bodyL);
        line-height: 1.5;
    }
}

.con19__right .con19_swiper {
    width: 82.4rem;

    .swiper-slide {
        align-items: start;
    }
    .slide__img {
        width: 100% !important;
        box-sizing: border-box;
        border: 1px solid #dbdcde;
        user-select: none;
    }
    .slide__text {
        .desc {
            font-size: var(--bodyS);
            line-height: 1.5;
        }
        .price {
            font-size: var(--subhead);
            line-height: 1;
        }
    }
}

.con19 .swiper-btn {
    user-select: none;

    .con19_05 {
        z-index: 3;
        transition: all 0.2s;
        cursor: pointer;
    }

    .btn-left {
        top: 50rem;
        left: 97.2rem;
        transform: scaleX(-1);

        &:hover {
            transform: scaleX(-1) scale(1.1);
        }
    }

    .btn-right {
        top: 50rem;
        right: 5rem;

        &:hover {
            transform: scale(1.1);
        }
    }

    .swiper-button-disabled {
        opacity: 1;
        filter: invert(1) grayscale(1);
        pointer-events: none;
    }
}

/* ---------------------- con20 ---------------------- */
.con20 {
    background: url(./../_files/con20_bg.webp) no-repeat center / cover;
    padding: 12rem 0;
}

.con20 .map__wrap {
    background-color: #fff;
    border-radius: 5rem;
    max-width: 168rem;
    margin: 0 auto !important;
    box-sizing: border-box;
    padding: 8.6rem 6.2rem;
}

.con20_04 {
    transform-origin: center;
}

.con20__text {
    justify-content: center;

    .text__head {
        font-size: var(--headS);
        line-height: 1.4;
        width: fit-content;
    }
    .line {
        height: 1px;
        background: rgba(0, 0, 0, 0.15);
    }

    .text__body {
        font-size: var(--bodyXS);
        line-height: 1.66;
    }

    .blue {
        color: #102e92;
    }
}

.con20__map {
    .bubble-1 {
        top: 14.1rem;
        left: 30rem;
    }
    .bubble-2 {
        top: 23.6rem;
        left: 35rem;
    }
    .bubble-3 {
        top: 11.4rem;
        left: 45rem;
    }
    .bubble-4 {
        top: 25.6rem;
        left: 40.6rem;
    }
    .bubble-5 {
        top: 12.2rem;
        left: 64.7rem;
    }
}

/* ------------------ con21 ------------------ */
.con21 .parallax {
    width: 100%;
    height: 100rem;
    overflow: hidden;
    color: #fff;
}

.con21__text {
    .text-head {
        font-size: var(--titleL);
        line-height: 1.1;
        text-transform: uppercase;
    }

    .text-body {
        text-align: center;
        font-size: var(--bodyL);
        line-height: 1.5;
    }
}

/* --------------------- con22 ------------------- */

.con22__left,
.con22__right {
    min-width: 0;
}

.con22 .gsap-rolling {
    width: 96rem;
    overflow: hidden;

    .rolling-wrapper {
        width: 100%;
        will-change: transfrom;
        > div {
            flex-shrink: 0;
        }
    }
}

.con22__right {
    padding-left: 14rem;
}
.con22 .right__text {
    justify-content: center;

    .text-head {
        font-size: var(--titleL);
        line-height: 1.1;
        text-transform: uppercase;

        > span {
            width: fit-content;
        }
    }

    .text-body {
        font-size: var(--bodyM);
        line-height: 1.5;
    }
}

.con22_02 {
    top: 0;
    right: 5rem;
    z-index: 2;
    height: 100%;
    justify-content: end;

    img {
        animation: marqueeY_r 20s infinite linear;
    }
}

/* ------------------- con23 ------------------------- */
.con23 {
    background: url(./../_files/con23_bg.webp) no-repeat center / cover;
    padding: 25rem 0 12.6rem;
    overflow: hidden;
}

.con23__marquee {
    .mq-slide {
        animation: marqueeX 10s infinite linear;
        padding-left: 2.4rem;
    }
}

.con23__marquee-r {
    justify-content: end;
    .mq-slide {
        animation: marqueeX_r 10s infinite linear;
        padding-left: 2.4rem;
    }
}

.con23__text {
    text-align: center;
    font-size: var(--bodyM);
}

.con23_01 {
    top: 13.7rem;
}
.con23_02 {
    top: 13.7rem;
}

/* ------------------------ con24 ------------------------ */
.con24__left {
    background: url(./../_files/con24_bg_1.webp) no-repeat center/cover;
    flex: 1 1 0;
    padding: 19rem 0 0;
}
.con24_02 {
    z-index: 3;
    pointer-events: none;
}

.con24__left-text {
    top: 14rem;
    left: 52%;
    transform: translate(-50%);
    font-size: var(--subhead);
}

.con24_swiper {
    width: 33.2rem;
    /* height: 62.3rem; */
    border-radius: 4rem 4rem 0 0;
    overflow: hidden;

    bottom: 12.7rem;
    left: 11.4rem;

    video {
        aspect-ratio: 9/16;
    }
}
/* swiper btn */
.con24_03 {
    transition: all 0.2s;
    user-select: none;

    &.btn-left {
        top: 47.7rem;
        left: 25.1rem;

        &:hover {
            transform: scale(1.1);
        }
    }
    &.btn-right {
        top: 47.7rem;
        right: 21.3rem;
        transform: scaleX(-1);

        &:hover {
            transform: scaleX(-1) scale(1.1);
        }
    }
}

.con24__right {
    background-color: var(--bg-color);
    width: 96rem;

    .text-head {
        font-size: var(--headL);
        font-weight: 900;
    }

    .text-body {
        font-size: var(--bodyM);
    }

    .insta,
    .yt,
    .naver {
        transition: all 0.2s;
        will-change: transform;

        &:hover {
            transform: scale(1.1);
        }
    }
}

.con24_04 {
    top: 24rem;
    left: 71rem;
    z-index: 4;
}
.con24_05 {
    top: 76rem;
    left: 8rem;
    z-index: 4;
}

.con24bg2 {
    bottom: 0;
}

/* -------------------- con25 ------------------- */
.con25 {
    height: 100rem;
}

.con25__left {
    background: url(./../_files/con25_bg.webp) no-repeat center/cover;
    flex: 1 1 0;
    color: #fff;
    box-sizing: border-box;
}

.con25__left .left-tel {
    .con25_01 {
        transition: all 0.2s;
        will-change: transform;
    }

    &:hover {
        .con25_01 {
            transform: scale(1.1);
        }
    }
}

.con25__right {
    width: 96rem;
    background-color: #000;
    color: #fff;

    .inner {
        width: 58.5rem;
    }
}

.con25__right .form-wrap {
    font-size: var(--bodyM);
}

.form_submit_div {
    background-color: var(--secondary);
    padding: 2.4rem 0;

    color: #000;
}

.con25 input {
    font-family: inherit;
    letter-spacing: inherit;
    font-size: var(--bodyS);
    box-sizing: border-box;

    &[type="text"],
    &[type="email"],
    &[type="tel"] {
        width: 39rem;
        padding: 1.8rem 1rem;
        background-color: transparent;
        border: 1px solid #fff;
        color: #fff;
    }

    &:focus {
        outline: none;
        border: 1px solid var(--secondary);
    }
}
.con25__body {
    font-size: var(--bodyM);
}

.con25 .form_index-label {
    padding-top: 2rem;
}

.con25 textarea {
    font-family: inherit;
    letter-spacing: inherit;
    width: 39rem;
    height: 22rem;
    font-size: var(--bodyS);
    padding: 1.8rem 1rem;
    background-color: transparent;
    border: 1px solid #fff;
    color: #fff;
    box-sizing: border-box;
    resize: none;

    &:focus {
        outline: none;
        border: 1px solid var(--secondary);
    }
}

.con25 label {
    display: flex;
    height: fit-content;
    gap: 1.8rem;

    &::before {
        content: "";
        display: inline-flex;
        align-self: center;
        width: 6px;
        height: 6px;
        background-color: var(--secondary);
        border-radius: 99px;
    }
}

.con25_03 {
    top: 6rem;
    left: 91rem;
}
.con25_04 {
    top: 75.8rem;
    right: 7rem;
}
