@charset "utf-8";
/* ── 서브페이지 전체 통합 CSS ──
   Generated: 2026-05-21
   모든 서브페이지 스타일을 하나의 파일로 통합
*/


/* ════════════════════════════════════
   공통 섹션 라벨 (컨펌 디자인 기준: .ceo-label)
   ════════════════════════════════════ */
.ceo-label,
.cta-label,
.strength-label,
.contact-label,
.expert-label,
.thesis-section-label,
.journal-section-label,
.lec-label,
.stat-label,
.ai-label,
.adm-label,
.prf-label {
    display: inline-block;
    font-family: "Jost", sans-serif;
    font-size: 2rem;
    font-weight: bolder;
    letter-spacing: 0.14em;
    color: var(--main-color);
    text-transform: uppercase;
    margin-bottom: 1.2rem;
}

input[type="search"], textarea{
    padding: 5px;
}

/* ════════════════════════════════════
   about_ceo
   ════════════════════════════════════ */
/* ── about_ceo.css ── */

/* ── 공통 섹션 ── */
.ceo-section {
    padding: 10rem 3rem;
    box-sizing: border-box;
}
.ceo-section-inner {
    max-width: 1380px;
    margin: 0 auto;
    position: relative;
}
/* .ceo-label — 공통 라벨 스타일은 상단에 통합 정의 */
.ceo-section-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 1.6rem;
}

/* ── SECTION 1: 대표 인사말 ── */
.greeting-wrap { background: #fff; }
.greeting-grid {
    display: grid;
    grid-template-columns: 420px 1fr;
    gap: 8rem;
    align-items: flex-start;
}
.greeting-img-box {
    position: relative;
}
.greeting-img-box img {
    width: 100%;
    border-radius: 1.6rem;
    display: block;
    object-fit: cover;
    aspect-ratio: 3/4;
}
.greeting-img-box::after {
    content: '';
    position: absolute;
    bottom: -2.4rem;
    right: -2.4rem;
    width: 100%;
    height: 100%;
    border-radius: 1.6rem;
    background: var(--color-light-ash);
    z-index: -1;
}
.greeting-txt { padding-top: 0.8rem; }
.greeting-quote {
    font-size: 2.4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.45;
    margin-bottom: 4rem;
    padding-bottom: 3rem;
    border-bottom: 1px solid var(--color-cloud-gray);
}
.greeting-quote em {
    color: var(--main-color);
    font-style: normal;
}
.greeting-body {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}
.greeting-body p {
    font-size: 1.6rem;
    color: var(--color-pewter);
    line-height: 1.9;
    letter-spacing: -0.03em;
}
.greeting-sign {
    width: 100%;
    margin-top: 4rem;
    padding-top: 3rem;
    border-top: 1px solid var(--color-cloud-gray);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 1.5rem; 
}
.greeting-sign-text {
    display: flex;
    align-items: baseline;
    justify-content: flex-end;
    gap: 1rem;
    width: 100%;
}
.greeting-sign-img {
    height: 6rem;
    width: auto;
    object-fit: contain;
}
.greeting-sign-label {
    font-size: 1.5rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
}
.greeting-sign-name {
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
}
.greeting-sign-badge {
    display: inline-flex;
    align-items: center;
    height: 2.8rem;
    padding: 0 1.2rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.2rem;
    font-weight: 600;
    border-radius: 0.6rem;
    letter-spacing: -0.01em;
    margin-left: 0.4rem;
}

/* ── SECTION 2: 경영이념 ── */
.value-wrap { background: #f8fafc; }

/* 핀텔 타이틀 박스 */
.title-box {
    text-align: center;
    margin-bottom: 80px;
}
.title-box .ceo-label {
    display: block;
    font-size: 46px;
    font-weight: 700;
    color: #155eef;
    letter-spacing: -0.5px;
    margin-bottom: 10px;
    text-transform: none;
    font-family: 'Pretendard', sans-serif;
}
.title-box .ceo-section-tit {
    font-size: 24px;
    font-weight: 600;
    color: #0f172a;
    letter-spacing: -0.5px;
    margin-bottom: 0;
}

/* 수평 타임라인 선 */
.timeline-line {
    position: absolute;
    top: 240px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #155eef;
    z-index: 1;
}

/* 핀텔 리스트 레이아웃 */
.pintel-value-list {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    list-style: none;
    padding: 0;
    margin: 0 auto 60px auto;
    position: relative;
    z-index: 2;
    max-width: 1100px;
}
.pintel-value-list li {
    position: relative;
    text-align: center;
    padding: 0 15px;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.25, 1, 0.5, 1);
}
.pintel-value-list li.on {
    opacity: 1;
    transform: translateY(0);
}
.value-wrap .pintel-value-list li { width: 25%; }
.strategy-wrap .pintel-value-list li { width: 33.333%; }

/* 타임라인 연결 점 */
.pintel-value-list li::after {
    content: '';
    position: absolute;
    top: 115px;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    background-color: #155eef;
    border-radius: 50%;
    z-index: 3;
}

/* 아이콘 원형 박스 */
.icon-box {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 75px;
    height: 75px;
    margin-bottom: 55px;
    background-color: #ffffff;
    border-radius: 50%;
    position: relative;
    z-index: 4;
}
.icon-box svg {
    width: 42px;
    height: 42px;
    stroke: #0f172a;
    stroke-width: 1.2;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: transform 0.4s ease;
}
.pintel-value-list li:hover .icon-box svg {
    transform: scale(1.1) rotate(5deg);
}

/* 텍스트 */
.value-card-en {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 4px;
}
.value-tit {
    font-size: 18px;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 12px;
    letter-spacing: -0.5px;
}
.value-card-txt {
    font-size: 14px;
    color: #475569;
    line-height: 1.6;
    word-break: keep-all;
    padding: 0 10px;
    letter-spacing: 0;
}

/* 하단 배너 */
.value-ps {
    max-width: 700px;
    margin: 40px auto 0 auto;
    background-color: #155eef;
    color: #ffffff;
    font-size: 16px;
    font-weight: 400;
    height: auto;
    padding: 18px 30px;
    border-radius: 50px;
    box-shadow: 0 10px 25px -5px rgba(21, 94, 239, 0.2);
    word-break: keep-all;
    text-align: center;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.3s;
}
.value-ps.on {
    opacity: 1;
    transform: translateY(0);
}

/* ── SECTION 3: 경영전략 ── */
.strategy-wrap { background: #fff; }

/* ── SECTION 4: CTA ── */
.cta-wrap {
    background: #f8fafc;
    padding: 10rem 3rem;
    box-sizing: border-box;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(62,106,225,0.08) 0%, transparent 70%);
}
.cta-inner {
    position: relative;
    z-index: 1;
    max-width: 72rem;
    margin: 0 auto;
}
.cta-label {
    /* 공통 라벨 스타일은 상단에 통합 정의 */
    margin-bottom: 2rem;
}
.cta-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 2rem;
}
.cta-txt {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
    margin-bottom: 4.5rem;
}
.cta-btn-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    flex-wrap: wrap;
}
.cta-btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 5.6rem;
    width: 21.6rem;
    box-sizing: border-box;
    background: var(--main-color);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    border-radius: 9rem;
    text-decoration: none;
    letter-spacing: -0.02em;
    border: 1.5px solid transparent;
    transition: background var(--transition-standard), transform 0.2s;
}
.cta-btn-primary:hover {
    background: var(--main-color2);
    transform: translateY(-2px);
}
.cta-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 5.6rem;
    width: 21.6rem;
    box-sizing: border-box;
    background: #fff;
    color: var(--color-graphite);
    font-size: 1.6rem;
    font-weight: 700;
    border-radius: 9rem;
    text-decoration: none;
    letter-spacing: -0.02em;
    border: 1.5px solid rgba(23, 26, 32, 0.15);
    transition: border-color 0.2s, color 0.2s, background-color 0.2s, transform 0.2s;
}
.cta-btn-outline:hover {
    border-color: var(--main-color);
    color: var(--main-color);
    background: rgba(62, 106, 225, 0.04);
    transform: translateY(-2px);
}

/* ── 반응형 ── */
@media all and (min-width: 1281px) {
    .greeting-grid {
        align-items: stretch;
    }
    .greeting-txt {
        padding-top: 0;
        display: flex;
        flex-direction: column;
    }
    .greeting-quote {
        margin-bottom: 2.8rem;
        padding-bottom: 2.2rem;
    }
    .greeting-body {
        gap: 1.6rem;
    }
    .greeting-sign {
        margin-top: auto;
        padding-top: 2.2rem;
    }
}

@media all and (max-width: 1280px) {
    .greeting-grid { grid-template-columns: 360px 1fr; gap: 6rem; }
}
@media all and (max-width: 1024px) {
    .ceo-section { padding: 7rem 2.4rem; }
    .greeting-grid { grid-template-columns: 1fr; gap: 5rem; }
    .greeting-img-box { max-width: 42rem; margin: 0 auto; }
    .greeting-img-box::after { display: none; }
    .cta-tit { font-size: 3rem; }
}
@media all and (max-width: 768px) {
    .ceo-section-tit { font-size: 3rem; }
    .cta-tit { font-size: 3rem; }
    .cta-btn-group { flex-direction: column; }
}

/* ── 핀텔 반응형 ── */
@media (max-width: 768px) {
    .timeline-line { display: none; }
    .pintel-value-list { flex-direction: column; align-items: center; gap: 50px; }
    .value-wrap .pintel-value-list li,
    .strategy-wrap .pintel-value-list li { width: 100%; max-width: 340px; }
    .pintel-value-list li::after { display: none; }
    .icon-box { margin-bottom: 15px; }
    .title-box .ceo-label { font-size: 36px; }
    .value-ps { font-size: 14px; padding: 15px 25px; border-radius: 24px; }
}

/* ════════════════════════════════════
   about_performance
   ════════════════════════════════════ */
/* ── 업무실적 페이지 전용 CSS ── */

/* 연혁 상단 */
.history-top-con {
    position: relative;
    background: #fff;
    padding: 8rem 3rem;
    box-sizing: border-box;
    overflow: hidden;
    text-align: center;
}
.history-top-con .share-buttons {
    position: absolute;
    top: 3rem;
    right: 3rem;
    display: flex;
    gap: 0.6rem;
    z-index: 1;
}
.history-top-con .share-buttons button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 0.8rem;
    background: #fff;
    color: var(--color-pewter);
    cursor: pointer;
    transition: border-color 0.2s, color 0.2s, transform 0.15s;
}
.history-top-con .share-buttons button:hover {
    border-color: var(--main-color);
    color: var(--main-color);
    transform: translateY(-2px);
}
.history-top-con .share-buttons svg { width: 1.5rem; height: 1.5rem; fill: currentColor; }
.history-top-con .share-buttons .link-copy svg { fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; }
.history-top-con-inner { position: relative; z-index: 1; max-width: 92rem; margin: 0 auto; }
.history-top-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    font-family: "Jost", sans-serif;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    color: var(--main-color);
    text-transform: uppercase;
    margin-bottom: 1.8rem;
}
/* .history-top-eyebrow::before,
.history-top-eyebrow::after {
    content: '';
    width: 2.8rem;
    height: 1px;
    background: rgba(62,106,225,0.45);
} */
.history-top-tit {
    font-size: clamp(3rem, 4vw, 4rem);
    font-weight: 800;
    color: var(--color-carbon-dark);
    letter-spacing: -0.05em;
    line-height: 1.25;
}

/* ── 연혁 탭 ── */
/* aside 래퍼 자체는 드롭다운과 탭 바를 모두 포함하므로, 둥근 회색 배경을 실제 탭 바인 .history-tab-inner로 이식하고 aside는 투명하게 유지합니다. */
aside.history-tab-wrapper-style { 
    background: transparent !important; 
    height: auto !important; 
    border-radius: 0 !important;
    position: sticky; 
    top: 5.6rem; 
    z-index: 50; 
}

/* 실제 탭 바가 표시되는 영역에 content.css의 둥근 회색 바 스타일을 적용 */
aside.history-tab-wrapper-style .history-tab-inner {
    background: #e8e8e8; 
    border-radius: 60px; 
    height: 7.4rem;
    padding: 1.1rem 1.4rem; 
    box-sizing: border-box;
}

.history-tab-filter-row { max-width: 1380px; margin: 0 auto; padding: 1rem 3rem; border-bottom: 1px solid #f0f0f0; }
.history-tab-row { max-width: 1380px; margin: 0 auto; padding: 0 3rem; }

/* 이동하는 밑줄 인디케이터 (3px 밑줄 제거 및 캡슐 배경 강제 적용) */
.move-line {
    height: 5.2rem !important;
    width: 100% !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    z-index: 1 !important;
}
.move-line span {
    height: 100% !important;
    background-color: var(--main-color2) !important;
    border-radius: 3rem !important;
    bottom: 0 !important;
    top: 0 !important;
    position: absolute !important;
}

/* ── 토스 스타일 연도 드롭다운 ── */
.toss-dropdown-container { position: relative; width: 140px; flex-shrink: 0; font-family: 'Pretendard', sans-serif; user-select: none; }
.toss-dropdown-trigger { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 9px 14px; background-color: transparent; border: none; border-radius: 0; outline: none; color: #333d4b; font-size: 14px; font-weight: 600; cursor: pointer; transition: color 0.15s ease; }
.toss-dropdown-trigger:active { transform: scale(0.97); }
.toss-arrow-svg { width: 15px; height: 15px; fill: none; stroke: #8b95a1; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1); flex-shrink: 0; }
.toss-dropdown-container.is-active .toss-arrow-svg { transform: rotate(180deg); stroke: #4e5968; }
.toss-dropdown-menu {
    display: block !important;
    position: absolute !important;
    top: calc(100% + 6px) !important;
    left: 0 !important;
    min-width: 100% !important;
    background-color: #ffffff !important;
    border-radius: 14px !important;
    padding: 6px !important;
    margin: 0 !important;
    list-style: none !important;
    box-shadow: 0 12px 40px rgba(0,0,0,0.1) !important;
    z-index: 9999 !important;
    opacity: 0;
    transform: translateY(-8px) scale(0.96);
    pointer-events: none;
    transition: opacity 0.18s cubic-bezier(0.4,0,0.2,1), transform 0.18s cubic-bezier(0.4,0,0.2,1);
    
    /* 세로 스크롤 상자 설정 */
    max-height: 250px !important;
    overflow-y: auto !important;
    flex-direction: column !important;
}
.toss-dropdown-container.is-active .toss-dropdown-menu { opacity: 1 !important; transform: translateY(0) scale(1) !important; pointer-events: auto !important; }
.toss-dropdown-item {
    display: block !important;
    width: 100% !important;
    padding: 9px 12px !important;
    color: #4e5968 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: background-color 0.1s ease, color 0.1s ease !important;
    
    /* leaked flex/margin styles override */
    margin: 0 !important;
    text-align: left !important;
    box-sizing: border-box !important;
    height: auto !important;
    line-height: normal !important;
}
.toss-dropdown-item:hover { background-color: #f2f4f6 !important; color: #191f28 !important; }
.toss-dropdown-item.selected { color: #3182f6 !important; font-weight: 700 !important; background-color: #e8f3ff !important; }

/* 토스 스타일 드롭다운 스크롤바 디자인 */
.toss-dropdown-menu::-webkit-scrollbar {
    width: 6px !important;
}
.toss-dropdown-menu::-webkit-scrollbar-track {
    background: transparent !important;
}
.toss-dropdown-menu::-webkit-scrollbar-thumb {
    background: #e2e8f0 !important;
    border-radius: 3px !important;
}
.toss-dropdown-menu::-webkit-scrollbar-thumb:hover {
    background: #cbd5e1 !important;
}

@media all and (min-width: 769px) {
    /* ── 데스크탑 탭 호버 글자 색상 수정 ── */
    /* 1. 마우스 호버가 없는 평상시 상태 */
    #historyTabs:not(.has-hover) li.selected a em {
        color: #fff !important;
    }
    #historyTabs:not(.has-hover) li:not(.selected) a em {
        color: #626262 !important;
    }

    /* 2. 마우스가 탭 영역 내에 호버되어 있을 때 기본적으로 모든 글자색을 어둡게 처리 (배경이 없는 탭용) */
    #historyTabs.has-hover li a em {
        color: #626262 !important;
        transition: color 0.2s;
    }

    /* 3. 호버된 탭(캡슐 배경이 올라간 탭)만 글자색을 흰색으로 변경 */
    #historyTabs.has-hover li a.tab-hover em {
        color: #fff !important;
    }
}

@media all and (max-width: 800px) {
    /* 모바일 환경에서는 둥근 회색 탭 바 디자인을 해제하여 기본 모바일 드롭다운 메뉴 스타일이 잘 보이도록 합니다. */
    aside.history-tab-wrapper-style .history-tab-inner {
        background: transparent !important;
        height: auto !important;
        padding: 0 !important;
        border-radius: 0 !important;
    }
}

/* ── 탭 콘텐츠 ── */
.sub-tab-con { max-width: 1380px; margin: 0 auto; padding: 6rem 3rem 10rem; box-sizing: border-box; gap: 8rem; opacity: 0; transform: translateY(10px); transition: opacity 0.35s ease, transform 0.35s ease; flex-direction: row; }
.sub-tab-con.active-tab { opacity: 1; transform: translateY(0); }

/* ── 스티키 연도 타이틀 ── */
.history-year-tit-box { position: sticky; top: calc(5.6rem + 5.6rem + 3rem); align-self: flex-start; flex-shrink: 0; width: 16rem; }
.history-year-tit-box .decade-label { font-family: "Jost", sans-serif; font-size: 3.2rem; font-weight: 800; color: var(--color-carbon-dark); letter-spacing: -0.04em; line-height: 1; }
.history-year-tit-box .decade-sub { display: block; margin-top: 0.8rem; font-size: 1.3rem; color: var(--color-silver-fog); letter-spacing: -0.01em; }

/* ── 스크롤 진행 바 ── */
.history-year-list-con { flex: 1; position: relative; padding-left: 3.2rem; }
.percent-bar-wrap { position: absolute; left: 0; top: 0.8rem; bottom: 1.2rem; width: 3px; background: var(--color-cloud-gray); border-radius: 3px; }
.percent-bar-fill { position: absolute; top: 0; left: 0; width: 100%; height: 0%; background: linear-gradient(to bottom, #6b94f0, var(--main-color)); border-radius: 3px; will-change: height; transition: height 0.2s ease; }

/* ── 연도 항목 ── */
.history-year-item { margin-bottom: 5.6rem; opacity: 0; transform: translateY(2.4rem); transition: opacity 0.55s ease, transform 0.55s cubic-bezier(0.16,1,0.3,1); }
.history-year-item:last-child { margin-bottom: 0; }
.history-year-item.in-view { opacity: 1; transform: translateY(0); }
.history-year-item dt.history-year { display: block; font-family: "Jost", sans-serif; font-size: 2.8rem; font-weight: 800; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.6rem; padding-bottom: 1.4rem; transition: color 0.3s; }
.history-year-item.in-view dt.history-year { color: var(--main-color); }
.history-info-con { display: flex; flex-direction: column; margin: 0; }
.history-info-con p { display: flex; align-items: center; gap: 0.8rem; padding: 1.2rem 0; padding-left: 0; border-bottom: 1px solid #f4f4f4; font-size: 1.45rem; color: var(--color-carbon-dark); line-height: 1.7; letter-spacing: -0.03em; transition: color 0.2s; margin: 0; }
.history-info-con p::before { content: ""; position: static; display: inline-block; width: 4px; height: 4px; background-color: var(--color-silver-fog); border-radius: 50%; flex-shrink: 0; transform: none; }
.history-info-con p:last-child { border-bottom: 0; }
.history-info-con p:hover { color: var(--main-color); }
.history-info-con p span { flex-shrink: 0; font-family: "Jost", sans-serif; font-size: 1.15rem; font-weight: 600; color: var(--main-color); min-width: 3.2rem; letter-spacing: 0; }
.history-info-con p em { font-style: normal; font-size: 1.2rem; color: var(--color-silver-fog); margin-left: 0.2rem; }
.history-info-con p { cursor: pointer; user-select: none; }
.history-info-con p[data-href] { cursor: pointer; }
.history-info-con p::after { content: "›"; flex-shrink: 0; margin-left: auto; padding-left: 0.8rem; opacity: 0; transform: translateX(-5px); transition: opacity 0.18s ease, transform 0.18s ease; color: var(--main-color); font-size: 1.4rem; align-self: center; line-height: 1; }
.history-info-con p:hover::after { opacity: 1; transform: translateX(0); }
.history-info-con p.history-item-hidden { display: none !important; }
.history-more-btn { display: inline-flex; align-items: center; gap: 0.6rem; margin-top: 1.4rem; padding: 0 2.4rem; height: 4.8rem; background: var(--main-color); border: 1.5px solid transparent; border-radius: 9rem; font-size: 1.4rem; font-weight: 700; color: #fff; cursor: pointer; letter-spacing: -0.02em; transition: background var(--transition-standard), transform 0.2s; }
.history-more-btn:hover { background: var(--main-color2); transform: translateY(-2px); }
.history-more-btn svg { width: 1.4rem; height: 1.4rem; stroke: currentColor; fill: none; stroke-width: 2.5; transition: transform 0.2s; }

/* ── 반응형 ── */
@media all and (max-width: 1024px) {
    .sub-tab-con { flex-direction: column !important; gap: 4rem; }
    .history-year-tit-box { display: none; }
    .history-year-list-con { padding-left: 2.8rem; }
}
@media all and (max-width: 768px) {
    .history-top-con { padding: 4rem 2.2rem 2.5rem; }
    .history-top-con-inner { padding-top: 3rem; }
    .history-top-tit { font-size: 3rem; }
    .history-top-con .share-buttons { top: 1.2rem; right: 1.2rem; }
    .sub-tab-con { padding: 4rem 2.2rem 8rem; }
    .history-year-item dt.history-year { font-size: 2.2rem; }
    .history-year-list-con { padding-left: 2.4rem; }
    .history-tab-filter-row { padding: 0.8rem 2.2rem; }
    .history-tab-row { padding: 0 2.2rem; }
    .toss-dropdown-container { width: 130px; }
}

/* ════════════════════════════════════
   about_strengths
   ════════════════════════════════════ */
/* ── about_strengths.css ── */

/* ── 글로빛 강점 ── */
.strengths-page {
    background: #fff;
}
.strengths-top {
    padding: 9rem 3rem 7rem;
    background:
        linear-gradient(180deg, #fff 0%, #f6f8ff 100%);
}
.strengths-inner {
    max-width: 1380px;
    margin: 0 auto;
}
.strengths-title-box {
    text-align: center;
    max-width: 92rem;
    margin: 0 auto;
}
.strengths-kicker {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    font-family: "Jost", sans-serif;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    color: var(--main-color);
    text-transform: uppercase;
    margin-bottom: 1.8rem;
}
/* .strengths-kicker::before,
.strengths-kicker::after {
    content: '';
    width: 2.8rem;
    height: 1px;
    background: rgba(62,106,225,0.45);
} */
.strengths-title {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    line-height: 1.25;
    letter-spacing: -0.05em;
    margin-bottom: 2rem;
}
.strengths-title em {
    color: var(--main-color);
    font-style: normal;
}
.strengths-lead {
    font-size: 1.8rem;
    color: var(--color-pewter);
    line-height: 1.85;
    letter-spacing: -0.03em;
    word-break: keep-all;
}
.strengths-proof-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.8rem;
    margin-top: 5rem;
}
.strengths-proof-card {
    padding: 3.2rem 2.8rem;
    background: #fff;
    border: 1px solid rgba(62,106,225,0.14);
    border-radius: 1.6rem;
    box-shadow: 0 1.8rem 4rem rgba(20,30,55,0.06);
}
.proof-num {
    display: block;
    font-family: "Jost", sans-serif;
    font-size: 3.6rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    line-height: 1;
    letter-spacing: -0.03em;
    margin-bottom: 1.4rem;
}
.proof-num small {
    font-size: 1.5rem;
    color: var(--main-color);
    margin-left: 0.2rem;
}
.proof-label {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-graphite);
    letter-spacing: -0.03em;
    margin-bottom: 0.8rem;
}
.proof-desc {
    font-size: 1.35rem;
    color: var(--color-silver-fog);
    line-height: 1.7;
    letter-spacing: -0.02em;
}
.strengths-list {
    padding: 2rem 3rem 10rem;
}
.strength-item {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 8rem;
    align-items: center;
    padding: 8rem 0;
    border-top: 1px solid var(--color-cloud-gray);
}
.strength-item.reverse {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}
.strength-item.reverse .strength-visual {
    order: 2;
}
.strength-item.reverse .strength-copy {
    order: 1;
}
.strength-visual {
    min-height: 34rem;
    border-radius: 2rem;
    overflow: hidden;
    position: relative;
    background: #f4f6fb;
}
.strength-visual.photo {
    background-size: cover;
    background-position: center;
}
.strength-visual.photo::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(15,20,35,0.18), rgba(62,106,225,0.2));
}
.strength-visual.photo.brand-logo {
    background-size: contain !important;
    background-color: #ffffff !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}
.strength-visual.photo.brand-logo::before {
    display: none !important;
}
.strength-visual.network-slide {
    background: #f4f6fb;
    border-radius: 2.4rem;
}
.network-slideshow {
    position: absolute;
    inset: 0;
}
.network-slide-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity 1s ease-in-out;
}
.network-slide-img.active {
    opacity: 1;
}
.strength-visual.network-slide::before {
    background: linear-gradient(135deg, rgba(15,20,35,0.10), rgba(62,106,225,0.12));
    z-index: 1;
}
.strength-visual.system {
    display: grid;
    place-items: center;
    padding: 4rem;
    position: relative;
    overflow: hidden;
    border-radius: 2.4rem;
}
.strength-visual.system.expert-network::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url('/images2/sub/Expert_bg2.jpg') center/cover no-repeat;
    opacity: 0.20;
    z-index: 0;
}
.strength-visual.system.expert-network::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, rgba(62,106,225,0.06) 0%, transparent 70%);
    z-index: 0;
}
.system-ring {
    width: min(34rem, 78vw);
    aspect-ratio: 1;
    border-radius: 50%;
    border: 1px solid rgba(62,106,225,0.22);
    display: grid;
    place-items: center;
    position: relative;
    z-index: 1;
}
.system-ring::before,
.system-ring::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    border: 1px solid rgba(62,106,225,0.14);
}
.system-ring::before { inset: 4.5rem; }
.system-ring::after { inset: 9rem; }
.system-core {
    width: 12rem;
    height: 12rem;
    border-radius: 50%;
    background: var(--main-color);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1.45;
    letter-spacing: -0.03em;
    position: relative;
    z-index: 2;
}
.ip-card-wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.6rem;
    width: 100%;
}
.ip-proof-card {
    border-radius: 1.2rem;
    background: #fff;
    border: 1px solid rgba(62,106,225,0.10);
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.ip-proof-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.partner-logos-mini {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
    width: 100%;
}
.partner-logos-mini span {
    min-height: 7.2rem;
    border-radius: 1.2rem;
    background: #fff;
    border: 1px solid rgba(20,30,55,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.2rem;
}
.partner-logos-mini img {
    max-height: 15rem;
    object-fit: contain;
    filter: grayscale(1);
    opacity: 0.72;
}
.strength-label { margin-bottom: 1.6rem; }
.strength-heading {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    line-height: 1.28;
    letter-spacing: -0.05em;
    margin-bottom: 2.4rem;
    word-break: keep-all;
}
.strength-text {
    font-size: 1.65rem;
    color: var(--color-pewter);
    line-height: 1.9;
    letter-spacing: -0.03em;
    word-break: keep-all;
}
.strength-points {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 3rem;
    list-style: none;
}
.strength-points li {
    display: flex;
    align-items: center;
    min-height: 4.6rem;
    padding: 0 1.6rem;
    background: var(--color-light-ash);
    border-radius: 0.8rem;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--color-graphite);
    letter-spacing: -0.03em;
}
.strength-points li::before {
    content: '';
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    background: var(--main-color);
    margin-right: 1rem;
    flex-shrink: 0;
}
[data-strength-reveal] {
    opacity: 0;
    transform: translateY(3.2rem);
    transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1);
}
[data-strength-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ── CTA ── */
.cta-wrap {
    background: #f8fafc;
    padding: 10rem 3rem;
    box-sizing: border-box;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(62,106,225,0.08) 0%, transparent 70%);
}
.cta-inner {
    position: relative;
    z-index: 1;
    max-width: 72rem;
    margin: 0 auto;
}
.cta-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 2rem;
}
.cta-txt {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
    margin-bottom: 4.5rem;
}
.cta-btn-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    flex-wrap: wrap;
}
.cta-btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 5.6rem;
    width: 21.6rem;
    box-sizing: border-box;
    background: var(--main-color);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    border-radius: 9rem;
    text-decoration: none;
    letter-spacing: -0.02em;
    border: 1.5px solid transparent;
    transition: background var(--transition-standard), transform 0.2s;
}
.cta-btn-primary:hover {
    background: var(--main-color2);
    transform: translateY(-2px);
}
.cta-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 5.6rem;
    width: 21.6rem;
    box-sizing: border-box;
    background: #fff;
    color: var(--color-graphite);
    font-size: 1.6rem;
    font-weight: 700;
    border-radius: 9rem;
    text-decoration: none;
    letter-spacing: -0.02em;
    border: 1.5px solid rgba(23, 26, 32, 0.15);
    transition: border-color 0.2s, color 0.2s, background-color 0.2s, transform 0.2s;
}
.cta-btn-outline:hover {
    border-color: var(--main-color);
    color: var(--main-color);
    background: rgba(62, 106, 225, 0.04);
    transform: translateY(-2px);
}

