/* ─── CUSTOM FONT FACES ─── */
@font-face { font-family: 'Weatherpia Display'; src: url('font/Weatherpia-D400.woff') format('woff'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'Weatherpia Display'; src: url('font/Weatherpia-D600.woff') format('woff'); font-weight: 600; font-style: normal; font-display: swap; }
@font-face { font-family: 'Weatherpia Text'; src: url('font/Weatherpia-T400.woff') format('woff'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'Weatherpia Text'; src: url('font/Weatherpia-T700.woff') format('woff'); font-weight: 700; font-style: normal; font-display: swap; }

:root {

  /* ── 1. PRIMITIVE ── 원시값 (브랜드 DNA · 그대로 계승) ───────────────────── */
  /* Storm palette (Pantone 301C monotone) — 기존 값 유지 */
  --storm-50:  #F3F6F9;  --storm-100: #DFEAF1;  --storm-200: #BFD2E1;
  --storm-300: #99B7CF;  --storm-400: #6695BC;  --storm-500: #33739F;
  --storm-600: #004B87;  --storm-700: #003C6C;  --storm-800: #002D51;
  --storm-900: #001E36;  --storm-950: #00132A;

  /* Cloud palette (cool-gray neutrals) — 기존 값 유지 */
  --cloud-0:   #F7F9FC;  --cloud-50:  #F1F4F9;  --cloud-100: #E6EBF2;
  --cloud-200: #D0D8E3;  --cloud-300: #B0BBCC;  --cloud-400: #8693AA;
  --cloud-500: #5E6B82;  --cloud-600: #444F63;  --cloud-700: #2E3849;
  --cloud-800: #1C2433;  --cloud-900: #0E1623;

  /* NEW — 라이브 데이터 강조색 1종만 절제 추가 (그 외 새 색 금지) */
  --signal-500: #2F7BFF;
  --signal-600: #1E63E0;

  /* ── 2. BRAND GRADIENT ── 단일 세트로 일원화 (뉴스 카드 6종 하드코딩 대체) ── */
  --gradient-corporate:        linear-gradient(135deg, #004B87 0%, #99B7CF 100%);
  --gradient-corporate-soft:   linear-gradient(180deg, #004B87 0%, #335E96 60%, #99B7CF 100%);
  --gradient-corporate-deep:   linear-gradient(135deg, #001E36 0%, #004B87 100%);
  --gradient-corporate-radial: radial-gradient(circle at 30% 30%, #99B7CF 0%, #004B87 75%);
  /* 뉴스/인사이트 카드는 위 4종 안에서만 선택. JS 의 무작위 6색 배열은
     deg 만 다른 이 토큰 참조로 교체한다. */

  /* ── 3. SEMANTIC ── 의미·역할 (컴포넌트는 원시값 대신 여기를 참조) ───────── */
  --color-bg:            var(--cloud-0);
  --color-bg-elev:       #ffffff;
  --color-bg-sunken:     var(--cloud-50);
  --color-fg:            var(--cloud-900);
  --color-fg-muted:      var(--cloud-600);
  --color-fg-subtle:     var(--cloud-500);
  --color-fg-on-brand:   #ffffff;
  --color-border:        var(--cloud-100);
  --color-border-strong: var(--cloud-200);
  --color-border-focus:  var(--signal-500);     /* 포커스를 signal 로 통일 */
  --color-brand:         var(--storm-600);
  --color-brand-hover:   var(--storm-700);
  --color-brand-active:  var(--storm-800);
  --color-brand-tint:    var(--storm-300);
  --color-accent:        var(--storm-500);
  --color-data-signal:   var(--signal-500);     /* NEW: 라이브 데이터 표시 전용 */

  /* ── 3b. LEGACY ALIAS ── 기존 이름 보존하되 "전부 시맨틱을 가리키게" 통일 ──
     (드리프트 방지: 같은 의미는 한 곳만 바꾸면 전 사이트에 전파) */
  --primary:        var(--color-brand);
  --primary-active: var(--color-brand-hover);
  --accent-tint:    var(--color-brand-tint);
  --ink:            var(--color-fg);
  --body:           var(--color-fg-muted);
  --muted:          var(--color-fg-subtle);
  --muted-soft:     var(--cloud-300);
  --hairline:       var(--color-border);
  --hairline-soft:  var(--cloud-50);
  --canvas:         var(--color-bg-elev);
  --surface-soft:   var(--cloud-50);
  --surface-dark:   var(--color-brand);
  --on-primary:     #ffffff;
  --on-dark:        #ffffff;
  --on-dark-soft:   var(--storm-300);

  /* ── 4. COMPONENT ── 부품 단위 (NEW: 빠져 있던 3번째 층) ────────────────── */
  /* Button */
  --btn-bg:              var(--color-brand);
  --btn-bg-hover:        var(--color-brand-hover);
  --btn-fg:              var(--color-fg-on-brand);
  --btn-radius:          var(--radius-full);
  --btn-pad-y:           14px;
  --btn-pad-x:           24px;
  --btn-ghost-fg:        var(--color-brand);
  --btn-ghost-border:    var(--color-border);
  /* Card */
  --card-bg:             var(--color-bg-elev);
  --card-border:         var(--color-border);
  --card-radius:         var(--radius-lg);
  --card-shadow:         var(--shadow-md);
  --card-shadow-hover:   var(--shadow-lg);
  /* Chip / Tag */
  --chip-bg:             var(--storm-100);
  --chip-fg:             var(--color-brand);
  --chip-radius:         var(--radius-full);
  /* GNB */
  --gnb-bg-scrolled:     rgba(4,14,32,.55);
  --gnb-bg-light:        rgba(255,255,255,.97);
  --gnb-border-light:    var(--cloud-100);

  /* ── 5. TYPOGRAPHY ── 폰트 패밀리 (기존 유지) ──────────────────────────── */
  --font-sans:    'Weatherpia Text', 'Pretendard Variable', Pretendard, -apple-system, BlinkMacSystemFont, system-ui, 'Apple SD Gothic Neo', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
  --font-display: 'Weatherpia Display', 'Weatherpia Text', 'Pretendard Variable', Pretendard, -apple-system, system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', 'SF Mono', ui-monospace, Menlo, monospace;
  --font-text:    var(--font-sans);

  /* ── 5b. FLUID TYPE SCALE ── NEW: 고정 px → clamp() 유동 (modular ×1.25) ──
     사용 예) .hero__slogan { font-size: var(--fs-display); }
              .sec__title   { font-size: var(--fs-h2); }
              body          { font-size: var(--fs-body); } */
  --fs-mono:    clamp(11px, 0.70rem + 0.10vw, 12.5px);
  --fs-caption: clamp(12px, 0.75rem + 0.10vw, 13.5px);
  --fs-body:    clamp(15px, 0.90rem + 0.20vw, 17px);
  --fs-lead:    clamp(18px, 1.00rem + 0.55vw, 22px);
  --fs-h4:      clamp(18px, 1.00rem + 0.60vw, 22px);
  --fs-h3:      clamp(22px, 1.10rem + 1.40vw, 34px);
  --fs-h2:      clamp(28px, 1.30rem + 3.00vw, 52px);
  --fs-h1:      clamp(34px, 1.50rem + 4.50vw, 68px);
  --fs-display: clamp(40px, 1.60rem + 7.00vw, 104px);

  /* line-height & tracking 토큰 */
  --lh-tight:   1.04;
  --lh-snug:    1.2;
  --lh-body:    1.72;
  --tr-display: -0.035em;
  --tr-heading: -0.02em;
  --tr-mono:    0.16em;

  /* ── 6. SPACING ── 8pt 그리드 (기존 유지 + 유동 섹션 여백 추가) ─────────── */
  --space-1: 4px;   --space-2: 8px;   --space-3: 12px;
  --space-4: 16px;  --space-5: 20px;  --space-6: 24px;
  --space-8: 32px;  --space-10: 40px; --space-12: 48px;
  --space-16: 64px; --space-20: 80px; --space-24: 96px; --space-32: 128px;

  /* 기존 고정 96px → 유동. 데스크톱 호흡 + 모바일 밀도 동시 충족 */
  --sp-section: clamp(72px, 11vw, 140px);
  --container-pad: clamp(20px, 5vw, 40px);   /* 좌우 여백도 유동 */
  --container-max: 1280px;

  /* ── 7. RADII ── (기존 유지) ──────────────────────────────────────────── */
  --radius-xs: 4px;  --radius-sm: 8px;  --radius-md: 12px;
  --radius-lg: 16px; --radius-xl: 24px; --radius-full: 999px;
  --r-xs: var(--radius-xs); --r-sm: var(--radius-sm); --r-md: var(--radius-md);
  --r-lg: var(--radius-lg); --r-xl: var(--radius-xl); --r-pill: var(--radius-full);

  /* ── 8. ELEVATION ── (기존 유지, 쿨 블루 틴트) ─────────────────────────── */
  --shadow-sm:    0 1px 2px rgba(0,30,54,.06), 0 1px 1px rgba(0,30,54,.04);
  --shadow-md:    0 6px 16px rgba(0,30,54,.08), 0 2px 4px rgba(0,30,54,.04);
  --shadow-lg:    0 20px 48px rgba(0,30,54,.12), 0 6px 12px rgba(0,30,54,.06);
  --shadow-focus: 0 0 0 3px rgba(47,123,255,.28);   /* signal 기반으로 통일 */

  /* ── 9. MOTION ── (기존 유지) ─────────────────────────────────────────── */
  --ease-out:        cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-in-out:     cubic-bezier(0.4, 0.0, 0.2, 1);
  --duration-fast:   120ms;
  --duration-base:   200ms;
  --duration-slow:   400ms;
  --duration-reveal: 600ms;
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; overflow-x: clip; }
body { font-family: var(--font-sans); color: var(--color-fg); background: var(--color-bg); -webkit-font-smoothing: antialiased; overflow-x: clip; font-size: var(--fs-body); }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
.container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 40px; }

/* ─── GNB: GOLDMAN SACHS MEGA-MENU ─── */
.gnb { position: fixed; top: 0; left: 0; right: 0; height: 64px; z-index: 100; background: transparent; backdrop-filter: none; -webkit-backdrop-filter: none; border-bottom: 1px solid transparent; box-shadow: none; transition: background .45s var(--ease-out), backdrop-filter .45s var(--ease-out), -webkit-backdrop-filter .45s var(--ease-out), border-color .45s var(--ease-out), box-shadow .45s var(--ease-out); }
.gnb--scrolled { background: rgba(4, 14, 32, 0.55); backdrop-filter: blur(24px) saturate(180%); -webkit-backdrop-filter: blur(24px) saturate(180%); border-bottom: 1px solid rgba(255,255,255,.08); box-shadow: 0 2px 24px rgba(0,15,40,.25); }
.gnb--light { background: rgba(255,255,255,.97); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border-bottom: 1px solid var(--cloud-100); box-shadow: var(--shadow-sm); }
.gnb--light .gnb__link { color: var(--cloud-700); }
.gnb--light .gnb__menu-item:hover .gnb__link,
.gnb--light .gnb__menu-item--active .gnb__link { color: var(--storm-600); }
.gnb--light .gnb__link::after { background: var(--storm-600); }
.gnb--light .gnb__lang { color: var(--cloud-400); }
.gnb--light .gnb__lang-item--active { color: var(--storm-600); background: rgba(0,75,135,.08); }
.gnb--light .gnb__mobile-btn { color: var(--cloud-700); }
.gnb--light .gnb__logo-white { opacity: 0; }
.gnb--light .gnb__logo-color { opacity: 1; }

/* News article route → keep the GNB dark (page body is white, transparent GNB would be invisible) */
body.route-news-article .gnb,
body.route-news-article .gnb.gnb--scrolled,
body.route-news-article .gnb.gnb--light,
body.route-news-article .gnb:hover {
  background: rgba(4, 14, 32, 0.92);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 2px 24px rgba(0,15,40,.25);
}
body.route-news-article .gnb .gnb__link,
body.route-news-article .gnb:hover .gnb__link { color: rgba(255,255,255,.85); }
body.route-news-article .gnb .gnb__menu-item--active .gnb__link,
body.route-news-article .gnb .gnb__menu-item:hover .gnb__link,
body.route-news-article .gnb:hover .gnb__menu-item:hover .gnb__link { color: #fff; }
body.route-news-article .gnb .gnb__link::after,
body.route-news-article .gnb:hover .gnb__link::after { background: #fff; }
body.route-news-article .gnb .gnb__lang,
body.route-news-article .gnb:hover .gnb__lang { color: rgba(255,255,255,.5); }
body.route-news-article .gnb .gnb__lang-item--active,
body.route-news-article .gnb:hover .gnb__lang-item--active { color: #fff; background: rgba(255,255,255,.12); }
body.route-news-article .gnb .gnb__mobile-btn,
body.route-news-article .gnb:hover .gnb__mobile-btn { color: rgba(255,255,255,.85); }
body.route-news-article .gnb__logo-white,
body.route-news-article .gnb:hover .gnb__logo-white { opacity: 1; }
body.route-news-article .gnb__logo-color,
body.route-news-article .gnb:hover .gnb__logo-color { opacity: 0; }

/* Hover the GNB → swap to light theme (white bg + dark text), regardless of scroll state */
.gnb:hover { background: rgba(255,255,255,.97); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border-bottom: 1px solid var(--cloud-100); box-shadow: var(--shadow-sm); }
.gnb:hover .gnb__link { color: var(--cloud-700); }
.gnb:hover .gnb__menu-item:hover .gnb__link,
.gnb:hover .gnb__menu-item--active .gnb__link { color: var(--storm-600); }
.gnb:hover .gnb__link::after { background: var(--storm-600); }
.gnb:hover .gnb__lang { color: var(--cloud-400); }
.gnb:hover .gnb__lang-item--active { color: var(--storm-600); background: rgba(0,75,135,.08); }
.gnb:hover .gnb__mobile-btn { color: var(--cloud-700); }
.gnb:hover .gnb__logo-white { opacity: 0; }
.gnb:hover .gnb__logo-color { opacity: 1; }
.gnb__inner { display: flex; align-items: center; justify-content: space-between; height: 100%; position: relative; }
.gnb__logo { position: relative; display: flex; align-items: center; z-index: 102; }
.gnb__logo-white, .gnb__logo-color { height: 39px; width: auto; object-fit: contain; transition: opacity .35s; }
.gnb__logo-color { position: absolute; left: 0; top: 50%; transform: translateY(-50%); opacity: 0; }

.gnb__menu { display: flex; align-items: center; gap: 0; height: 100%; z-index: 101; }
.gnb__menu-list { display: flex; align-items: center; height: 100%; list-style: none; }
.gnb__menu-item { position: relative; height: 100%; display: flex; align-items: center; }
.gnb__link {
  font-family: var(--font-display); font-weight: 600; font-size: 14px; letter-spacing: .2px;
  color: rgba(255,255,255,.8); transition: color .25s; position: relative;
  padding: 0 22px; height: 100%; display: flex; align-items: center;
}
.gnb__link::after {
  content: ''; position: absolute; left: 22px; right: 22px; bottom: 0;
  height: 2px; background: #fff; transform: scaleX(0);
  transform-origin: left; transition: transform .3s;
}
.gnb__menu-item:hover .gnb__link { color: #fff; }
.gnb__menu-item:hover .gnb__link::after { transform: scaleX(1); }
.gnb__menu-item--active .gnb__link { color: #fff; }
.gnb__menu-item--active .gnb__link::after { transform: scaleX(1); }

/* Mega Dropdown Panel */
.gnb__mega {
  position: fixed; top: 64px; left: 0; right: 0;
  background: rgba(255,255,255,.98); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid rgba(255,255,255,.1);
  box-shadow: var(--shadow-lg);
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .3s ease, transform .3s ease, visibility .3s;
  z-index: 99;
}
.gnb__menu-item:hover .gnb__mega { opacity: 1; visibility: visible; transform: translateY(0); }
.gnb__mega-inner {
  max-width: 1280px; margin: 0 auto; padding: 48px 40px;
  display: grid; grid-template-columns: 260px 1fr auto; gap: 48px; align-items: start;
}
.gnb__mega-desc { padding-right: 16px; border-right: 1px solid var(--hairline-soft); }
.gnb__mega-title {
  font-family: var(--font-display); font-size: 28px; font-weight: 800;
  letter-spacing: -1px; color: var(--ink); line-height: 1.2; margin-bottom: 16px;
}
.gnb__mega-text {
  font-size: 14px; line-height: 1.7; color: var(--body); margin-bottom: 24px; white-space: pre-line;
}
.gnb__mega-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-size: 13px; font-weight: 700;
  color: var(--ink); padding: 10px 20px;
  border: 1.5px solid var(--ink); border-radius: 0; transition: all .25s;
}
.gnb__mega-cta:hover { background: var(--ink); color: #fff; }
.gnb__mega-cta svg { transition: transform .2s; }
.gnb__mega-cta:hover svg { transform: translateX(3px); }

.gnb__mega-links { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 32px; }
.gnb__mega-col-title {
  font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--muted); margin-bottom: 16px;
}
.gnb__mega-link {
  display: block; font-size: 15px; font-weight: 500; color: var(--ink);
  padding: 6px 0; transition: all .2s; position: relative;
}
.gnb__mega-link:hover { color: var(--primary); padding-left: 6px; }

.gnb__mega-featured {
  width: 240px; background: var(--surface-soft); border-radius: var(--r-xl);
  overflow: hidden; transition: transform .3s;
}
.gnb__mega-featured:hover { background: var(--storm-50); }
.gnb__mega-featured-img {
  height: 140px; background: linear-gradient(135deg, var(--primary) 0%, #003a6c 100%);
  display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.3);
}
.gnb__mega-featured-body { padding: 20px; }
.gnb__mega-featured-title { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: var(--ink); margin-bottom: 6px; }
.gnb__mega-featured-text { font-size: 12px; line-height: 1.6; color: var(--body); }

.gnb__right { display: flex; align-items: center; gap: 16px; z-index: 102; position: relative; }
.gnb__lang { display: flex; align-items: center; gap: 2px; font-size: 12px; font-weight: 700; color: rgba(255,255,255,.5); }
.gnb__lang-item { padding: 4px 8px; border-radius: var(--r-sm); cursor: pointer; transition: all .2s; }
.gnb__lang-item--active { color: #fff; background: rgba(255,255,255,.12); }
.gnb__lang--mobile { display: none; }

.gnb__mobile-btn {
  display: none; background: transparent; border: none; cursor: pointer;
  color: rgba(255,255,255,.85); transition: color .25s; padding: 4px; z-index: 103;
}
.gnb__mobile-btn.is-open { color: var(--ink); }

@media (max-width: 1024px) {
  .gnb__mobile-btn { display: flex; align-items: center; justify-content: center; }
  .gnb__logo { z-index: 90; }
  .gnb__right { z-index: 102; }
  .gnb__menu {
    position: fixed; top: 0; right: 0; width: 100%; max-width: 300px;
    height: 100dvh; background: var(--canvas);
    flex-direction: column; align-items: flex-start;
    padding: 80px 10px 0 40px; overflow-y: hidden;
    transform: translateX(100%); transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    box-shadow: var(--shadow-lg); z-index: 101;
  }
  .gnb__menu.is-open { transform: translateX(0); }
  /* Lock the page behind the open menu so dragging scrolls the menu, not the page. */
  body.gnb-menu-open { overflow: hidden; }
  .gnb__menu-list { display: flex; flex-direction: column; width: 100%; gap: 4px; flex: 1; overflow-y: auto; min-height: 0; padding-bottom: 16px; overscroll-behavior: contain; -webkit-overflow-scrolling: touch; }
  .gnb__menu-item { flex-direction: column; align-items: flex-start; width: 100%; height: auto; }
  .gnb__link { font-size: 20px; font-weight: 800; padding: 12px 0; height: auto; color: var(--ink); width: 100%; border-bottom: 1px solid var(--hairline-soft); }
  /* Mobile panel is white — active/hover must not be white-on-white */
  .gnb__menu-item--active .gnb__link,
  .gnb__menu-item:hover .gnb__link { color: var(--primary); }
  .gnb__link::after { display: none; }
  /* News-article route forces white nav text for its dark hero; the slide-in
     panel is white, so re-assert readable colors inside the open menu. */
  body.route-news-article .gnb__menu .gnb__link,
  body.route-news-article .gnb:hover .gnb__menu .gnb__link { color: var(--ink); }
  body.route-news-article .gnb__menu .gnb__menu-item--active .gnb__link,
  body.route-news-article .gnb__menu .gnb__menu-item:hover .gnb__link { color: var(--primary); }
  body.route-news-article .gnb__menu .gnb__lang--mobile .gnb__lang-item { color: var(--muted); }
  body.route-news-article .gnb__menu .gnb__lang--mobile .gnb__lang-item--active { color: var(--primary); background: rgba(0,75,135,.08); }
  /* Close (X) button sits over the white panel — keep it dark on every route. */
  body .gnb .gnb__mobile-btn.is-open,
  body.route-news-article .gnb .gnb__mobile-btn.is-open,
  body.route-news-article .gnb:hover .gnb__mobile-btn.is-open { color: var(--ink); }
  /* Closed hamburger may sit over a bright photo hero — a subtle dark chip
     guarantees the white icon stays visible regardless of the image. */
  .gnb__mobile-btn { width: 40px; height: 40px; border-radius: 50%; background: rgba(0,0,0,.28); display: flex; align-items: center; justify-content: center; }
  .gnb--light .gnb__mobile-btn, .gnb--scrolled .gnb__mobile-btn, .gnb__mobile-btn.is-open { background: transparent; }
  .gnb__mega {
    position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none;
    background: transparent; backdrop-filter: none; border-top: none;
  }
  .gnb__mega-inner { padding: 8px 0 16px 12px; display: flex; flex-direction: column; gap: 0; }
  .gnb__mega-desc { display: none; }
  .gnb__mega-featured { display: none; }
  .gnb__mega-links { display: flex; flex-direction: column; gap: 0; }
  .gnb__mega-col-title { display: none; }
  .gnb__mega-link { font-size: 14px; padding: 8px 0; color: var(--muted); }
  .gnb__overlay {
    position: fixed; inset: 0; height: 100dvh;
    background: rgba(0,0,0,.5); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
    opacity: 0; visibility: hidden; transition: all .3s; z-index: 100;
  }
  .gnb__overlay.is-open { opacity: 1; visibility: visible; }
  .gnb__lang--desktop { display: none; }
  .gnb__lang--mobile {
    display: flex; gap: 8px;
    flex-shrink: 0;
    padding: 0 0 18px; margin-bottom: 12px;
    border-bottom: 1px solid var(--hairline-soft); width: 100%;
  }
  .gnb__lang--mobile .gnb__lang-item { font-size: 14px; font-weight: 700; color: var(--muted); padding: 8px 12px; border-radius: var(--r-md); cursor: pointer; transition: all .2s; }
  .gnb__lang--mobile .gnb__lang-item--active { color: var(--primary); background: rgba(0,75,135,.08); }
}

/* ─── HERO SLIDER (HOME) ─── */
.hero { position: relative; height: 100vh; min-height: 700px; overflow: hidden; background: #424242; }
.hero__video-wrap { position: absolute; inset: 0; }
.hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero__video-fallback { position: absolute; inset: 0; background-size: cover; background-position: center; }
.hero__video-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.48); z-index: 1; }

.hero__content { position: absolute; inset: 0; z-index: 10; display: flex; align-items: center; pointer-events: none; }
.hero__content > .container { pointer-events: auto; }
.hero__slogan { font-family: var(--font-display); font-size: var(--fs-display); font-weight: 800; line-height: 1.05; letter-spacing: -2px; color: var(--on-dark); margin-bottom: 28px; opacity: 0; transform: translateY(30px); animation: fadeUp .9s .3s ease forwards; }
.hero__sub { font-family: var(--font-text); font-size: 17px; font-weight: 400; line-height: 1.65; color: rgba(255,255,255,.85); max-width: 540px; margin-bottom: 40px; opacity: 0; transform: translateY(20px); animation: fadeUp .8s .55s ease forwards; }
.hero__cta { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-text); font-weight: 700; font-size: 16px; color: var(--on-primary); background: transparent; border: 1.5px solid rgba(255,255,255,.35); padding: 14px 28px; border-radius: var(--r-pill); cursor: pointer; transition: all .3s; opacity: 0; transform: translateY(20px); animation: fadeUp .8s .7s ease forwards; }
.hero__cta:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.6); }
.hero__cta svg { transition: transform .25s; }
.hero__cta:hover svg { transform: translateX(3px); }
.hero__indicators { position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%); z-index: 10; display: flex; gap: 12px; }
.hero__dot { width: 32px; height: 3px; background: rgba(255,255,255,.3); border-radius: 2px; cursor: pointer; transition: all .4s; border: none; padding: 0; }
.hero__dot--active { background: #fff; width: 48px; }

/* ─── NEWS SLIDER ─── */
.news { padding: 80px 0 88px; }
.news__header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 40px; }
.news__label { font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--primary); margin-bottom: 12px; }
.news__title { font-family: var(--font-display); font-size: var(--fs-h2); font-weight: 800; letter-spacing: -0.8px; color: var(--ink); }
.news__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.news__card { display: flex; flex-direction: column; border-radius: 0; border: none; background: transparent; overflow: visible; transition: opacity .2s; text-decoration: none; }
.news__card:hover { opacity: .85; }
.news__card-img { width: 100%; height: 220px; background: var(--cloud-100); background-size: cover; background-position: center; flex-shrink: 0; border-radius: var(--r-lg); }
.news__card-body { padding: 16px 0 20px; display: flex; flex-direction: column; flex: 1; }
.news__card-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.news__card-tag { font-size: 12px; font-weight: 700; color: var(--primary); }
.news__card-date { font-size: 12px; color: var(--muted); }
.news__card-title { font-family: var(--font-display); font-size: var(--fs-h4); font-weight: 800; letter-spacing: -0.3px; color: var(--ink); line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; flex: 1; }
.news__card-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.news__card-chip { font-size: 12px; color: var(--chip-fg); background: var(--chip-bg); border: 1px solid var(--hairline); padding: 3px 10px; border-radius: var(--chip-radius); }
/* Home news: lead story featured (full-width, horizontal) above the grid — desktop only */
@media (min-width: 769px) {
  #newsTrack .news__card:first-child {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: stretch;
    gap: 28px;
    padding-bottom: 28px;
    margin-bottom: 8px;
    border-bottom: 1px solid var(--hairline);
  }
  #newsTrack .news__card:first-child .news__card-img { width: 58%; height: 340px; }
  #newsTrack .news__card:first-child .news__card-body { justify-content: center; padding: 8px 8px 8px 4px; }
  #newsTrack .news__card:first-child .news__card-title { font-size: var(--fs-h3); -webkit-line-clamp: 4; }
}

/* ─── QUICK NAV ─── */
.quicknav { padding: 0; }
.quicknav__stack { display: flex; flex-direction: column; }
.quicknav__panel { position: relative; height: 200px; overflow: hidden; cursor: pointer; transition: height .5s cubic-bezier(.25,.46,.45,.94); border-bottom: 1px solid rgba(255,255,255,.08); background: var(--storm-900); }
.quicknav__panel:last-child { border-bottom: none; }
.quicknav__panel:hover { height: 300px; }
.quicknav__panel-bg { position: absolute; inset: 0; background-size: cover; background-position: center; filter: grayscale(100%) brightness(1.2); opacity: .5; z-index: 1; transition: filter .6s ease, opacity .6s ease; }
.quicknav__panel:hover .quicknav__panel-bg { filter: grayscale(20%) brightness(1); opacity: 1; }
.quicknav__panel-dark { position: absolute; inset: 0; background: rgba(0,0,0,.3); z-index: 2; }
.quicknav__panel-overlay { position: absolute; top: 0; left: 0; bottom: 0; width: 100%; background: rgba(0,75,135,.55); z-index: 3; transform: translateX(-100%); transition: transform .5s cubic-bezier(.25,.46,.45,.94); }
.quicknav__panel:hover .quicknav__panel-overlay { transform: translateX(0); }
.quicknav__panel-content { position: relative; z-index: 4; height: 100%; display: flex; align-items: center; padding: 0 60px; }
.quicknav__panel-inner { display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: 1280px; margin: 0 auto; }
.quicknav__panel-num { font-family: var(--font-display); font-size: 13px; font-weight: 700; letter-spacing: 2px; color: rgba(255,255,255,.60); margin-bottom: 10px; transition: color .4s; }
.quicknav__panel:hover .quicknav__panel-num { color: rgba(255,255,255,.7); }
.quicknav__panel-title { font-family: var(--font-display); font-size: 32px; font-weight: 800; letter-spacing: -0.5px; color: #fff; transition: font-size .4s; }
.quicknav__panel:hover .quicknav__panel-title { font-size: 40px; }
.quicknav__panel-desc { font-size: 15px; line-height: 1.5; color: rgba(255,255,255,.65); margin-top: 12px; max-width: 480px; opacity: 0; transform: translateY(8px); transition: opacity .4s .1s, transform .4s .1s; }
.quicknav__panel:hover .quicknav__panel-desc { opacity: 1; transform: translateY(0); }
.quicknav__panel-cta { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-text); font-weight: 700; font-size: 15px; color: #fff; background: transparent; border: 1.5px solid rgba(255,255,255,.4); padding: 14px 28px; border-radius: var(--r-pill); white-space: nowrap; opacity: 0; transform: translateX(20px); transition: opacity .4s .15s, transform .4s .15s, background .25s, border-color .25s; }
.quicknav__panel:hover .quicknav__panel-cta { opacity: 1; transform: translateX(0); }
.quicknav__panel-cta:hover { background: rgba(255,255,255,.80); border-color: rgba(255,255,255,.7); }

/* ─── KEY FIGURES ─── */
.figures { padding: 100px 0; position: relative; overflow: hidden; background: #fff; }
.figures__header { margin-bottom: 56px; }
.figures__label { font-size: 12px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--primary); margin-bottom: 8px; }
.figures__title { font-family: var(--font-display); font-size: 32px; font-weight: 800; letter-spacing: -1px; color: var(--ink); }
.figures__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; position: relative; z-index: 1; }
.figures__item { padding: 0 36px; border-left: 1px solid var(--hairline); position: relative; }
.figures__item:first-child { border-left: none; padding-left: 0; }
.figures__item:last-child { padding-right: 0; }
.figures__accent { width: 32px; height: 3px; border-radius: 2px; margin-bottom: 24px; }
.figures__number { font-family: var(--font-display); font-size: var(--fs-h1); font-weight: 800; letter-spacing: -2px; color: var(--ink); line-height: 1; margin-bottom: 4px; }
.figures__number span { font-size: 36px; font-weight: 700; }
.figures__caption { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: var(--ink); margin-bottom: 12px; letter-spacing: -.2px; }
.figures__desc { font-size: 13px; line-height: 1.7; color: var(--muted); }

/* ─── PARTNER LOGO WALL ─── */
.partners { padding: 80px 0 var(--sp-section); background: var(--surface-soft); overflow: hidden; }
.partners__header { text-align: center; margin-bottom: 10px; }
.partners__label { font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--primary); margin-bottom: 16px; }
.partners__title { font-family: var(--font-display); font-size: var(--fs-h2); font-weight: 800; letter-spacing: -0.8px; color: var(--ink); }
.partners__marquee-wrap { display: flex; flex-direction: column; gap: 10px; width: 100vw; margin-left: calc(-50vw + 50%); }
.partners__row { display: flex; gap: 10px; width: max-content; will-change: transform; }
.partners__row--left { animation: marqueeLeft 50s linear infinite; }
.partners__row--right { animation: marqueeRight 50s linear infinite; }
.partners__row:nth-child(2) { margin-left: -80px; }
.partners__row:nth-child(4) { margin-left: -80px; }
.partners__item {
  width: 168px; height: 86px; flex-shrink: 0;
  background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  padding: 16px 20px; overflow: hidden; transition: all .35s;
}
.partners__item:hover { border-color: var(--color-border-strong); }
.partners__logo-img {
  width: 100%; height: 100%; object-fit: contain;
  filter: grayscale(100%) opacity(0.4); transition: filter .4s;
}
.partners__item:hover .partners__logo-img { filter: grayscale(0%) opacity(1); }
.partners__logo-text {
  font-family: var(--font-display); font-weight: 800; font-size: 14px;
  color: var(--muted); letter-spacing: -.3px; text-align: center;
  transition: color .3s;
}
.partners__item:hover .partners__logo-text { color: var(--ink); }
.partners__sub { text-align: center; margin-bottom: 40px; font-size: 14px; color: var(--muted); line-height: 1.6; }

@keyframes marqueeLeft {
  0% { transform: translateX(0); }
  100% { transform: translateX(-33.33%); }
}
@keyframes marqueeRight {
  0% { transform: translateX(-33.33%); }
  100% { transform: translateX(0); }
}

/* ─── FOOTER ─── */
.footer { background: var(--ink); padding: 64px 0 40px; color: rgba(255,255,255,.5); }
.footer__inner { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.footer__brand { display: flex; flex-direction: column; gap: 16px; }
.footer__logo { display: flex; align-items: center; }
.footer__logo-img { height: 50px; width: auto; object-fit: contain; }
.footer__desc { font-size: 13px; line-height: 1.7; max-width: 380px; }
.footer__inner > div:not(.footer__brand) { padding-left: 50px; }
.footer__col-title { font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 20px; }
.footer__link { display: block; font-size: 14px; color: rgba(255,255,255,.55); padding: 5px 0; transition: color .2s; }
.footer__link:hover { color: var(--on-dark); }
.footer__credentials {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 32px;
  padding: 28px 0; margin-bottom: 8px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.footer__cred {
  display: flex; align-items: center; gap: 8px;
}
.footer__cred-logo {
  height: 36px; width: auto; opacity: .7;
}
.footer__cred-logo--wide {
  height: 36px;
}
.footer__cred-label {
  font-family: var(--font-display); font-size: 10px; font-weight: 600;
  line-height: 1.35; letter-spacing: .4px; color: rgba(255,255,255,.45);
  text-transform: uppercase;
}
.footer__bottom { border-top: 1px solid rgba(255,255,255,.08); padding-top: 28px; display: flex; justify-content: space-between; align-items: center; font-size: 12px; }
.footer__legal { display: flex; gap: 24px; }
.footer__legal a:hover { color: rgba(255,255,255,.8); }

@keyframes fadeUp { to { opacity: 1; transform: translateY(0); } }
.reveal { opacity: 0; transform: translateY(40px); transition: opacity var(--duration-reveal) var(--ease-out), transform var(--duration-reveal) var(--ease-out); }
.reveal--visible { opacity: 1; transform: translateY(0); }
.reveal--delay-1 { transition-delay: .1s; }
.reveal--delay-2 { transition-delay: .2s; }
.reveal--delay-3 { transition-delay: .3s; }
.reveal--delay-4 { transition-delay: .35s; }

/* ─── ALL SUB-PAGES SPECIFIC ─── */
.page-hero { position: relative; height: 700px; background: var(--surface-dark); overflow: hidden; display: flex; align-items: flex-end; padding-bottom: 56px; }
.page-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; }
.page-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,30,54,.35) 0%, rgba(0,30,54,.78) 100%); }
.page-hero__content { position: relative; z-index: 2; }
.page-hero__breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 500; color: rgba(255,255,255,.45); margin-bottom: 20px; }
.page-hero__breadcrumb a { color: rgba(255,255,255,.45); transition: color .2s; }
.page-hero__breadcrumb a:hover { color: rgba(255,255,255,.8); }
.page-hero__breadcrumb svg { opacity: .4; }
.page-hero__title { font-family: var(--font-display); font-size: var(--fs-h1); font-weight: 800; letter-spacing: -1.5px; color: var(--on-dark); margin-bottom: 16px; opacity: 0; transform: translateY(24px); animation: fadeUp .8s .2s ease forwards; }
.page-hero__desc { font-size: 17px; line-height: 1.65; color: rgba(255,255,255,.6); white-space: nowrap; opacity: 0; transform: translateY(16px); animation: fadeUp .7s .4s ease forwards; }

