    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --ink:         #0f172a;
      --ink-soft:    #334155;
      --ink-muted:   #64748b;
      --ink-faint:   #94a3b8;
      --rule:        rgba(148, 163, 184, 0.22);
      --rule-strong: rgba(148, 163, 184, 0.36);
      --bg:          #f4f7fb;
      --card:        rgba(255, 255, 255, 0.84);
      --shadow-soft: 0 24px 60px rgba(15, 23, 42, 0.08);
      --shadow-card: 0 14px 34px rgba(15, 23, 42, 0.08);
      --shadow-nav:  0 12px 34px rgba(15, 23, 42, 0.12);
      --bbc:      #1d4ed8;
      --lm:       #16a34a;
      --pd:       #dc2626;
      --tass:     #7c3aed;
      --hindu:    #c2410c;
      --folha:    #b45309;
      --aj:       #0369a1;
      --kompas:   #0891b2;
      --arabnews: #0f766e;
      --dw:       #991b1b;
      --sabah:    #d97706;
      --gazeta:   #3730a3;
      --khaosod:  #0284c7;
      --cna:      #9f1239;
      --mavrik:   #14532d;
      --nation:   #7c2d12;
      --cat-geopolitics:  #dc2626;
      --cat-economy:      #16a34a;
      --cat-tech:         #7c3aed;
      --cat-science:      #0369a1;
      --cat-environment:  #0891b2;
      --cat-health:       #db2777;
      --cat-sports:       #ea580c;
      --cat-society:      #64748b;
    }

    body {
      font-family: "Manrope", "Helvetica Neue", Arial, sans-serif;
      background: var(--bg);
      color: var(--ink);
      margin: 0;
      min-height: 100vh;
      padding-top: 5rem;
      position: relative;
      background-image:
        radial-gradient(circle at top left, rgba(37, 99, 235, 0.10), transparent 32%),
        radial-gradient(circle at top right, rgba(8, 145, 178, 0.10), transparent 24%),
        linear-gradient(180deg, #f8fbff 0%, #f4f7fb 42%, #eff4fb 100%);
    }

    body::before {
      content: "";
      position: fixed;
      inset: 0;
      pointer-events: none;
      background-image:
        linear-gradient(rgba(255,255,255,0.35) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.35) 1px, transparent 1px);
      background-size: 32px 32px;
      mask-image: linear-gradient(180deg, rgba(0,0,0,0.35), transparent 82%);
      opacity: 0.35;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    .sticky-bar {
      position: fixed;
      top: 1rem;
      left: 50%;
      transform: translateX(-50%);
      width: min(calc(100% - 2rem), 1180px);
      z-index: 200;
      background: rgba(15, 23, 42, 0.72);
      display: flex;
      align-items: center;
      gap: 1rem;
      padding: 0.75rem 1rem;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, 0.14);
      box-shadow: var(--shadow-nav);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
    }

    .sticky-logo {
      font-size: 0.98rem;
      font-weight: 800;
      letter-spacing: -0.03em;
      color: #fff;
      white-space: nowrap;
      flex-shrink: 0;
      padding: 0 1rem 0 0.25rem;
      border-right: 1px solid rgba(255, 255, 255, 0.12);
    }
    .logo-accent {
      background: linear-gradient(90deg,
        #8b5cf6,
        #38bdf8,
        var(--cat-environment)
      );
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
    .sticky-cats {
      display: flex;
      gap: 0.35rem;
      flex: 1;
      overflow-x: auto;
      scrollbar-width: none;
    }
    .sticky-cats::-webkit-scrollbar { display: none; }

    .cat-tab {
      cursor: pointer;
      font-size: 0.72rem;
      font-family: "Manrope", "Helvetica Neue", Arial, sans-serif;
      font-weight: 700;
      color: rgba(226, 232, 240, 0.72);
      background: transparent;
      border: 1px solid transparent;
      padding: 0.42rem 0.8rem;
      border-radius: 999px;
      white-space: nowrap;
      text-decoration: none;
      transition: color 0.18s, background 0.18s, border-color 0.18s, transform 0.18s;
      user-select: none;
    }
    .cat-tab:hover {
      color: #fff;
      background: rgba(255, 255, 255, 0.08);
      border-color: rgba(255, 255, 255, 0.10);
      transform: translateY(-1px);
    }
    .cat-tab[data-cat="all"].active          { background: #fff; color: var(--ink); border-color: #fff; }
    .cat-tab[data-cat="geopolitics"].active  { background: var(--cat-geopolitics); color: #fff; border-color: var(--cat-geopolitics); }
    .cat-tab[data-cat="economy"].active      { background: var(--cat-economy);     color: #fff; border-color: var(--cat-economy); }
    .cat-tab[data-cat="tech"].active         { background: var(--cat-tech);        color: #fff; border-color: var(--cat-tech); }
    .cat-tab[data-cat="environment"].active  { background: var(--cat-environment); color: #fff; border-color: var(--cat-environment); }
    .cat-tab[data-cat="health"].active       { background: var(--cat-health);      color: #fff; border-color: var(--cat-health); }
    .cat-tab[data-cat="sports"].active       { background: var(--cat-sports);      color: #fff; border-color: var(--cat-sports); }
    .cat-tab[data-cat="society"].active      { background: var(--cat-society);     color: #fff; border-color: var(--cat-society); }

    .sticky-feed-link {
      flex-shrink: 0;
      font-size: 0.72rem;
      font-family: "Manrope", sans-serif;
      font-weight: 700;
      color: rgba(226, 232, 240, 0.72);
      padding: 0.42rem 0.8rem;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, 0.12);
      white-space: nowrap;
      background: rgba(255, 255, 255, 0.06);
      transition: color 0.18s, border-color 0.18s, background 0.18s, transform 0.18s;
    }
    .sticky-feed-link:hover {
      color: #fff;
      border-color: rgba(255, 255, 255, 0.32);
      background: rgba(255, 255, 255, 0.12);
      transform: translateY(-1px);
    }

    .mobile-bottom-nav {
      display: none;
    }

    .hero-shell {
      max-width: 1180px;
      margin: 0 auto;
      padding: 2.25rem 1.5rem 1.25rem;
    }

    .topic-hero {
      position: relative;
      overflow: hidden;
      padding: 2.4rem;
      color: #fff;
      border-radius: 32px;
      box-shadow: var(--shadow-soft);
    }

    .topic-hero.cat-geopolitics  { background: linear-gradient(135deg, #7f1d1d 0%, #dc2626 100%); }
    .topic-hero.cat-economy      { background: linear-gradient(135deg, #14532d 0%, #16a34a 100%); }
    .topic-hero.cat-tech         { background: linear-gradient(135deg, #3b0764 0%, #7c3aed 100%); }
    .topic-hero.cat-science      { background: linear-gradient(135deg, #1e3a8a 0%, #0369a1 100%); }
    .topic-hero.cat-environment  { background: linear-gradient(135deg, #0c4a6e 0%, #0891b2 100%); }
    .topic-hero.cat-health       { background: linear-gradient(135deg, #500724 0%, #db2777 100%); }
    .topic-hero.cat-sports       { background: linear-gradient(135deg, #7c2d12 0%, #ea580c 100%); }
    .topic-hero.cat-society      { background: linear-gradient(135deg, #1e293b 0%, #64748b 100%); }
    .topic-hero.cat-misc         { background: linear-gradient(135deg, #1e293b 0%, #475569 100%); }

    .topic-hero::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at top right, rgba(255,255,255,0.20), transparent 30%),
        radial-gradient(circle at 20% 100%, rgba(255,255,255,0.10), transparent 28%);
      pointer-events: none;
    }

    .hero-inner {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
      gap: 1.5rem;
      align-items: end;
    }

    .hero-copy {
      max-width: 56rem;
    }

    .hero-kicker {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      font-size: 0.72rem;
      font-weight: 800;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.92);
      padding: 0.45rem 0.8rem;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.18);
      margin-bottom: 1rem;
    }

    .hero-meta {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      flex-wrap: wrap;
      margin-bottom: 0.85rem;
    }

    .hero-category {
      font-family: "Manrope", sans-serif;
      font-size: 0.65rem;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.78);
      padding: 0.28rem 0.52rem;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.10);
      border: 1px solid rgba(255, 255, 255, 0.16);
    }

    .hero-status {
      font-size: 0.58rem;
      font-family: "Manrope", sans-serif;
      font-weight: 800;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      padding: 0.28rem 0.56rem;
      border-radius: 999px;
    }
    .status-new        { background: rgba(220, 252, 231, 0.96); color: #15803d; }
    .status-developing { background: rgba(254, 249, 195, 0.96); color: #a16207; }
    .status-fading     { background: rgba(255,255,255,0.14); color: rgba(255,255,255,0.92); border: 1px solid rgba(255,255,255,0.18); }

    .hero-title {
      font-family: "Newsreader", Georgia, serif;
      font-size: clamp(2.5rem, 5vw, 4.6rem);
      font-weight: 800;
      line-height: 0.98;
      letter-spacing: -0.05em;
      margin-bottom: 0.95rem;
      max-width: 12ch;
    }

    .hero-dek {
      max-width: 58ch;
      font-size: 1rem;
      line-height: 1.75;
      color: rgba(255,255,255,0.80);
      margin-bottom: 1.35rem;
    }

    .hero-foot {
      display: flex;
      flex-wrap: wrap;
      gap: 0.7rem 1rem;
      font-size: 0.8rem;
      color: rgba(255,255,255,0.72);
      font-weight: 600;
    }

    .hero-foot span {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
    }

    .hero-stats {
      display: grid;
      gap: 0.85rem;
      align-content: start;
    }

    .site-footer {
      width: min(1180px, calc(100% - 2rem));
      margin: 2rem auto 1.5rem;
      padding-top: 1.2rem;
      border-top: 1px solid var(--rule);
      color: var(--ink-muted);
      font-size: 0.82rem;
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: space-between;
      gap: 0.85rem;
    }

    .footer-links {
      display: flex;
      flex-wrap: wrap;
      gap: 0.8rem;
    }

    .footer-links a {
      color: var(--ink-soft);
      font-weight: 800;
    }

    .footer-links a:hover {
      color: var(--cat-geopolitics);
    }

    .hero-stat-card {
      padding: 1rem 1.05rem;
      border-radius: 22px;
      border: 1px solid rgba(255,255,255,0.18);
      background: rgba(255,255,255,0.10);
      backdrop-filter: blur(14px);
      -webkit-backdrop-filter: blur(14px);
    }

    .hero-stat-value {
      display: block;
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.9rem;
      font-weight: 700;
      letter-spacing: -0.05em;
      color: #fff;
      margin-bottom: 0.18rem;
    }

    .hero-stat-label {
      display: block;
      font-size: 0.78rem;
      font-weight: 700;
      color: rgba(255,255,255,0.88);
      margin-bottom: 0.22rem;
    }

    .hero-stat-note {
      display: block;
      font-size: 0.72rem;
      line-height: 1.5;
      color: rgba(255,255,255,0.68);
    }


    .content {
      max-width: 1180px;
      margin: 0 auto;
      padding: 0 1.5rem 4rem;
    }

    .content-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.72fr);
      gap: 1.5rem;
      align-items: start;
    }

    .main-column {
      min-width: 0;
    }

    .side-column {
      min-width: 0;
      position: sticky;
      top: 6.25rem;
      max-height: calc(100vh - 7.5rem);
      overflow-y: auto;
      overscroll-behavior: contain;
      scrollbar-width: thin;
      scrollbar-color: rgba(148,163,184,0.4) transparent;
      display: grid;
      gap: 1rem;
      align-content: start;
    }
    .side-column::-webkit-scrollbar { width: 4px; }
    .side-column::-webkit-scrollbar-thumb { background: rgba(148,163,184,0.4); border-radius: 2px; }

    .panel {
      background: var(--card);
      border: 1px solid rgba(255, 255, 255, 0.7);
      border-radius: 24px;
      box-shadow: var(--shadow-card);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
    }

    .ai-brief {
      margin-bottom: 1.2rem;
      overflow: hidden;
      border-color: rgba(37, 99, 235, 0.12);
      background:
        linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.78)),
        radial-gradient(circle at top right, rgba(37,99,235,0.12), transparent 30%);
    }

    .ai-brief-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 1rem;
      padding: 1.1rem 1.2rem 0.9rem;
      border-bottom: 1px solid rgba(148, 163, 184, 0.14);
    }

    .ai-brief-kicker {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      margin-bottom: 0.55rem;
      padding: 0.26rem 0.5rem;
      border-radius: 999px;
      background: rgba(37, 99, 235, 0.08);
      color: #2563eb;
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }

    .ai-brief-title {
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.55rem;
      font-weight: 700;
      line-height: 1.08;
      color: var(--ink);
    }

    .ai-brief-note {
      max-width: 28rem;
      font-size: 0.82rem;
      line-height: 1.6;
      color: var(--ink-muted);
    }

    .ai-brief-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0.75rem;
      padding: 1rem;
    }

    .ai-brief-card {
      border: 1px solid rgba(148, 163, 184, 0.16);
      border-radius: 18px;
      background: rgba(255, 255, 255, 0.72);
      padding: 0.95rem;
    }

    .ai-brief-card.full {
      grid-column: 1 / -1;
    }

    .ai-brief-label {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.75rem;
      margin-bottom: 0.6rem;
      font-size: 0.62rem;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--ink-muted);
    }

    .ai-brief-label.consensus { color: #15803d; }
    .ai-brief-label.contested { color: #b91c1c; }
    .ai-brief-card.contested li::before { background: #dc2626; }

    .ai-brief-list {
      list-style: none;
      display: grid;
      gap: 0.5rem;
    }

    .ai-brief-list li {
      position: relative;
      padding-left: 1rem;
      font-size: 0.82rem;
      line-height: 1.58;
      color: var(--ink-soft);
    }

    .ai-brief-list li::before {
      content: "";
      position: absolute;
      left: 0;
      top: 0.6em;
      width: 0.35rem;
      height: 0.35rem;
      border-radius: 50%;
      background: var(--ink-faint);
    }

    .ai-brief-card.consensus li::before { background: #16a34a; }

    .qc-card {
      border-color: rgba(15, 118, 110, 0.20);
      background: linear-gradient(135deg, rgba(240, 253, 250, 0.92), rgba(255, 251, 235, 0.78));
    }

    .qc-card .ai-brief-label {
      color: #0f766e;
    }

    .qc-note {
      color: var(--ink-soft);
      font-size: 0.86rem;
      line-height: 1.6;
      margin-bottom: 0.7rem;
    }

    .qc-foot {
      color: var(--ink-muted);
      font-size: 0.74rem;
      font-weight: 800;
      margin-top: 0.75rem;
    }

    .ai-metrics {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 0.65rem;
    }

    .ai-metric {
      padding: 0.75rem;
      border-radius: 14px;
      background: rgba(248, 250, 252, 0.82);
      border: 1px solid rgba(148, 163, 184, 0.14);
    }

    .ai-metric-value {
      display: block;
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1;
      color: var(--ink);
      margin-bottom: 0.25rem;
    }

    .ai-metric-label {
      display: block;
      font-size: 0.7rem;
      line-height: 1.35;
      color: var(--ink-muted);
      font-weight: 700;
    }

    .background-card {
      padding: 1.05rem 1.1rem;
      display: flex;
      gap: 0.75rem;
      align-items: flex-start;
    }
    .background-label {
      flex-shrink: 0;
      font-family: "Manrope", sans-serif;
      font-size: 0.58rem;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--ink-muted);
      margin-top: 0.2rem;
      background: rgba(255, 255, 255, 0.88);
      padding: 0.26rem 0.5rem;
      border-radius: 999px;
      white-space: nowrap;
    }
    .background-text {
      font-size: 0.92rem;
      color: var(--ink-soft);
      line-height: 1.72;
    }

    .viewpoints {
      border-radius: 24px;
      overflow: hidden;
    }
    .viewpoints-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.8rem;
      padding: 1rem 1.1rem 0.8rem;
      border-bottom: 1px solid rgba(148, 163, 184, 0.12);
      flex-wrap: wrap;
    }
    .viewpoints-label {
      font-family: "Manrope", sans-serif;
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #7c2d12;
      background: rgba(251, 191, 36, 0.16);
      border: 1px solid rgba(251, 191, 36, 0.24);
      padding: 0.28rem 0.52rem;
      border-radius: 999px;
    }
    .divergence {
      display: flex;
      align-items: center;
      gap: 0.55rem;
    }
    .divergence-label,
    .divergence-value {
      font-family: "Manrope", sans-serif;
      font-size: 0.62rem;
      font-weight: 600;
      color: var(--ink-faint);
    }
    .divergence-dots {
      display: flex;
      gap: 4px;
    }
    .divergence-dot {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: rgba(226, 232, 240, 0.9);
    }
    .divergence-dot.filled.d1 { background: #22c55e; }
    .divergence-dot.filled.d2 { background: #86efac; }
    .divergence-dot.filled.d3 { background: #fbbf24; }
    .divergence-dot.filled.d4 { background: #f97316; }
    .divergence-dot.filled.d5 { background: #ef4444; }

    /* ── Divergence tooltip ── */
    .divergence-wrap {
      position: relative;
      display: inline-flex;
      align-items: center;
      cursor: default;
    }
    .divergence-tip {
      position: fixed;
      width: 230px;
      background: #1a2535;
      border: 1px solid rgba(148, 163, 184, 0.18);
      border-radius: 12px;
      padding: 0.8rem 0.9rem 0.75rem;
      box-shadow: 0 12px 32px rgba(0,0,0,0.5), 0 2px 8px rgba(0,0,0,0.3);
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.17s ease;
      z-index: 9999;
    }
    .divergence-tip.visible {
      opacity: 1;
      pointer-events: auto;
    }
    .divergence-tip-title {
      font-family: "Manrope", sans-serif;
      font-size: 0.66rem;
      font-weight: 700;
      color: #e2e8f0;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      margin-bottom: 0.35rem;
    }
    .divergence-tip-desc {
      font-family: "Manrope", sans-serif;
      font-size: 0.63rem;
      color: #94a3b8;
      line-height: 1.55;
      margin-bottom: 0.55rem;
    }
    .divergence-tip-scale {
      display: flex;
      flex-direction: column;
      gap: 0.22rem;
      border-top: 1px solid rgba(148, 163, 184, 0.1);
      padding-top: 0.45rem;
    }
    .divergence-tip-row {
      display: flex;
      align-items: center;
      gap: 0.45rem;
    }
    .divergence-tip-swatch {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      flex-shrink: 0;
    }
    .divergence-tip-row span {
      font-family: "Manrope", sans-serif;
      font-size: 0.61rem;
      color: #94a3b8;
      line-height: 1.4;
    }
    .divergence-tip-row span strong {
      color: #cbd5e1;
      font-weight: 600;
    }
    /* Hero stat card — tooltip handled by JS like all other divergence tips */
    .hero-stat-card.has-tip { cursor: default; }

    .viewpoint-row {
      display: flex;
      gap: 0.75rem;
      align-items: baseline;
      padding: 0.58rem 1.1rem;
    }
    .viewpoint-row:last-child { padding-bottom: 1rem; }
    .viewpoint-country {
      flex-shrink: 0;
      font-family: "Manrope", sans-serif;
      font-size: 0.68rem;
      font-weight: 700;
      min-width: 98px;
      color: #fff;
      padding: 0.2rem 0.5rem;
      border-radius: 999px;
      text-align: center;
    }
    .viewpoint-angle {
      font-size: 0.9rem;
      color: var(--ink-soft);
      line-height: 1.62;
    }

    .section-label {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      margin: 0 0 1.1rem;
      font-family: "Manrope", sans-serif;
      font-size: 0.63rem;
      font-weight: 800;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--ink-muted);
    }
    .section-label::after {
      content: ""; flex: 1;
      height: 1px;
      background: linear-gradient(90deg, rgba(148,163,184,0.36), rgba(148,163,184,0));
    }

    .article-stream {
      display: grid;
      gap: 0.9rem;
    }

    .article {
      position: relative;
      background: var(--card);
      border: 1px solid rgba(255, 255, 255, 0.7);
      border-radius: 24px;
      padding: 1.15rem 1.2rem;
      box-shadow: var(--shadow-card);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      transition: box-shadow 0.18s, transform 0.18s, border-color 0.18s;
      display: flex;
      gap: 1rem;
      align-items: flex-start;
    }
    .article:hover {
      border-color: rgba(148, 163, 184, 0.28);
      box-shadow: 0 20px 42px rgba(15, 23, 42, 0.12);
      transform: translateY(-2px);
    }

    .article-index {
      position: absolute;
      top: 1rem;
      right: 1rem;
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.3rem;
      font-weight: 700;
      color: rgba(15, 23, 42, 0.16);
    }

    .article-body {
      flex: 1;
      min-width: 0;
      padding-right: 2.2rem;
    }

    .article-thumb {
      flex-shrink: 0;
      width: 138px;
      height: 102px;
      border-radius: 16px;
      object-fit: cover;
      background: #f1f5f9;
      display: block;
      box-shadow: 0 10px 24px rgba(15, 23, 42, 0.10);
    }

    .article-meta {
      display: flex;
      align-items: center;
      gap: 0.3rem;
      font-size: 0.68rem;
      font-family: "Manrope", sans-serif;
      color: var(--ink-faint);
      margin-bottom: 0.38rem;
      flex-wrap: wrap;
    }

    .article-source { color: var(--ink-soft); font-weight: 600; font-family: "Manrope", sans-serif; }

    .article-title a {
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.18rem;
      font-weight: 700;
      color: var(--ink);
      line-height: 1.3;
      letter-spacing: -0.03em;
    }
    .article-title a:hover { color: var(--cat-geopolitics); }

    .article-original {
      font-size: 0.74rem;
      color: #94a3b8;
      margin-top: 0.28rem;
      font-style: italic;
      font-family: "Manrope", sans-serif;
    }

    .article-summary {
      font-size: 0.9rem;
      color: var(--ink-soft);
      margin-top: 0.38rem;
      line-height: 1.72;
    }

    .lang-badge {
      display: inline-block;
      font-size: 0.6rem;
      font-family: "Manrope", sans-serif;
      font-weight: 700;
      padding: 0.12rem 0.38rem;
      border-radius: 3px;
      vertical-align: middle;
      margin-right: 0.2rem;
      letter-spacing: 0.04em;
    }
    .lang-en   { background: var(--bbc);    color: #fff; }
    .lang-fr   { background: var(--lm);     color: #fff; }
    .lang-zh   { background: var(--pd);     color: #fff; }
    .lang-ru   { background: var(--tass);   color: #fff; }
    .lang-pt   { background: var(--folha);  color: #fff; }
    .lang-ar   { background: var(--aj);     color: #fff; }
    .lang-id   { background: var(--kompas); color: #fff; }
    .lang-misc { background: #6b7280;       color: #fff; }

    .country-badge {
      display: inline-block;
      font-size: 0.6rem;
      font-family: "Manrope", sans-serif;
      font-weight: 600;
      padding: 0.12rem 0.38rem;
      border-radius: 3px;
      vertical-align: middle;
      margin-right: 0.2rem;
      background: rgba(255, 255, 255, 0.64);
      border: 1px solid rgba(148, 163, 184, 0.22);
      color: var(--ink-muted);
    }


    .nuance-toggle {
      display: inline-flex;
      align-items: center;
      gap: 0.3rem;
      margin-top: 0.45rem;
      font-size: 0.67rem;
      font-family: "Manrope", sans-serif;
      font-weight: 700;
      color: #92400e;
      cursor: pointer;
      background: rgba(254, 249, 195, 0.7);
      border: 1px solid rgba(251, 191, 36, 0.24);
      border-radius: 999px;
      padding: 0.24rem 0.68rem;
      user-select: none;
      transition: background 0.12s;
    }
    .nuance-toggle:hover { background: rgba(253, 230, 138, 0.72); }

    .nuance-list {
      display: none;
      margin-top: 0.5rem;
      border: 1px solid rgba(251, 191, 36, 0.25);
      border-radius: 14px;
      overflow: hidden;
    }
    .nuance-list.open { display: block; }

    .nuance-item {
      font-size: 0.8rem;
      line-height: 1.65;
      color: var(--ink-soft);
      padding: 0.55rem 0.8rem;
      background: rgba(255, 251, 235, 0.82);
    }
    .nuance-item + .nuance-item { border-top: 1px solid rgba(251, 191, 36, 0.22); }

    .fading-notice {
      padding: 0.9rem 1rem;
      font-family: "Manrope", sans-serif;
      font-size: 0.8rem;
      line-height: 1.65;
      color: var(--ink-muted);
    }

    .nuance-phrase {
      font-family: "Manrope", sans-serif;
      font-weight: 700;
      color: #92400e;
    }

    .side-stack {
      display: grid;
      gap: 1rem;
    }

    .mini-panel {
      padding: 1.05rem 1.1rem;
    }

    .mini-label {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      margin-bottom: 0.7rem;
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--ink-muted);
      padding: 0.26rem 0.5rem;
      border-radius: 999px;
      background: rgba(148, 163, 184, 0.10);
    }

    .mini-value {
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.9rem;
      font-weight: 700;
      letter-spacing: -0.05em;
      color: var(--ink);
      margin-bottom: 0.2rem;
    }

    .mini-note {
      font-size: 0.82rem;
      line-height: 1.6;
      color: var(--ink-muted);
    }

    .source-memory-list {
      display: grid;
      gap: 0.7rem;
    }

    .source-memory-item {
      padding: 0.75rem;
      border-radius: 14px;
      border: 1px solid rgba(148, 163, 184, 0.14);
      background: rgba(255, 255, 255, 0.58);
    }

    .source-memory-name {
      display: block;
      margin-bottom: 0.32rem;
      color: var(--ink);
      font-size: 0.78rem;
      font-weight: 800;
    }

    .source-memory-name:hover {
      color: var(--cat-geopolitics);
    }

    .source-memory-text {
      font-size: 0.76rem;
      line-height: 1.55;
      color: var(--ink-muted);
    }

    .related-topics {
      margin-top: 1.2rem;
      padding: clamp(1rem, 2.2vw, 1.35rem);
      overflow: hidden;
      background:
        radial-gradient(circle at 8% 0%, rgba(37, 99, 235, 0.08), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.78));
    }

    .related-head {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: 1rem;
      margin-bottom: 1rem;
    }

    .related-title {
      font-size: 0.68rem;
      font-weight: 900;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--ink-muted);
    }

    .related-head .mini-note {
      max-width: 42rem;
      margin-top: 0.22rem;
      font-size: 0.78rem;
    }

    .related-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0.85rem;
    }

    .related-card {
      display: block;
      min-width: 0;
      padding: 0.95rem 1rem;
      border-radius: 20px;
      border: 1px solid rgba(148, 163, 184, 0.16);
      background: rgba(255, 255, 255, 0.78);
      box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
      transition: transform 0.18s, border-color 0.18s, background 0.18s, box-shadow 0.18s;
    }

    .related-card:hover {
      transform: translateY(-2px);
      border-color: rgba(37, 99, 235, 0.28);
      background: #fff;
      box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
    }

    .related-kicker {
      color: var(--ink-faint);
      font-size: 0.58rem;
      font-weight: 900;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      margin-bottom: 0.42rem;
    }

    .related-name {
      font-family: "Newsreader", Georgia, serif;
      font-size: clamp(1.08rem, 2vw, 1.32rem);
      line-height: 1.02;
      letter-spacing: -0.03em;
      color: var(--ink);
    }

    .topic-nav-wrap {
      margin-top: 2rem;
    }

    .topic-nav {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 0.8rem;
      padding-top: 1.25rem;
      border-top: 1px solid rgba(148, 163, 184, 0.14);
    }

    .topic-nav a {
      font-family: "Manrope", sans-serif;
      font-size: 0.78rem;
      font-weight: 700;
      color: var(--ink-soft);
      padding: 0.58rem 0.92rem;
      border: 1px solid rgba(148, 163, 184, 0.20);
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.76);
      transition: color 0.18s, border-color 0.18s, transform 0.18s;
    }
    .topic-nav a:hover {
      color: var(--cat-geopolitics);
      border-color: rgba(147, 197, 253, 0.85);
      transform: translateY(-1px);
    }
    .topic-nav .placeholder { visibility: hidden; }

    @media (max-width: 920px) {
      body { padding-top: 5.75rem; }

      .sticky-bar {
        top: 0.75rem;
        width: calc(100% - 1rem);
        padding: 0.75rem 0.85rem;
        gap: 0.75rem;
      }

      .hero-shell,
      .content {
        padding-left: 1rem;
        padding-right: 1rem;
      }

      .hero-inner,
      .content-grid {
        grid-template-columns: 1fr;
      }

      .topic-hero {
        padding: 1.6rem;
      }

      .side-column {
        position: static;
      }
    }

    @media (max-width: 640px) {
      body {
        padding-top: 4.75rem;
        padding-bottom: 5.5rem;
      }

      .sticky-bar {
        border-radius: 999px;
        align-items: center;
        flex-wrap: nowrap;
        padding: 0.62rem 0.75rem;
      }

      .sticky-logo {
        border-right: none;
        padding-right: 0;
        flex-shrink: 0;
      }

      .sticky-cats {
        flex: 1;
        min-width: 0;
      }

      .sticky-feed-link {
        display: none;
      }

      .topic-hero {
        padding: 1.2rem;
        border-radius: 20px;
      }

      .hero-kicker {
        font-size: 0.62rem;
        letter-spacing: 0.1em;
        margin-bottom: 0.7rem;
      }

      .hero-title {
        max-width: none;
        font-size: 2.2rem;
      }

      .hero-dek {
        font-size: 0.92rem;
        line-height: 1.58;
        margin-bottom: 0.9rem;
      }

      .hero-stats {
        display: none;
      }

      .side-column {
        order: -1;
      }

      .main-column {
        order: 1;
      }

      .panel,
      .article {
        border-radius: 18px;
      }

      .ai-brief-head {
        display: block;
        padding: 1rem;
      }

      .ai-brief-title {
        font-size: 1.32rem;
        margin-bottom: 0.45rem;
      }

      .ai-brief-grid,
      .ai-metrics {
        grid-template-columns: 1fr;
      }

      .ai-brief-grid {
        padding: 0.85rem;
      }

      .side-stack {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
      }

      .mini-panel {
        padding: 0.9rem;
      }

      .mini-value {
        font-size: 1.45rem;
      }

      .article {
        flex-direction: row;
        gap: 0.75rem;
        padding: 1rem;
      }

      .article-body {
        padding-right: 0;
      }

      .article-index {
        display: none;
      }

      .article:not(:first-child) .article-thumb {
        display: none;
      }

      .article:first-child {
        flex-direction: column-reverse;
      }

      .article:first-child .article-thumb {
        width: 100%;
        height: 190px;
      }

      .article-title a {
        font-size: 1.05rem;
      }

      .article-summary {
        font-size: 0.84rem;
        line-height: 1.58;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
      }

      .viewpoint-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
      }

      .viewpoint-country {
        min-width: 0;
      }

      .topic-nav {
        flex-wrap: wrap;
      }

      .topic-nav a,
      .topic-nav .placeholder {
        width: 100%;
        text-align: center;
      }

      .related-grid {
        grid-template-columns: 1fr;
      }

      .mobile-bottom-nav {
        position: fixed;
        left: 50%;
        bottom: 0.75rem;
        transform: translateX(-50%);
        z-index: 220;
        display: flex;
        align-items: center;
        justify-content: space-around;
        gap: 0.35rem;
        width: min(calc(100% - 1rem), 28rem);
        padding: 0.45rem;
        border-radius: 999px;
        background: rgba(15, 23, 42, 0.82);
        border: 1px solid rgba(255,255,255,0.14);
        box-shadow: var(--shadow-nav);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
      }

      .mobile-bottom-nav a {
        flex: 1;
        text-align: center;
        color: rgba(226, 232, 240, 0.82);
        font-size: 0.72rem;
        font-weight: 800;
        padding: 0.55rem 0.45rem;
        border-radius: 999px;
      }

      .mobile-bottom-nav a.active {
        color: var(--ink);
        background: #fff;
      }
    }

    /* ── Consensus / Contested ───────────────────────────────────────── */
    .framing-panel {
      display: flex;
      flex-direction: column;
      gap: 0.9rem;
    }
    .framing-half {
      background: rgba(255,255,255,0.78);
      border: 1px solid rgba(148,163,184,0.22);
      border-radius: 14px;
      padding: 0.85rem 0.95rem;
    }
    .framing-half-label {
      font-family: "Manrope", sans-serif;
      font-size: 0.62rem;
      font-weight: 700;
      letter-spacing: 0.07em;
      text-transform: uppercase;
      margin-bottom: 0.55rem;
      display: flex;
      align-items: center;
      gap: 0.35rem;
    }
    .framing-half.consensus .framing-half-label { color: #16a34a; }
    .framing-half.contested .framing-half-label { color: #dc2626; }
    .framing-icon {
      font-style: normal;
      font-size: 0.75rem;
    }
    .framing-list {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 0.42rem;
    }
    .framing-list li {
      font-family: "Manrope", sans-serif;
      font-size: 0.7rem;
      color: var(--ink-soft);
      line-height: 1.55;
      padding-left: 1rem;
      position: relative;
    }
    .framing-half.consensus .framing-list li::before {
      content: "✓";
      position: absolute;
      left: 0;
      color: #16a34a;
      font-weight: 700;
    }
    .framing-half.contested .framing-list li::before {
      content: "⟂";
      position: absolute;
      left: 0;
      color: #dc2626;
      font-weight: 700;
    }

    /* ── Story evolution timeline ────────────────────────────────────── */
    .evolution-panel {}
    .evolution-label {
      font-family: "Manrope", sans-serif;
      font-size: 0.62rem;
      font-weight: 700;
      letter-spacing: 0.07em;
      text-transform: uppercase;
      color: var(--ink-faint);
      margin-bottom: 0.65rem;
    }
    .evolution-table {
      width: 100%;
      border-collapse: collapse;
    }
    .evolution-table th {
      font-family: "Manrope", sans-serif;
      font-size: 0.58rem;
      font-weight: 700;
      letter-spacing: 0.05em;
      text-transform: uppercase;
      color: var(--ink-faint);
      text-align: left;
      padding: 0 0 0.45rem;
      border-bottom: 1px solid var(--rule);
    }
    .evolution-table th:last-child { text-align: right; }
    .evolution-table td {
      font-family: "Manrope", sans-serif;
      font-size: 0.67rem;
      color: var(--ink-muted);
      padding: 0.42rem 0;
      border-bottom: 1px solid rgba(148,163,184,0.1);
      vertical-align: middle;
    }
    .evolution-table tr:last-child td { border-bottom: none; }
    .evolution-table td:last-child { text-align: right; }
    .evo-date { color: var(--ink-faint); font-size: 0.63rem; }
    .evo-div-cell {
      display: flex;
      align-items: center;
      gap: 5px;
    }
    .evo-dots {
      display: flex;
      gap: 3px;
    }
    .evo-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: rgba(148,163,184,0.4);
    }
    .evo-dot.on.d1 { background: #22c55e; }
    .evo-dot.on.d2 { background: #86efac; }
    .evo-dot.on.d3 { background: #fbbf24; }
    .evo-dot.on.d4 { background: #f97316; }
    .evo-dot.on.d5 { background: #ef4444; }
    .evo-div-num { font-size: 0.63rem; color: var(--ink-faint); }
    .evo-trend {
      font-size: 0.7rem;
      margin-left: 3px;
    }
    .evo-trend.up   { color: #ef4444; }
    .evo-trend.down { color: #22c55e; }
    .evo-current {
      background: rgba(37,99,235,0.05);
    }
    .evo-current td { color: var(--ink-soft); font-weight: 600; }

    /* ── Bias dimension bars ─────────────────────────────────────────── */
    .bias-dims {
      display: grid;
      gap: 0.4rem;
      margin-top: 0.55rem;
    }
    .bias-dim-row {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }
    .bias-dim-label {
      font-size: 0.6rem;
      font-weight: 700;
      color: var(--ink-faint);
      width: 5.8rem;
      flex-shrink: 0;
      text-transform: capitalize;
    }
    .bias-bar-track {
      flex: 1;
      height: 4px;
      border-radius: 3px;
      background: rgba(148, 163, 184, 0.18);
      overflow: hidden;
    }
    .bias-bar-fill {
      height: 100%;
      border-radius: 3px;
      background: linear-gradient(90deg, #38bdf8, #7c3aed);
    }
    .bias-dim-val {
      font-size: 0.6rem;
      color: var(--ink-faint);
      width: 1.2rem;
      text-align: right;
      flex-shrink: 0;
    }

    /* ── Loaded term tags ────────────────────────────────────────────── */

    /* ── Framing drift panel ─────────────────────────────────────────── */
    .drift-panel {
      margin-bottom: 1.2rem;
      overflow: hidden;
      border-color: rgba(251, 191, 36, 0.18);
      background:
        linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.78)),
        radial-gradient(circle at top right, rgba(251,191,36,0.09), transparent 30%);
    }
    .drift-head {
      padding: 0.9rem 1.2rem 0.75rem;
      border-bottom: 1px solid rgba(148, 163, 184, 0.12);
      display: flex;
      align-items: center;
      gap: 0.7rem;
    }
    .drift-kicker {
      display: inline-flex;
      align-items: center;
      padding: 0.24rem 0.48rem;
      border-radius: 999px;
      background: rgba(251, 191, 36, 0.12);
      color: #92400e;
      font-size: 0.58rem;
      font-weight: 800;
      letter-spacing: 0.13em;
      text-transform: uppercase;
      white-space: nowrap;
    }
    .drift-title {
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.18rem;
      font-weight: 700;
      color: var(--ink);
      line-height: 1.2;
    }
    .drift-rows {
      padding: 0.65rem 1.2rem 1rem;
      display: grid;
      gap: 0.5rem;
    }
    .drift-row {
      display: flex;
      gap: 0.7rem;
      align-items: flex-start;
      padding: 0.5rem 0.65rem;
      border-radius: 12px;
      background: rgba(251, 191, 36, 0.06);
      border: 1px solid rgba(251, 191, 36, 0.14);
    }
    .drift-country {
      flex-shrink: 0;
      font-size: 0.64rem;
      font-weight: 700;
      font-family: "Manrope", sans-serif;
      color: #fff;
      padding: 0.18rem 0.48rem;
      border-radius: 999px;
      min-width: 76px;
      text-align: center;
    }
    .drift-signal {
      font-size: 0.83rem;
      line-height: 1.58;
      color: var(--ink-soft);
    }

    /* ── Perspectives in main column ───────────────────────────────── */
    .viewpoints-main {
      margin-bottom: 1.2rem;
      overflow: hidden;
    }
    .viewpoints-main-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.8rem;
      padding: 1rem 1.2rem 0.85rem;
      border-bottom: 1px solid rgba(148, 163, 184, 0.12);
      flex-wrap: wrap;
    }
    .viewpoints-main-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
      gap: 0.65rem;
      padding: 0.85rem 1.2rem 1rem;
    }
    .vp-card {
      background: rgba(248, 250, 252, 0.72);
      border: 1px solid rgba(148, 163, 184, 0.14);
      border-radius: 14px;
      padding: 0.72rem 0.85rem;
      display: flex;
      flex-direction: column;
      gap: 0.42rem;
    }
    .vp-country {
      display: inline-flex;
      align-self: flex-start;
      font-family: "Manrope", sans-serif;
      font-size: 0.65rem;
      font-weight: 700;
      color: #fff;
      padding: 0.18rem 0.5rem;
      border-radius: 999px;
    }
    .vp-angle {
      font-size: 0.86rem;
      line-height: 1.6;
      color: var(--ink-soft);
      margin: 0;
    }
    /* ── Compare mode ───────────────────────────────────────────────── */
    .vp-mode-toggle {
      display: flex;
      gap: 0.35rem;
      margin-left: auto;
    }
    .vp-mode-btn {
      font-family: "Manrope", sans-serif;
      font-size: 0.72rem;
      font-weight: 700;
      padding: 0.38rem 0.85rem;
      border-radius: 999px;
      border: 1px solid rgba(148, 163, 184, 0.3);
      background: transparent;
      color: var(--ink-muted);
      cursor: pointer;
      transition: all 0.15s;
      white-space: nowrap;
    }
    .vp-mode-btn.active {
      background: var(--ink);
      color: #fff;
      border-color: var(--ink);
    }
    .vp-mode-btn:hover:not(.active) {
      border-color: var(--ink-soft);
      color: var(--ink);
    }
    .compare-panel {
      display: none;
      padding: 0.9rem 1.2rem 1.1rem;
      flex-direction: column;
      gap: 0.85rem;
    }
    .compare-panel.visible { display: flex; }
    .compare-selectors {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0.75rem;
      align-items: center;
    }
    .compare-select {
      width: 100%;
      font-family: "Manrope", sans-serif;
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--ink);
      background: rgba(248, 250, 252, 0.9);
      border: 1px solid rgba(148, 163, 184, 0.3);
      border-radius: 10px;
      padding: 0.5rem 0.75rem;
      cursor: pointer;
      appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 0.75rem center;
      padding-right: 2rem;
    }
    .compare-columns {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0.75rem;
    }
    .compare-col {
      background: rgba(248, 250, 252, 0.72);
      border: 1px solid rgba(148, 163, 184, 0.14);
      border-radius: 14px;
      padding: 1rem 1.1rem;
      display: flex;
      flex-direction: column;
      gap: 0.55rem;
      min-height: 140px;
    }
    .compare-col-source {
      font-family: "Manrope", sans-serif;
      font-size: 0.8rem;
      font-weight: 700;
      color: var(--ink);
    }
    .compare-col-angle {
      font-size: 0.88rem;
      line-height: 1.62;
      color: var(--ink-soft);
      flex: 1;
    }
    .compare-col-link {
      font-size: 0.76rem;
      font-weight: 600;
      color: var(--ink-muted);
      text-decoration: none;
      margin-top: auto;
    }
    .compare-col-link:hover { color: var(--ink); }
    .compare-col-empty {
      color: var(--ink-faint);
      font-size: 0.82rem;
      font-style: italic;
    }
    .compare-share {
      display: flex;
      align-items: center;
      gap: 0.6rem;
    }
    .compare-share-btn {
      font-family: "Manrope", sans-serif;
      font-size: 0.76rem;
      font-weight: 700;
      padding: 0.38rem 0.9rem;
      border-radius: 999px;
      border: 1px solid rgba(148, 163, 184, 0.3);
      background: transparent;
      color: var(--ink-muted);
      cursor: pointer;
      transition: all 0.15s;
    }
    .compare-share-btn:hover {
      border-color: var(--ink-soft);
      color: var(--ink);
    }
    .compare-share-confirm {
      font-size: 0.74rem;
      color: #16a34a;
      font-weight: 600;
      opacity: 0;
      transition: opacity 0.2s;
    }
    .compare-share-confirm.show { opacity: 1; }
    @media (max-width: 640px) {
      .compare-selectors,
      .compare-columns { grid-template-columns: 1fr; }
      .compare-col:first-child::after {
        content: 'vs';
        display: block;
        text-align: center;
        font-size: 0.7rem;
        font-weight: 800;
        letter-spacing: 0.08em;
        color: var(--ink-faint);
        margin-top: 0.5rem;
      }
    }

    .drift-inline {
      border-top: 1px solid rgba(148, 163, 184, 0.1);
      padding: 0.65rem 1.2rem 0.9rem;
    }
    .drift-inline-label {
      display: block;
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--ink-faint);
      margin-bottom: 0.5rem;
    }
    .drift-inline-row {
      display: flex;
      gap: 0.7rem;
      align-items: flex-start;
      margin-bottom: 0.4rem;
    }

    /* ── What's missing toggle ──────────────────────────────────────── */
    .missing-toggle-card { padding: 0; overflow: hidden; }
    .missing-toggle {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.78rem 0.95rem;
      background: none;
      border: none;
      cursor: pointer;
      font-family: "Manrope", sans-serif;
      font-size: 0.72rem;
      font-weight: 700;
      color: var(--ink-muted);
      text-align: left;
    }
    .missing-toggle:hover { color: var(--ink-soft); }
    .missing-arrow { transition: transform 0.18s; font-size: 0.68rem; }
    .missing-toggle[aria-expanded="true"] .missing-arrow { transform: rotate(90deg); }
    .missing-body { padding: 0 0.95rem 0.85rem; display: grid; gap: 0.65rem; }
    .missing-item { display: grid; gap: 0.3rem; }
    .missing-item-label {
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 0.1em;
      text-transform: uppercase;
    }
    .missing-item-label.unknowns  { color: #b45309; }
    .missing-item-label.omissions { color: #7c3aed; }
    .missing-item-text { font-size: 0.82rem; line-height: 1.62; color: var(--ink-soft); margin: 0; }

    /* ── Story evolution toggle ─────────────────────────────────────── */
    .evolution-toggle {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.78rem 0.95rem;
      background: none;
      border: none;
      cursor: pointer;
      font-family: "Manrope", sans-serif;
      font-size: 0.72rem;
      font-weight: 700;
      color: var(--ink-muted);
      text-align: left;
    }
    .evolution-toggle:hover { color: var(--ink-soft); }
    .evo-cycle-count { font-weight: 600; color: var(--ink-faint); }
    .evo-arrow { transition: transform 0.18s; font-size: 0.68rem; }
    .evolution-toggle[aria-expanded="true"] .evo-arrow { transform: rotate(90deg); }
    .evolution-body { padding: 0 0.95rem 0.85rem; }

    /* ── Scope badge ────────────────────────────────────────────────── */
    .scope-badge {
      font-family: "Manrope", sans-serif;
      font-size: 0.58rem;
      font-weight: 800;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      padding: 0.24rem 0.5rem;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,0.2);
    }
    .scope-global           { background: rgba(255,255,255,0.10); color: rgba(255,255,255,0.85); }
    .scope-regional         { background: rgba(251,191,36,0.18);  color: #fff8e1; border-color: rgba(251,191,36,0.3); }
    .scope-local-but-revealing { background: rgba(167,243,208,0.18); color: #d1fae5; border-color: rgba(167,243,208,0.3); }

    /* ── Key actors chips ───────────────────────────────────────────── */
    .key-actors {
      display: flex;
      flex-wrap: wrap;
      gap: 0.3rem;
      margin-top: 0.55rem;
    }
    .actor-chip {
      font-size: 0.66rem;
      font-family: "Manrope", sans-serif;
      font-weight: 600;
      padding: 0.2rem 0.52rem;
      border-radius: 999px;
      background: rgba(37, 99, 235, 0.07);
      border: 1px solid rgba(37, 99, 235, 0.14);
      color: #1e40af;
    }

    /* ── Timeline context card ──────────────────────────────────────── */
    .timeline-card {
      padding: 1.05rem 1.1rem;
      display: flex;
      gap: 0.75rem;
      align-items: flex-start;
    }
    .timeline-label {
      flex-shrink: 0;
      font-family: "Manrope", sans-serif;
      font-size: 0.58rem;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--ink-muted);
      margin-top: 0.2rem;
      background: rgba(255, 255, 255, 0.88);
      padding: 0.26rem 0.5rem;
      border-radius: 999px;
      white-space: nowrap;
    }

    /* ── Unknowns / Omissions cards ─────────────────────────────────── */
    .ai-brief-card.unknowns  { border-color: rgba(245,158,11,0.18); background: rgba(255,251,235,0.72); }
    .ai-brief-card.omissions { border-color: rgba(139,92,246,0.18);  background: rgba(245,243,255,0.72); }
    .ai-brief-label.unknowns  { color: #b45309; }
    .ai-brief-label.omissions { color: #7c3aed; }
    .ai-brief-text {
      font-size: 0.82rem;
      line-height: 1.62;
      color: var(--ink-soft);
    }

    /* ── Observation confidence badge ───────────────────────────────── */
    .obs-confidence {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      font-size: 0.56rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      padding: 0.12rem 0.38rem;
      border-radius: 999px;
      margin-left: 0.3rem;
      vertical-align: middle;
    }
    .conf-high   { background: rgba(220,252,231,0.9); color: #15803d; }
    .conf-medium { background: rgba(254,249,195,0.9); color: #92400e; }
    .conf-low    { background: rgba(241,245,249,0.9); color: #64748b; }

    /* ── Consensus trend badge ───────────────────────────────────────── */
    .trend-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.28rem;
      font-size: 0.62rem;
      font-weight: 700;
      padding: 0.2rem 0.48rem;
      border-radius: 999px;
      margin-top: 0.18rem;
    }
    .trend-converging { background: rgba(220, 252, 231, 0.9); color: #15803d; }
    .trend-fracturing  { background: rgba(254, 226, 226, 0.9); color: #b91c1c; }
    .trend-stable      { background: rgba(219, 234, 254, 0.9); color: #1d4ed8; }

    /* ── Perspective CTA — invites prose readers to /perspectives/<slug> ── */
    .perspective-cta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      padding: 1.05rem 1.3rem;
      border-radius: 14px;
      border: 1px solid rgba(15,118,110,0.22);
      background: linear-gradient(135deg, rgba(15,118,110,0.10), rgba(180,83,9,0.06));
      color: inherit;
      transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
      margin-bottom: 1.1rem;
    }
    .perspective-cta:hover {
      transform: translateY(-1px);
      border-color: rgba(15,118,110,0.40);
      box-shadow: 0 12px 28px rgba(15,118,110,0.14);
    }
    .perspective-cta-copy { display: flex; flex-direction: column; gap: 0.18rem; }
    .perspective-cta-kicker {
      color: #0f766e;
      text-transform: uppercase;
      letter-spacing: 0.16em;
      font-size: 0.66rem;
      font-weight: 900;
    }
    .perspective-cta-title {
      font-family: "Newsreader", Georgia, serif;
      font-size: 1.25rem;
      font-weight: 700;
      letter-spacing: -0.015em;
      line-height: 1.15;
    }
    .perspective-cta-note {
      color: #475569;
      font-size: 0.88rem;
      line-height: 1.45;
      margin-top: 0.15rem;
    }
    .perspective-cta-arrow {
      font-size: 1.4rem;
      color: #0f766e;
      flex-shrink: 0;
    }
    @media (max-width: 640px) {
      .perspective-cta { flex-direction: column; align-items: flex-start; }
      .perspective-cta-arrow { align-self: flex-end; margin-top: -1.5rem; }
    }

    /* Lead-position article stream gets a subtle emphasis under the CTA. */
    .article-stream-lead { margin-top: 0.35rem; }
