@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css");
body {
    font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, sans-serif;
}
.section-hero{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    min-height: 720px;
    height: 100vh;
    width: 100%;
    /* background: linear-gradient(0deg, rgba(0, 0, 0, 0.20) 0%, rgba(0, 0, 0, 0.20) 100%), url('/images/hero_bg_img.png') lightgray 50% / cover no-repeat; */
}
.container-hero-vid{
    padding: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    position: absolute;
}
#background_video {
    z-index: -1;
    width: 100vw;
    position: absolute;
}
.section-header{
    border-bottom: 1px solid rgba(255, 255, 255, 0.20);
    background: rgba(255, 255, 255, 0.20);
    position: absolute;
    top: 0;
    width: 100%;
}
.container-header{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    height: 66px;
}
.container-hero-catch-phrase{
    position: absolute;
    top:50%;
    left: calc((100% - 940px) / 2);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 48px;
}
.scroll-icon{
    filter: invert(100%) sepia(0%) saturate(7492%) hue-rotate(145deg) brightness(105%) contrast(105%);
    width: 24px;
    height: 24px;
}
.container-scroll{
    position: absolute;
    bottom: 0;
    height: 100px;
    width: 100%;
    border-top: solid 1px rgba(255, 255, 255, 0.20);
    align-items: center;
    align-content: center;
    text-align: -webkit-center;
}
.scroll-icon-box{
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.40);
    background: rgba(255, 255, 255, 0.20);
    display: inline-flex;
    padding: 6px 20px;
    justify-content: center;
    align-items: center;
    gap: 2px;
}
/* section-01 */
.section-01{
    height: 100vh;
    min-height: 720px;
}
.reveal-mid-bar{
    width:1px;
    height: 56px;
}
.container-reveal-text-white, .container-reveal-text-black{
    height: 100%;
    align-content: center;
}
.container-reveal-text{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    height: 252px;
}
.reveal-color-overlay{
    position: relative;
}
.reveal-text, .reveal-second-text{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.reveal-text img{
    width: 168px;
    height: 8px;
}

/* section-02 */
.section-02{
    height: 100vh;
    min-height: 720px;
    background: var(--Neutral-99, #F7F7F7);
}

.container-section-02{
    align-content: center;
}

.section-02-wrapper{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 80px;
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
}

/* 이미지 컨테이너 */
.container-card-img{
    width: 448px;
    height: 460px;
    border-radius: 24px;
    overflow: hidden;
    flex-shrink: 0;
    position: relative; /* 이미지들을 겹치기 위해 */
}

.container-card-img img{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 24px;
    transition: opacity 0.8s ease-in-out;
}

.container-card-img .first-img {
    opacity: 1;
    z-index: 2;
}

.container-card-img .second-img {
    opacity: 0;
    z-index: 1;
}

/* 텍스트 컨테이너 */
.container-card-text-wrapper {
    flex: 1;
    min-width: 0;
    position: relative; /* 텍스트들을 겹치기 위해 */
    min-height: 200px; /* 텍스트 높이 확보 */
}

.container-card-text {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    transition: transform 0.6s ease-out, opacity 0.6s ease-out;
}

.container-card-text.first-text {
    opacity: 1;
    transform: translateY(0);
    z-index: 2;
}

.container-card-text.second-text {
    opacity: 0;
    transform: translateY(100%);
    z-index: 1;
}

/* .section-02{
    background: var(--Neutral-99, #F7F7F7);
    height: 100vh;
    min-height: 720px;
}
.container-section-02{
    align-content: center;
}
.container-card-img{
    width: 448px;
    height: 460px;
    border-radius: 20px;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
}
.section-02 .wrapper{
    height: 460px;
    width: 960px;
    position: relative;
}
.container-card-img img{
    object-fit: cover;
    width: 448px;
    height: 460px;
}
.container-card-text{
    justify-content: center;
    width: 45%;
    position: absolute;
    top: 142px;
    right: 0;
}
.card-content, .card-title{
    font-feature-settings: 'ss10' on;
} */
/* section-03 */
.section-03{
    height: 766px;
}
.container-section-03{
    padding: 120px 0 180px 0;
    justify-content: space-between;
}
.container-title{
    width: fit-content;
    text-align: center;
    justify-self: center;
    margin-bottom: 80px;
}
.container-card{
    width:100%;
    height: 282px;
}
.card{
    padding: 28px;
    align-items: flex-start;
    border-radius: 20px;
    width: 304px;
}
.card-01{
    background: linear-gradient(180deg, #732E00 0%, #2A2A2A 80%);    
}
.card-02{
    background: linear-gradient(180deg, #265E00 0%, #2A2A2A 80%);
}
.card-03{
    background: linear-gradient(180deg, #005B7F 0%, #2A2A2A 80%);
}
.icon-card{
    width: 100px;
    height: 100px;
}
.icon-card img{
    height: 100%;
    width: 100%;
}
.content-card{
    font-size: 14px;
}
/* section-05 */
.section-05{
    height: 504px;
}
.container-section-05{
    position: relative;
    height: 100%;
}
.section-05-bg-icon-box{
    width: 570px;
    height: 420px;
    position: absolute;
    bottom: 0;
}
.section-05-bg-icon{
    width: 569.885px;
    height: 420.672px;  
    fill: var(--Neutral-20, #2A2A2A);
}
.section-05-main-phrase{
    padding: 180px 0;
    position: relative;
    z-index: 9;
    justify-items: center;
}
.container-direct-link-main-section-05{
    margin-top: 36px;
}


/* interaction */
/* section-01 */
/* Swiper 관련 - 오버레이 효과를 위한 절대 위치 설정 */
.mySwiper {
    width: 100%;
    height: 100vh;
}

.swiper-wrapper {
    position: relative;
}

.swiper-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    overflow: hidden;
}

/* 레이어 순서 및 초기 위치 설정 */
.section-hero {
    z-index: 1;
}

.section-01 {
    z-index: 2;
    /* 초기에는 아래쪽에 숨김 */
    transform: translateY(100vh);
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40% { transform: translateY(-10px); }
    60% { transform: translateY(-5px); }
}
/* 패럴렉스 효과를 위한 추가 CSS */
body {
    overflow-x: hidden;
}

/* 패럴렉스 컨테이너 - hero와 section-01만 */
.parallax-container {
    position: relative;
    height: 100vh;
    overflow: hidden;
}

/* Hero Section 수정 */
.section-hero {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

/* Section 01 수정 */
.section-01 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2;
    transform: translateY(100vh);
}

/* 기존 Swiper 관련 스타일 제거를 위한 오버라이드 */
.mySwiper {
    display: none;
}

/* 스크롤 아이콘에 커서 포인터 추가 */
.scroll-icon-box {
    cursor: pointer;
}

/* Reveal 텍스트 인터렉션 효과 */
.container-reveal-text-white {
    /* 초기 상태: Scale 80%, Opacity 0% */
    transform: scale(0.8);
    opacity: 0;
    transition: transform 0.8s ease-out, opacity 0.8s ease-out;
}

/* 텍스트 색상 변화 효과 */
.container-reveal-text {
    position: relative;
    color: #0F0F0F; /* 배경과 같은 색으로 시작 */
    transition: color 1.2s ease-out;
}

.container-reveal-text .reveal-mid-bar {
    background-color: #0F0F0F; /* 배경색과 같게 시작 */
    transition: background-color 1.2s ease-out;
}

.container-reveal-text svg circle {
    fill: #0F0F0F; /* 배경색과 같게 시작 */
    transition: fill 1.2s ease-out;
}

/* 색상 변화를 위한 오버레이 - 개별 요소별로 분리 */
.reveal-color-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    height: 252px;
    pointer-events: none;
}

/* 첫 번째 텍스트 오버레이 */
.reveal-first-text {
    color: #FFFFFF;
    clip-path: inset(100% 0 0 0);
    transition: clip-path 0.8s ease-out;
}

.reveal-first-text.reveal-active {
    clip-path: inset(0 0 0 0);
}

/* 중간 바 오버레이 */
.reveal-mid-bar-overlay {
    width: 1px;
    height: 56px;
    background-color: #8A8A8A;
    opacity: 0;
    transition: opacity 0.4s ease-out;
}

.reveal-mid-bar-overlay.reveal-active {
    opacity: 1;
}

/* 두 번째 텍스트 오버레이 */
.reveal-second-text {
    color: #FFFFFF;
    display: flex;
    flex-direction: column;
    clip-path: inset(100% 0 0 0);
    transition: clip-path 0.8s ease-out;
}

.reveal-second-text.reveal-active {
    clip-path: inset(0 0 0 0);
}

.reveal-second-text svg circle {
    fill: #FF5E00;
}

/* section-04 */
.section-04{
    padding: 120px 0;
    width: 100%;
    justify-items: center;
    background: var(--Orange-99, #FFFAF7);
    font-feature-settings: 'ss10' on;
}
.container-direct-link-main-section-04{
    width: 200px;
    margin: 0 auto;
}
.container-direct-link-main-section-04 button{
    width: 100%;
}
.section-04 .swiper-container {
overflow: hidden; /* 넘치는 슬라이드 숨김 */
}
.section-04 .swiper-wrapper{
    align-items: stretch; /* 카드 높이 균일 */
}
.container-review-slide.swiper-slide{
    margin-top: 80px;
    margin-bottom: 74px;
    width: 330px;
    height: 438px;
    padding: 28px;
    border-radius: 20px;
    background: var(--Common-100, #FFF);
    box-shadow: 0 2px 48px 0 rgba(0, 0, 0, 0.08);
}
.container-review-thumb{
    margin-bottom: 40px;
}
.review-thumb-box{
    height: 180px;
    width: 100%;
    aspect-ratio: 330 / 180;
}
.review-thumb-box img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
    aspect-ratio: 330 / 180;
}
.container-star{
    width: 100%;
    height: 24px;
}
.review__star{
    height: 24px;
    width: 24px;
}
.review-type{
    display: inline-flex;       /* 수직 가운데 정렬 유지 */
    align-items: center;
    padding: 8px 9.6px;
    border-radius: 6.4px;
    background: var(--Orange-95, #FEEEE5);
    color: var(--Orange-50, #FF5E00);

    white-space: nowrap;        /* 줄바꿈 금지 */
    flex: 0 0 auto;             /* flex 컨테이너에서 축소 금지 */
    min-width: max-content;     /* 내용 길이만큼 가로 확장 */
}
.gap-11{
    gap: 11px;
}
.gap-24{
    gap: 24px;
}
/* 행 레이아웃이 아니면 추가 */
.review-summary{
    align-items:center;
    height:40px;
    width:100%;
    overflow:hidden;
}

/* 핵심: ellipsis */
.review-category{
    color: var(--Neutral-40, #5C5C5C);
}

/* span은 인라인 유지 */
.review-category > span{
    display: inline;
}

/* 선택: span 사이 구분점 */
.review-category > span + span::before{
    content: " · ";
    margin: 0 4px;
}
.review-title{
    color: var(--Neutral-10, #171717);
}
.review-content{
    color: var(--Neutral-30, #474747);
    font-feature-settings: 'ss10' on;
    display: -webkit-box;
    -webkit-line-clamp: 3; /* 3줄 표시 */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    height: auto; /* 자동 높이 */
}
.elipsis{
    min-width: 0;           /* ✅ flex에서 ellipsis 동작 필수 */
    white-space: nowrap;    /* 한 줄 고정 */
    overflow: hidden;
    text-overflow: ellipsis;
}

.section-04 .swiper-container { 
    width: 100%;
    height: 100%;
}
.section-04 .swiper-wrapper {
    transition-timing-function: linear !important;
}
.swiper-wrapper.dragging {
    animation: none !important;
}
@keyframes marquee {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

.swiper-wrapper.animate {
    animation: marquee 29.28s linear infinite;
}

.swiper-wrapper.paused {
    animation-play-state: paused;
}
.container-review-slide.swiper-slide {
    width: 330px !important;
    min-width: 330px;
    max-width: 330px;
    height: 438px !important;
    min-height: 438px;
    max-height: 438px;
    flex-shrink: 0;
}
.landing-body{
    position: relative;
}
.scroll-to-top{
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 1000;
}
.btn-scroll-top{
    width: 60px;
    height: 60px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: rgba(0, 0, 0, 0.30);
}

/* emph 점 */
/* 기본 텍스트의 img - #0F0F0F 색으로 시작 */
.reveal-text img {
    opacity: 0;
    transition: opacity 1.2s ease-out;
    margin-left: 14px;
}

/* Reveal overlay의 img - 오렌지색 유지 */
.reveal-second-text img {
    opacity: 1;
    margin-left: 14px;
}
.container-hero-vid {
    position: relative; /* 추가 */
}
.container-hero-vid::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(0deg, rgb(0 0 0 / 45%), rgba(0, 0, 0, 0) 100%);    pointer-events: none;
    z-index: 0;
}