.subnav { position: sticky; top: 64px; z-index: 90; background: rgba(255,255,255,.97); border-bottom: 1px solid var(--hairline); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.subnav__inner { display: flex; align-items: center; gap: 15px; height: 52px; overflow-x: auto; -ms-overflow-style: none; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.subnav__inner::-webkit-scrollbar { display: none; }
.subnav__link { display: flex; align-items: center; gap: 8px; padding: 0 20px; height: 100%; font-size: 14px; font-weight: 600; color: var(--muted); white-space: nowrap; position: relative; transition: color .25s; flex-shrink: 0; }
.subnav__link::after { content: ''; position: absolute; left: 20px; right: 20px; bottom: 0; height: 2px; background: var(--primary); transform: scaleX(0); transform-origin: left; transition: transform .3s; }
.subnav__link:hover { color: var(--primary); }
.subnav__link--active { color: var(--primary); }
.subnav__link--active::after { transform: scaleX(1); }

.sec { padding: 96px 0; scroll-margin-top: 116px; }
.sec--history { padding-top: 86px; }
.sec--alt { background: var(--surface-soft); }
.sec--bg-image { position: relative; isolation: isolate; overflow: hidden; }
.sec--bg-image::before { content: ''; position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; opacity: 1; z-index: -1; pointer-events: none; }
.sec--bg-founder::before { background-image: url('founder.jpg'); }
.sec--bg-ceo::before { background-image: url('ceo.jpg'); ;}
/* Founder / CEO sections — natural flow (previous sticky-reveal effect removed: overflowed on shorter viewports) */
.op-reveal-wrap { position: relative; }
.op-reveal-wrap > #founder,
.op-reveal-wrap > #ceo { position: relative; min-height: auto; display: flex; align-items: center; padding: 96px 0; }
.sec--bg-image > .container { position: relative; z-index: 1; }

/* Mobile: the desktop bg-photo crops the right-aligned subject out (cover + center).
   Show the portrait as a top banner instead, with the letter flowing underneath. */
@media (max-width: 768px) {
  .op-reveal-wrap > #founder,
  .op-reveal-wrap > #ceo {
    min-height: 0;
    display: block;
    padding-top: 300px;
    padding-bottom: 64px;
  }
  #founder::before,
  #ceo::before {
    inset: 0 0 auto 0;
    height: 260px;
    background-position: right center;
    border-bottom: 1px solid var(--hairline);
  }
}

.sec--dark { background: var(--surface-dark); color: var(--on-dark); }
.sec__title { font-family: var(--font-display); font-size: 38px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.30; color: var(--color-fg); margin-bottom: 20px; }
.sec--dark .sec__title { color: var(--on-dark); }
.sec__subtitle { font-size: 16px; line-height: 1.65; color: var(--color-fg-muted); max-width: 1000px; margin-bottom: 56px; }
.sec--dark .sec__subtitle { color: var(--on-dark-soft); }

.timeline { position: relative; max-width: 900px; margin: 0 auto; padding-left: 40px; }
.timeline::before { content: ''; position: absolute; left: 15px; top: 8px; bottom: 8px; width: 2px; background: var(--hairline); }
.timeline__item { position: relative; padding-bottom: 44px; padding-left: 36px; }
.timeline__item:last-child { padding-bottom: 0; }
.timeline__dot { position: absolute; left: -32px; top: 6px; width: 14px; height: 14px; border-radius: 50%; background: var(--primary); border: 3px solid var(--canvas); z-index: 2; box-shadow: 0 0 0 4px rgba(0,75,135,.08); }
.timeline__dot--major { width: 18px; height: 18px; left: -34px; top: 4px; box-shadow: 0 0 0 5px rgba(0,75,135,.12); }
.timeline__year { font-family: var(--font-display); font-size: 24px; font-weight: 800; color: var(--primary); letter-spacing: -.5px; margin-bottom: 8px; }
.timeline__desc { font-size: 15px; line-height: 1.65; color: var(--body); }

.biz-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.biz-card { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--card-radius); padding: 40px 32px; transition: all .35s; position: relative; overflow: hidden; }
.biz-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--primary); transform: scaleX(0); transform-origin: left; transition: transform .4s; }
.biz-card:hover::before { transform: scaleX(1); }
.biz-card:hover { border-color: var(--color-border-strong); }
.biz-card__icon { width: 52px; height: 52px; background: rgba(0,75,135,.06); border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; margin-bottom: 24px; color: var(--primary); }
.biz-card__title { font-family: var(--font-display); font-size: 20px; font-weight: 800; letter-spacing: -.3px; color: var(--ink); margin-bottom: 6px; }
.biz-card__title-ko { font-size: 14px; font-weight: 500; color: var(--muted); margin-bottom: 16px; }
.biz-card__desc { font-size: 14px; line-height: 1.7; color: var(--body); margin-bottom: 24px; }
.biz-card__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.biz-card__tag { font-size: 11px; font-weight: 600; color: var(--primary); background: rgba(0,75,135,.05); padding: 4px 10px; border-radius: var(--r-sm); }

.strategy-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.strategy__visual { position: relative; background: linear-gradient(135deg, var(--storm-50) 0%, var(--storm-100) 100%); border-radius: var(--r-xl); padding: 48px; min-height: 420px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.strategy__visual::before { content: ''; position: absolute; top: -60px; right: -60px; width: 220px; height: 220px; border-radius: 50%; background: rgba(0,75,135,.04); }
.strategy__visual::after { content: ''; position: absolute; bottom: -40px; left: -40px; width: 160px; height: 160px; border-radius: 50%; background: rgba(0,75,135,.03); }
.strategy__diagram { position: relative; z-index: 1; text-align: center; width: 100%; }
.strategy__pillars { display: flex; gap: 16px; justify-content: center; margin-bottom: 24px; }
.strategy__pillar { background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: 20px 16px; text-align: center; flex: 1; max-width: 140px; transition: all .3s; }
.strategy__pillar:hover { border-color: var(--color-border-strong); }
.strategy__pillar-label { font-family: var(--font-display); font-size: 12px; font-weight: 800; color: var(--primary); letter-spacing: .3px; }
.strategy__center { background: var(--primary); color: var(--on-primary); border-radius: var(--r-xl); padding: 16px 24px; font-family: var(--font-display); font-size: 13px; font-weight: 800; letter-spacing: .5px; display: inline-block; }
.strategy__text h3 { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); margin-bottom: 16px; }
.strategy__text p { font-size: 15px; line-height: 1.8; color: var(--body); margin-bottom: 16px; }
.strategy__list { margin-top: 28px; display: flex; flex-direction: column; gap: 14px; }
.strategy__list-item { display: flex; align-items: flex-start; gap: 12px; font-size: 14px; line-height: 1.6; color: var(--body); }
.strategy__list-bullet { width: 6px; height: 6px; min-width: 6px; border-radius: 50%; background: var(--primary); margin-top: 8px; }

.fin-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 48px; }
.fin-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.06); border-radius: var(--r-xl); padding: 36px 28px; text-align: center; transition: all .3s; }
.fin-card:hover { background: rgba(255,255,255,.08); }
.fin-card__number { font-family: var(--font-display); font-size: 42px; font-weight: 800; color: var(--on-dark); letter-spacing: -1px; line-height: 1; margin-bottom: 8px; }
.fin-card__number span { font-size: 24px; }
.fin-card__caption { font-size: 13px; font-weight: 500; line-height: 1.5; color: var(--on-dark-soft); }
.fin-note { text-align: center; font-size: 13px; color: rgba(255,255,255,.35); font-style: italic; }

.cap-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.cap-card { background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 36px 32px; display: flex; gap: 24px; align-items: flex-start; transition: all .35s; }
.cap-card:hover { border-color: var(--color-border-strong); }
.cap-card__icon { width: 52px; height: 52px; min-width: 52px; background: rgba(0,75,135,.06); border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; color: var(--primary); }
.cap-card__title { font-family: var(--font-display); font-size: 17px; font-weight: 800; color: var(--ink); margin-bottom: 8px; }
.cap-card__desc { font-size: 14px; line-height: 1.7; color: var(--body); }

