/* ============================================
   RESET & VARIABLES
   ============================================ */
*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --color_primary: #111827;
    --color_primary_light: #374151;
    --color_primary_dark: #030712;
    --color_accent: #2C5282;
    --gradient_accent: linear-gradient(135deg, #4A90D9 0%, #2C5282 55%, #C9A84C 100%);
    --gradient_accent_text: linear-gradient(135deg, #4A90D9 0%, #2C5282 55%, #C9A84C 100%);
    --color_accent_light: #EBF4FF;
    --color_gradient_start: #111827;
    --color_gradient_mid: #1f2937;
    --color_gradient_end: #374151;
    --color_white: #ffffff;
    --color_off_white: #F8FAFC;
    --color_light_gray: #F1F5F9;
    --color_medium_gray: #999999;
    --color_dark_gray: #333333;
    --color_text: #555555;
    --color_text_dark: #2d2d2d;
    --color_border: #E2E8F0;
    --font_main: 'Pretendard', -apple-system, BlinkMacSystemFont, sans-serif;
    --font_display: 'Pretendard', -apple-system, BlinkMacSystemFont, sans-serif;
    --font_eng: 'Pretendard', -apple-system, BlinkMacSystemFont, sans-serif;
    --header_height: 80px;
    --transition_fast: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --transition_mid: 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    --transition_slow: 1s cubic-bezier(0.4, 0, 0.2, 1);
}

/* html overflow/height: 데스크톱 전용 @media (min-width:1025px) 블록에서만 설정 */

body {
    font-family: var(--font_main);
    font-size: 16px;
    color: var(--color_text);
    line-height: 1.6;
    background: var(--color_white);
}

/* 데스크톱 전용 풀페이지 스크롤 환경 */
@media (min-width: 1025px) {
    html {
        overflow: hidden;
        height: 100%;
    }

    body {
        overflow: hidden;
        height: 100%;
    }
}

/* 서브페이지용 overflow 해제 (자바스크립트 의존성 제거 및 sticky 고정 보장) */
@media (min-width: 1025px) {
    html.sub_page,
    html.sub_page body {
        overflow: auto !important;
        height: auto !important;
    }
}

a {
    text-decoration: none;
    color: inherit;
    transition: color var(--transition_fast);
}

ul,
ol {
    list-style: none;
}

img {
    max-width: 100%;
    display: block;
}

button {
    border: none;
    background: transparent;
    cursor: pointer;
    font-family: var(--font_main);
}

/* ============================================
      HEADER
      ============================================ */
.secret_area {
    position: absolute;
    top: 0;
    right: 0;
    width: 300px;
    height: 100%;
    cursor: pointer;
    z-index: 9999;
    background: transparent;
}

@media (max-width: 1024px) {
    .secret_area {
        display: none;
    }
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    transition: background var(--transition_fast), box-shadow var(--transition_fast);
}

.header.is_white,
.header.nav_hovered {
    background: rgba(255, 255, 255, 0.97);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
}

.header_inner {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--header_height);
    padding: 0 40px;
    position: relative;
}

.logo a {
    display: flex;
    align-items: center;
}

.logo img {
    height: 52px;
    width: auto;
    transition: filter var(--transition_fast);
    filter: brightness(0) invert(1);
}

.header.is_white .logo img,
.header.nav_hovered .logo img {
    filter: none;
}

/* GNB */
.gnb {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.gnb_list {
    display: flex;
}

.gnb_item {
    position: relative;
}

.gnb_item>a {
    display: flex;
    align-items: center;
    height: var(--header_height);
    padding: 0 44px;
    font-size: 17px;
    font-weight: 500;
    color: var(--color_white);
    letter-spacing: -0.2px;
    transition: color var(--transition_fast);
    position: relative;
}

.gnb_item>a::after {
    content: '';
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) scaleX(0);
    width: 24px;
    height: 2px;
    background: var(--gradient_accent);
    transition: transform var(--transition_fast);
    transform-origin: center;
}

.gnb_item:hover>a::after {
    transform: translateX(-50%) scaleX(1);
}

.header.is_white .gnb_item>a,
.header.nav_hovered .gnb_item>a {
    color: var(--color_text_dark);
}

.header.is_white .gnb_item:hover>a,
.header.nav_hovered .gnb_item:hover>a {
    color: var(--color_primary);
}


/* 메가메뉴 배경 */
.header::before {
    content: '';
    position: absolute;
    top: var(--header_height);
    left: 0;
    width: 100%;
    height: 0;
    background: rgba(255, 255, 255, 0.98);
    border-top: 1px solid var(--color_border);
    transition: height var(--transition_fast), opacity var(--transition_fast);
    z-index: -1;
    opacity: 0;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.05);
}

.header.nav_hovered::before {
    height: 280px;
    opacity: 1;
}

/* 서브메뉴 */
.gnb_sub_wrap {
    position: absolute;
    top: var(--header_height);
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease;
    padding-top: 20px;
    z-index: 10;
}

.header.nav_hovered .gnb_sub_wrap {
    opacity: 1;
    visibility: visible;
}

.gnb_sub {
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
    min-width: max-content;
    border-top: none;
    overflow: visible;
    text-align: center;
}

.gnb_sub li a {
    display: inline-block;
    padding: 10px 15px;
    font-size: 15px;
    color: var(--color_text);
    transition: all var(--transition_fast);
    position: relative;
}

.gnb_sub li a:hover {
    background: transparent;
    color: var(--color_text_dark);
    font-weight: 600;
}

/* 모바일 메뉴 버튼 */
.mobile_menu_btn {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    width: 32px;
    height: 32px;
    padding: 4px 0;
    z-index: 10;
}

.mobile_menu_btn span {
    display: block;
    width: 100%;
    height: 2px;
    background: var(--color_white);
    border-radius: 2px;
    transition: all var(--transition_fast);
}

.header.is_white .mobile_menu_btn span {
    background: var(--color_dark_gray);
}

/* ============================================
      FULLPAGE
      ============================================ */
.fullpage_wrap {
    position: relative;
    width: 100%;
    transition: transform 0.85s cubic-bezier(0.76, 0, 0.24, 1);
}

.fp_section {
    width: 100%;
    position: relative;
}

/* 데스크톱: 풀페이지 스크롤에 필요한 총 높이 고정 (높이 850px 이하에서는 예외 처리) */
@media (min-width: 1025px) and (min-height: 851px) {
    .fullpage_wrap {
        height: 100vh;
    }

    .fp_section {
        height: 100vh;
        overflow: hidden;
    }
}

/* ============================================
      SECTION HERO
      ============================================ */
.section_hero {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #1a1a2e;
    position: relative;
}

.hero_video_wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    overflow: hidden;
}

.hero_video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero_video_overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    /* Dim processing */
}

.sub_hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--color_primary_dark);
    background-image: radial-gradient(circle at center, rgba(255, 255, 255, 0.05) 0%, transparent 70%);
    height: 280px;
    padding-top: var(--header_height);
    position: relative;
    overflow: hidden;
    border-bottom: 2px solid var(--color_border);
}

.sub_hero .hero_video_overlay {
    display: none;
}

.sub_hero .hero_video_wrap {
    display: none;
}

.sub_hero .hero_title {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-bottom: 0;
}

.sub_hero .hero_line_1 {
    font-family: var(--font_eng);
    font-size: 14px;
    letter-spacing: 6px;
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: 0;
    animation: hero_fade_in 0.8s ease 0.2s forwards;
}

.sub_hero .hero_line_2 {
    font-size: 38px;
    letter-spacing: -1px;
    color: var(--color_white);
    font-weight: 600;
    animation: hero_fade_in 0.8s ease 0.4s forwards;
}

/* 서브 히어로 텍스트 즉시 노출 (animation-delay 없이 바로 보임) */
.sub_hero .hero_line_2.is_shown {
    opacity: 1;
    transform: translateY(0);
    animation: none;
}

/* CEO인사말 강조 텍스트 */
.text_accent_bold {
    font-weight: 600;
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.hero_content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: var(--color_white);
}

.hero_logo_badge {
    margin-bottom: 30px;
    opacity: 0;
    transform: translateY(30px);
    animation: hero_fade_in 1s ease 0.3s forwards;
}