/* ── 반응형 ── */
@media all and (max-width: 1280px) {
    .strengths-proof-grid { grid-template-columns: repeat(2, 1fr); }
    .strength-item,
    .strength-item.reverse {
        grid-template-columns: 1fr;
        gap: 4rem;
    }
    .strength-item.reverse .strength-visual,
    .strength-item.reverse .strength-copy {
        order: initial;
    }
    .strength-item.visual-bottom .strength-copy { order: 1; }
    .strength-item.visual-bottom .strength-visual { order: 2; }
}
@media all and (max-width: 1024px) {
    .strengths-top { padding: 7rem 2.4rem 5rem; }
    .strengths-list { padding: 0 2.4rem 8rem; }
    .strength-item { padding: 6rem 0; }
    .strength-visual { min-height: 28rem; }
    .cta-tit { font-size: 3rem; }
}
@media all and (max-width: 768px) {
    .strengths-title-box { text-align: center; }
    .strengths-kicker::before,
    .strengths-kicker::after { display: none; }
    .strengths-lead { font-size: 1.6rem; }
    .strengths-proof-grid { grid-template-columns: 1fr; gap: 1.2rem; }
    .strengths-proof-card { padding: 2.4rem; }
    .proof-num { font-size: 3rem; }
    .strength-item { padding: 5rem 0; }
    .strength-visual { min-height: 24rem; border-radius: 1.4rem; }
    .strength-visual.system { padding: 2.2rem 1.6rem; min-height: auto; }
    .strengths-title { font-size: 3rem; }
    .strength-heading { font-size: 3rem; margin-bottom: 3rem; }
    .strength-heading-row .mv-more-link { margin-bottom: 1.8rem; }
    .strength-heading-row { align-items: flex-end; }
    .strength-text { font-size: 1.6rem; }
    .strength-points { grid-template-columns: 1fr; }
    .ip-card-wrap { grid-template-columns: repeat(2, 1fr); }
    .partner-logos-mini { grid-template-columns: repeat(3, 1fr); gap: 0.8rem; }
    .partner-logos-mini span { min-height: 5.6rem; padding: 0.8rem; border-radius: 0.8rem; }
    .partner-logos-mini img { max-width: 100%; max-height: 100%; }
    .ip-proof-card { min-height: 20rem; }
    .system-core { width: 10rem; height: 10rem; font-size: 1.35rem; }
    .cta-tit { font-size: 3rem; }
    .cta-btn-group { flex-direction: column; }
}

/* ════════════════════════════════════
   about_contact
   ════════════════════════════════════ */
/* ── about_contact.css ── */

/* ── 오시는길 ── */
.contact-page {
    background: #fff;
    padding: 9rem 3rem 11rem;
}
.contact-inner {
    max-width: 1380px;
    margin: 0 auto;
}
.contact-heading {
    display: flex;
    justify-content: center;
    text-align: center;
    /* align-items: flex-end; */
    gap: 4rem;
    margin-bottom: 5rem;
}
.contact-label { margin-bottom: 1.4rem; }
.contact-title {
    font-size: clamp(3rem, 4vw, 4rem);
    font-weight: 800;
    color: var(--color-carbon-dark);
    line-height: 1.25;
    letter-spacing: -0.05em;
}
.contact-desc {
    max-width: 46rem;
    font-size: 1.55rem;
    color: var(--color-pewter);
    line-height: 1.8;
    letter-spacing: -0.03em;
    word-break: keep-all;
}
.contact-tabs {
    display: flex;
    border-bottom: 1px solid var(--color-cloud-gray);
    margin-bottom: 0;
    overflow-x: auto;
}
.contact-tab-btn {
    height: 5.8rem;
    padding: 0 3rem;
    border: 0;
    border-bottom: 3px solid transparent;
    background: transparent;
    color: var(--color-silver-fog);
    font-family: inherit;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    cursor: pointer;
    white-space: nowrap;
    transition: color 0.2s, border-color 0.2s;
}
.contact-tab-btn:hover,
.contact-tab-btn.active {
    color: var(--color-carbon-dark);
}
.contact-tab-btn.active {
    border-bottom-color: var(--main-color);
}
.contact-panel {
    display: none;
}
.contact-panel.active {
    display: block;
    animation: contactPanelFade 0.45s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
@keyframes contactPanelFade {
    from {
        opacity: 0;
        transform: translateY(1.2rem);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.contact-map-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 39rem;
    min-height: 52rem;
    background: #fff;
    border: 1px solid rgba(20,30,55,0.1);
    border-radius: 2.4rem;
    overflow: hidden;
    box-shadow: 0 2.4rem 5.5rem rgba(20,30,55,0.1);
}
.contact-map-area {
    position: relative;
    min-height: 52rem;
    background: #eef1f6;
    overflow: hidden;
}
.contact-map-frame {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}
.contact-info {
    padding: 4.4rem 4rem;
    border-left: 1px solid var(--color-cloud-gray);
    color: var(--color-carbon-dark);
    display: flex;
    flex-direction: column;
    background: #f8fafc;
}
.office-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    width: fit-content;
    padding: 0.6rem 1rem;
    border: 1px solid rgba(62,106,225,0.35);
    background: rgba(62,106,225,0.12);
    color: var(--main-color);
    font-family: "Jost", sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.office-badge::before {
    content: '';
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    background: currentColor;
}
.office-name {
    margin-top: 2.2rem;
    font-size: 2.6rem;
    font-weight: 800;
    line-height: 1.3;
    letter-spacing: -0.05em;
}
.office-sub {
    margin-top: 0.6rem;
    font-family: "Jost", sans-serif;
    font-size: 1.25rem;
    color: var(--color-silver-fog);
    letter-spacing: 0.06em;
}
.office-info-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
    margin-top: 3.6rem;
    padding-top: 3rem;
    border-top: 1px solid var(--color-cloud-gray);
}
.office-info-list li {
    display: flex;
    align-items: flex-start;
    gap: 1.4rem;
    font-size: 1.45rem;
    color: var(--color-graphite);
    line-height: 1.7;
    letter-spacing: -0.03em;
}
.office-info-list i {
    width: 1.8rem;
    color: #475569;
    font-size: 1.6rem;
    margin-top: 0.3rem;
    flex-shrink: 0;
    text-align: center;
}
.office-info-list a {
    color: inherit;
    text-decoration: none;
}
.contact-btn-group {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: auto;
    padding-top: 3.6rem;
}
.contact-map-link,
.contact-map-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
    min-height: 5rem;
    padding: 0 1.8rem;
    border: 1px solid var(--color-cloud-gray);
    background: #fff;
    color: var(--color-graphite);
    font-size: 1.3rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.contact-map-toggle {
    width: 100%;
    font-family: inherit;
}
.contact-map-link,
.contact-map-toggle.is-google {
    background: rgba(66,133,244,0.08);
    border-color: rgba(66,133,244,0.28);
    color: #4285F4;
}
.contact-map-link:hover,
.contact-map-toggle.is-google:hover {
    background: #4285F4;
    border-color: #4285F4;
    color: #fff;
}
.contact-map-toggle.is-naver {
    background: rgba(3,199,90,0.09);
    border-color: rgba(3,199,90,0.3);
    color: #03C75A;
}
.contact-map-toggle.is-naver:hover {
    background: #03C75A;
    border-color: #03C75A;
    color: #fff;
}
.contact-map-icon {
    width: 2rem;
    height: 2rem;
    object-fit: contain;
    flex-shrink: 0;
}
.contact-guide {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.6rem;
    margin-top: 3rem;
}
.contact-guide-card {
    padding: 2.4rem;
    background: var(--color-light-ash);
    border: 1px solid transparent;
}
.contact-guide-card strong {
    display: block;
    font-size: 1.55rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 0.8rem;
}
.contact-guide-card p {
    font-size: 1.35rem;
    color: var(--color-pewter);
    line-height: 1.7;
    letter-spacing: -0.03em;
}
[data-contact-reveal] {
    opacity: 0;
    transform: translateY(3rem);
    transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1);
}
[data-contact-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ── 핀텔형 오시는길 지점 세그먼트 탭 선택기 ── */
.office-tab-selector {
    display: flex;
    background: #ffffff;
    border-radius: 100px;
    padding: 0.6rem;
    margin-bottom: 2.8rem;
    width: 100%;
    box-sizing: border-box;
    border: 1px solid #e2e8f0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.02);
}
.office-tab-item {
    flex: 1;
    text-align: center;
    border: none;
    background: none;
    padding: 1.2rem 0.5rem;
    font-size: 1.4rem;
    font-weight: 700;
    color: #475569;
    border-radius: 100px;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    white-space: nowrap;
    outline: none;
}
.office-tab-item:hover {
    color: var(--main-color);
    background: rgba(62, 106, 225, 0.06);
}
.office-tab-item.active {
    background: var(--main-color) !important;
    color: #fff !important;
    font-weight: 700 !important;
    box-shadow: 0 0.6rem 1.6rem rgba(62, 106, 225, 0.22);
}

/* ── 핀텔형 구글/네이버 지도 링크 & 지도 바로가기 버튼 ── */
.map-sub-links {
    display: flex;
    gap: 1rem;
    margin-top: 1.2rem;
    width: 100%;
}
.map-sub-link {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    height: 4.8rem;
    background: #ffffff;
    border: 1.5px solid #e2e8f0;
    border-radius: 100px;
    font-size: 1.35rem;
    font-weight: 700;
    color: #475569;
    text-decoration: none;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    outline: none;
    cursor: pointer;
}
.map-sub-link img {
    width: 1.8rem;
    height: 1.8rem;
    object-fit: contain;
}
/* Google Map Button Custom Colors */
.map-sub-link.google {
    border-color: #3e6ae1 !important;
    color: #3e6ae1 !important;
    background: #ffffff !important;
}
.map-sub-link.google:hover {
    background: #3e6ae1 !important;
    border-color: #3e6ae1 !important;
    color: #ffffff !important;
    box-shadow: 0 0.4rem 1.2rem rgba(62, 106, 225, 0.15) !important;
}
.map-sub-link.google.active {
    background: #3e6ae1 !important;
    border-color: #3e6ae1 !important;
    color: #ffffff !important;
    box-shadow: 0 0.4rem 1.2rem rgba(62, 106, 225, 0.22) !important;
}

/* Naver Map Button Custom Colors */
.map-sub-link.naver {
    border-color: #e2e8f0 !important;
    color: #475569 !important;
    background: #ffffff !important;
}
.map-sub-link.naver:hover {
    border-color: #03c75a !important;
    color: #03c75a !important;
    background: #ffffff !important;
    box-shadow: 0 0.4rem 1.2rem rgba(3, 199, 90, 0.08) !important;
}
.map-sub-link.naver.active {
    background: #03c75a !important;
    border-color: #03c75a !important;
    color: #ffffff !important;
    box-shadow: 0 0.4rem 1.2rem rgba(3, 199, 90, 0.22) !important;
}
.pintel-map-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 5.6rem;
    padding: 0 2.8rem;
    background: #fff;
    border: 2px solid #000;
    border-radius: 100px;
    color: #000;
    font-size: 1.5rem;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.22s ease;
    box-sizing: border-box;
    cursor: pointer;
}
.pintel-map-btn:hover {
    background: #000 !important;
    color: #fff !important;
}
.pintel-map-btn svg {
    stroke: currentColor;
    fill: none;
    transition: all 0.22s ease;
}

/* ── Naver Map Embedded Placeholder Styles ── */
.naver-map-placeholder {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
.naver-map-overlay {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.12);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 2.4rem;
    box-sizing: border-box;
}

/* ── Naver Map Marker Style ── */
.naver-map-marker {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 2.4rem;
    cursor: pointer;
}
.marker-pulse {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 5.6rem;
    height: 5.6rem;
    border-radius: 50%;
    background: rgba(3, 199, 90, 0.25);
    animation: markerPulseAnimate 2s infinite ease-out;
    z-index: 1;
}
@keyframes markerPulseAnimate {
    0% {
        transform: translate(-50%, -50%) scale(0.6);
        opacity: 1;
    }
    100% {
        transform: translate(-50%, -50%) scale(1.6);
        opacity: 0;
    }
}
.marker-icon {
    position: relative;
    width: 4rem;
    height: 4rem;
    background: #03C75A;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 2.2rem;
    box-shadow: 0 0.6rem 1.6rem rgba(3, 199, 90, 0.4);
    z-index: 2;
    transition: transform 0.25s ease;
}
.naver-map-marker:hover .marker-icon {
    transform: scale(1.12);
}
.marker-label {
    position: relative;
    margin-top: 1.2rem;
    background: #ffffff;
    padding: 0.8rem 1.4rem;
    border-radius: 0.8rem;
    font-size: 1.35rem;
    font-weight: 800;
    color: #171A20;
    box-shadow: 0 0.8rem 2.4rem rgba(15, 23, 42, 0.12);
    border: 1px solid rgba(15, 23, 42, 0.08);
    z-index: 2;
    white-space: nowrap;
}

/* ── Naver Map Button Style ── */
.naver-map-btn {
    position: absolute;
    bottom: 2.8rem;
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    height: 5.4rem;
    padding: 0 2.8rem;
    background: #ffffff;
    border: none;
    border-radius: 100px;
    box-shadow: 0 1.2rem 3.2rem rgba(15, 23, 42, 0.18);
    font-size: 1.45rem;
    font-weight: 800;
    color: #03C75A;
    text-decoration: none;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 3;
    border: 1.5px solid #03C75A;
}
.naver-map-btn img {
    width: 2.2rem;
    height: 2.2rem;
    object-fit: contain;
}
.naver-map-btn:hover {
    background: #03C75A !important;
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: 0 1.6rem 4rem rgba(3, 199, 90, 0.35);
}

/* ── CTA ── */
.cta-wrap {
    background: #f8fafc;
    padding: 10rem 3rem;
    box-sizing: border-box;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(62,106,225,0.08) 0%, transparent 70%);
}
.cta-inner {
    position: relative;
    z-index: 1;
    max-width: 72rem;
    margin: 0 auto;
}
.cta-label {
    /* 공통 라벨 스타일은 상단에 통합 정의 */
    margin-bottom: 2rem;
}
.cta-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 2rem;
}
.cta-txt {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
    margin-bottom: 4.5rem;
}
.cta-btn-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    flex-wrap: wrap;
}
.cta-btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 5.6rem;
    width: 21.6rem;
    box-sizing: border-box;
    background: var(--main-color);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    border-radius: 9rem;
    text-decoration: none;
    letter-spacing: -0.02em;
    border: 1.5px solid transparent;
    transition: background var(--transition-standard), transform 0.2s;
}
.cta-btn-primary:hover {
    background: var(--main-color2);
    transform: translateY(-2px);
}
.cta-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 5.6rem;
    width: 21.6rem;
    box-sizing: border-box;
    background: #fff;
    color: var(--color-graphite);
    font-size: 1.6rem;
    font-weight: 700;
    border-radius: 9rem;
    text-decoration: none;
    letter-spacing: -0.02em;
    border: 1.5px solid rgba(23, 26, 32, 0.15);
    transition: border-color 0.2s, color 0.2s, background-color 0.2s, transform 0.2s;
}
.cta-btn-outline:hover {
    border-color: var(--main-color);
    color: var(--main-color);
    background: rgba(62, 106, 225, 0.04);
    transform: translateY(-2px);
}

/* ── 반응형 ── */
@media all and (max-width: 1280px) {
    .contact-map-card { grid-template-columns: 1fr; }
    .contact-info {
        border-left: 0;
        border-top: 1px solid var(--color-cloud-gray);
    }
    .contact-guide { grid-template-columns: 1fr; }
}
@media all and (max-width: 1024px) {
    .contact-page { padding: 7rem 2.4rem 9rem; }
    .contact-heading {
        flex-direction: column;
        align-items: center;
        gap: 2rem;
    }
    .contact-map-area,
    .contact-map-card { min-height: 42rem; }
    .cta-tit { font-size: 3rem; }
}
@media all and (max-width: 768px) {
    .contact-page { padding: 5.5rem 2rem 8rem; }
    .contact-desc { font-size: 1.45rem; }
    .contact-tab-btn {
        height: 5.2rem;
        padding: 0 2rem;
        font-size: 1.4rem;
    }
    .contact-map-area,
    .contact-map-card { min-height: 34rem; }
    .contact-map-card { border-radius: 1.8rem; }
    .contact-info { padding: 3.2rem 2.4rem; }
    .office-name { font-size: 2.3rem; }
    .office-info-list li { font-size: 1.6rem; }
    .contact-btn-group { padding-top: 2.8rem; }
    .cta-tit { font-size: 3rem; }
    .cta-btn-group { flex-direction: column; }
}

/* ════════════════════════════════════
   about_experts
   ════════════════════════════════════ */
/* ========================================
   about_experts.css
   전문가그룹 페이지 전용 스타일
   ======================================== */

/* ── 섹션 공통 ── */
.exp-section {
    padding: 9rem 3rem;
    max-width: 1380px;
    margin: 0 auto;
    box-sizing: border-box;
}
.exp-section-full {
    padding: 9rem 0;
}
.exp-section-full .exp-section-inner {
    max-width: 1380px;
    margin: 0 auto;
    padding: 0 3rem;
    box-sizing: border-box;
}
.exp-tit-box {
    margin-bottom: 6rem;
}
.exp-en-label {
    display: block;
    font-family: "Jost", sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    color: var(--main-color);
    text-transform: uppercase;
    margin-bottom: 1.2rem;
}
.exp-main-tit {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.03em;
    line-height: 1.3;
    margin: 0 0 1.4rem;
}
.exp-main-desc {
    font-size: 1.7rem;
    color: var(--color-pewter);
    line-height: 1.75;
    max-width: 70rem;
    margin: 0;
}

/* ── 숫자 강점 바 ── */
.exp-stats-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    background: var(--color-carbon-dark);
    border-radius: 1.6rem;
    overflow: hidden;
    margin-bottom: 9rem;
}
.exp-stat-item {
    padding: 4rem 3rem;
    text-align: center;
    border-right: 1px solid rgba(255,255,255,0.07);
}
.exp-stat-item:last-child { border-right: none; }
.exp-stat-num {
    display: block;
    font-family: "Jost", sans-serif;
    font-size: 4.8rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.03em;
    line-height: 1;
    margin-bottom: 0.8rem;
}
.exp-stat-num em {
    font-style: normal;
    font-size: 2.4rem;
    color: var(--main-color);
}
.exp-stat-label {
    font-size: 1.4rem;
    color: rgba(255,255,255,0.5);
    letter-spacing: 0.02em;
}

/* ── 분야별 전문가 카테고리 ── */
.exp-category-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.4rem;
    margin-bottom: 8rem;
}
.exp-category-card {
    background: var(--color-light-ash);
    border-radius: 1.6rem;
    padding: 3.6rem 3.2rem;
    transition: background var(--transition-standard), box-shadow var(--transition-standard);
    cursor: default;
}
.exp-category-card:hover {
    background: #fff;
    box-shadow: 0 8px 40px rgba(62,106,225,0.10);
}
.exp-category-icon {
    width: 5.4rem;
    height: 5.4rem;
    border-radius: 1.2rem;
    background: var(--main-color);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2.4rem;
}
.exp-category-icon svg { color: #fff; }
.exp-category-name {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.02em;
    margin: 0 0 1rem;
}
.exp-category-desc {
    font-size: 1.5rem;
    color: var(--color-pewter);
    line-height: 1.7;
    margin: 0 0 2rem;
}
.exp-category-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}
.exp-category-tag {
    font-size: 1.2rem;
    font-weight: 500;
    color: var(--main-color);
    background: rgba(62,106,225,0.08);
    border-radius: 10rem;
    padding: 0.4rem 1.2rem;
    letter-spacing: -0.01em;
}

/* ── 전문가 카드 그리드 ── */
.exp-bg-ash { background: var(--color-light-ash); }
.exp-card-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2.4rem;
}
.exp-card {
    background: #fff;
    border-radius: 1.6rem;
    overflow: hidden;
    transition: box-shadow var(--transition-standard), transform var(--transition-standard);
}
.exp-card:hover {
    box-shadow: 0 12px 48px rgba(62,106,225,0.12);
    transform: translateY(-4px);
}
.exp-card-photo {
    width: 100%;
    aspect-ratio: 1 / 1;
    background: linear-gradient(135deg, #1a2744 0%, #2F55C8 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Jost", sans-serif;
    font-size: 4rem;
    font-weight: 700;
    color: rgba(255,255,255,0.35);
    letter-spacing: 0.05em;
    overflow: hidden;
}
.exp-card-photo img { width: 100%; height: 100%; object-fit: cover; }
.exp-card-body {
    padding: 2.4rem;
}
.exp-card-field {
    font-family: "Jost", sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: var(--main-color);
    text-transform: uppercase;
    margin-bottom: 0.6rem;
}
.exp-card-name {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.02em;
    margin: 0 0 0.4rem;
}
.exp-card-title {
    font-size: 1.4rem;
    color: var(--color-pewter);
    margin: 0 0 1.6rem;
}
.exp-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.exp-card-tag {
    font-size: 1.2rem;
    color: var(--color-graphite);
    background: var(--color-light-ash);
    border-radius: 10rem;
    padding: 0.3rem 1rem;
}

/* ── 매칭 프로세스 ── */
.exp-process-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    margin-top: 5rem;
}
.exp-process-item {
    text-align: center;
    padding: 3.2rem 2rem;
    background: #fff;
    border-radius: 1.6rem;
    position: relative;
}
.exp-process-item::after {
    content: '\2192';
    position: absolute;
    right: -1.2rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 2rem;
    color: var(--color-cloud-gray);
    z-index: 1;
}
.exp-process-item:last-child::after { display: none; }
.exp-process-num {
    font-family: "Jost", sans-serif;
    font-size: 3.6rem;
    font-weight: 700;
    color: var(--main-color);
    opacity: 0.18;
    line-height: 1;
    margin-bottom: 1.2rem;
}
.exp-process-name {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    margin: 0 0 0.8rem;
}
.exp-process-desc {
    font-size: 1.4rem;
    color: var(--color-pewter);
    line-height: 1.6;
    margin: 0;
}

/* ── CTA ── */
.exp-cta {
    background: linear-gradient(135deg, #0d1321 0%, #1a2744 100%);
    text-align: center;
    padding: 10rem 3rem;
}
.exp-cta-en {
    font-family: "Jost", sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    color: var(--main-color);
    text-transform: uppercase;
    display: block;
    margin-bottom: 1.6rem;
}
.exp-cta-tit {
    font-size: 4rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.03em;
    line-height: 1.3;
    margin: 0 0 1.6rem;
}
.exp-cta-desc {
    font-size: 1.7rem;
    color: rgba(255,255,255,0.55);
    margin: 0 0 4rem;
    line-height: 1.75;
}
.exp-cta-btn {
    display: inline-block;
    background: var(--main-color);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 600;
    padding: 1.6rem 4rem;
    border-radius: 10rem;
    text-decoration: none;
    transition: background var(--transition-standard);
    letter-spacing: -0.01em;
    cursor: pointer;
    border: none;
}
.exp-cta-btn:hover { background: var(--main-color2); }

/* ── Expert Group Directory ── */
[data-expert-reveal] {
    opacity: 0;
    transform: translateY(3rem);
    transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1);
}
[data-expert-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
    
}
.expert-overview {
    padding: 10rem 3rem 8rem;
    background: #fff;
}
.expert-inner {
    max-width: 1380px;
    margin: 0 auto;
}
.expert-label { margin-bottom: 2rem; }
.expert-title {
    font-size: clamp(3rem, 4vw, 4rem);
    font-weight: 700;
    color: var(--color-carbon-dark);
    line-height: 1.25;
    letter-spacing: -0.05em;
    margin-bottom: 1.8rem;
}
.expert-title em {
    /* color: var(--main-color); */
    font-weight: bold;
}
.expert-desc {
    max-width: 82rem;
    font-size: 1.6rem;
    color: var(--color-pewter);
    line-height: 1.85;
    letter-spacing: -0.03em;
    word-break: keep-all;
}
.expert-group-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.6rem;
    margin-top: 5.6rem;
}
.expert-group-card {
    min-height: 30rem;
    padding: 3.4rem 2.8rem;
    background: #fff;
    border: 1px solid rgba(20,30,55,0.1);
    border-radius: 1.8rem;
    box-shadow: 0 1.8rem 4.5rem rgba(20,30,55,0.06);
    transition: transform var(--transition-standard), box-shadow var(--transition-standard), border-color var(--transition-standard);
}
.expert-group-card:hover {
    transform: translateY(-0.6rem);
    border-color: rgba(62,106,225,0.28);
    box-shadow: 0 2.6rem 5.5rem rgba(62,106,225,0.12);
}
.expert-card-num {
    display: block;
    font-family: "Jost", sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--color-silver-fog);
    text-transform: uppercase;
    margin-bottom: 1.6rem;
}
.expert-card-icon {
    width: 5.4rem;
    height: 5.4rem;
    border-radius: 1.4rem;
    background: rgba(62,106,225,0.08);
    color: var(--main-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.6rem;
    margin-bottom: 2.4rem;
}
.expert-card-title {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 1.2rem;
}
.expert-card-desc {
    font-size: 1.45rem;
    color: var(--color-pewter);
    line-height: 1.75;
    letter-spacing: -0.03em;
    margin-bottom: 2.2rem;
}
.expert-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}
.expert-tag {
    display: inline-flex;
    align-items: center;
    min-height: 2.8rem;
    padding: 0 1.2rem;
    border-radius: 9rem;
    background: rgba(62,106,225,0.08);
    color: var(--main-color);
    border: 1px solid rgba(62,106,225,0.16);
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}
.expert-tag-label {
    width: 100%;
    font-size: 1.2rem;
    color: var(--color-silver-fog);
    margin: 0.4rem 0 0.2rem;
}
.expert-count-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    margin-top: 6rem;
    background: rgba(255,255,255,0.12);
    border-radius: 1.8rem;
    overflow: hidden;
    background-color: var(--color-carbon-dark);
}
.expert-count-item {
    padding: 3.8rem 2.4rem;
    text-align: center;
    background: rgba(255,255,255,0.02);
}
.expert-count-num {
    display: block;
    font-family: "Jost", sans-serif;
    font-size: 4.4rem;
    font-weight: 800;
    color: #fff;
    line-height: 1;
    letter-spacing: -0.03em;
    margin-bottom: 1rem;
}
.expert-count-num small {
    font-size: 1.9rem;
    color: var(--main-color);
    margin-left: 0.2rem;
}
.expert-count-label {
    font-size: 1.35rem;
    color: rgba(255,255,255,0.58);
    letter-spacing: -0.02em;
}
.expert-directory {
    padding: 9rem 3rem 10rem;
    background: var(--color-light-ash);
}
.expert-directory-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 4rem;
    margin-bottom: 4rem;
}
.expert-note {
    font-size: 1.35rem;
    color: var(--color-silver-fog);
    letter-spacing: -0.03em;
}
.expert-role-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-bottom: 2.6rem;
}
.expert-role-btn,
.expert-filter-btn {
    border: 1px solid rgba(20,30,55,0.12);
    background: #fff;
    color: var(--color-pewter);
    font-family: inherit;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.expert-role-btn {
    height: 4.8rem;
    padding: 0 2.4rem;
    border-radius: 9rem;
}
.expert-role-btn:hover,
.expert-role-btn.active,
.expert-filter-btn:hover,
.expert-filter-btn.active {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
}
.expert-subject-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    min-height: 3.8rem;
    margin-bottom: 2.4rem;
}
.expert-filter-btn {
    min-height: 3.6rem;
    padding: 0 1.5rem;
    border-radius: 9rem;
    font-size: 1.25rem;
}
.expert-table-panel {
    display: none;
}
.expert-table-panel.active {
    display: block;
}
.expert-table-wrap {
    background: #fff;
    border: 1px solid rgba(20,30,55,0.1);
    border-radius: 1.8rem;
    overflow: hidden;
    box-shadow: 0 1.8rem 4.5rem rgba(20,30,55,0.06);
}
.expert-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 1.4rem;
}
.expert-table thead tr {
    background: #f5f7ff;
}
.expert-table th,
.expert-table td {
    padding: 1.8rem 2rem;
    text-align: left;
    border-bottom: 1px solid var(--color-cloud-gray);
    vertical-align: top;
    line-height: 1.65;
}
.expert-table th {
    font-family: "Jost", sans-serif;
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--main-color);
}
.expert-table tbody tr:last-child td {
    border-bottom: 0;
}
.expert-table tbody tr:hover {
    background: rgba(62,106,225,0.035);
}
.expert-table td:first-child {
    font-weight: 800;
    color: var(--color-carbon-dark);
    white-space: nowrap;
}
.expert-table .major {
    color: var(--main-color);
    font-weight: 800;
    white-space: nowrap;
}
.expert-table .detail {
    color: var(--color-pewter);
    line-height: 1.75;
    word-break: keep-all;
}
.expert-closing {
    padding: 10rem 3rem;
    background: #f8fafc;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.expert-closing::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(62,106,225,0.08) 0%, transparent 70%);
}
.expert-closing-inner {
    position: relative;
    z-index: 1;
    max-width: 76rem;
    margin: 0 auto;
}
.expert-closing .expert-title {
    color: var(--color-carbon-dark);
}
.expert-closing .expert-desc {
    margin: 0 auto 4rem;
    color: var(--color-pewter);
}
.expert-cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1rem;
    height: auto;
    padding: 1.2rem 3.2rem;
    border: 0;
    border-radius: 9rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 800;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
}
.expert-cta-btn:hover {
    background: var(--main-color2);
    transform: translateY(-2px);
    box-shadow: 0 1.8rem 4rem rgba(62,106,225,0.28);
}
.expert-cta-sub {
    margin-top: 1.8rem;
    font-size: 1.25rem;
    color: var(--color-pewter);
}