.partner-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; margin-bottom: 64px; }
.partner-intro__text h3 { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); margin-bottom: 16px; }
.partner-intro__text p { font-size: 15px; line-height: 1.8; color: var(--body); }
.partner-intro__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.partner-stat { text-align: center; padding: 28px 16px; background: rgba(0,75,135,.03); border-radius: var(--r-xl); }
.partner-stat__num { font-family: var(--font-display); font-size: 36px; font-weight: 800; color: var(--primary); line-height: 1; margin-bottom: 8px; }
.partner-stat__label { font-size: 12px; font-weight: 600; color: var(--muted); line-height: 1.4; }
.partner-logos { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.partner-logo {
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-lg);
  padding: 20px 16px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 140px;
  gap: 6px;
  transition: border-color .25s, box-shadow .25s, transform .25s;
  text-align: center; text-decoration: none;
}
.partner-logo:hover { border-color: var(--storm-200); box-shadow: 0 6px 16px rgba(0,30,54,.06); transform: translateY(-2px); }
.partner-logo__img {
  max-width: 100%; max-height: 64px;
  width: auto; height: auto; object-fit: contain;
  filter: grayscale(40%); opacity: .85;
  transition: filter .25s, opacity .25s;
}
.partner-logo:hover .partner-logo__img { filter: grayscale(0%); opacity: 1; }
.partner-logo__name { font-family: var(--font-display); font-weight: 800; font-size: 14px; color: var(--muted); letter-spacing: -.3px; transition: color .3s; line-height: 1.3; }
.partner-logo:hover .partner-logo__name { color: var(--primary); }
.partner-logo__sub { font-size: 11px; font-weight: 500; color: var(--muted-soft); }
@media (max-width: 1024px) { .partner-logos { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .partner-logos { grid-template-columns: repeat(2, 1fr); } .partner-logo { height: 120px; } }

/* ─── [1-1] HISTORY INTRO ─── */
.history-intro { font-size: 15px; line-height: 1.8; color: var(--body); max-width: 760px; margin-bottom: 48px; }

/* ─── [1-3] STRATEGY SUB-LABELS ─── */
.strat-sub-label { font-family: var(--font-display); font-size: 18px; font-weight: 800; color: var(--ink); margin-bottom: 28px; display: flex; align-items: center; gap: 12px; letter-spacing: -.3px; }
.strat-sub-label__tag { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; background: var(--primary); color: var(--on-primary); font-size: 12px; font-weight: 800; letter-spacing: 0; flex-shrink: 0; }

/* ─── [1-3-1] VISION TIMELINE ─── */
.vision-timeline { display: flex; align-items: stretch; justify-content: center; gap: 0; margin-bottom: 48px; }
.vision-phase { flex: 1; max-width: 320px; background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 32px 28px; display: flex; flex-direction: column; transition: all .35s; }
.vision-phase:hover { border-color: var(--color-border-strong); }
.vision-phase__badge { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vision-phase__ver { font-family: var(--font-display); font-size: 13px; font-weight: 800; color: var(--on-primary); background: var(--primary); padding: 4px 12px; border-radius: var(--r-pill); letter-spacing: .3px; }
.vision-phase__period { font-size: 13px; font-weight: 600; color: var(--muted); }
.vision-phase__title { font-family: var(--font-display); font-size: 17px; font-weight: 800; color: var(--ink); margin-bottom: 10px; letter-spacing: -.3px; }
.vision-phase__desc { font-size: 14px; line-height: 1.7; color: var(--body); flex: 1; }
.vision-phase__arrow { display: flex; align-items: center; justify-content: center; flex-shrink: 0; width: 48px; }

/* ─── [1-3-3] GLOBAL MAP SECTION ─── */
.global-map-section { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; margin-bottom: 16px; }
.global-map__text h3 { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); margin-bottom: 16px; letter-spacing: -.5px; }
.global-map__text p { font-size: 15px; line-height: 1.8; color: var(--body); margin-bottom: 24px; }
.global-map__flags { display: flex; flex-wrap: wrap; gap: 8px; }
.global-flag { display: inline-flex; align-items: center; gap: 6px; background: var(--surface-soft); border: 1px solid var(--hairline-soft); border-radius: var(--r-sm); padding: 5px 10px; transition: all .25s; }
.global-flag:hover { border-color: var(--primary); background: rgba(0,75,135,.03); }
.global-flag img { width: 20px; height: 14px; object-fit: cover; border-radius: 2px; }
.global-flag__code { font-family: var(--font-display); font-size: 11px; font-weight: 700; color: var(--muted); letter-spacing: .5px; }
.global-map__visual { display: flex; align-items: center; justify-content: center; }
.global-map__placeholder { width: 100%; }

/* ─── [1-4] FINANCIAL — CREDIT RATING ─── */
.fin-credit { margin-top: 36px; text-align: center; }
.fin-credit__inner { display: inline-flex; align-items: center; gap: 16px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-xl); padding: 18px 32px; }
.fin-credit__label { font-size: 13px; font-weight: 600; color: var(--on-dark-soft); }
.fin-credit__grade { font-family: var(--font-display); font-size: 28px; font-weight: 800; color: var(--on-dark); letter-spacing: -.5px; }
.fin-credit__agency { font-size: 12px; color: var(--on-dark-soft); opacity: .7; }

/* ─── [1-5] CAPABILITY STACK ─── */
.cap-stack { display: flex; flex-direction: column; gap: 24px; }
.cap-item { background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 36px 36px 32px; transition: all .35s; }
.cap-item:hover { border-color: var(--primary); box-shadow: var(--shadow-md); }
.cap-item__head { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.cap-item__icon { width: 44px; height: 44px; min-width: 44px; background: rgba(0,75,135,.06); border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; color: var(--primary); }
.cap-item__badge { font-family: var(--font-display); font-size: 11px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; color: var(--on-primary); background: var(--primary); padding: 4px 12px; border-radius: var(--r-pill); }
.cap-item__title { font-family: var(--font-display); font-size: 19px; font-weight: 800; color: var(--ink); margin-bottom: 10px; letter-spacing: -.3px; }
.cap-item__desc { font-size: 14px; line-height: 1.75; color: var(--body); margin-bottom: 20px; max-width: 800px; }
.cap-item__highlights { display: flex; flex-wrap: wrap; gap: 12px 24px; margin-bottom: 16px; }
.cap-item__hl { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink); font-weight: 600; }
.cap-item__hl svg { flex-shrink: 0; }
.cap-item__certs { display: flex; flex-wrap: wrap; gap: 10px 20px; }
.cap-item__cert { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--body); }
.cap-item__cert svg { flex-shrink: 0; }
.cap-item__img-slot { display: none; }
.cap-item__img-slot[data-img]:not([data-img=""]) { display: block; margin-top: 20px; border-radius: var(--r-lg); overflow: hidden; background: var(--surface-soft); min-height: 120px; }

/* ─── [1-6] PARTNERSHIP SUB-SECTIONS ─── */
.part-sub-label { font-family: var(--font-display); font-size: 18px; font-weight: 800; color: var(--ink); margin-bottom: 12px; display: flex; align-items: center; gap: 12px; letter-spacing: -.3px; }
.part-sub-desc { font-size: 14px; line-height: 1.7; color: var(--body); margin-bottom: 24px; max-width: 720px; }

/* Research Partners */
.research-partners { }
.research-group { }
.research-group__title { font-family: var(--font-display); font-size: 14px; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.research-group__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.research-group__grid--intl { grid-template-columns: repeat(3, 1fr); }
.research-card {
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-lg);
  padding: 24px 22px; text-align: center;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 160px; gap: 12px;
  transition: border-color .25s, box-shadow .25s, transform .25s;
}
.research-card:hover { border-color: var(--storm-200); box-shadow: 0 6px 16px rgba(0,30,54,.06); transform: translateY(-2px); }
.research-card__logo { flex: 1; align-self: stretch; display: flex; align-items: center; justify-content: center; }
.research-card__logo img { max-height: 100px; max-width: 80%; width: auto; height: auto; object-fit: contain; filter: grayscale(40%); opacity: .85; transition: filter .25s, opacity .25s; }
.research-card:hover .research-card__logo img { filter: grayscale(0%); opacity: 1; }
.research-card__name { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: var(--ink); letter-spacing: -.2px; line-height: 1.35; margin: 0; }
/* Text-only card (international universities) — same width, smaller height */
.research-card--text {
  height: 96px;
  justify-content: center; padding: 18px 20px;
}
.research-card--text .research-card__name { font-size: 14px; font-weight: 700; color: var(--cloud-700); margin-bottom: 0; }
@media (max-width: 1024px) { .research-group__grid, .research-group__grid--intl { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .research-group__grid, .research-group__grid--intl { grid-template-columns: 1fr; } .research-card { height: auto; min-height: 180px; } }
.research-card__detail { font-size: 12px; line-height: 1.5; color: var(--muted); }
.research-card--intl { height: auto; min-height: 180px; padding: 24px 16px 18px; gap: 10px; }
.research-card--intl .research-card__logo { flex: 1; }
.research-card--intl .research-card__logo img { max-height: 80px; }
.research-card__caption { font-size: 12px; font-weight: 600; color: var(--cloud-500); line-height: 1.4; text-align: center; }
.research-card__country { font-weight: 500; color: var(--cloud-400); }

/* National Partner Flags */
/* ── Three.js waving flags (per-item) ── */
.flag3d-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  margin-top: 32px;
}
.flag3d-item {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.flag3d-canvas {
  width: 80%; aspect-ratio: 8 / 5;
  border-radius: var(--r-md); overflow: hidden;
}
.flag3d-canvas canvas { width: 100%; height: 100%; display: block; }
.flag3d-name {
  font-family: var(--font-display); font-size: 13px; font-weight: 700;
  color: var(--cloud-700); letter-spacing: -.2px;
}
@media (max-width: 1024px) { .flag3d-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .flag3d-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; } }

.cta-banner { text-align: center; padding: 80px 40px; }
.cta-banner__title { font-family: var(--font-display); font-size: 32px; font-weight: 800; letter-spacing: -.5px; color: var(--ink); margin-bottom: 16px; }
.cta-banner__desc { font-size: 16px; line-height: 1.7; color: var(--body); max-width: 520px; margin: 0 auto 36px; }
.cta-banner__btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-text); font-weight: 700; font-size: 16px; color: var(--on-primary); background: var(--primary); padding: 16px 32px; border-radius: var(--r-pill); transition: all .3s; border: none; cursor: pointer; }
.cta-banner__btn:hover { background: var(--primary-active); }
.cta-banner__btn svg { transition: transform .25s; }
.cta-banner__btn:hover svg { transform: translateX(3px); }