.hero_logo_badge img {
    height: 70px;
    margin: 0 auto;
    filter: brightness(0) invert(1);
}

.hero_title {
    font-family: var(--font_display);
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: 24px;
}

.hero_line {
    display: block;
    opacity: 0;
    transform: translateY(40px);
}

.hero_line_1 {
    font-size: 72px;
    letter-spacing: 4px;
    animation: hero_fade_in 1s ease 0.5s forwards;
}

.hero_line_2 {
    font-size: 72px;
    letter-spacing: 4px;
    color: var(--color_white);
    animation: hero_fade_in 1s ease 0.7s forwards;
}

.hero_desc {
    font-size: 17px;
    font-weight: 300;
    letter-spacing: 1px;
    line-height: 1.8;
    opacity: 0;
    transform: translateY(20px);
    animation: hero_fade_in 1s ease 0.9s forwards;
    color: rgba(255, 255, 255, 0.85);
}

@keyframes hero_fade_in {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.scroll_indicator {
    position: absolute;
    bottom: 50px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 10;
    opacity: 0;
    animation: scroll_indicator_fade 1s ease 1.2s forwards;
}

@keyframes scroll_indicator_fade {
    0% {
        opacity: 0;
        transform: translate(-50%, 40px);
    }
    100% {
        opacity: 1;
        transform: translate(-50%, 0);
    }
}

.scroll_text {
    color: rgba(255, 255, 255, 0.7);
    font-family: var(--font_eng);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 5px;
    margin-bottom: 16px;
    text-transform: uppercase;
}

.scroll_line {
    width: 1px;
    height: 60px;
    background: rgba(255, 255, 255, 0.25);
    position: relative;
    overflow: hidden;
}

.scroll_line::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 15px;
    background: var(--color_white);
    animation: scroll_indicator_drop 2s ease-in-out infinite;
}

@keyframes scroll_indicator_drop {
    0% {
        transform: translateY(-20px);
        opacity: 1;
    }

    50% {
        transform: translateY(60px);
        opacity: 1;
    }

    51% {
        opacity: 0;
    }

    100% {
        opacity: 0;
    }
}


/* ============================================
      공통 섹션
      ============================================ */
.section_inner {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 0 40px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.section_tag {
    display: inline-block;
    font-family: var(--font_eng);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 4px;
    text-transform: uppercase;
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    margin-bottom: 16px;
    position: relative;
    padding-left: 40px;
}

.section_tag::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 28px;
    height: 1px;
    background: var(--gradient_accent);
}

.section_title {
    font-size: 42px;
    font-weight: 300;
    color: var(--color_text_dark);
    line-height: 1.4;
    margin-bottom: 50px;
}

.section_title strong {
    font-weight: 900;
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* ============================================
      ABOUT
      ============================================ */
.section_about {
    background: var(--color_white);
}

.about_content {
    display: flex;
    gap: 100px;
    align-items: center;
}

.about_text {
    flex: 1;
}

.about_quote {
    margin-bottom: 20px;
}

.about_quote i {
    font-size: 36px;
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.about_text h3 {
    font-size: 26px;
    font-weight: 700;
    color: var(--color_text_dark);
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--color_border);
}

.about_text p {
    font-size: 17px;
    line-height: 1.9;
    color: var(--color_text);
    margin-bottom: 16px;
}

.ceo_sign {
    margin-top: 30px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.ceo_sign span {
    font-size: 16px;
    color: var(--color_medium_gray);
}

.ceo_sign strong {
    font-size: 22px;
    color: var(--color_primary);
    font-weight: 700;
}

.about_visual {
    flex: 0 0 270px;
}

.about_img_box {
    position: relative;
}

.about_img_deco {
    position: absolute;
    top: -20px;
    right: -20px;
    width: 100%;
    height: 100%;
    border: 2px solid transparent;
    border-color: var(--color_accent);
    border-radius: 0px;
}

.about_img_placeholder {
    width: 400px;
    height: 460px;
    background: linear-gradient(135deg, var(--color_off_white), var(--color_light_gray));
    border-radius: 0px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.about_img_placeholder::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: var(--gradient_accent);
}

.about_img_placeholder i {
    font-size: 80px;
    color: var(--color_border);
}

/* ============================================
      BUSINESS
      ============================================ */
.section_business {
    background: var(--color_off_white);
}

/* ============================================ */
.section_history {
    background: var(--color_white);
}

.history_timeline {
    position: relative;
    max-width: 700px;
    padding-left: 60px;
}

.timeline_line {
    position: absolute;
    left: 20px;
    top: 0;
    width: 1px;
    height: 100%;
    background: var(--color_border);
}

.timeline_line::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 0;
    background: var(--gradient_accent);
    transition: height 1.5s ease;
}

.history_timeline.is_visible .timeline_line::before {
    height: 100%;
}

.timeline_item {
    display: flex;
    align-items: flex-start;
    gap: 24px;
    margin-bottom: 40px;
    position: relative;
    opacity: 0;
    transform: translateX(-20px);
    transition: all 0.6s ease;
}

.history_timeline.is_visible .timeline_item {
    opacity: 1;
    transform: translateX(0);
}

.history_timeline.is_visible .timeline_item:nth-child(2) {
    transition-delay: 0.15s;
}

.history_timeline.is_visible .timeline_item:nth-child(3) {
    transition-delay: 0.3s;
}

.history_timeline.is_visible .timeline_item:nth-child(4) {
    transition-delay: 0.45s;
}

.history_timeline.is_visible .timeline_item:nth-child(5) {
    transition-delay: 0.6s;
}

.timeline_dot {
    position: absolute;
    left: -48px;
    top: 6px;
    width: 10px;
    height: 10px;
    border-radius: 0;
    background: var(--color_white);
    border: 3px solid var(--color_accent);
    z-index: 1;
    transition: all var(--transition_fast);
}

.timeline_item:hover .timeline_dot {
    background: var(--gradient_accent);
    transform: scale(1.3);
}

.timeline_year {
    font-family: var(--font_display);
    font-size: 28px;
    font-weight: 700;
    color: var(--color_primary);
    min-width: 80px;
}

.timeline_desc {
    font-size: 15px;
    color: var(--color_text);
    line-height: 1.6;
    padding-top: 6px;
}

/* ============================================
       PARTNERS (RE-DESIGNED)
       ============================================ */
.section_partners {
    background: var(--color_off_white);
}

.partners_category_wrap {
    margin-top: 60px;
}

.partner_category_header {
    margin-bottom: 30px;
    border-bottom: 1px solid var(--color_border);
    padding-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 20px;
}

.category_tag {
    font-family: var(--font_display);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--color_accent);
    border: 1px solid var(--color_accent);
    padding: 4px 10px;
    border-radius: 20px;
}

.partner_category_header h4 {
    font-size: 22px;
    font-weight: 700;
    color: var(--color_text_dark);
    letter-spacing: -0.5px;
}

.partners_display_grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
}

.partner_info_box h5 {
    font-size: 19px;
    font-weight: 700;
    color: var(--color_text_dark);
    margin-bottom: 8px;
    transition: color var(--transition_fast);
}

.partner_card:hover .partner_info_box h5 {
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.partner_info_box p {
    font-size: 15px;
    line-height: 1.6;
    color: var(--color_text);
}

.partner_card {
    padding: 0;
    overflow: hidden;
    border-radius: 0;
}

.partner_card_inner {
    display: flex;
    align-items: center;
    padding: 30px;
    gap: 30px;
    height: 100%;
    background: var(--color_white);
}

.partner_logo_box {
    flex: 0 0 160px;
    height: 100px;
    background: var(--color_off_white);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 15px;
    border: 1px solid var(--color_light_gray);
}

.partner_logo_box img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: all var(--transition_mid);
}

.partner_card:hover .partner_logo_box img {
    transform: scale(1.05);
}

.partners_footer_note {
    margin-top: 80px;
    text-align: center;
    padding: 40px;
    background: var(--color_off_white);
    border: 1px dashed var(--color_border);
}

.partners_footer_note p {
    font-size: 14px;
    color: var(--color_medium_gray);
    font-style: italic;
}

