@font-face {
  font-family: 'Days Sans Black';
  src: url('/content/dam/embed/interactive-map/assets/font/DaysSansBlack.woff2') format('woff2'),
       url('/content/dam/embed/interactive-map/assets/font/DaysSansBlack.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* ========= common ========= */
.intractive{ 
  --ease-in-quad: cubic-bezier(0.550, 0.085, 0.680, 0.530);
  --ease-in-cubic: cubic-bezier(0.550, 0.055, 0.675, 0.190);
  --ease-in-quart: cubic-bezier(0.895, 0.030, 0.685, 0.220);
  --ease-in-quint: cubic-bezier(0.755, 0.050, 0.855, 0.060);
  --ease-in-sine: cubic-bezier(0.470, 0.000, 0.745, 0.715);
  --ease-in-expo: cubic-bezier(0.950, 0.050, 0.795, 0.035);
  --ease-in-circ: cubic-bezier(0.600, 0.040, 0.980, 0.335);
  --ease-in-back: cubic-bezier(.600, -0.280, 0.735, 0.045);
  --ease-out-quad: cubic-bezier(0.250, 0.460, 0.450, 0.940);
  --ease-out-cubic: cubic-bezier(0.215, 0.610, 0.355, 1.000);
  --ease-out-quart: cubic-bezier(0.165, 0.840, 0.440, 1.000);
  --ease-out-quint: cubic-bezier(0.230, 1.000, 0.320, 1.000);
  --ease-out-sine: cubic-bezier(0.390, 0.575, 0.565, 1.000);
  --ease-out-expo: cubic-bezier(0.190, 1.000, 0.220, 1.000);
  --ease-out-circ: cubic-bezier(0.075, 0.820, 0.165, 1.000);
  --ease-out-back: cubic-bezier(0.18, 0.89, 0.33, 1.55);
  --ease-inout-quad: cubic-bezier(0.455, 0.030, 0.515, 0.955);
  --ease-inout-cubic: cubic-bezier(0.645, 0.045, 0.355, 1.000);
  --ease-inout-quart: cubic-bezier(0.770, 0.000, 0.175, 1.000);
  --ease-inout-quint: cubic-bezier(0.860, 0.000, 0.070, 1.000);
  --ease-inout-sine: cubic-bezier(0.445, 0.050, 0.550, 0.950);
  --ease-inout-expo: cubic-bezier(1.000, 0.000, 0.000, 1.000);
  --ease-inout-circ: cubic-bezier(0.785, 0.135, 0.150, 0.860);
  --ease-inout-back: cubic-bezier(.680, -0.550, 0.265, 1.550);
  --ease-out-slide: cubic-bezier(0.230, 1.000, 0.320, 1.000);

  --foot-height: 0px;
}

.intractive{ font-family: 'Gotham'; overflow: hidden; position: relative; width: 100%; max-width: 1600px; margin: 0 auto; }
.intractive h1, 
.intractive h2, 
.intractive h3, 
.intractive h4, 
.intractive h5, 
.intractive h6, 
.intractive p{ margin: 0; }
.intractive *{ box-sizing: border-box; }
.intractive ul{ list-style: none; }
.intractive ul, 
.intractive li{ margin: 0; padding: 0; }
.intractive button{ cursor: pointer; border: none; outline: none; box-shadow: none; }
.intractive section{ /* overflow: hidden; */ position: absolute; width: 100%; height: 100%; padding: 40px 56px calc(var(--foot-height, 0px) + 40px); }
.intractive .inner{ display: flex; flex-direction: column; justify-content: space-between; align-items: flex-start; gap: 40px; height: 100%; }

/* button */
.intractive .btn-link{ 
  min-width: 258px; min-height: 50px; padding: 12px 32px;
  background: #0F3133; border-radius: 0 26px 26px 26px;
  color: #fff; font-size: 22px; font-weight: 700; line-height: 26px;
  text-transform: uppercase; 
  /* transition: all .2s ease-in; */
  transition: transform .2s ease-in, background .2s ease-out;
}
/* .intractive .btn-link:hover{ transform: scale(1.05) !important; } */
.intractive .btn-link:hover{ background: #027982; }
.intractive .btn-back{ width: 36px; height: 36px; margin-bottom: 12px; background: #000 url('/content/dam/embed/interactive-map/assets/images/icon-back.svg') no-repeat center center / contain; border-radius: 50%; font-size: 0; }

/* graphics */
.intractive .graphics .lottie{ position: absolute; top: 50%; left: 50%; transform: translate3d(-50%, -50%, 0); z-index: 2; width: 100%; height: 100%; }
.intractive .graphics .lottie > div{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.intractive .graphics .lottie .lottie-1 { z-index: 1; }
.intractive .graphics .lottie .lottie-2 { z-index: 2; }
.intractive .graphics .lottie .lottie-3 { z-index: 3; }
.intractive .graphics .lottie .lottie-4 { z-index: 4; }
.intractive .graphics .lottie .lottie-5 { z-index: 5; }
/* 크롬에서 SVG 렌더링 최적화 */
.intractive .graphics .lottie svg {
  pointer-events: none;
  /* 크롬에서 SVG 렌더링 최적화 */
  will-change: transform;
  transform: translateZ(0);
  backface-visibility: hidden;
  perspective: 1000px;
  /* GPU 가속 활성화 */
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
  -ms-transform: translateZ(0);
  -o-transform: translateZ(0);
}
/* 로띠 컨테이너 최적화 */
.intractive .graphics .lottie > div {
  /* 크롬에서 렌더링 성능 향상 */
  will-change: transform;
  transform: translateZ(0);
  /* GPU 가속 활성화 */
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
  -ms-transform: translateZ(0);
  -o-transform: translateZ(0);
}

/* info */
.intractive .foot-info{ 
  position: absolute; bottom: 0; left: 0; width: 100%; padding: 15px 24px; 
  background: rgba(255, 255, 255, 0.5); backdrop-filter: blur(4px); 
  color: #3F4145; font-size: 12px; font-weight: 400; line-height: 1.33; text-align: center;
}
/* texts */
.intractive .texts{ position: relative; z-index: 1; }
.intractive .texts .title{ font-size: 50px; line-height: 1.04; }
.intractive .texts .title span{ display: block; }
.intractive .texts .desc{ margin-top: 12px; font-size: 20px; font-weight: 400; line-height: 1.2; }
.intractive .texts .desc span{ display: block; }
.intractive .list{ 
  --active: -1;
  --button-height: 86px;
  overflow: hidden; position: relative; margin-top: 24px; padding-left: 44px;
}
.intractive .list > ul > li > button{ display: flex; flex-direction: column; justify-content: center; height: var(--button-height); background: transparent; border: none; text-align: left; }
.intractive .list > ul > li > button > span{ display: block; margin-bottom: 2px; font-size: 22px; font-weight: 400; line-height: 1; transition: color 0.2s ease-out, font-weight 0.2s ease-out; }
.intractive .list > ul > li > button > p{ font-size: 14px; font-weight: 400; line-height: 1.28; color: #3F4145; }
.intractive .list > ul > li > button.active > span{ font-weight: 700; color: #027982; }

/* lottie */
.intractive .graphics .lottie > div{ opacity: 0; transition: opacity 0.5s 0.5s ease-out; }
.intractive .graphics .lottie > div.show{ opacity: 1; transition: .2s ease-out; }
.intractive .graphics .lottie > div.active{ opacity: 1; z-index: 9; transition: opacity .2s ease-out; } 

/* bottom-wrap */
.intractive .bottom-wrap{ position: relative; z-index: 3; }

/* --- RESPONSIVE : COMMON --- */
@media screen and (min-width: 1001px) {
  .intractive .only-m{ display: none; }

  .intractive .list::before{ content: ''; position: absolute; top: 0; left: 7px; width: 1px; height: 100%; background: #000; } 
  .intractive .list::after{ content: ''; position: absolute; top: calc(var(--active) * var(--button-height)); left: 6px; width: 3px; height: var(--button-height); background: #FB8429; transition: top 0.3s var(--ease-out-quad), height 0.3s var(--ease-out-quad); }
}
@media screen and (max-width: 1000px) {
  .intractive .only-p{ display: none; }

  .intractive section{ height: calc(100vh - 80px); min-height: 640px; max-height: 1000px; }
  .intractive .texts .title{ font-size: min(50px, 6vw); }
  .intractive .texts .desc{ font-size: min(20px, 3vw); }
  .intractive .list{ 
    --button-height: auto; overflow: visible; 
    width: calc(100% - 20px); max-width: 715px;
    padding: 52px 24px 36px;
    border: 1px solid #fff; border-radius: 20px 20px 20px 0;  background-color: rgba(255, 255, 255, 0.5);  backdrop-filter: blur(3px);
  }
  .intractive .list > ul{ display: flex; gap: 4px; position: absolute; top: -18px; left: 50%; transform: translate3d(-50%, 0, 0); }
  .intractive .list > ul > li > button{ padding: 10px 14px; border-radius: 20px; border: 1px solid #B6BFC0; background-color: #fff; /* backdrop-filter: blur(18.87152099609375px); */ box-shadow: 0px 1.57px 33.03px 0px #0000001A; }
  .intractive .list > ul > li > button span{ font-size: 13px; font-weight: 700; color: #2E372F; margin: 0; }
  .intractive .list > ul > li > button > p { display: none; }
  .intractive .list > ul > li > button.active{ border: 2px solid #2AEDE5; }
  .intractive .list > ul > li > button.active span{ color: #0F3133; }
  .intractive .list > .descriptions{ position: relative; height: 2.6em; font-size: 14px; font-weight: 400; line-height: 1.3; }
  .intractive .list > .descriptions p{ position: absolute; top: 0; left: 0; width: 100%; opacity: 0; transform: translate3d(-20px, 0, 0); transition: opacity 0.3s var(--ease-out-quad), transform 0.3s var(--ease-out-quad); }
  .intractive .list > .descriptions p.active{ position: relative; opacity: 1; transform: translate3d(0, 0, 0); animation: descriptions 0.3s var(--ease-out-quad); }
  @keyframes descriptions {
    0% { opacity: 0; transform: translate3d(20px, 0, 0);}
    100% { opacity: 1; transform: translate3d(0, 0, 0);}
  }
  .intractive section[data-lottie=''] .list > .descriptions{ height: 0 !important; }
}
@media screen and (max-width: 767px) {
  .intractive section{ min-height: 600px; max-height: 720px; padding: 26px 16px calc(var(--foot-height) + 26px); }
  .intractive .btn-link{ padding: 14px 28px; font-size: 16px; min-width: 0; min-height: 0; line-height: 1.2; white-space: nowrap; }
  .intractive .list{ max-width: 540px; }
  .intractive .foot-info{ font-size: 10px; }
}
@media screen and (max-width: 375px) {
  .intractive section{ 
    padding: 20px 14px calc(var(--foot-height, 0px) + 20px);
  }
  .intractive .btn-back{ width: 32px; height: 32px; }
}



/* ========= Map ========= */
.intractive section.map{ position: relative; background: #fff url('/content/dam/embed/interactive-map/assets/images/map/bg.png') no-repeat center center / cover; }
/* map > graphics */
.intractive section.map .graphics{ position: absolute; top: 40%; left: 50%; transform: translate3d(-50%, -50%, 0); width: 100%; aspect-ratio: 1/1; background: url('/content/dam/embed/interactive-map/assets/images/map/bg-map2.png') no-repeat center left -15% / cover; }
.intractive section.map .graphics .maps{ position: absolute; top: 50%; right: 4%; transform: translate3d(0, -38%, 0); width: 68%; aspect-ratio: 366/211; } 
.intractive section.map .graphics .maps::before{ content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%;  background: url('/content/dam/embed/interactive-map/assets/images/map/base-color.png') no-repeat center center / contain;  }
/* map > lottie */
.intractive section.map .graphics .maps .lottie{ transform: translate3d(-50%, -51.5%, 0); width: 116.5%; height: 117%; }
.intractive section.map .graphics .maps .lottie .lottie-2 .btn-link{ position: absolute; z-index: 9; background: #F95E4A; top: 66%; left: 67%; font-size: 16px; }
.intractive section.map .graphics .maps .lottie .lottie-2 .btn-link:hover{ background: #FB8429; }
.intractive section.map .graphics .maps .lottie-2 .btn-link{ pointer-events: none; transform: scale(0); transition: transform  0.2s var(--ease-out-quad), background .2s ease-out; transform-origin: top left; }
.intractive section.map .graphics .maps .lottie-2.active .btn-link{ pointer-events: auto; transform: scale(1); transition: transform  0.3s var(--ease-out-quad), background .2s ease-out;  }
/* map > bottom-wrap */
.intractive section.map .bottom-wrap{ display: flex; justify-content: space-between; align-items: flex-end; gap: 40px;position: relative; z-index: 1; width: 100%; }
/* map > summary */
.intractive section.map .summary{ display: flex; flex-direction: column-reverse; justify-content: flex-start; align-items: flex-start;position: relative; z-index: 1;  }
.intractive section.map .summary .btn-link{ position: absolute; bottom:-10px; left: 0; z-index: 1; transform-origin: top left; }
.intractive section.map .summary ul{ display: flex; gap: 36px; position: relative; }
.intractive section.map .summary ul p{ display: block; font-size: 15px; font-weight: 400; line-height: 1.4; }
.intractive section.map .summary ul strong{ display: block; margin-top: 2px; font-size: 22px; font-weight: 500 !important; line-height: 1.1; color: #0F3133; }
/* map > legend */
.intractive section.map .legend{ transition: opacity 0.3s ease-out; }
.intractive section.map .legend ul{ display: flex; gap: 11px; }
.intractive section.map .legend ul li{ display: flex; align-items: center; gap: 6px; }
.intractive section.map .legend ul li img{ height: 13px; }
.intractive section.map .legend ul li span{ display: block; font-size: 12px; font-weight: 400; white-space: nowrap; }
.intractive section.map[data-lottie=''] .legend { opacity: 0; pointer-events: none; }
/* --- RESPONSIVE : MAP --- */
@media screen and (min-width: 1001px) {
  .intractive section.map .texts{ max-width: 420px; }
  .intractive section.map .list{ max-width: 360px; }
  .intractive section.map .summary ul{ min-width: 595px; padding: 28px 35px 56px; border: 1px solid #fff; border-radius: 10px;  background-color: rgba(255, 255, 255, 0.5);  backdrop-filter: blur(3px); }
  .intractive section.map .summary ul::before{ content: ''; position: absolute; bottom: 15px; left: -1px; width: 1px; height: 90px; background: linear-gradient(360deg, #3F4145 0%, rgba(156, 161, 171, 0) 100%); }
}
@media screen and (max-width: 1000px) {
  .intractive section.map{ background: none; }
  .intractive section.map::before{ content: ''; pointer-events: none;; position: absolute; top: 0; left: 0; width: 100%; height: calc(100% - var(--foot-height)); background: #fff url('/content/dam/embed/interactive-map/assets/images/map/bg-mo.png') no-repeat center bottom / cover; } 
  .intractive section.map .texts{ width: 100%; } 
  .intractive section.map .texts .title span{ display: inline-block; }
  .intractive section.map .texts .desc span{ display: inline-block; }
  .intractive section.map .bottom-wrap{ flex-direction: column; align-items: center; }
  .intractive section.map .summary{ position: unset; margin-top: 10px; padding-top: 10px; border-top: 1px solid #3F4145; }
  .intractive section.map .summary ul{ justify-content: space-between; width: 100%; gap: 8px; }
  .intractive section.map .summary ul li p{ max-width: 75px; font-size: 12px; line-height: 1.33; }  
  .intractive section.map .summary ul li strong{ margin-top: 6px; font-size: 16px; line-height: 1; }
  .intractive section.map .summary ul li strong span{ line-height: 12px; }
  .intractive section.map .summary .btn-link{ 
    position: absolute; bottom: -17px; left: 50%; transform: translate3d(-50%, 0, 0);
    background: #fff url('/content/dam/embed/interactive-map/assets/images/map/icon-arrow-down.svg') no-repeat center center / 16px; border: 1px solid #B6C0C0;
    border-radius: 50%;
    font-size: 0; width: 36px; height: 36px; min-width: 0; min-height: 0; padding: 0;
  }
  .intractive section.map .legend{ justify-self: center; line-height: 1.2; margin: 9px auto 0; }  
  .intractive section.map .legend ul{ gap: 8px; }
  .intractive section.map .legend ul li{ gap: 4px; }
  .intractive section.map .legend ul li img{ height: 10px; }
  .intractive section.map .legend ul li span{ font-size: 9px; }
  .intractive section.map .graphics{ top: 35%; aspect-ratio: 1/1.25; background-size: 162%; background-position: 33% 50%; }
  .intractive section.map .graphics .maps{ top: 50%; right: 5%; transform: translate3d(0, -38%, 0); width: 85%; }
  .intractive section.map .graphics .maps .lottie .lottie-2 .btn-link{ 
    top: min(66%, max(18vh, 600px*0.18));
    left: calc(-3.25% + 50vw + min(50vw - 56px - 10px, 715px/2) - 258px);
  }
  .intractive section[data-lottie=''] .list{ padding-top: 32px; }
  .intractive section[data-lottie=''] .summary{ margin-top: 0; padding-top: 0; border-top: none; }
}
@media screen and (max-width: 767px) {
  .intractive section.map::after{ content: ''; position: absolute; bottom: var(--foot-height); left: 0; pointer-events: none; width: 100%; aspect-ratio: 750/438; background: url('/content/dam/embed/interactive-map/assets/images/map/bg-cloud.png') no-repeat center bottom / 100%; } 
  .intractive section.map .texts .title{ font-size: min(25px, 5.8vw); }
  .intractive section.map .texts .desc{ margin-top: 4px; font-size: min(12px, 2.8vw); }
  .intractive section.map .graphics{ top: 32%; aspect-ratio: 1/1.3; background-size: 165%; background-position: 33% 50%; }
  .intractive section.map .graphics .maps{ right: 4%; width: 86%; }
  .intractive section.map .graphics .maps .lottie .lottie-2 .btn-link{
    left: calc(1% + 50vw + min(50vw - 16px - 10px, 540px/2) - 222px);
  }
}
@media screen and (max-width: 375px) {
  .intractive section.map .texts .title{ font-size: min(23px, 6.1vw); }
  .intractive section.map .texts .desc{ font-size: min(11px, 3vw); }
}


/* .intractive section.map .graphics .lottie > div{ opacity: 1; transition: 0s 1.5s; }
.intractive section.map .graphics .lottie > div.show{ opacity: 1; transition: 0s; }
.intractive section.map .graphics .lottie > div.active{ opacity: 1; z-index: 9; transition: 0s; }  */





/* ========= Tube ========= */
.intractive section.tube{ position: absolute; top: 0; left: 0 }
/* tube > texts */
.intractive section.tube .list li strong{ display: block; } 
/* tube > pannel */
.intractive section.tube .pannel{ display: inline-block; position: relative; z-index: 1; }
.intractive section.tube .pannel .title{ font-size: 22px; font-weight: 500; line-height: 24px; color: #0F3133; }
.intractive section.tube .pannel ul{ display: flex; gap: 19px; margin-top: 12px; }
.intractive section.tube .pannel ul li{ font-family: 'Days Sans Black'; font-size: 14px; font-weight: 400; line-height: 1; text-transform: uppercase; }
.intractive section.tube .pannel ul li img{ height: 16px; }
.intractive section.tube .pannel ul li:nth-child(1){ color: #3CE2E2; }
.intractive section.tube .pannel ul li:nth-child(2){ color: #EB8A01; }
.intractive section.tube .pannel ul li:nth-child(3){ color: #F6C739; }
/* tube > graphics */
.intractive section.tube .graphics{ position: absolute; top: 40%; left: 50%; transform: translate3d(-50%, -50%, 0); z-index: -1; width: 100vw; height: 100vh; background: url('/content/dam/embed/interactive-map/assets/images/tube/bg.png') no-repeat 40% 50% / cover; }
/* .intractive section.tube .graphics::after{ content: ''; position: absolute; top: 0; left: 0; z-index: -1; width: 100%; height: 100%; background: linear-gradient(45deg, #fff, transparent); } */
.intractive section.tube .graphics .inwrap{ position: absolute; top: 55%; left: 60%; transform: translate3d(-50%, -50%, 0); width: 55%; max-width: 800px; aspect-ratio: 1600/1000; 
  background: url('/content/dam/embed/interactive-map/assets/images/tube/_base.png') no-repeat center center / contain,
              url('/content/dam/embed/interactive-map/assets/images/tube/base.png') no-repeat top 53% right 15% / 57%;
}
.intractive section.tube .graphics .inwrap .images{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_01.png') no-repeat center center / contain; }
.intractive section.tube[data-prev-lottie='2025'] .graphics .inwrap .images{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_02.png') no-repeat center center / contain; }
.intractive section.tube[data-prev-lottie='2028'] .graphics .inwrap .images{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_03.png') no-repeat center center / contain; }
.intractive section.tube .graphics .inwrap .images > div {
  --circle-size-1: 100%;
  --circle-size-2: 100%;
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  mask: radial-gradient(circle at 15% 50%, transparent 0%, transparent var(--circle-size-1), black var(--circle-size-1), black var(--circle-size-2), transparent var(--circle-size-2));
  opacity: 0;
}
.intractive section.tube .graphics .inwrap .images .image-1{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_01_D.png') no-repeat center center / cover; }
.intractive section.tube .graphics .inwrap .images .image-2{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_01.png') no-repeat center center / cover; --circle-size: 0%; opacity: 1; }
.intractive section.tube .graphics .inwrap .images .image-3{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_02_D.png') no-repeat center center / cover; }
.intractive section.tube .graphics .inwrap .images .image-4{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_02.png') no-repeat center center / cover; }
.intractive section.tube .graphics .inwrap .images .image-5{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_03_D.png') no-repeat center center / cover; }
.intractive section.tube .graphics .inwrap .images .image-6{ background: url('/content/dam/embed/interactive-map/assets/images/tube/stills/Bores_03.png') no-repeat center center / cover; }
.intractive section.tube[data-lottie='2022'] .graphics .images .image-1{ z-index: 2; }
.intractive section.tube[data-lottie='2022'] .graphics .images .image-2{ z-index: 2; }
.intractive section.tube[data-lottie='2025'] .graphics .images .image-3{ z-index: 2; }
.intractive section.tube[data-lottie='2025'] .graphics .images .image-4{ z-index: 2; }
.intractive section.tube[data-lottie='2028'] .graphics .images .image-5{ z-index: 2; }
.intractive section.tube[data-lottie='2028'] .graphics .images .image-6{ z-index: 2; }
/* --- RESPONSIVE : Tube --- */
@media screen and (min-width: 1001px) {
  .intractive section.tube .texts{ max-width: 440px; }
  .intractive section.tube .list{ --button-height: 102px; }
  .intractive section.tube .list li{ width: 240px; }
  .intractive section.tube .pannel{  
    min-width: 460px; padding: 30px 28px 27px 36px; 
    border: 1px solid #fff; border-radius: 0 10px 10px 10px; background-color: rgba(255, 255, 255, 1);
    backdrop-filter: blur(8px); box-shadow: 0px 14px 34px -9px #3942591F;
  }
}
@media screen and (max-width: 1000px) {
  .intractive section.tube .bottom-wrap{ display: flex; flex-direction: column; width: 100%; flex-direction: column; align-items: center; }
  .intractive section.tube .graphics .inwrap{ top: 55%; left: 55%; width: 100%; } 
}
@media screen and (max-width: 767px) {
  .intractive section.tube .btn-back{ position: absolute; top: 0; left: 0; }
  .intractive section.tube .texts{ padding-left: 48px; }
  .intractive section.tube .texts .title{ font-size: min(33px, 7.8vw); }
  .intractive section.tube .texts .desc{ margin-top: 8px; font-size: min(16px, 3.7vw); }
  .intractive section.tube .list{ padding: 46px min(30px, 7vw) 24px; }
  .intractive section.tube .list ul{ gap: 15px; }
  .intractive section.tube .pannel{ margin-top: 12px; }
  .intractive section.tube .pannel .title{ font-size: 19px; }
  .intractive section.tube .pannel ul{ gap: 10px; }
  .intractive section.tube .pannel ul li{ font-size: min(12px, 2.5vw); }
  .intractive section.tube .graphics .inwrap{ top: 50%; left: 55%; width: 100%; } 
}
@media screen and (max-width: 375px) {
  .intractive section.tube .texts{ padding-left: 40px; }
  .intractive section.tube .texts .title{ font-size: min(23px, 6.1vw); }
  .intractive section.tube .texts .desc{ font-size: min(11px, 3vw); }
  .intractive section.tube .list{ padding: 40px min(24px, 6vw) 20px; }
  .intractive section.tube .pannel .title{ font-size: 16px; /* font-size: min(16px, 3.7vw); */ }
  .intractive section.tube .pannel ul{ gap: 10px; margin-top: 2px; }
  .intractive section.tube .pannel ul li{ font-size: min(10px, 2.6vw); }
}





/* ========= Scheme ========= */
.intractive section.scheme{ position: absolute; top: 0; left: 0;  background: url('/content/dam/embed/interactive-map/assets/images/map/bg.png') no-repeat center center / cover; }
/* scheme > graphics */
.intractive section.scheme .graphics{ position: absolute; top: 50%; left: 70%; transform: translate3d(-50%, -50%, 0); width: 55%; max-height: 90%; aspect-ratio: 654/540; }
.intractive section.scheme .graphics .lottie > div{ transition: opacity 0s 0.05s ease-in; }
.intractive section.scheme .graphics .lottie > div.active{ transition: opacity 0s ease-out; }
/* --- RESPONSIVE : Scheme --- */
@media screen and (min-width: 1001px) {
  .intractive section.scheme .texts{ max-width: 587px; }
  .intractive section.scheme .list{ --button-height: 114px; }
  .intractive section.scheme .list li{ width: 283px; }
}
@media screen and (max-width: 1000px) {
  .intractive section.scheme{ background: none; }
  .intractive section.scheme::before{ content: ''; position: absolute; top: 0; left: 0; width: 100%; height: calc(100% - var(--foot-height)); background: #fff url('/content/dam/embed/interactive-map/assets/images/map/bg-mo.png') no-repeat center bottom / cover; }
  .intractive section.scheme .texts{ width: 100%; } 
  .intractive section.scheme .texts .title span{ display: inline-block; }
  .intractive section.scheme .texts .desc span{ display: inline-block; }
  .intractive section.scheme .bottom-wrap{ display: flex; flex-direction: column; width: 100%; flex-direction: column; align-items: center; }
  .intractive section.scheme .graphics{ top: 45%; left: 50%; width: 90%; max-height: 65%; }
}
@media screen and (max-width: 767px) {
  .intractive section.scheme .texts{ padding-left: 48px; }
  .intractive section.scheme .btn-back{ position: absolute; top: 0; left: 0; }
  .intractive section.scheme .graphics{ top: 42%; left: 50%; width: 100%; max-height: 60%; }
}
@media screen and (max-width: 375px) {
  .intractive section.scheme .texts{ padding-left: 40px; }
  .intractive section.scheme .graphics{ top: 38%; }
}





/* ========= 화면 전환 ========= */
/* pending & out */
.intractive section .btn-back{ opacity: 0; transform: scale(0); transition: opacity 0.5s var(--ease-out-cubic), transform 0.5s var(--ease-out-cubic); }

/* pending */
.intractive section[data-state='pending']{ pointer-events: none; opacity: 0; }
.intractive section[data-state='pending'] .texts{ opacity: 0; }
.intractive section[data-state='pending'] .texts .title span{ transform: translate3d(50px, 0, 0); }
.intractive section[data-state='pending'] .texts .desc span{ transform: translate3d(50px, 0, 0); }

/* on */
.intractive section[data-state='on']{ transition: opacity 1.2s ease-out; }
.intractive section[data-state='on'] .texts{ transition: opacity 1.2s ease-out; }
.intractive section[data-state='on'] .texts .title span{ transition: transform .5s var(--ease-out-quad); }
.intractive section[data-state='on'] .texts .title span:nth-child(1){ transition-delay: 0s; }
.intractive section[data-state='on'] .texts .title span:nth-child(2){ transition-delay: 0.1s; }
.intractive section[data-state='on'] .texts .title span:nth-child(3){ transition-delay: 0.2s; }
.intractive section[data-state='on'] .texts .desc span{ transition: transform .5s var(--ease-out-quad); }
.intractive section[data-state='on'] .texts .desc span:nth-child(1){ transition-delay: 0.2s; }
.intractive section[data-state='on'] .texts .desc span:nth-child(2){ transition-delay: 0.3s; }
.intractive section[data-state='on'] .texts .desc span:nth-child(3){ transition-delay: 0.4s; }

.intractive section[data-state='on'] .btn-back{ opacity: 1; transform: scale(1); transition-delay: 0.2s; }

/* out */
.intractive section[data-state='out']{ pointer-events: none; opacity: 0; transition: opacity 0.5s var(--ease-in-quad); }
.intractive section[data-state='out'] .texts{ opacity: 0; transition: opacity 0.3s var(--ease-in-quad); }
.intractive section[data-state='out'] .texts .title,
.intractive section[data-state='out'] .texts .desc{ opacity: 0; transform: translate3d(-20px, 0, 0); transition: transform 0.3s var(--ease-in-quad), opacity 0.5s var(--ease-in-expo); }

/* - map */
.intractive section.map .graphics{ transition: transform 1.2s var(--ease-out-quart); }
.intractive section.map[data-state='out']{ transition: opacity 0.5s var(--ease-out-quad); } 
.intractive section.map[data-state='pending'] .graphics{ transform: translate3d(-50%, -50%, 0) scale(2.5); transform-origin: center center;  }
.intractive[data-current='tube'] section.map[data-state='out'] .graphics{ transform: translate3d(-50%, -50%, 0) scaleX(2.4) scaleY(2); transform-origin: center 90%; }
.intractive[data-current='tube'] section.map[data-state='pending'] .graphics{ transform: translate3d(-50%, -50%, 0) scaleX(2.4) scaleY(2); transform-origin: center 90%; }
.intractive[data-current='scheme'] section.map[data-state='out'] .graphics{ transform: translate3d(-50%, -50%, 0) scaleX(2.4) scaleY(2); transform-origin: 60% 65%;  }
.intractive[data-prev='tube'] section.map[data-state='on'] .graphics{ transform-origin: center 90%; transition: transform 0.8s 0.2s var(--ease-out-quart); }
.intractive[data-prev='scheme'] section.map[data-state='on'] .graphics{ transform-origin: 60% 65%; transition: transform 0.8s 0.2s var(--ease-out-quart); }

/* - tube */
.intractive section.tube .bg{ transition: transform 1s var(--ease-out-quad); }
.intractive section.tube .graphics{ transform: translate3d(-50%, -30%, 0) scale(1.1); transition: transform 0.5s var(--ease-in-quad); }
.intractive section.tube[data-state='on']{ transition: opacity 1.2s 0.1s ease-out; }
.intractive section.tube[data-state='on'] .graphics{ transform: translate3d(-50%, -50%, 0) scale(1); transition: transform 1s var(--ease-out-quad); }

/* - scheme */
.intractive section.scheme .graphics{ transform: translate3d(-50%, -50%, 0) scale(0.3); opacity: 0; transition: transform 0.7s var(--ease-inout-cubic), opacity 0.5s var(--ease-inout-cubic); }
.intractive section.scheme[data-state='on'] .graphics{ transform: translate3d(-50%, -50%, 0) scale(1); opacity: 1; transition: transform 1s var(--ease-out-expo), opacity 1s var(--ease-out-expo); }


@media screen and (min-width: 1001px) {
  .intractive section[data-state='pending'] .list li{ transform: translate3d(50px, 0, 0); }
  .intractive section[data-state='pending'] .list::before{ height: 0; }
  .intractive section[data-state='on'] .list::before{ transition: height 1s .2s var(--ease-out-quad); }
  .intractive section[data-state='on'] .list li{ transition: transform .5s .2s var(--ease-out-quad); }
  .intractive section[data-state='out'] .list li{ opacity: 0; transform: translate3d(-20px, 0, 0); transition: transform 0.3s var(--ease-in-quad), opacity 0.5s var(--ease-in-expo); }
  .intractive section[data-state='out'] .list::before{ height: 0; }
  .intractive section[data-state='out'] .list::after{ height: 0; }
  /* - tube */
  .intractive section.tube .pannel{ transition: transform 0.5s var(--ease-in-quad); }
  .intractive section.tube[data-state='pending'] .pannel{ transform: translate3d(50px, 0, 0);  }
  .intractive section.tube[data-state='out'] .pannel{ transform: translate3d(-50px, 0, 0);  }
  .intractive section.tube[data-state='on'] .pannel{ transform: translate3d(0, 0, 0); }
}
@media screen and (max-width: 1000px) {
  .intractive section[data-state='on'] .texts .title span:nth-child(2){ transition-delay: 0s; }
  .intractive section[data-state='on'] .texts .title span:nth-child(3){ transition-delay: 0s; }
  .intractive section[data-state='on'] .texts .desc span:nth-child(1){ transition-delay: 0.1s; }
  .intractive section[data-state='on'] .texts .desc span:nth-child(2){ transition-delay: 0.1s; }
  .intractive section[data-state='on'] .texts .desc span:nth-child(3){ transition-delay: 0s; }
  /* - map */
  .intractive section.map .legend ul{ transition: transform .5s var(--ease-out-quad), opacity .5s var(--ease-out-quad); transition-delay: 0.2s;  }
  .intractive section.map[data-state='out'] .legend ul{ opacity: 0; transform: translate3d(-20px, 0, 0); transition: transform 0.3s var(--ease-in-quad), opacity 0.5s var(--ease-in-expo); }
  .intractive section.map[data-state='pending'] .legend ul{ opacity: 0; transform: translate3d(50px, 0, 0); }
  .intractive section.map[data-state='on'] .legend ul{ opacity: 1; transform: translate3d(0, 0, 0); }
  .intractive section.map .bottom-wrap{ transition: transform 0.5s ease-out, opacity 0.5s ease-out; }
  .intractive section.map[data-state='out'] .bottom-wrap,
  .intractive section.map[data-state='pending'] .bottom-wrap{ transform: translate3d(100%, 0, 0); opacity: 0; } 
  .intractive[data-current='scheme'] section.map[data-state='out'] .bottom-wrap,
  .intractive[data-current='scheme'] section.map[data-state='pending'] .bottom-wrap{ transform: translate3d(-100%, 0, 0); opacity: 0; } 
  .intractive[data-current='tube'] section.map[data-state='out'] .bottom-wrap,
  .intractive[data-current='tube'] section.map[data-state='pending'] .bottom-wrap{ transform: translate3d(0, -100px, 0); } 
  .intractive section.map[data-state='on'] .bottom-wrap{ transform: translate3d(0, 0, 0); opacity: 1; } 
  /* - tube */
  .intractive section.tube .bottom-wrap{ transition: transform 0.5s ease-out, opacity 0.5s ease-out; }
  .intractive section.tube[data-state='out'] .bottom-wrap,
  .intractive section.tube[data-state='pending'] .bottom-wrap{ transform: translate3d(0, 100px, 0); opacity: 0;  } 
  .intractive section.tube[data-state='on'] .bottom-wrap{ transform: translate3d(0, 0, 0); opacity: 1; } 
  /* - scheme */
  .intractive section.scheme .bottom-wrap{ transition: transform 0.5s ease-out, opacity 0.5s ease-out; }
  .intractive section.scheme[data-state='out'] .bottom-wrap,
  .intractive section.scheme[data-state='pending'] .bottom-wrap{ transform: translate3d(100%, 0, 0); opacity: 0; } 
  .intractive section.scheme[data-state='on'] .bottom-wrap{ transform: translate3d(0, 0, 0); opacity: 1; } 
}