/* ─── 반응형 미디어 쿼리 종합 ─── */
@media(max-width:1024px){
  .biz-grid{grid-template-columns:repeat(2,1fr)}
  .fin-grid{grid-template-columns:repeat(2,1fr)}
  .strategy-layout{grid-template-columns:1fr;gap:40px}
  .partner-intro{grid-template-columns:1fr;gap:40px}
  .partner-logos{grid-template-columns:repeat(3,1fr)}
  .global-map-section{grid-template-columns:1fr;gap:32px}
  .vision-phase{max-width:260px}
  .research-group__grid{grid-template-columns:repeat(2,1fr)}
  .research-group__grid--intl{grid-template-columns:repeat(3,1fr)}
  .figures__grid { grid-template-columns: repeat(2, 1fr); gap: 32px 0; }
  .figures__item { padding: 0 28px; }
  .figures__item:nth-child(odd) { border-left: none; padding-left: 0; }
  .figures__item:nth-child(3), .figures__item:nth-child(4) { padding-top: 32px; border-top: 1px solid var(--hairline); }
  .partners__item { width: 168px; height: 84px; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
  .news__grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
}

@media(max-width:768px){
  .container { padding: 0 24px; }
  /* News header: 제목 한 줄, 인스타 아래로 */
  .news__header { flex-direction: column; align-items: stretch; gap: 16px; margin-bottom: 28px; }
  .news__header-right { align-items: flex-end; }
  .news__insta-label { text-align: right; }
  /* 뉴스 그리드: 1열, 카드 2개만 표시 */
  .news__grid { grid-template-columns: 1fr; }
  .news__grid .news__card:nth-child(n+3) { display: none; }
  /* Quicknav mobile */
  .quicknav__panel { height: 120px; }
  .quicknav__panel:hover { height: 120px; }
  .quicknav__panel-content { padding: 0 20px; }
  .quicknav__panel-inner { flex-direction: row; align-items: center; justify-content: space-between; gap: 12px; }
  .quicknav__panel-text { flex: 1; min-width: 0; }
  .quicknav__panel-num { font-size: 11px; margin-bottom: 6px; }
  .quicknav__panel-title { font-size: 18px; letter-spacing: -0.3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .quicknav__panel-desc { display: none; }
  .quicknav__panel-cta { opacity: 1; transform: none; font-size: 0; padding: 0; border: none; border-radius: 0; width: auto; height: auto; min-width: 0; justify-content: center; align-items: center; flex-shrink: 0; background: transparent; color: #fff; }
  .quicknav__panel-cta svg { width: 22px; height: 22px; flex-shrink: 0; stroke-width: 2; }
  .hero__slogan { letter-spacing: -1px; }
  .page-hero { height: 520px; padding-bottom: 40px; }
  .page-hero__desc { white-space: normal; word-break: keep-all; }
  .sec{padding:64px 0}
  .biz-grid{grid-template-columns:1fr}
  .cap-grid{grid-template-columns:1fr}
  .fin-grid{grid-template-columns:1fr 1fr}
  .partner-intro__stats{grid-template-columns:1fr 1fr 1fr;gap:12px}
  .partner-logos{grid-template-columns:repeat(2,1fr)}
  /* Who We Are — Vision timeline vertical */
  .vision-timeline{flex-direction:column;align-items:stretch;gap:0}
  /* Who We Are — History timeline: respect container margin */
  .hist-box-wrap { padding: 0 24px; }
  .vision-phase{max-width:100%}
  .vision-phase__arrow{width:auto;height:36px;transform:rotate(90deg)}
  /* Global map */
  .global-map-section{grid-template-columns:1fr;gap:24px}
  .global-map__text h3{font-size:19px}
  .global-flag{padding:4px 8px}
  .global-flag__code{font-size:10px}
  /* Financial credit */
  .fin-credit__inner{flex-direction:column;gap:8px;padding:16px 24px}
  .fin-credit__grade{font-size:24px}
  /* Capability */
  .cap-item{padding:28px 24px}
  .cap-item__title{font-size:17px}
  .cap-item__highlights{gap:8px 16px}
  .cap-item__hl{font-size:12px}
  .cap-item__cert{font-size:12px}
  /* Partnership research & national */
  .research-group__grid{grid-template-columns:1fr 1fr}
  .research-group__grid--intl{grid-template-columns:repeat(2,1fr)}
  .research-card{padding:18px 16px}
  .research-card__name{font-size:14px}
  /* legacy small-flag rules retired — handled in modern .national-flag block */
  /* Sub labels */
  .strat-sub-label{font-size:16px;margin-bottom:20px}
  .part-sub-label{font-size:16px}
  .figures__grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .figures__item { border-left: none; border-bottom: none; padding: 0 0 24px 0; }
  .figures__item:last-child { padding-bottom: 0; }
  .figures__number { font-size: 44px; }
  .partners__item { width: 144px; height: 72px; padding: 14px; }
  .footer__inner { grid-template-columns: 1fr; gap: 32px; }
  .footer__brand, .footer__desc, .footer__col-title, .footer__link, .footer__bottom { text-align: left; }
  .footer__inner > div:not(.footer__brand) { padding-left: 0; }
  .news__card-img { height: 180px; }
  .footer__bottom { flex-direction: column-reverse; align-items: flex-start; gap: 12px; }
}
/* ─── OUR PEOPLE ─── */
.people-intro { text-align: center; max-width: 680px; margin: 0 auto 64px; }
.people-intro__text { font-size: 17px; line-height: 1.8; color: var(--body); }

.founder-section { display: block; max-width: 760px; }
.founder-letter { padding-top: 8px; }
.founder-letter__name { font-family: var(--font-display); font-size: 28px; font-weight: 800; color: var(--ink); margin-bottom: 4px; }
.founder-letter__role { font-size: 15px; font-weight: 600; color: var(--primary); margin-bottom: 28px; }
.founder-letter__body { font-size: 15px; line-height: 1.85; color: var(--body); margin-bottom: 28px; }
.founder-letter__para { margin-bottom: 18px; }
.founder-letter__para:last-child { margin-bottom: 0; }
.founder-letter__cv { display: flex; flex-direction: column; gap: 20px; margin-top: 28px; padding-top: 24px; }
.founder-cv__label { font-size: 13px; font-weight: 800; color: var(--ink); margin-bottom: 8px; letter-spacing: .3px; text-transform: uppercase; }
.founder-cv__entry { position: relative; font-size: 14px; line-height: 1.6; color: var(--body); padding: 4px 0 4px 14px; }
.founder-cv__entry a { color: var(--primary); text-decoration: underline; text-underline-offset: 2px; }
.founder-cv__period { font-size: 13px; color: var(--muted); margin-left: 4px; }
.founder-cv__memorial { margin-top: 20px; font-size: 13px; color: var(--muted); font-style: italic; }
/* Phase 6-1: Education/Career as a vertical timeline — data/copy unchanged, presentation only */
.founder-cv__block { position: relative; padding-left: 24px; }
.founder-cv__block::before { content: ''; position: absolute; left: 6px; top: 6px; bottom: 6px; width: 2px; background: var(--storm-200); }
.founder-cv__entry::before { content: ''; position: absolute; left: -21.5px; top: 50%; transform: translateY(-50%); width: 9px; height: 9px; border-radius: 50%; background: var(--primary); }

.bio-timeline { display: flex; flex-direction: column; gap: 24px; }
.bio-period { display: grid; grid-template-columns: 140px 1fr; gap: 20px; padding: 20px 24px; background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); transition: all .3s; }
.bio-period:hover { border-color: var(--primary); box-shadow: var(--shadow-md); }
.bio-period__label { font-family: var(--font-display); font-size: 13px; font-weight: 800; color: var(--primary); letter-spacing: .3px; padding-top: 2px; }
.bio-period__desc { font-size: 14px; line-height: 1.7; color: var(--body); }
.founder-legacy { margin-top: 28px; padding: 20px 24px; background: rgba(0,75,135,.03); border-radius: var(--r-lg); font-size: 14px; line-height: 1.7; color: var(--body); font-style: italic; }

.ceo-section { display: grid; grid-template-columns: 1fr 360px; gap: 64px; align-items: start; }
.ceo-letter { padding-top: 8px; }
.ceo-letter__name { font-family: var(--font-display); font-size: 28px; font-weight: 800; color: var(--ink); margin-bottom: 4px; }
.ceo-letter__role { font-size: 15px; font-weight: 600; color: var(--primary); margin-bottom: 28px; }
.ceo-letter__body { position: relative; font-size: 15px; line-height: 1.85; color: var(--body); margin-bottom: 28px; white-space: pre-line; padding-left: 28px; }
.ceo-letter__body::before { content: "\201C"; position: absolute; left: -8px; top: -18px; font-family: Georgia, 'Times New Roman', serif; font-size: 96px; line-height: 1; color: var(--primary); opacity: .12; pointer-events: none; }
.ceo-letter__body::after { content: "\201D"; font-family: Georgia, 'Times New Roman', serif; font-size: 96px; line-height: 0; color: var(--primary); opacity: .12; vertical-align: -32px; margin-left: 4px; pointer-events: none; }
.ceo-letter__sig { font-family: var(--font-display); font-size: 15px; font-weight: 700; color: var(--ink); font-style: italic; }
.ceo-portrait { position: relative; border-radius: var(--r-xl); overflow: hidden; background: linear-gradient(135deg, var(--storm-50) 0%, var(--storm-100) 100%); aspect-ratio: 3/4; display: flex; align-items: center; justify-content: center; }
.ceo-portrait__icon { width: 120px; height: 120px; border-radius: 50%; background: rgba(0,75,135,.08); display: flex; align-items: center; justify-content: center; color: var(--primary); }

.board-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; }
.board-card { background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 32px 24px; text-align: center; transition: all .35s; }
.board-card:hover { border-color: var(--color-border-strong); }
.board-card__avatar { width: 72px; height: 72px; border-radius: 50%; background: rgba(0,75,135,.06); display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; color: var(--primary); }
.board-card__name { font-family: var(--font-display); font-size: 17px; font-weight: 800; color: var(--ink); margin-bottom: 6px; }
.board-card__role { font-size: 13px; line-height: 1.5; color: var(--muted); }

/* Advisory — swipe carousel as full-section backdrop */
#advisory.sec { position: relative; }
#advisory .sec__title, #advisory .sec__subtitle { position: relative; z-index: 2; }
.adv { margin-top: 36px; width: 100vw; margin-left: calc(-50vw + 50%); position: relative; }
.adv__scroll {
  overflow-x: auto; overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 14px 0 22px;
  cursor: grab;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.adv__scroll::-webkit-scrollbar { width: 0; height: 0; display: none; }
.adv__scroll:active { cursor: grabbing; }
@media (prefers-reduced-motion: reduce) { .adv__scroll { scroll-behavior: auto; } }

/* Header row: title left, prev/next buttons right (same line as title) */
.adv__header {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 24px; margin-bottom: 8px;
}
.adv__header-text { flex: 1; min-width: 0; }
.adv__header-text .sec__subtitle { margin-bottom: 0; }
.adv__header-nav { display: flex; gap: 8px; flex-shrink: 0; padding-top: 6px; }
.adv__nav {
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid var(--hairline); background: #fff;
  color: var(--storm-700); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(0,30,54,.08);
  transition: background .2s, border-color .2s, transform .2s, opacity .2s;
}
.adv__nav:hover { background: var(--storm-50); border-color: var(--storm-300); }
.adv__nav:active { transform: scale(.94); }
.adv__nav[disabled] { opacity: .35; pointer-events: none; }
@media (max-width: 720px) {
  .adv__header { flex-wrap: wrap; }
  .adv__nav { width: 40px; height: 40px; }
}
.adv__fan {
  display: flex; gap: 0; width: max-content; margin: 0;
  padding-inline: max(24px, calc((100vw - 1180px) / 2));
}
.adv-card {
  position: relative; flex: 0 0 260px; width: 260px; height: 348px;
  cursor: pointer; user-select: none; perspective: 1600px;
  scroll-snap-align: center;
  transition: transform var(--duration-base) var(--ease-out);
}
.adv-card + .adv-card { margin-left: -50px; }   /* 50px overlap — tighter spacing */
.adv-card:hover { transform: translateY(-10px); z-index: 5; }
.adv-card.is-active { position: fixed; top: 50%; left: 50%; margin: 0; width: 360px; height: 480px;
  z-index: 1300; transform-origin: 50% 50%;
  transform: translate(-50%, -50%) !important;
  transition: transform var(--duration-slow) var(--ease-out); }
.adv-card__inner { position: relative; width: 100%; height: 100%; transform-style: preserve-3d;
  transition: transform 420ms var(--ease-out); }
/* active flip + return direction is JS-driven via inline transform (see renderWhatWeDo) */
/* backdrop */
.adv__backdrop { position: fixed; inset: 0; z-index: 1200; background: rgba(0,30,54,.5); opacity: 0; visibility: hidden; transition: opacity var(--duration-base) var(--ease-out), visibility var(--duration-base); }
.adv__backdrop.is-open { opacity: 1; visibility: visible; }
.adv-card__face { position: absolute; inset: 0; backface-visibility: hidden; -webkit-backface-visibility: hidden; border-radius: var(--radius-xl); overflow: hidden; display: flex; flex-direction: column; box-shadow: var(--shadow-md); }
/* FRONT — Motif 04 layered translucency on corporate gradient */
.adv-card__front { background: var(--gradient-corporate); color: #fff; }
.adv-card__art { position: absolute; inset: 0; overflow: hidden; }
.adv-card__art span { position: absolute; border-radius: 50%; background: rgba(255,255,255,.14); will-change: transform; }
/* Motion Library #04 — Layered clouds: 3-layer parallax drift, 12–22s ease-in-out alternate */
.adv-card__art span:nth-child(1) { width: 150%; height: 62%; top: 6%;  left: -28%; background: rgba(255,255,255,.14); animation: advDrift1 18s var(--ease-in-out) infinite alternate; }
.adv-card__art span:nth-child(2) { width: 140%; height: 56%; top: 26%; left: -10%; background: rgba(255,255,255,.11); animation: advDrift2 22s var(--ease-in-out) infinite alternate; }
.adv-card__art span:nth-child(3) { width: 120%; height: 48%; top: 44%; left: -22%; background: rgba(255,255,255,.09); animation: advDrift3 15s var(--ease-in-out) infinite alternate; }
@keyframes advDrift1 { from { transform: translate(0,0) rotate(-22deg); } to { transform: translate(7%,-5%) rotate(-15deg); } }
@keyframes advDrift2 { from { transform: translate(0,0) rotate(-14deg); } to { transform: translate(-6%,4%) rotate(-22deg); } }
@keyframes advDrift3 { from { transform: translate(0,0) rotate(-26deg); } to { transform: translate(5%,6%) rotate(-18deg); } }
@media (prefers-reduced-motion: reduce) { .adv-card__art span { animation: none; } }
.adv-card__fbody { position: relative; z-index: 1; flex: 1; display: flex; flex-direction: column; justify-content: flex-end; padding: 28px 26px; text-align: left; }
.adv-card__id { text-align: left; }
.adv-card__name { font-family: var(--font-display); font-size: 22px; font-weight: 800; font-style: italic; color: #fff; letter-spacing: -.3px; line-height: 1.2; }
.adv-card__front .adv-card__field { display: block; font-family: var(--font-sans); font-size: 15px; font-weight: 500; color: rgba(255,255,255,.85); text-transform: none; letter-spacing: 0; margin-top: 4px; }
.adv-card__tagline { font-size: 14px; line-height: 1.55; color: rgba(255,255,255,.92); text-align: left; margin: 18px 0; }
.adv-card__more { font-size: 12px; font-weight: 700; transition: color var(--duration-base) var(--ease-out); }
.adv-card__front .adv-card__more { text-align: left; color: rgba(255,255,255,.7); }
.adv-card:hover .adv-card__front .adv-card__more { color: #fff; }
/* BACK — solid storm */
.adv-card__back { background: var(--storm-700); transform: rotateY(180deg); color: #fff; padding: 30px 28px; }
.adv-card__back .adv-card__field { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--storm-300); }
.adv-card__back-name { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: #fff; margin: 8px 0 18px; letter-spacing: -.3px; }
.adv-card__bio { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,.82); flex: 1; }
.adv-card__back .adv-card__more { margin-top: auto; color: rgba(255,255,255,.6); }

/* Org chart — vertical, DS-clean */
.org-chart { display: flex; flex-direction: column; align-items: center; margin-top: 48px; }
.org-chart__trunk { display: flex; flex-direction: column; align-items: center; }
.org-trunk-line { width: 2px; height: 80px; background: var(--cloud-200); flex-shrink: 0; }
.org-node { width: 220px; padding: 16px 24px; border-radius: var(--r-pill); text-align: center; display: flex; flex-direction: column; align-items: center; gap: 3px; }
.org-node__label { font-family: var(--font-display); font-size: 15px; font-weight: 700; letter-spacing: .2px; line-height: 1; }
.org-node__tag { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; }
.org-node--board { background: var(--color-bg-elev); border: 1px solid var(--cloud-200); color: var(--cloud-700); }
.org-node--board .org-node__tag { color: var(--cloud-400); }
.org-node--ceo { background: var(--storm-600); color: #fff; }
.org-node--ceo .org-node__tag { color: var(--storm-300); }
.org-trunk-line--down { height: 40px; }

.org-chart__divisions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; width: 100%; }
.org-card { background: var(--color-bg-elev); border: 1px solid var(--cloud-100); border-radius: var(--radius-lg); overflow: hidden; align-self: start; transition: border-color var(--duration-base) var(--ease-out); }
.org-card.is-open { border-color: var(--storm-300); }
.org-card__main { width: 100%; min-height: 88px; display: flex; align-items: center; gap: 16px; padding: 20px 22px; cursor: pointer; background: transparent; border: 0; text-align: left; font: inherit; transition: background var(--duration-base) var(--ease-out); }
.org-card__main:hover { background: var(--cloud-50); }
.org-card__num { font-family: var(--font-mono); font-size: 13px; font-weight: 700; color: var(--cloud-400); line-height: 1; flex-shrink: 0; }
.org-card.is-open .org-card__num { color: var(--storm-600); }
.org-card__name { font-family: var(--font-display); font-size: 16px; font-weight: 700; color: var(--cloud-900); letter-spacing: -.2px; flex: 1; line-height: 1.35; }
.org-card__chevron { color: var(--cloud-400); flex-shrink: 0; transition: transform var(--duration-base) var(--ease-out), color var(--duration-base) var(--ease-out); }
.org-card.is-open .org-card__chevron { transform: rotate(180deg); color: var(--storm-600); }
.org-card__teams { max-height: 0; overflow: hidden; transition: max-height var(--duration-slow) var(--ease-out); }
.org-card.is-open .org-card__teams { max-height: 360px; }
.org-card__teams-inner { list-style: none; margin: 0; padding: 4px 22px 20px 22px; display: flex; flex-direction: column; }
.org-card__team { font-size: 13px; font-weight: 500; color: var(--cloud-600); padding: 9px 0 9px 16px; border-left: 2px solid var(--cloud-100); }
.org-card__team:hover { color: var(--storm-700); border-left-color: var(--storm-300); }
/* ─── OVERSEAS CORPORATION (org-chart 우상단 세로) ─── */
.org-chart { position: relative; }
.org-overseas--side {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
  padding: 14px 18px;
  background: var(--cloud-50);
  border: 1px solid var(--cloud-100);
  border-radius: var(--radius-lg);
}
.org-overseas__label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--cloud-400);
  white-space: nowrap;
}
.org-overseas__item {
  height: 22px;
  display: flex;
  align-items: center;
}
.org-overseas__item img {
  height: 100%;
  width: auto;
  object-fit: contain;
  opacity: .7;
  transition: opacity var(--duration-base) var(--ease-out);
}
.org-overseas__item img:hover { opacity: 1; }
@media (max-width: 768px) {
  .org-overseas--side { position: static; flex-direction: row; flex-wrap: wrap; justify-content: center; align-items: center; margin-top: 28px; margin-bottom: 0; }
  .org-overseas__item { height: 18px; }
}

.koica-banner { display: flex; align-items: center; gap: 16px; padding: 20px 28px; background: linear-gradient(135deg, #004887 0%, #003a6c 100%); border-radius: var(--r-xl); color: var(--on-dark); }
.koica-banner__icon { width: 48px; height: 48px; min-width: 48px; border-radius: var(--r-lg); background: rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; }
.koica-banner__text { font-size: 14px; font-weight: 600; line-height: 1.5; }

/* ─── WHAT WE DO: 3D GLOBE ─── */
.globe-section { position: relative; overflow: visible; }
.globe-scroll-wrap {
  position: relative; width: 100%; transition: all .8s cubic-bezier(.22,1,.36,1);
  border-radius: var(--r-xl); overflow: hidden;
}
.globe-scroll-wrap--expanded {
  width: 100vw; margin-left: calc(-50vw + 50%); border-radius: 0;
}
.globe-wrap {
  position: relative; background: var(--storm-900);
  padding: 0; overflow: hidden; min-height: 560px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
}
.globe-canvas {
  display: block; margin: 0 auto; position: relative; z-index: 2;
  max-width: 100%; touch-action: none;
}
.globe-legend {
  display: flex; justify-content: center; gap: 28px; margin-top: 32px;
  flex-wrap: wrap; position: relative; z-index: 2;
}
.globe-legend__item { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: rgba(255,255,255,.55); letter-spacing: .3px; }
.globe-legend__dot { width: 10px; height: 10px; border-radius: 50%; }

.globe-tooltip { position: fixed; z-index: 1000; background: rgba(0,36,68,.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); border-radius: var(--r-lg); padding: 16px 20px; pointer-events: none; opacity: 0; transition: opacity .2s; max-width: 320px; box-shadow: 0 16px 48px rgba(0,0,0,.4); }
.globe-tooltip--visible { opacity: 1; }
.globe-tooltip__title { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.globe-tooltip__count { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.5); margin-bottom: 10px; }
.globe-tooltip__list { list-style: none; }
.globe-tooltip__list li { font-size: 12px; line-height: 1.6; color: rgba(255,255,255,.75); padding-left: 14px; position: relative; }
.globe-tooltip__list li::before { content: '›'; position: absolute; left: 0; color: rgba(255,255,255,.35); font-weight: 700; }

/* ═══════════════════════════════════════════════
   WHAT WE DO — EDITORIAL ATLAS REDESIGN
   ═══════════════════════════════════════════════ */

/* ── SHARED SECTION HEAD ── */
.wd-sec { padding: clamp(56px, 7vw, 96px) 0; scroll-margin-top: 116px; }
.wd-sechead { max-width: 800px; margin-bottom: 64px; }
.wd-sechead__tag { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.wd-sechead__no {
  font-family: var(--font-display); font-size: 13px; font-weight: 800;
  letter-spacing: .5px; color: #fff; background: var(--primary);
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.wd-sechead__no--light { background: var(--storm-300); color: var(--storm-900); }
.wd-sechead__kicker {
  font-family: var(--font-display); font-size: 13px; font-weight: 800;
  letter-spacing: 2px; text-transform: uppercase; color: var(--primary);
}
.wd-sechead__kicker--light { color: var(--storm-300); }
.wd-sechead__title {
  font-family: var(--font-display); font-size: clamp(32px, 4vw, 52px);
  font-weight: 800; line-height: 1.12; letter-spacing: -1.6px; color: var(--ink);
}
.wd-sechead__title--light { color: #fff; }
.wd-sechead__sub {
  margin-top: 20px; font-size: 17px; line-height: 1.7; color: var(--body); max-width: 64ch;
}
.wd-sechead__sub--light { color: rgba(255,255,255,.62); }

/* ── [3-1] STRATEGY CARDS ── */
.wd-strategymap { background: var(--canvas); }
.strat-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.strat-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--canvas); border: 1px solid var(--hairline);
  border-radius: var(--r-lg); padding: 40px 34px 32px;
  overflow: hidden;
  transition: transform .45s var(--ease-out), box-shadow .45s var(--ease-out), border-color .3s;
}
.strat-card__rail {
  position: absolute; top: 0; left: 0; width: 100%; height: 4px;
  background: var(--sc); transform: scaleX(0); transform-origin: left;
  transition: transform .5s var(--ease-out);
}
.strat-card:hover {
  transform: translateY(-8px); box-shadow: var(--shadow-lg); border-color: transparent;
}
.strat-card:hover .strat-card__rail { transform: scaleX(1); }
.strat-card__head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px;
}
.strat-card__no {
  font-family: var(--font-display); font-size: 11px; font-weight: 800;
  letter-spacing: 1.4px; text-transform: uppercase; color: var(--sc);
}
.strat-card__index {
  font-family: var(--font-display); font-size: 58px; font-weight: 800;
  line-height: .8; letter-spacing: -3px;
  color: transparent; -webkit-text-stroke: 1.5px color-mix(in srgb, var(--sc) 32%, transparent);
  transition: -webkit-text-stroke-color .4s, color .4s;
}
.strat-card:hover .strat-card__index {
  -webkit-text-stroke-color: transparent;
  color: color-mix(in srgb, var(--sc) 12%, transparent);
}
.strat-card__title {
  font-family: var(--font-display); font-size: 25px; font-weight: 800;
  letter-spacing: -.6px; line-height: 1.22; color: var(--ink); margin-bottom: 8px;
}
.strat-card__label {
  font-size: 13px; font-weight: 700; color: var(--sc); margin-bottom: 20px;
}
.strat-card__desc {
  font-size: 14.5px; line-height: 1.78; color: var(--body); flex: 1; margin-bottom: 28px;
}
.strat-card__more {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-size: 13px; font-weight: 800;
  color: var(--sc); letter-spacing: .2px;
  padding-top: 18px; border-top: 1px solid var(--hairline);
}
.strat-card__more svg { transition: transform .3s var(--ease-out); }
.strat-card:hover .strat-card__more svg { transform: translateX(5px); }

/* ── EWS VALUE CHAIN ── */
.wd-valuechain {
  position: relative; padding: clamp(56px, 7vw, 96px) 0;
  background: linear-gradient(165deg, #00132A 0%, #002D51 55%, #003C6C 100%);
  overflow: hidden;
}
.wd-valuechain__bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 20% 30%, rgba(102,149,188,.18) 0%, transparent 45%),
                    radial-gradient(circle at 85% 75%, rgba(51,115,159,.22) 0%, transparent 50%);
}
.wd-valuechain .container { position: relative; z-index: 2; }
.vc-flow {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-lg); overflow: hidden;
}
.vc-step {
  background: linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.015) 100%);
  padding: 34px 28px 32px;
  transition: background .35s;
}
.vc-step:hover { background: rgba(255,255,255,.07); }
.vc-step__rule { display: flex; align-items: center; gap: 12px; margin-bottom: 22px; }
.vc-step__no {
  font-family: var(--font-display); font-size: 17px; font-weight: 800;
  color: #fff; flex-shrink: 0;
  width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--storm-500), var(--storm-700));
  border: 1px solid rgba(255,255,255,.22);
}
.vc-step__track { flex: 1; height: 1px; background: rgba(255,255,255,.14); }
.vc-step__title {
  font-family: var(--font-display); font-size: 17px; font-weight: 800;
  color: #fff; line-height: 1.32; margin-bottom: 8px;
}
.vc-step__summary {
  font-size: 13px; line-height: 1.6; color: var(--storm-300);
  margin-bottom: 20px; padding-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.vc-step__list { display: flex; flex-direction: column; gap: 11px; }
.vc-step__list li {
  position: relative; padding-left: 16px;
  font-size: 13px; line-height: 1.6; color: rgba(255,255,255,.74);
}
.vc-step__list li::before {
  content: ''; position: absolute; left: 0; top: 7px;
  width: 5px; height: 5px; border-radius: 50%; background: var(--storm-400);
}

/* ── GLOBE SECTION HEAD ── */
.globe-section { background: var(--canvas); }

/* ── Accumulating sticky pillar header bars (Naver-style) ── */
.wd-stick-stack {
  position: fixed;
  left: 0; right: 0;
  z-index: 60;
  display: flex; flex-direction: column;
  pointer-events: none;
}
.wd-stickbar {
  height: 52px;
  display: block;
  background: rgba(255,255,255,0.92);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--hairline);
  color: var(--ink);
  text-decoration: none;
  opacity: 0;
  transform: translateY(-100%);
  pointer-events: none;
  transition: opacity .35s var(--ease-out), transform .35s var(--ease-out), background .25s, color .25s;
}
.wd-stickbar__inner {
  height: 100%;
  display: flex; align-items: center;
  gap: 18px;
}
.wd-stickbar.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.wd-stickbar:hover { background: rgba(255,255,255,1); color: var(--storm-700); }
.wd-stickbar__num {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--storm-500);
  font-variant-numeric: tabular-nums;
  min-width: 28px;
}
.wd-stickbar__rule { width: 28px; height: 1px; background: var(--storm-400); }
.wd-stickbar__title {
  font-family: var(--font-display);
  font-size: 15px; font-weight: 700;
  letter-spacing: -.2px;
  color: var(--ink);
}
@media (max-width: 720px) {
  .wd-stickbar { height: 46px; }
  .wd-stickbar__inner { gap: 12px; }
  .wd-stickbar__rule { width: 18px; }
  .wd-stickbar__title { font-size: 13.5px; }
  .wd-stickbar__num { font-size: 12px; }
}

/* ── STRATEGY PILLAR SECTIONS (Editorial split + motif) ── */
.wd-pillar {
  position: relative; padding: 0 0 45px;
  scroll-margin-top: 116px;
  background: var(--canvas);
  overflow: hidden;
}
/* All strategy sections share the same background — no alt fill */
.wd-pillar--soft { background: var(--canvas); }

/* — Editorial header band — */
.wd-pillar__band {
  background: transparent;
  padding: 64px 0 48px;
  margin-bottom: 24px;
}
.wd-pillar__band-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  gap: 80px;
  align-items: center;
}
.wd-pillar__band-text { max-width: 640px; }
.wd-pillar__meta {
  display: flex; align-items: center; gap: 18px;
  margin-bottom: 28px;
}
.wd-pillar__num {
  font-family: var(--font-display);
  font-size: 56px; font-weight: 200;
  letter-spacing: -1.5px; line-height: 1;
  color: var(--storm-700);
  font-variant-numeric: tabular-nums;
}
.wd-pillar__meta-rule {
  flex: 0 0 64px; height: 1px;
  background: var(--storm-400);
}
.wd-pillar__kicker {
  font-family: var(--font-display); font-size: 12.5px; font-weight: 800;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--storm-600);
}
.wd-pillar__title {
  font-family: var(--font-display); font-size: 52px;
  font-weight: 700; line-height: 1.08; letter-spacing: -1.4px;
  color: var(--ink); margin-bottom: 28px;
}
.wd-pillar__desc {
  font-size: 17px; line-height: 1.75; color: var(--body);
  max-width: 56ch;
}
.wd-pillar__motif {
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.wd-pillar__motif-frame {
  position: relative;
  width: 100%;
  max-width: 380px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  background: var(--canvas);
  box-shadow: 0 30px 70px -32px rgba(0, 30, 54, 0.35);
  border: 1px solid var(--hairline);
}
.wd-pillar__motif-frame svg.biz-motif {
  width: 100%; height: 100%; display: block;
}

/* — Hero photo (still kept) — */
.wd-pillar__figure { margin: 75px 0 24px; padding: 0; }
.wd-pillar__hero {
  width: 100vw; margin-left: calc(-50vw + 50%);
  overflow: hidden; aspect-ratio: 24 / 8; max-height: 720px;
  position: relative; background: var(--surface-soft);
}
.wd-pillar__hero img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 900ms var(--ease-out);
}
.wd-pillar__hero:hover img { transform: scale(1.03); }
.wd-pillar__hero-caption {
  text-align: center;
  font-size: 12px; font-style: italic;
  color: var(--muted); letter-spacing: .2px;
  margin: 14px auto 0; max-width: 80ch;
}

/* — Projects collapsible section — */
.wd-proj-section { margin-top: 8px; }
.wd-proj-section__toggle {
  width: 100%; appearance: none;
  background: transparent; border: 0;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  padding: 22px 4px;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  color: var(--ink);
  cursor: pointer;
  text-align: left;
  transition: padding-left .25s var(--ease-out);
}
.wd-proj-section__toggle:hover { padding-left: 10px; }
.wd-proj-section__label {
  font-family: var(--font-display);
  font-size: 14px; font-weight: 800;
  letter-spacing: 1.6px; text-transform: uppercase;
  color: var(--ink);
}
.wd-proj-section__action {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--storm-600);
  font-family: var(--font-display);
  font-size: 12px; font-weight: 800;
  letter-spacing: 1.4px; text-transform: uppercase;
}
.wd-proj-section__count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 28px; height: 24px; padding: 0 8px;
  border-radius: var(--r-pill);
  border: 1px solid var(--hairline);
  background: var(--canvas);
  font-family: var(--font-display);
  font-size: 12px; font-weight: 800;
  color: var(--storm-700);
  font-variant-numeric: tabular-nums;
}
.wd-proj-section__chevron {
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform .35s var(--ease-out);
}
.wd-proj-section[data-open="true"] .wd-proj-section__chevron {
  transform: rotate(180deg);
}
.wd-proj-section[data-open="true"] .wd-proj-section__action {
  color: var(--ink);
}
.wd-proj-section__panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 480ms var(--ease-out);
}
.wd-proj-section[data-open="true"] .wd-proj-section__panel {
  grid-template-rows: 1fr;
}
.wd-proj-section__inner {
  min-height: 0;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}
.wd-proj-section[data-open="true"] .wd-proj-section__inner {
  /* Once open, let vertical card shadows/hover lift escape — keep horizontal clipped */
  overflow: visible hidden;
}
.wd-proj-section__inner-pad {
  min-width: 0;
  max-width: 100%;
  padding-top: 36px;
  padding-bottom: 8px;
}
.wd-proj-section__inner-pad .biz-swipe { margin-top: 0; max-width: 100%; }

/* ── ACCORDION LIST ── */
.acc-list {
  display: flex; flex-direction: column;
  margin-top: 48px;
  border-top: 2px solid var(--ink);
}
.acc-item {
  border-bottom: 1px solid var(--hairline);
  transition: background .25s;
}
.acc-item--open { background: color-mix(in srgb, var(--pc) 4%, transparent); }