/* ── 반응형 ── */
@media all and (max-width: 1200px) {
    .exp-card-grid { grid-template-columns: repeat(3, 1fr); }
    .expert-group-grid { grid-template-columns: repeat(2, 1fr); }
}
@media all and (max-width: 960px) {
    .exp-stats-bar { grid-template-columns: repeat(2, 1fr); }
    .exp-category-grid { grid-template-columns: repeat(2, 1fr); }
    .exp-card-grid { grid-template-columns: repeat(2, 1fr); }
    .exp-process-grid { grid-template-columns: repeat(2, 1fr); }
    .exp-process-item::after { display: none; }
    .expert-directory-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 1.6rem;
    }
    .expert-count-bar { grid-template-columns: repeat(2, 1fr); }
}
@media all and (max-width: 768px) {
    .expert-table-wrap {
        background: transparent;
        border: none;
        border-radius: 0;
        box-shadow: none;
        overflow: visible;
    }
    .expert-table { min-width: 0; }
    .expert-table tr,
    .expert-table th,
    .expert-table td { word-break: auto-phrase; }
    .expert-table thead { display: none; }
    .expert-table tbody tr {
        display: block;
        background: #fff;
        border: 1px solid rgba(20,30,55,0.08);
        border-radius: 1.2rem;
        margin-bottom: 1.2rem;
        padding: 2rem 2rem 0.8rem;
        box-shadow: 0 2px 8px rgba(20,30,55,0.04);
    }
    .expert-table tbody tr:last-child td { border-bottom: 1px solid rgba(20,30,55,0.06); }
    .expert-table tbody tr:hover { background: #fff; }
    .expert-table td {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        gap: 1.2rem;
        padding: 0.8rem 0;
        border-bottom: 1px solid rgba(20,30,55,0.06);
        text-align: right;
    }
    .expert-table td:last-child { border-bottom: none; }
    .expert-table td::before {
        content: attr(data-label);
        flex-shrink: 0;
        font-size: 1.2rem;
        font-weight: 700;
        color: var(--main-color);
        text-align: left;
        min-width: 7rem;
    }
    .expert-table td:first-child {
        white-space: normal;
        font-size: 1.4rem;
    }
    .expert-table .major { white-space: normal; }
    /* .expert-table .detail { word-break: break-word; } */
}
@media all and (max-width: 600px) {
    .exp-stats-bar { grid-template-columns: repeat(2, 1fr); }
    .exp-category-grid { grid-template-columns: 1fr; }
    .exp-card-grid { grid-template-columns: repeat(2, 1fr); }
    .exp-process-grid { grid-template-columns: 1fr; }
    .exp-main-tit { font-size: 2.6rem; }
    .exp-cta-tit { font-size: 2.6rem; }
    .expert-overview,
    .expert-directory,
    .expert-closing { padding-left: 2rem; padding-right: 2rem; }
    .expert-overview { padding-top: 5rem; }
    .expert-group-grid,
    .expert-count-bar { grid-template-columns: 1fr; }
    .expert-group-card { min-height: auto; padding: 2.8rem 2.4rem; }
    .expert-role-btn { flex: 1 1 calc(50% - 0.8rem); padding: 0 1.4rem; }
    .expert-title { font-size: 3rem; }
}
@media all and (max-width: 480px) {
    .exp-card-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════
   service_thesis
   ════════════════════════════════════ */
/* ── 페이지 로컬 스타일: 학위논문 컨설팅 ── */

/* ── 공통 섹션 ── */
.thesis-section {
    padding: 10rem 3rem;
    box-sizing: border-box;
}
.thesis-section-inner {
    max-width: 1380px;
    margin: 0 auto;
}
.thesis-section-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.25;
    margin-bottom: 1.6rem;
}
.thesis-section-sub {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
}
/* .thesis-section-label — 공통 라벨 스타일은 상단에 통합 정의 */

/* ── SECTION 1: 대상 + 신뢰 ── */
.thesis-intro-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6rem;
    align-items: center;
}
.thesis-checklist {
    list-style: none;
    margin-top: 3.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
}
.thesis-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 1.4rem;
    font-size: 1.6rem;
    color: var(--color-graphite);
    line-height: 1.6;
    letter-spacing: -0.03em;
}
.thesis-checklist li::before {
    content: '';
    flex-shrink: 0;
    margin-top: 0.3rem;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background: var(--main-color);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='white' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 60%;
}
.thesis-trust-card {
    /* background: var(--color-carbon-dark); */
    background: #4A68D7;
    border-radius: 3rem;
    padding: 5.5rem 5rem;
    color: #fff;
    text-align: center;
}
.thesis-trust-card h4 {
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.03em;
    margin-bottom: 3.5rem;
}
.thesis-trust-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3.5rem 4rem;
}
.thesis-trust-item .num {
    font-family: "Jost", sans-serif;
    font-size: 4rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
    line-height: 1;
    margin-bottom: 0.6rem;
}
.thesis-trust-item .label {
    font-size: 1.35rem;
    color: rgba(255,255,255,0.5);
    letter-spacing: -0.02em;
}

/* ── SECTION 2: 연간 로드맵 ── */
.thesis-roadmap-wrap {
    background: #fff;
}
.thesis-roadmap-tab-row {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-top: 4rem;
    margin-bottom: 5rem;
}
.roadmap-tab-btn {
    display: inline-flex;
    align-items: center;
    height: 4.4rem;
    padding: 0 2.8rem;
    border-radius: 9rem;
    font-size: 1.5rem;
    font-weight: 700;
    font-family: var(--font-family1);
    letter-spacing: -0.03em;
    border: 1.5px solid var(--color-cloud-gray);
    color: var(--color-graphite);
    background: transparent;
    cursor: pointer;
    transition: background-color var(--transition-standard), color var(--transition-standard), border-color var(--transition-standard);
}
.roadmap-tab-btn.active,
.roadmap-tab-btn:hover {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
}
.thesis-roadmap-table {
    border: 1px solid var(--color-cloud-gray);
    border-radius: 1.6rem;
    overflow: hidden;
    background: #fff;
}
.roadmap-months {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    background: var(--color-light-ash);
    border-bottom: 1px solid var(--color-cloud-gray);
}
.roadmap-months > div {
    text-align: center;
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--color-silver-fog);
    padding: 1.4rem 0;
    letter-spacing: -0.02em;
}
.roadmap-body {
    position: relative;
    min-height: 12rem;
}
.roadmap-phase-bg {
    position: absolute;
    inset: 0;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    pointer-events: none;
}
.roadmap-phase-bg .phase-col {
    height: 100%;
}
.roadmap-phase-bg .phase-col.proposal { background: rgba(148,163,184,0.06); }
.roadmap-phase-bg .phase-col.research { background: rgba(249,115,22,0.05); }
.roadmap-phase-bg .phase-col.completion { background: rgba(37,99,235,0.05); }
.roadmap-events {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 0 0.5rem;
    position: relative;
    z-index: 2;
    padding: 2.5rem 0.5rem;
    min-height: 12rem;
    align-items: stretch;
}
.roadmap-event {
    grid-column: span 1;
    display: flex;
    flex-direction: column;
}
.roadmap-event-badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    padding: 1rem 0.6rem;
    border-radius: 0.8rem;
    font-size: 1.15rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
    white-space: normal;
    line-height: 1.35;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
    box-shadow: 0 4px 10px rgba(0,0,0,0.06);
}
.roadmap-event-badge strong {
    display: block;
    font-weight: 800;
    margin-bottom: 0.4rem;
    word-break: keep-all;
}
.roadmap-event-badge span {
    display: block;
    font-size: 0.95rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.88);
    word-break: keep-all;
}
.roadmap-event-badge.proposal { background: #94a3b8; }
.roadmap-event-badge.research { background: #f97316; }
.roadmap-event-badge.completion { background: var(--main-color); }
.thesis-roadmap-phases {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-top: 3rem;
}
.roadmap-phase-card {
    padding: 2rem 2.5rem;
    border-left: 4px solid transparent;
    background: #fff;
    border-radius: 0 1.2rem 1.2rem 0;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.roadmap-phase-card.proposal { border-left-color: #94a3b8; }
.roadmap-phase-card.research { border-left-color: #f97316; }
.roadmap-phase-card.completion { border-left-color: var(--main-color); }
.roadmap-phase-card .period {
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin-bottom: 0.4rem;
}
.roadmap-phase-card.proposal .period { color: #94a3b8; }
.roadmap-phase-card.research .period { color: #f97316; }
.roadmap-phase-card.completion .period { color: var(--main-color); }
.roadmap-phase-card .name {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.03em;
}

/* ── SECTION 3: 16단계 ── */
.thesis-process-wrap {
    background: var(--color-light-ash);
}
.thesis-phase-header {
    display: flex;
    align-items: center;
    gap: 1.6rem;
    margin-bottom: 3.5rem;
}
.thesis-phase-badge {
    display: inline-flex;
    align-items: center;
    height: 3.4rem;
    padding: 0 2rem;
    border-radius: 0.6rem;
    font-size: 1.4rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.02em;
}
.thesis-phase-badge.early { background: #0d9488; }
.thesis-phase-badge.late { background: #1e3a8a; }
.thesis-phase-sub {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-silver-fog);
    letter-spacing: -0.03em;
    font-style: italic;
}
.thesis-step-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem 3rem;
}
.thesis-step-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-left: 4px solid transparent;
    border-radius: 0 1.6rem 1.6rem 0;
    padding: 3rem 2.8rem;
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
    transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard);
}
.thesis-step-card::after {
    content: '';
    position: absolute;
    right: -2rem;
    top: 50%;
    transform: translateY(-50%);
    border-top: 0.8rem solid transparent;
    border-bottom: 0.8rem solid transparent;
    border-left: 1.1rem solid;
    z-index: 3;
}
.thesis-step-card.early::after { border-left-color: #0d9488; }
.thesis-step-card.late::after { border-left-color: #1e3a8a; }
.thesis-step-card:nth-child(4n)::after,
.thesis-step-card:last-child::after { display: none; }
.thesis-step-card.early { border-left-color: #0d9488; }
.thesis-step-card.late { border-left-color: #1e3a8a; }
.thesis-step-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.08);
}
.thesis-step-card.early:hover { border-left-color: #0f766e; }
.thesis-step-card.late:hover { border-left-color: #1e40af; }
.thesis-step-num {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.6rem;
}
.sn-circle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4.4rem;
    height: 4.4rem;
    border-radius: 50%;
    font-family: "Jost", sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
}
.thesis-step-num.early .sn-circle { background: #0d9488; }
.thesis-step-num.late .sn-circle { background: #1e3a8a; }
.sn-label {
    font-family: "Jost", sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: #94a3b8;
}
.thesis-step-title {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.35;
    margin-bottom: 1rem;
}
.thesis-step-desc {
    font-size: 1.4rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
}
.thesis-step-desc .step-desc-line {
    display: flex;
    align-items: flex-start;
    gap: 0.4em;
}
.thesis-step-desc .sdl-bullet {
    flex-shrink: 0;
    line-height: inherit;
}
.thesis-step-desc .sdl-text {
    flex: 1 1 auto;
    min-width: 0;
}
.thesis-process-divider {
    height: 4rem;
}

/* ── SECTION 4: CTA ── */
.thesis-cta-wrap {
    background: var(--color-carbon-dark);
    text-align: center;
    padding: 14rem 3rem;
}
.thesis-cta-wrap .thesis-section-label {
    color: rgba(255,255,255,0.4);
}
.thesis-cta-tit {
    font-size: 4.2rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 2rem;
}
.thesis-cta-sub {
    font-size: 1.7rem;
    color: rgba(255,255,255,0.45);
    letter-spacing: -0.03em;
    line-height: 1.7;
    margin-bottom: 5rem;
}
.thesis-cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 6.4rem;
    padding: 0 5rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    border-radius: 4px;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-standard), transform var(--transition-standard);
}
.thesis-cta-btn:hover {
    background: var(--main-color2);
    transform: scale(1.02);
}
.thesis-cta-note {
    display: block;
    margin-top: 2.5rem;
    font-size: 1.3rem;
    color: rgba(255,255,255,0.25);
    letter-spacing: -0.02em;
}

@media all and (max-width: 1024px) {
    .thesis-intro-grid { grid-template-columns: 1fr; gap: 4rem; }
    .thesis-step-grid { grid-template-columns: repeat(2, 1fr); }
    .thesis-step-card:nth-child(2n)::after { display: none; }
    .thesis-roadmap-phases { grid-template-columns: 1fr; }
    .thesis-cta-tit { font-size: 3rem; }
    .thesis-section-tit { font-size: 3rem; }
    .thesis-trust-card { padding: 4rem 3rem; }
}
@media all and (max-width: 768px) {
    .thesis-roadmap-table { border: none; background: transparent; overflow: visible; }
    .roadmap-months { display: none; }
    .roadmap-phase-bg { display: none; }
    .roadmap-body { position: static; }
    .roadmap-events {
        display: flex;
        flex-direction: column;
        padding: 1.5rem 0 1.5rem 2.6rem;
        margin-left: 5rem;
        min-height: 0;
    }
    .roadmap-events::before {
        content: '';
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        width: 2px;
        background: #cbd5e1;
    }
    .roadmap-event:empty { display: none; }
    .roadmap-event {
        position: relative;
        padding: 0.6rem 0;
        flex-direction: column;
    }
    .roadmap-event::before {
        content: attr(data-month);
        position: absolute;
        left: -10rem;
        top: 50%;
        transform: translateY(-50%);
        width: 5.5rem;
        text-align: right;
        font-size: 1.3rem;
        font-weight: 800;
        color: #334155;
        letter-spacing: -0.02em;
        white-space: nowrap;
    }
    .roadmap-event::after {
        content: '';
        position: absolute;
        left: -2.6rem;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 1.2rem;
        height: 1.2rem;
        border-radius: 50%;
        border: 3px solid var(--main-color);
        background: #fff;
        z-index: 1;
    }
    .roadmap-event:has(.proposal)::after { border-color: #94a3b8; }
    .roadmap-event:has(.research)::after { border-color: #f97316; }
    .roadmap-event:has(.completion)::after { border-color: var(--main-color); }
    .roadmap-event-badge {
        flex: none;
        width: 100%;
        padding: 1.4rem 1.8rem;
        border-radius: 1rem;
        text-align: left;
        align-items: flex-start;
    }
    .roadmap-event-badge strong {
        font-size: 1.4rem;
        margin-bottom: 0.3rem;
    }
    .roadmap-event-badge span {
        font-size: 1.15rem;
    }
}
@media all and (max-width: 640px) {
    .thesis-step-grid { grid-template-columns: 1fr; }
    .thesis-step-card::after {
        display: block;
        right: 50%;
        top: auto;
        bottom: -1.5rem;
        transform: translateX(50%);
        border-left: 0.8rem solid transparent;
        border-right: 0.8rem solid transparent;
        border-top: 1.1rem solid;
        border-bottom: none;
    }
    .thesis-step-card:nth-child(2n)::after,
    .thesis-step-card:nth-child(4n)::after { display: block; }
    .thesis-step-card.early::after { border-top-color: #0d9488; border-left-color: transparent; }
    .thesis-step-card.late::after { border-top-color: #1e3a8a; border-left-color: transparent; }
    .thesis-step-card:last-child::after { display: none; }
    .thesis-trust-grid { grid-template-columns: 1fr 1fr; }
    .thesis-section { padding: 7rem 2rem; }
}

/* ════════════════════════════════════
   service_journal
   ════════════════════════════════════ */
/* -- Page styles: service_journal -- */

/* ── 공통 ── */
.journal-section {
    padding: 10rem 3rem;
    box-sizing: border-box;
}
.journal-section-inner {
    max-width: 1380px;
    margin: 0 auto;
}
.journal-section-label {
    display: inline-block;
    font-family: "Jost", sans-serif;
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    color: var(--main-color);
    text-transform: uppercase;
    margin-bottom: 1.2rem;
}
.journal-section-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.25;
    margin-bottom: 1.6rem;
}
.journal-section-sub {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
}

/* ── SECTION 1: 히어로 보조 + 신뢰 카드 ── */
.journal-hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6rem;
    align-items: center;
}
.journal-highlight {
    /* color: var(--main-color); */
}
.journal-cta-row {
    display: flex;
    gap: 1.6rem;
    margin-top: 4rem;
    flex-wrap: wrap;
}
.journal-btn-primary {
    display: inline-flex;
    align-items: center;
    height: 5.6rem;
    padding: 0 3.8rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    border-radius: 4px;
    text-decoration: none;
    transition: background-color var(--transition-standard);
}
.journal-btn-primary:hover { background: var(--main-color2); }
.journal-btn-secondary {
    display: inline-flex;
    align-items: center;
    height: 5.6rem;
    padding: 0 3.8rem;
    background: #fff;
    color: var(--color-graphite);
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    border-radius: 4px;
    text-decoration: none;
    border: 1.5px solid var(--color-cloud-gray);
    transition: border-color var(--transition-standard), background-color var(--transition-standard);
}
.journal-btn-secondary:hover { border-color: var(--color-pewter); background: var(--color-light-ash); }

.journal-type-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}
.journal-type-card {
    background: var(--color-light-ash);
    border: 1px solid var(--color-cloud-gray);
    border-radius: 1.8rem;
    padding: 3rem 2.4rem;
    transition: border-color var(--transition-standard), box-shadow var(--transition-standard);
}
.journal-type-card:hover {
    border-color: rgba(62,106,225,0.3);
    box-shadow: 0 8px 24px rgba(62,106,225,0.08);
}
.journal-type-card .badge {
    display: inline-flex;
    align-items: center;
    height: 2.8rem;
    padding: 0 1.4rem;
    border-radius: 10rem;
    font-family: "Jost", sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    margin-bottom: 1.6rem;
}
.journal-type-card .badge.sci { background: rgba(62,106,225,0.12); color: var(--main-color); }
.journal-type-card .badge.kci { background: rgba(13,148,136,0.12); color: #0d9488; }
.journal-type-card .badge.cand { background: rgba(249,115,22,0.12); color: #f97316; }
.journal-type-card .name {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 0.8rem;
}
.journal-type-card .duration {
    font-family: "Jost", sans-serif;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--color-silver-fog);
    letter-spacing: -0.01em;
    margin-bottom: 1.4rem;
}
.journal-type-card .desc {
    font-size: 1.4rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.7;
}

/* ── SECTION 2: 타임라인 로드맵 ── */
.journal-roadmap-wrap { background: #fff; }

.journal-tab-row {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-top: 4rem;
    margin-bottom: 5rem;
    flex-wrap: wrap;
}
.journal-tab-btn {
    display: inline-flex;
    align-items: center;
    height: 4.4rem;
    padding: 0 3rem;
    border-radius: 4px;
    font-size: 1.5rem;
    font-weight: 700;
    font-family: var(--font-family1);
    letter-spacing: -0.03em;
    border: 1.5px solid var(--color-cloud-gray);
    color: var(--color-graphite);
    background: transparent;
    cursor: pointer;
    transition: background-color var(--transition-standard), color var(--transition-standard), border-color var(--transition-standard);
}
.journal-tab-btn.active,
.journal-tab-btn:hover {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
}

/* 타임라인 비주얼 */
.journal-timeline-box {
    background: var(--color-light-ash);
    border-radius: 2rem;
    padding: 4rem;
    border: 1px solid var(--color-cloud-gray);
}
.journal-week-scale {
    display: flex;
    justify-content: space-between;
    margin-bottom: 1.4rem;
    font-size: 1.1rem;
    font-family: "Jost", sans-serif;
    font-weight: 700;
    color: var(--color-silver-fog);
    letter-spacing: 0.04em;
    padding: 0 0.4rem;
}
.journal-week-scale span { min-width: 0; text-align: center; }
.journal-progress-bar {
    display: flex;
    height: 6.4rem;
    background: #fff;
    border-radius: 1.2rem;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.journal-bar-phase {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    white-space: nowrap;
    padding: 0 1rem;
    overflow: hidden;
}
.journal-bar-phase.proposal { background: #94a3b8; color: #fff; }
.journal-bar-phase.research { background: #f97316; color: #fff; }
.journal-bar-phase.completion { background: var(--main-color); color: #fff; }
.journal-timeline-hint {
    text-align: center;
    margin-top: 2.4rem;
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--main-color);
    letter-spacing: -0.02em;
}

/* 주차 상세 그리드 */
.journal-week-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.6rem;
    margin-top: 5rem;
}
.journal-week-card {
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 1.6rem;
    padding: 2.8rem 2.4rem;
    transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard);
}
.journal-week-card:hover {
    border-color: rgba(62,106,225,0.3);
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(62,106,225,0.1);
}
.journal-week-card.phase-proposal { border-top: 3px solid #94a3b8; }
.journal-week-card.phase-research { border-top: 3px solid #f97316; }
.journal-week-card.phase-completion { border-top: 3px solid var(--main-color); }
.journal-week-card .week-label {
    font-family: "Jost", sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--color-silver-fog);
    margin-bottom: 1rem;
    text-transform: uppercase;
}
.journal-week-card .week-title {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 0.8rem;
    line-height: 1.35;
}
.journal-week-card .week-desc {
    font-size: 1.35rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.65;
}

/* week-sub, week-desc-list */
.journal-week-card .week-sub {
    font-size: 1.35rem;
    font-weight: 700;
    margin-bottom: 1.2rem;
    line-height: 1.4;
    letter-spacing: -0.02em;
}
.journal-week-card.phase-proposal .week-sub { color: #475569; }
.journal-week-card.phase-research .week-sub { color: #ea580c; }
.journal-week-card.phase-completion .week-sub { color: var(--main-color); }

.week-desc-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}
.week-desc-list li {
    position: relative;
    padding-left: 1.2rem;
    font-size: 1.3rem;
    color: var(--color-pewter);
    line-height: 1.5;
    letter-spacing: -0.02em;
}
.week-desc-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.6rem;
    width: 0.4rem;
    height: 0.4rem;
    border-radius: 50%;
    background: var(--color-silver-fog);
}

/* ── SECTION 3: 상세 지도 범위 ── */
.journal-detail-wrap { background: var(--color-light-ash); }

.journal-detail-header-row {
    margin-bottom: 3.5rem;
    text-align: center;
}

.journal-table-container {
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 2rem;
    padding: 3.5rem 3rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
    margin-top: 3.5rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.journal-modern-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}
.journal-modern-table th {
    padding: 1.8rem 2.5rem;
    background: rgba(62, 106, 225, 0.04);
    color: var(--color-graphite);
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    border-bottom: 1.5px solid var(--color-cloud-gray);
}
.journal-modern-table td {
    padding: 3rem 2.5rem;
    border-bottom: 1px solid var(--color-cloud-gray);
    vertical-align: top;
}
.journal-modern-table tr:last-child td {
    border-bottom: none;
}

.journal-modern-table.secondary-table th {
    background: rgba(13, 148, 136, 0.04);
}

.course-name {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    align-items: flex-start;
}
.course-name .badge {
    border-radius: 10rem;
}
.course-name strong {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    line-height: 1.4;
    letter-spacing: -0.03em;
}

.course-name.spec-td {
    gap: 1.6rem;
}

.badge {
    display: inline-flex;
    align-items: center;
    height: 2.6rem;
    padding: 0 1.2rem;
    border-radius: 10rem;
    font-family: "Jost", sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}
.sci-badge { background: rgba(62, 106, 225, 0.1); color: var(--main-color); }
.scopus-badge { background: rgba(249, 115, 22, 0.1); color: #f97316; }
.science-badge { background: rgba(13, 148, 136, 0.1); color: #0d9488; }

.table-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}
.table-list li {
    position: relative;
    padding-left: 1.6rem;
    font-size: 1.45rem;
    color: var(--color-graphite);
    line-height: 1.6;
    letter-spacing: -0.02em;
    word-break: auto-phrase;
}
.table-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.8rem;
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: var(--color-silver-fog);
}
.table-list li strong {
    color: var(--color-carbon-dark);
}

.table-list.double-col-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.6rem 3rem;
}

.table-list.compact {
    gap: 0.8rem;
}
.table-list.compact li {
    font-size: 1.35rem;
}

.highlight-text {
    color: var(--main-color);
}
.table-note {
    font-size: 1.3rem;
    color: var(--color-pewter);
    margin-top: 1.8rem;
    letter-spacing: -0.02em;
}

.target-field {
    margin-top: 1rem;
    background: var(--color-light-ash);
    padding: 1.4rem 1.8rem;
    border-radius: 1rem;
    width: 100%;
    box-sizing: border-box;
}
.target-field strong {
    display: block;
    font-size: 1.2rem;
    color: var(--color-pewter);
    margin-bottom: 0.4rem;
}
.target-field span {
    font-size: 1.35rem;
    font-weight: 700;
    color: #0d9488;
}

.info-block {
    padding: 1.8rem 0;
}
.info-block:first-child {
    padding-top: 0;
}
.info-block.border-top {
    border-top: 1px solid var(--color-cloud-gray);
}
.info-block strong {
    display: block;
    font-size: 1.4rem;
    color: var(--color-carbon-dark);
    margin-bottom: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

/* Margin helper */
.margin-top-lg {
    margin-top: 5rem;
}

/* ── 프로세스 플로우 카드 (jkp) ── */
.jkp-wrap {
    margin-top: 0;
    margin-bottom: 5rem;
}
.jkp-steps {
    display: flex;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 0;
    margin-bottom: 2rem;
}
.jkp-card {
    flex: 1;
    min-width: 0;
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 1.6rem;
    padding: 2.8rem 2rem;
    transition: border-color var(--transition-standard), box-shadow var(--transition-standard);
}
.jkp-card:hover {
    border-color: rgba(62, 106, 225, 0.3);
    box-shadow: 0 8px 24px rgba(62, 106, 225, 0.08);
}
.jkp-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.6rem;
    height: 3.6rem;
    background: rgba(62, 106, 225, 0.1);
    color: var(--main-color);
    font-family: "Jost", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    border-radius: 50%;
    margin-bottom: 1.6rem;
}
.jkp-title {
    font-size: 1.55rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.4;
    margin-bottom: 1rem;
    word-break: keep-all;
}
.jkp-desc {
    font-size: 1.3rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.65;
    word-break: keep-all;
}
.jkp-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 3.6rem;
}
.jkp-arrow-icon {
    width: 1.1rem;
    height: 1.1rem;
    border-right: 0.3rem solid var(--main-color);
    border-top: 0.3rem solid var(--main-color);
    transform: rotate(45deg);
    background: none;
    box-shadow: none;
    border-radius: 0;
    flex-shrink: 0;
}
.jkp-points {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin-top: 2rem;
}
.jkp-point {
    background: var(--color-light-ash);
    border: 1px solid var(--color-cloud-gray);
    border-radius: 1.4rem;
    padding: 2.4rem 2.4rem;
}
.jkp-point-title {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 1rem;
}
.jkp-point-desc {
    font-size: 1.4rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.6;
    word-break: keep-all;
}

/* ── SECTION 4: CTA ── */
.journal-cta-wrap {
    background: var(--color-carbon-dark);
    text-align: center;
    padding: 14rem 3rem;
}
.journal-cta-tit {
    font-size: 4.2rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 2rem;
}
.journal-cta-sub {
    font-size: 1.7rem;
    color: rgba(255,255,255,0.45);
    letter-spacing: -0.03em;
    line-height: 1.7;
    margin-bottom: 5rem;
}
.journal-cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 6.4rem;
    padding: 0 5rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    border-radius: 4px;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-standard), transform var(--transition-standard);
}
.journal-cta-btn:hover { background: var(--main-color2); transform: scale(1.02); }
.journal-cta-note {
    display: block;
    margin-top: 2.5rem;
    font-size: 1.3rem;
    color: rgba(255,255,255,0.25);
    letter-spacing: -0.02em;
}

@media all and (max-width: 1024px) {
    .journal-hero-grid { grid-template-columns: 1fr; gap: 4rem; }
    .journal-hero-grid > div:first-child { text-align: center; }
    .journal-hero-grid > div:first-child .journal-cta-row { justify-content: center; }
    .journal-type-cards { grid-template-columns: 1fr; gap: 1.5rem; }
    .journal-detail-grid { grid-template-columns: 1fr; }
    .journal-week-grid { grid-template-columns: repeat(2, 1fr); }
    .journal-cta-tit { font-size: 3rem; }
    .journal-section-tit { font-size: 2.8rem; }
    
    /* Table responsive stack */
    .journal-modern-table, 
    .journal-modern-table thead, 
    .journal-modern-table tbody, 
    .journal-modern-table th, 
    .journal-modern-table td, 
    .journal-modern-table tr {
        display: block;
        width: 100%;
        box-sizing: border-box;
    }
    .journal-modern-table thead {
        display: none;
    }
    .journal-modern-table tr {
        border-bottom: 2px dashed var(--color-cloud-gray);
        padding: 3rem 0;
    }
    .journal-modern-table tr:last-child {
        border-bottom: none;
    }
    .journal-modern-table td {
        padding: 1.2rem 0;
        border-bottom: none;
    }
    .journal-modern-table td:first-child {
        padding-top: 0;
    }
    .journal-modern-table td:last-child {
        padding-bottom: 0;
    }
    .table-list.double-col-list {
        grid-template-columns: 1fr;
        gap: 1.2rem;
    }
    .journal-table-container {
        padding: 2.5rem 2rem;
    }
    .info-block.border-top {
        margin-top: 2rem;
        padding-top: 2rem;
    }
}
@media all and (max-width: 768px) {
    .journal-cta-row { flex-wrap: nowrap; }
    .journal-btn-primary,
    .journal-btn-secondary { flex: 1; justify-content: center; padding: 0 1rem; font-size: 1.35rem; white-space: nowrap; }
    .journal-tab-row { flex-direction: column; }
    .journal-tab-btn { width: 100%; justify-content: center; }
    .journal-progress-bar { height: 4.8rem; }
    .journal-bar-phase { font-size: 1.05rem; padding: 0 0.4rem; }
    .course-name .badge { display: flex; width: fit-content; }
    .jkp-steps { flex-wrap: wrap; gap: 1.6rem; }
    .jkp-card { flex: 0 0 calc(50% - 0.8rem); }
    .jkp-arrow { display: none; }
    .jkp-points { grid-template-columns: 1fr; }
    .journal-cta-wrap { padding: 8rem 2rem; }
    .journal-cta-tit { font-size: 2.6rem; }
    .journal-cta-sub { font-size: 1.5rem; margin-bottom: 3rem; }
}
@media all and (max-width: 640px) {
    .journal-week-grid { grid-template-columns: 1fr; }
    .jkp-card { flex: 0 0 100%; }
    .journal-section { padding: 7rem 2rem; }
    .journal-timeline-box { padding: 2.5rem 1.6rem; }
    .journal-section-tit { font-size: 3rem; }
    .journal-section-sub { font-size: 1.6rem; }
    .journal-week-scale { display: none; }
    .journal-progress-bar { height: 4rem; border-radius: 0.8rem; }
    .journal-bar-phase { font-size: 1rem; }
    .journal-table-container { padding: 2rem 1.6rem; border-radius: 1.2rem; }
    .course-name strong { font-size: 1.5rem; }
    .table-list li { font-size: 1.3rem; padding-left: 1.2rem; }
    .journal-cta-wrap { padding: 6rem 2rem; }
    .journal-cta-tit { font-size: 2.2rem; }
}

/* ════════════════════════════════════
   service_lecture
   ════════════════════════════════════ */
/* -- Page styles: service_lecture -- */

/* ── 공통 ── */
.lec-section {
    padding: 10rem 3rem;
    box-sizing: border-box;
}
.lec-inner {
    max-width: 1380px;
    margin: 0 auto;
}
/* .lec-label — 공통 라벨 스타일은 상단에 통합 정의 */
.lec-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.25;
    margin-bottom: 1.6rem;
}
.lec-sub {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
}

/* ── SECTION 1: 고민 카드 4종 ── */
.lec-target-header {
    text-align: center;
    margin-bottom: 6rem;
}
.lec-wrap-ash { background: var(--color-light-ash); }
.lec-target-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2.4rem;
}
.lec-target-card {
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 2.4rem;
    padding: 4.5rem 4rem;
    position: relative;
    overflow: hidden;
    transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard);
}
.lec-target-card::before {
    content: 'Q.';
    position: absolute;
    top: -1rem;
    right: 2rem;
    font-family: "Jost", sans-serif;
    font-size: 9rem;
    font-weight: 800;
    color: rgba(62,106,225,0.04);
    line-height: 1;
    pointer-events: none;
}
.lec-target-card:hover {
    border-color: rgba(62,106,225,0.35);
    transform: translateY(-6px);
    box-shadow: 0 20px 48px rgba(62,106,225,0.1);
}
.lec-target-card h4 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 1.4rem;
    line-height: 1.35;
    position: relative;
    z-index: 1;
}
.lec-target-card p {
    font-size: 1.5rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.8;
    position: relative;
    z-index: 1;
}

/* ── SECTION 2: 접근법 ── */
.lec-approach-wrap { background: var(--color-light-ash); }
.lec-approach-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 8rem;
    align-items: start;
}
.lec-approach-list {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    margin-top: 1rem;
}
.lec-approach-item {
    display: flex;
    align-items: flex-start;
    gap: 2.4rem;
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 1.8rem;
    padding: 3.5rem;
    transition: border-color var(--transition-standard), box-shadow var(--transition-standard);
}
.lec-approach-item:hover {
    border-color: rgba(62,106,225,0.25);
    box-shadow: 0 8px 24px rgba(62,106,225,0.07);
}
.lec-approach-num {
    font-family: "Jost", sans-serif;
    font-size: 3rem;
    font-weight: 700;
    color: var(--main-color);
    letter-spacing: -0.02em;
    line-height: 1;
    flex-shrink: 0;
    opacity: 0.5;
}
.lec-approach-item h4 {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 1rem;
    line-height: 1.3;
}
.lec-approach-item p {
    font-size: 1.5rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.75;
}

/* ── SECTION 3: 신뢰/실적 ── */
.lec-trust-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 3rem;
    margin-bottom: 5rem;
    flex-wrap: wrap;
}
.lec-trust-link {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--main-color);
    text-decoration: none;
    letter-spacing: -0.02em;
    transition: gap var(--transition-standard);
    white-space: nowrap;
}
.lec-trust-link:hover { gap: 1.4rem; }
.lec-trust-link svg { flex-shrink: 0; }
.lec-trust-link-abs {
    position: absolute;
    right: 0;
    bottom: 0;
}
@media (max-width: 768px) {
    .lec-trust-link-abs {
        position: static;
        margin-top: 2rem;
    }
}
/* 클로징 섹션 슬라이더 — about_strengths 의 network-slide 와 동일 패턴 */
.lec-closing-slide {
    position: relative;
    width: 100%;
    min-height: 38rem;
    border-radius: 2.4rem;
    overflow: hidden;
    background: #f4f6fb;
    margin: 0;
}
.lec-closing-slide .network-slideshow {
    position: absolute;
    inset: 0;
}
@media (max-width: 768px) {
    .lec-closing-slide { min-height: 26rem; }
}
/* 특강 페이지 파트너 슬라이더 — 한 줄 6개 */
.lec-partner-slider .main-partners-list .partner-item { width: 24rem; }
@media (max-width: 1024px) {
    .lec-partner-slider .main-partners-list .partner-item { width: 18rem; }
}
@media (max-width: 640px) {
    .lec-partner-slider .main-partners-list .partner-item { width: 14rem; }
}
/* 기관 로고: 절반 크기 (about_performance 정부·공공기관 + service_lecture 하단 슬라이더) */
.perf-partner-roller-wrap .main-partners-list .partner-inner > span img[src*="/institutions/"],
.lec-partner-slider .main-partners-list .partner-inner > span img[src*="/institutions/"] {
    max-height: 50%;
    max-width: 55%;
    width: auto;
    height: auto;
    object-fit: contain;
}
.perf-partner-roller-wrap .main-partners-list .partner-inner > span:has(img[src*="/institutions/"]),
.lec-partner-slider .main-partners-list .partner-inner > span:has(img[src*="/institutions/"]) {
    box-sizing: border-box;
}
/* about_performance 페이지 left/right 롤러 — main.css 기본값과 다른 속도로 별도 지정 */
/* 정부·공공기관(#government) 슬라이더 속도 — 위/아래 각각 조정 */
#government .perf-partner-roller-wrap .main-partners-roller.left {
    animation-duration: 140s;
}
#government .perf-partner-roller-wrap .main-partners-roller.right {
    animation-duration: 140s;
}