/* Mobile Responsive for Partners */
@media (max-width: 900px) {
    .partners_display_grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .partner_card_inner {
        flex-direction: column;
        text-align: center;
        padding: 30px 20px;
    }

    .partner_logo_box {
        flex: 0 0 auto;
        width: 100%;
    }
}


/* ============================================
      CONTACT
      ============================================ */
.section_contact {
    background: var(--color_white);
    display: flex;
    flex-direction: column;
}

.section_contact .section_inner {
    flex: 1;
    justify-content: center;
}

.contact_content {
    display: flex;
    gap: 50px;
    align-items: stretch;
}

.contact_map {
    flex: 1;
    min-height: 280px;
}

.map_placeholder {
    width: 100%;
    height: 100%;
    min-height: 280px;
    background: var(--color_light_gray);
    border-radius: 0px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    color: var(--color_medium_gray);
}

.map_placeholder i {
    font-size: 48px;
}

.map_placeholder p {
    font-size: 14px;
    text-align: center;
}

.map_placeholder small {
    font-size: 12px;
    color: var(--color_border);
}

.contact_info {
    flex: 0 0 380px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    justify-content: center;
}

.contact_info_item {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    padding: 16px 24px;
    border-radius: 0px;
    transition: background var(--transition_fast);
}

.contact_info_item:hover {
    background: var(--color_off_white);
}

.contact_icon {
    width: 44px;
    height: 44px;
    border-radius: 0px;
    background: var(--color_off_white);
    border: 1px solid var(--color_border);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.contact_icon i {
    font-size: 16px;
    color: var(--color_text_dark);
}

.contact_info_item h4 {
    font-size: 15px;
    font-weight: 700;
    color: var(--color_primary);
    margin-bottom: 4px;
}

.contact_info_item p {
    font-size: 17px;
    color: var(--color_text);
}

/* ============================================
      FOOTER
      ============================================ */
.footer {
    background: var(--color_primary_dark);
}

.footer_inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 56px 40px;
}

.footer_top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 28px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    margin-bottom: 28px;
}

.footer_logo img {
    height: 44px;
    filter: brightness(0) invert(1);
}

.footer_links {
    display: flex;
    gap: 36px;
}

.footer_links li a {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.6);
}

.footer_links li a strong {
    color: inherit;
}

.footer_links li a:hover {
    color: var(--color_white);
}

.footer_bottom p {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.8;
}

.copyright {
    margin-top: 14px;
    color: rgba(255, 255, 255, 0.3) !important;
}

/* ============================================
      SIDE NAV (기존 디자인 복원 + 활성점 이동)
      ============================================ */
.side_nav {
    position: fixed;
    right: 36px;
    top: 0;
    height: 100vh;
    z-index: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.side_nav_inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    pointer-events: all;
}

/* 활성 타이틀 영역 (위쪽 고정 블록) */
.side_nav_active_block {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 14px;
}

.side_nav_active_title {
    font-family: var(--font_eng);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 3px;
    color: var(--color_white);
    writing-mode: vertical-rl;
    text-orientation: mixed;
    text-transform: uppercase;
    transition: color var(--transition_fast);
    cursor: default;
    white-space: nowrap;
    margin-bottom: 12px;
}

/* 세로 라인 */
.side_nav_line {
    width: 1px;
    height: 80px;
    background: rgba(255, 255, 255, 0.35);
    margin-bottom: 10px;
    position: relative;
    overflow: hidden;
}

.side_nav_line::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 0%;
    background: var(--color_white);
    transition: height 0.85s cubic-bezier(0.76, 0, 0.24, 1);
}

.side_nav_line.filling::after {
    height: 100%;
}

/* 넘버링 */
.side_nav_number {
    font-family: var(--font_eng);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 2px;
    color: var(--color_white);
    writing-mode: vertical-rl;
    text-orientation: mixed;
    margin-bottom: 16px;
    opacity: 0.7;
    transition: all var(--transition_fast);
}

/* 비활성 도트들 (이 리스트 내에서 점이 스케일링으로 이동) */
.side_nav_dots {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}

.side_nav_dot_item {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.35);
    cursor: pointer;
    transition: all var(--transition_fast);
    position: relative;
}

.side_nav_dot_item:hover,
.side_nav_dot_item.active {
    background: rgba(255, 255, 255, 0.8);
    transform: scale(1.4);
}

.side_nav_dot_item.active {
    background: var(--color_white);
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.4);
}

.side_nav_dot_item .dot_label {
    position: absolute;
    right: 22px;
    top: 50%;
    transform: translateY(-50%);
    font-family: var(--font_eng);
    font-size: 10px;
    font-weight: 500;
    color: var(--color_white);
    white-space: nowrap;
    opacity: 0;
    transition: all var(--transition_fast);
    pointer-events: none;
    letter-spacing: 1px;
    text-transform: uppercase;
    background: rgba(0, 0, 0, 0.5);
    padding: 4px 10px;
    border-radius: 0px;
}

.side_nav_dot_item:hover .dot_label {
    opacity: 1;
    right: 18px;
}

/* 다크모드 (밝은 배경 섹션) */
.side_nav.is_dark .side_nav_active_title {
    color: var(--color_primary_dark);
}

.side_nav.is_dark .side_nav_line {
    background: rgba(0, 0, 0, 0.12);
}

.side_nav.is_dark .side_nav_line::after {
    background: var(--color_primary);
}

.side_nav.is_dark .side_nav_number {
    color: var(--color_primary);
}

.side_nav.is_dark .side_nav_dot_item {
    background: rgba(0, 0, 0, 0.2);
}

.side_nav.is_dark .side_nav_dot_item:hover,
.side_nav.is_dark .side_nav_dot_item.active {
    background: var(--color_primary);
}

.side_nav.is_dark .side_nav_dot_item.active {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
}

.side_nav.is_dark .side_nav_dot_item .dot_label {
    color: var(--color_white);
    background: var(--color_primary_dark);
}

/* ============================================
      ANIMATE
      ============================================ */
[data-animate] {
    opacity: 0;
    transition: opacity 0.8s ease, transform 0.8s ease;
}

[data-animate="fade-up"] {
    transform: translateY(50px);
}

[data-animate="fade-right"] {
    transform: translateX(-50px);
}

[data-animate="fade-left"] {
    transform: translateX(50px);
}

[data-animate].is_visible {
    opacity: 1;
    transform: translate(0, 0);
}

/* ============================================
      MOBILE NAV
      ============================================ */
.mobile_nav_overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition_fast);
}

.mobile_nav_overlay.active {
    opacity: 1;
    visibility: visible;
}

.mobile_nav {
    position: fixed;
    top: 0;
    right: -360px;
    width: 340px;
    height: 100%;
    background: var(--color_white);
    z-index: 2001;
    transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    overflow-y: auto;
}

.mobile_nav.active {
    right: 0;
}

.mobile_nav_header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--color_border);
}

.mobile_nav_logo {
    height: 36px;
}

.mobile_nav_close {
    font-size: 22px;
    color: var(--color_dark_gray);
    padding: 4px;
}

.mobile_nav_list {
    padding: 10px 0;
}

.mobile_nav_item {
    border-bottom: 1px solid var(--color_border);
}

.mobile_nav_link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    font-size: 16px;
    font-weight: 600;
    color: var(--color_text_dark);
}

.mobile_nav_link::after {
    content: '\f078';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    font-size: 12px;
    color: var(--color_medium_gray);
    transition: transform var(--transition_fast);
}

.mobile_nav_item.open .mobile_nav_link::after {
    transform: rotate(180deg);
}

.mobile_sub_list {
    display: none;
    background: var(--color_off_white);
    padding: 6px 0;
}

.mobile_nav_item.open .mobile_sub_list {
    display: block;
}

.mobile_sub_list li a {
    display: block;
    padding: 11px 24px 11px 40px;
    font-size: 14px;
    color: var(--color_text);
    transition: all var(--transition_fast);
}

.mobile_sub_list li a:hover {
    color: var(--color_primary);
    padding-left: 46px;
}

/* ============================================
   풀페이지 예외 처리 (태블릿 및 낮은 해상도)
   화면 너비 1024px 이하 또는 높이 850px 이하일 때 일반 스크롤 작동
   ============================================ */