/* Trigger (closed state) */
.acc-trigger {
  width: 100%; display: grid;
  grid-template-columns: 52px 1fr 40px;
  align-items: center; gap: 20px;
  padding: 24px 4px 24px 0;
  background: none; border: none; cursor: pointer;
  text-align: left;
  transition: opacity .2s;
}
.acc-trigger:hover { opacity: .82; }
.acc-trigger__num {
  font-family: var(--font-display); font-size: 13px; font-weight: 800;
  letter-spacing: .5px; color: var(--pc); flex-shrink: 0;
}
.acc-trigger__main {
  display: flex; flex-direction: column; gap: 8px; min-width: 0;
}
.acc-trigger__tags {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.acc-tag {
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 500;
  padding: 3px 10px; border-radius: var(--r-pill);
  color: var(--pc);
  background: color-mix(in srgb, var(--pc) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--pc) 24%, transparent);
  white-space: nowrap;
}
.acc-trigger__title {
  font-family: var(--font-display); font-size: clamp(17px, 2vw, 22px);
  font-weight: 800; letter-spacing: -.4px; line-height: 1.3;
  color: var(--ink);
}
.acc-trigger__icon {
  width: 36px; height: 36px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--pc) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--pc) 22%, transparent);
  transition: background .25s, transform .4s var(--ease-out);
}
.acc-trigger__icon svg {
  width: 18px; height: 18px;
  color: var(--pc);
  transition: transform .4s var(--ease-out);
}
.acc-item--open .acc-trigger__icon svg { transform: rotate(180deg); }
.acc-item--open .acc-trigger__icon {
  background: var(--pc);
  border-color: var(--pc);
}
.acc-item--open .acc-trigger__icon svg { color: #fff; }

/* Panel (collapsed → expanded) */
.acc-panel {
  max-height: 0; overflow: hidden;
  transition: max-height .5s var(--ease-out);
}
.acc-panel__inner {
  display: grid; grid-template-columns: 320px 1fr; gap: 40px;
  padding: 8px 4px 40px;
}
.acc-panel__ph {
  aspect-ratio: 4 / 3; border-radius: var(--r-md);
  background:
    repeating-linear-gradient(45deg,
      color-mix(in srgb, var(--pc) 6%, transparent) 0 10px,
      transparent 10px 20px),
    color-mix(in srgb, var(--pc) 8%, var(--canvas));
  border: 1px solid color-mix(in srgb, var(--pc) 20%, transparent);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px;
  color: color-mix(in srgb, var(--pc) 55%, var(--muted));
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
}
.acc-panel__body { display: flex; flex-direction: column; justify-content: center; }
.acc-panel__desc { font-size: 15.5px; line-height: 1.85; color: var(--body); max-width: 66ch; }

/* ── PROJECT PHOTO CARDS (text top · image bottom) ── */
.proj-cards {
  display: flex;
  gap: 24px;
  margin-top: 48px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: 4px 0 20px;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--pc) 40%, transparent) transparent;
}
.proj-cards::-webkit-scrollbar { height: 6px; }
.proj-cards::-webkit-scrollbar-track { background: transparent; }
.proj-cards::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--pc) 35%, transparent);
  border-radius: var(--r-pill);
}
.proj-card {
  position: relative;
  flex: 0 0 clamp(300px, 30vw, 380px);
  scroll-snap-align: start;
  display: flex; flex-direction: column;
  background: #fff;
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(0,30,54,.06), 0 1px 1px rgba(0,30,54,.04);
  transition: box-shadow 240ms var(--ease-out), transform 240ms var(--ease-out);
}
.proj-card:hover {
  box-shadow: 0 20px 48px rgba(0,30,54,.12), 0 6px 12px rgba(0,30,54,.06);
  transform: translateY(-3px);
}
.proj-card__text {
  padding: 36px 40px 28px;
  display: flex; flex-direction: column; gap: 14px;
}
.proj-card__eyebrow {
  font-family: var(--font-display); font-size: 12px; font-weight: 700;
  letter-spacing: .6px; color: var(--pc);
}
.proj-card__title {
  font-family: var(--font-display);
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 800; letter-spacing: -.5px; line-height: 1.28;
  color: var(--ink); margin: 0;
}
.proj-card__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.proj-tag {
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 500;
  padding: 3px 10px; border-radius: var(--r-pill);
  color: var(--pc);
  background: color-mix(in srgb, var(--pc) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--pc) 24%, transparent);
  white-space: nowrap;
}
.proj-card__desc {
  font-size: 14.5px; line-height: 1.8; color: var(--body); margin: 0;
}
.proj-card__media {
  position: relative;
  margin-top: auto;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--surface-soft);
}
.proj-card__media::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, transparent 50%, #fff 100%);
  z-index: 1;
  pointer-events: none;
}
.proj-card__media img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
  transition: transform 600ms var(--ease-out);
}
.proj-card:hover .proj-card__media img { transform: scale(1.04); }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .wd-pillar { padding-bottom: 64px; }
  .wd-pillar__band { padding: 64px 0 48px; margin-bottom: 24px; }
  .wd-pillar__band-grid { grid-template-columns: 1fr; gap: 48px; }
  .wd-pillar__motif-frame { max-width: 420px; margin: 0 auto; }
  .wd-pillar__title { font-size: 40px; letter-spacing: -1px; }
  .wd-pillar__num { font-size: 44px; }
  .wd-pillar__hero { margin-bottom: 36px; aspect-ratio: 16 / 9; }
  .proj-card { flex: 0 0 82vw; }
  .proj-card__text { padding: 28px 24px 22px; }
}
@media (max-width: 720px) {
  .wd-pillar__band { padding: 52px 0 40px; margin-bottom: 20px; }
  .wd-pillar__band-grid { gap: 36px; }
  .wd-pillar__title { font-size: 30px; letter-spacing: -.6px; margin-bottom: 20px; }
  .wd-pillar__num { font-size: 36px; }
  .wd-pillar__meta { gap: 12px; margin-bottom: 20px; }
  .wd-pillar__meta-rule { flex-basis: 36px; }
  .wd-pillar__desc { font-size: 15px; line-height: 1.7; }
  .wd-pillar__motif-frame { max-width: 320px; }
}
@media (max-width: 768px) {
  .wd-sechead { margin-bottom: 40px; }
  .vc-flow { grid-template-columns: 1fr; }
  .strat-card { padding: 28px 22px; }
  .acc-trigger { grid-template-columns: 36px 1fr 32px; padding: 18px 0; }
  .acc-trigger__title { font-size: 16px; }
  .acc-panel__inner { grid-template-columns: 1fr; gap: 20px; }
  .acc-panel__ph { aspect-ratio: 16/7; }
}
.news__more { text-align: center; margin-top: 40px; }
.news__more-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-size: 14px; font-weight: 700;
  color: var(--primary); padding: 12px 28px;
  border: 1.5px solid var(--primary); border-radius: var(--r-pill);
  transition: all .25s;
}
.news__more-btn:hover { background: var(--primary); color: #fff; }
/* News toolbar — tag chips + search */
/* Toolbar — chips + search (Hanwha-style) */
.news-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; flex-wrap: wrap; margin-bottom: 40px;
}
.news-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.news-chip {
  padding: 11px 22px; border-radius: var(--r-pill);
  border: 0; background: transparent;
  color: var(--cloud-600); font-family: var(--font-display);
  font-weight: 700; font-size: 14px; letter-spacing: .1px;
  cursor: pointer; transition: background .2s, color .2s;
}
.news-chip:hover { color: var(--ink); background: var(--cloud-50); }
.news-chip.is-active { background: var(--ink); color: #fff; }

.news-search { position: relative; flex: 0 0 360px; max-width: 100%; }
.news-search svg { position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: var(--cloud-500); pointer-events: none; }
.news-search input {
  width: 100%; padding: 13px 48px 13px 22px;
  border-radius: var(--r-pill); border: 1px solid var(--cloud-200);
  background: var(--canvas); font-size: 14px; color: var(--ink);
  font-family: var(--font-sans); transition: border-color .2s, box-shadow .2s;
}
.news-search input::placeholder { color: var(--cloud-400); }
.news-search input:focus {
  outline: none; border-color: var(--cloud-400);
  box-shadow: 0 0 0 4px var(--cloud-50);
}
.news-empty {
  padding: 96px 24px; text-align: center; color: var(--muted);
  font-size: 14px; grid-column: 1 / -1;
  background: var(--surface-soft); border: 1px dashed var(--hairline);
  border-radius: var(--r-xl);
}
@media (max-width: 720px) {
  .news-toolbar { flex-direction: column; align-items: stretch; gap: 16px; }
  .news-search { flex: 1 1 auto; }
  /* Pin the chip row to the toolbar width so it scrolls its chips internally.
     Without an explicit width the nowrap row keeps its full content width and
     pushes the whole page into horizontal scroll. */
  .news-chips { width: 100%; min-width: 0; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  .news-chips::-webkit-scrollbar { display: none; }
  .news-chip { flex-shrink: 0; }
}

/* Cards (Hanwha-style — photo + meta + title + hashtags, no overlay tag) */
.news-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.news-card {
  background: transparent; border: 0; border-radius: 0;
  overflow: hidden; cursor: pointer; transition: transform .35s;
}
.news-card:hover { transform: translateY(-4px); }
.news-card__img {
  height: 280px; width: 100%;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  border-radius: var(--r-lg);
  background-color: var(--cloud-50);
}
.news-card__img--placeholder svg { width: 56px; height: 56px; }
.news-card__body { padding: 20px 4px 8px; }
.news-card__meta { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; font-size: 13px; }
.news-card__cat { font-family: var(--font-display); font-weight: 700; font-size: 13px; }
.news-card__sep { width: 1px; height: 12px; background: var(--cloud-200); }
.news-card__date { color: var(--cloud-500); font-size: 13px; font-weight: 500; }
.news-card__title {
  font-family: var(--font-display); font-size: 19px; font-weight: 800;
  color: var(--ink); letter-spacing: -.3px; line-height: 1.45;
  margin-bottom: 18px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-card__hashtags { display: flex; flex-wrap: wrap; gap: 6px; }
.news-card__hashtag {
  padding: 6px 12px; border-radius: var(--r-pill);
  background: var(--cloud-50); color: var(--cloud-700);
  font-size: 12px; font-weight: 600;
  transition: background .2s, color .2s;
}
.news-card:hover .news-card__hashtag { background: var(--cloud-100); color: var(--cloud-800); }
@media (max-width: 1024px) {
  .news-board { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .news-card__img { height: 240px; }
}
@media (max-width: 640px) {
  .news-board { grid-template-columns: 1fr; }
  .news-card__img { height: 220px; }
}

.news-modal { position: fixed; inset: 0; z-index: 2000; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.6); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); opacity: 0; visibility: hidden; transition: all .3s; padding: 40px; }
.news-modal--open { opacity: 1; visibility: visible; }
.news-modal__content { background: var(--canvas); border-radius: var(--r-xl); max-width: 680px; width: 100%; max-height: 80vh; overflow-y: auto; position: relative; box-shadow: var(--shadow-lg); }
.news-modal__header { padding: 20px 28px 16px; position: relative; }
.news-modal__close { position: absolute; top: 16px; right: 16px; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--hairline); background: var(--canvas); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .2s; color: var(--muted); z-index: 2; }
.news-modal__close:hover { border-color: var(--primary); color: var(--primary); }
.news-modal__tag { display: inline-block; font-size: 11px; font-weight: 700; color: #fff; padding: 4px 12px; border-radius: var(--r-sm); margin-bottom: 12px; }
.news-modal__title { font-family: var(--font-display); font-size: 24px; font-weight: 800; color: var(--ink); letter-spacing: -.5px; line-height: 1.3; margin-bottom: 8px; padding-right: 40px; }
.news-modal__date { font-size: 13px; color: var(--muted); }
.news-modal__body { padding: 0 28px 32px; }
.news-modal__desc { font-size: 15px; line-height: 1.8; color: var(--body); }

/* ─── INSIGHT ─── */
.pub-section { margin-bottom: 56px; }
.pub-section:last-child { margin-bottom: 0; }
.pub-section__header { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 2px solid var(--hairline); }
.pub-section__icon { width: 40px; height: 40px; min-width: 40px; border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; }
.pub-section__title { font-family: var(--font-display); font-size: 20px; font-weight: 800; color: var(--ink); letter-spacing: -.3px; }
.pub-section__desc { font-size: 13px; color: var(--muted); margin-top: 2px; }
.pub-list { display: flex; flex-direction: column; gap: 0; }
.pub-item { display: flex; align-items: center; gap: 20px; padding: 18px 20px; border-bottom: 1px solid var(--hairline-soft); transition: all .25s; cursor: pointer; border-radius: 0; }
.pub-item:last-child { border-bottom: none; }
.pub-item:hover { background: rgba(0,75,135,.02); padding-left: 24px; }
.pub-item__year { font-family: var(--font-display); font-size: 13px; font-weight: 800; color: var(--primary); min-width: 44px; }
.pub-item__title { font-size: 14px; font-weight: 600; color: var(--ink); flex: 1; line-height: 1.4; }
.pub-item__file { font-size: 11px; color: var(--muted); display: flex; align-items: center; gap: 6px; white-space: nowrap; }
.pub-item--featured { background: rgba(0,75,135,.03); border-radius: var(--r-lg); border-bottom: none; margin-bottom: 4px; }
.pub-item--featured .pub-item__title { font-weight: 800; color: var(--primary); }
.pub-item--featured::after { content: 'NEW'; font-size: 10px; font-weight: 800; color: #fff; background: var(--primary); padding: 2px 8px; border-radius: var(--r-sm); letter-spacing: .5px; }

/* ── PUBLICATION — unified bookshelf grid (chips + search + pagination) ── */
.pub-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; flex-wrap: wrap; margin: 24px 0 32px;
}
.pub-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.pub-chip {
  padding: 10px 20px; border-radius: var(--r-pill); border: 0; background: transparent;
  color: var(--cloud-600); font-family: var(--font-display); font-weight: 700; font-size: 13px;
  cursor: pointer; transition: background .2s, color .2s;
}
.pub-chip:hover { color: var(--ink); background: var(--cloud-50); }
.pub-chip.is-active { background: var(--ink); color: #fff; }
.pub-search { position: relative; flex: 0 0 320px; max-width: 100%; }
.pub-search svg { position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: var(--cloud-500); pointer-events: none; }
.pub-search input {
  width: 100%; padding: 12px 48px 12px 20px;
  border-radius: var(--r-pill); border: 1px solid var(--cloud-200);
  background: var(--canvas); font-size: 14px; color: var(--ink);
  font-family: var(--font-sans); transition: border-color .2s, box-shadow .2s;
}
.pub-search input::placeholder { color: var(--cloud-400); }
.pub-search input:focus { outline: none; border-color: var(--cloud-400); box-shadow: 0 0 0 4px var(--cloud-50); }

.pub-shelf {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 28px 24px; padding: 8px 4px 8px;
}
.pub-empty {
  grid-column: 1 / -1; padding: 80px 24px; text-align: center; color: var(--muted);
  font-size: 14px; background: var(--surface-soft); border: 1px dashed var(--hairline); border-radius: var(--r-xl);
}

/* Pagination — matches news-pagination style */
.pub-pagination { display: flex; justify-content: center; align-items: center; gap: 4px; margin-top: 48px; }
.pub-pagination__btn {
  width: 40px; height: 40px; border-radius: var(--r-md); border: 1px solid var(--hairline);
  background: var(--canvas); display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 14px; font-weight: 700; color: var(--muted);
  cursor: pointer; transition: all .25s;
}
.pub-pagination__btn:hover { border-color: var(--primary); color: var(--primary); }
.pub-pagination__btn.is-active { background: var(--primary); border-color: var(--primary); color: #fff; }
.pub-pagination__btn.is-active:hover { background: var(--primary); color: #fff; }
.pub-pagination__btn--arrow { color: var(--muted); }
.pub-pagination__btn--arrow:hover { color: var(--primary); }
.pub-pagination__btn:disabled { opacity: .3; cursor: default; pointer-events: none; }

/* Book cover — front face shown, hover lifts forward */
.pub-book {
  position: relative;
  border: 0; padding: 22px 20px 18px;
  width: 100%; aspect-ratio: 5 / 7;
  border-radius: 4px 8px 8px 4px;
  cursor: pointer; color: #fff;
  display: flex; flex-direction: column; justify-content: space-between;
  text-align: left;
  box-shadow:
    inset 6px 0 0 rgba(255,255,255,.10),
    inset -2px 0 0 rgba(0,0,0,.16),
    0 12px 24px rgba(0,15,40,.18);
  transition: transform .28s var(--ease-out), box-shadow .28s var(--ease-out), filter .25s;
  transform-origin: bottom center;
  font-family: var(--font-display);
  overflow: hidden;
}
.pub-book::after {
  /* subtle spine line on the left edge to evoke a real book */
  content: ''; position: absolute; top: 0; bottom: 0; left: 14px; width: 1px;
  background: rgba(255,255,255,.18); pointer-events: none;
}
.pub-book:hover { transform: translateY(-10px); filter: brightness(1.06); box-shadow: 0 22px 32px rgba(0,15,40,.26); }
.pub-book--active { transform: translateY(-12px); box-shadow: 0 24px 36px rgba(0,15,40,.32); outline: 2px solid var(--storm-300); outline-offset: 4px; }
.pub-book--featured {
  transform: translateY(-4px);
  box-shadow: 0 18px 28px rgba(0,15,40,.24);
}
.pub-book--has-cover { padding: 0; }
.pub-book--has-cover::after { display: none; }
.pub-book__cat {
  position: absolute; top: 12px; right: 12px;
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .5px; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--r-pill);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.pub-book__year {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 2px;
  color: rgba(255,255,255,.75);
}
.pub-book__title {
  font-size: 16px; font-weight: 800; letter-spacing: -.2px; line-height: 1.3;
  color: rgba(255,255,255,.98);
  display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
.pub-book__ribbon {
  position: absolute; top: 12px; right: -4px;
  font-family: var(--font-mono); font-size: 9px; font-weight: 800; letter-spacing: 1px;
  background: #F4B400; color: #1C2433;
  padding: 3px 8px; border-radius: 2px;
  box-shadow: 0 2px 4px rgba(0,0,0,.20);
}

/* Cover detail panel — shown when a book is clicked */
.pub-cover { margin-top: 24px; }
.pub-cover[hidden] { display: none; }
.pub-cover__card {
  display: grid; grid-template-columns: 220px 1fr; gap: 32px;
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-xl);
  padding: 24px; box-shadow: 0 12px 32px rgba(0,15,40,.10);
  animation: pubCoverIn .35s var(--ease-out);
}
@keyframes pubCoverIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.pub-cover__face {
  width: 220px; height: 300px;
  border-radius: 6px 8px 8px 6px;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 26px 22px; color: #fff;
  box-shadow:
    inset 6px 0 0 rgba(255,255,255,.06),
    inset -2px 0 0 rgba(0,0,0,.18),
    0 18px 30px rgba(0,15,40,.30);
  position: relative; overflow: hidden;
}
.pub-cover__face::after {
  content: ''; position: absolute; top: 0; bottom: 0; left: 8px; width: 1px;
  background: rgba(255,255,255,.20);
}
.pub-cover__year { font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 2px; color: rgba(255,255,255,.75); }
.pub-cover__title { font-family: var(--font-display); font-size: 22px; font-weight: 800; line-height: 1.25; letter-spacing: -.3px; }
.pub-cover__sig { font-family: var(--font-display); font-style: italic; font-size: 12px; color: rgba(255,255,255,.65); }
.pub-cover__info { position: relative; display: flex; flex-direction: column; gap: 12px; padding-right: 36px; }
.pub-cover__eyebrow { font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--storm-500); margin: 0; }
.pub-cover__h { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); letter-spacing: -.3px; line-height: 1.3; margin: 0; }
.pub-cover__desc { font-size: 14px; line-height: 1.7; color: var(--cloud-700); margin: 0; }
.pub-cover__dl {
  margin-top: auto; align-self: flex-start;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px; border-radius: var(--r-pill);
  background: var(--storm-600); color: #fff;
  font-family: var(--font-display); font-size: 13px; font-weight: 700;
  text-decoration: none;
  transition: background .2s;
}
.pub-cover__dl:hover { background: var(--storm-700); }
.pub-cover__close {
  position: absolute; top: 0; right: 0;
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--hairline); background: #fff;
  font-size: 18px; color: var(--cloud-500); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
}
.pub-cover__close:hover { background: var(--cloud-50); color: var(--ink); }

@media (max-width: 720px) {
  /* Mobile: fixed 2-column shelf → 2×2 per page (4 items), flip pages for the rest */
  .pub-shelf { grid-template-columns: repeat(2, 1fr); gap: 16px 12px; padding: 4px 2px; }
  .pub-book { padding: 16px 14px 12px; }
  .pub-book__title { font-size: 14px; -webkit-line-clamp: 3; }
  .pub-cover__card { grid-template-columns: 1fr; gap: 20px; padding: 18px; }
  .pub-cover__face { width: 180px; height: 240px; margin: 0 auto; }
  .pub-cover__info { padding-right: 0; }
}

/* DATA PLATFORM — Weather Intelligence API (kept simple) */
.dp-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin: 40px 0 48px; }
.dp-pillar { background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 28px 26px 24px; display: flex; flex-direction: column; gap: 10px; transition: border-color .25s, box-shadow .25s, transform .25s; }
.dp-pillar:hover { border-color: var(--storm-200); box-shadow: 0 6px 16px rgba(0,30,54,.06); transform: translateY(-2px); }
.dp-pillar__icon { width: 44px; height: 44px; border-radius: var(--r-lg); background: var(--storm-50); color: var(--storm-600); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-bottom: 4px; }
.dp-pillar__label { font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--storm-500); margin: 0; }
.dp-pillar__title { font-family: var(--font-display); font-size: 18px; font-weight: 800; color: var(--ink); letter-spacing: -.3px; line-height: 1.3; margin: 0; }
.dp-pillar__desc  { font-size: 14px; line-height: 1.7; color: var(--body); margin: 0; }

/* ── Data Platform: intro text ── */
.dp-intro { font-size: 15px; line-height: 1.75; color: var(--body); max-width: 680px; margin: -8px 0 48px; }

