/* Self-hosted Google Fonts — Latin + Latin-ext only */
/* Inter 400 */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/fonts/inter-400.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Inter 500 */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/fonts/inter-500.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Montserrat 700 */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/fonts/montserrat-700.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Montserrat 800 */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/fonts/montserrat-800.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; font-size: 16px; overflow-x: hidden; }
    body {
      font-family: 'Inter', sans-serif;
      background: #ffffff;
      color: #0D1B3E;
      -webkit-font-smoothing: antialiased;
      overflow-x: hidden;
    }
    h1, h2, h3, h4, h5 {
      font-family: 'Montserrat', sans-serif;
      letter-spacing: -0.03em;
      line-height: 1.13;
    }
    p, li, span, a, label, input, button, select, textarea, small {
      font-family: 'Inter', sans-serif;
      line-height: 1.7;
    }

    /* GRAIN */
    .grain { position: relative; }
    .grain::after {
      content: '';
      position: absolute; inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.04'/%3E%3C/svg%3E");
      pointer-events: none; z-index: 2;
    }

    /* HERO BG */
    .hero-bg {
      background:
        radial-gradient(ellipse 110% 60% at 55% -5%,  rgba(30, 86, 181, 0.30) 0%, transparent 62%),
        radial-gradient(ellipse 55%  55% at 95% 45%,  rgba(77,174, 229, 0.14) 0%, transparent 58%),
        radial-gradient(ellipse 65%  70% at  0% 100%, rgba(13, 27,  62, 0.25) 0%, transparent 60%),
        linear-gradient(160deg, #04091a 0%, #0D1B3E 50%, #122244 100%);
    }

    /* NAV */
    .nav-blur {
      backdrop-filter: blur(20px) saturate(160%);
      -webkit-backdrop-filter: blur(20px) saturate(160%);
    }
    .nav-link {
      font-family: 'Inter', sans-serif;
      font-size: 0.875rem; font-weight: 500;
      color: rgba(255,255,255,0.70);
      text-decoration: none;
      padding: 0.4rem 0.8rem; border-radius: 8px;
      transition: background 0.14s ease, color 0.14s ease;
    }
    .nav-link:hover       { color: #fff; background: rgba(255,255,255,0.09); }
    .nav-link:active      { background: rgba(255,255,255,0.15); }
    .nav-link:focus-visible { outline: 2px solid #4DAEE5; outline-offset: 2px; }

    .nav-dropdown-wrap { position: relative; display: flex; align-items: center; }
    .nav-dropdown-wrap::after { content: ''; position: absolute; top: 100%; left: 0; right: 0; height: 14px; }
    .nav-dropdown-trigger { display: flex; align-items: center; gap: 2px; }
    .dd-caret { transition: transform 0.22s cubic-bezier(0.16,1,0.3,1); opacity: 0.5; flex-shrink: 0; }
    .nav-dropdown-wrap:hover .dd-caret { transform: rotate(180deg); }
    .nav-dropdown {
      position: absolute; top: calc(100% + 10px); left: 50%;
      transform: translateX(-50%) translateY(-8px);
      min-width: 220px;
      background: rgba(6,13,40,0.98);
      backdrop-filter: blur(24px) saturate(160%);
      -webkit-backdrop-filter: blur(24px) saturate(160%);
      border: 1px solid rgba(255,255,255,0.09); border-radius: 14px;
      padding: 0.45rem;
      opacity: 0; visibility: hidden; pointer-events: none;
      transition: opacity 0.18s ease, transform 0.22s cubic-bezier(0.16,1,0.3,1), visibility 0s linear 0.18s;
      z-index: 200;
      box-shadow: 0 24px 56px rgba(0,0,0,0.65), 0 4px 14px rgba(0,0,0,0.35), 0 0 0 1px rgba(255,255,255,0.04) inset;
    }
    .nav-dropdown::before {
      content: ''; position: absolute; top: -5px; left: 50%;
      transform: translateX(-50%) rotate(45deg);
      width: 10px; height: 10px; background: rgba(6,13,40,0.98);
      border-left: 1px solid rgba(255,255,255,0.09);
      border-top: 1px solid rgba(255,255,255,0.09);
      border-radius: 2px 0 0 0;
    }
    .nav-dropdown-wrap:hover .nav-dropdown,
    .nav-dropdown-wrap:focus-within .nav-dropdown {
      opacity: 1; visibility: visible; pointer-events: auto;
      transform: translateX(-50%) translateY(0);
      transition: opacity 0.18s ease, transform 0.22s cubic-bezier(0.16,1,0.3,1), visibility 0s;
    }
    .nav-dd-item {
      display: flex; align-items: center; gap: 0.65rem;
      padding: 0.55rem 0.85rem; border-radius: 9px;
      font-size: 0.82rem; color: rgba(195,215,245,0.72);
      text-decoration: none; font-family: 'Inter', sans-serif; font-weight: 500;
      transition: background 0.12s ease, color 0.12s ease; white-space: nowrap;
    }
    .nav-dd-item:hover { background: rgba(255,255,255,0.09); color: #fff; }
    .nav-dd-item:focus-visible { outline: 2px solid #4DAEE5; outline-offset: -2px; border-radius: 9px; }
    .nav-dd-icon {
      width: 22px; height: 22px; border-radius: 6px; flex-shrink: 0;
      background: linear-gradient(135deg, rgba(30,86,181,0.32), rgba(77,174,229,0.20));
      display: flex; align-items: center; justify-content: center;
    }

    .lang-toggle {
      display: flex; align-items: center;
      background: rgba(255,255,255,0.07);
      border: 1px solid rgba(255,255,255,0.12);
      border-radius: 8px; overflow: hidden; flex-shrink: 0;
    }
    .lang-btn {
      padding: 0.28rem 0.62rem; border: none; background: transparent; cursor: pointer;
      font-family: 'Inter', sans-serif; font-size: 0.72rem; font-weight: 600;
      color: rgba(195,215,245,0.45); transition: color 0.14s ease, background 0.14s ease;
    }
    .lang-btn:hover { color: rgba(195,215,245,0.8); }
    .lang-btn.active { color: #fff; background: rgba(255,255,255,0.12); }
    .lang-divider { width: 1px; height: 14px; background: rgba(255,255,255,0.12); }

    /* BUTTONS */
    .btn-primary {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
      padding: 0.875rem 2rem;
      background: linear-gradient(135deg, #1E56B5 0%, #1A3462 100%);
      color: #fff;
      font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 0.9rem; letter-spacing: 0.005em;
      border-radius: 10px; border: none; cursor: pointer; text-decoration: none; white-space: nowrap;
      box-shadow: 0 4px 14px rgba(30,86,181,0.38), 0 1px 3px rgba(0,0,0,0.22);
      transition: transform 0.2s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.2s ease, opacity 0.15s ease;
    }
    .btn-primary:hover       { transform: translateY(-2px) scale(1.025); box-shadow: 0 8px 24px rgba(30,86,181,0.48), 0 2px 6px rgba(0,0,0,0.28); }
    .btn-primary:active      { transform: translateY(0) scale(0.98); opacity: 0.92; }
    .btn-primary:focus-visible { outline: 2px solid #4DAEE5; outline-offset: 3px; }
    @media(max-width:639px){header .btn-primary,header .lang-toggle,header #dark-toggle{display:none!important}}

    .btn-light {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
      padding: 0.875rem 2rem;
      background: #ffffff;
      color: #0D1B3E;
      font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 0.9rem;
      border-radius: 10px; border: none; cursor: pointer; text-decoration: none; white-space: nowrap;
      box-shadow: 0 2px 8px rgba(13,27,62,0.12), 0 1px 2px rgba(13,27,62,0.08);
      transition: transform 0.2s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.2s ease;
    }
    .btn-light:hover       { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(13,27,62,0.18), 0 2px 4px rgba(13,27,62,0.10); }
    .btn-light:active      { transform: translateY(0) scale(0.98); }
    .btn-light:focus-visible { outline: 2px solid #1E56B5; outline-offset: 3px; }

    .btn-outline-dark {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
      padding: 0.875rem 1.875rem;
      background: transparent; color: #1E56B5;
      font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 0.9rem;
      border-radius: 10px; border: 1.5px solid rgba(30,86,181,0.25); cursor: pointer; text-decoration: none; white-space: nowrap;
      transition: transform 0.2s cubic-bezier(0.34,1.56,0.64,1), background 0.14s ease, border-color 0.14s ease;
    }
    .btn-outline-dark:hover   { background: rgba(30,86,181,0.06); border-color: rgba(30,86,181,0.45); transform: translateY(-1px); }
    .btn-outline-dark:active  { transform: translateY(0); }
    .btn-outline-dark:focus-visible { outline: 2px solid #4DAEE5; outline-offset: 3px; }

    /* BADGE */
    .badge {
      display: inline-flex; align-items: center; gap: 0.35rem;
      padding: 0.28rem 0.85rem; border-radius: 999px;
      background: rgba(30,86,181,0.09);
      border: 1px solid rgba(30,86,181,0.20);
      color: #1E56B5;
      font-family: 'Montserrat', sans-serif; font-size: 0.72rem; font-weight: 700;
      letter-spacing: 0.07em; text-transform: uppercase;
    }
    .badge-dark {
      background: rgba(77,174,229,0.13);
      border-color: rgba(77,174,229,0.30);
      color: #7ECEF5;
    }

    /* MOBILE MENU */
    #mob-menu {
      display: none;
      background: rgba(4,9,26,0.96);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
    }
    #mob-menu.open { display: block; }

    /* ── FLOW DIAGRAM ANIMATION ── */
    @keyframes dash {
      to { stroke-dashoffset: -24; }
    }
    @keyframes glow-pulse {
      0%, 100% { opacity: 0.5; transform: scale(1); }
      50% { opacity: 1; transform: scale(1.3); }
    }
    .flow-line {
      stroke-dasharray: 8 4;
      animation: dash 1.5s linear infinite;
    }
    .glow-node {
      animation: glow-pulse 2.5s ease-in-out infinite;
    }

    /* ── RING GAUGE ANIMATION ── */
    .ring-gauge-bg { fill: none; stroke: rgba(30,86,181,0.12); }
    .ring-gauge-fill {
      fill: none;
      stroke-linecap: round;
      transition: stroke-dashoffset 1.8s cubic-bezier(0.16,1,0.3,1);
    }

    /* ── CASE CARD ZIGZAG ── */
    .case-zigzag {
      background: #fff;
      border-radius: 24px;
      border: 1px solid rgba(30,86,181,0.10);
      position: relative;
      overflow: hidden;
      transition: transform 0.3s cubic-bezier(0.16,1,0.3,1), box-shadow 0.3s ease;
      box-shadow: 0 2px 4px rgba(13,27,62,0.05), 0 8px 24px rgba(13,27,62,0.06);
    }
    .case-zigzag::before {
      content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; z-index: 2;
      background: linear-gradient(90deg, #1E56B5, #4DAEE5, #7ECEF5);
    }
    .case-zigzag:hover {
      transform: translateY(-6px);
      box-shadow: 0 4px 8px rgba(13,27,62,0.08), 0 20px 40px rgba(30,86,181,0.12);
    }
    .case-photo {
      position: relative;
      height: 200px;
      overflow: hidden;
    }
    .case-photo img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }
    .case-photo::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(to bottom, rgba(4,9,26,0.15) 0%, rgba(4,9,26,0.5) 100%);
      mix-blend-mode: multiply;
    }
    .case-content {
      display: grid;
      grid-template-columns: 150px 1fr;
      gap: 2rem;
      align-items: start;
      padding: 2rem 2.5rem 2.5rem;
    }
    .case-zigzag.reverse .case-content { grid-template-columns: 1fr 150px; }
    @media(max-width:767px) {
      .case-content, .case-zigzag.reverse .case-content { grid-template-columns: 1fr; }
      .case-content .case-illust { order: -1; justify-self: center; }
      .case-photo { height: 160px; }
    }

    /* ── GEAR ANIMATION ── */
    @keyframes spin-cw { to { transform: rotate(360deg); } }
    @keyframes spin-ccw { to { transform: rotate(-360deg); } }

    /* ── BUBBLE ANIMATION ── */
    @keyframes bubble-rise {
      0% { transform: translateY(0); opacity: 0.7; }
      100% { transform: translateY(-40px); opacity: 0; }
    }

    /* ── FACTOR CONNECTOR LINES ── */
    .factor-card-v2 {
      background: #fff;
      border-radius: 20px;
      padding: 2rem 1.5rem;
      border: 1px solid rgba(30,86,181,0.10);
      position: relative;
      overflow: hidden;
      transition: transform 0.3s cubic-bezier(0.16,1,0.3,1), box-shadow 0.3s ease;
      box-shadow: 0 1px 2px rgba(13,27,62,0.05), 0 4px 12px rgba(13,27,62,0.06);
    }
    .factor-card-v2:hover {
      transform: translateY(-6px);
      box-shadow: 0 4px 8px rgba(13,27,62,0.06), 0 16px 32px rgba(30,86,181,0.10);
    }

    /* ── STORY CARD MAGAZINE ── */
    .story-mag {
      background: #fff;
      border: 1px solid rgba(30,86,181,0.10);
      border-radius: 24px;
      padding: 3rem 2.5rem;
      position: relative;
      overflow: hidden;
      transition: transform 0.3s cubic-bezier(0.16,1,0.3,1), box-shadow 0.3s ease;
      box-shadow: 0 2px 8px rgba(13,27,62,0.04);
    }
    .story-mag::before {
      content: '';
      position: absolute; top: 0; left: 0; width: 4px; height: 100%;
      background: linear-gradient(to bottom, #1E56B5, #4DAEE5);
      border-radius: 0 4px 4px 0;
    }
    .story-mag:hover {
      transform: translateY(-4px);
      box-shadow: 0 4px 8px rgba(13,27,62,0.06), 0 16px 36px rgba(30,86,181,0.10);
    }
    .story-number {
      position: absolute; top: 1rem; right: 1.5rem;
      font-family: 'Montserrat', sans-serif; font-weight: 900; font-size: 5rem;
      line-height: 1; letter-spacing: -0.04em;
      background: linear-gradient(135deg, rgba(30,86,181,0.06), rgba(77,174,229,0.04));
      -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
      pointer-events: none;
    }
    .story-columns { columns: 1; column-gap: 2rem; }
    @media(min-width:768px) { .story-columns { columns: 2; } }
    .story-metrics {
      display: flex; flex-wrap: wrap; gap: 2rem;
      padding-top: 1.25rem; margin-top: 1.25rem;
      border-top: 1px solid rgba(30,86,181,0.10);
    }
    .pull-quote {
      font-family: 'Montserrat', sans-serif; font-size: 1.15rem; font-weight: 700;
      color: #0D1B3E; line-height: 1.4; letter-spacing: -0.02em;
      padding: 1.5rem 0 1.5rem 1.5rem;
      border-left: 3px solid #4DAEE5;
      margin: 1rem 0 1.5rem;
      position: relative;
    }

    /* ── TIMELINE HORIZONTAL ── */
    .timeline-h { overflow-x: auto; padding: 2rem 0; }
    .timeline-h-inner {
      display: flex; gap: 0; min-width: 900px; position: relative; padding: 0 2rem;
    }
    .timeline-h-node {
      flex: 1; text-align: center; position: relative; padding-top: 4rem;
    }
    @media(max-width:767px) {
      .timeline-h-inner { flex-direction: column; min-width: 0; padding: 0; }
      .timeline-h-node { padding-top: 0; padding-left: 3rem; text-align: left; margin-bottom: 2rem; }
    }

    /* ── SVG BAR CHART ── */
    .bar-animated {
      transition: width 1.2s cubic-bezier(0.16,1,0.3,1);
    }

    /* ── CTA SHIELD ── */
    @keyframes shield-draw {
      to { stroke-dashoffset: 0; }
    }
    @keyframes check-draw {
      to { stroke-dashoffset: 0; }
    }

    /* ── WAVE DIVIDERS ── */
    .wave-divider { display: block; width: 100vw !important; height: auto; margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }

    /* ── RELATED CARD ── */
    .related-card-v2 {
      background: #fff;
      border: 1px solid rgba(30,86,181,0.10);
      border-radius: 16px;
      padding: 0;
      text-decoration: none;
      display: flex;
      flex-direction: column;
      overflow: hidden;
      transition: transform 0.25s cubic-bezier(0.16,1,0.3,1), box-shadow 0.25s ease, border-color 0.25s ease;
      box-shadow: 0 2px 8px rgba(13,27,62,0.04);
    }
    .related-card-v2 .rc-img {
      width: 100%;
      height: 140px;
      object-fit: cover;
      display: block;
    }
    .related-card-v2 .rc-body {
      padding: 1.25rem 1.5rem 1.5rem;
    }
    .related-card-v2:hover {
      transform: translateY(-4px);
      border-color: rgba(30,86,181,0.25);
      box-shadow: 0 4px 8px rgba(13,27,62,0.06), 0 12px 28px rgba(30,86,181,0.10);
    }
    .related-card-v2 .arrow-icon {
      transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1);
    }
    .related-card-v2:hover .arrow-icon {
      transform: translateX(4px);
    }

    /* ── HERO MOUSE SPOTLIGHT ── */
    .hero-spotlight {
      position: absolute; inset: 0; pointer-events: none; z-index: 1;
      background: radial-gradient(600px circle at var(--mx, 50%) var(--my, 30%), rgba(77,174,229,0.08), transparent 60%);
    }

    /* ── DARK MODE ── */
    :root{--bg-base:#ffffff;--bg-raised:#f5f8fe;--bg-card:#ffffff;--clr-h:#0D1B3E;--clr-b:#5a6e8c;--bdr:#dde5f4}
    html.dark{--bg-base:#0a1428;--bg-raised:#0D1B3E;--bg-card:#122244;--clr-h:#e8f0fa;--clr-b:#8aaac8;--bdr:rgba(77,174,229,0.18)}
    html.dark body{background:var(--bg-base)!important;color:var(--clr-h)!important}
    .logo-light{display:none}html.dark .logo-dark{display:none!important}html.dark .logo-light{display:inline!important}

    /* ── Global text color overrides ── */
    html.dark [style*="color:#0D1B3E"]{color:#e8f0fa!important}
    html.dark [style*="color: #0D1B3E"]{color:#e8f0fa!important}
    html.dark [style*="color:#5a6e8c"]{color:#8aaac8!important}
    html.dark [style*="color: #5a6e8c"]{color:#8aaac8!important}
    html.dark [style*="color:#8a9ab8"]{color:#7a9ab8!important}
    html.dark [style*="color: #8a9ab8"]{color:#7a9ab8!important}
    html.dark [style*="color:#374151"]{color:#a8c0d8!important}

    /* ── Global background overrides ── */
    html.dark [style*="background:#ffffff"]{background:var(--bg-base)!important}
    html.dark [style*="background: #ffffff"]{background:var(--bg-base)!important}
    html.dark [style*="background:#fff"]{background:var(--bg-base)!important}
    html.dark [style*="background:#f5f8fe"]{background:var(--bg-raised)!important}
    html.dark [style*="background: #f5f8fe"]{background:var(--bg-raised)!important}
    html.dark [style*="background:#f8fafd"]{background:var(--bg-raised)!important}
    html.dark [style*="background:#e8eef8"]{background:rgba(77,174,229,0.12)!important}
    html.dark .bg-white{background:var(--bg-card)!important}

    /* ── Global border overrides ── */
    html.dark [style*="border-color:#dde5f4"]{border-color:var(--bdr)!important}
    html.dark [style*="border:1px solid #dde5f4"]{border-color:var(--bdr)!important}
    html.dark [style*="border-bottom:1px solid #dde5f4"]{border-color:var(--bdr)!important}
    html.dark [style*="border-top:1px solid #dde5f4"]{border-color:var(--bdr)!important}

    /* ── Section backgrounds ── */
    html.dark section[style*="background:#ffffff"]{background:var(--bg-base)!important}
    html.dark section[style*="background: #ffffff"]{background:var(--bg-base)!important}
    html.dark section[style*="background:#fff"]{background:var(--bg-base)!important}

    /* ── Cards ── */
    html.dark .case-zigzag{background:var(--bg-card)!important;border-color:var(--bdr)!important}
    html.dark .case-zigzag .case-result-v2{background:var(--bg-raised)!important;border-color:var(--bdr)!important}
    html.dark .factor-card-v2{background:var(--bg-card)!important;border-color:var(--bdr)!important}
    html.dark .story-mag{background:var(--bg-card)!important;border-color:var(--bdr)!important}
    html.dark .related-card-v2{background:var(--bg-card)!important;border-color:var(--bdr)!important}
    html.dark .related-card-v2:hover{border-color:rgba(77,174,229,0.3)!important}
    html.dark .industry-card-v2{background:var(--bg-card)!important;border-color:var(--bdr)!important}

    /* ── Badge ── */
    html.dark .badge{background:rgba(77,174,229,0.12)!important;border-color:rgba(77,174,229,0.25)!important;color:#7ECEF5!important}

    /* ── Stats / Gauges ── */
    html.dark .stats-gauges{background:var(--bg-card)!important;border-color:var(--bdr)!important}
    html.dark .ring-gauge-bg{stroke:rgba(77,174,229,0.25)!important}
    html.dark #ring-gauges{background:var(--bg-card)!important;border-color:var(--bdr)!important}
    html.dark .gauge-number{fill:#e8f0fa!important}
    html.dark .gauge-label{fill:#8aaac8!important}
    html.dark .stat-item-label{color:#8aaac8!important}

    /* ── SVG text in bar chart ── */
    html.dark .chart-label{fill:#8aaac8!important}
    html.dark .chart-value{fill:#c8daf0!important}
    html.dark .chart-grid-label{fill:#5a7a9a!important}
    html.dark .bar-chart-bg{fill:var(--bg-card)!important}
    html.dark svg text[fill="#0D1B3E"]{fill:#e8f0fa!important}
    html.dark svg text[fill="#5a6e8c"]{fill:#8aaac8!important}
    html.dark svg text[fill="#8a9ab8"]{fill:#7a9ab8!important}

    /* ── TL;DR ── */
    html.dark .tldr-summary{background:var(--bg-raised)!important;border-color:var(--bdr)!important;color:#8aaac8!important}
    html.dark .tldr-summary strong{color:#c8daf0!important}

    /* ── Story magazine ── */
    html.dark .story-mag .pull-quote{color:#c8daf0!important;border-left-color:rgba(77,174,229,0.5)!important}
    html.dark .story-mag .story-number{color:rgba(77,174,229,0.08)!important}
    html.dark .story-mag h3{color:#e8f0fa!important}
    html.dark .story-mag p{color:#8aaac8!important}
    html.dark .story-mag .story-columns p{color:#8aaac8!important}
    html.dark .story-metrics{border-top-color:rgba(77,174,229,0.18)!important}

    /* ── Timeline ── */
    html.dark .timeline-step h3{color:#e8f0fa!important}
    html.dark .timeline-step p{color:#8aaac8!important}

    /* ── Section wave dividers ── */
    html.dark .wave-divider path{fill:var(--bg-base)!important}
    html.dark .wave-divider-top path{fill:var(--bg-base)!important}

    /* ── Mid-article CTA ── */
    html.dark [style*="background:linear-gradient(135deg,rgba(30,86,181,0.06)"]{background:rgba(30,86,181,0.15)!important;border-color:rgba(77,174,229,0.2)!important}

    /* ── Floating SVG shapes ── */
    html.dark .floating-shape{opacity:0.03!important}

    /* ── Factor card connector lines ── */
    html.dark .connector-line{stroke:rgba(77,174,229,0.12)!important}

    /* ── SVG text class overrides ── */
    html.dark .svg-text-dark{fill:#e8f0fa!important}
    html.dark .svg-text-muted{fill:#8aaac8!important}
    html.dark .svg-text-light{fill:#7a9ab8!important}

    /* ── Gauge stat items ── */
    html.dark .stat-item-wrap{background:var(--bg-card)!important;border-color:var(--bdr)!important}

    /* ── Case card headers and results ── */
    html.dark .case-zigzag .case-header-v2{background:var(--bg-raised)!important}
    html.dark .case-zigzag h2{color:#e8f0fa!important}
    html.dark .case-zigzag h3{color:#e8f0fa!important}
    html.dark .case-zigzag p{color:#8aaac8!important}
    html.dark .case-zigzag span{color:#8aaac8!important}

    /* ── Factor card text ── */
    html.dark .factor-card-v2 h3{color:#e8f0fa!important}
    html.dark .factor-card-v2 p{color:#8aaac8!important}

    /* ── Industry card text ── */
    html.dark .industry-card-v2 p{color:#8aaac8!important}

    /* ── Related card text ── */
    html.dark .related-card-v2 div{color:#e8f0fa!important}
    html.dark .related-card-v2 p{color:#8aaac8!important}

    /* ── SVG grid lines in chart ── */
    html.dark .chart-gridline{stroke:rgba(77,174,229,0.1)!important}
    html.dark .chart-bar-track{fill:rgba(77,174,229,0.08)!important}

    /* ── Wave fills for dark bg sections ── */
    html.dark .wave-fill-white{fill:var(--bg-base)!important}
    html.dark .wave-fill-raised{fill:var(--bg-raised)!important}
    html.dark .wave-fill-tinted{fill:var(--bg-base)!important}
    html.dark .wave-divider path.wave-fill-raised{fill:var(--bg-raised)!important}
    html.dark .wave-divider rect.wave-fill-raised{fill:var(--bg-raised)!important}

    /* ── Misc ── */
    html.dark #ham-btn span{background:#fff!important}
    html.dark #dark-toggle:hover,html.dark #dark-toggle-mob:hover{background:rgba(255,255,255,0.14)!important;color:#fff!important}
    html.dark .external-citations{background:var(--bg-raised)!important;border-color:var(--bdr)!important}
    html.dark .check-dot-sm{background:linear-gradient(135deg,rgba(77,174,229,0.3),rgba(30,86,181,0.4))!important}
    html.dark .story-mag .story-metrics div div:first-child{color:#4DAEE5!important}
    html.dark .story-mag .story-metrics div div:last-child{color:#7a9ab8!important}

    /* ── Bar chart container ── */
    html.dark .chart-container{background:var(--bg-card)!important;border-color:var(--bdr)!important}

    /* ── Bar chart grid lines & labels ── */
    html.dark #bar-chart line{stroke:rgba(77,174,229,0.12)!important}
    html.dark .bar-label{fill:#7ECEF5!important}
    html.dark #barGrad2 stop:first-child{stop-color:#4DAEE5}
    html.dark #barGrad2 stop:last-child{stop-color:#7ECEF5}

    /* ── Section bg overrides ── */
    html.dark section[style*="background:#f5f8fe"]{background:var(--bg-raised)!important}
    html.dark [style*="background:#f5f8fe"]{background:var(--bg-raised)!important}

    /* ── Wave dividers in dark mode ── */
    html.dark .wave-divider{background:transparent!important}
    html.dark .wave-divider.wave-cta-grad{background:linear-gradient(160deg,#04091a 0%,#0D1B3E 50%,#122244 100%)!important}
    html.dark .wave-divider path{fill:var(--bg-base)!important}
    html.dark .wave-divider path[fill="#04091a"]{fill:#04091a!important}
    html.dark .wave-divider rect[fill="#04091a"]{fill:#04091a!important}

    /* ── Case result boxes ── */
    html.dark .case-result-v2{background:var(--bg-raised)!important;border-color:var(--bdr)!important}

    /* ── All headings and body text in dark ── */
    html.dark h2{color:#e8f0fa!important}
    html.dark h3{color:#e8f0fa!important}

    /* ── Gradient text still works in dark ── */
    html.dark .stat-gradient{-webkit-text-fill-color:transparent!important}
    html.dark .counter-value{-webkit-text-fill-color:transparent!important}

    /* ── Timeline milestone text ── */
    html.dark .timeline-desc h3{color:#e8f0fa!important}
    html.dark .timeline-desc p{color:#8aaac8!important}
    html.dark [style*="color:#1E56B5"]{color:#4DAEE5!important}
    html.dark [style*="color: #1E56B5"]{color:#4DAEE5!important}

    /* ── CTA mid-article ── */
    html.dark [style*="rgba(30,86,181,0.06)"]{background:rgba(30,86,181,0.18)!important;border-color:rgba(77,174,229,0.2)!important}

    /* ── Disclaimer text ── */
    html.dark p[style*="color:#8a9ab8"]{color:#5a8aaa!important}

@media(max-width:639px) {
  #ring-gauges { grid-template-columns: 1fr !important; gap: 2rem !important; }
}

.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.footer-grid{grid-template-columns:1.6fr 1fr 2fr 1fr}}