@media (max-width: 1024px), (max-height: 850px) {
    /* fullpage 전환 완전 비활성화 (transform 초기화) */
    .fullpage_wrap {
        transition: none !important;
        transform: none !important;
    }

    .fp_section {
        height: auto;
        min-height: 100svh;
    }

    /* 일반 스크롤로 바운드될 때 상하 여백 확보 */
    .section_inner {
        padding-top: 100px;
        padding-bottom: 90px;
        height: auto;
        justify-content: flex-start;
    }

    .section_hero.fp_section {
        min-height: 100svh;
        height: 100svh;
    }

    .section_hero .section_inner {
        padding: 0;
    }

    /* Contact/Footer section은 auto */
    .section_contact {
        height: auto;
        min-height: auto;
    }

    .section_contact .section_inner {
        padding-top: 100px;
        padding-bottom: 60px;
    }

    .section_footer_auto {
        height: auto !important;
        min-height: auto !important;
    }
}

/* ============================================
      RESPONSIVE
      ============================================ */

/* ── 태블릿 가로 (1024px 이하) ────────────────── */
@media (max-width: 1024px) {
    /* GNB → 모바일 햄버거 메뉴로 전환 */
    .gnb {
        display: none;
    }

    .mobile_menu_btn {
        display: flex;
    }

    .side_nav {
        display: none;
    }

    /* Hero */
    .hero_line_1,
    .hero_line_2 {
        font-size: 52px;
        letter-spacing: 2px;
    }

    .hero_desc {
        font-size: 16px;
    }

    /* 공통 섹션 */
    .section_inner {
        padding-left: 32px;
        padding-right: 32px;
    }

    .section_title {
        font-size: 34px;
        margin-bottom: 40px;
    }

    .section_tag {
        margin-bottom: 12px;
    }

    /* About – 세로 배치 */
    .about_content,
    .about_flex_container {
        flex-direction: column !important;
        gap: 32px !important;
    }

    .about_visual,
    .about_visual_stretch {
        flex: 0 0 auto !important;
        width: 100% !important;
        order: -1;
        align-self: auto !important;
    }

    .about_img_box_fluid_container {
        min-height: 320px !important;
    }

    .about_img_placeholder {
        width: 100%;
        max-width: 100%;
        height: 300px;
    }

    .title_28_lh14_mb20 {
        font-size: 24px;
    }

    /* Business */
    .business_cards {
        grid-template-columns: repeat(2, 1fr);
    }

    /* History strip */
    .strip_milestones {
        flex-direction: column;
        height: auto;
        gap: 12px;
        margin-top: 30px;
    }

    .ms_strip {
        height: 170px;
        flex: none;
        padding: 28px 20px;
    }

    .ms_strip:hover {
        flex: none;
        height: 220px;
    }

    .ms_strip:hover p {
        height: auto;
    }

    .ms_strip_year {
        font-size: 60px;
    }

    .ms_strip h4 {
        font-size: 17px;
    }

    /* Partners */
    .partners_display_grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .partners_grid {
        grid-template-columns: repeat(3, 1fr);
    }

    /* Contact */
    .contact_flex_container {
        flex-direction: column !important;
        gap: 24px !important;
        margin-top: 24px !important;
    }

    .contact_map_wrapper {
        flex: none !important;
        height: 260px !important;
        width: 100% !important;
    }

    .contact_info_wrapper {
        flex: none !important;
        gap: 20px !important;
    }

    .contact_content {
        flex-direction: column;
    }

    .contact_info {
        flex: 0 0 auto;
    }

    /* Footer */
    .footer_inner {
        padding: 48px 32px;
    }
}

/* ── 태블릿 세로 / 큰 모바일 (768px 이하) ──── */
@media (max-width: 768px) {
    :root {
        --header_height: 60px;
    }

    /* Header */
    .header_inner {
        padding: 0 20px;
    }

    .logo img {
        height: 36px;
    }

    /* Hero */
    .section_hero .section_inner,
    .fp_section.section_hero {
        padding: 0;
    }

    .hero_line_1,
    .hero_line_2 {
        font-size: 38px;
        letter-spacing: 1px;
    }

    .hero_desc {
        font-size: 14px;
        letter-spacing: 0.3px;
        padding: 0 20px;
    }

    .hero_logo_badge img {
        height: 50px;
    }

    .scroll_indicator {
        bottom: 30px;
    }

    .scroll_line {
        height: 44px;
    }

    /* 공통 섹션 */
    .section_inner {
        padding: 60px 20px;
        height: auto;
        justify-content: flex-start;
    }

    .section_title {
        font-size: 26px;
        margin-bottom: 28px;
        line-height: 1.35;
    }

    .section_tag {
        font-size: 11px;
        margin-bottom: 10px;
    }

    /* About */
    .about_content,
    .about_flex_container {
        flex-direction: column !important;
        gap: 24px !important;
        padding: 0 !important;
    }

    .about_visual,
    .about_visual_stretch {
        flex: 0 0 auto !important;
        width: 100% !important;
        order: -1;
        align-self: auto !important;
    }

    .about_img_box_fluid_container {
        min-height: 240px !important;
    }

    .about_img_placeholder {
        width: 100%;
        max-width: 100%;
        height: 240px;
    }

    .about_img_deco {
        display: none;
    }

    .title_28_lh14_mb20 {
        font-size: 20px;
        line-height: 1.4;
        margin-bottom: 16px !important;
    }

    .desc_16_mb15 {
        font-size: 14px;
        margin-bottom: 12px !important;
    }

    .desc_15_lh16_mb15,
    .desc_15_lh16_mb30 {
        font-size: 14px;
        margin-bottom: 12px !important;
    }

    .about_quote i {
        font-size: 28px;
    }

    .ceo_sign_name_bold {
        font-size: 17px;
    }

    /* Business */
    .business_cards {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .business_card {
        padding: 28px 20px;
    }

    /* History strip */
    .strip_milestones {
        flex-direction: column;
        height: auto;
        gap: 10px;
        margin-top: 20px;
    }

    .ms_strip {
        height: 150px;
        flex: none;
        padding: 22px 18px;
    }

    .ms_strip:hover {
        flex: none;
        height: auto;
    }

    .ms_strip:hover p {
        height: auto;
    }

    .ms_strip_year {
        font-size: 50px;
        top: 10px;
        left: 14px;
    }

    .ms_strip h4 {
        font-size: 15px;
        margin-bottom: 10px;
    }

    .ms_strip_date {
        font-size: 12px;
        margin-bottom: 10px;
    }

    .ms_strip_multi_item {
        font-size: 12px;
    }

    /* Partners */
    .partners_display_grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .partner_card_inner {
        flex-direction: column;
        text-align: center;
        padding: 24px 16px;
        gap: 16px;
    }

    .partner_logo_box {
        flex: 0 0 auto;
        width: 100%;
        height: 80px;
    }

    .partner_info_box h5 {
        font-size: 16px;
    }

    .partner_info_box p {
        font-size: 13px;
    }

    .partners_grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 14px;
    }

    /* Contact */
    .contact_flex_container {
        flex-direction: column !important;
        gap: 20px !important;
        margin-top: 16px !important;
    }

    .contact_map_wrapper {
        flex: none !important;
        height: 220px !important;
        width: 100% !important;
    }

    .contact_iframe_radius {
        border-radius: 8px;
    }

    .contact_info_wrapper {
        flex: none !important;
        gap: 16px !important;
    }

    .contact_info_item_flex {
        gap: 14px;
    }

    .icon_accent_24_mt5 {
        font-size: 18px;
    }

    .contact_h4_mb8 {
        font-size: 14px;
    }

    .contact_p_lh15 {
        font-size: 13px;
    }

    .contact_map {
        min-height: 200px;
    }

    .map_placeholder {
        min-height: 200px;
    }

    /* Footer */
    .footer_inner {
        padding: 36px 20px;
    }

    .footer_top {
        flex-direction: column;
        gap: 16px;
        align-items: flex-start;
    }

    .footer_logo img {
        height: 36px;
    }

    .footer_links {
        gap: 14px;
        flex-wrap: wrap;
    }

    .footer_links li a {
        font-size: 13px;
    }

    .footer_bottom p {
        font-size: 12px;
        word-break: keep-all;
    }

    /* History timeline (old) */
    .history_timeline {
        padding-left: 46px;
    }

    .timeline_dot {
        left: -40px;
    }

    .timeline_year {
        font-size: 22px;
    }

    /* Side nav 제거 */
    .side_nav {
        display: none;
    }
}