/* 대학교(#university) 슬라이더 속도 — 위/아래 각각 조정 */
#university .perf-partner-roller-wrap .main-partners-roller.left {
    animation-duration: 70s;
}
#university .perf-partner-roller-wrap .main-partners-roller.right {
    animation-duration: 70s;
}
.lec-logo-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1.6rem;
}
.lec-logo-item {
    height: 9rem;
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 1.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.6rem 2rem;
    transition: border-color var(--transition-standard), box-shadow var(--transition-standard);
}
.lec-logo-item:hover {
    border-color: rgba(62,106,225,0.25);
    box-shadow: 0 4px 16px rgba(62,106,225,0.07);
}
.lec-logo-item img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    filter: grayscale(100%);
    opacity: 0.55;
    transition: filter var(--transition-standard), opacity var(--transition-standard);
}
.lec-logo-item:hover img {
    filter: grayscale(0%);
    opacity: 1;
}

/* ── SECTION 4: 운영 프로세스 ── */
.lec-process-wrap { background: var(--color-light-ash); }
.lec-process-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    margin-top: 6rem;
    position: relative;
}
.lec-process-grid::before {
    content: '';
    position: absolute;
    top: 5.6rem;
    left: calc(25% - 1rem);
    right: calc(25% - 1rem);
    height: 1px;
    background: var(--color-cloud-gray);
    z-index: 0;
}
.lec-process-card {
    position: relative;
    z-index: 1;
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 2rem;
    padding: 4rem 3rem;
    text-align: center;
    transition: border-color var(--transition-standard), box-shadow var(--transition-standard);
}
.lec-process-card:hover {
    border-color: rgba(62,106,225,0.3);
    box-shadow: 0 12px 32px rgba(62,106,225,0.09);
}
.lec-process-card.main-step {
    border-color: var(--main-color);
    background: var(--main-color);
}
.lec-process-card.main-step .step-num,
.lec-process-card.main-step h4,
.lec-process-card.main-step p { color: #fff; }
.lec-process-card.main-step .step-divider { background: rgba(255,255,255,0.3); }
.step-num {
    font-family: "Jost", sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--color-silver-fog);
    margin-bottom: 2rem;
    display: block;
    text-transform: uppercase;
}
.lec-process-card h4 {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.3;
}
.step-divider {
    width: 3rem;
    height: 2px;
    background: var(--color-cloud-gray);
    margin: 1.8rem auto;
    border-radius: 2px;
}
.lec-process-card p {
    font-size: 1.45rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.7;
}

/* ── SECTION 5: 클로징 + CTA ── */
.lec-closing-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10rem;
    align-items: center;
}
.lec-photo-mosaic {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.4rem;
    justify-items: center;
}
.lec-photo-item {
    width: 20rem;
    height: 20rem;
    border-radius: 50%;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}
.lec-photo-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.lec-photo-item:hover img {
    transform: scale(1.08);
}
.lec-photo-item:nth-child(2) { margin-top: 3rem; }
.lec-photo-item:nth-child(3) { margin-top: -2rem; }
.lec-photo-item:nth-child(4) { margin-top: 1rem; }
.lec-closing-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 2.4rem;
}
@media (max-width: 768px) {
    .lec-closing-tit { font-size: 3rem; }
}
/* .lec-closing-tit span { color: var(--main-color); } */
.lec-closing-txt {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.85;
    margin-bottom: 4.5rem;
}
.lec-closing-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1rem;
    height: auto;
    padding: 1.2rem 3.2rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    border-radius: 9rem;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.lec-closing-btn:hover {
    background: var(--main-color2);
    transform: translateY(-2px);
    box-shadow: 0 1.2rem 3rem rgba(62, 106, 225, 0.18);
}

@media all and (max-width: 1024px) {
    .lec-target-grid { grid-template-columns: 1fr; gap: 2rem; }
    .lec-approach-grid { grid-template-columns: 1fr; gap: 4rem; }
    .lec-process-grid { grid-template-columns: repeat(2, 1fr); }
    .lec-process-grid::before { display: none; }
    .lec-closing-grid { grid-template-columns: 1fr; gap: 6rem; }
    .lec-logo-grid { grid-template-columns: repeat(3, 1fr); }
    .lec-tit { font-size: 3rem; }
}
@media all and (max-width: 768px) {
    .lec-approach-grid > div:first-child { text-align: center; }
    .lec-closing-grid > div { text-align: center; }
    .lec-closing-grid > div .cta-btn-primary { display: inline-flex; }
}
@media all and (max-width: 640px) {
    .lec-process-grid { grid-template-columns: 1fr; }
    .lec-logo-grid { grid-template-columns: repeat(2, 1fr); }
    .lec-photo-mosaic { grid-template-columns: 1fr 1fr; }
    .lec-section { padding: 7rem 2rem; }
}

/* ════════════════════════════════════
   service_statistics
   ════════════════════════════════════ */
/* -- Page styles: service_statistics -- */

/* ── 공통 ── */
.stat-section { padding: 10rem 3rem; box-sizing: border-box; }
.stat-inner { max-width: 1380px; margin: 0 auto; }
/* .stat-label — 공통 라벨 스타일은 상단에 통합 정의 */
.stat-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.25;
    margin-bottom: 1.6rem;
}
.stat-sub {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
}

/* ── SECTION 1: 대상 카드 ── */
.stat-target-header { text-align: center; margin-bottom: 6rem; }
.stat-target-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2.4rem;
}
@media (max-width: 1024px) {
    .stat-target-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .stat-target-grid { grid-template-columns: 1fr; }
}
.stat-target-card {
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 2.4rem;
    padding: 4rem 3.5rem;
    transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard);
}
.stat-target-card:hover {
    border-color: rgba(62,106,225,0.3);
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(62,106,225,0.09);
}
.stat-target-icon {
    width: 5.6rem;
    height: 5.6rem;
    border-radius: 1.4rem;
    background: rgba(62,106,225,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    margin-bottom: 2.8rem;
}
.stat-target-card h3 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 1.2rem;
    line-height: 1.35;
}
.stat-target-card p {
    font-size: 1.5rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.75;
}

/* ── SECTION 2: 분석 유형 ── */
.stat-approach-wrap { background: var(--color-light-ash); }
.stat-approach-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    margin-top: 6rem;
}
.stat-approach-card {
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 2.8rem;
    padding: 5rem 4.5rem;
    transition: box-shadow var(--transition-standard);
}
.stat-approach-card:hover { box-shadow: 0 12px 40px rgba(0,0,0,0.07); }
.stat-approach-badge {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--main-color);
    letter-spacing: -0.01em;
    margin-bottom: 1.4rem;
    display: block;
}
.stat-approach-card h3 {
    font-size: 2.8rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 1.8rem;
    line-height: 1.25;
}
.stat-approach-card p {
    font-size: 1.5rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.8;
    margin-bottom: 3rem;
}
.stat-tag-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
}
.stat-tag {
    display: inline-flex;
    align-items: center;
    height: 3.4rem;
    padding: 0 1.4rem;
    border-radius: 10rem;
    background: var(--color-light-ash);
    border: 1px solid var(--color-cloud-gray);
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--color-graphite);
    letter-spacing: -0.02em;
    transition: background-color var(--transition-standard), border-color var(--transition-standard), color var(--transition-standard);
}
.stat-tag:hover {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
}

/* ── SECTION 3: 통계 환경 ── */
.stat-tools-header { text-align: center; margin-bottom: 5rem; }
.stat-tools-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.4rem;
}
.stat-tool-pill {
    display: inline-flex;
    align-items: center;
    height: 5rem;
    padding: 0 3rem;
    border-radius: 10rem;
    border: 1.5px solid var(--color-cloud-gray);
    font-family: "Jost", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-graphite);
    letter-spacing: 0.02em;
    transition: border-color var(--transition-standard), background-color var(--transition-standard), color var(--transition-standard);
}
.stat-tool-pill:hover {
    border-color: var(--main-color);
    background: rgba(62,106,225,0.06);
    color: var(--main-color);
}

/* ── SECTION 4: 프로세스 5단계 ── */
.stat-process-wrap { background: var(--color-light-ash); }
.stat-process-header { text-align: center; margin-bottom: 7rem; }
.stat-process-orbit {
    position: relative;
    width: 68rem;
    height: 68rem;
    margin: 0 auto;
}
.stat-orbit-ring {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    border: 1.5px dashed rgba(62,106,225,0.2);
    border-radius: 50%;
    box-sizing: border-box;
}
.stat-process-card {
    position: absolute;
    width: 17rem;
    background: #fff;
    border: 1px solid var(--color-cloud-gray);
    border-radius: 2rem;
    padding: 3rem 2.2rem;
    text-align: center;
    transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard);
}
.stat-process-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 36px rgba(0,0,0,0.08);
}
.stat-pos-1 { top: 0;    left: 50%; transform: translateX(-50%); }
.stat-pos-1:hover { transform: translateX(-50%) translateY(-6px); }
.stat-pos-2 { top: 28%; right: 0; }
.stat-pos-3 { top: 65%; right: 12%; }
.stat-pos-4 { top: 65%; left: 12%; }
.stat-pos-5 { top: 28%; left: 0; }
.stat-process-card.highlight {
    border-color: var(--main-color);
    border-width: 2px;
    box-shadow: 0 16px 40px rgba(62,106,225,0.15);
}
.stat-process-card.highlight:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 50px rgba(62,106,225,0.2);
}
.stat-expert-badge {
    position: absolute;
    top: -1.6rem;
    left: 50%;
    transform: translateX(-50%);
    background: var(--main-color);
    color: #fff;
    font-size: 1.1rem;
    font-weight: 700;
    padding: 0.5rem 1.4rem;
    border-radius: 10rem;
    white-space: nowrap;
    letter-spacing: -0.01em;
    box-shadow: 0 8px 20px rgba(62,106,225,0.3);
}
.stat-step-num {
    width: 4.4rem;
    height: 4.4rem;
    border-radius: 50%;
    background: var(--color-carbon-dark);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Jost", sans-serif;
    font-size: 1.3rem;
    font-weight: 700;
    margin: 0 auto 1.8rem;
}
.stat-process-card.highlight .stat-step-num {
    background: var(--main-color);
    box-shadow: 0 6px 16px rgba(62,106,225,0.35);
    width: 5.2rem;
    height: 5.2rem;
    font-size: 1.5rem;
}
.stat-process-card h4 {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 1rem;
    line-height: 1.3;
}
.stat-process-card.highlight h4 {
    font-size: 1.9rem;
    color: var(--main-color);
}
.stat-process-card p {
    font-size: 1.3rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.7;
}
.stat-process-list {
    display: none;
    flex-direction: column;
    gap: 2rem;
}
.stat-process-list .stat-process-card {
    position: relative;
    width: 100%;
    box-sizing: border-box;
    transform: none !important;
}

/* ── SECTION 5: CTA ── */
.stat-cta-wrap {
    background: var(--color-carbon-dark);
    text-align: center;
    padding: 14rem 3rem;
}
.stat-cta-tit {
    font-size: 4.2rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.04em;
    line-height: 1.3;
    margin-bottom: 2rem;
}
.stat-cta-sub {
    font-size: 1.7rem;
    color: rgba(255,255,255,0.45);
    letter-spacing: -0.03em;
    line-height: 1.7;
    margin-bottom: 5rem;
}
.stat-cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 6.4rem;
    padding: 0 5rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    border-radius: 4px;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-standard), transform var(--transition-standard);
}
.stat-cta-btn:hover { background: var(--main-color2); transform: scale(1.02); }
.stat-cta-note {
    display: block;
    margin-top: 2.5rem;
    font-size: 1.3rem;
    color: rgba(255,255,255,0.25);
    letter-spacing: -0.02em;
}

@media all and (max-width: 1100px) {
    .stat-process-orbit { display: none; }
    .stat-process-list { display: flex; }
    .stat-approach-grid { grid-template-columns: 1fr; }
    .stat-target-grid { grid-template-columns: 1fr; gap: 2rem; }
}
@media all and (max-width: 640px) {
    .stat-section { padding: 7rem 2rem; }
    .stat-tit { font-size: 3rem; }
    .stat-cta-tit { font-size: 3rem; }
}

/* ════════════════════════════════════
   service_ai_education
   ════════════════════════════════════ */
/* -- Page styles: service_ai_education -- */

/* ── 공통 ── */
.ai-section { padding: 10rem 3rem; box-sizing: border-box; }
.ai-inner { max-width: 1380px; margin: 0 auto; }
/* .ai-label — 공통 라벨 스타일은 상단에 통합 정의 */
.ai-tit {
    font-size: 4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    line-height: 1.25;
    margin-bottom: 1.6rem;
}
.ai-sub {
    font-size: 1.6rem;
    color: var(--color-pewter);
    letter-spacing: -0.03em;
    line-height: 1.7;
}

/* ── SECTION 1: HERO 플로우 ── */
.ai-hero-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 4rem;
    align-items: center;
    margin-top: 6rem;
}
.ai-hero-left {
    position: relative;
    border-radius: 3rem;
    padding: 5.5rem 5rem;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.5) 0%, rgba(255,255,255,0.2) 100%),
        linear-gradient(135deg, #e8eefb 0%, #dbe4f8 50%, #c7d7f5 100%);
    backdrop-filter: blur(22px) saturate(180%);
    -webkit-backdrop-filter: blur(22px) saturate(180%);
    border: 1.5px solid rgba(255,255,255,0.7);
    box-shadow:
        0 18px 45px rgba(62,106,225,0.14),
        inset 0 1px 0 rgba(255,255,255,0.8),
        inset 0 -1px 0 rgba(255,255,255,0.1);
    overflow: hidden;
    isolation: isolate;
}
/* 글래스 효과가 보이도록 컬러풀한 블롭 배경 (z-index -1) */
.ai-hero-left::before,
.ai-hero-left::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    z-index: -1;
    opacity: 0.85;
    pointer-events: none;
}
.ai-hero-left::before {
    width: 50rem;
    height: 50rem;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle at center, #b4c8f5 0%, transparent 60%);
}
.ai-hero-left::after {
    width: 28rem;
    height: 28rem;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle at center, #c7d7f5 0%, transparent 60%);
    opacity: 1;
}
.ai-hero-left .badge { font-size: 2rem; font-weight: 700; color: var(--main-color); letter-spacing: -0.01em; margin-bottom: 2rem; display: block; }
.ai-hero-left h2 { font-size: 3rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; line-height: 1.3; margin-bottom: 2rem; }
.ai-hero-left p { font-size: 1.55rem; color: var(--color-pewter); line-height: 1.8; letter-spacing: -0.02em; }
.ai-hero-arrow { font-size: 3.2rem; font-weight: 900; color: var(--main-color); flex-shrink: 0; line-height: 1; }
.ai-course-stack { display: flex; flex-direction: column; gap: 1.4rem; }
.ai-course-pill { background: #fff; color: var(--color-carbon-dark); border-radius: 1.6rem; padding: 2.2rem 2.8rem; border: 1px solid var(--color-cloud-gray); }
.ai-course-pill.premium { background: var(--main-color); border: 1px solid rgba(62,106,225,0.15); }
.ai-course-pill .course-level { font-family: "Jost", sans-serif; font-size: 1.2rem; font-weight: 700; letter-spacing: 0.06em; color: var(--main-color); margin-bottom: 0.6rem; display: block; }
.ai-course-pill .course-name { font-size: 2rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; line-height: 1.3; }
.ai-course-pill.premium .course-level { color: rgba(255,255,255,0.6); }
.ai-course-pill.premium .course-name { color: #fff; }

/* ── SECTION 2: 대상 ── */
.ai-wrap-ash { background: var(--color-light-ash); }
.ai-target-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.4rem; margin-top: 6rem; }
.ai-target-card { background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2.8rem; padding: 4rem 3.5rem; transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard); }
.ai-target-card:hover { border-color: rgba(62,106,225,0.3); transform: translateY(-6px); box-shadow: 0 16px 40px rgba(62,106,225,0.09); }
.ai-target-card .icon { font-size: 4rem; margin-bottom: 2.4rem; display: block; }
.ai-target-card h3 { font-size: 2rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.2rem; line-height: 1.35; }
.ai-target-card p { font-size: 1.5rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.75; }