/* ── Section eyebrow label ── */
.dp-section-eyebrow { margin-bottom: 20px; }
.dp-section-label { display: inline-block; font-family: var(--font-mono); font-size: 10px; font-weight: 800; letter-spacing: 1.8px; text-transform: uppercase; color: var(--storm-500); margin-bottom: 8px; }
.dp-section-desc { font-size: 14px; color: var(--body); line-height: 1.65; margin: 0; max-width: 640px; }

/* ── Dataset category tabs ── */
.dp-datasets-wrap { margin-bottom: 64px; }
.dp-dataset-tabs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 20px 0 0; }
.dp-dataset-tab {
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-xl);
  padding: 18px 20px 16px; text-align: left; cursor: pointer; transition: all .2s;
  display: flex; flex-direction: column; gap: 6px;
}
.dp-dataset-tab:hover { border-color: var(--storm-200); box-shadow: 0 4px 12px rgba(0,30,54,.06); }
.dp-dataset-tab--active {
  background: var(--primary); border-color: var(--primary); box-shadow: 0 6px 20px rgba(0,75,135,.18);
}
.dp-dataset-tab__tag {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--storm-400); transition: color .2s;
}
.dp-dataset-tab--active .dp-dataset-tab__tag { color: rgba(255,255,255,.65); }
.dp-dataset-tab__name {
  font-family: var(--font-display); font-size: 14px; font-weight: 800; color: var(--ink);
  line-height: 1.3; letter-spacing: -.2px; transition: color .2s;
}
.dp-dataset-tab--active .dp-dataset-tab__name { color: #fff; }

/* ── Dataset detail panel ── */
.dp-dataset-panel { margin-top: 12px; }
.dp-panel-inner {
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-xl);
  padding: 22px 28px 26px; display: flex; flex-direction: column; gap: 20px;
}
.dp-panel__meta {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 20px;
  padding-bottom: 18px; border-bottom: 1px solid var(--hairline);
}
.dp-panel__desc { font-size: 13px; line-height: 1.65; color: var(--body); margin: 0; flex: 1; }
.dp-panel__source {
  font-size: 11px; color: var(--cloud-600); margin: 0; flex-shrink: 0;
  display: flex; align-items: center; gap: 6px;
  background: var(--storm-50); padding: 4px 10px 4px 8px; border-radius: 20px;
}
.dp-panel__source span { font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--storm-400); }
.dp-panel__vars { display: flex; flex-direction: column; gap: 12px; }
.dp-panel__vars-label {
  font-family: var(--font-mono); font-size: 11px; font-weight: 800; letter-spacing: 1.8px;
  text-transform: uppercase; color: var(--primary); margin: 0;
  display: flex; align-items: center; gap: 10px;
}
.dp-panel__var-count {
  font-size: 11px; font-weight: 600; color: var(--storm-400);
  letter-spacing: 0; text-transform: none; font-family: inherit;
}
.dp-var-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.dp-var-chip {
  display: inline-flex; align-items: center; gap: 0;
  background: var(--storm-50); border: 1px solid var(--hairline);
  border-radius: 6px; overflow: hidden; font-size: 12.5px;
}
.dp-var-chip__code {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .5px;
  color: #fff; background: var(--storm-600); padding: 4px 8px;
}
.dp-var-chip__label { padding: 4px 7px; color: var(--ink); font-weight: 600; }
.dp-var-chip__unit { padding: 4px 8px 4px 0; color: var(--cloud-600); font-size: 11px; }

/* ── Core values section wrap ── */
.dp-values-wrap { margin-bottom: 56px; }
.dp-values-wrap .dp-pillars { margin: 20px 0 0; }