/* ── 소형 모바일 (480px 이하) ────────────────── */
@media (max-width: 480px) {
    /* Hero */
    .hero_line_1,
    .hero_line_2 {
        font-size: 30px;
        letter-spacing: 0;
    }

    .hero_desc {
        font-size: 13px;
    }

    /* 공통 */
    .section_inner {
        padding: 50px 16px;
    }

    .section_title {
        font-size: 22px;
        margin-bottom: 22px;
    }

    /* About */
    .about_img_box_fluid_container {
        min-height: 200px !important;
    }

    .title_28_lh14_mb20 {
        font-size: 18px;
    }

    /* History strip */
    .ms_strip {
        padding: 18px 14px;
        height: 140px;
    }

    .ms_strip_year {
        font-size: 42px;
    }

    .ms_strip h4 {
        font-size: 14px;
    }

    /* Business */
    .bp_card_inner {
        padding: 32px 24px;
    }

    .bp_title {
        font-size: 20px;
    }

    .bp_desc {
        font-size: 14px;
    }

    /* Partners */
    .partner_card_inner {
        padding: 20px 14px;
    }

    /* Footer */
    .footer_inner {
        padding: 28px 16px;
    }

    .footer_links {
        gap: 10px;
    }

    .footer_links li a {
        font-size: 12px;
    }

    .footer_bottom p {
        font-size: 11px;
    }
}

/* ============================================
   PRIVACY MODAL
   ============================================ */
.privacy_modal_overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.6);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition_fast);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.privacy_modal_overlay.active {
    opacity: 1;
    visibility: visible;
}

.privacy_modal_box {
    background: var(--color_white);
    width: 90%;
    max-width: 800px;
    max-height: 85vh;
    border-radius: 0;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    transform: translateY(30px);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border-top: 4px solid var(--color_primary_dark);
}

.privacy_modal_overlay.active .privacy_modal_box {
    transform: translateY(0);
}

.privacy_modal_header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 24px 32px;
    border-bottom: 1px solid var(--color_border);
    background: var(--color_off_white);
}

.privacy_modal_header h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--color_text_dark);
    margin: 0;
}

.privacy_close_btn {
    font-size: 24px;
    color: var(--color_text);
    cursor: pointer;
    transition: color var(--transition_fast);
}

.privacy_close_btn:hover {
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.privacy_modal_body {
    padding: 32px;
    overflow-y: auto;
    font-size: 15px;
    line-height: 1.8;
    color: var(--color_text);
}

.privacy_modal_body p,
.privacy_modal_body ul {
    margin-bottom: 12px;
    word-break: keep-all;
}

@media (max-width: 768px) {
    .privacy_modal_box {
        width: 100%;
        height: 100vh;
        max-height: 100vh;
        border-top: none;
    }

    .privacy_modal_overlay {
        align-items: flex-end;
    }
}

/* ============================================
   RESPONSIVE (SUB PAGES)
   ============================================ */
@media (max-width: 1024px) {
    .sub_hero {
        height: 240px;
    }

    .sub_hero .hero_line_2 {
        font-size: 32px;
    }

    .ceo_greeting_wrap {
        padding: 50px 0 !important;
    }

    .ceo_greeting_wrap h3 {
        font-size: 26px !important;
    }

    .protection_content,
    .privacy_modal_body {
        font-size: 14px;
    }

    .sub_content_wrap .section_inner {
        padding: 0 24px;
    }
}

@media (max-width: 768px) {
    .sub_hero {
        height: 200px;
        padding-top: calc(var(--header_height) + 20px);
    }

    .sub_hero .hero_line_1 {
        font-size: 12px;
        letter-spacing: 4px;
    }

    .sub_hero .hero_line_2 {
        font-size: 26px;
    }

    .sub_content_wrap .section_inner {
        padding: 0 20px;
    }

    .ceo_greeting_wrap {
        padding: 40px 0 !important;
    }

    .ceo_greeting_wrap h3 {
        font-size: 22px !important;
        line-height: 1.5 !important;
    }

    .ceo_greeting_wrap p {
        font-size: 15px !important;
        margin-bottom: 20px !important;
    }

    .ceo_sign {
        margin-top: 30px !important;
    }

    .ceo_sign span {
        font-size: 13px !important;
    }

    .ceo_sign strong {
        font-size: 18px !important;
    }
}

/* ============================================
   SUB CONTENT WRAP
   ============================================ */
.sub_content_wrap {
    padding-top: 80px;
    padding-bottom: 100px;
}

/* sub_content_wrap 안의 section_inner는 fullpage용 height: 100% 해제 */
.sub_content_wrap .section_inner {
    height: auto;
    justify-content: flex-start;
}

/* ============================================
   HISTORY SUB PAGE (컨텐츠 헤더)
   ============================================ */
.history_section_header {
    text-align: center;
    margin-bottom: 60px;
    padding-top: 40px;
}

.history_section_header h3 {
    font-size: 32px;
    font-weight: 700;
    color: var(--color_primary_dark);
    margin-bottom: 16px;
}

.history_section_header p {
    font-size: 16px;
    color: var(--color_medium_gray);
    word-break: keep-all;
}

.partners_top_desc {
    font-size: 20px !important;
    color: var(--color_text_dark) !important;
    line-height: 1.6 !important;
    font-weight: 500;
}

/* ============================================
   CEO GREETING SUB PAGE
   ============================================ */
.ceo_greeting_wrap {
    padding: 80px 0;
}

.ceo_greeting_title {
    font-size: 32px;
    font-weight: 300;
    line-height: 1.4;
    border-bottom: none;
    padding-bottom: 10px;
}

.ceo_greeting_subtitle {
    font-size: 18px;
    font-weight: 500;
    color: var(--color_text_dark);
    margin-bottom: 30px;
}

.ceo_sign_large {
    margin-top: 50px;
}

/* ============================================
   POLICY BOX (개인정보처리방침, 금융소비자보호기준 등)
   ============================================ */
.policy_box {
    background: var(--color_white);
    padding: 40px 0;
    font-size: 16px;
    color: var(--color_text);
    line-height: 1.8;
}

.policy_title_wrap {
    text-align: center;
    margin-bottom: 40px;
}

.policy_main_title {
    font-size: 32px;
    font-weight: 700;
    color: var(--color_primary_dark);
    margin: 8px 0;
}

.policy_sub_title {
    font-size: 18px;
    font-weight: 500;
    color: var(--color_medium_gray);
}

.policy_box p {
    margin-bottom: 12px;
    word-break: keep-all;
}

.policy_intro {
    margin-bottom: 30px !important;
}

.policy_box ul {
    margin-bottom: 12px;
}

.policy_chapter {
    font-size: 24px;
    font-weight: 700;
    color: var(--color_text_dark);
    margin-top: 60px;
    margin-bottom: 24px;
    border-bottom: 2px solid var(--color_text_dark);
    padding-bottom: 12px;
}

.policy_article {
    font-size: 18px;
    font-weight: 700;
    color: var(--color_primary_dark);
    margin-top: 40px;
    margin-bottom: 16px;
}

.policy_indent_1 {
    margin-bottom: 12px;
    padding-left: 20px;
    text-indent: -20px;
    color: var(--color_text_dark);
    word-break: keep-all;
}

.policy_indent_2 {
    margin-bottom: 8px;
    padding-left: 32px;
    text-indent: -16px;
    word-break: keep-all;
}

.policy_indent_3 {
    margin-bottom: 8px;
    padding-left: 44px;
    text-indent: -16px;
    color: var(--color_medium_gray);
    word-break: keep-all;
}

.policy_list_disc {
    margin-bottom: 12px;
    padding-left: 20px;
    list-style-type: disc;
}

.policy_list_none {
    list-style-type: none;
    margin-bottom: 12px;
    padding-left: 0;
}

.policy_info_box {
    background: rgba(0, 0, 0, 0.03);
    padding: 20px;
    border-radius: 4px;
    margin-bottom: 20px;
}

.policy_info_box strong {
    display: block;
    margin-bottom: 8px;
    color: var(--color_primary_dark);
}

/* ============================================
   컨텐츠 준비 중 플레이스홀더
   ============================================ */
.content_placeholder {
    text-align: center;
    padding: 100px 0;
    color: #999;
}

.content_placeholder i {
    font-size: 48px;
    margin-bottom: 20px;
    opacity: 0.3;
    display: block;
}

/* ============================================
   LUXURY HISTORY UI
   ============================================ */
.luxury_history_wrap {
    padding: 60px 0 120px 0;
    display: flex;
    flex-direction: column;
    gap: 40px;
    max-width: 900px;
    margin: 0 auto;
}

.luxury_year_block {
    position: relative;
    background: var(--color_white);
    padding: 40px 60px;
    border-radius: 0px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.04);
    border: 1px solid var(--color_border);
    border-left: 4px solid var(--color_accent);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: 20px;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    opacity: 0;
    transform: translateY(30px);
}