/* ── SECTION 3: 5단계 원형 + 코스 카드 ── */
.ai-process-orbit { position: relative; width: 68rem; height: 68rem; margin: 0 auto 8rem; }
.ai-orbit-ring { position: absolute; inset: 0; border: 1.5px dashed rgba(62,106,225,0.2); border-radius: 50%; }
.ai-step-card { position: absolute; width: 17rem; background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2rem; padding: 3rem 2.2rem; text-align: center; transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard); }
.ai-step-card:hover { transform: translateY(-6px); box-shadow: 0 16px 36px rgba(0,0,0,0.08); }
.ai-pos-1 { top: 0; left: 50%; transform: translateX(-50%); }
.ai-pos-1:hover { transform: translateX(-50%) translateY(-6px); }
.ai-pos-2 { top: 28%; right: 0; }
.ai-pos-3 { top: 65%; right: 12%; }
.ai-pos-4 { top: 65%; left: 12%; }
.ai-pos-5 { top: 28%; left: 0; }
.ai-step-card.highlight { border-color: var(--main-color); border-width: 2px; box-shadow: 0 16px 40px rgba(62,106,225,0.15); }
.ai-step-card.highlight:hover { box-shadow: 0 24px 50px rgba(62,106,225,0.2); }
.ai-expert-badge { position: absolute; top: -1.6rem; left: 50%; transform: translateX(-50%); background: var(--main-color); color: #fff; font-size: 1.1rem; font-weight: 700; padding: 0.5rem 1.4rem; border-radius: 10rem; white-space: nowrap; letter-spacing: -0.01em; box-shadow: 0 8px 20px rgba(62,106,225,0.3); }
.ai-step-num { width: 4.4rem; height: 4.4rem; border-radius: 50%; background: var(--color-carbon-dark); color: #fff; display: flex; align-items: center; justify-content: center; font-family: "Jost", sans-serif; font-size: 1.3rem; font-weight: 700; margin: 0 auto 1.8rem; }
.ai-step-card.highlight .ai-step-num { background: var(--main-color); box-shadow: 0 6px 16px rgba(62,106,225,0.35); width: 5.2rem; height: 5.2rem; font-size: 1.5rem; }
.ai-step-card h4 { font-size: 1.7rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1rem; line-height: 1.3; }
.ai-step-card.highlight h4 { font-size: 1.9rem; color: var(--main-color); }
.ai-step-card p { font-size: 1.3rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.7; }
.ai-step-list { display: none; flex-direction: column; gap: 2rem; margin-bottom: 6rem; }
.ai-step-list .ai-step-card { position: relative; width: 100%; transform: none !important; box-sizing: border-box; }

/* 코스 카드 3종 */
.ai-course-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.4rem; margin-top: 2rem; }
.ai-course-card { border-radius: 2.8rem; padding: 4.5rem 4rem; transition: transform var(--transition-standard), box-shadow var(--transition-standard); }
.ai-course-card:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(0,0,0,0.12); }
.ai-course-card.dark { background: #fff; border: 1px solid var(--color-cloud-gray); }
.ai-course-card.blue { background: var(--main-color); border: 1px solid rgba(62,106,225,0.15); }
.ai-course-card .course-level { font-family: "Jost", sans-serif; font-size: 1.2rem; font-weight: 700; letter-spacing: 0.06em; margin-bottom: 1.6rem; display: block; }
.ai-course-card.dark .course-level { color: var(--main-color); }
.ai-course-card.blue .course-level { color: rgba(255,255,255,0.65); }
.ai-course-card.dark h4 { font-size: 2.2rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; line-height: 1.3; margin-bottom: 1.4rem; }
.ai-course-card.dark p { font-size: 1.4rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.7; }
.ai-course-card.blue h4 { font-size: 2.2rem; font-weight: 700; color: #fff; letter-spacing: -0.04em; line-height: 1.3; margin-bottom: 1.4rem; }
.ai-course-card.blue p { font-size: 1.4rem; color: rgba(255,255,255,0.55); letter-spacing: -0.02em; line-height: 1.7; }

/* ── SECTION 4: 지원 환경 ── */
.ai-tools-header { text-align: center; margin-bottom: 5rem; }
.ai-tools-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 1.4rem; }
.ai-tool-pill { display: inline-flex; align-items: center; height: 5rem; padding: 0 3rem; border-radius: 10rem; background-color: #ffffff; border: 1.5px solid rgba(23, 26, 32, 0.15); font-family: "Jost", sans-serif; font-size: 1.5rem; font-weight: 700; color: var(--color-graphite); letter-spacing: 0.02em; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.02); transition: border-color var(--transition-standard), background-color var(--transition-standard), color var(--transition-standard), box-shadow var(--transition-standard), transform var(--transition-standard); }
.ai-tool-pill:hover { border-color: var(--main-color); background: rgba(62,106,225,0.06); color: var(--main-color); transform: translateY(-2px); box-shadow: 0 6px 14px rgba(62, 106, 225, 0.12); }

/* ── SECTION 5: 교육 진행과정 4단계 ── */
.ai-timeline-wrap { background: #fff; }
.ai-timeline-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; margin-top: 6rem; position: relative; }
.ai-timeline-grid::before { content: ''; position: absolute; top: 4.9rem; left: 12%; right: 12%; height: 2px; background: rgba(62,106,225,0.2); z-index: 0; }
.ai-timeline-card { position: relative; z-index: 1; background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2rem; padding: 4rem 3rem; text-align: center; transition: border-color .45s ease, transform .45s ease, box-shadow .45s ease; }
.ai-timeline-card:hover { border-color: rgba(62,106,225,0.3); transform: translateY(-6px); box-shadow: 0 16px 36px rgba(62,106,225,0.09); }
.ai-timeline-dot { width: 1.8rem; height: 1.8rem; border-radius: 50%; background: #cbd5e1; border: 4px solid #fff; box-shadow: 0 0 0 3px rgba(148,163,184,0.25); margin: 0 auto 2.4rem; position: relative; z-index: 2; transition: background .45s ease, box-shadow .45s ease, transform .35s ease; }
.ai-timeline-step { font-size: 1.2rem; font-weight: 700; color: #94a3b8; letter-spacing: -0.01em; margin-bottom: 1.2rem; display: block; transition: color .45s ease; }
.ai-timeline-card.is-active { border-color: rgba(62,106,225,0.35); box-shadow: 0 16px 36px rgba(62,106,225,0.12); transform: translateY(-4px); }
.ai-timeline-card.is-active .ai-timeline-dot { background: var(--main-color); box-shadow: 0 0 0 3px rgba(62,106,225,0.25); transform: scale(1.15); }
.ai-timeline-card.is-active .ai-timeline-step { color: var(--main-color); }
.ai-timeline-card h3 { font-size: 2.2rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1rem; }
.ai-timeline-card p { font-size: 1.45rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.7; }

/* ── SECTION 6: CTA ── */
.ai-cta-wrap { background: linear-gradient(135deg, #1a2744 0%, #1d4ed8 100%); text-align: center; padding: 14rem 3rem; }
.ai-cta-tit { font-size: 4.2rem; font-weight: 700; color: #fff; letter-spacing: -0.04em; line-height: 1.3; margin-bottom: 2rem; }
.ai-cta-sub { font-size: 1.7rem; color: rgba(255,255,255,0.45); letter-spacing: -0.03em; line-height: 1.7; margin-bottom: 5rem; }
.ai-cta-btn { display: inline-flex; align-items: center; justify-content: center; height: 6.4rem; padding: 0 5rem; background: var(--main-color); color: #fff; font-size: 1.8rem; font-weight: 700; letter-spacing: -0.03em; border-radius: 4px; text-decoration: none; border: none; cursor: pointer; transition: background-color var(--transition-standard), transform var(--transition-standard); }
.ai-cta-btn:hover { background: var(--main-color2); transform: scale(1.02); }
.ai-cta-note { display: block; margin-top: 2.5rem; font-size: 1.3rem; color: rgba(255,255,255,0.25); letter-spacing: -0.02em; }

@media all and (max-width: 1100px) {
    .ai-hero-grid { grid-template-columns: 1fr; gap: 3rem; }
    .ai-hero-arrow { display: none; }
    .ai-process-orbit { display: none; }
    .ai-step-list { display: flex; }
    .ai-target-grid { grid-template-columns: 1fr; }
    .ai-course-grid { grid-template-columns: 1fr; }
    .ai-timeline-grid { grid-template-columns: repeat(2, 1fr); }
    .ai-timeline-grid::before { display: none; }
}
@media all and (max-width: 640px) {
    .ai-section { padding: 7rem 2rem; }
    .ai-tit { font-size: 3rem; }
    .ai-cta-tit { font-size: 3rem; }
    .ai-timeline-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════
   service_overseas
   ════════════════════════════════════ */
/* -- Page styles: service_overseas -- */

/* ── 공통 섹션 ── */
.adm-section { padding: 10rem 3rem; box-sizing: border-box; }
.adm-inner { max-width: 1380px; margin: 0 auto; }
.adm-wrap-ash { background: var(--color-light-ash); }
/* .adm-label — 공통 라벨 스타일은 상단에 통합 정의 */
.adm-tit { font-size: 4rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; line-height: 1.25; margin-bottom: 1.6rem; }
.adm-sub { font-size: 1.6rem; color: var(--color-pewter); letter-spacing: -0.03em; line-height: 1.7; }

/* ── 페이드업 애니메이션 ── */
.fade-up { opacity: 0; transform: translateY(40px); transition: opacity 0.7s ease-out, transform 0.7s ease-out; }
.fade-up.is-visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }

/* ── SECTION 1: 이런 분께 필요해요 ── */
.adm-needs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.8rem; margin-top: 6rem; }
.adm-needs-card { background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2.8rem; padding: 5rem 4rem; text-align: center; transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard); }
.adm-needs-card:hover { border-color: rgba(62,106,225,0.35); transform: translateY(-8px); box-shadow: 0 20px 48px rgba(62,106,225,0.1); }
.adm-needs-card .adm-card-icon { font-size: 4rem; margin-bottom: 2.4rem; display: block; }
.adm-needs-card h4 { font-size: 2rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.4rem; line-height: 1.35; }
.adm-needs-card p { font-size: 1.5rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.75; }

/* ── SECTION 2: 접근 방식 — 타임라인 ── */
.adm-timeline-list { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.6rem; margin-top: 6rem; margin-bottom: 10rem; position: relative; }
.adm-timeline-list::before { content: ''; position: absolute; top: 5.4rem; left: 8%; right: 8%; height: 2px; background: rgba(62,106,225,0.18); z-index: 0; }
.adm-timeline-item { position: relative; z-index: 1; background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2.4rem; padding: 4.5rem 2.5rem 3.5rem; text-align: center; transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard); }
.adm-timeline-item:hover { border-color: rgba(62,106,225,0.3); transform: translateY(-6px); box-shadow: 0 16px 36px rgba(62,106,225,0.09); }
.adm-timeline-dot { width: 1.8rem; height: 1.8rem; border-radius: 50%; background: var(--main-color); border: 4px solid #fff; box-shadow: 0 0 0 3px rgba(62,106,225,0.22); margin: 0 auto 2.4rem; }
.adm-timeline-num { display: block; font-family: "Jost", sans-serif; font-size: 1.2rem; font-weight: 700; color: var(--main-color); letter-spacing: 0.04em; margin-bottom: 1.4rem; }
.adm-timeline-period { display: block; font-size: 1.25rem; font-weight: 600; color: var(--color-silver-fog); letter-spacing: -0.01em; margin-bottom: 0.8rem; }
.adm-timeline-item h4 { font-size: 1.8rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1rem; line-height: 1.3; }
.adm-timeline-item p { font-size: 1.4rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.65; }
.adm-timeline-output { margin-top: 2rem; padding-top: 1.6rem; border-top: 1px solid var(--color-cloud-gray); font-size: 1.25rem; color: var(--main-color); font-weight: 600; letter-spacing: -0.02em; }

/* ── SECTION 2: 탭 메뉴 ── */
.adm-tab-area { margin-top: 4rem; }
.adm-tab-menu { display: flex; gap: 0; margin-bottom: 4rem; border-bottom: 1px solid var(--color-cloud-gray); }
.adm-tab-menu li { padding: 2rem 3rem; font-size: 1.7rem; font-weight: 600; color: var(--color-silver-fog); cursor: pointer; position: relative; transition: color var(--transition-standard); letter-spacing: -0.03em; white-space: nowrap; }
.adm-tab-menu li.active { color: var(--color-carbon-dark); }
.adm-tab-menu li.active::after { content: ''; position: absolute; bottom: -1px; left: 0; width: 100%; height: 2px; background: var(--color-carbon-dark); }
.adm-tab-content { display: none; }
.adm-tab-content.active { display: block; animation: admTabIn 0.4s ease-out forwards; }
@keyframes admTabIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.adm-tab-flex { display: flex; gap: 6rem; align-items: center; }
.adm-tab-left { flex: 1; }
.adm-tab-left h3 { font-size: 3rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.6rem; line-height: 1.3; }
.adm-tab-left p { font-size: 1.6rem; color: var(--color-pewter); letter-spacing: -0.03em; line-height: 1.75; }
.adm-tab-right { flex: 1.2; display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.adm-info-card { background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2rem; padding: 3.5rem 3rem; transition: border-color var(--transition-standard), box-shadow var(--transition-standard); }
.adm-info-card:hover { border-color: rgba(62,106,225,0.3); box-shadow: 0 12px 30px rgba(62,106,225,0.07); }
.adm-info-card h4 { font-size: 1.8rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.2rem; }
.adm-info-card p, .adm-info-card li { font-size: 1.45rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.7; margin-bottom: 0.6rem; }

/* ── SECTION 3: 신뢰 요소 ── */
.adm-trust-layout {
    display: grid;
    grid-template-columns: 38% 1fr;
    grid-template-rows: auto auto;
    gap: 3rem 8rem;
    align-items: start;
}
.adm-trust-left { grid-column: 1; grid-row: 1; }
.adm-winner-list { grid-column: 1; grid-row: 2; }
.adm-trust-right { grid-column: 2; grid-row: 1 / span 2; }
.adm-trust-list { display: flex; flex-direction: column; gap: 2rem; }
.adm-trust-list li { padding: 4rem; background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2rem; box-shadow: 0 4px 16px rgba(0,0,0,0.04); }
.adm-trust-tit { display: block; font-size: 2.4rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.6rem; line-height: 1.35; }
.adm-trust-desc { font-size: 1.5rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.8; margin-bottom: 0.8rem; }
.adm-result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 2rem; margin-top: 1.6rem; }
.adm-result-item { display: flex; align-items: flex-start; gap: 1rem; font-size: 1.45rem; color: var(--color-graphite); letter-spacing: -0.02em; line-height: 1.6; }
.adm-result-item::before { content: ''; flex-shrink: 0; width: 6px; height: 6px; border-radius: 50%; background: var(--main-color); margin-top: 0.8rem; }

/* ── 수상자 학생 일부(예시) — 좌측 하단 ── */
.adm-winner-tit { font-size: 1.7rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.03em; margin: 0 0 1.6rem; }
.adm-winner-list ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.7rem; }
.adm-winner-list li { font-size: 1.35rem; color: var(--color-graphite); letter-spacing: -0.02em; line-height: 1.55; padding-left: 1.4rem; position: relative; }
.adm-winner-list li::before { content: ''; position: absolute; left: 0; top: 0.85rem; width: 5px; height: 5px; border-radius: 50%; background: var(--main-color); }
.adm-winner-list li strong { color: var(--main-color); font-weight: 700; margin-right: 0.4rem; }

/* ── Competitions 이미지 — 섹션 하단 가로 일렬 ── */
.adm-competitions-row { margin-top: 2rem; text-align: center; }
.adm-comp-tit { text-align: center; }
.adm-comp-row { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1rem; align-items: stretch; justify-items: center; max-width: 120rem; margin: 0 auto; }
.adm-comp-row img { display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 2rem; padding: 0.8rem; }

/* ── CTA ── */
.adm-cta-wrap { background: var(--color-carbon-dark); text-align: center; padding: 14rem 3rem; }
.adm-cta-tit { font-size: 4.2rem; font-weight: 700; color: #fff; letter-spacing: -0.04em; line-height: 1.3; margin-bottom: 2rem; }
.adm-cta-sub { font-size: 1.7rem; color: rgba(255,255,255,0.45); letter-spacing: -0.03em; line-height: 1.7; margin-bottom: 5rem; }
.adm-cta-btn { display: inline-flex; align-items: center; justify-content: center; height: 6.4rem; padding: 0 5rem; background: var(--main-color); color: #fff; font-size: 1.8rem; font-weight: 700; letter-spacing: -0.03em; border-radius: 4px; text-decoration: none; transition: background-color var(--transition-standard), transform var(--transition-standard); }
.adm-cta-btn:hover { background: var(--main-color2); transform: scale(1.02); }
.adm-cta-note { display: block; margin-top: 2.5rem; font-size: 1.3rem; color: rgba(255,255,255,0.25); letter-spacing: -0.02em; }

@media all and (max-width: 1100px) {
    .adm-needs-grid { grid-template-columns: 1fr; }
    .adm-timeline-list { grid-template-columns: repeat(2, 1fr); }
    .adm-timeline-list::before { display: none; }
    .adm-trust-layout {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
        gap: 4rem;
    }
    .adm-trust-left { grid-column: 1; grid-row: 1; width: 100%; text-align: center; }
    .adm-trust-right { grid-column: 1; grid-row: 2; }
    .adm-winner-list { grid-column: 1; grid-row: 3; text-align: center; }
    .adm-winner-list ul { display: inline-flex; text-align: left; }
    .adm-tab-flex { flex-direction: column; gap: 3rem; align-items: stretch; }
    .adm-tab-right { grid-template-columns: 1fr; }
    .adm-tab-left { text-align: left; width: 100%; }
    .adm-comp-row { grid-template-columns: repeat(4, 1fr); }
}
@media all and (max-width: 640px) {
    .adm-section { padding: 7rem 2rem; }
    .adm-tit { font-size: 3rem; }
    .adm-cta-tit { font-size: 3rem; }
    .adm-timeline-list { grid-template-columns: 1fr; }
    .adm-result-grid { grid-template-columns: 1fr; }
    .adm-tab-menu { overflow-x: auto; scrollbar-width: none; }
    .adm-tab-menu::-webkit-scrollbar { display: none; }
    .adm-comp-row { grid-template-columns: repeat(2, 1fr); }
}

/* ════════════════════════════════════
   service_proofreading
   ════════════════════════════════════ */
/* -- Page styles: service_proofreading -- */

/* ── 공통 ── */
.prf-section { padding: 10rem 3rem; box-sizing: border-box; }
.prf-inner { max-width: 1380px; margin: 0 auto; }
.prf-wrap-ash { background: var(--color-light-ash); }
/* .prf-label — 공통 라벨 스타일은 상단에 통합 정의 */
.prf-tit { font-size: 4rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; line-height: 1.25; margin-bottom: 1.6rem; }
.prf-sub { font-size: 1.6rem; color: var(--color-pewter); letter-spacing: -0.03em; line-height: 1.7; }

/* ── 페이드업 ── */
.fade-up { opacity: 0; transform: translateY(40px); transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1), transform 0.7s cubic-bezier(0.16, 1, 0.3, 1); }
.fade-up.is-visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }

/* ── SECTION 1: 이런 경우 교정이 필요합니다 ── */
.prf-needs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; margin-top: 5rem; }
.prf-needs-card { background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2rem; padding: 3.6rem 4rem; display: flex; align-items: center; gap: 2rem; transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard); }
.prf-needs-card:hover { border-color: rgba(62,106,225,0.35); transform: translateY(-5px); box-shadow: 0 16px 40px rgba(62,106,225,0.08); }
.prf-needs-dot { flex-shrink: 0; width: 1rem; height: 1rem; border-radius: 50%; background: var(--main-color); }
.prf-needs-card h4 { font-size: 1.8rem; font-weight: 600; color: var(--color-carbon-dark); letter-spacing: -0.04em; line-height: 1.4; }

/* ── SECTION 2: 교정 프로세스 4단계 ── */
.prf-process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; margin-top: 6rem; position: relative; }
.prf-process-grid::before { content: ''; position: absolute; top: 7.3rem; left: 9%; right: 9%; height: 2px; background: rgba(62,106,225,0.18); z-index: 0; }
.prf-process-card { position: relative; z-index: 1; background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2.4rem; padding: 4.5rem 3rem 3.5rem; transition: border-color var(--transition-standard), transform var(--transition-standard), box-shadow var(--transition-standard); }
.prf-process-card:hover { border-color: rgba(62,106,225,0.3); transform: translateY(-6px); box-shadow: 0 16px 36px rgba(62,106,225,0.09); }
.prf-process-num { width: 5.6rem; height: 5.6rem; background: var(--main-color); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: "Jost", sans-serif; font-size: 1.8rem; font-weight: 700; margin: 0 auto 2.8rem; box-shadow: 0 8px 20px rgba(62,106,225,0.3); position: relative; z-index: 2; }
.prf-process-card h4 { font-size: 1.9rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.2rem; text-align: center; line-height: 1.35; }
.prf-process-card p { font-size: 1.45rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.7; text-align: center; }

/* ── SECTION 3: 5가지 교정 원칙 ── */
.prf-principle-row1 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-top: 5rem; }
.prf-principle-row2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; margin-top: 2rem; }
.prf-principle-card { background: #fff; border: 1px solid var(--color-cloud-gray); border-radius: 2.4rem; padding: 4rem 3.5rem; transition: border-color var(--transition-standard), box-shadow var(--transition-standard), transform var(--transition-standard); }
.prf-principle-card:hover { border-color: rgba(62,106,225,0.3); box-shadow: 0 12px 30px rgba(62,106,225,0.07); transform: translateY(-4px); }
.prf-principle-num { display: inline-flex; align-items: center; justify-content: center; width: 4rem; height: 4rem; border-radius: 50%; background: rgba(62,106,225,0.08); color: var(--main-color); font-family: "Jost", sans-serif; font-size: 1.4rem; font-weight: 700; margin-bottom: 2rem; }
.prf-principle-card h4 { font-size: 2rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.2rem; line-height: 1.3; }
.prf-principle-card p { font-size: 1.5rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.75; }

/* ── SECTION 4: 서비스 종류 ── */
.prf-service-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 3rem; margin-top: 6rem; }
.prf-service-card { background: #fff; border: 1px solid #6b7280; border-radius: 3.2rem; padding: 5.5rem 5rem; display: flex; flex-direction: column; position: relative; transition: border-color var(--transition-standard), box-shadow var(--transition-standard), transform var(--transition-standard); }
.prf-service-card:hover { transform: translateY(-6px); box-shadow: 0 24px 56px rgba(62,106,225,0.1); }
.prf-service-card.highlight { border: 2px solid var(--main-color); box-shadow: 0 20px 48px rgba(62,106,225,0.12); }
.prf-service-tag { position: absolute; top: 4.5rem; right: 5rem; background: rgba(62,106,225,0.1); color: var(--main-color); font-size: 1.2rem; font-weight: 700; padding: 0.6rem 1.4rem; border-radius: 10rem; letter-spacing: -0.01em; }
.prf-service-card h3 { font-size: 2.8rem; font-weight: 700; color: var(--color-carbon-dark); letter-spacing: -0.04em; margin-bottom: 1.6rem; }
.prf-service-card > p { font-size: 1.55rem; color: var(--color-pewter); letter-spacing: -0.02em; line-height: 1.7; margin-bottom: 3.5rem; min-height: 5rem; }
.prf-service-list { flex: 1; margin-bottom: 5rem; }
.prf-service-list li { display: flex; align-items: flex-start; gap: 1.2rem; font-size: 1.5rem; color: var(--color-graphite); letter-spacing: -0.02em; line-height: 1.6; margin-bottom: 1.4rem; }
.prf-service-list li::before { content: ''; flex-shrink: 0; width: 6px; height: 6px; border-radius: 50%; background: var(--main-color); margin-top: 0.8rem; }
.prf-service-btn { display: flex; align-items: center; justify-content: center; height: 6rem; border-radius: 4px; font-size: 1.6rem; font-weight: 700; letter-spacing: -0.02em; text-decoration: none; transition: background-color var(--transition-standard), transform var(--transition-standard); }
.prf-service-btn.gray { background: var(--color-light-ash); color: var(--color-graphite); }
.prf-service-btn.gray:hover { background: var(--color-cloud-gray); }
.prf-service-btn.blue { background: var(--main-color); color: #fff; }
.prf-service-btn.blue:hover { background: var(--main-color2); transform: scale(1.01); }

/* ── CTA ── */
.prf-cta-wrap { background: var(--color-carbon-dark); text-align: center; padding: 14rem 3rem; }
.prf-cta-tit { font-size: 4.2rem; font-weight: 700; color: #fff; letter-spacing: -0.04em; line-height: 1.4; margin-bottom: 2rem; }
/* .prf-cta-tit span { color: var(--main-color); } */
.prf-cta-sub { font-size: 1.7rem; color: rgba(255,255,255,0.45); letter-spacing: -0.03em; line-height: 1.7; margin-bottom: 5rem; }
.prf-cta-btn { display: inline-flex; align-items: center; justify-content: center; height: 6.4rem; padding: 0 5rem; background: var(--main-color); color: #fff; font-size: 1.8rem; font-weight: 700; letter-spacing: -0.03em; border-radius: 4px; text-decoration: none; transition: background-color var(--transition-standard), transform var(--transition-standard); }
.prf-cta-btn:hover { background: var(--main-color2); transform: scale(1.02); }
.prf-cta-note { display: block; margin-top: 2.5rem; font-size: 1.3rem; color: rgba(255,255,255,0.25); letter-spacing: -0.02em; }

@media all and (max-width: 1100px) {
    .prf-process-grid { grid-template-columns: repeat(2, 1fr); }
    .prf-process-grid::before { display: none; }
    .prf-service-grid { grid-template-columns: 1fr; }
    .prf-principle-row1 { grid-template-columns: 1fr; }
    .prf-principle-row2 { grid-template-columns: 1fr; }
}
@media all and (max-width: 640px) {
    .prf-section { padding: 7rem 2rem; }
    .prf-tit { font-size: 3rem; }
    .prf-cta-tit { font-size: 3rem; }
    .prf-needs-grid { grid-template-columns: 1fr; }
    .prf-process-grid { grid-template-columns: 1fr; }
    .prf-service-tag { position: static; display: inline-block; margin-bottom: 1.5rem; }
}

/* ════════════════════════════════════
   notice
   ════════════════════════════════════ */
/* ── notice.css ── */
/* notice board */
:root {
    --nb-accent: var(--main-color, #3E6AE1);
    --nb-accent-light: #edf1fd;
    --nb-bg: #f6f7f9;
    --nb-surface: #ffffff;
    --nb-border: #e2e6ef;
    --nb-border-strong: #222222;
    --nb-text-main: #171A20;
    --nb-text-sub: #5a6277;
    --nb-text-muted: #9aa0b2;
    --nb-badge-notice-bg: #1751D9;
    --nb-badge-notice-color: #ffffff;
    --nb-badge-important-bg: #d63333;
    --nb-badge-important-color: #ffffff;
    --nb-badge-info-bg: #2F55C8;
    --nb-badge-info-color: #ffffff;
    --nb-badge-event-bg: #16a34a;
    --nb-badge-event-color: #ffffff;
    --nb-radius: 4px;
    --nb-transition: 0.18s ease;
}

/* ── 공지사항 섹션 ── */
.notice-section {
    padding: 6rem 3rem 10rem;
    background: var(--nb-bg);
    min-height: 60vh;
}
.notice-inner {
    max-width: 900px;
    margin: 0 auto;
}

/* ── 상단 바 ── */
.board-top-bar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 2rem;
    margin-bottom: 2.4rem;
    flex-wrap: wrap;
}
.notice-header h2 {
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--nb-text-main);
    letter-spacing: -0.04em;
    margin-bottom: 2.4rem;
}
.notice-header p {
    font-size: 1.4rem;
    color: var(--nb-text-sub);
    letter-spacing: -0.02em;
}
.notice-header strong {
    color: var(--nb-text-main);
    font-weight: 700;
}
.search-form {
    display: flex;
    align-items: center;
    background: #fff;
    border: 1.5px solid var(--color-border, #e8eaf0);
    border-radius: 8px;
    overflow: visible;
    height: 4.4rem;
    transition: border-color 0.22s ease, box-shadow 0.22s ease;
}
.search-form:focus-within {
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px rgba(62,106,225,0.10);
}
/* 커스텀 드롭다운 */
.search-dropdown {
    position: relative;
    flex-shrink: 0;
    border-right: 1px solid var(--color-border, #e8eaf0);
}
.search-dropdown-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    border: none;
    outline: none;
    background: transparent;
    font-size: 1.3rem;
    color: var(--nb-text-sub, #5a6277);
    padding: 0 1.2rem;
    height: 4.4rem;
    cursor: pointer;
    font-family: inherit;
    letter-spacing: -0.02em;
    white-space: nowrap;
}
.search-dropdown-btn svg { flex-shrink: 0; color: #9aa0b2; transition: transform 0.18s ease; }
.search-dropdown.open .search-dropdown-btn svg { transform: rotate(180deg); }
.search-dropdown-list {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 100%;
    background: #fff;
    border: 1px solid var(--color-border, #e8eaf0);
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.10);
    list-style: none;
    padding: 4px 0;
    z-index: 200;
    overflow: hidden;
}
.search-dropdown.open .search-dropdown-list { display: block; }
.search-dropdown-item {
    padding: 8px 16px;
    font-size: 1.3rem;
    color: var(--nb-text-sub, #5a6277);
    cursor: pointer;
    letter-spacing: -0.02em;
    transition: background 0.15s;
    white-space: nowrap;
}
.search-dropdown-item:hover { background: #f1f5f9; color: var(--nb-text-main, #171A20); }
.search-dropdown-item.active { color: var(--main-color, #3E6AE1); font-weight: 600; background: #eef2fd; }

.search-select {
    display: none;
}
.search-input {
    border: none;
    outline: none;
    background: transparent;
    font-size: 1.3rem;
    color: var(--color-carbon-dark);
    padding: 0 1.2rem;
    font-family: inherit;
    width: 18rem;
    height: 100%;
    letter-spacing: -0.02em;
}
.search-btn {
    border: none;
    background: var(--main-color);
    color: #fff;
    padding: 0 1.6rem;
    cursor: pointer;
    font-size: 1.4rem;
    transition: background 0.22s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    border-radius: 0 6px 6px 0;
}
.search-btn:hover { background: var(--main-color2); }

/* ── 구분선 (상단 두꺼운 선) ── */
.board-divider {
    border: none;
    border-top: 2px solid var(--nb-border-strong);
    margin: 0;
}

/* ── 목록 헤더 행 ── */
.bbs-list-header {
    display: flex;
    align-items: center;
    padding: 0 22px;
    height: 44px;
    background: #f8f9fb;
    border-bottom: 1px solid var(--nb-border);
}
.bbs-list-header .col-no  { width: 80px; text-align: center; flex-shrink: 0; }
.bbs-list-header .col-tit { flex: 1; min-width: 0; padding-left: 12px; }
.bbs-list-header .col-date { width: 110px; text-align: left; flex-shrink: 0; }
.bbs-list-header span {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--nb-text-sub);
    letter-spacing: -0.01em;
}

/* ── 목록 ── */
.bbs-list {
    list-style: none;
    background: var(--nb-surface);
}

/* ── 항목 ── */
.bbs-item {
    display: flex;
    align-items: center;
    gap: 0;
    padding: 0 22px;
    height: 60px;
    border-bottom: 1px solid var(--nb-border);
    cursor: pointer;
    transition: background var(--nb-transition);
    text-decoration: none;
    color: inherit;
    position: relative;
}
.bbs-item:last-child { border-bottom: 1px solid var(--nb-border); }
.bbs-item:hover { background: #f0f4ff; }
.bbs-item:hover .bbs-subject-txt { color: var(--nb-accent); }
.bbs-pinned { background: var(--nb-accent-light); }
.bbs-pinned .bbs-no { display: flex; align-items: center; justify-content: center; }
.bbs-pinned .badge-pc { display: inline-flex; }
.bbs-pinned .badge-mo { display: none; }

/* 번호 컬럼 */
.bbs-no {
    width: 80px;
    text-align: center;
    flex-shrink: 0;
    font-size: 1.3rem;
    color: var(--nb-text-muted);
    font-family: 'Jost', 'Roboto', sans-serif;
    letter-spacing: 0;
}

/* 배지 - 소프트 rounded */
.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.2px;
    padding: 3px 8px;
    border-radius: 5px;
    border: none;
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 0;
    height: 20px;
    line-height: 1;
}
.badge-important {
    background: #fef2f2;
    color: #c02020;
}
.badge-info {
    background: var(--main-color);
    color: #fff;
}
.badge-notice {
    background: #eef2fd;
    color: #1751D9;
}
.badge-event {
    background: #f0fdf4;
    color: #15803d;
}

/* 제목 컬럼 */
.bbs-subject {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 10px;
    padding-left: 12px;
}
.bbs-subject-txt {
    font-size: 1.45rem;
    font-weight: 500;
    color: var(--nb-text-main);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.5;
    letter-spacing: -0.025em;
    transition: color var(--nb-transition);
}

/* 날짜 컬럼 */
.bbs-date {
    width: 110px;
    text-align: left;
    flex-shrink: 0;
    font-size: 1.25rem;
    color: var(--nb-text-muted);
    font-family: 'Jost', 'Roboto', sans-serif;
    white-space: nowrap;
    letter-spacing: 0;
}

/* 화살표 제거 */
.bbs-arrow { display: none; }

/* ── 하단 구분선 ── */
.board-bottom-divider {
    border: none;
    border-top: 1px solid var(--nb-border);
    margin: 0;
}

/* ── 페이지네이션 (공통) ── */
.paging-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-top: 3.6rem;
}
.paging-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.6rem;
    height: 3.6rem;
    border-radius: 0.8rem;
    border: 1.5px solid var(--color-border, #e8eaf0);
    background: #fff;
    color: var(--color-pewter);
    font-size: 1.3rem;
    font-family: "Jost", sans-serif;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.22s cubic-bezier(.4,0,.2,1);
    user-select: none;
    text-decoration: none;
}
.paging-btn:hover {
    border-color: var(--main-color);
    color: var(--main-color);
    background: var(--main-light, #edf1fd);
}
.paging-btn.cur {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
    font-weight: 700;
    box-shadow: 0 2px 8px rgba(62,106,225,0.28);
}
.paging-btn.disabled {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
}

/* ── 반응형 ── */
@media (max-width: 768px) {
    .notice-section { padding: 4rem 1.6rem 7rem; }
    .board-top-bar { flex-direction: column; align-items: stretch; gap: 1.6rem; }
    .search-form { width: 100%; }
    .search-input { flex: 1; width: auto; }
    .bbs-list-header { display: none; }
    .bbs-item {
        height: auto;
        flex-wrap: wrap;
        gap: 6px;
        padding: 14px 16px;
        align-items: center;
    }
    .bbs-no { width: auto; text-align: left; font-size: 1.2rem; order: 3; display: inline-flex; align-items: center; height: 2rem; line-height: 1; font-family: 'Jost', 'Roboto', sans-serif; }
    .bbs-subject { padding-left: 0; order: 1; width: 100%; flex: none; margin-bottom: 4px; }
    .bbs-date { width: auto; text-align: left; order: 2; font-size: 1.2rem; padding-left: 0; display: inline-flex; align-items: center; height: 2rem; line-height: 1; }
    .bbs-subject-txt { font-size: 1.4rem; }
    .bbs-pinned .bbs-no { display: none; }
    .bbs-pinned .badge-pc { display: none; }
    .bbs-pinned .badge-mo { display: inline-flex; }
}

/* ── 게시판 상세 페이지 (공지사항·이용후기 공통) ── */
.board-view-section {
    background: #fff;
    padding: 6rem 3rem 10rem;
}
.board-view-inner {
    max-width: 960px;
    margin: 0 auto;
}
.board-view-head {
    padding-bottom: 2.4rem;
    border-bottom: 2px solid #222;
    margin-bottom: 0;
}
.board-view-head-top {
    margin-bottom: 1.2rem;
}
.board-view-title {
    font-size: 2.4rem;
    font-weight: 700;
    color: #1a1a1a;
    line-height: 1.45;
    letter-spacing: -0.03em;
    word-break: keep-all;
}
.board-view-meta {
    display: flex;
    gap: 2rem;
    margin-top: 1.4rem;
    font-size: 1.35rem;
    color: #888;
}
.board-view-meta .meta-item strong {
    color: #666;
    margin-right: 0.6rem;
    font-weight: 500;
}
.board-view-body {
    padding: 4rem 0;
    min-height: 24rem;
    font-size: 1.5rem;
    line-height: 1.85;
    color: #333;
    word-break: keep-all;
    border-bottom: 1px solid #e2e6ef;
}
.board-view-body img {
    max-width: 100%;
    height: auto;
}
.board-view-links {
    margin-top: 2rem;
    padding: 1.4rem 1.6rem;
    background: #f8f9fb;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.board-view-links a {
    color: #1a6dcc;
    font-size: 1.4rem;
    word-break: break-all;
    text-decoration: none;
}
.board-view-links a:hover {
    text-decoration: underline;
}
.board-view-file {
    padding: 2rem 0;
    border-bottom: 1px solid #e2e6ef;
}
.board-view-file .file-title {
    font-size: 1.4rem;
    font-weight: 600;
    color: #555;
    margin: 0 0 1rem;
}
.board-view-file .file-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.board-view-file .file-item a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: #f5f7fb;
    border: 1px solid #e2e6ef;
    border-radius: 6px;
    text-decoration: none;
    color: #333;
    font-size: 1.4rem;
    transition: background 0.2s, border-color 0.2s;
}
.board-view-file .file-item a:hover {
    background: #eef2fd;
    border-color: #3E6AE1;
    color: #3E6AE1;
}
.board-view-file .file-size {
    color: #9aa0b2;
    font-size: 1.2rem;
}
.board-view-nav {
    border-bottom: 1px solid #e2e6ef;
}
.view-nav-item {
    display: flex;
    align-items: center;
    padding: 1.6rem 0;
    gap: 2rem;
    text-decoration: none;
    color: #333;
    transition: background 0.15s;
    border-bottom: 1px solid #f0f1f5;
}
.view-nav-item:last-child {
    border-bottom: none;
}
.view-nav-item:hover:not(.disabled) {
    background: #f8f9fc;
    padding-left: 1rem;
    padding-right: 1rem;
    margin-left: -1rem;
    margin-right: -1rem;
    border-radius: 0.6rem;
}
.view-nav-item.disabled {
    color: #bbb;
    cursor: default;
}
.nav-label {
    flex-shrink: 0;
    width: 5rem;
    font-size: 1.3rem;
    font-weight: 600;
    color: #666;
}
.view-nav-item.disabled .nav-label {
    color: #bbb;
}
.nav-title {
    font-size: 1.4rem;
    line-height: 1.5;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.board-view-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 4rem;
    gap: 1rem;
}
.board-list-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 12rem;
    height: 4.6rem;
    padding: 0 3rem;
    border: 1.5px solid #d0d4dd;
    border-radius: 0.6rem;
    background: #fff;
    color: #333;
    font-size: 1.4rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.18s;
    cursor: pointer;
}
.board-list-btn:hover {
    background: #f4f6fb;
    border-color: #3e6ae1;
    color: #3e6ae1;
}


/* ── 관리자: 리스트 삭제 컬럼 ── */
.bbs-list-header .col-del { width: 60px; text-align: center; flex-shrink: 0; }
.bbs-del { width: 60px; text-align: center; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.bbs-del-btn {
    border: none; border-radius: 4px; padding: 4px 10px;
    background: transparent; color: #9aa0b2; font-size: 1.2rem; font-weight: 600;
    cursor: pointer; transition: all 0.15s; letter-spacing: -0.02em;
}
.bbs-del-btn:hover { background: #fef2f2; color: #c02020; }

/* ── 관리자: 글쓰기 버튼 ── */
.board-write-wrap { display: flex; justify-content: flex-end; margin-top: 2.4rem; }
.board-write-btn {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 10rem; height: 4.4rem; padding: 0 2.4rem;
    background: var(--main-color); color: #fff; border: none; border-radius: 0.6rem;
    font-size: 1.4rem; font-weight: 600; text-decoration: none;
    transition: background 0.18s; cursor: pointer;
}
.board-write-btn:hover { background: var(--main-color2, #2c54c4); }

/* 수정·삭제 버튼 묶음 */
.board-action-btns {
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* 수정하기 버튼 */
.board-edit-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    height: 4.6rem;
    padding: 0 2.2rem;
    border: 1.5px solid var(--main-color, #3e6ae1);
    border-radius: 0.6rem;
    background: #fff;
    color: var(--main-color, #3e6ae1);
    font-size: 1.4rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.18s;
    font-family: inherit;
    letter-spacing: -0.02em;
}
.board-edit-btn:hover {
    background: var(--main-color, #3e6ae1);
    color: #fff;
}

/* 삭제하기 버튼 */
.board-delete-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    height: 4.6rem;
    padding: 0 2.2rem;
    border: 1.5px solid #e03131;
    border-radius: 0.6rem;
    background: #fff;
    color: #e03131;
    font-size: 1.4rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.18s;
    font-family: inherit;
    letter-spacing: -0.02em;
}
.board-delete-btn:hover {
    background: #e03131;
    color: #fff;
}
.board-delete-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

@media (max-width: 768px) {
    .board-view-section { padding: 3rem 1.6rem 6rem; }
    .board-view-title { font-size: 1.9rem; }
    .board-view-meta { gap: 1.2rem; font-size: 1.2rem; }
    .board-view-body { padding: 2.4rem 0; font-size: 1.4rem; min-height: 16rem; }
    .view-nav-item { gap: 1.2rem; padding: 1.2rem 0; }
    .nav-label { width: 4.4rem; font-size: 1.2rem; }
    .nav-title { font-size: 1.3rem; }
    .board-view-foot { margin-top: 3rem; flex-wrap: wrap; }
    .board-action-btns { gap: 0.8rem; }
    .board-edit-btn, .board-delete-btn { height: 4.2rem; padding: 0 1.6rem; font-size: 1.3rem; }
    .bbs-del { width: auto; order: 5; }
}



/* ════════════════════════════════════
   faq
   ════════════════════════════════════ */
/* ── faq.css ── */

/* ── FAQ 섹션 ── */
.faq-section {
    padding: 7rem 3rem 11rem;
    background: var(--color-light-ash);
    min-height: 70vh;
}
.faq-section-inner {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.faq-main {
    display: flex;
    gap: 5rem;
    align-items: flex-start;
}

/* ── 사이드바 ── */
.faq-sidebar {
    width: 22rem;
    flex-shrink: 0;
    position: sticky;
    top: 9rem;
}
.faq-sidebar-title {
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--main-color);
    font-family: "Jost", sans-serif;
    margin-bottom: 1.6rem;
    padding-left: 0.4rem;
}
.faq-tab-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.faq-tab-item {
    padding: 1.4rem 1.8rem;
    border-radius: 1rem;
    cursor: pointer;
    font-size: 1.45rem;
    font-weight: 500;
    color: var(--color-pewter);
    transition: all 0.22s ease;
    border: 1.5px solid transparent;
    line-height: 1.4;
}
.faq-tab-item:hover {
    background: #fff;
    color: var(--color-graphite);
    border-color: var(--color-cloud-gray);
}
.faq-tab-item.active {
    background: var(--main-color);
    color: #fff;
    font-weight: 700;
    border-color: var(--main-color);
    box-shadow: 0 4px 14px rgba(62,106,225,0.28);
}

/* ── 컨텐츠 영역 ── */
.faq-content {
    flex: 1;
    min-width: 0;
}
.faq-content-head {
    margin-bottom: 3.6rem;
}
.faq-main {
    width: 100%;
}
.faq-content-head h2 {
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 2rem;
}
.faq-content-head p {
    font-size: 1.45rem;
    color: var(--color-pewter);
    line-height: 1.7;
    letter-spacing: -0.02em;
}
.faq-category-label {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.03em;
    margin-bottom: 2.4rem;
}
.faq-category-label::before {
    content: "";
    display: inline-block;
    width: 4px;
    height: 3.2rem;
    background: var(--main-color);
    border-radius: 4px;
    flex-shrink: 0;
}

/* ── 아코디언 ── */
.faq-list {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}
.faq-item {
    border: 1.5px solid #e2e8f0;
    border-radius: 1.2rem;
    background: #fff;
    overflow: hidden;
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.faq-item:hover {
    border-color: #c7d2e8;
    box-shadow: 0 4px 14px rgba(0,0,0,0.05);
}
.faq-item.open {
    border-color: var(--main-color);
    box-shadow: 0 6px 20px rgba(62,106,225,0.12);
}

.faq-question {
    width: 100%;
    text-align: left;
    padding: 2.2rem 2.4rem;
    border: none;
    background: transparent;
    font-size: 1.55rem;
    font-weight: 600;
    color: var(--color-graphite);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1.6rem;
    transition: color 0.22s ease;
    letter-spacing: -0.02em;
    line-height: 1.5;
}
.faq-item.open .faq-question {
    color: var(--main-color);
    padding-bottom: 1.2rem;
}

.faq-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.8rem;
    height: 2.8rem;
    border-radius: 50%;
    background: var(--color-light-ash);
    color: var(--color-silver-fog);
    font-size: 2rem;
    font-weight: 300;
    flex-shrink: 0;
    transition: transform 0.3s ease, background 0.3s ease, color 0.3s ease;
    line-height: 1;
    padding-bottom: 0.15rem;
}
.faq-item.open .faq-icon {
    transform: rotate(45deg);
    background: var(--main-color);
    color: #fff;
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
}
.faq-item.open .faq-answer {
    max-height: 40rem;
}
.faq-answer-inner {
    padding: 0 2.4rem 2.4rem;
    font-size: 1.6rem;
    color: var(--color-carbon-dark);
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: -0.02em;
    border-top: 1px dashed #e2e8f0;
    padding-top: 1.6rem;
    margin: 0 2.4rem;
    margin-bottom: 0;
}

/* ── 반응형 ── */
@media (max-width: 900px) {
    .faq-section { padding: 5rem 2rem 8rem; }
    .faq-main { flex-direction: column; gap: 3rem; }
    .faq-sidebar { width: 100%; box-sizing: border-box; position: static; background: #fff; border-radius: 1.2rem; padding: 2rem; }
    .faq-content-head { margin-bottom: 2.4rem; }
    .faq-tab-list { flex-direction: row; flex-wrap: wrap; gap: 0.8rem; }
    .faq-tab-item { padding: 1rem 1.6rem; font-size: 1.35rem; }
}
@media (max-width: 600px) {
    .faq-content-head h2 { font-size: 2rem; }
    .faq-question { font-size: 1.45rem; padding: 1.8rem 1.8rem; }
    .faq-answer-inner { margin: 0 1.8rem; font-size: 1.5rem; }
}

/* ════════════════════════════════════
   payment
   ════════════════════════════════════ */
/* ── payment.css ── */

/* ── 결제 섹션 ── */
.payment-section {
    padding: 8rem 2rem 12rem;
    background: var(--color-light-ash);
}
.payment-section-inner {
    max-width: 980px;
    margin: 0 auto;
}

/* 헤더 */
.pay-header {
    margin-bottom: 2.8rem;
}
.pay-header h2 {
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    letter-spacing: -0.05em;
    margin-bottom: 1.2rem;
    line-height: 1.25;
}
.pay-header p {
    font-size: 1.55rem;
    color: var(--color-pewter);
    line-height: 1.7;
    letter-spacing: -0.02em;
}

/* 섹션 타이틀 */
.pay-section-title {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.03em;
    margin-bottom: 2rem;
}

/* ── 결제수단 섹션 박스 ── */
.method-section {
    background: #fff;
    border-radius: 1.6rem;
    padding: 3.2rem;
    margin-bottom: 3rem;
    border: 1.5px solid var(--color-cloud-gray);
}

/* ── 결제수단 그리드 ── */
.method-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.4rem;
    margin-bottom: 0;
}
.method-card {
    background: #fff;
    border-radius: 1.4rem;
    padding: 2rem 1.6rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.2rem;
    border: 1.5px solid #e2e8f0;
    transition: border-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
    cursor: default;
}
.method-card-body {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}
.method-card:hover {
    border-color: var(--main-color);
    box-shadow: 0 6px 24px rgba(62,106,225,0.10);
    transform: translateY(-2px);
}
.method-icon {
    width: 4rem;
    height: 4rem;
    border-radius: 1rem;
    background: var(--color-light-ash);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    flex-shrink: 0;
}
.method-card-title {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.03em;
}
.method-card-desc {
    font-size: 1.35rem;
    color: var(--color-pewter);
    line-height: 1.6;
    letter-spacing: -0.02em;
}

/* ── 무이자 배너 ── */
.installment-banner {
    background: linear-gradient(135deg, #1c58ef, #3a7bff);
    border-radius: 2rem;
    padding: 3.6rem 3.2rem;
    margin-bottom: 5rem;
    box-shadow: 0 12px 36px rgba(62,106,225,0.22);
    position: relative;
    overflow: hidden;
}
.installment-banner::before {
    content: '';
    position: absolute;
    right: -4rem;
    top: -4rem;
    width: 20rem;
    height: 20rem;
    border-radius: 50%;
    background: rgba(255,255,255,0.06);
}
.installment-banner::after {
    content: '';
    position: absolute;
    right: 4rem;
    bottom: -6rem;
    width: 16rem;
    height: 16rem;
    border-radius: 50%;
    background: rgba(255,255,255,0.04);
}
.installment-banner-inner { position: relative; z-index: 1; }
.installment-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: rgba(255,255,255,0.18);
    border-radius: 10rem;
    padding: 0.5rem 1.2rem;
    font-size: 1.2rem;
    font-weight: 700;
    color: rgba(255,255,255,0.9);
    letter-spacing: 0.04em;
    margin-bottom: 1.6rem;
    font-family: "Jost", sans-serif;
    text-transform: uppercase;
}
.installment-banner h3 {
    font-size: 2.2rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.04em;
    margin-bottom: 1rem;
    line-height: 1.3;
}
.installment-banner p {
    font-size: 1.45rem;
    color: rgba(255,255,255,0.85);
    line-height: 1.7;
    letter-spacing: -0.02em;
}

/* ── 유의사항 ── */
.notice-box {
    background: #fff;
    border-radius: 1.6rem;
    padding: 3.2rem;
    margin-bottom: 5rem;
    border: 1.5px solid var(--color-cloud-gray);
}
.notice-box-title {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.03em;
    margin-bottom: 1.8rem;
    display: flex;
    align-items: center;
    gap: 0.8rem;
}
.notice-box-title::before {
    display: none;
}
.notice-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
}
.notice-list li {
    position: relative;
    padding-left: 1.6rem;
    font-size: 1.4rem;
    color: #555;
    line-height: 1.6;
    letter-spacing: -0.02em;
}
.notice-list li::before {
    content: '\00B7';
    position: absolute;
    left: 0.2rem;
    top: 0;
    font-size: 1.8rem;
    font-weight: 900;
    color: var(--color-silver-fog);
    line-height: 1.3;
}

/* ── 문의 버튼 ── */
.inquiry-btn-wrap {
    display: flex;
    justify-content: center;
}
.inquiry-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 5.6rem;
    width: 21.6rem;
    box-sizing: border-box;
    background: var(--main-color);
    color: #fff;
    border: 1.5px solid transparent;
    border-radius: 9rem;
    font-size: 1.6rem;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
    letter-spacing: -0.02em;
    font-family: inherit;
    text-decoration: none;
}
.inquiry-btn:hover {
    background: var(--main-color2);
    transform: translateY(-2px);
    color: #fff;
}

/* ── 반응형 ── */
@media (max-width: 768px) {
    .payment-section { padding: 5rem 2rem 8rem; }
    .pay-header h2 { font-size: 2.6rem; }
    .installment-banner { padding: 2.8rem 2.4rem; }
    .installment-banner h3 { font-size: 1.9rem; }
    .notice-box { padding: 2.4rem 2rem; }
    .method-section { padding: 2.4rem; }
    .method-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .method-grid { grid-template-columns: 1fr; gap: 1.2rem; }
    .method-card { flex-direction: row; align-items: flex-start; padding: 2rem; gap: 1.6rem; }
    .method-icon { width: 4.4rem; height: 4.4rem; font-size: 2rem; flex-shrink: 0; }
    .pay-header h2 { font-size: 2.2rem; }
    .inquiry-btn { font-size: 1.55rem; padding: 1.8rem; }
}

/* ════════════════════════════════════
   review
   ════════════════════════════════════ */
/* ── review.css ── */
:root {
    --main-light: #edf1fd;
    --color-border: #e8eaf0;
    --transition-fast: 0.22s cubic-bezier(.4,0,.2,1);
}

/* ── 이용후기 섹션 ── */
.review-section {
    padding: 6rem 2rem 11rem;
    background: var(--color-light-ash);
    min-height: 60vh;
}
.review-inner {
    max-width: 900px;
    margin: 0 auto;
}

/* ── 상단: 헤더 + 탭 ── */
.rv-top {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 2rem;
    margin-bottom: 2.4rem;
    flex-wrap: wrap;
}
.rv-header h2 {
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 0.6rem;
}
.rv-header p {
    font-size: 1.4rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
}
.rv-write-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    background: var(--main-color);
    color: #fff;
    border: none;
    border-radius: 1rem;
    padding: 1.2rem 2rem;
    font-size: 1.4rem;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
    font-family: inherit;
    letter-spacing: -0.02em;
}
.rv-write-btn:hover {
    background: var(--main-color2);
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(62,106,225,0.28);
}

/* 카테고리 탭 pills */
.rv-tabs {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap;
    margin-bottom: 2rem;
}
.rv-tab-btn {
    display: inline-flex;
    align-items: center;
    height: 3.6rem;
    padding: 0 1.6rem;
    border-radius: 10rem;
    border: 1.5px solid var(--color-border);
    background: #fff;
    color: var(--color-pewter);
    font-size: 1.35rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
    font-family: inherit;
    letter-spacing: -0.02em;
}
.rv-tab-btn:hover {
    border-color: var(--main-color);
    color: var(--main-color);
}
.rv-tab-btn.active {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
    box-shadow: 0 3px 10px rgba(62,106,225,0.24);
}

/* ── 구분선 ── */
.rv-divider {
    border: none;
    border-top: 2px solid var(--color-carbon-dark);
    margin: 0;
}

/* ── 리스트 ── */
.rv-list-wrap {
    background: #fff;
    border-radius: 0 0 1.2rem 1.2rem;
    overflow: hidden;
    margin-bottom: 3rem;
}
.rv-list { list-style: none; }
.rv-item {
    display: flex;
    align-items: center;
    gap: 1.4rem;
    padding: 1.8rem 2.2rem;
    border-bottom: 1px solid var(--color-border);
    cursor: pointer;
    transition: background var(--transition-fast);
    text-decoration: none;
    color: inherit;
}
.rv-item:last-child { border-bottom: none; }
.rv-item:hover { background: var(--main-light); }
.rv-item:hover .rv-title { color: var(--main-color); }
.rv-item:hover .rv-arrow {
    transform: translateX(4px);
    color: var(--main-color);
}

.rv-num {
    width: 3.2rem;
    text-align: center;
    font-size: 1.3rem;
    color: var(--color-silver-fog);
    font-family: "Jost", sans-serif;
    font-weight: 500;
    flex-shrink: 0;
}

/* 배지 */
.rv-badge {
    display: inline-flex;
    align-items: center;
    font-size: 1.1rem;
    font-weight: 700;
    padding: 0.3rem 0.9rem;
    border-radius: 2rem;
    white-space: nowrap;
    flex-shrink: 0;
    background: var(--main-light);
    color: var(--main-color);
    border: 1px solid #c7d8f9;
    letter-spacing: 0.01em;
}
.rv-badge.badge-sci    { background: var(--main-light); color: var(--main-color); border-color: #c7d8f9; }
.rv-badge.badge-stat   { background: #f0fdf4; color: #16a34a; border-color: #bbf7d0; }
.rv-badge.badge-edit   { background: #fff8e6; color: #d97706; border-color: #fde68a; }
.rv-badge.badge-thesis { background: var(--main-light); color: var(--main-color); border-color: #c7d8f9; }
.rv-badge.badge-jounal { background: #f5f0ff; color: #7c3aed; border-color: #ddd6fe; }

.rv-subject { flex: 1; min-width: 0; }
.rv-title {
    font-size: 1.45rem;
    font-weight: 500;
    color: var(--color-carbon-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.5;
    letter-spacing: -0.02em;
    transition: color var(--transition-fast);
}
.rv-date {
    font-size: 1.2rem;
    color: var(--color-silver-fog);
    font-family: "Jost", sans-serif;
    white-space: nowrap;
    flex-shrink: 0;
}
.rv-arrow {
    color: var(--color-silver-fog);
    font-size: 1.6rem;
    flex-shrink: 0;
    transition: transform var(--transition-fast), color var(--transition-fast);
    line-height: 1;
}

/* 빈 결과 */
.rv-empty {
    padding: 5rem 2rem;
    text-align: center;
    font-size: 1.4rem;
    color: var(--color-silver-fog);
    letter-spacing: -0.02em;
}

/* ── 하단: 페이지네이션 + 검색 ── */
.rv-bottom {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    margin-top: 3.6rem;
}
.rv-bottom .paging-wrap {
    grid-column: 2;
    display: flex;
    justify-content: center;
    margin-top: 0;
}
.rv-bottom .rv-write-btn {
    grid-column: 3;
    justify-self: end;
}

/* 검색 행 및 상단 액션 */
.rv-top-actions {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    flex-wrap: wrap;
}
.rv-search-form {
    display: flex;
    align-items: center;
    background: #fff;
    border: 1.5px solid var(--color-border);
    border-radius: 10rem;
    overflow: hidden;
    height: 4.4rem;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.rv-search-form:focus-within {
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px rgba(62,106,225,0.10);
}
.rv-search-select {
    border: none;
    outline: none;
    background: transparent;
    font-size: 1.3rem;
    color: var(--color-pewter);
    padding: 0 1rem 0 1.6rem;
    font-family: inherit;
    cursor: pointer;
    border-right: 1px solid var(--color-border);
    min-width: 6.4rem;
    height: 100%;
}
.rv-search-input {
    border: none;
    outline: none;
    background: transparent;
    font-size: 1.3rem;
    color: var(--color-carbon-dark);
    padding: 0 1.2rem;
    font-family: inherit;
    width: 18rem;
    height: 100%;
}
.rv-search-btn {
    border: none;
    background: var(--main-color);
    color: #fff;
    padding: 0 1.6rem;
    cursor: pointer;
    font-size: 1.4rem;
    transition: background var(--transition-fast);
    display: flex;
    align-items: center;
    height: 100%;
}
.rv-search-btn:hover { background: var(--main-color2); }

/* ── 반응형 ── */
@media (max-width: 768px) {
    .review-section { padding: 4rem 1.6rem 8rem; }
    .rv-bottom .paging-wrap button:first-child,
    .rv-bottom .paging-wrap button:last-child { display: none; }
    .rv-top { flex-direction: column; align-items: stretch; gap: 1.6rem; }
    .rv-top-actions { width: 100%; flex-direction: column; align-items: stretch; gap: 1rem; }
    .rv-search-form { width: 100%; height: 4.4rem; }
    .rv-search-input { flex: 1; }
    .rv-write-btn { width: auto; padding: 1rem 1.6rem; justify-content: center; }
}
@media (max-width: 768px) {
    .rv-item {
        flex-wrap: wrap;
        height: auto;
        padding: 1.4rem 1.6rem;
        gap: 4px 8px;
        align-items: center;
    }
    .rv-num { order: 1; width: 3.6rem; text-align: left; font-size: 1.2rem; flex-shrink: 0; }
    .rv-badge { order: 1; }
    .rv-subject { order: 1; flex: 1; min-width: 0; padding-left: 0; overflow: hidden; }
    .rv-date { order: 1; width: auto; font-size: 1.2rem; flex-shrink: 0; }
    .rv-arrow { display: none; }
    .rv-write-btn svg { display: none; }
}

/* ════════════════════════════════════
   review_write (후기 작성 폼)
   ════════════════════════════════════ */
.review-write-section {
    padding: 6rem 2rem 11rem;
    background: var(--color-light-ash);
    min-height: 60vh;
}
.review-write-inner {
    max-width: 760px;
    margin: 0 auto;
}
.review-write-head {
    margin-bottom: 3.2rem;
}
.review-write-head h2 {
    font-size: 2.4rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 0.8rem;
}
.review-write-head p {
    font-size: 1.4rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
}

/* 에러 알림 */
.rw-alert {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.4rem 1.8rem;
    border-radius: 1rem;
    font-size: 1.4rem;
    margin-bottom: 2.4rem;
    letter-spacing: -0.02em;
}
.rw-alert-error {
    background: #fff2f2;
    border: 1.5px solid #fecaca;
    color: #dc2626;
}

/* 폼 카드 */
.rw-form {
    background: #fff;
    border-radius: 1.6rem;
    box-shadow: 0 2px 20px rgba(0,0,0,0.06);
    padding: 3.6rem 3.2rem;
    display: flex;
    flex-direction: column;
    gap: 2.8rem;
}

/* 필드 */
.rw-field {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.rw-label {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.02em;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}
.rw-required {
    display: inline-flex;
    align-items: center;
    height: 2rem;
    padding: 0 0.7rem;
    background: var(--main-color);
    color: #fff;
    font-size: 1.1rem;
    font-weight: 600;
    border-radius: 0.4rem;
    letter-spacing: 0;
}

/* 셀렉트 */
.rw-select-wrap {
    position: relative;
    display: inline-block;
    width: 100%;
    max-width: 320px;
}
.rw-select {
    width: 100%;
    height: 5rem;
    padding: 0 4rem 0 1.6rem;
    border: 1.5px solid var(--color-border, #e8eaf0);
    border-radius: 1rem;
    background: #fff;
    font-size: 1.4rem;
    color: var(--color-carbon-dark);
    font-family: inherit;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    letter-spacing: -0.02em;
}
.rw-select:focus {
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px rgba(62,106,225,0.12);
}
.rw-select-arrow {
    position: absolute;
    right: 1.4rem;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--color-pewter);
}

/* 텍스트 인풋 */
.rw-input {
    width: 100%;
    height: 5rem;
    padding: 1.2rem 1.6rem 1.2rem 1.6rem !important;
    border: 1.5px solid var(--color-border, #e8eaf0);
    border-radius: 1rem;
    font-size: 1.45rem;
    line-height: 1.4;
    font-family: inherit;
    color: var(--color-carbon-dark);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    letter-spacing: -0.02em;
    box-sizing: border-box;
    vertical-align: middle;
}
.rw-input::placeholder { color: #bbb; }
.rw-input:focus {
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px rgba(62,106,225,0.12);
}

/* 텍스트에어리어 */
.rw-textarea {
    width: 100%;
    min-height: 24rem;
    padding: 1.6rem;
    border: 1.5px solid var(--color-border, #e8eaf0);
    border-radius: 1rem;
    font-size: 1.45rem;
    font-family: inherit;
    color: var(--color-carbon-dark);
    line-height: 1.8;
    letter-spacing: -0.02em;
    resize: vertical;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
}
.rw-textarea::placeholder { color: #bbb; }
.rw-textarea:focus {
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px rgba(62,106,225,0.12);
}
.rw-char-count {
    font-size: 1.2rem;
    color: var(--color-silver-fog);
    text-align: right;
    letter-spacing: -0.01em;
}

/* 안내 문구 */
.rw-notice {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    padding: 1.4rem 1.6rem;
    background: #f8f9fc;
    border-radius: 0.8rem;
    font-size: 1.3rem;
    color: var(--color-pewter);
    letter-spacing: -0.02em;
    line-height: 1.6;
}
.rw-notice svg {
    flex-shrink: 0;
    margin-top: 0.2rem;
    color: var(--main-color);
}

/* 버튼 행 */
.rw-btn-row {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 1.2rem;
    padding-top: 0.8rem;
    border-top: 1px solid var(--color-border, #e8eaf0);
}
.rw-btn-cancel {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 4.8rem;
    padding: 0 2.4rem;
    border: 1.5px solid var(--color-border, #e8eaf0);
    border-radius: 1rem;
    background: #fff;
    color: var(--color-pewter);
    font-size: 1.4rem;
    font-weight: 600;
    text-decoration: none;
    transition: border-color 0.2s, color 0.2s;
    letter-spacing: -0.02em;
    font-family: inherit;
}
.rw-btn-cancel:hover {
    border-color: var(--main-color);
    color: var(--main-color);
}
.rw-btn-submit {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    height: 4.8rem;
    padding: 0 2.8rem;
    background: var(--main-color);
    color: #fff;
    border: none;
    border-radius: 1rem;
    font-size: 1.4rem;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: -0.02em;
    transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
    font-family: inherit;
}
.rw-btn-submit:hover {
    background: var(--main-color2);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(62,106,225,0.28);
}
.rw-btn-submit:disabled {
    background: #b0b8d1;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* 반응형 */
@media (max-width: 768px) {
    .review-write-section { padding: 4rem 1.6rem 8rem; }
    .rw-form { padding: 2.4rem 1.8rem; gap: 2.2rem; }
    .rw-select-wrap { max-width: 100%; }
    .rw-btn-row { flex-direction: column-reverse; }
    .rw-btn-cancel, .rw-btn-submit { width: 100%; justify-content: center; }
}

/* ════════════════════════════════════
   media_newsroom
   ════════════════════════════════════ */
/* ── media_newsroom.css ── */

/* ── 뉴스룸 섹션 ── */
.newsroom-section {
    padding: 8rem 3rem 10rem;
    background: var(--color-light-ash);
    min-height: 60vh;
}
.newsroom-inner {
    max-width: 1000px;
    margin: 0 auto;
}

/* ── 필터 탭 ── */
.nr-filter-row {
    display: flex;
    align-items: center;
    gap: 1.6rem;
    margin-bottom: 3.6rem;
    flex-wrap: wrap;
}
.nr-filter-row .search-form {
    margin-left: auto;
}
.nr-tabs {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap;
}
.nr-tab-btn {
    display: inline-flex;
    align-items: center;
    height: 4rem;
    padding: 0 2rem;
    border-radius: 10rem;
    border: 1.5px solid var(--color-cloud-gray);
    background: #fff;
    color: var(--color-pewter);
    font-size: 1.4rem;
    font-weight: 500;
    cursor: pointer;
    letter-spacing: -0.02em;
    transition: all var(--transition-standard);
}
.nr-tab-btn:hover {
    border-color: var(--main-color);
    color: var(--main-color);
}
.nr-tab-btn.active {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
    font-weight: 700;
}

/* ── 검색 ── */
.nr-search-wrap {
    position: relative;
    flex-shrink: 0;
    width: 28rem;
    margin-left: auto;
}
.nr-search-wrap input {
    width: 100%;
    height: 4.4rem;
    padding: 0 1.8rem 0 4.4rem;
    border: 1.5px solid var(--color-cloud-gray);
    border-radius: 1rem;
    background: #fff;
    font-size: 1.4rem;
    color: var(--color-graphite);
    letter-spacing: -0.02em;
    outline: none;
    transition: border-color var(--transition-standard), box-shadow var(--transition-standard);
}
.nr-search-wrap input:focus {
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px rgba(62,106,225,0.1);
}
.nr-search-wrap input::placeholder { color: var(--color-silver-fog); }
.nr-search-icon {
    position: absolute;
    left: 1.4rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-silver-fog);
    pointer-events: none;
    display: flex;
}

/* ── 뉴스 카드 리스트 ── */
.nr-list {
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
}

.nr-card {
    background: #fff;
    border-radius: 1.6rem;
    border: 1.5px solid var(--color-cloud-gray);
    overflow: hidden;
    display: flex;
    cursor: pointer;
    transition: border-color var(--transition-standard), box-shadow var(--transition-standard);
    position: relative;
    height: 18rem;
    align-items: stretch;
}
.nr-card:hover {
    border-color: var(--main-color);
    box-shadow: 0 8px 32px rgba(62,106,225,0.12);
}
.nr-card:hover .nr-card-thumb img {
    transform: scale(1.1);
}

.nr-card-body {
    flex: 1;
    padding: 2.8rem 3.2rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-width: 0;
}
.nr-card-meta {
    display: flex;
    align-items: center;
    gap: 1rem;
}
.nr-badge {
    display: inline-flex;
    align-items: center;
    background: rgba(62,106,225,0.1);
    color: var(--main-color);
    font-size: 1.15rem;
    font-weight: 700;
    padding: 0.3rem 1.1rem;
    border-radius: 10rem;
    letter-spacing: -0.01em;
    white-space: nowrap;
}
.nr-date {
    font-size: 1.3rem;
    color: var(--color-silver-fog);
    font-weight: 400;
    letter-spacing: -0.02em;
}
.nr-card-title {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    line-height: 1.45;
    letter-spacing: -0.04em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color var(--transition-standard);
}
.nr-cat-prefix { color: var(--main-color); font-weight: 800; white-space: nowrap; }
.nr-card:hover .nr-card-title { color: var(--main-color); text-decoration: underline; }
.nr-card:hover .nr-card-summary { text-decoration: underline; }
.nr-card:hover .nr-card-meta time { text-decoration: underline; }
.nr-card-summary {
    font-size: 1.4rem;
    color: var(--color-pewter);
    /* line-height: 1.75; */
    letter-spacing: -0.02em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.nr-card-source {
    font-size: 1.25rem;
    color: var(--color-silver-fog);
    font-weight: 500;
    letter-spacing: -0.01em;
    margin-top: 0.4rem;
}

.nr-card-thumb {
    width: 22rem;
    height: 100%;
    flex-shrink: 0;
    overflow: hidden;
    background: var(--color-carbon-dark);
}
.nr-card-thumb img {
    width: 100%;
    height: 100%;
    object-fit: fill;
    transition: transform 0.45s cubic-bezier(0.25,0.46,0.45,0.94);
    display: block;
}
.nr-card-thumb .nr-thumb-placeholder {
    width: 100%;
    height: 100%;
    min-height: 17rem;
    background: linear-gradient(135deg, var(--color-carbon-dark) 0%, #1e2a4a 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.nr-thumb-placeholder .nr-thumb-logo {
    font-family: "Jost", sans-serif;
    font-size: 2rem;
    font-weight: 800;
    color: var(--main-color);
    letter-spacing: 0.08em;
}
.nr-thumb-placeholder .nr-thumb-sub {
    font-size: 1.2rem;
    color: rgba(255,255,255,0.3);
    letter-spacing: -0.01em;
}

/* ── 페이지네이션 ── */
.nr-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    margin-top: 4.8rem;
}
.nr-page-btn {
    width: 4rem;
    height: 4rem;
    border-radius: 1rem;
    border: 1.5px solid var(--color-cloud-gray);
    background: #fff;
    color: var(--color-pewter);
    font-size: 1.4rem;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: -0.02em;
    transition: all var(--transition-standard);
}
.nr-page-btn:hover {
    border-color: var(--main-color);
    color: var(--main-color);
}
.nr-page-btn.active {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
    font-weight: 700;
}
.nr-page-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
    pointer-events: none;
}

/* ── 검색 결과 없음 ── */
.nr-empty {
    text-align: center;
    padding: 8rem 0;
    color: var(--color-silver-fog);
    font-size: 1.5rem;
    letter-spacing: -0.02em;
}
.nr-empty svg { margin-bottom: 1.6rem; opacity: 0.35; }

/* ── 모달 ── */
.nr-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 99999;
    align-items: center;
    justify-content: center;
    padding: 2.4rem;
    backdrop-filter: blur(6px);
    animation: nrFadeIn 0.2s ease;
}
.nr-modal-overlay.open { display: flex; }
@keyframes nrFadeIn { from { opacity: 0; } to { opacity: 1; } }

.nr-modal {
    background: #fff;
    border-radius: 2.4rem;
    max-width: 720px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 32px 80px rgba(0,0,0,0.22);
    animation: nrSlideUp 0.28s cubic-bezier(0.34,1.3,0.64,1);
    position: relative;
    /* 스크롤바 시각적으로만 숨김 (스크롤 기능은 유지) */
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE/Edge */
}
.nr-modal::-webkit-scrollbar { display: none; } /* Chrome/Safari */
/* 모달 열려있을 때 사이트 헤더 숨김 (모달이 헤더에 가려지는 문제 해결) */
body.nr-modal-open #header,
body.nr-modal-open #headerInnerWrap { display: none !important; }
@keyframes nrSlideUp {
    from { transform: translateY(2.4rem); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}
.nr-modal-hero {
    width: 100%;
    height: 28rem;
    object-fit: contain;
    background: #f4f6fb;
    border-radius: 2.4rem 2.4rem 0 0;
    display: block;
}
.nr-modal-hero-placeholder {
    width: 100%;
    height: 28rem;
    background: linear-gradient(135deg, var(--color-carbon-dark) 0%, #1e2a4a 60%, #0f1f40 100%);
    border-radius: 2.4rem 2.4rem 0 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
}
.nr-modal-hero-placeholder .hero-logo {
    font-family: "Jost", sans-serif;
    font-size: 3.6rem;
    font-weight: 800;
    color: var(--main-color);
    letter-spacing: 0.1em;
}
.nr-modal-hero-placeholder .hero-sub {
    font-size: 1.3rem;
    color: rgba(255,255,255,0.3);
    letter-spacing: 0.02em;
}
.nr-modal-close {
    position: absolute;
    top: 1.6rem;
    right: 1.6rem;
    width: 3.6rem;
    height: 3.6rem;
    border-radius: 50%;
    background: rgba(0,0,0,0.5);
    border: none;
    color: #fff;
    font-size: 1.6rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
    z-index: 10;
}
.nr-modal-close:hover { background: rgba(0,0,0,0.75); }
.nr-modal-body {
    padding: 3.6rem 4rem 4rem;
}
.nr-modal-meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.8rem;
    flex-wrap: wrap;
}
.nr-modal-title {
    font-size: 2.4rem;
    font-weight: 800;
    color: var(--color-carbon-dark);
    line-height: 1.4;
    letter-spacing: -0.05em;
    margin-bottom: 2.4rem;
}
.nr-modal-content {
    font-size: 1.55rem;
    color: var(--color-pewter);
    line-height: 1.85;
    letter-spacing: -0.02em;
    /* 한국어 친화 줄바꿈 + 깨질 만한 긴 토큰(URL, NBSP 등) 대응 */
    word-break: keep-all;
    overflow-wrap: break-word;
}
.nr-modal-content p { margin-bottom: 1.6rem; word-break: keep-all; overflow-wrap: break-word; }
.nr-modal-content p:last-child { margin-bottom: 0; }
.nr-modal-footer {
    padding: 1.6rem 4rem 2.8rem;
    border-top: 1px solid var(--color-cloud-gray);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
    font-size: 1.3rem;
    color: var(--color-silver-fog);
    letter-spacing: -0.02em;
}
.nr-modal-source-label { font-weight: 600; }

/* ── 반응형 ── */
@media (max-width: 768px) {
    .newsroom-section { padding: 5rem 2rem 7rem; }
    .nr-filter-row { flex-direction: column; align-items: flex-start; }
    .nr-search-wrap { width: 100%; }
    .nr-card { flex-direction: row-reverse; height: 13.5rem; align-items: stretch; border-radius: 1.2rem; }
    .nr-card-thumb { width: 13.5rem; height: 100%; flex-shrink: 0; align-self: stretch; }
    .nr-card-thumb img { object-fit: fill; }
    .nr-card-thumb .nr-thumb-placeholder { min-height: 0; gap: 0.4rem; }
    .nr-thumb-placeholder .nr-thumb-logo { font-size: 1.4rem; }
    .nr-thumb-placeholder .nr-thumb-sub { font-size: 0.95rem; }
    .nr-card-body { padding: 1.4rem 1.6rem 3.2rem 1.8rem; gap: 0.4rem; position: relative; }
    .nr-card-meta { gap: 0.6rem; }
    .nr-card-meta .nr-badge { display: none; }
    .nr-card-meta .nr-date {
        position: absolute;
        right: 1.6rem;
        bottom: 1.2rem;
        font-size: 1.1rem;
        color: var(--color-silver-fog);
    }
    .nr-cat-prefix { display: block; margin-bottom: 0.2rem; }
    .nr-card-title { font-size: 1.5rem; line-height: 1.4; -webkit-line-clamp: 3; line-clamp: 3; }
    .nr-card-summary { display: none; }
    .nr-card-source {
        position: absolute;
        left: 1.8rem;
        bottom: 1.2rem;
        font-size: 1.1rem;
        margin-top: 0;
    }
    .nr-modal-body { padding: 2.4rem 2.4rem 3rem; }
    .nr-modal-footer { padding: 1.2rem 2.4rem 2rem; }
    .nr-modal-title { font-size: 1.9rem; }
    .nr-modal-hero, .nr-modal-hero-placeholder { height: 20rem; }
}
@media (max-width: 480px) {
    .nr-card { height: 12rem; }
    .nr-card-thumb { width: 12rem; }
    .nr-card-body { padding: 1.2rem 1.4rem 2.8rem 1.6rem; }
    .nr-card-title { font-size: 1.6rem; }
    .nr-card-source { left: 1.6rem; }
    .nr-card-meta .nr-date { right: 1.4rem; }
    .nr-tabs { gap: 0.6rem; }
    .nr-tab-btn { font-size: 1.3rem; padding: 0 1.4rem; height: 3.6rem; }
}

/* ════════════════════════════════════
   media_video
   ════════════════════════════════════ */
/* ── media_video.css ── */
:root {
    --transition-std:   0.33s cubic-bezier(0.5,0,0,0.75);
    --transition-hover: 0.28s cubic-bezier(0.4,0,0.2,1);
    --shadow-card:      0 2px 16px rgba(62,106,225,.07);
    --shadow-hover:     0 12px 40px rgba(62,106,225,.18);
    --radius-card:      1.4rem;
}

/* ── 공통 레이아웃 ── */
.mv-section {
    padding: 8rem 3rem;
}
.mv-section.bg-ash { background: var(--color-light-ash); }
.mv-section.bg-white { background: #fff; }
.mv-inner {
    max-width: 1280px;
    margin: 0 auto;
}

/* ── 섹션 헤더 ── */
.mv-section-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 4rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--color-cloud-gray);
}
.mv-eyebrow {
    font-family: "Jost", sans-serif;
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--main-color);
    margin-bottom: 0.8rem;
}
.mv-section-title {
    font-size: 3rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.mv-month-tag {
    font-family: "Jost", sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: .1em;
    background: var(--main-color);
    color: #fff;
    padding: 0.3rem 1rem;
    border-radius: 0.4rem;
}
.mv-more-link {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-family: "Jost", sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--main-color);
    text-decoration: none;
    border-bottom: 1.5px solid var(--main-color);
    padding-bottom: 0.2rem;
    white-space: nowrap;
    transition: var(--transition-hover);
}
.mv-more-link:hover { color: var(--main-color2); border-color: var(--main-color2); }
.mv-more-link svg { transition: transform var(--transition-hover); }
.mv-more-link:hover svg { transform: translateX(4px); }
.strength-heading-row .mv-more-link { margin-bottom: 2.4rem; }

/* ── 헤드라인 카드 ── */
.headline-card {
    display: flex;
    background: #fff;
    border: 1.5px solid var(--color-cloud-gray);
    border-radius: var(--radius-card);
    overflow: hidden;
    cursor: pointer;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-hover), border-color var(--transition-hover);
    margin-bottom: 4rem;
}
.headline-card:hover {
    box-shadow: var(--shadow-hover);
    border-color: var(--main-color);
}
.headline-thumb {
    flex: 0 0 48rem;
    position: relative;
    overflow: hidden;
    background: var(--color-carbon-dark);
}
.headline-thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .5s cubic-bezier(.25,.46,.45,.94);
}
.headline-card:hover .headline-thumb img { transform: scale(1.06); }

/* 호버 오버레이 + 재생 버튼 */
.mv-overlay {
    position: absolute;
    inset: 0;
    background: rgba(62,106,225,0);
    transition: background var(--transition-hover);
    display: flex;
    align-items: center;
    justify-content: center;
}
.headline-card:hover .mv-overlay,
.mv-card:hover .mv-overlay {
    background: rgba(62,106,225,.42);
}
.mv-play {
    width: 5.6rem; height: 5.6rem;
    background: rgba(255,255,255,.96);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(.72);
    transition: opacity var(--transition-hover), transform var(--transition-hover);
    box-shadow: 0 4px 20px rgba(0,0,0,.25);
}
.mv-play svg { fill: var(--main-color); margin-left: 0.4rem; }
.headline-card:hover .mv-play,
.mv-card:hover .mv-play { opacity: 1; transform: scale(1); }

.headline-info {
    flex: 1;
    padding: 4rem 4rem 3.6rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.mv-pill {
    display: inline-flex;
    align-items: center;
    font-family: "Jost", sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 0.55rem 1.3rem;
    border-radius: 10rem;
    color: #fff;
    margin-bottom: 1.8rem;
    width: fit-content;
}
.pill-blue   { background: var(--main-color); }
.pill-cyan   { background: #0891b2; }
.pill-violet { background: #7c3aed; }
.pill-green  { background: #059669; }
.pill-red    { background: #dc2626; }

.headline-title {
    font-size: 2.6rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    line-height: 1.4;
    letter-spacing: -0.04em;
    margin-top: 1.6rem;
    transition: color var(--transition-hover);
}
.headline-card:hover .headline-title { color: var(--main-color); }
.headline-desc {
    font-size: 1.5rem;
    color: var(--color-pewter);
    line-height: 1.75;
    letter-spacing: -0.02em;
    margin-bottom: 3rem;
}
.headline-foot {
    margin-top: 2.4rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.mv-date {
    font-family: "Jost", sans-serif;
    font-size: 1.25rem;
    color: var(--color-silver-fog);
    letter-spacing: .03em;
}
.arrow-circle {
    width: 3.6rem; height: 3.6rem;
    border: 1.5px solid var(--color-pale-silver);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-pewter);
    transition: var(--transition-hover);
}
.headline-card:hover .arrow-circle {
    background: var(--main-color);
    border-color: var(--main-color);
    color: #fff;
}

/* ── 슬라이더 ── */
.sl-outer { position: relative; }
.sl-viewport { overflow: hidden; }
.sl-track {
    display: flex;
    gap: 2rem;
    transition: transform .42s cubic-bezier(.4,0,.2,1);
    will-change: transform;
}
.sl-arrow {
    position: absolute;
    top: 50%; transform: translateY(calc(-50% - 2rem));
    width: 4rem; height: 4rem;
    background: #fff;
    border: 1.5px solid var(--color-cloud-gray);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    color: var(--main-color);
    box-shadow: 0 2px 10px rgba(0,0,0,.1);
    transition: var(--transition-hover);
}
.sl-arrow:hover { background: var(--main-color); border-color: var(--main-color); color: #fff; }
.sl-arrow.prev { left: -2.2rem; }
.sl-arrow.next { right: -2.2rem; }
.sl-arrow:disabled { opacity: .3; pointer-events: none; }
.sl-dots {
    display: flex;
    justify-content: center;
    gap: 0.6rem;
    margin-top: 2.4rem;
}
.sl-dot {
    height: 0.4rem;
    width: 1.6rem;
    background: var(--color-cloud-gray);
    border-radius: 0.2rem;
    cursor: pointer;
    transition: var(--transition-hover);
}
.sl-dot.on { width: 3.2rem; background: var(--main-color); }

/* ── 비디오 카드 (슬라이더용) ── */
.mv-card {
    flex: 0 0 calc(33.333% - 1.4rem);
    background: #fff;
    border: 1.5px solid var(--color-cloud-gray);
    border-radius: var(--radius-card);
    overflow: hidden;
    cursor: pointer;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-hover), border-color var(--transition-hover), transform var(--transition-hover);
}
.mv-card:hover {
    box-shadow: var(--shadow-hover);
    border-color: rgba(62,106,225,.5);
    transform: translateY(-0.4rem);
}
.mv-thumb {
    position: relative;
    aspect-ratio: 16/9;
    background: var(--color-carbon-dark);
    overflow: hidden;
}
.mv-thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .5s cubic-bezier(.25,.46,.45,.94);
}
.mv-card:hover .mv-thumb img { transform: scale(1.07); }
.mv-play-sm {
    width: 4.4rem; height: 4.4rem;
    background: rgba(255,255,255,.96);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(.72);
    transition: opacity var(--transition-hover), transform var(--transition-hover);
    box-shadow: 0 4px 16px rgba(0,0,0,.2);
}
.mv-play-sm svg { fill: var(--main-color); margin-left: 0.3rem; }
.mv-card:hover .mv-play-sm { opacity: 1; transform: scale(1); }

.mv-card-body {
    padding: 1.8rem 2rem 2rem;
}
.mv-cat-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.7rem;
}
.mv-cat {
    font-family: "Jost", sans-serif;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: .04em;
    color: var(--main-color);
    background: var(--main-color-lt, #EBF1FD);
    padding: 0.45rem 1.1rem;
    border-radius: 10rem;
    display: inline-block;
}
.mv-title-row {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
}
.mv-card-title {
    flex: 1;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.5;
    color: var(--color-carbon-dark);
    letter-spacing: -0.03em;
    word-break: keep-all;
    overflow-wrap: break-word;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 0;
    transition: color var(--transition-hover);
}
.mv-card:hover .mv-card-title { color: var(--main-color); }
.mv-card-arrow {
    flex-shrink: 0;
    font-size: 1.5rem;
    color: var(--color-silver-fog);
    padding-top: 0.15rem;
    transition: var(--transition-hover);
}
.mv-card:hover .mv-card-arrow { color: var(--main-color); transform: translateX(3px); }

/* ── 전체 영상 그리드 ── */
.mv-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.4rem;
}
.mv-grid-card {
    background: #fff;
    border: 1.5px solid var(--color-cloud-gray);
    border-radius: var(--radius-card);
    overflow: hidden;
    cursor: pointer;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-hover), border-color var(--transition-hover), transform var(--transition-hover);
}
.mv-grid-card:hover {
    box-shadow: var(--shadow-hover);
    border-color: rgba(62,106,225,.5);
    transform: translateY(-0.4rem);
}
.mv-grid-card .mv-thumb { aspect-ratio: 16/9; }
.mv-grid-card:hover .mv-play-sm { opacity: 1; transform: scale(1); }
.mv-grid-card:hover .mv-thumb img { transform: scale(1.07); }
.mv-grid-card:hover .mv-card-title { color: var(--main-color); }
.mv-grid-card:hover .mv-card-arrow { color: var(--main-color); transform: translateX(3px); }
.mv-grid-card .mv-overlay { position: absolute; inset: 0; background: rgba(62,106,225,0); transition: background var(--transition-hover); display: flex; align-items: center; justify-content: center; }
.mv-grid-card:hover .mv-overlay { background: rgba(62,106,225,.42); }
.mv-hidden { display: none; }

/* 섹션 구분선 */
.mv-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-cloud-gray) 20%, var(--color-cloud-gray) 80%, transparent);
}

/* ── 버튼 영역 ── */
.mv-btn-area {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    margin-top: 4.8rem;
    flex-wrap: wrap;
}
.mv-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    height: 5.6rem;
    width: 21.6rem;
    padding: 0;
    box-sizing: border-box;
    border: 1.5px solid transparent;
    border-radius: 9rem;
    background: var(--main-color);
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: #fff;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition-hover), transform 0.2s;
}
.mv-btn-outline:hover {
    background: var(--main-color2);
    transform: translateY(-2px);
}
.mv-btn-outline.mv-btn-cta {
    width: auto;
    min-width: 24rem;
    height: auto;
    padding: 1.2rem 2.6rem;
    flex-direction: column;
    gap: 0.2rem;
    line-height: 1.3;
}
.mv-btn-cta .mv-cta-sub { font-size: 1.2rem; font-weight: 500; opacity: 0.85; letter-spacing: 0; }
.mv-btn-cta .mv-cta-main { display: inline-flex; align-items: center; gap: 0.6rem; font-size: 1.6rem; font-weight: 800; }
.mv-btn-youtube {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1.4rem 3rem;
    background: #ff0000;
    border: 1.5px solid #ff0000;
    border-radius: 0.8rem;
    font-family: "Jost", sans-serif;
    font-size: 1.35rem;
    font-weight: 600;
    letter-spacing: .04em;
    color: #fff;
    text-decoration: none;
    transition: var(--transition-hover);
}
.mv-btn-youtube:hover { background: #cc0000; border-color: #cc0000; transform: translateY(-1px); }

/* ── 모달 ── */
.mv-modal-bg {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.78);
    z-index: 2000;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(8px);
}
.mv-modal-bg.open { display: flex; }
.mv-modal-box {
    position: relative;
    width: min(800px, 94vw);
    background: #000;
    border-radius: 2rem;
    overflow: hidden;
    animation: mvIn .25s cubic-bezier(.34,1.3,.64,1);
    box-shadow: 0 32px 80px rgba(0,0,0,.6);
}
@keyframes mvIn {
    from { transform: scale(.88) translateY(1.4rem); opacity: 0; }
    to   { transform: scale(1)   translateY(0);      opacity: 1; }
}
.mv-modal-box iframe {
    display: block;
    width: 100%;
    aspect-ratio: 16/9;
    border: none;
}
.mv-modal-close {
    position: absolute;
    top: -4.8rem; right: 0;
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 50%;
    width: 3.6rem; height: 3.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.7rem;
    cursor: pointer;
    transition: background .2s;
    line-height: 1;
}
.mv-modal-close:hover { background: rgba(255,255,255,.3); }

/* ── 반응형 ── */
@media (max-width: 900px) {
    .headline-card { flex-direction: column; }
    .headline-thumb { flex: 0 0 24rem; }
    .mv-card { flex: 0 0 calc(50% - 1rem); }
    .mv-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
    .mv-section { padding: 5rem 2rem; }
    .mv-section-head { flex-direction: column; align-items: center; gap: 1.6rem; text-align: center; }
    .mv-section-head > div { text-align: center; }
    .mv-section-title { justify-content: center; }
}
@media (max-width: 560px) {
    .mv-card { flex: 0 0 100%; }
    .mv-grid { grid-template-columns: 1fr; }
    .headline-info { padding: 2.4rem 2rem; }
    .headline-title { font-size: 1.8rem; }
    .mv-btn-area { flex-direction: column; align-items: center; text-align: center; }
}

/* ════════════════════════════════════
   sample_thesis
   ════════════════════════════════════ */
/* ── sample_thesis.css ── */
:root {
    --main-color-lt: #EBF1FD;
    --color-border: #E2E8F0;
}

/* ── 샘플 페이지 메인 ── */
.sample-section {
    padding: 8rem 3rem;
    background: var(--color-light-ash);
    box-sizing: border-box;
}
.sample-section-inner {
    max-width: 1380px;
    margin: 0 auto;
}

/* ── 사이드바 레이아웃 ── */
.sample-layout {
    display: grid;
    grid-template-columns: 270px 1fr;
    gap: 5rem;
    align-items: start;
}
.sample-sidebar-sticky {
    position: sticky;
    top: 12rem;
    align-self: flex-start;
    max-height: calc(100vh - 14rem);
    overflow-y: auto;
    padding-top: 5.29rem;
}
.sample-sidebar-nav {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 1.6rem;
    box-shadow: 0 2px 8px rgba(23,26,32,0.06);
    padding: 2rem 1.2rem 1.6rem;
}
.sample-sidebar-head {
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--main-color);
    font-family: "Jost", sans-serif;
    margin-bottom: 1.4rem;
    padding: 0 0.4rem;
}
.sidebar-acc-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.3rem 1.4rem;
    background: transparent;
    border: none;
    border-radius: 0.8rem;
    cursor: pointer;
    font-size: 1.4rem;
    font-weight: 500;
    color: var(--color-pewter);
    text-align: left;
    gap: 0.8rem;
    transition: all 0.22s ease;
}
.sidebar-acc-btn { margin-bottom: 0.4rem; box-sizing: border-box; }
.sidebar-acc-btn:hover { background: var(--color-light-ash); color: var(--color-graphite); }
.sidebar-acc-btn.active { color: #fff; background: var(--main-color); font-weight: 700; box-shadow: none; }
.sidebar-acc-btn .arr {
    font-size: 1.7rem;
    color: #475569;
    font-weight: 800;
    transition: transform 0.18s;
    flex-shrink: 0;
    line-height: 1;
}
.sidebar-acc-btn.active .arr { color: #fff; }
.sidebar-acc-btn.open .arr { transform: rotate(180deg); }

.sidebar-sub {
    background: transparent;
    display: none;
    padding: 0.3rem 0 0.4rem;
}
.sidebar-sub.open { display: block; }
.sidebar-sub a {
    display: block;
    padding: 1rem 1.4rem 1rem 2.6rem;
    font-size: 1.35rem;
    color: var(--color-pewter);
    text-decoration: none;
    border-radius: 0.8rem;
    transition: all 0.18s ease;
    letter-spacing: -0.02em;
}
.sidebar-sub a:hover { color: var(--color-graphite); background: var(--color-light-ash); }
.sidebar-sub a.active {
    background: var(--main-color-lt);
    color: var(--main-color);
    font-weight: 700;
}

/* ── 콘텐츠 영역 ── */
.sample-content-tit {
    font-size: 2.4rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.04em;
    margin-bottom: 2.8rem;
}
.sample-content-sub {
    font-size: 1.4rem;
    color: var(--color-pewter);
    margin-bottom: 2.8rem;
    letter-spacing: -0.02em;
}

/* ── 샘플 패널 전환 ── */
.sample-panel { display: none; }
.sample-panel.active { display: block; }

/* ── 샘플 이미지 리스트 ── */
.sample-img-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
    align-items: start;
}
/* 기본: 전체폭 (한 줄 차지) */
.sample-img-item { grid-column: span 2; }
/* 관리자가 절반폭 설정한 항목: 한 칸만 차지 → 두 개가 같은 줄에 들어감 */
.sample-img-item.is-half { grid-column: span 1; }
/* 짝이 안 맞아 외톨이가 된 마지막 절반폭 항목:
   컨테이너는 전체폭(다른 카드들과 통일감) 유지, 이미지만 절반폭으로 중앙 정렬 */
.sample-img-item.is-half.is-half-centered {
    grid-column: 1 / -1;
}
.sample-img-item.is-half.is-half-centered img {
    width: calc(50% - 1.5rem - 8rem);
    margin: 4rem auto;
}
.sample-img-item {
    border: 1px solid var(--color-border);
    border-radius: 1.4rem;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 1px 4px rgba(23,26,32,0.05);
}
.sample-img-label {
    padding: 1.8rem 2.4rem;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--color-carbon-dark);
    letter-spacing: -0.02em;
    border-bottom: 1px solid var(--color-border);
}
.sample-img-item img {
    display: block;
    width: calc(100% - 8rem);
    height: auto;
    margin: 4rem auto;
}

/* ── 반응형 ── */
@media (max-width: 960px) {
    .sample-layout {
        grid-template-columns: 1fr;
    }
    .sample-sidebar-sticky { position: static; padding-top: 0; }
}
@media (max-width: 640px) {
    .sample-section { padding: 5rem 2rem; }
    .sample-img-list { grid-template-columns: 1fr; gap: 2rem; }
    .sample-img-item, .sample-img-item.is-half { grid-column: span 1; }
    .sample-img-item img { width: calc(100% - 4rem); margin: 2.6rem auto; }
    .sample-img-label { padding: 1.4rem 1.6rem; font-size: 1.45rem; }
}

/* ════════════════════════════════════
   tips_thesis
   ════════════════════════════════════ */
/* ── tips_thesis.css ── */
:root {
    --main-color-lt: #EBF1FD;
    --color-border: #E2E8F0;
}

/* ── 팁 콘텐츠 영역 ── */
.tips-page-bg {
    background: #ffffff;
}
.tips-wrap {
    font-family: 'Hanken Grotesk', sans-serif;
    -webkit-font-smoothing: antialiased;
    display: flex;
    min-height: 100vh;
    max-width: 1280px;
    margin: 0 auto;
}

/* 사이드바 */
.tips-sidebar {
    width: 290px;
    flex-shrink: 0;
    border-right: 1px solid #E2E8F0;
    display: flex;
    flex-direction: column;
    padding: 32px 20px;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
    background: #ffffff;
    box-sizing: border-box;
}
/* 사이드바 내 카테고리 nav 박스 */
.tips-sidebar-nav {
    margin-top: 0;
}
.tips-sidebar::-webkit-scrollbar { width: 4px; }
.tips-sidebar::-webkit-scrollbar-track { background: transparent; }
.tips-sidebar::-webkit-scrollbar-thumb { background: #e4e2e1; border-radius: 10px; }

.tips-sidebar-brand {
    margin-bottom: 48px;
}
.tips-sidebar-brand h1 {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 22px;
    font-weight: 800;
    color: #3E6AE1;
    letter-spacing: -0.02em;
    margin: 0 0 4px 0;
    line-height: 1.2;
}
.tips-sidebar-brand p {
    font-size: 11px;
    color: #585f68;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin: 0;
}
.tips-cat-title {
    color: #1b1c1c;
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 24px 0;
    padding: 0 16px;
}
.tips-cat-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.tips-cat-list li a {
    display: block;
    padding: 6px 16px;
    color: #434656;
    text-decoration: none;
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 15px;
    line-height: 1.6;
    border-radius: 6px;
    transition: color 0.2s, background 0.2s;
    border-left: 2px solid transparent;
}
.tips-cat-list li a:hover {
    color: #3E6AE1;
}
.tips-cat-list li a.active {
    color: #3E6AE1;
    font-weight: 700;
    border-left-color: #3E6AE1;
}

/* 메인 */
.tips-main {
    flex: 1;
    min-width: 0;
}
.tips-main-inner {
    max-width: 860px;
    margin: 0 auto;
    padding: 32px 24px;
}

/* 글 목록 */
.tips-list-section {
    background: #ffffff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 48px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.tips-list-header {
    background: #ffffff;
    padding: 14px 24px;
    border-bottom: 1px solid #E2E8F0;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.tips-list-header-title {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 17px;
    font-weight: 600;
    color: #1b1c1c;
    margin: 0;
}
.tips-list-header-title span {
    color: #3E6AE1;
    font-size: 15px;
    font-weight: 400;
}
.tips-list-header-btn {
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    color: #585f68;
    font-family: 'Hanken Grotesk', sans-serif;
    transition: color 0.2s;
    letter-spacing: 0.01em;
    padding: 0;
}
.tips-list-header-btn:hover { color: #3E6AE1; }

.tips-list-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 11px 24px;
    border-top: 1px solid #E2E8F0;
    text-decoration: none;
    transition: background 0.15s;
    gap: 16px;
}
.tips-list-item:first-child { border-top: none; }
.tips-list-item:hover { background: #f8fafc; }
.tips-list-item.current {
    background: rgba(62,106,225,0.05);
}
.tips-list-item.current:hover { background: rgba(62,106,225,0.08); }
.tips-list-item-left {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}
.tips-list-item-text {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 15px;
    line-height: 1.6;
    color: #434656;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 400px;
}
.tips-list-item-text.current-text {
    color: #3E6AE1;
    font-weight: 700;
}
.tips-list-item-date {
    font-size: 12px;
    font-weight: 600;
    color: #585f68;
    white-space: nowrap;
    letter-spacing: 0.01em;
    flex-shrink: 0;
}

/* Material icon helper */
.mso {
    font-family: 'Material Symbols Outlined';
    font-style: normal;
    font-weight: normal;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

/* 아티클 */
.tips-article {
    background: #ffffff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.tips-article-header {
    padding: 32px 48px;
    border-bottom: 1px solid #E2E8F0;
    background: #ffffff;
}
.tips-article-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
}
.tips-article-cat {
    font-family: 'Hanken Grotesk', sans-serif;
    color: #3E6AE1;
    font-weight: 700;
    font-size: 2rem;
    letter-spacing: 0.01em;
}
.tips-article-cat-sep { color: #c3c5d9; }
.tips-article-cat-sub {
    color: #585f68;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.01em;
    font-family: 'Hanken Grotesk', sans-serif;
}
.tips-article-title {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 36px;
    font-weight: 800;
    color: #1b1c1c;
    margin: 0 0 28px 0;
    line-height: 1.3;
    letter-spacing: -0.02em;
}
.tips-article-info-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}
.tips-article-info-left {
    display: flex;
    align-items: center;
    gap: 16px;
    color: #585f68;
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.01em;
}
.tips-article-info-item {
    display: flex;
    align-items: center;
    gap: 6px;
}
.tips-article-info-right {
    display: flex;
    align-items: center;
    gap: 8px;
}
.tips-icon-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #585f68;
    background: none;
    border: none;
    cursor: pointer;
    transition: color 0.2s;
    border-radius: 50%;
}
.tips-icon-btn:hover { color: #3E6AE1; background: #EBF1FD; }

/* 아티클 본문 */
.tips-article-body {
    padding: 32px 48px;
}
.tips-article-feature-img {
    margin-bottom: 40px;
    border-radius: 8px;
    overflow: hidden;
    aspect-ratio: 16/9;
}
.tips-article-feature-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.tips-article-intro {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 17px;
    line-height: 1.8;
    color: #434656;
    margin-bottom: 40px;
}
.tips-article-intro strong { color: #3E6AE1; font-weight: 700; }

.tips-article-section { margin-bottom: 32px; }
.tips-article-h2 {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 22px;
    font-weight: 600;
    line-height: 1.4;
    color: #1b1c1c;
    margin: 40px 0 14px 0;
}
.tips-article-p {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 15px;
    line-height: 1.9;
    color: #434656;
    margin: 0 0 14px 0;
}

/* 어드바이스 박스 */
.tips-advice-box {
    margin: 40px 0;
    padding: 28px 32px;
    background: #ffffff;
    border: 1px solid #E2E8F0;
    border-radius: 0 12px 12px 0;
    position: relative;
    overflow: hidden;
}
.tips-advice-box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 5px;
    height: 100%;
    background: #3E6AE1;
}
.tips-advice-title-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
    color: #3E6AE1;
}
.tips-advice-title {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
    color: #3E6AE1;
}
.tips-advice-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.tips-advice-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 15px;
    line-height: 1.7;
    color: #434656;
}
.tips-advice-num {
    color: #3E6AE1;
    font-weight: 700;
    margin-top: 2px;
    flex-shrink: 0;
    font-size: 14px;
}
.tips-advice-item strong { color: #1b1c1c; }

/* 아티클 푸터 */
.tips-article-footer {
    margin-top: 48px;
    padding-top: 28px;
    border-top: 1px solid #c3c5d9;
}
.tips-article-quote {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 17px;
    line-height: 1.8;
    color: #434656;
    font-style: italic;
    margin: 0 0 28px 0;
}
.tips-article-nav-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.tips-btn-outline {
    padding: 9px 20px;
    background: #fbf9f8;
    border: 1px solid #c3c5d9;
    color: #434656;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 7px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    transition: background 0.15s;
    font-family: 'Hanken Grotesk', sans-serif;
}
.tips-btn-outline:hover { background: #f0eded; }
.tips-btn-ghost {
    padding: 9px 28px;
    border: 1px solid #c3c5d9;
    color: #1b1c1c;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    background: transparent;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    transition: background 0.15s;
    font-family: 'Hanken Grotesk', sans-serif;
}
.tips-btn-ghost:hover { background: #f0eded; }
.tips-btn-primary {
    padding: 9px 28px;
    background: #3E6AE1;
    color: #ffffff;
    border: none;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: box-shadow 0.2s;
    font-family: 'Hanken Grotesk', sans-serif;
}
.tips-btn-primary:hover { box-shadow: 0 6px 16px rgba(62,106,225,0.35); }

/* 페이지네이션 */
.tips-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4px;
    padding: 14px 24px;
    border-top: 1px solid #E2E8F0;
}
.tips-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 8px;
    border: 1px solid #E2E8F0;
    border-radius: 6px;
    font-size: 13px;
    color: #434656;
    text-decoration: none;
    background: #ffffff;
    transition: all 0.15s;
    font-family: 'Hanken Grotesk', sans-serif;
}
.tips-page-btn:hover { border-color: #3E6AE1; color: #3E6AE1; }
.tips-page-btn.active { background: #3E6AE1; border-color: #3E6AE1; color: #ffffff; font-weight: 700; }
.tips-page-btn.disabled { opacity: 0.35; pointer-events: none; cursor: default; }

/* 반응형 */
@media (max-width: 900px) {
    .tips-wrap { flex-direction: column; }
    .tips-sidebar {
        width: 100%;
        height: auto;
        position: static;
        border-right: none;
        border-bottom: 1px solid #E2E8F0;
        padding: 20px;
        overflow-y: visible;
    }
    .tips-sidebar-brand { margin-bottom: 16px; }
    .tips-article-header { padding: 24px 28px; }
    .tips-article-body { padding: 24px 28px; }
    .tips-article-title { font-size: 26px; }
}
@media (max-width: 640px) {
    .tips-sidebar { padding: 16px; }
    .tips-sidebar-brand { margin-bottom: 12px; }
    .tips-sidebar-brand h1 { font-size: 18px; }
    .tips-main-inner { padding: 24px 16px; }
    .tips-article-header { padding: 20px 20px; }
    .tips-article-body { padding: 20px 20px; }
    .tips-article-title { font-size: 3rem; }
    .tips-pagination { flex-wrap: wrap; }
    .tips-page-hide-mo { display: none; }
}


/* ════════════════════════════════════
   sub/terms (개인정보처리방침, 이메일무단수집금지, 컨설팅운영안내)
   ════════════════════════════════════ */

.sub-terms-section {
    padding: 8rem 3rem 10rem;
    background: #fff;
}
.sub-terms-inner {
    max-width: 960px;
    margin: 0 auto;
}
.sub-terms-tit {
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--font-color);
    text-align: center;
    margin-bottom: 6rem;
    letter-spacing: -0.02em;
}
.sub-terms-body {
    font-size: 1.5rem;
    line-height: 1.9;
    color: #444;
}
.sub-terms-body > div {
    margin-bottom: 4rem;
}
.sub-terms-body h3 {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--font-color);
    margin-bottom: 1.6rem;
    margin-top: 3.6rem;
}
.sub-terms-body p {
    margin-bottom: 1.2rem;
    word-break: keep-all;
}
.sub-terms-body ul {
    padding-left: 2rem;
    margin-bottom: 1.6rem;
}
.sub-terms-body ul li {
    list-style: disc;
    margin-bottom: 1rem;
    word-break: keep-all;
}
.sub-terms-body ol {
    list-style: decimal;
    padding-left: 2.4rem;
    margin-bottom: 2rem;
}
.sub-terms-body ol li {
    list-style: decimal;
    margin-bottom: 1rem;
    word-break: keep-all;
}
.sub-terms-body ol li > span {
    display: inline-block;
    min-width: 1.4em;
    font-weight: 600;
    margin-right: 0.4rem;
    color: var(--font-color, #1b394e);
}
.sub-terms-body ol ol,
.sub-terms-body ol.agr_list_dec {
    list-style: decimal;
    padding-left: 2.4rem;
    margin-top: 0.8rem;
}
.sub-terms-admin {
    margin-top: 3rem;
    text-align: right;
}
.sub-terms-admin .board-admin-link {
    display: inline-block;
    padding: 0.7rem 1.6rem;
    font-size: 1.3rem;
    color: #fff;
    background: var(--color-brand);
    border-radius: 0.4rem;
    text-decoration: none;
}

/* 반응형 */
@media (max-width: 900px) {
    .sub-terms-section { padding: 6rem 2.4rem 8rem; }
    .sub-terms-tit { font-size: 2.6rem; margin-bottom: 4rem; }
    .sub-terms-body { font-size: 1.4rem; }
    .sub-terms-body h3 { font-size: 1.6rem; }
}
@media (max-width: 640px) {
    .sub-terms-section { padding: 4rem 1.6rem 6rem; }
    .sub-terms-tit { font-size: 2.2rem; margin-bottom: 3rem; }
    .sub-terms-body { font-size: 1.3rem; }
    .sub-terms-body h3 { font-size: 1.5rem; }
    .sub-terms-body > div { margin-bottom: 3rem; }
}

/* ════════════════════════════════════════════════════════════════════
   Consulting Services CTA Section Light Theme Overrides (ceo.php style)
   ════════════════════════════════════════════════════════════════════ */
.thesis-cta-wrap,
.journal-cta-wrap,
.stat-cta-wrap,
.ai-cta-wrap,
.adm-cta-wrap,
.prf-cta-wrap {
    background: #f8fafc !important;
    text-align: center !important;
    padding: 10rem 3rem !important;
    position: relative !important;
    overflow: hidden !important;
}

.thesis-cta-wrap::before,
.journal-cta-wrap::before,
.stat-cta-wrap::before,
.ai-cta-wrap::before,
.adm-cta-wrap::before,
.prf-cta-wrap::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(62,106,225,0.08) 0%, transparent 70%) !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

.thesis-cta-wrap > div,
.journal-cta-wrap > div,
.stat-cta-wrap > div,
.ai-cta-wrap > div,
.adm-cta-wrap > div,
.prf-cta-wrap > div {
    position: relative !important;
    z-index: 1 !important;
}

/* Section Labels */
.thesis-cta-wrap .thesis-section-label,
.journal-cta-wrap .journal-section-label,
.stat-cta-wrap .stat-label,
.ai-cta-wrap .ai-label,
.adm-cta-wrap .adm-label,
.prf-cta-wrap .prf-label {
    display: block !important;
    font-family: "Jost", sans-serif !important;
    font-size: 2rem !important;
    font-weight: bolder !important;
    letter-spacing: 0.14em !important;
    color: var(--main-color) !important;
    text-transform: uppercase !important;
    margin-bottom: 2rem !important;
}

/* Titles */
.thesis-cta-tit,
.journal-cta-tit,
.stat-cta-tit,
.ai-cta-tit,
.adm-cta-tit,
.prf-cta-tit {
    font-size: 4rem !important;
    font-weight: 700 !important;
    color: var(--color-carbon-dark) !important;
    letter-spacing: -0.04em !important;
    line-height: 1.3 !important;
    margin-bottom: 2rem !important;
}
@media (max-width: 768px) {
    .thesis-cta-tit,
    .journal-cta-tit,
    .stat-cta-tit,
    .ai-cta-tit,
    .adm-cta-tit,
    .prf-cta-tit {
        font-size: 3rem !important;
    }
}
.prf-cta-tit b {
    color: var(--color-carbon-dark) !important;
    text-decoration-color: var(--main-color) !important;
}

/* Subtitles */
.thesis-cta-sub,
.journal-cta-sub,
.stat-cta-sub,
.ai-cta-sub,
.adm-cta-sub,
.prf-cta-sub {
    font-size: 1.6rem !important;
    color: var(--color-pewter) !important;
    letter-spacing: -0.03em !important;
    line-height: 1.7 !important;
    margin-bottom: 5rem !important;
}

/* Buttons */
.thesis-cta-btn,
.journal-cta-btn,
.stat-cta-btn,
.ai-cta-btn,
.adm-cta-btn,
.prf-cta-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 1rem !important;
    height: auto !important;
    padding: 1.2rem 3.2rem !important;
    background: var(--main-color) !important;
    color: #fff !important;
    font-size: 1.6rem !important;
    font-weight: 700 !important;
    letter-spacing: -0.03em !important;
    border-radius: 9rem !important;
    text-decoration: none !important;
    border: none !important;
    cursor: pointer !important;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.thesis-cta-btn:hover,
.journal-cta-btn:hover,
.stat-cta-btn:hover,
.ai-cta-btn:hover,
.adm-cta-btn:hover,
.prf-cta-btn:hover {
    background: var(--main-color2) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 1.2rem 3rem rgba(62, 106, 225, 0.18) !important;
}

/* Notes */
.thesis-cta-note,
.journal-cta-note,
.stat-cta-note,
.ai-cta-note,
.adm-cta-note,
.prf-cta-note {
    display: block !important;
    margin-top: 2.5rem !important;
    font-size: 1.6rem !important;
    color: var(--color-pewter) !important;
    opacity: 0.8 !important;
    letter-spacing: -0.02em !important;
}
