@charset "UTF-8";

@font-face {
    font-family: 'ONE';
    src: url('../font/ONE-Mobile-Title.woff') format('woff');
    font-weight: normal;
    font-display: swap;
}

/*-------------------------------------------------------------------
    적용영역 : 전체영역
	속성순서 : 레이아웃, 박스 모델, 배경, 폰트/정렬, 기타
    최종변경일 : 2025.11.21
-------------------------------------------------------------------*/
#wrap {display: flex; overflow: hidden; position: relative; background: #202022; flex-direction: column;}
#wrap::before {content: ""; display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: url(../images/vr/bg.jpg) no-repeat center / cover;}
#wrap .bg {display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(36, 34, 43, 0.8);}



.vr-header {display: flex; position: fixed; top: 0; left: 0; width: 100%; z-index: 1; padding: 20px 70px; height: 100px; flex-shrink: 0; align-items: center;}
.vr-header .logo-box {display: block;}
.vr-header .logo-box .logo {display: flex; gap: 20px; color: #fff;}
.vr-header .logo-box .logo img {display: block;}
.vr-header .logo-box .logo strong {display: block; line-height: 1; font-weight: 700; font-size: 40px;}

.vr-header {transition: transform 0.3s; transform: translateY(-100%);}
[data-scrolled="start"] .vr-header {backdrop-filter: blur(10px); transform: translateY(0);}

/*-------------------------------------------------------------------
	@media
-------------------------------------------------------------------*/
@media screen and (max-width: 1500px) {
    .vr-header {padding: 20px;}
}
@media screen and (max-width: 1024px) {
    .vr-header {height: 80px;}
    .vr-header .logo-box .logo img {height: 30px;}
    .vr-header .logo-box .logo strong {font-size: 30px;}
}
@media screen and (max-width: 600px) {
    .vr-header {height: 60px; padding: 0 20px;}
    .vr-header .logo-box .logo {gap: 10px;}
    .vr-header .logo-box .logo img {height: 20px;}
    .vr-header .logo-box .logo strong {font-size: 20px;}
}



.vr-main {display: block;}
.vr-main .sc-content {display: block; position: relative; min-height: 100vh;}

/*-------------------------------------------------------------------
	분류이름 : 상단 텍스트 배너
	분류그룹 : section
-------------------------------------------------------------------*/
#sc01 {display: flex; padding: 50px; align-items: center; justify-content: center;}
#sc01 .content-box {display: block; position: relative; max-width: 1000px; width: 100%; padding: 80px 50px 50px; border: 1px solid #fff; border-radius: 8px; backdrop-filter: blur(0);}
#sc01 .content-box .title-box {display: block; margin-bottom: 25px; color: #fff;}
#sc01 .content-box .title-box .logo {display: block; margin: 0 auto 10px;}
#sc01 .content-box .title-box strong {display: block; line-height: 1; font-weight: 700; font-size: 78px; text-align: center; font-family: 'Ria','Pretendard','Noto Sans KR', sans-serif;}
#sc01 .content-box .rolling-text {display: block; overflow: hidden; height: 1em; line-height: 1; font-weight: 700; font-size: 28px;}
#sc01 .content-box .rolling-text .rail {display: block; animation: scroll-left 10s linear infinite;}
#sc01 .content-box .rolling-text .rail .txt {display: block; line-height: 1; font-weight: inherit; font-size: inherit; color: #fff; text-align: center;}
#sc01 .content-box .btn-scroll {display: block; margin: 30px auto 0; font-weight: 500; font-size: 13px; color: #fff; text-transform: uppercase; text-align: center;}
#sc01 .content-box .btn-scroll::before {content: "\EF7D"; display: block; padding: 20px 0 10px; font-family: 'remixicon'; font-weight: normal; font-size: 24px; color: #fff;}


/*-------------------------------------------------------------------
	@interaction
-------------------------------------------------------------------*/
#sc01 .content-box {transition: backdrop-filter 0.3s;}
#sc01.active .content-box {backdrop-filter: blur(10px);}

#sc01 .content-box .btn-scroll::before {animation: scroll-bounce 1.5s infinite;}

@keyframes scroll-bounce {
    0%, 100% {transform: translateY(0);}
    50% {transform: translateY(10px);}
}

/*-------------------------------------------------------------------
	@media
-------------------------------------------------------------------*/
@media screen and (max-width: 1024px) {
    #sc01 .content-box {padding: 60px 20px 30px;}
    #sc01 .content-box .title-box strong {font-size: 64px;}
    #sc01 .content-box .rolling-text {font-size: 22px;}
    #sc01 .content-box .btn-scroll {margin-top: 10px;}
}
@media screen and (max-width: 600px) {
    #sc01 {padding: 20px;}
    #sc01 .content-box {padding: 50px 15px 25px;}
    #sc01 .content-box .title-box {margin-bottom: 15px;}
    #sc01 .content-box .title-box strong {font-size: 40px;}
    #sc01 .content-box .rolling-text {font-size: 14px;}
}



/*-------------------------------------------------------------------
	분류이름 : VR 슬라이드
	분류그룹 : section
-------------------------------------------------------------------*/
#sc02 {display: flex; padding: 100px 0 60px; justify-content: center; flex-direction: column;}
#sc02 .sc-wrap {display: block;}
/* #sc02 .slide-area {position: relative; max-width: 1000px; width: 33.333%; margin: 70px auto 0; padding: 0 200px;} */
#sc02 .slide-area {position: relative; max-width: 600px; width: 33.333%; margin: 70px auto 0;}
#sc02 .slide-area .vr-slide {display: block; width: 100%;}
#sc02 .slide-area .vr-slide .swiper-slide {overflow: hidden; border-radius: 10px; aspect-ratio: 1.2 / 1;}
#sc02 .slide-area .vr-slide .swiper-slide img {display: block; width: 100%; height: 100%; object-fit: cover;}
#sc02 .slide-area .swiper-notification {display: none;}
#sc02 .slide-area .slide-controls {display: block;}
#sc02 .slide-area .slide-controls .btn-ctrl {position: absolute; top: 0; width: 150px; height: 100%; background-color: transparent; cursor: pointer;}
#sc02 .slide-area .slide-controls .btn-ctrl span {position: absolute; top: 50%; display: block; width: 119px; height: 50px; color: #fff; font-size: 16px; transform: translateY(-50%);}
#sc02 .slide-area .slide-controls .btn-ctrl span::before {content: ""; display: block; position: absolute; bottom: 0; left: 0; width: 1em; height: 50px; font-size: 119px; background: url(../images/vr/slide_arrow.png); background-repeat: no-repeat; background-size: 2em;}

#sc02 .slide-area .slide-content {display: block; position: relative; margin-top: -110px; padding-left: 120px; padding-right: 30px;}
#sc02 .slide-area .slide-content .content-inner {display: flex; overflow: hidden; min-height: 200px; padding: 35px 35px 25px; border-radius: 50px 10px 10px 10px; background-color: #fff; flex-direction: column;}
#sc02 .slide-area .slide-content .content-inner .tit {display: block; margin-bottom: 10px; line-height: 1.2; font-weight: normal; font-size: 25px; color: #111; font-family: 'ONE','Pretendard','Noto Sans KR', sans-serif;}
#sc02 .slide-area .slide-content .content-inner .desc {display: block; margin-bottom: 10px; line-height: 1.3; font-weight: 500; font-size: 17px; color: #666666;}
#sc02 .slide-area .slide-content .content-inner .link {display: inline-flex; height: 40px; margin: auto 0 0 auto; padding: 0 20px; border-radius: 999px; background-color: #1B9E50; font-weight: 700; color: #fff; align-items: center;}
#sc02 .slide-area .slide-content .content-inner .link::after {content: "\EA6C"; font-family: 'remixicon'; font-weight: normal; font-size: 24px; color: #fff;}

#sc02 .navigation {display: flex; margin-top: 100px; padding: 0 50px; gap: 20px 80px; align-items: center; justify-content: center; flex-wrap: wrap;}
#sc02 .navigation > li {display: block;}
#sc02 .navigation > li .nav {display: flex; gap: 10px; align-items: center;}
#sc02 .navigation > li .nav .num {display: flex; width: 40px; height: 40px; border: 1px solid #fff; border-radius: 50%; line-height: 1; color: #fff; align-items: center; justify-content: center; font-family: 'ONE','Pretendard','Noto Sans KR', sans-serif;}
#sc02 .navigation > li .nav .tit {display: block; position: relative; font-weight: normal; font-size: 18px; color: #fff; font-family: 'ONE','Pretendard','Noto Sans KR', sans-serif;}
#sc02 .navigation > li .nav .tit::before {content: ""; position: absolute; top: calc(50% - 1.5px); left: 0; width: 100%; height: 3px; background-color: #1B9E50;}

/*-------------------------------------------------------------------
	@variation
-------------------------------------------------------------------*/
#sc02 .slide-area .slide-controls .btn-ctrl.prev {left: 0; transform: translateX(-100%);}
#sc02 .slide-area .slide-controls .btn-ctrl.prev span {left: 0; text-align: right;}
#sc02 .slide-area .slide-controls .btn-ctrl.prev span::before {background-position: 0 center;}
#sc02 .slide-area .slide-controls .btn-ctrl.next {right: 0; transform: translateX(100%);}
#sc02 .slide-area .slide-controls .btn-ctrl.next span {right: 0; text-align: left;}
#sc02 .slide-area .slide-controls .btn-ctrl.next span::before {background-position: -1em center;}

/*-------------------------------------------------------------------
	@interaction
-------------------------------------------------------------------*/
#sc02 .slide-area .slide-controls .btn-ctrl span::before {transition: background-image 0.3s;}
#sc02 .slide-area .slide-controls .btn-ctrl.prev:focus-visible span::before,
#sc02 .slide-area .slide-controls .btn-ctrl.prev:hover span::before,
#sc02 .slide-area .slide-controls .btn-ctrl.next:focus-visible span::before,
#sc02 .slide-area .slide-controls .btn-ctrl.next:hover span::before {background-image: url(../images/vr/slide_arrow_active.png);}

#sc02 .slide-area .slide-content .content-inner .desc {opacity: 0;}
#sc02 .slide-area .slide-content .content-inner .desc.on {animation: descAni 0.3s forwards;}
#sc02 .slide-area .slide-content .content-inner .tit.complete .Typewriter__cursor {display: none;}

#sc02 .navigation > li .nav .num {transition: border-color 0.3s, background-color 0.3s;}
#sc02 .navigation > li .nav:focus-visible .num,
#sc02 .navigation > li .nav:hover .num,
#sc02 .navigation > li .nav.active .num,
#sc02 .navigation > li .nav.passed .num {border-color: #1B9E50; background-color: #1B9E50;}

#sc02 .navigation > li .nav .tit::before {transform: scaleX(0); transition: transform 0.3s; transform-origin: left center;}
#sc02 .navigation > li .nav.passed .tit::before {transform: scaleX(1);}

@keyframes descAni {
    0% {opacity: 0;}
    100% {opacity: 1;}
}
/*-------------------------------------------------------------------
	@media
-------------------------------------------------------------------*/
@media screen and (max-width: 1500px) {
    #sc02 {padding-bottom: 50px;}
    #sc02 .slide-area .slide-content {margin-top: -80px; padding-left: 20px; padding-right: 20px;}
    #sc02 .navigation {margin-top: 50px; gap: 20px 40px;}
}
@media screen and (max-width: 1024px) {
    #sc02 {padding-top: 80px;}
    #sc02 .slide-area {max-width: 100%; width: 50%;}
}
@media screen and (max-width: 768px) {
    #sc02 .slide-area {width: 80%; max-width: calc(100% - 240px);}
    #sc02 .slide-area .slide-content .content-inner {padding: 30px 20px 20px;}
    #sc02 .slide-area .slide-content .content-inner .tit {font-size: 20px;}
    #sc02 .slide-area .slide-controls .btn-ctrl {width: 100px;}
    #sc02 .slide-area .slide-controls .btn-ctrl span {width: 80px;}
    #sc02 .slide-area .slide-controls .btn-ctrl span::before {font-size: 80px;}
    
    #sc02 .navigation {gap: 20px; padding: 0 20px;}
    #sc02 .navigation > li .nav .num {width: 32px; height: 32px; font-size: 13px;}
    #sc02 .navigation > li .nav .tit {font-size: 16px;}
}
@media screen and (max-width: 600px) {
    #sc02 {padding-top: 60px; padding-bottom: 30px;}
    #sc02 .slide-area {max-width: calc(100% - 80px); width: 100%;}
    #sc02 .slide-area .slide-content {margin-top: -40px; margin-left: -20px; margin-right: -20px; padding: 0;}
    #sc02 .slide-area .slide-content .content-inner {min-height: 180px; padding: 20px; border-radius: 30px 10px 10px 10px;}
    #sc02 .slide-area .slide-content .content-inner .desc {margin-bottom: 15px; font-size: 15px;}
    #sc02 .slide-area .slide-controls {display: none;}

    #sc02 .navigation {margin-top: 30px; justify-content: flex-start;}
    #sc02 .navigation > li {width: calc(50% - 10px);}
    #sc02 .navigation > li .nav {gap: 5px;}
    #sc02 .navigation > li .nav .tit {font-size: 15px;}
}


.curtain {position: fixed; top: 0; left: 0; z-index: 10; width: 100%; height: 100%;}
.curtain::before {content: ""; position: absolute; top: 0; left: 0; width: 50%; height: 100%; backdrop-filter: blur(5px); animation: curtain-left 0.6s 0.3s forwards;}
.curtain::after {content: ""; position: absolute; top: 0; right: 0; width: 50%; height: 100%; backdrop-filter: blur(5px); animation: curtain-right 0.6s 0.3s forwards;}

body.intro-played .curtain {visibility: hidden;}

@keyframes curtain-left {
    0% {transform: translateX(0);}
    100% {transform: translateX(-100%);}
}
@keyframes curtain-right {
    0% {transform: translateX(0);}
    100% {transform: translateX(100%);}
}