.luxury_year_block.is_visible {
    opacity: 1;
    transform: translateY(0);
}

.luxury_year_block:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.08);
}

.year_bg_text {
    position: absolute;
    top: -20px;
    right: 20px;
    font-size: 140px;
    font-weight: 900;
    color: var(--color_light_gray);
    line-height: 1;
    z-index: 0;
    pointer-events: none;
    font-family: var(--font_display);
    opacity: 0.6;
}

.year_content {
    position: relative;
    z-index: 1;
}

.year_title {
    font-size: 32px;
    font-weight: 800;
    color: var(--color_primary_dark);
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    gap: 16px;
}

.year_title::after {
    content: '';
    height: 2px;
    width: 40px;
    background: var(--gradient_accent);
    display: inline-block;
}

.year_events {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.year_events li {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

.event_month {
    display: inline-block;
    font-size: 18px;
    font-weight: 700;
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    min-width: 50px;
    padding-top: 2px;
    font-family: var(--font_display);
}

.event_text {
    font-size: 17px;
    color: var(--color_text);
    font-weight: 500;
    line-height: 1.6;
    word-break: keep-all;
}

@media (max-width: 768px) {
    .luxury_history_wrap {
        padding: 20px 0 40px 0;
        gap: 20px;
    }

    .luxury_year_block {
        padding: 30px 24px;
        border-left-width: 3px;
    }

    .year_bg_text {
        font-size: 90px;
        top: 0;
        right: 10px;
        opacity: 0.4;
    }

    .year_title {
        font-size: 26px;
        margin-bottom: 20px;
    }

    .year_events li {
        gap: 16px;
    }

    .event_month {
        font-size: 16px;
        min-width: 45px;
    }

    .event_text {
        font-size: 15px;
    }
}

/* ============================================
   CERTIFICATE SUB PAGE
   ============================================ */
.cert_wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    max-width: 1000px;
    margin: 0 auto;
    padding-top: 20px;
}

.cert_item {
    background: var(--color_white);
    border: 1px solid var(--color_border);
    padding: 30px;
    text-align: center;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
    border-top: 4px solid var(--color_accent);
}

.cert_title {
    font-size: 20px;
    font-weight: 700;
    color: var(--color_primary_dark);
    margin-bottom: 24px;
}

.cert_img img {
    width: 100%;
    height: auto;
    border: 1px solid var(--color_border);
}

@media (max-width: 768px) {
    .cert_wrap {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .cert_item {
        padding: 20px;
    }
}

.partner_img {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.partner_img img {
    max-width: 100%;
    max-height: 40px;
    object-fit: contain;
}


/* ============================================
      NEW HISTORY GRID
      ============================================ */
@media (max-width: 480px) {
    .history_grid_ui {
        grid-template-columns: 1fr;
    }
}


/* UNIFIED LUXURY CARD UI */
.luxury_card {
    background: var(--color_white);
    border: 1px solid var(--color_border);
    position: relative;
    transition: transform var(--transition_mid), box-shadow var(--transition_mid);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.02);
}

.luxury_card:hover {
    transform: translateY(-8px);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.06);
    border-color: transparent;
}

.luxury_card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 4px;
    background: var(--gradient_accent);
    transition: width var(--transition_mid);
    z-index: 2;
}

.luxury_card:hover::before {
    width: 100%;
}

/* Remove default background and borders for business card since luxury_card handles it */
.section_business .business_card {
    border: none;
    background: transparent;
}

/* Responsive overrides for inline flex layouts → handled in main RESPONSIVE section above */
@media (max-width: 768px) {
    .partners_grid_3 {
        grid-template-columns: repeat(1, 1fr) !important;
    }
}

/* ============================================
   EXTRACTED INLINE STYLES
   ============================================ */
.about_flex_container {
    display: flex;
    gap: 100px;
}

.flex_grow_1 {
    flex: 1;
}

.icon_accent_24 {
    color: var(--color_accent);
    font-size: 24px;
}

.title_28_lh14_mb20 {
    font-size: 28px;
    line-height: 1.4;
    margin-bottom: 20px;
}

.desc_16_mb15 {
    font-size: 16px;
    color: var(--color_text);
    margin-bottom: 15px;
}

.desc_15_lh16_mb15 {
    font-size: 15px;
    color: var(--color_text);
    line-height: 1.6;
    margin-bottom: 15px;
}

.desc_15_lh16_mb30 {
    font-size: 15px;
    color: var(--color_text);
    line-height: 1.6;
    margin-bottom: 30px;
}

.ceo_sign_wrapper_right {
    text-align: right;
    margin-top: 30px;
    display: block;
}

.ceo_sign_position {
    font-size: 14px;
    color: var(--color_medium_gray);
}

.ceo_sign_name_bold {
    font-size: 20px;
    color: var(--color_text_dark);
    margin-top: 5px;
    display: inline-block;
}

.img_box_fluid {
    width: 100%;
    height: 100%;
    position: relative;
}

.bg_company_cover {
    width: 100%;
    height: 100%;
    min-height: 350px;
    background: url('../assets/company.jpg') no-repeat center center / cover;
}

.ceo_img_bg {
    background: url('../assets/company.jpg') no-repeat center center / cover;
}

.partners_grid_container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 40px;
}

.partner_item_box {
    padding: 40px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 140px;
}

.partner_img_fluid {
    max-width: 70%;
    max-height: 60px;
    object-fit: contain;
}

.contact_flex_container {
    display: flex;
    gap: 40px;
    margin-top: 40px;
}

.mt_40 {
    margin-top: 40px;
}

.contact_map_wrapper {
    flex: 1;
    height: 300px;
}

.contact_iframe_radius {
    border: 0;
    border-radius: 16px;
}

.contact_iframe_radius_12 {
    border: 0;
    border-radius: 12px;
}

.contact_info_wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 30px;
}

.contact_info_item_flex {
    display: flex;
    gap: 20px;
    align-items: flex-start;
}

.icon_accent_24_mt5 {
    color: var(--color_accent);
    font-size: 24px;
    margin-top: 5px;
}

.contact_h4_mb8 {
    font-size: 16px;
    margin-bottom: 8px;
}

.contact_p_lh15 {
    color: var(--color_text);
    line-height: 1.5;
}

.section_footer_auto {
    min-height: auto;
    height: auto;
}



/* ============================================
   MAIN HISTORY GRID (Main Page)
   ============================================ */
.main_history_grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-top: 40px;
    width: 100%;
}

.history_grid_card {
    background: var(--color_white);
    border: 1px solid var(--color_border);
    padding: 30px 24px;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
    transition: all var(--transition_mid);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.02);
}

.history_grid_card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.05);
    border-color: transparent;
}

.history_grid_card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 4px;
    background: var(--gradient_accent);
    transition: width var(--transition_mid);
    z-index: 2;
}

.history_grid_card:hover::before {
    width: 100%;
}

.hc_year {
    font-family: var(--font_display);
    font-size: 40px;
    font-weight: 900;
    color: rgba(0, 0, 0, 0.04);
    position: absolute;
    top: 10px;
    right: 15px;
    line-height: 1;
    pointer-events: none;
    transition: all 0.4s ease;
}