/* ── Add-ons section ── */
.dp-addons-wrap { margin-bottom: 56px; }
.dp-addons { display: flex; flex-direction: column; gap: 14px; margin: 20px 0 0; }
.dp-addon {
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-xl);
  overflow: hidden; transition: border-color .25s, box-shadow .25s;
}
.dp-addon:hover { border-color: var(--storm-200); box-shadow: 0 8px 24px rgba(0,30,54,.08); }
.dp-addon__head { display: flex; align-items: flex-start; gap: 18px; padding: 26px 28px; }
.dp-addon__num {
  font-family: var(--font-mono); font-size: 11px; font-weight: 800; letter-spacing: 1px;
  color: var(--primary); padding-top: 3px; flex-shrink: 0;
}
.dp-addon__icon {
  width: 44px; height: 44px; border-radius: var(--r-lg);
  background: var(--storm-50); color: var(--storm-600);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.dp-addon__title-block { display: flex; flex-direction: column; gap: 8px; }
.dp-addon__title { font-family: var(--font-display); font-size: 17px; font-weight: 800; color: var(--ink); letter-spacing: -.2px; margin: 0; }
.dp-addon__desc { font-size: 13.5px; line-height: 1.7; color: var(--body); margin: 0; }
.dp-addon__examples {
  display: grid; grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--hairline);
}
.dp-addon__example {
  padding: 16px 20px; border-right: 1px solid var(--hairline);
  transition: background .2s;
}
.dp-addon__example:last-child { border-right: none; }
.dp-addon__example:hover { background: var(--storm-50); }
.dp-addon__example-name { display: block; font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.dp-addon__example-vars { font-size: 11px; font-family: var(--font-mono); color: var(--storm-500); line-height: 1.5; }

@media (max-width: 1024px) {
  .dp-dataset-tabs { grid-template-columns: repeat(2, 1fr); }
  .dp-addon__examples { grid-template-columns: 1fr; }
  .dp-addon__example { border-right: none; border-bottom: 1px solid var(--hairline); }
  .dp-addon__example:last-child { border-bottom: none; }
  .dp-dark-section .dp-addon__example { border-bottom-color: rgba(255,255,255,.07); }
}
@media (max-width: 640px) {
  .dp-dataset-tabs { grid-template-columns: 1fr 1fr; gap: 8px; }
  .dp-dataset-tab { padding: 14px 14px 12px; }
  .dp-panel-inner { padding: 18px 18px 20px; }
  .dp-panel__meta { flex-direction: column; gap: 10px; }
  .dp-addon__head { padding: 20px 20px; gap: 14px; }
}

/* ── Data Platform: dark animated section ── */
.dp-dark-section {
  position: relative;
  background: #00132A; /* storm-950 */
  overflow: hidden;
}
.dp-dark-bg {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse 80% 60% at 10% 20%, rgba(0,75,135,.55) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 75%, rgba(0,40,90,.50) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 55% 50%, rgba(0,100,180,.20) 0%, transparent 55%);
  animation: dpBgShift 14s ease-in-out infinite alternate;
}
@keyframes dpBgShift {
  0%   { opacity: 1;    transform: scale(1)    translateY(0px); }
  50%  { opacity: .85;  transform: scale(1.04) translateY(-12px); }
  100% { opacity: 1;    transform: scale(1.02) translateY(6px); }
}
.dp-dark-content { position: relative; z-index: 1; }
.dp-dark-title { color: #fff !important; }
.dp-dark-sub   { color: rgba(255,255,255,.65) !important; }
.dp-section-label--light {
  color: rgba(255,255,255,.45);
  border-color: rgba(255,255,255,.12);
}
.dp-dark-section .dp-dataset-tab {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.1);
  color: #fff;
}
.dp-dark-section .dp-dataset-tab:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.2);
  box-shadow: 0 4px 16px rgba(0,0,0,.25);
}
.dp-dark-section .dp-dataset-tab__tag { color: rgba(255,255,255,.4); }
.dp-dark-section .dp-dataset-tab__name { color: rgba(255,255,255,.85); }
.dp-dark-section .dp-dataset-tab--active {
  background: var(--primary);
  border-color: var(--primary);
  box-shadow: 0 6px 24px rgba(0,90,180,.45);
}
.dp-dark-section .dp-dataset-tab--active .dp-dataset-tab__tag  { color: rgba(255,255,255,.6); }
.dp-dark-section .dp-dataset-tab--active .dp-dataset-tab__name { color: #fff; }
.dp-dark-section .dp-panel-inner {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
  backdrop-filter: blur(8px);
}
.dp-dark-section .dp-panel__meta { border-bottom-color: rgba(255,255,255,.08); }
.dp-dark-section .dp-panel__desc  { color: rgba(255,255,255,.6); }
.dp-dark-section .dp-panel__source { background: rgba(255,255,255,.07); color: rgba(255,255,255,.5); }
.dp-dark-section .dp-panel__source span { color: rgba(255,255,255,.3); }
.dp-dark-section .dp-panel__vars-label { color: #5bb0ff; }
.dp-dark-section .dp-panel__var-count  { color: rgba(255,255,255,.35); }
.dp-dark-section .dp-var-chip {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.1);
}
.dp-dark-section .dp-var-chip__code  { background: rgba(0,90,170,.7); }
.dp-dark-section .dp-var-chip__label { color: rgba(255,255,255,.85); }
.dp-dark-section .dp-var-chip__unit  { color: rgba(255,255,255,.35); }
.dp-dark-section .dp-pillar {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
}
.dp-dark-section .dp-pillar:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}
.dp-dark-section .dp-pillar__icon { background: rgba(255,255,255,.07); color: #5bb0ff; }
.dp-dark-section .dp-pillar__label { color: rgba(255,255,255,.4); }
.dp-dark-section .dp-pillar__title { color: #fff; }
.dp-dark-section .dp-pillar__desc  { color: rgba(255,255,255,.65); }
.dp-dark-section .dp-addon {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
}
.dp-dark-section .dp-addon:hover {
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}
.dp-dark-section .dp-addon__num  { color: #5bb0ff; }
.dp-dark-section .dp-addon__icon { background: rgba(255,255,255,.07); color: #5bb0ff; }
.dp-dark-section .dp-addon__title { color: #fff; }
.dp-dark-section .dp-addon__desc  { color: rgba(255,255,255,.6); }
.dp-dark-section .dp-addon__examples { border-top-color: rgba(255,255,255,.08); background: rgba(0,0,0,.15); }
.dp-dark-section .dp-addon__example { border-right-color: rgba(255,255,255,.07); }
.dp-dark-section .dp-addon__example:hover { background: rgba(255,255,255,.05); }
.dp-dark-section .dp-addon__example-name { color: rgba(255,255,255,.9); }
.dp-dark-section .dp-addon__example-vars { color: rgba(255,255,255,.35); }

/* Meta — partners + reliability (2 columns under chapter 02) */
.dp-meta {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr); gap: 32px;
  padding: 28px 32px; background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-xl);
}
.dp-meta__col { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.dp-meta__col + .dp-meta__col { padding-left: 32px; border-left: 1px solid var(--hairline); }
.dp-meta__label { font-family: var(--font-mono); font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--storm-500); margin: 0; }
.dp-partners { display: flex; gap: 28px; flex-wrap: wrap; }
.dp-partner { font-family: var(--font-display); font-weight: 800; font-size: 16px; color: var(--cloud-800); letter-spacing: -.2px; }
.dp-reliability { font-size: 13.5px; color: var(--cloud-700); line-height: 1.7; margin: 0; }

@media (max-width: 1024px) {
  .dp-pillars { grid-template-columns: 1fr 1fr; }
  .dp-meta { grid-template-columns: 1fr; }
  .dp-meta__col + .dp-meta__col { padding-left: 0; border-left: none; padding-top: 24px; border-top: 1px solid var(--hairline); }
}
@media (max-width: 640px) {
  .dp-pillars { grid-template-columns: 1fr; }
  .dp-pillar { padding: 24px 22px; }
}

.talent-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 64px; }
.talent-card {
  position: relative;
  display: flex;
  background: var(--canvas);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  padding: 36px 32px 32px;
  transition: border-color .35s, transform .35s var(--ease-out), box-shadow .35s;
}
.talent-card:hover {
  border-color: var(--storm-200);
  transform: translateY(-6px);
  box-shadow: 0 24px 56px -28px rgba(0, 30, 54, 0.22);
}
.talent-card__inner {
  display: flex; flex-direction: column;
  width: 100%;
}
.talent-card__icon {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--canvas);
  border: 1px solid var(--hairline);
  box-shadow: 0 16px 36px -20px rgba(0, 30, 54, 0.28);
  color: var(--storm-700);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 28px;
  flex-shrink: 0;
  transition: color .35s, background .35s;
}
.talent-card:hover .talent-card__icon {
  background: var(--storm-50);
  color: var(--ink);
}
.talent-card__kicker {
  display: block;
  font-family: var(--font-display);
  font-size: 12.5px; font-weight: 800;
  color: var(--storm-500);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.talent-card__title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: -.4px;
  color: var(--ink);
  margin: 0;
}

.job-table { width: 100%; border-collapse: collapse; margin-bottom: 32px; }
.job-table th { text-align: left; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--muted); padding: 12px 16px; border-bottom: 2px solid var(--hairline); }
.job-table td { padding: 16px; border-bottom: 1px solid var(--hairline-soft); font-size: 14px; color: var(--body); }
.job-table tr:hover td { background: rgba(0,75,135,.02); }
.job-status { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; padding: 4px 12px; border-radius: var(--r-pill); }
/* Status badges — clear visual distinction */
.job-status {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-size: 12px; font-weight: 800;
  letter-spacing: .3px; padding: 7px 14px; border-radius: var(--r-pill);
  border: 1px solid transparent;
}
.job-status__dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; box-shadow: 0 0 0 3px rgba(255,255,255,.6); }
.job-status--open    { color: #15803d; background: #DCFCE7;  border-color: #BBF7D0; }
.job-status--open    .job-status__dot { background: #16A34A; box-shadow: 0 0 0 3px rgba(22,163,74,.18); }
.job-status--closed  { color: var(--cloud-600); background: var(--cloud-50); border-color: var(--cloud-100); }
.job-status--closed  .job-status__dot { background: var(--cloud-400); box-shadow: 0 0 0 3px rgba(160,165,176,.20); }
.job-status--special { color: #92400E; background: #FFF7E0;  border-color: #FCD34D; }
.job-status--special .job-status__dot { background: #F4B400; box-shadow: 0 0 0 3px rgba(244,180,0,.22); }

/* Vertical job list — one card per row, minimal monotone */
.job-list { display: flex; flex-direction: column; gap: 16px; margin-bottom: 32px; }
.job-card {
  position: relative;
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-xl);
  padding: 28px 32px; display: grid;
  grid-template-columns: 1fr auto; gap: 24px; align-items: center;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s, transform .25s;
}
.job-card:hover { border-color: var(--storm-200); box-shadow: 0 6px 16px rgba(0,30,54,.06); transform: translateY(-2px); }
.job-card--open { border-color: #BBF7D0; }
.job-card--open:hover { border-color: #16A34A; box-shadow: 0 10px 24px rgba(22,163,74,.12); }
.job-card--special { border-color: #FCD34D; }
.job-card--special:hover { border-color: #F4B400; box-shadow: 0 10px 24px rgba(244,180,0,.14); }
.job-card--closed { background: var(--surface-soft); }
.job-card--closed .job-card__title { color: var(--cloud-600); }
.job-card--closed .job-card__summary,
.job-card--closed .job-card__regions { color: var(--cloud-400); }
.job-card--closed:hover { border-color: var(--hairline); box-shadow: none; transform: none; }

.job-card__body { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.job-card__head { display: flex; align-items: baseline; gap: 14px; }
.job-card__num { font-family: var(--font-display); font-weight: 800; font-size: 13px; letter-spacing: 1px; color: var(--storm-300); }
.job-card__title { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); letter-spacing: -.4px; line-height: 1.25; margin: 0; }
.job-card__summary { font-size: 14px; line-height: 1.6; color: var(--cloud-700); margin: 0; }
.job-card__regions { font-size: 13px; line-height: 1.65; color: var(--cloud-500); margin: 0; }

.job-card__aside { display: flex; flex-direction: column; align-items: flex-end; gap: 14px; flex-shrink: 0; }
.job-card__apply {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-display); font-size: 13px; font-weight: 700;
  color: var(--storm-600); text-decoration: none;
  transition: color .2s, transform .2s;
}
.job-card__apply:hover { color: var(--storm-700); transform: translateX(2px); }
.job-card__apply--disabled { color: var(--cloud-500); cursor: default; pointer-events: none; }

@media (max-width: 720px) {
  .job-card { grid-template-columns: 1fr; padding: 22px 24px; }
  .job-card__aside { flex-direction: row; align-items: center; justify-content: space-between; }
}

.social-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.social-card { background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 36px 28px; text-align: center; transition: all .35s; }
.social-card:hover { border-color: var(--primary); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.social-card__icon { width: 64px; height: 64px; border-radius: 50%; background: rgba(0,75,135,.05); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; color: var(--primary); }
.social-card__name { font-family: var(--font-display); font-size: 20px; font-weight: 800; color: var(--ink); margin-bottom: 8px; }
.social-card__desc { font-size: 14px; line-height: 1.7; color: var(--body); }

/* ─── RESPONSIVE: NEW PAGE STYLES ─── */
@media (max-width: 1024px) {
  .founder-section { grid-template-columns: 1fr; gap: 32px; }
  .ceo-section { grid-template-columns: 1fr; gap: 32px; }
  .ceo-portrait { max-width: 280px; order: -1; }
  .pillar-grid { grid-template-columns: 1fr; }
  .pub-item { padding: 14px 16px; }
  .pub-item__file { display: none; }
  .dp-features { grid-template-columns: repeat(2, 1fr); }
  .talent-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .talent-card { padding: 28px 24px; }
  .talent-card__title { font-size: 20px; }
  .social-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .board-grid { grid-template-columns: repeat(2, 1fr); }
  .org-chart__divisions { grid-template-columns: 1fr; }
  .org-chart__trunk { width: 100%; }
  .org-node { width: 100%; }
  .news-board { grid-template-columns: 1fr; }
  .pub-section__header { flex-direction: column; align-items: flex-start; }
  .dp-features { grid-template-columns: 1fr; }
  .talent-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .talent-card { padding: 26px 22px; }
  .talent-card__title { font-size: 18px; }
  .talent-card__icon { width: 56px; height: 56px; margin-bottom: 22px; }
  .bio-period { grid-template-columns: 1fr; gap: 8px; }
  .news-modal { padding: 16px; }
  .globe-wrap { padding: 24px 16px; }
  .job-table { font-size: 13px; }
  .job-table th, .job-table td { padding: 12px 10px; }
}


/* ─── ANIMATED CIRCLE BACKGROUNDS (HOME) ─── */
.quicknav__panel { position: relative; overflow: hidden; }
.circle-bg { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.circle-bg__dot {
  position: absolute; border-radius: 50%;
  opacity: 0; transition: opacity .8s ease, border-color .8s ease, background .8s ease;
}
.circle-bg__dot--outline { background: transparent; }
.circle-bg--active .circle-bg__dot { opacity: 1; }

@keyframes floatCircle1 { 0% { transform: translate(-120%, 40%); opacity: 0; } 15% { opacity: 1; } 85% { opacity: 1; } 100% { transform: translate(120%, -60%); opacity: 0; } }
@keyframes floatCircle2 { 0% { transform: translate(110%, -30%); opacity: 0; } 15% { opacity: 1; } 85% { opacity: 1; } 100% { transform: translate(-130%, 50%); opacity: 0; } }
@keyframes floatCircle3 { 0% { transform: translate(-80%, -60%); opacity: 0; } 15% { opacity: 1; } 85% { opacity: 1; } 100% { transform: translate(100%, 80%); opacity: 0; } }
@keyframes floatCircle4 { 0% { transform: translate(90%, 70%); opacity: 0; } 15% { opacity: 1; } 85% { opacity: 1; } 100% { transform: translate(-110%, -40%); opacity: 0; } }
/* Decorative circles hold still when the user prefers reduced motion */
@media (prefers-reduced-motion: reduce) {
  .circle-bg__dot, .home-cta__circle { animation: none !important; }
}

/* ─── GLOBE TOOLTIP (persisted) ─── */
.globe-tooltip { position: fixed; z-index: 1000; background: rgba(0,20,40,.92); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-lg); padding: 16px 20px; pointer-events: none; opacity: 0; transition: opacity .2s; max-width: 320px; box-shadow: 0 16px 48px rgba(0,0,0,.5); }
.globe-tooltip--visible { opacity: 1; }
.globe-tooltip__title { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.globe-tooltip__count { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.45); margin-bottom: 10px; }
.globe-tooltip__list { list-style: none; }
.globe-tooltip__list li { font-size: 12px; line-height: 1.6; color: rgba(255,255,255,.7); padding-left: 14px; position: relative; }
.globe-tooltip__list li::before { content: '›'; position: absolute; left: 0; color: rgba(255,255,255,.3); font-weight: 700; }

/* ─── GLOBE POPUP CARD ─── */
.globe-popup {
  position: fixed; z-index: 1001;
  background: rgba(255,255,255,.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  padding: 24px; border-radius: var(--r-xl); width: 300px;
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .3s ease, visibility .3s ease, transform .3s ease;
  pointer-events: none;
}
.globe-popup--open { opacity: 1; visibility: visible; transform: translateY(0); pointer-events: auto; }
.globe-popup__close {
  position: absolute; top: 10px; right: 12px; border: none; background: none;
  font-size: 22px; cursor: pointer; color: #999; line-height: 1;
}
.globe-popup__close:hover { color: var(--ink); }
.globe-popup__title {
  font-family: var(--font-display); font-size: 18px; font-weight: 800;
  color: var(--primary); margin: 0 0 8px; letter-spacing: -.3px;
}
.globe-popup__company { font-size: 14px; font-weight: 600; color: var(--ink); margin: 0 0 8px; }
.globe-popup__desc { font-size: 13px; color: var(--body); line-height: 1.6; margin: 0 0 12px; }
.globe-popup__projects { border-top: 1px solid var(--hairline); padding-top: 12px; }
.globe-popup__projects-title { font-size: 11px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.globe-popup__project-item { font-size: 12px; color: var(--body); line-height: 1.5; padding: 4px 0 4px 14px; position: relative; }
.globe-popup__project-item::before { content: '›'; position: absolute; left: 0; color: var(--primary); font-weight: 700; }
.globe-popup__branch { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; font-weight: 800; color: #fff; background: var(--primary); padding: 2px 8px; border-radius: var(--r-sm); letter-spacing: .3px; margin-bottom: 8px; }
.globe-popup__info { border-top: 1px solid var(--hairline); padding-top: 10px; }
.globe-popup__info p { font-size: 11px; color: var(--muted); margin: 3px 0; line-height: 1.4; }

/* ─── GLOBE RESPONSIVE ─── */
@media (max-width: 768px) {
  .globe-wrap { padding: 32px 16px; min-height: 400px; }
  .globe-scroll-wrap--expanded { border-radius: 0; }
}

/* ─── NEWS PAGE PAGINATION ─── */
.news-pagination { display: flex; justify-content: center; align-items: center; gap: 4px; margin-top: 48px; }
.news-pagination__btn {
  width: 40px; height: 40px; border-radius: var(--r-md); border: 1px solid var(--hairline);
  background: var(--canvas); display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 14px; font-weight: 700; color: var(--muted);
  cursor: pointer; transition: all .25s;
}
.news-pagination__btn:hover { border-color: var(--primary); color: var(--primary); }
.news-pagination__btn--active { background: var(--primary); border-color: var(--primary); color: #fff; }
.news-pagination__btn--active:hover { background: var(--primary); color: #fff; }
.news-pagination__btn--arrow { color: var(--muted); }
.news-pagination__btn--arrow:hover { color: var(--primary); }
.news-pagination__btn:disabled { opacity: .3; cursor: default; pointer-events: none; }

/* ─── NEWS ARTICLE PAGE ─── */
/* News article (detail) — Hanwha newsroom style */
.news-art { padding: 64px 0 100px; background: var(--canvas); }
.news-art__crumbs {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--cloud-500);
  margin-bottom: 28px; letter-spacing: .2px;
}
.news-art__crumbs a { color: var(--cloud-500); text-decoration: none; transition: color .2s; }
.news-art__crumbs a:hover { color: var(--ink); }
.news-art__crumb-sep { color: var(--cloud-300); font-size: 11px; }
.news-art__head { max-width: 980px; margin: 0 auto 48px; }
.news-art__cat {
  display: inline-block; font-family: var(--font-display);
  font-size: 14px; font-weight: 700; letter-spacing: .2px;
  margin-bottom: 18px;
}
.news-art__title {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 44px); font-weight: 800;
  letter-spacing: -.5px; line-height: 1.28;
  color: var(--ink); margin: 0 0 24px;
}
.news-art__lead {
  font-size: 18px; line-height: 1.75; color: var(--cloud-700);
  margin: 0 0 32px; max-width: 880px;
}
.news-art__meta {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 16px;
  padding-top: 22px; border-top: 1px solid var(--hairline);
}
.news-art__meta-left { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.news-art__date {
  font-size: 13px; font-weight: 600; color: var(--cloud-600);
  font-family: var(--font-mono); letter-spacing: .3px;
}
.news-art__hashtags { display: flex; flex-wrap: wrap; gap: 6px; }
.news-art__hashtag {
  padding: 5px 11px; border-radius: var(--r-pill);
  background: var(--cloud-50); color: var(--cloud-700);
  font-size: 12px; font-weight: 600;
}
.news-art__hero {
  max-width: 1180px; margin: 0 auto 64px;
  border-radius: var(--r-lg); overflow: hidden;
  background: var(--cloud-50);
}
.news-art__hero img { width: 100%; height: auto; display: block; }
.news-art__body {
  max-width: 820px; margin: 0 auto 80px;
  font-size: 17px; line-height: 1.9; color: var(--cloud-800);
}
.news-art__body p { margin: 0 0 24px; }
.news-art__nav {
  max-width: 1180px; margin: 0 auto 32px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  padding-top: 32px; border-top: 1px solid var(--hairline);
}
.news-art__nav-item {
  display: flex; flex-direction: column; gap: 6px;
  padding: 18px 22px; border-radius: var(--r-lg);
  border: 1px solid var(--hairline); background: #fff;
  text-decoration: none; color: var(--ink);
  transition: border-color .2s, background .2s, transform .2s;
}
.news-art__nav-item:hover { border-color: var(--cloud-300); background: var(--cloud-50); transform: translateY(-2px); }
.news-art__nav-item--next { text-align: right; }
.news-art__nav-item--empty { opacity: .45; pointer-events: none; }
.news-art__nav-label {
  font-size: 11px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--cloud-500); font-family: var(--font-mono);
}
.news-art__nav-title {
  font-family: var(--font-display); font-weight: 700;
  font-size: 14px; color: var(--ink);
  display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden;
}
.news-art__back-wrap { display: flex; justify-content: center; margin-top: 12px; }
.news-art__back-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 28px; border-radius: var(--r-pill);
  border: 1px solid var(--cloud-200); background: #fff; color: var(--ink);
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  text-decoration: none; transition: background .2s, color .2s, border-color .2s;
}
.news-art__back-btn:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
@media (max-width: 720px) {
  .news-art { padding: 40px 0 64px; }
  .news-art__nav { grid-template-columns: 1fr; }
  .news-art__nav-item--next { text-align: left; }
  .news-art__title { font-size: 26px; }
  .news-art__lead { font-size: 16px; }
  .news-art__body { font-size: 16px; line-height: 1.8; }
}

/* legacy article styles (kept for backward compat — no longer rendered) */
.news-article-sec { background: var(--canvas); }
.news-article { max-width: 780px; margin: 0 auto; padding: 0 40px; }
.news-article__back { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--muted); margin-bottom: 40px; transition: color .2s; }
.news-article__back:hover { color: var(--primary); }
.news-article__tag { display: inline-block; font-size: 11px; font-weight: 700; color: #fff; padding: 5px 14px; border-radius: var(--r-sm); letter-spacing: .5px; margin-bottom: 20px; }
.news-article__title { font-family: var(--font-display); font-size: clamp(28px, 3.5vw, 42px); font-weight: 800; letter-spacing: -1px; color: var(--ink); line-height: 1.25; margin-bottom: 16px; }
.news-article__date { font-size: 14px; color: var(--muted); margin-bottom: 48px; padding-bottom: 32px; border-bottom: 1px solid var(--hairline); }
.news-article__body { font-size: 16px; line-height: 2; color: var(--body); margin-bottom: 64px; }
.news-article__body p { margin-bottom: 24px; }

.news-article__nav { border-top: 1px solid var(--hairline); padding-top: 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 48px; }
.news-article__nav-item { padding: 24px; border: 1px solid var(--hairline); border-radius: var(--r-lg); transition: all .3s; display: flex; flex-direction: column; gap: 8px; }
.news-article__nav-item:hover { border-color: var(--primary); box-shadow: 0 8px 24px rgba(0,75,135,.06); }
.news-article__nav-item--next { text-align: right; }
.news-article__nav-label { font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.news-article__nav-item--next .news-article__nav-label { justify-content: flex-end; }
.news-article__nav-title { font-family: var(--font-display); font-size: 15px; font-weight: 700; color: var(--ink); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.news-article__nav-item:hover .news-article__nav-title { color: var(--primary); }
.news-article__nav-item--empty { border: 1px dashed var(--hairline-soft); opacity: .4; pointer-events: none; }

.news-article__list-btn { display: flex; justify-content: center; margin-bottom: 80px; }
.news-article__list-btn a { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display); font-size: 14px; font-weight: 700; color: var(--primary); padding: 14px 32px; border: 1.5px solid var(--primary); border-radius: var(--r-pill); transition: all .25s; }
.news-article__list-btn a:hover { background: var(--primary); color: #fff; }

@media (max-width: 768px) {
  .news-article { padding: 0 24px; }
  .news-article__nav { grid-template-columns: 1fr; }
  .news-article__nav-item--next { text-align: left; }
  .news-article__nav-item--next .news-article__nav-label { justify-content: flex-start; }
}

/* ─── HOME CTA SECTION ─── */
.home-cta { position: relative; padding: 80px 0; overflow: hidden; background: linear-gradient(135deg, #001a33 0%, #003366 40%, #004887 100%); }
.home-cta__circles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.home-cta__circle {
  position: absolute; border-radius: 50%;
  will-change: transform;
  animation: ctaFloat linear infinite;
}
.home-cta__circle--filled { background: rgba(255,255,255,.04); }
.home-cta__circle--outline { background: transparent; border: 1.5px solid rgba(255,255,255,.06); }

@keyframes ctaFloat {
  0%   { transform: translate(0, 0); }
  25%  { transform: translate(var(--dx1), var(--dy1)); }
  50%  { transform: translate(var(--dx2), var(--dy2)); }
  75%  { transform: translate(var(--dx3), var(--dy3)); }
  100% { transform: translate(0, 0); }
}

.home-cta__inner { position: relative; z-index: 1; text-align: center; max-width: 760px; margin: 0 auto; }
.home-cta__label { font-size: 12px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.35); margin-bottom: 20px; }
.home-cta__title { font-family: var(--font-display); font-size: clamp(32px, 4vw, 48px); font-weight: 800; letter-spacing: -1.5px; color: #fff; line-height: 1.15; margin-bottom: 20px; }
.home-cta__desc { font-size: 16px; line-height: 1.75; color: rgba(255,255,255,.55); margin-bottom: 40px; }
.home-cta__actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.home-cta__btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-text); font-weight: 700; font-size: 15px; padding: 16px 32px; border-radius: var(--r-pill); transition: all .3s; border: none; cursor: pointer; }
.home-cta__btn--primary { color: var(--ink); background: #fff; }
.home-cta__btn--primary:hover { background: rgba(255,255,255,.9); box-shadow: 0 8px 32px rgba(0,0,0,.2); transform: translateY(-2px); }
.home-cta__btn--secondary { color: #fff; background: transparent; border: 1.5px solid rgba(255,255,255,.3); }
.home-cta__btn--secondary:hover { border-color: rgba(255,255,255,.6); background: rgba(255,255,255,.08); }
.home-cta__btn svg { transition: transform .25s; }
.home-cta__btn:hover svg { transform: translateX(3px); }

@media(max-width:768px){
  .home-cta__inner { text-align: left; margin: 0; }
  .home-cta__actions { justify-content: flex-start; }
}

/* ─── HOME NEWS INSTAGRAM BUTTON ─── */
.news__header-right { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.news__insta-label { font-size: 12px; color: var(--muted-soft); line-height: 1.5; text-align: right; }
.news__insta-btn { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: var(--muted); padding: 10px 20px; border: 1.5px solid var(--hairline); border-radius: var(--r-pill); transition: all .25s; white-space: nowrap; }
.news__insta-btn:hover { border-color: var(--storm-600); color: var(--storm-600); background: var(--storm-50); }
.news__insta-btn svg { width: 18px; height: 18px; }

/* ─── NEWS COUNTRY FLAGS ─── */
.news-flags { display: flex; gap: 0; align-items: center; margin-bottom: 10px; }
.news-flags__item { width: 26px; height: 26px; border-radius: 50%; overflow: hidden; border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0,0,0,.1); margin-right: -6px; position: relative; flex-shrink: 0; }
.news-flags__item:last-child { margin-right: 0; }
.news-flags__item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.news-flags--lg .news-flags__item { width: 32px; height: 32px; margin-right: -8px; }
.news-flags--article { margin-bottom: 20px; }
.news-flags--article .news-flags__item { width: 36px; height: 36px; margin-right: -8px; border-width: 2.5px; }

/* ─── FOOTER SOCIAL ICONS ─── */
.footer__social { display: flex; gap: 12px; margin-top: 20px; }
.footer__social-link { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.4); transition: all .25s; }
.footer__social-link:hover { border-color: rgba(255,255,255,.35); color: rgba(255,255,255,.85); background: rgba(255,255,255,.06); }

/* ─── HISTORY: SCROLL BOX ─── */
.hist-box-wrap { position: relative; }
.hist-box { height: calc(100vh - 640px); min-height: 360px; overflow-y: auto; scrollbar-width: auto; scrollbar-color: var(--storm-300) var(--cloud-100); }
.hist-box::-webkit-scrollbar { width: 8px; }
.hist-box::-webkit-scrollbar-track { background: var(--cloud-100); border-radius: 8px; }
.hist-box::-webkit-scrollbar-thumb { background: var(--storm-300); border-radius: 8px; }
.hist-box::-webkit-scrollbar-thumb:hover { background: var(--storm-500); }
.hist-box-fade { position: absolute; bottom: 0; left: 0; right: 0; height: 120px; background: linear-gradient(to bottom, transparent, var(--color-bg) 85%); pointer-events: none; transition: opacity .4s; }
.hist-box-fade--hidden { opacity: 0; }
.hist-scroll-hint { position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 4px; pointer-events: none; transition: opacity .4s; }
.hist-scroll-hint--hidden { opacity: 0; }
.hist-scroll-hint__text { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted-soft); }
.hist-scroll-hint__chevron { width: 18px; height: 18px; border-right: 2px solid var(--primary); border-bottom: 2px solid var(--primary); transform: rotate(45deg) translateY(-3px); opacity: .5; animation: hist-bounce .9s ease-in-out infinite; }
@keyframes hist-bounce { 0%,100% { transform: rotate(45deg) translateY(-3px); } 50% { transform: rotate(45deg) translateY(2px); } }

/* ─── BUSINESS STRUCTURE: DIAGONAL SLASH PANELS ─── */
.biz-slash-wrap { padding: 80px 0 var(--sp-section); scroll-margin-top: 116px; background: var(--surface-soft); }
.biz-slash-header { padding-bottom: 0px; }
.biz-slash { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.biz-pillar { position: relative; background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 36px 32px 32px; display: flex; flex-direction: column; gap: 24px; transition: border-color .3s, transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s; overflow: hidden; }
.biz-pillar:hover { border-color: var(--storm-200); transform: translateY(-6px); box-shadow: var(--shadow-md); }
.biz-pillar__head { display: flex; justify-content: space-between; align-items: flex-start; }
.biz-pillar__icon { width: 56px; height: 56px; border-radius: var(--r-lg); background: var(--storm-50); color: var(--storm-600); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .35s, color .35s; }
.biz-pillar__icon svg { width: 28px; height: 28px; }
.biz-pillar:hover .biz-pillar__icon { background: var(--gradient-corporate); color: #fff; }
.biz-pillar__num { font-family: var(--font-display); font-size: 14px; font-weight: 800; letter-spacing: 1.5px; color: var(--storm-300); padding: 6px 12px; border: 1px solid var(--hairline); border-radius: var(--r-pill); }
.biz-pillar__body { flex: 1; }
.biz-pillar__title { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); margin-bottom: 4px; letter-spacing: -.4px; line-height: 1.25; }
.biz-pillar__title-ko { font-size: 13px; font-weight: 600; color: var(--storm-500); margin-bottom: 16px; letter-spacing: -.2px; }
.biz-pillar__motif {
  width: 100%;
  max-width: 240px;
  margin: 4px auto 16px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  background: var(--canvas);
  border: 1px solid var(--hairline);
  box-shadow: 0 24px 56px -28px rgba(0, 30, 54, 0.30);
}
.biz-pillar__motif svg.biz-motif { width: 100%; height: 100%; display: block; }
.biz-pillar__desc { font-size: 14px; line-height: 1.7; color: var(--body); margin-bottom: 0; }
.biz-pillar__tags { display: flex; flex-wrap: wrap; gap: 6px; padding-top: 4px; border-top: 1px dashed var(--hairline-soft); padding-top: 20px; }
.biz-pillar__tag { font-size: 11px; font-weight: 700; color: var(--storm-700); background: var(--storm-50); border: 1px solid var(--storm-100); padding: 5px 11px; border-radius: var(--r-pill); letter-spacing: .2px; }

/* Global Strategy Map — header in normal flow, globe + panel below */
/* All detail pages — first content section starts with 40px top padding */
.subnav + section,
.subnav + section.sec,
.page-hero + section.sec,
.page-hero + section { padding-top: 40px !important; }
.news-art { padding-top: 40px !important; }

/* Globe = full-section dark backdrop; head + panel overlay on top */
.wd-gsm {
  position: relative; overflow: clip;
  padding: 40px 0 80px; min-height: 760px;
  background: var(--storm-900);
}
.wd-gsm__mapwrap { position: absolute; inset: 0; z-index: 0; }
.wd-gsm__map { position: absolute; inset: 0; width: 100%; height: 100%; transform: scale(0.8); transform-origin: center center; }
/* Keep country markers clickable even after chart reflow/redraw (the map div is
   pointer-events:none so drag reaches the wrapper; markers opt back in here). */
.wd-gsm__map .highcharts-mappoint-series { pointer-events: auto; }
.wd-gsm__overlay {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: minmax(0,1fr) 360px; gap: 32px;
  align-items: start; pointer-events: none;
}
.wd-gsm__overlay > * { pointer-events: auto; }
.wd-gsm__head { max-width: 620px; }
.wd-gsm__eyebrow { font-family: var(--font-display); font-size: 12px; font-weight: 800; letter-spacing: 1.4px; text-transform: uppercase; color: var(--storm-300); margin-bottom: 14px; }
.wd-gsm__title { font-family: var(--font-display); font-size: 38px; font-weight: 800; letter-spacing: -.8px; line-height: 1.15; color: #fff; margin-bottom: 14px; }
.wd-gsm__sub { font-size: 15px; line-height: 1.7; color: rgba(255,255,255,.75); }
.wd-gsm__legend {
  position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 18px; padding: 8px 16px;
  background: rgba(255,255,255,.10); backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.18); border-radius: var(--r-pill);
  flex-wrap: wrap; z-index: 3;
}
.wd-gsm__legitem { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: rgba(255,255,255,.85); letter-spacing: .2px; }
.wd-gsm__dot { width: 10px; height: 10px; border-radius: 50%; }
.wd-gsm__dot--impl { background: var(--storm-600); box-shadow: 0 0 0 2px #fff; }
.wd-gsm__dot--target { background: #F26B1E; box-shadow: 0 0 0 2px #fff; }

.wd-gsm__panel {
  background: rgba(255,255,255,.96); backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.20); border-radius: var(--r-xl);
  padding: 24px; display: flex; flex-direction: column; gap: 20px;
  box-shadow: 0 12px 32px rgba(0,15,40,.20);
  min-height: 480px;
  align-self: end; margin-top: 220px;
  user-select: none; touch-action: none;
  will-change: transform;
  transition: box-shadow .25s;
}
.wd-gsm__panel:active { box-shadow: 0 20px 48px rgba(0,15,40,.30); }
/* Scrollable list area remains text-selectable */
.wd-gsm__panel-body { user-select: text; cursor: auto; }
.wd-gsm__panel-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; padding-bottom: 18px; border-bottom: 1px dashed var(--hairline-soft); }
.wd-gsm__stat { display: flex; flex-direction: column; gap: 4px; }
.wd-gsm__stat-num { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: 800; color: var(--ink); letter-spacing: -.5px; line-height: 1; }
.wd-gsm__stat-lbl { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--storm-500); }
.wd-gsm__panel-body { flex: 1; overflow-y: auto; max-height: 360px; }
.wd-gsm__panel-hint { font-size: 13.5px; line-height: 1.7; color: var(--muted); }
.wd-gsm__panel-head { margin-bottom: 14px; }
.wd-gsm__statusbadge { display: inline-block; font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 5px 10px; border-radius: var(--r-pill); margin-bottom: 8px; }
.wd-gsm__statusbadge.is-impl { background: var(--storm-50); color: var(--storm-700); border: 1px solid var(--storm-100); }
.wd-gsm__statusbadge.is-target { background: #FFE9DA; color: #B6480C; border: 1px solid #FFD3B5; }
.wd-gsm__country { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); letter-spacing: -.4px; margin-bottom: 4px; }
.wd-gsm__panel-meta { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: var(--cloud-500); letter-spacing: .5px; }
.wd-gsm__proj { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.wd-gsm__proj li { position: relative; padding: 10px 12px 10px 28px; background: var(--storm-100); border: 1px solid var(--storm-200); border-radius: var(--r-md); font-size: 13px; line-height: 1.6; color: var(--body); }
.wd-gsm__proj li::before { content:''; position: absolute; left: 12px; top: 18px; width: 6px; height: 6px; border-radius: 50%; background: var(--storm-600); }
@media (max-width: 1024px) {
  .wd-gsm { padding: 40px 0 56px; min-height: auto; }
  .wd-gsm__mapwrap { position: relative; height: 420px; z-index: 0; margin-bottom: 24px; }
  .wd-gsm__overlay { grid-template-columns: 1fr; gap: 20px; }
  .wd-gsm__panel { min-height: auto; margin-top: 0; align-self: stretch; }
  .wd-gsm__head { max-width: none; }
}
@media (max-width: 720px) {
  .wd-gsm__mapwrap { height: 340px; }
}

/* Mobile globe fallback — status directory replaces the Highcharts map (<=768px) */
.wd-gsm__fallback { display: none; }
.wd-gsm__fb-group { margin-bottom: 24px; }
.wd-gsm__fb-group:last-child { margin-bottom: 0; }
.wd-gsm__fb-title { display: flex; align-items: center; gap: 8px; font-family: var(--font-display); font-size: 15px; font-weight: 800; color: #fff; letter-spacing: .2px; margin-bottom: 12px; }
.wd-gsm__fb-count { font-family: var(--font-mono); font-size: 11px; font-weight: 700; color: var(--storm-300); }
.wd-gsm__fb-list { display: flex; flex-direction: column; gap: 8px; }
.wd-gsm__fb-item { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: var(--r-md); overflow: hidden; }
.wd-gsm__fb-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 14px; cursor: pointer; list-style: none; }
.wd-gsm__fb-row::-webkit-details-marker { display: none; }
.wd-gsm__fb-item--flat .wd-gsm__fb-row { cursor: default; }
.wd-gsm__fb-name { font-size: 14px; font-weight: 600; color: rgba(255,255,255,.92); }
.wd-gsm__fb-badge { flex-shrink: 0; min-width: 22px; text-align: center; font-family: var(--font-mono); font-size: 11px; font-weight: 700; color: var(--storm-200); background: rgba(0,75,135,.45); border-radius: var(--r-pill); padding: 2px 8px; }
.wd-gsm__fb-item[open] .wd-gsm__fb-badge { background: var(--storm-600); color: #fff; }
.wd-gsm__fb-projects { list-style: none; margin: 0; padding: 0 14px 12px; display: flex; flex-direction: column; gap: 8px; }
.wd-gsm__fb-projects li { position: relative; padding: 8px 10px 8px 22px; background: rgba(255,255,255,.05); border-radius: var(--r-sm); font-size: 12.5px; line-height: 1.55; color: rgba(255,255,255,.72); }
.wd-gsm__fb-projects li::before { content: ''; position: absolute; left: 9px; top: 14px; width: 5px; height: 5px; border-radius: 50%; background: var(--storm-300); }
@media (max-width: 768px) {
  /* Show the interactive globe on mobile too (drag + gentle auto-rotate);
     the status-list fallback stays hidden. */
  .wd-gsm__mapwrap { height: 360px; }
  .wd-gsm__map { transform: none; } /* full size in the smaller mobile box */
  /* Smaller country labels so they don't crowd on the small mobile globe */
  .wd-gsm__map .highcharts-data-label text { font-size: 11px !important; }
  .wd-gsm__legend { position: static; transform: none; width: fit-content; margin: 14px auto 0; }
  .wd-gsm__fallback { display: none; }
}

/* Biz-pillar swipe variant — used when there are more than 3 cards */
.biz-swipe { position: relative; margin-top: 48px; }
.biz-swipe__track {
  display: flex; gap: 24px; overflow-x: auto; overflow-y: visible;
  scroll-snap-type: x proximity; scroll-behavior: smooth;
  padding: 14px 4px 22px;
  scrollbar-width: none; -ms-overflow-style: none;
}
.biz-swipe__track::-webkit-scrollbar { display: none; }
.biz-swipe__track > .biz-pillar {
  flex: 0 0 calc((100% - 48px) / 3);
  min-width: 280px;
  scroll-snap-align: start;
}
.biz-swipe--2up .biz-swipe__track > .biz-pillar {
  flex: 0 0 calc((100% - 24px) / 2);
  min-width: 320px;
}
.biz-swipe__btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 56px; height: 56px; border-radius: 50%;
  border: 1px solid var(--hairline); background: var(--canvas);
  box-shadow: 0 12px 32px -8px rgba(0, 30, 54, 0.25);
  cursor: pointer; z-index: 5;
  display: flex; align-items: center; justify-content: center;
  color: var(--ink);
  transition: background .2s, border-color .2s, transform .2s, opacity .2s, box-shadow .2s;
}
.biz-swipe__btn svg { width: 22px; height: 22px; }
.biz-swipe__btn:hover {
  background: var(--ink); color: var(--canvas);
  border-color: var(--ink);
  box-shadow: 0 16px 40px -8px rgba(0, 30, 54, 0.35);
}
.biz-swipe__btn:active { transform: translateY(-50%) scale(.94); }
.biz-swipe__btn[disabled] { opacity: .25; pointer-events: none; }
.biz-swipe__btn--prev { left: 16px; }
.biz-swipe__btn--next { right: 16px; }
/* Title-to-description breathing room inside swipe/grid cards on What We Do */
.wd-pillar .biz-pillar__body .biz-pillar__title { margin-bottom: 18px; }
@media (max-width: 1024px) {
  .biz-swipe__track > .biz-pillar { flex: 0 0 calc((100% - 24px) / 2); }
  .biz-swipe__btn { width: 48px; height: 48px; }
  .biz-swipe__btn--prev { left: 8px; }
  .biz-swipe__btn--next { right: 8px; }
}
@media (max-width: 720px) {
  .biz-swipe__track > .biz-pillar { flex: 0 0 86%; min-width: 260px; }
  .biz-swipe__btn { width: 44px; height: 44px; }
  .biz-swipe__btn svg { width: 18px; height: 18px; }
}

/* ─── STORY SCROLL: STRATEGY + FINANCIAL ─── */
.story-scroll { position: relative; }
.story-scroll__sticky { position: sticky; top: 64px; height: calc(100vh - 64px); overflow: hidden; background: #020d1a; }
.story-scroll__bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 20% 50%, #001840 0%, #010b16 65%); pointer-events: none; }
.story-morph { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.story-morph canvas { width: 100% !important; height: 100% !important; display: block; }
.story-triggers { /* spacers only */ }
.story-trigger { height: 75vh; }

/* Side nav dots */
.story-nav-dots { position: absolute; left: 50%; top: 80px; transform: translateX(-50%); display: flex; flex-direction: row; gap: 14px; z-index: 10; }
.story-nav-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.18); cursor: pointer; transition: all .35s; position: relative; }
.story-nav-dot--active { background: #fff; transform: scale(1.5); }
.story-nav-dot::after { content: attr(data-idx); position: absolute; left: 16px; top: 50%; transform: translateY(-50%); font-size: 10px; font-weight: 700; color: rgba(255,255,255,.35); white-space: nowrap; opacity: 0; transition: opacity .2s; pointer-events: none; }
.story-nav-dot:hover::after { opacity: 1; }

/* Slides container */
.story-slides { position: absolute; top: 0; left: 0; right: 0; will-change: transform; z-index: 2; transition: transform 0.4s cubic-bezier(0.22, 0.61, 0.36, 1); }
.story-slide { position: relative; height: calc(100vh - 64px); display: flex; flex-direction: column; align-items: stretch; padding: 260px 0 200px; opacity: 1; pointer-events: auto; }
.story-slide--active, .story-slide--exit { opacity: 1; }
.story-slide__body { max-width: 1280px; width: 100%; margin: 0 auto; padding: 0 40px; position: relative; z-index: 1; text-align: left; flex: 1; display: flex; flex-direction: column; }
.story-slide__main { flex: 1; display: flex; flex-direction: column; justify-content: flex-start; gap: 14px; max-width: 1100px; }

/* Fixed head — stays in place while slides translate */
.story-slide-head-fixed { position: absolute; top: 120px; left: 0; right: 0; pointer-events: none; z-index: 5; }
.story-slide-head-item { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 1280px; padding: 0 40px; box-sizing: border-box; opacity: 0; transition: opacity .2s ease; }
.story-slide-head-item--active { opacity: 1; }
.story-slide__eyebrow { margin-bottom: 14px; }
.story-slide__ver-row { margin-bottom: 0; }
.story-slide__title { margin-bottom: 8px; }
.story-slide__desc { margin-bottom: 0; }
.story-slide__counter { display: none; }

/* Text elements */
.story-slide__eyebrow { font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 20px; }
.story-slide__ver-row { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; }
.story-slide__ver { font-family: var(--font-display); font-size: 13px; font-weight: 800; border: 1.5px solid var(--accent-tint); color: var(--accent-tint); padding: 5px 16px; border-radius: var(--r-pill); letter-spacing: .5px; }
.story-slide__period { font-size: 14px; font-weight: 600; color: rgba(255,255,255,.35); }
.story-slide__title { font-family: var(--font-display); font-size: clamp(28px,3vw,46px); font-weight: 800; letter-spacing: -1px; color: #fff; line-height: 1.15; margin-bottom: 22px; }
.story-slide__desc { font-size: 15px; line-height: 1.8; color: #fff; margin-bottom: 0; max-width: 880px; }

/* Vision progress track */
.story-vision-bottom { position: absolute; top: 130px; left: 50%; transform: translateX(-50%); width: 100%; max-width: 1280px; padding: 0 40px; box-sizing: border-box; display: flex; align-items: center; gap: 0; justify-content: flex-end; opacity: 0; pointer-events: none; z-index: 5; }
.story-vision-bottom--visible { opacity: 1; }
.story-vision-step { display: flex; flex-direction: column; align-items: center; gap: 10px; flex-shrink: 0; }
.story-vision-node { position: relative; width: 64px; height: 64px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,.18); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 14px; font-weight: 800; color: rgba(255,255,255,.32); background: transparent; }
.story-vision-node > span { position: relative; z-index: 1; }
.story-vision-node--past { border-color: rgba(153,183,207,.4); color: rgba(153,183,207,.6); }
.story-vision-node--active { border-color: transparent; color: #fff; background: var(--storm-600); box-shadow: 0 0 0 0 rgba(0,75,135,.45); animation: visionPulse 2.4s cubic-bezier(.4,0,.2,1) infinite; }
.story-vision-node--active > span { color: #fff; }
@keyframes visionPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(0,75,135,.5), 0 0 18px rgba(153,183,207,.25); }
  50%      { box-shadow: 0 0 0 10px rgba(0,75,135,0), 0 0 30px rgba(153,183,207,.5); }
}
.story-vision-label { font-size: 11px; font-weight: 700; color: rgba(255,255,255,.32); letter-spacing: .5px; white-space: nowrap; }
.story-vision-label--active { color: rgba(255,255,255,.85); }
.story-vision-line { width: 56px; height: 1.5px; background: rgba(255,255,255,.12); margin: 0 4px; margin-bottom: 28px; flex-shrink: 0; position: relative; overflow: hidden; }
.story-vision-line--past { background: var(--storm-300); }

/* Sustainability pillars */
.story-slide__main--sustain { max-width: none; }
.story-slide__main--sustain .story-slide__desc { max-width: 760px; }
.story-pillars-row { display: flex; align-items: stretch; gap: 16px; margin: 36px 0 32px; }
.story-pillar-box { flex: 1; position: relative; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12); border-radius: var(--r-xl); padding: 32px 28px; text-align: left; display: flex; flex-direction: column; gap: 6px; }
.story-pillar-box__step { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--accent-tint); letter-spacing: 1.5px; margin-bottom: 12px; }
.story-pillar-box__label { font-family: var(--font-display); font-size: 19px; font-weight: 800; color: #fff; letter-spacing: -.2px; }
.story-pillar-box__ko { font-size: 13px; color: rgba(255,255,255,.4); }
.story-pillar-arrow { display: flex; align-items: center; color: rgba(255,255,255,.25); font-size: 22px; font-weight: 300; flex-shrink: 0; }
.story-sustain-list { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 40px; max-width: none; }
.story-sustain-item { display: flex; align-items: flex-start; gap: 12px; font-size: 14px; color: rgba(255,255,255,.55); line-height: 1.65; }
.story-sustain-dot { width: 6px; height: 6px; min-width: 6px; border-radius: 50%; background: var(--accent-tint); margin-top: 8px; }

/* Global flags */
.story-flags-grid { display: flex; flex-wrap: wrap; gap: 8px; max-width: 560px; margin-top: 20px; }
.story-flag-item { display: inline-flex; align-items: center; gap: 5px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); border-radius: var(--r-sm); padding: 3px 8px; }
.story-flag-item img { width: 16px; height: 12px; object-fit: cover; border-radius: 1px; }
.story-flag-item span { font-size: 9px; font-weight: 700; color: rgba(255,255,255,.35); letter-spacing: .5px; }

/* Financial fact grid */
.story-fin-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 28px; }
.story-fin-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: var(--r-xl); padding: 24px 28px; }
.story-fin-card__num { font-family: var(--font-display); font-size: 32px; font-weight: 800; color: #fff; line-height: 1; margin-bottom: 8px; letter-spacing: -1px; }
.story-fin-card__num span { font-size: 16px; font-weight: 600; color: var(--accent-tint); }
.story-fin-card__label { font-size: 13px; color: rgba(255,255,255,.45); line-height: 1.5; }
.story-credit-badge { display: inline-flex; align-items: center; gap: 14px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-xl); padding: 12px 22px; margin-top: 20px; }
.story-credit-badge__label { font-size: 11px; color: rgba(255,255,255,.35); }
.story-credit-badge__grade { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: #fff; }
.story-credit-badge__agency { font-size: 10px; color: rgba(255,255,255,.25); }

/* ─── CAPABILITY: 3-COLUMN ─── */
.cap-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cap-col { background: var(--canvas); border: 1px solid var(--hairline); border-radius: var(--r-xl); padding: 40px 32px; display: flex; flex-direction: column; transition: all .35s; }
.cap-col:hover { border-color: var(--primary); box-shadow: var(--shadow-md); transform: translateY(-4px); }
.cap-col__head { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.cap-col__icon { width: 44px; height: 44px; min-width: 44px; background: rgba(0,75,135,.06); border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; color: var(--primary); }
.cap-col__badge { font-family: var(--font-display); font-size: 10px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; color: var(--on-primary); background: var(--primary); padding: 3px 10px; border-radius: var(--r-pill); white-space: nowrap; }
.cap-col__title { font-family: var(--font-display); font-size: 16px; font-weight: 800; color: var(--ink); margin-bottom: 12px; letter-spacing: -.3px; line-height: 1.35; }
.cap-col__desc { font-size: 13px; line-height: 1.75; color: var(--body); flex: 1; margin-bottom: 20px; }
.cap-col__list { display: flex; flex-direction: column; gap: 8px; margin-top: auto; }
.cap-col__list-item { display: flex; align-items: flex-start; gap: 8px; font-size: 12px; color: var(--body); line-height: 1.5; }
.cap-col__list-item svg { flex-shrink: 0; color: var(--primary); margin-top: 1px; }

/* ─── CAPABILITY: implementation pipeline + credentials (dark card) ─── */
/* Whole section is dark so the title/subtitle and card read as one dark block */
#capability { background: var(--storm-950); }
#capability .sec__title { color: #fff; }
#capability .sec__subtitle { color: var(--storm-200); }
.cap-pipeline { margin-top: 8px; }
.cap-pw-card { background: transparent; color: #fff; padding: 40px 0 28px; position: relative; }
.cap-rail { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); height: 54px; margin-bottom: 6px; }
.cap-rail__line { position: absolute; top: 50%; left: 12.5%; right: 12.5%; height: 2px; transform: translateY(-50%); background: rgba(255,255,255,.14); border-radius: 2px; overflow: hidden; }
.cap-rail__flow { position: absolute; inset: 0; background: linear-gradient(90deg, transparent, var(--signal-500) 18%, var(--signal-600) 50%, var(--signal-500) 82%, transparent); background-size: 36% 100%; background-repeat: no-repeat; animation: capFlow 3.2s linear infinite; opacity: .9; }
@keyframes capFlow { 0% { background-position: -40% 0; } 100% { background-position: 140% 0; } }
.cap-rnode { display: flex; align-items: center; justify-content: center; position: relative; z-index: 1; }
.cap-dot { width: 46px; height: 46px; border-radius: 50%; background: var(--storm-800); border: 2px solid var(--signal-500); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 14px; letter-spacing: -.01em; color: var(--signal-500); box-shadow: 0 0 0 6px var(--storm-900), 0 0 18px -2px rgba(47,123,255,.6); }
.cap-rnode.last .cap-dot { background: var(--signal-500); border-color: var(--signal-500); color: #fff; box-shadow: 0 0 0 6px var(--storm-900), 0 0 22px -2px rgba(47,123,255,.85); }
.cap-stage-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.cap-stage { text-align: center; padding: 0 8px; }
.cap-stage__ic { width: 50px; height: 50px; border-radius: 14px; margin: 8px auto 14px; display: flex; align-items: center; justify-content: center; background: rgba(47,123,255,.14); color: var(--signal-500); transition: transform .2s; }
.cap-stage__ic.last-ic { background: var(--signal-500); color: #fff; }
.cap-stage__ic svg { width: 24px; height: 24px; }
.cap-stage__tag { font-family: var(--font-sans); font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--signal-500); margin-bottom: 2px; }
.cap-stage__title { font-family: var(--font-display); font-weight: 800; font-size: 16px; color: #fff; margin: 7px 0 6px; letter-spacing: -.01em; }
.cap-stage__desc { font-size: 12.5px; color: var(--storm-200); line-height: 1.5; }
.cap-stage:hover .cap-stage__ic { transform: translateY(-3px); }
.cap-logo-band { background: transparent; border-top: 1px solid rgba(255,255,255,.10); padding: 32px 0 8px; position: relative; }
.cap-logo-group.second { margin-top: 26px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.08); }
.cap-gleyb { font-family: var(--font-sans); font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--storm-300); margin-bottom: 18px; }
.cap-logo-row { display: flex; align-items: flex-start; flex-wrap: wrap; gap: 34px 42px; }
.cap-logo-item { display: flex; flex-direction: column; align-items: center; gap: 14px; min-height: 84px; }
.cap-logo-mark { height: 56px; display: flex; align-items: center; justify-content: center; }
.cap-logo-img { display: block; height: 56px; width: auto; max-width: 180px; object-fit: contain; opacity: .97; }
.cap-logo-cap { font-family: var(--font-sans); font-size: 12px; letter-spacing: .01em; color: var(--cloud-400); text-align: center; }
/* Domestic logos rendered ~30% larger than international */
.cap-logo-group:not(.second) .cap-logo-mark { height: 73px; }
.cap-logo-group:not(.second) .cap-logo-img { height: 73px; max-width: 234px; }
@media (max-width: 768px) {
  .cap-pw-card { padding: 24px 0 16px; }
  .cap-logo-band { padding: 28px 0 4px; }
  .cap-rail { display: none; }
  .cap-stage-row { grid-template-columns: 1fr; gap: 0; position: relative; padding-left: 26px; }
  .cap-stage-row::before { content: ""; position: absolute; left: 5px; top: 10px; bottom: 10px; width: 2px; background: rgba(255,255,255,.16); }
  .cap-stage { text-align: left; display: block; padding: 12px 0; position: relative; }
  .cap-stage::before { content: ""; position: absolute; left: -25px; top: 8px; width: 12px; height: 12px; border-radius: 50%; background: var(--storm-800); border: 2px solid var(--signal-500); }
  .cap-stage:last-child::before { background: var(--signal-500); border-color: var(--signal-500); }
  .cap-stage__tag, .cap-stage__title, .cap-stage__desc { text-align: left; }
  .cap-logo-row { gap: 24px 28px; }
}
@media (prefers-reduced-motion: reduce) { .cap-rail__flow { animation: none; } }

/* ─── RESPONSIVE: STORY SLIDE HEIGHT BREAKPOINTS ─── */
/* Reduce vertical padding on shorter viewports (e.g. 13" MacBook at 900px) so rich vision text isn't clipped */
@media (min-width: 1025px) and (max-height: 920px) {
  .story-slide { padding-top: 210px; padding-bottom: 150px; }
  .story-slide__desc { font-size: 14px; line-height: 1.76; }
}
@media (min-width: 1025px) and (max-height: 800px) {
  .story-slide { padding-top: 185px; padding-bottom: 110px; }
  .story-slide__desc { font-size: 13px; line-height: 1.72; }
}

/* ─── RESPONSIVE: NEW COMPONENTS ─── */
@media(max-width:1024px){
  .biz-slash { grid-template-columns: 1fr; gap: 16px; }
  .biz-pillar { padding: 28px 24px 24px; gap: 18px; }
  .biz-pillar__title { font-size: 20px; }
  .cap-cols { grid-template-columns: 1fr; }
  .story-slide { padding: 48px 60px 48px 100px; }
  .story-nav-dots { left: 20px; }
}
@media(max-width:768px){
  .biz-pillar { padding: 24px 20px; }
  .biz-slash-header { padding: 0 0 32px; }
  .story-slide__title { font-size: 24px; }
  .story-fin-grid { grid-template-columns: 1fr 1fr; }
  .story-pillars-row { gap: 8px; }
  .story-pillar-box { min-width: 90px; padding: 10px 12px; }
  .story-slide__counter { display: none; }
  /* ── Strategy: unstick & stack on mobile ── */
  .story-scroll { min-height: 0 !important; }
  .story-scroll__sticky { position: static; height: auto; padding: 56px 0 24px; }
  .story-nav-dots,
  .story-slide-head-fixed,
  .story-vision-bottom,
  .story-morph { display: none !important; }
  .story-slides { position: static; transform: none !important; }
  .story-slide { position: relative; height: auto; padding: 0 0 36px; opacity: 1 !important; }
  .story-slide + .story-slide { border-top: 1px solid rgba(255,255,255,.08); padding-top: 36px; }
  .story-slide__body { padding: 0 24px; max-width: none; }
  .story-slide__head-inline { margin-bottom: 16px; }
  .story-slide__head-inline .story-slide__eyebrow { margin-bottom: 12px; }
  .story-slide__head-inline .story-slide__ver-row { margin-bottom: 0; gap: 10px; flex-wrap: wrap; }
  .story-slide__title { margin-bottom: 16px; }
  .story-slide__desc { font-size: 14px; line-height: 1.7; max-width: none; }
  .story-triggers { display: none; }
}

/* ==========================================================================
   Typography — natural line breaking & orphan/widow prevention (KR / EN / FR)
   - Korean: break at word (eojeol) boundaries, never mid-syllable
   - Headings: balance lines so no single word is left alone on the last line
   - Body copy: text-wrap: pretty avoids orphans (progressive enhancement)
   ========================================================================== */

/* Long unbreakable tokens (URLs, long words) wrap instead of overflowing */
body { overflow-wrap: break-word; }

/* Korean reads by 어절: keep words whole and break on spaces */
html[lang="ko"] body { word-break: keep-all; }

/* Headings / display text — balance multi-line into even lines (no orphan) */
.hero__slogan,
.page-hero__title,
.sec__title,
.quicknav__panel-title,
.partners__title,
.partners__label,
.news__title,
.news__label,
.news-card__title,
.news__card-title,
.news-art__title,
.news-art__nav-title,
.pub-book__title,
.pub-cover__title,
.pub-cover__eyebrow,
.job-card__title,
.talent-card__title,
.biz-pillar__title,
.biz-pillar__title-ko,
.wd-pillar__title,
.wd-gsm__title,
.wd-gsm__eyebrow,
.wd-gsm__fb-title,
.wd-stickbar__title,
.dp-addon__title,
.dp-pillar__title,
.dp-dark-title,
.story-slide__title,
.story-slide__eyebrow,
.cap-stage__title,
.ceo-letter__name,
.founder-letter__name,
.board-card__name,
.org-card__name,
.research-card__name,
.research-group__title,
.partner-logo__name,
.gnb__mega-title,
.home-cta__title,
.footer__col-title,
.figures__label {
  text-wrap: balance;
}

/* Body copy / descriptions — prevent a lone short word on the last line */
.hero__sub,
.page-hero__desc,
.sec__subtitle,
.quicknav__panel-desc,
.figures__desc,
.partners__sub,
.part-sub-desc,
.partner-intro__text,
.partner-logo__sub,
.news-art__body,
.news-art__lead,
.news-card__body,
.job-card__body,
.biz-pillar__body,
.biz-pillar__desc,
.wd-pillar__desc,
.wd-gsm__sub,
.wd-gsm__panel-hint,
.dp-addon__desc,
.dp-pillar__desc,
.dp-panel__desc,
.dp-dark-sub,
.cap-stage__desc,
.ceo-letter__body,
.founder-letter__body,
.home-cta__desc,
.footer__desc,
.gnb__mega-desc,
.story-slide__body,
.story-slide__desc,
.timeline__desc,
.pub-cover__desc {
  text-wrap: pretty;
}