.history_grid_card:hover .hc_year {
    color: rgba(164, 145, 197, 0.12);
    transform: scale(1.1) translateX(-5px);
}

.hc_month {
    font-family: var(--font_eng);
    font-size: 15px;
    font-weight: 800;
    color: var(--color_accent);
    margin-bottom: 12px;
    letter-spacing: 1px;
}

.history_grid_card h4 {
    font-size: 19px;
    font-weight: 700;
    color: var(--color_text_dark);
    margin-bottom: 12px;
    line-height: 1.4;
    word-break: keep-all;
}

.history_grid_card p {
    font-size: 15px;
    color: var(--color_text);
    line-height: 1.6;
    word-break: keep-all;
    margin-bottom: 0;
}

.hc_multi_item {
    font-size: 14px;
    color: var(--color_text);
    margin-bottom: 8px;
    display: flex;
    gap: 8px;
    align-items: center;
}

.hc_multi_item span {
    font-family: var(--font_eng);
    font-weight: 800;
    color: var(--color_accent);
    font-size: 12px;
}

@media (max-width: 1024px) {
    .main_history_grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .main_history_grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .main_history_grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   PREMIUM CONTACT UI (Main Page)
   ============================================ */
.premium_contact_wrap {
    display: flex;
    gap: 0;
    margin-top: 40px;
    height: 540px;
    border: 1px solid var(--color_border);
    background: var(--color_white);
    overflow: hidden;
    width: 100%;
    max-width: 1200px;
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.05);
}

.contact_map_box {
    flex: 1.4;
    background: var(--color_off_white);
}

.contact_premium_panel {
    flex: 1;
    background: var(--color_white);
    padding: 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-left: 1px solid var(--color_border);
}

.panel_inner h3 {
    font-family: var(--font_eng);
    font-size: 22px;
    font-weight: 800;
    margin-bottom: 40px;
    text-transform: uppercase;
    letter-spacing: 3px;
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.panel_items {
    display: flex;
    flex-direction: column;
    gap: 35px;
}

.pi_item {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pi_label {
    font-family: var(--font_eng);
    font-size: 11px;
    font-weight: 700;
    color: var(--color_accent);
    letter-spacing: 2px;
}

.pi_item p {
    font-size: 16px;
    color: var(--color_text_dark);
    line-height: 1.5;
    word-break: keep-all;
    font-weight: 500;
}

.pi_group {
    display: flex;
    gap: 40px;
}

.panel_footer {
    margin-top: 50px;
    padding-top: 30px;
    border-top: 1px dashed var(--color_border);
}

.map_btn {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    font-weight: 700;
    color: var(--color_text_dark);
    text-decoration: none;
    transition: all var(--transition_fast);
}

.map_btn i {
    color: var(--color_accent);
    transition: transform 0.3s ease;
}

.map_btn:hover {
    color: var(--color_accent);
}

.map_btn:hover i {
    transform: translateX(8px);
}

/* Responsive Contact */
@media (max-width: 1024px) {
    .premium_contact_wrap {
        flex-direction: column;
        height: auto;
        max-width: 600px;
        margin-left: auto;
        margin-right: auto;
    }

    .contact_map_box {
        height: 300px;
        flex: none;
    }

    .contact_premium_panel {
        padding: 40px 30px;
        border-left: none;
        border-top: 1px solid var(--color_border);
    }

    .pi_group {
        gap: 30px;
        flex-wrap: wrap;
    }
}

/* ============================================
   PARTNERS GRID UTILITY
   ============================================ */
.partners_grid_5 {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 15px;
    width: 100%;
}

.logo_text {
    font-family: var(--font_display);
    font-size: 15px;
    font-weight: 800;
    color: var(--color_text_dark);
    text-align: center;
    line-height: 1;
}

.partners_note {
    margin-top: 40px;
    font-size: 13px;
    color: var(--color_medium_gray);
    text-align: center;
}

@media (max-width: 1024px) {
    .partners_grid_5 {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .partners_grid_5 {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ============================================
   PREMIUM BUSINESS GRID (Main Page)
   ============================================ */
.premium_business_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 50px;
    width: 100%;
}

.bp_card {
    background: var(--color_white);
    position: relative;
    overflow: hidden;
    border: 1px solid var(--color_border);
    transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
    cursor: pointer;
    height: 100%;
    min-height: 440px;
}

.bp_card_inner {
    padding: 50px 40px;
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.bp_card_bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--color_primary_dark);
    opacity: 0;
    transform: translateY(100%);
    transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
    z-index: 1;
}

.bp_card:hover .bp_card_bg {
    opacity: 1;
    transform: translateY(0);
}

.bp_icon {
    width: 64px;
    height: 64px;
    background: var(--color_off_white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: var(--color_accent);
    margin-bottom: 30px;
    border: 1px solid var(--color_border);
    transition: all 0.4s ease;
}

.bp_card:hover .bp_icon {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: var(--color_white);
    transform: rotateY(180deg);
}

.bp_title {
    font-size: 24px;
    font-weight: 700;
    color: var(--color_text_dark);
    margin-bottom: 20px;
    transition: color 0.4s ease;
}

.bp_card:hover .bp_title {
    color: var(--color_white);
}

.bp_desc {
    font-size: 16px;
    color: var(--color_text);
    line-height: 1.6;
    margin-bottom: 30px;
    transition: color 0.4s ease;
    word-break: keep-all;
}

.bp_card:hover .bp_desc {
    color: rgba(255, 255, 255, 0.8);
}

.bp_number {
    position: absolute;
    bottom: -10px;
    right: 15px;
    font-family: var(--font_display);
    font-size: 100px;
    font-weight: 900;
    color: rgba(0, 0, 0, 0.02);
    line-height: 1;
    transition: all 0.4s ease;
}

.bp_card:hover .bp_number {
    color: rgba(255, 255, 255, 0.05);
    bottom: 10px;
}

.bp_features {
    list-style: none;
    padding-top: 25px;
    border-top: 1px solid var(--color_border);
    margin-top: auto;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.4s ease;
}

.bp_card:hover .bp_features {
    opacity: 1;
    transform: translateY(0);
    border-top-color: rgba(255, 255, 255, 0.1);
}

.bp_features li {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 10px;
    position: relative;
    padding-left: 15px;
}

.bp_features li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 8px;
    width: 4px;
    height: 4px;
    background: var(--color_accent);
}

.bp_card:hover {
    transform: translateY(-15px);
    box-shadow: 0 40px 80px rgba(0, 0, 0, 0.1);
}

/* Responsive Business Grid */
@media (max-width: 1024px) {
    .premium_business_grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .premium_business_grid {
        grid-template-columns: 1fr;
    }

    .bp_card {
        min-height: auto;
    }
}

/* ============================================
   PREMIUM MILESTONE LIST (History Sub Page)
   ============================================ */
.premium_milestones {
    margin-top: 50px;
    width: 100%;
}

.milestone_item {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 0;
    padding: 30px 0;
    border-bottom: 1px solid var(--color_border);
    transition: background var(--transition_fast), padding var(--transition_fast);
    align-items: center;
}

.milestone_item:first-child {
    border-top: 1px solid var(--color_border);
}

.milestone_item:hover {
    background: rgba(0, 0, 0, 0.01);
    padding-left: 20px;
}

.premium_milestones .ms_year_bg {
    font-family: var(--font_display);
    font-size: 38px;
    font-weight: 800;
    color: rgba(0, 0, 0, 0.05);
    /* Synchronized with index visibility */
    letter-spacing: -1px;
    transition: color var(--transition_fast);
}

.milestone_item:hover .ms_year_bg {
    background: var(--gradient_accent_text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.ms_content {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.ms_multi_wrap {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.ms_multi_row {
    display: flex;
    gap: 0;
    align-items: flex-start;
}

.ms_date {
    font-family: var(--font_eng);
    font-size: 14px;
    font-weight: 700;
    color: var(--color_accent);
    letter-spacing: 2px;
    text-transform: uppercase;
    flex-shrink: 0;
    margin-right: 15px;
}

.ms_multi_text {
    flex: 1;
}

.milestone_item h4,
.ms_multi_text h4 {
    font-size: 19px;
    font-weight: 700;
    color: var(--color_text_dark);
    margin-bottom: 4px;
}

.milestone_item p,
.ms_multi_text p {
    font-size: 14px;
    color: var(--color_text);
    line-height: 1.6;
    max-width: 700px;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .milestone_item {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 30px 0;
    }

    .premium_milestones .ms_year_bg {
        font-size: 32px;
    }

    .ms_multi_row {
        gap: 0;
    }
}

/* ============================================
   ABOUT SECTION INLINE STYLES MOVED
   ============================================ */
.about_visual_stretch {
    align-self: stretch;
}

.about_img_box_fluid_container {
    overflow: hidden;
    min-height: 380px;
    border-radius: 20px;
}

.about_bg_video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}

.about_img_placeholder_transparent {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    background: transparent;
}

/* ============================================
      PASSWORD POPUP
      ============================================ */
#btn_partners_link {
    color: inherit; 
    text-decoration: none;
}
.history_multi_wrap {
    margin-bottom: 12px;
}
.password_popup_wrap {
    display: none; 
    position: fixed; 
    top: 0; 
    left: 0; 
    width: 100%; 
    height: 100%; 
    background: rgba(0,0,0,0.6); 
    z-index: 10000; 
    justify-content: center; 
    align-items: center; 
    backdrop-filter: blur(5px);
}
.password_popup_box {
    background: #fff; 
    padding: 35px 30px; 
    border-radius: 12px; 
    text-align: center; 
    box-shadow: 0 10px 25px rgba(0,0,0,0.2); 
    width: 100%; 
    max-width: 320px; 
    box-sizing: border-box;
}
.password_popup_title {
    margin: 0 0 20px; 
    font-size: 20px; 
    color: #222; 
    font-weight: 700;
}
.password_popup_input {
    width: 100%; 
    padding: 12px; 
    margin-bottom: 8px; 
    border: 1px solid #ddd; 
    border-radius: 6px; 
    box-sizing: border-box; 
    font-size: 15px; 
    outline: none; 
    transition: border-color 0.2s;
}
.password_popup_input:focus {
    border-color: #222;
}
.password_popup_error {
    color: #ff3b3b; 
    font-size: 13px; 
    display: none; 
    margin: 0 0 15px; 
    text-align: left; 
    padding-left: 2px;
}
.password_popup_btn_wrap {
    margin-top: 20px; 
    display: flex; 
    gap: 10px; 
    justify-content: center;
}
.password_popup_btn {
    padding: 12px 10px; 
    border: none; 
    border-radius: 6px; 
    cursor: pointer; 
    flex: 1; 
    font-size: 14px; 
    font-weight: 600; 
    transition: background 0.2s;
}
.password_popup_btn_cancel {
    background: #f0f0f0; 
    color: #555; 
}
.password_popup_btn_cancel:hover {
    background: #e4e4e4;
}
.password_popup_btn_confirm {
    background: #222; 
    color: #fff; 
}
.password_popup_btn_confirm:hover {
    background: #333;
}

/* ============================================
   금융소비자보호기준 프리미엄 레이아웃 및 스타일
   ============================================ */
.policy_layout_main {
    background-color: var(--color_off_white);
    padding: 80px 0;
}

.policy_container {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
}

/* 본문 영역 */
.policy_content_wrap {
    width: 100%;
}

.policy_box {
    background: transparent;
    padding: 0;
}

.policy_title_wrap {
    text-align: center;
    margin-bottom: 40px;
}

.policy_badge {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    color: var(--color_accent);
    background-color: var(--color_accent_light);
    padding: 6px 12px;
    border-radius: 20px;
    margin-bottom: 12px;
}

.policy_main_title {
    font-size: 36px;
    font-weight: 800;
    color: var(--color_primary_dark);
    margin: 0 0 10px;
    letter-spacing: -1px;
}

.policy_sub_title {
    font-size: 15px;
    font-weight: 500;
    color: var(--color_medium_gray);
}

/* 개별 장(Chapter) 카드 스타일 */
.policy_section {
    background: var(--color_white);
    border: 1px solid var(--color_border);
    border-radius: 20px;
    padding: 40px;
    margin-bottom: 30px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.02);
    transition: transform var(--transition_fast), box-shadow var(--transition_fast);
}

.policy_section:hover {
    transform: translateY(-2px);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.04);
}

.policy_chapter {
    font-size: 22px;
    font-weight: 800;
    color: var(--color_primary_dark);
    margin-top: 0;
    margin-bottom: 30px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--color_primary);
    display: flex;
    align-items: center;
    gap: 10px;
}

.chapter_num {
    color: var(--color_accent);
    font-size: 18px;
    font-weight: 700;
}

.policy_articles {
    display: flex;
    flex-direction: column;
    gap: 35px;
}

.policy_article_item {
    scroll-margin-top: 120px;
}

.policy_article {
    font-size: 17px;
    font-weight: 700;
    color: var(--color_primary_dark);
    margin-top: 0;
    margin-bottom: 12px;
    border-left: 4px solid var(--color_accent);
    padding-left: 12px;
    line-height: 1.4;
}

.policy_text {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color_text);
    word-break: keep-all;
}

/* 들여쓰기 클래스 고도화 */
.policy_indent_1, .policy_indent_2, .policy_indent_3 {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color_text);
    margin-bottom: 8px;
    position: relative;
    word-break: keep-all;
    margin-left: 16px; /* 모든 들여쓰기를 article 텍스트 시작선에 맞춤 */
}

.policy_indent_1 {
    padding-left: 24px; /* 본문 텍스트와 불릿이 겹치지 않게 여백 확보 */
}

.policy_indent_2 {
    padding-left: 44px;
    color: #4b5563;
}

.policy_indent_3 {
    padding-left: 64px;
    color: #6b7280;
}

.num_bullet {
    position: absolute;
    left: 0;
    font-weight: 600;
    color: var(--color_accent);
}

.policy_indent_2 .num_bullet {
    left: 24px; /* 상위 텍스트 시작선에 맞추어 불릿 배치 */
    color: var(--color_primary_light);
}

.policy_indent_3 .num_bullet {
    left: 44px;
    color: var(--color_medium_gray);
}

/* 조직 구성 시각화 */
.org_chart_box {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 15px 0 20px 24px;
}

.org_card {
    background: linear-gradient(135deg, rgba(44, 82, 130, 0.04) 0%, rgba(74, 144, 217, 0.01) 100%);
    border: 1px solid rgba(44, 82, 130, 0.12);
    border-radius: 12px;
    padding: 18px;
    text-align: center;
    transition: border-color var(--transition_fast), box-shadow var(--transition_fast);
}

.org_card:hover {
    border-color: rgba(44, 82, 130, 0.3);
    box-shadow: 0 4px 12px rgba(44, 82, 130, 0.06);
}

.org_role {
    font-size: 13px;
    font-weight: 600;
    color: var(--color_accent);
    margin-bottom: 6px;
    letter-spacing: -0.2px;
}

.org_name {
    font-size: 16px;
    font-weight: 700;
    color: var(--color_primary_dark);
}

/* 매뉴얼 그리드 박스 */
.manual_grid_box {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin: 15px 0 20px 24px;
}

.manual_item {
    background: var(--color_off_white);
    border: 1px solid var(--color_border);
    border-radius: 8px;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--color_text_dark);
    font-weight: 500;
    transition: all var(--transition_fast);
}

.manual_item:hover {
    border-color: var(--color_accent);
    background: var(--color_white);
    box-shadow: 0 4px 12px rgba(44, 82, 130, 0.06);
    transform: translateX(4px);
}

.manual_num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    background: var(--color_accent_light);
    color: var(--color_accent);
    font-weight: 700;
    font-size: 11px;
    border-radius: 50%;
}

/* 반응형 모바일 최적화 */
@media (max-width: 1024px) {
    .policy_layout_main {
        padding: 50px 0;
    }
    
    .policy_section {
        padding: 30px 20px;
        border-radius: 12px;
        margin-bottom: 20px;
    }
    
    .org_chart_box {
        grid-template-columns: 1fr;
        margin-left: 0;
    }
    
    .manual_grid_box {
        grid-template-columns: 1fr;
        margin-left: 0;
    }
    
    .policy_main_title {
        font-size: 28px;
    }
}