/* ==========================================================================
   Nyakundi Report — Command Center
   Brutalist editorial UI. Inter + Newsreader. 0px radius, 2px borders.
   Desktop design aligned to the Stitch mockups (Homepage, Radar, Politics,
   Article/International, Article/High-Density).
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Design tokens
   -------------------------------------------------------------------------- */
:root {
    /* Brand */
    --primary:                    #000000;
    --on-primary:                 #ffffff;
    --primary-container:          #1b1b1b;
    --on-primary-container:       #848484;
    --primary-fixed:              #e2e2e2;
    --primary-fixed-dim:          #c6c6c6;
    --on-primary-fixed:           #1b1b1b;
    --on-primary-fixed-variant:   #474747;
    --inverse-primary:            #c6c6c6;

    /* Surface */
    --surface:                    #f9f9f9;
    --surface-bright:             #f9f9f9;
    --surface-dim:                #dadada;
    --surface-container-lowest:   #ffffff;
    --surface-container-low:      #f3f3f3;
    --surface-container:          #eeeeee;
    --surface-container-high:     #e8e8e8;
    --surface-container-highest:  #e2e2e2;
    --surface-variant:            #e2e2e2;
    --surface-tint:               #5e5e5e;
    --inverse-surface:            #303030;
    --inverse-on-surface:         #f1f1f1;

    --on-surface:                 #1a1c1c;
    --on-surface-variant:         #4c4546;

    /* Outline */
    --outline:                    #7e7576;
    --outline-variant:            #cfc4c5;

    /* Secondary (Signal Red) */
    --secondary:                  #b7221e;
    --on-secondary:               #ffffff;
    --secondary-container:        #fe5649;
    --on-secondary-container:     #5c0003;
    --secondary-fixed:            #ffdad5;
    --secondary-fixed-dim:        #ffb4aa;

    /* Error */
    --error:                      #ba1a1a;
    --on-error:                   #ffffff;
    --error-container:            #ffdad6;
    --on-error-container:         #93000a;

    /* Semantic surfaces used in this theme */
    --paper:                      #ffffff;          /* cards, main canvas */
    --sidebar-surface:            #f9fafb;          /* zinc-50 */
    --topbar-surface:             #ffffff;
    --topbar-border:              #000000;

    /* Fonts */
    --font-sans:   "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-serif:  "Newsreader", "Times New Roman", Georgia, serif;
    --font-icon:   "Material Symbols Outlined";

    /* Type scale (from mockups) */
    --fs-headline-xl: 48px;   /* Newsreader 700, lh 1.1, -0.02em */
    --fs-headline-lg: 32px;   /* Newsreader 600, lh 1.2, -0.01em */
    --fs-headline-md: 24px;   /* Newsreader 600, lh 1.2 */
    --fs-body-lg:     18px;   /* Inter 400,  lh 1.6 */
    --fs-body-md:     15px;   /* Inter 400,  lh 1.5 */
    --fs-label-caps:  12px;   /* Inter 700,  lh 1, 0.08em, uppercase */
    --fs-data-mono:   13px;   /* Inter 500,  lh 1, 0.02em */

    /* Spacing */
    --grid-margin:    24px;
    --grid-gutter:    1px;
    --stack-tight:    4px;
    --stack-base:     8px;
    --section-gap:    32px;
    --topbar-h:       64px;
    --sidebar-w:      256px;
    --content-max:    1440px;

    /* Control metrics */
    --border-thin:  1px;
    --border-base:  2px;
    --focus-ring:   0 0 0 2px #fff, 0 0 0 4px #000;
}

/* Dark mode — Command Center (zinc-950 canvas, white ink) */
@media (prefers-color-scheme: dark) {
    :root {
        --primary:                    #ffffff;
        --on-primary:                 #000000;
        --primary-container:          #1b1b1b;
        --on-primary-container:       #c6c6c6;
        --primary-fixed:              #1b1b1b;
        --primary-fixed-dim:          #474747;
        --on-primary-fixed:           #ffffff;
        --on-primary-fixed-variant:   #c6c6c6;

        --surface:                    #09090b;            /* zinc-950 */
        --surface-bright:             #09090b;
        --surface-dim:                #000000;
        --surface-container-lowest:   #000000;
        --surface-container-low:      #111113;
        --surface-container:          #18181b;            /* zinc-900 */
        --surface-container-high:     #1f1f23;
        --surface-container-highest:  #27272a;            /* zinc-800 */
        --surface-variant:            #18181b;
        --surface-tint:               #c6c6c6;
        --inverse-surface:            #f1f1f1;
        --inverse-on-surface:         #1a1c1c;

        --on-surface:                 #ffffff;
        --on-surface-variant:         #c6c6c7;

        --outline:                    #52525b;            /* zinc-600 */
        --outline-variant:            #27272a;            /* zinc-800 */

        --secondary:                  #fe5649;
        --on-secondary:               #000000;
        --secondary-container:        #b7221e;
        --on-secondary-container:     #ffdad5;
        --secondary-fixed:            #5c0003;
        --secondary-fixed-dim:        #930009;

        --paper:                      #09090b;
        --sidebar-surface:            #18181b;
        --topbar-surface:             #09090b;
        --topbar-border:              #ffffff;
    }
}

html[data-theme="dark"] {
    --primary:                    #ffffff;
    --on-primary:                 #000000;
    --primary-container:          #1b1b1b;
    --on-primary-container:       #c6c6c6;

    --surface:                    #09090b;
    --surface-bright:             #09090b;
    --surface-dim:                #000000;
    --surface-container-lowest:   #000000;
    --surface-container-low:      #111113;
    --surface-container:          #18181b;
    --surface-container-high:     #1f1f23;
    --surface-container-highest:  #27272a;
    --surface-variant:            #18181b;
    --surface-tint:               #c6c6c6;

    --on-surface:                 #ffffff;
    --on-surface-variant:         #c6c6c7;

    --outline:                    #52525b;
    --outline-variant:            #27272a;

    --secondary:                  #fe5649;
    --on-secondary:               #000000;
    --secondary-container:        #b7221e;

    --paper:                      #09090b;
    --sidebar-surface:             #18181b;
    --topbar-surface:              #09090b;
    --topbar-border:               #ffffff;
}

/* --------------------------------------------------------------------------
   2. Base & reset
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html {
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.5;
    color: var(--on-surface);
    background: var(--surface);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* App shell layout — content lives under fixed topbar, right of fixed sidebar. */
body.has-shell {
    padding-top: var(--topbar-h);
}
@media (min-width: 960px) {
    body.has-shell { padding-left: var(--sidebar-w); }
}

/* Cap the readable canvas at 1440px, like the mockups */
.canvas {
    max-width: var(--content-max);
    margin-left: auto;
    margin-right: auto;
}

/* Remove default button / input chrome */
button, input, select, textarea {
    font: inherit;
    color: inherit;
}
button {
    background: none;
    border: 0;
    padding: 0;
    cursor: pointer;
}

/* Focus ring */
:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
}

/* Images */
img { max-width: 100%; height: auto; display: block; }

/* Links */
a { color: inherit; text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

/* Selection */
::selection { background: var(--primary); color: var(--on-primary); }

/* Screen reader only */
.sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}

.skip-link {
    position: absolute;
    left: 8px; top: 8px;
    padding: 8px 12px;
    background: var(--primary);
    color: var(--on-primary);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    transform: translateY(-200%);
    z-index: 200;
}
.skip-link:focus { transform: translateY(0); }

/* --------------------------------------------------------------------------
   3. Typography utility classes (mirror the Tailwind tokens in the mockups)
   -------------------------------------------------------------------------- */
.font-serif { font-family: var(--font-serif); }
.font-sans  { font-family: var(--font-sans); }

.headline-xl {
    font-family: var(--font-serif);
    font-size: clamp(36px, 4vw, var(--fs-headline-xl));
    line-height: 1.1;
    letter-spacing: -0.02em;
    font-weight: 700;
}
.headline-lg {
    font-family: var(--font-serif);
    font-size: clamp(26px, 2.6vw, var(--fs-headline-lg));
    line-height: 1.2;
    letter-spacing: -0.01em;
    font-weight: 600;
}
.headline-md {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    line-height: 1.2;
    font-weight: 600;
}
.body-lg {
    font-size: var(--fs-body-lg);
    line-height: 1.6;
}
.body-md {
    font-size: var(--fs-body-md);
    line-height: 1.5;
}
.label-caps {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    line-height: 1;
    letter-spacing: 0.08em;
    font-weight: 700;
    text-transform: uppercase;
}
.data-mono {
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 500;
}

h1, h2, h3, h4 { font-family: var(--font-serif); margin: 0; }
p { margin: 0 0 1rem; }

/* --------------------------------------------------------------------------
   4. Topbar
   -------------------------------------------------------------------------- */
.topbar {
    position: fixed;
    inset: 0 0 auto 0;
    height: var(--topbar-h);
    background: var(--topbar-surface);
    color: var(--on-surface);
    border-bottom: var(--border-base) solid var(--topbar-border);
    z-index: 50;
}
.topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    height: 100%;
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 0 24px;
}
.topbar__left {
    display: flex;
    align-items: center;
    gap: 32px;
    min-width: 0;
}
.topbar__right {
    display: flex;
    align-items: center;
    gap: 16px;
}
.topbar__brand {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 900;
    font-size: 28px;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: var(--on-surface);
    white-space: nowrap;
    text-decoration: none;
}
.topbar__brand:hover { text-decoration: none; }

.topbar__nav {
    display: none;
    align-items: stretch;
    height: 100%;
    gap: 0;
}
@media (min-width: 900px) {
    .topbar__nav { display: flex; }
}
.topbar__nav a {
    display: flex;
    align-items: center;
    padding: 0 10px;
    height: 100%;
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
    text-decoration: none;
    transition: none;
}
.topbar__nav a:hover {
    background: var(--surface-container);
    color: var(--on-surface);
    text-decoration: none;
}
.topbar__nav a.is-active {
    color: var(--on-surface);
    border-bottom: 2px solid var(--on-surface);
    padding-bottom: 0;
}

.topbar__search {
    display: none;
    align-items: center;
    gap: 6px;
    border: 1px solid var(--on-surface);
    padding: 4px 8px;
    background: transparent;
    min-width: 220px;
}
@media (min-width: 1100px) {
    .topbar__search { display: inline-flex; }
}
.topbar__search input {
    border: 0;
    background: transparent;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--on-surface);
    width: 100%;
    outline: none;
}
.topbar__search input::placeholder {
    color: var(--outline);
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.08em;
    font-size: 11px;
}
.topbar__search .material-symbols-outlined {
    font-size: 18px;
    color: var(--outline);
}

.topbar__subscribe {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 0;
}
.topbar__subscribe:hover { background: var(--on-surface-variant); color: var(--surface-bright); text-decoration: none; }

.topbar__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    color: var(--on-surface);
    background: transparent;
    border: 0;
}
.topbar__icon:hover { background: var(--surface-container); }
.topbar__icon .material-symbols-outlined { font-size: 22px; }
.topbar__icon--live { color: var(--secondary); }

.topbar__menu {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px; height: 40px;
    margin-left: -8px;
    color: var(--on-surface);
}
.topbar__menu .material-symbols-outlined { font-size: 24px; }
@media (min-width: 960px) {
    .topbar__menu { display: none; }
}

/* --------------------------------------------------------------------------
   5. Sidebar (Command Center)
   -------------------------------------------------------------------------- */
.drawer {
    position: fixed;
    top: var(--topbar-h);
    left: 0;
    height: calc(100vh - var(--topbar-h));
    width: var(--sidebar-w);
    background: var(--sidebar-surface);
    color: var(--on-surface);
    border-right: var(--border-base) solid var(--topbar-border);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    z-index: 40;

    transform: translateX(-100%);
    transition: transform 180ms ease-out;
}
@media (min-width: 960px) {
    .drawer { transform: translateX(0); }
}
.drawer.is-open { transform: translateX(0); }

.drawer__header {
    padding: 16px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: var(--on-surface);
    color: var(--surface-bright);
}
.drawer__title {
    font-family: var(--font-sans);
    font-size: 18px;
    font-weight: 900;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    color: var(--surface-bright);
    margin: 0;
}
.drawer__version {
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--outline-variant);
    opacity: 0.7;
}

.drawer__nav {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    border-bottom: var(--border-base) solid var(--topbar-border);
}
.drawer__nav a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    color: var(--on-surface-variant);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-left: 4px solid transparent;
    border-bottom: 1px solid var(--outline-variant);
    text-decoration: none;
    transition: background 75ms ease;
}
.drawer__nav a:hover {
    background: var(--surface-container);
    color: var(--on-surface);
    text-decoration: none;
}
.drawer__nav a[aria-current="page"],
.drawer__nav a.is-active {
    background: var(--surface-container);
    color: var(--on-surface);
    border-left-color: var(--on-surface);
}
.drawer__nav .material-symbols-outlined { font-size: 20px; }

.drawer__cta {
    padding: 16px;
    border-bottom: var(--border-base) solid var(--topbar-border);
}
.drawer__cta button,
.drawer__cta a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px 16px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 2px solid var(--on-surface);
}
.drawer__cta button:hover,
.drawer__cta a:hover {
    background: var(--surface-bright);
    color: var(--on-surface);
    text-decoration: none;
}

.drawer__footer {
    display: flex;
    flex-direction: column;
}
.drawer__footer a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    color: var(--on-surface-variant);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--outline-variant);
    text-decoration: none;
}
.drawer__footer a:hover { background: var(--surface-container); color: var(--on-surface); text-decoration: none; }
.drawer__footer .material-symbols-outlined { font-size: 20px; }

/* Backdrop for mobile overlay drawer */
.drawer-backdrop {
    position: fixed;
    inset: var(--topbar-h) 0 0 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 30;
    opacity: 0;
    pointer-events: none;
    transition: opacity 180ms ease-out;
}
.drawer-backdrop.is-open { opacity: 1; pointer-events: auto; }
@media (min-width: 960px) { .drawer-backdrop { display: none; } }

/* --------------------------------------------------------------------------
   6. Container, canvas, grid
   -------------------------------------------------------------------------- */
.container {
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 24px;
}
@media (min-width: 960px) {
    .container { padding: 24px 32px; }
}

/* Brutalist grid container — gap is a 1px bleed of the primary border. */
.grid-frame {
    display: grid;
    gap: 1px;
    background: var(--topbar-border);
    border: 2px solid var(--topbar-border);
}
.grid-frame > * { background: var(--paper); }

/* --------------------------------------------------------------------------
   7. Ticker strip
   -------------------------------------------------------------------------- */
.ticker {
    position: relative;
    display: flex;
    align-items: stretch;
    height: 40px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    background: var(--on-surface);
    color: var(--surface-bright);
    overflow: hidden;
}
.ticker__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0 16px;
    background: var(--secondary);
    color: var(--on-secondary);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    flex-shrink: 0;
}
.ticker__badge .material-symbols-outlined { font-size: 14px; }
.ticker__track {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 0 16px;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    font-weight: 500;
    color: var(--surface-bright);
    white-space: nowrap;
    overflow: hidden;
}
.ticker__track a { color: var(--surface-bright); text-decoration: none; }
.ticker__track a:hover { color: var(--secondary); text-decoration: none; }
.ticker__track > span { display: inline-flex; align-items: center; gap: 8px; }
.ticker__sep { color: var(--outline-variant); opacity: 0.4; }
.ticker__dot {
    width: 8px; height: 8px;
    background: var(--secondary);
    border-radius: 0;
}
.ticker__marquee {
    display: inline-flex;
    align-items: center;
    gap: 24px;
    animation: ticker-scroll 60s linear infinite;
}
@keyframes ticker-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
    .ticker__marquee { animation: none; }
}

/* --------------------------------------------------------------------------
   8. Buttons & pills
   -------------------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 18px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 2px solid var(--on-surface);
    text-decoration: none;
    cursor: pointer;
}
.btn:hover {
    background: var(--surface-bright);
    color: var(--on-surface);
    text-decoration: none;
}
.btn--ghost {
    background: transparent;
    color: var(--on-surface);
}
.btn--ghost:hover {
    background: var(--on-surface);
    color: var(--surface-bright);
}
.btn--accent {
    background: var(--secondary);
    color: var(--on-secondary);
    border-color: var(--secondary);
}
.btn--accent:hover {
    background: var(--paper);
    color: var(--secondary);
}
.btn--block { width: 100%; }

.pill {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 0;
    border-radius: 0;
}
.pill--ghost {
    background: transparent;
    color: var(--on-surface);
    border: 1px solid var(--outline);
}
.pill--accent {
    background: var(--secondary);
    color: var(--on-secondary);
}
.pill--inverse {
    background: var(--surface-bright);
    color: var(--on-surface);
}

.badge-breaking {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--secondary);
    color: var(--on-secondary);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.badge-breaking .live-dot {
    width: 8px; height: 8px;
    background: var(--on-secondary);
    border-radius: 0;
}

.live-dot--pulse { animation: dot-pulse 1.4s ease-in-out infinite; }
@keyframes dot-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.35; }
}

/* --------------------------------------------------------------------------
   9. Block header / section heading
   -------------------------------------------------------------------------- */
.block-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    background: var(--surface-container);
}
.block-header h2,
.block-header h3 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    line-height: 1.2;
    font-weight: 600;
    color: var(--on-surface);
    margin: 0;
}
.block-header--inverse {
    background: var(--on-surface);
    color: var(--surface-bright);
}
.block-header--inverse h2,
.block-header--inverse h3 { color: var(--surface-bright); }

.section-heading {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    padding: 24px 0 12px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    margin-bottom: 24px;
}
.section-heading h1 {
    font-family: var(--font-serif);
    font-size: clamp(28px, 3vw, var(--fs-headline-lg));
    font-weight: 600;
    letter-spacing: -0.01em;
    margin: 0;
}

/* --------------------------------------------------------------------------
   10. Homepage — Lead / Wire / Secondary
   -------------------------------------------------------------------------- */
.home-hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--topbar-border);
    border-bottom: var(--border-base) solid var(--topbar-border);
}
@media (min-width: 1024px) {
    .home-hero { grid-template-columns: 8fr 4fr; }
}
.home-hero > * { background: var(--paper); }

.lead-story {
    display: flex;
    flex-direction: column;
    padding: 32px;
    gap: 16px;
    position: relative;
}
.lead-story__flag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    align-self: flex-start;
    padding: 6px 12px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.lead-story__title {
    font-family: var(--font-serif);
    font-size: clamp(32px, 4vw, var(--fs-headline-xl));
    line-height: 1.1;
    letter-spacing: -0.02em;
    font-weight: 700;
    color: var(--on-surface);
    margin: 0;
}
@media (max-width: 639px) {
    .lead-story {
        padding: 24px 20px;
    }
    .lead-story__title {
        font-size: clamp(28px, 9vw, 52px);
    }
    .lead-story__lede {
        font-size: 1.125rem;
    }
}
.lead-story__title a { color: inherit; }
.lead-story__title a:hover { text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px; }
.lead-story__lede {
    font-family: var(--font-sans);
    font-size: var(--fs-body-lg);
    line-height: 1.6;
    color: var(--on-surface-variant);
    max-width: 60ch;
    margin: 0;
}
.lead-story__media {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    border: 2px solid var(--topbar-border);
    overflow: hidden;
    background: var(--surface-container);
    position: relative;
}
.lead-story__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: grayscale(1) contrast(1.05);
    transition: filter 400ms ease;
}
.lead-story__media:hover img { filter: grayscale(0) contrast(1); }
.lead-story__media-label {
    position: absolute;
    top: 12px; left: 12px;
    padding: 4px 10px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.lead-story__byline {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--outline-variant);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    text-transform: uppercase;
}
.lead-story__byline .sep { color: var(--outline-variant); }

/* The Wire (right rail) */
.wire {
    display: flex;
    flex-direction: column;
    background: var(--paper);
}
.wire__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}
.wire__item {
    display: flex;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--outline-variant);
    text-decoration: none;
    color: var(--on-surface);
    transition: background 100ms ease;
}
.wire__item:hover {
    background: var(--surface-container-low);
    text-decoration: none;
}
.wire__time {
    flex-shrink: 0;
    width: 56px;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--secondary);
    padding-top: 2px;
    white-space: nowrap;
}
.wire__item:not(:first-child) .wire__time { color: var(--on-surface); }
.wire__body { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.wire__title {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    font-weight: 700;
    line-height: 1.35;
    color: var(--on-surface);
    margin: 0;
}
.wire__item:hover .wire__title { text-decoration: underline; text-underline-offset: 3px; }
.wire__excerpt {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.5;
    color: var(--on-surface-variant);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.wire__tag {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}
.wire__footer {
    margin-top: auto;
    padding: 12px 16px;
    border-top: var(--border-base) solid var(--topbar-border);
    text-align: center;
}
.wire__footer a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    padding: 8px 12px;
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--on-surface);
    border: 1px solid var(--on-surface);
    text-decoration: none;
}
.wire__footer a:hover {
    background: var(--on-surface);
    color: var(--surface-bright);
    text-decoration: none;
}

/* Secondary grid (3 columns) */
.home-secondary {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--topbar-border);
    border-bottom: var(--border-base) solid var(--topbar-border);
}
@media (min-width: 768px)  { .home-secondary { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .home-secondary { grid-template-columns: 1fr 1fr 1fr; } }
.home-secondary > * { background: var(--paper); }
.home-secondary--two { grid-template-columns: 1fr; }
@media (min-width: 900px) {
    .home-secondary--two { grid-template-columns: 1fr 1fr; }
}
.home-secondary--three { grid-template-columns: 1fr; }
@media (min-width: 768px) {
    .home-secondary--three { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
    .home-secondary--three { grid-template-columns: 1fr 1fr 1fr; }
}

.module {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}
.module__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    background: var(--surface-container);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--on-surface);
}
.module__header--inverse {
    background: var(--on-surface);
    color: var(--surface-bright);
}
.module__header .material-symbols-outlined { font-size: 18px; }
.module__body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    flex: 1;
}
.module__media {
    width: 100%;
    aspect-ratio: 4 / 3;
    border: 1px solid var(--topbar-border);
    background: var(--surface-container);
    overflow: hidden;
}
.module__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: grayscale(1) contrast(1.1);
}
.module__title {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    line-height: 1.2;
    font-weight: 600;
    color: var(--on-surface);
    margin: 0;
}
.module__title a { color: inherit; }
.module__title a:hover { text-decoration: underline; text-underline-offset: 3px; }
.module__excerpt {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.5;
    color: var(--on-surface-variant);
    margin: 0;
}
.module__meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    margin-top: auto;
    border-top: 1px solid var(--outline-variant);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--outline);
}

/* Opinion variant (cream/neutral panel) */
.module--opinion {
    background: var(--surface-dim);
}
.module--opinion .module__title { font-style: italic; }
.module--opinion .module__avatar {
    width: 48px; height: 48px;
    border: 2px solid var(--topbar-border);
    overflow: hidden;
    filter: grayscale(1);
}
.module--opinion .module__avatar img { width: 100%; height: 100%; object-fit: cover; }

/* --------------------------------------------------------------------------
   11. Section / desk grid
   -------------------------------------------------------------------------- */
.section-hero {
    padding: 48px 24px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    background: var(--paper);
}
.section-hero .eyebrow {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--secondary);
    display: block;
    margin-bottom: 8px;
}
.section-hero h1 {
    font-family: var(--font-serif);
    font-size: clamp(36px, 4vw, var(--fs-headline-xl));
    line-height: 1.1;
    letter-spacing: -0.02em;
    font-weight: 700;
    margin: 0 0 12px;
    color: var(--on-surface);
    max-width: 24ch;
}
.section-hero__lede {
    font-family: var(--font-sans);
    font-size: var(--fs-body-lg);
    line-height: 1.6;
    color: var(--on-surface-variant);
    max-width: 60ch;
    margin: 0;
}

.section-feature {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--topbar-border);
    border-bottom: var(--border-base) solid var(--topbar-border);
}
@media (min-width: 1024px) {
    .section-feature { grid-template-columns: 7fr 5fr; }
}
.section-feature > * { background: var(--paper); }
.section-feature__media {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--surface-container);
}
.section-feature__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: grayscale(1) contrast(1.05);
}
.section-feature__body {
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    justify-content: center;
}
.section-feature__title {
    font-family: var(--font-serif);
    font-size: clamp(28px, 2.8vw, var(--fs-headline-lg));
    line-height: 1.2;
    letter-spacing: -0.01em;
    font-weight: 600;
    margin: 0;
    color: var(--on-surface);
}
.section-feature__lede {
    font-family: var(--font-sans);
    font-size: var(--fs-body-lg);
    line-height: 1.6;
    color: var(--on-surface-variant);
    margin: 0;
}

.story-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 20px 0;
    border-bottom: 1px solid var(--outline-variant);
}
@media (min-width: 640px) {
    .story-row { grid-template-columns: 200px 1fr; gap: 24px; align-items: flex-start; }
}
.story-row__media {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border: 1px solid var(--outline-variant);
    background: var(--surface-container);
    position: relative;
}
.story-row__media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); }
.story-row__media--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--outline);
}
.story-row__body { display: flex; flex-direction: column; gap: 8px; }
.story-row__eyebrow {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}
.story-row__title {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    font-weight: 600;
    line-height: 1.25;
    margin: 0;
    color: var(--on-surface);
}
.story-row__title a { color: inherit; }
.story-row__title a:hover { text-decoration: underline; text-underline-offset: 3px; }
.story-row__excerpt {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.5;
    color: var(--on-surface-variant);
    margin: 0;
}
.story-row__meta {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--outline);
}

/* Bento-style story list used for archive/search results */
.story-list {
    display: grid;
    gap: 1px;
    background: var(--topbar-border);
    border: 2px solid var(--topbar-border);
}
@media (min-width: 640px)  { .story-list { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .story-list { grid-template-columns: 1fr 1fr 1fr; } }
.story-list > * { background: var(--paper); }
.story-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 20px;
}
.story-card__media {
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    border: 1px solid var(--outline-variant);
    background: var(--surface-container);
}
.story-card__media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); }
.story-card__body { display: flex; flex-direction: column; gap: 8px; }
.story-card__eyebrow {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}
.story-card h2, .story-card h3 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    line-height: 1.25;
    font-weight: 600;
    margin: 0;
}
.story-card p {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    color: var(--on-surface-variant);
    margin: 0;
}
.story-card__meta {
    display: flex;
    gap: 12px;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--outline);
}

/* --------------------------------------------------------------------------
   12. Article detail
   -------------------------------------------------------------------------- */
.article {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--topbar-border);
    border-left: var(--border-base) solid var(--topbar-border);
    border-right: var(--border-base) solid var(--topbar-border);
}
@media (min-width: 1024px) {
    .article { grid-template-columns: 2fr 1fr; }
}
.article > * { background: var(--paper); }

.article__main {
    padding: 32px 24px;
}
@media (min-width: 768px) { .article__main { padding: 48px 48px; } }

.article-header {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-bottom: 24px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    margin-bottom: 24px;
}
.article-header__flag {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.article-header h1 {
    font-family: var(--font-serif);
    font-size: clamp(32px, 4vw, var(--fs-headline-xl));
    line-height: 1.1;
    letter-spacing: -0.02em;
    font-weight: 700;
    color: var(--on-surface);
    margin: 0;
}
@media (max-width: 639px) {
    .article-header h1 {
        font-size: clamp(28px, 9vw, 56px);
    }
    .article-header {
        gap: 16px;
    }
}
.article-header .lede {
    font-family: var(--font-sans);
    font-size: var(--fs-body-lg);
    line-height: 1.6;
    font-weight: 500;
    color: var(--on-surface-variant);
    margin: 0;
    max-width: 60ch;
}

.article-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    padding: 16px 0;
    border-top: 1px solid var(--outline-variant);
    border-bottom: 1px solid var(--outline-variant);
}
.article-meta__author {
    display: flex;
    align-items: center;
    gap: 12px;
}
.article-meta__avatar {
    width: 48px; height: 48px;
    border: 2px solid var(--topbar-border);
    overflow: hidden;
    background: var(--surface-container);
    flex-shrink: 0;
}
.article-meta__avatar img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); }
.article-meta__avatar-fallback {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--on-surface);
}
.article-meta__byline {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--on-surface);
}
.article-meta__role {
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    text-transform: uppercase;
}
.article-meta__row {
    display: flex;
    align-items: center;
    gap: 16px;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    text-transform: uppercase;
}
.article-meta__actions {
    display: inline-flex;
    gap: 8px;
    flex-wrap: wrap;
}
.icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border: 2px solid var(--on-surface);
    background: transparent;
    color: var(--on-surface);
    text-decoration: none;
}
.icon-btn:hover {
    background: var(--on-surface);
    color: var(--surface-bright);
    text-decoration: none;
}
.icon-btn.is-success {
    background: var(--on-surface);
    color: var(--surface-bright);
}
.icon-btn .material-symbols-outlined { font-size: 18px; }

.article-figure {
    margin: 24px 0;
}
.article-figure__media {
    border: 2px solid var(--topbar-border);
    overflow: hidden;
    background: var(--surface-container);
    position: relative;
}
.article-figure__media img {
    width: 100%;
    object-fit: cover;
    filter: grayscale(1) contrast(1.1);
}
.article-figure figcaption {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 0;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    border-bottom: 1px solid var(--outline-variant);
}
.article-figure figcaption .credit { text-transform: uppercase; }

/* Key takeaways (Key Findings box) */
.takeaways {
    margin: 24px 0;
    padding: 24px;
    background: var(--surface-container);
    border: 2px solid var(--on-surface);
}
.takeaways h3 {
    font-family: var(--font-sans);
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--on-surface);
    margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--on-surface);
}
.takeaways ul {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.takeaways li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.5;
    color: var(--on-surface);
}
.takeaways li::before {
    content: "►";
    flex-shrink: 0;
    color: var(--secondary);
    font-size: 14px;
    line-height: 1.4;
}

/* Article prose */
.prose {
    font-family: var(--font-sans);
    font-size: var(--fs-body-lg);
    line-height: 1.7;
    color: var(--on-surface);
    max-width: 72ch;
}
.prose > p { margin: 0 0 1.25em; }
.prose > p:first-of-type::first-letter {
    font-family: var(--font-serif);
    font-weight: 800;
    font-size: 4.5em;
    line-height: 0.85;
    float: left;
    padding: 0.1em 0.1em 0 0;
    margin-right: 0.05em;
    color: var(--on-surface);
}
.prose h2 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-lg);
    font-weight: 600;
    letter-spacing: -0.01em;
    margin: 2em 0 0.6em;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--on-surface);
    text-transform: uppercase;
}
.prose h3 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    font-weight: 600;
    margin: 1.6em 0 0.5em;
}
.prose a {
    color: var(--on-surface);
    border-bottom: 1px solid var(--on-surface);
}
.prose a:hover { color: var(--secondary); border-bottom-color: var(--secondary); text-decoration: none; }
.prose blockquote {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 500;
    font-size: var(--fs-headline-md);
    line-height: 1.35;
    color: var(--on-surface);
    margin: 2em 0;
    padding: 0 0 0 24px;
    border-left: 4px solid var(--on-surface);
}
.prose blockquote cite {
    display: block;
    margin-top: 16px;
    font-family: var(--font-sans);
    font-style: normal;
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--outline);
}
.prose ul, .prose ol {
    padding-left: 1.2em;
    margin: 0 0 1.25em;
}
.prose li { margin-bottom: 0.4em; }
.prose img { width: 100%; border: 2px solid var(--topbar-border); filter: grayscale(1) contrast(1.05); margin: 1.5em 0; }

/* Speed-read / reading progress bar */
.speedread {
    position: sticky;
    top: var(--topbar-h);
    height: 3px;
    background: var(--outline-variant);
    z-index: 10;
}
.speedread__fill {
    height: 100%;
    width: 0;
    background: var(--secondary);
    transition: width 120ms linear;
}

/* Tag row */
.tag-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding-top: 20px;
    margin-top: 32px;
    border-top: 2px solid var(--on-surface);
}
.tag {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    background: var(--surface-container);
    color: var(--on-surface);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    font-weight: 600;
    text-transform: uppercase;
    border: 1px solid var(--on-surface);
}
.tag:hover { background: var(--on-surface); color: var(--surface-bright); text-decoration: none; }

/* Editor's note / opinion callout */
.opinion-callout {
    margin: 32px 0;
    padding: 24px;
    border: 2px solid var(--secondary);
    background: var(--paper);
    position: relative;
}
.opinion-callout::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: var(--secondary);
}
.opinion-callout .eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--secondary);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.opinion-callout h4 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    font-weight: 600;
    color: var(--on-surface);
    margin: 0 0 12px;
}
.opinion-callout p {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.5;
    color: var(--on-surface-variant);
    margin: 0 0 12px;
}

/* Article aside / right rail */
.article__aside {
    padding: 0;
    display: flex;
    flex-direction: column;
    border-top: var(--border-base) solid var(--topbar-border);
}
@media (min-width: 1024px) {
    .article__aside { border-top: 0; }
}
.aside-module {
    display: flex;
    flex-direction: column;
    border-bottom: var(--border-base) solid var(--topbar-border);
}
.aside-module__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.aside-module__body { padding: 16px; display: flex; flex-direction: column; }
.aside-story-link {
    padding: 12px 0;
    border-bottom: 1px solid var(--outline-variant);
    text-decoration: none;
}
.aside-story-link:last-child { border-bottom: 0; }
.aside-story-link__title {
    font-family: var(--font-serif);
    font-size: 18px;
    font-weight: 600;
    margin: 6px 0;
}

.trending-list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
}
.trending-list li {
    border-bottom: 1px solid var(--outline-variant);
}
.trending-list li:last-child { border-bottom: 0; }
.trending-list a {
    display: block;
    padding: 16px;
    color: var(--on-surface);
    text-decoration: none;
}
.trending-list a:hover { background: var(--surface-container-low); text-decoration: none; }
.trending-list .rank {
    display: block;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--secondary);
    margin-bottom: 4px;
}
.trending-list h4 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    line-height: 1.25;
    font-weight: 600;
    color: var(--on-surface);
    margin: 0 0 8px;
}
.trending-list a:hover h4 { text-decoration: underline; text-underline-offset: 3px; }
.trending-list .meta {
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--outline);
}

/* Newsletter signup */
.newsletter {
    padding: 24px;
    background: var(--surface-container);
    border-top: 2px solid var(--on-surface);
}
.newsletter .material-symbols-outlined { font-size: 32px; color: var(--on-surface); margin-bottom: 8px; }
.newsletter h3 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    font-weight: 600;
    color: var(--on-surface);
    margin: 0 0 8px;
}
.newsletter p {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    color: var(--on-surface-variant);
    margin: 0 0 12px;
}
.newsletter form { display: flex; flex-direction: column; gap: 8px; }
.newsletter input[type="email"] {
    padding: 10px 12px;
    border: 2px solid var(--on-surface);
    background: var(--paper);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    outline: none;
}
.newsletter button {
    padding: 12px;
    border: 2px solid var(--on-surface);
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.newsletter button:hover { background: var(--paper); color: var(--on-surface); }

/* Ad slot */
.ad-slot {
    padding: 32px 16px;
    text-align: center;
    background: var(--surface-container);
    border: 1px dashed var(--outline);
    color: var(--outline);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* Breadcrumbs */
.breadcrumbs {
    list-style: none;
    margin: 0 0 16px;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    text-transform: uppercase;
}
.breadcrumbs li + li::before {
    content: "/";
    margin-right: 8px;
    color: var(--outline);
}
.breadcrumbs a { color: var(--on-surface); }

/* --------------------------------------------------------------------------
   13. Radar / search
   -------------------------------------------------------------------------- */
.radar-head {
    padding: 48px 24px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    background: var(--surface-container-lowest);
}
@media (min-width: 768px) { .radar-head { padding: 64px 48px; } }
.radar-head__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--on-surface);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 16px;
}
.radar-head__eyebrow .material-symbols-outlined { color: var(--secondary); font-size: 18px; }
.search-form {
    position: relative;
    display: block;
    max-width: 900px;
}
.search-form input {
    width: 100%;
    padding: 12px 48px 12px 0;
    border: 0;
    border-bottom: 4px solid var(--on-surface);
    background: transparent;
    font-family: var(--font-serif);
    font-size: clamp(28px, 3.6vw, var(--fs-headline-xl));
    line-height: 1.1;
    letter-spacing: -0.02em;
    font-weight: 700;
    color: var(--on-surface);
    outline: none;
}
.search-form input::placeholder {
    color: var(--outline);
}
.search-form input:focus { border-bottom-color: var(--secondary); }
.search-form button {
    position: absolute;
    right: 0;
    bottom: 12px;
    width: 44px; height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 0;
    color: var(--on-surface);
}
.search-form button .material-symbols-outlined { font-size: 32px; }
.search-form button:hover { color: var(--secondary); }

.chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 16px 24px;
    border-bottom: 1px solid var(--outline-variant);
    background: var(--paper);
}
.chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border: 1px solid var(--on-surface);
    background: transparent;
    color: var(--on-surface);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    font-weight: 600;
    text-transform: uppercase;
}
.chip:hover, .chip.is-active { background: var(--on-surface); color: var(--surface-bright); text-decoration: none; }

.radar-vectors {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--topbar-border);
    border-top: var(--border-base) solid var(--topbar-border);
    border-bottom: var(--border-base) solid var(--topbar-border);
}
@media (min-width: 768px) { .radar-vectors { grid-template-columns: repeat(3, 1fr); } }
.radar-vectors > * { background: var(--paper); }
.vector-box {
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 128px;
    text-decoration: none;
    color: var(--on-surface);
}
.vector-box:hover { background: var(--surface-container-low); text-decoration: none; }
.vector-box__row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}
.vector-box__row .material-symbols-outlined { color: var(--secondary); font-size: 18px; }
.vector-box__row .vol {
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    text-transform: uppercase;
}
.vector-box__title {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    font-weight: 600;
    line-height: 1.1;
    color: var(--on-surface);
    margin: 8px 0 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.search-meta {
    padding: 16px 24px;
    border-bottom: 1px solid var(--outline-variant);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--outline);
}
.search-meta strong { color: var(--on-surface); font-weight: 700; }

/* Ranked intercepts list (priority sorted) */
.ranked-list {
    display: flex;
    flex-direction: column;
    border-top: var(--border-base) solid var(--topbar-border);
}
.ranked-list__item {
    display: flex;
    align-items: stretch;
    border-bottom: var(--border-base) solid var(--topbar-border);
    background: var(--paper);
    text-decoration: none;
    color: var(--on-surface);
}
.ranked-list__item:hover { background: var(--surface-container-low); text-decoration: none; }
.ranked-list__rank {
    flex-shrink: 0;
    width: 72px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--surface-container);
    color: var(--on-surface);
    font-family: var(--font-serif);
    font-size: var(--fs-headline-xl);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
    border-right: 2px solid var(--topbar-border);
}
.ranked-list__item:first-child .ranked-list__rank,
.ranked-list__item:hover .ranked-list__rank {
    background: var(--on-surface);
    color: var(--surface-bright);
}
.ranked-list__body {
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    justify-content: center;
}
.ranked-list__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.ranked-list__title {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-md);
    line-height: 1.25;
    font-weight: 600;
    color: var(--on-surface);
    margin: 0;
}
.ranked-list__excerpt {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    color: var(--on-surface-variant);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* --------------------------------------------------------------------------
   14. Pagination
   -------------------------------------------------------------------------- */
.pagination {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 24px;
    border-top: var(--border-base) solid var(--topbar-border);
}
.pagination a {
    display: inline-flex;
    align-items: center;
    padding: 10px 16px;
    border: 2px solid var(--on-surface);
    background: transparent;
    color: var(--on-surface);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
}
.pagination a:hover { background: var(--on-surface); color: var(--surface-bright); }

/* --------------------------------------------------------------------------
   15. Error shell & empty states
   -------------------------------------------------------------------------- */
.error-shell {
    text-align: center;
    padding: 80px 24px;
    max-width: 640px;
    margin: 0 auto;
    border: 2px solid var(--on-surface);
}
.error-code {
    font-family: var(--font-serif);
    font-size: clamp(72px, 10vw, 144px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.04em;
    color: var(--on-surface);
    margin: 0 0 16px;
}
.error-shell h1 {
    font-family: var(--font-serif);
    font-size: var(--fs-headline-lg);
    font-weight: 600;
    margin: 0 0 12px;
}
.error-shell p {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    color: var(--on-surface-variant);
    margin: 0 0 24px;
}

.btn-row {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
}

.empty-state {
    padding: 48px 24px;
    text-align: center;
    color: var(--on-surface-variant);
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    border-bottom: 1px solid var(--outline-variant);
}

.utility-shell {
    display: flex;
    flex-direction: column;
    gap: 24px;
}
.utility-shell__card {
    max-width: 780px;
    padding: 24px;
    border: 1px solid var(--outline-variant);
    background: var(--paper);
}
.utility-shell__card p:last-child {
    margin-bottom: 0;
}
.utility-shell__success {
    margin-top: 16px;
    padding: 12px 14px;
    background: var(--surface-container);
    border-left: 4px solid var(--secondary);
    color: var(--on-surface);
}
.utility-shell__actions {
    margin-top: 24px;
    justify-content: flex-start;
}

/* --------------------------------------------------------------------------
   16. Footer
   -------------------------------------------------------------------------- */
.site-footer {
    border-top: var(--border-base) solid var(--topbar-border);
    background: var(--topbar-surface);
    color: var(--on-surface);
    margin-top: 0;
}
.site-footer__inner {
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 32px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}
@media (min-width: 768px) {
    .site-footer__inner {
        flex-direction: row;
        justify-content: space-between;
    }
}
.site-footer__brand-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: center;
    text-align: center;
}
@media (min-width: 768px) {
    .site-footer__brand-group { align-items: flex-start; text-align: left; }
}
.site-footer__brand {
    font-family: var(--font-serif);
    font-weight: 900;
    font-style: italic;
    font-size: 18px;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: var(--on-surface);
}
.site-footer__tagline {
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--outline);
}
.site-footer__copy {
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}
.site-footer__nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
}
.site-footer__nav a {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
    text-decoration: none;
}
.site-footer__nav a:hover { color: var(--on-surface); }

/* --------------------------------------------------------------------------
   17. Utilities
   -------------------------------------------------------------------------- */
.visually-hidden { /* alias for sr-only */
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap;
}
.stack    { display: flex; flex-direction: column; gap: 16px; }
.stack-sm { display: flex; flex-direction: column; gap: 8px; }
.row      { display: flex; align-items: center; gap: 12px; }
.muted    { color: var(--outline); }
.eyebrow  {
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--secondary);
}
.meta-sm {
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    text-transform: uppercase;
}

/* --------------------------------------------------------------------------
   18. Material Symbols settings
   -------------------------------------------------------------------------- */
.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    vertical-align: middle;
}
.material-symbols-outlined.is-filled {
    font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

/* --------------------------------------------------------------------------
   19. Mobile bottom nav (5 items, black bar, hidden on desktop)
   -------------------------------------------------------------------------- */
.bottom-nav {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    background: var(--on-surface);
    border-top: var(--border-base) solid var(--on-surface);
    z-index: 50;
    height: 64px;
}
.bottom-nav__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 6px 4px;
    color: var(--outline-variant);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    border-right: 1px solid rgba(255,255,255,0.08);
}
.bottom-nav__item:last-child { border-right: 0; }
.bottom-nav__item .material-symbols-outlined { font-size: 22px; }
.bottom-nav__item.is-active,
.bottom-nav__item[aria-current="page"] {
    background: var(--surface-bright);
    color: var(--on-surface);
}
.bottom-nav__item:hover {
    color: var(--surface-bright);
    text-decoration: none;
}
.bottom-nav__item.is-active:hover {
    color: var(--on-surface);
    background: var(--surface-bright);
}
@media (min-width: 960px) {
    .bottom-nav { display: none; }
}
/* Add bottom padding to main on mobile so content isn't hidden under the nav */
@media (max-width: 959px) {
    body.has-shell { padding-bottom: 64px; }
}

/* --------------------------------------------------------------------------
   20. Social card (From Social Media — X/TikTok source pills)
   -------------------------------------------------------------------------- */
.social-card {
    display: flex;
    flex-direction: column;
    border: var(--border-base) solid var(--topbar-border);
    background: var(--paper);
    margin-bottom: 12px;
}
.social-card__time {
    margin-left: auto;
    color: var(--outline-variant);
}

.lead-story__media.is-broken,
.module__media.is-broken,
.story-row__media.is-broken,
.story-card__media.is-broken,
.article-figure__media.is-broken,
.section-feature__media.is-broken {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 220px;
    background:
        linear-gradient(135deg, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.02)),
        var(--surface-container);
    color: var(--outline);
}

.lead-story__media.is-broken::after,
.module__media.is-broken::after,
.story-row__media.is-broken::after,
.story-card__media.is-broken::after,
.article-figure__media.is-broken::after,
.section-feature__media.is-broken::after {
    content: "Media updating";
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.breadcrumb-strip {
    padding: 16px 24px;
    border-bottom: 1px solid var(--outline-variant);
}
.breadcrumb-strip .breadcrumbs { margin: 0; }

.story-feed {
    padding: 24px 32px;
}
@media (max-width: 639px) {
    .story-feed { padding: 20px; }
}

.article__main--full { grid-column: 1 / -1; }

.world-watch__item {
    padding: 12px 0;
    border-bottom: 1px solid var(--outline-variant);
}
.world-watch__title { margin: 6px 0 8px; }
.social-card__head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
.social-card__head .material-symbols-outlined { font-size: 14px; }
.social-card__head .social-card__handle {
    margin-left: auto;
    color: var(--outline-variant);
    opacity: 0.8;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: none;
}
.social-card__body {
    padding: 12px;
    font-family: var(--font-serif);
    font-size: 15px;
    line-height: 1.45;
    color: var(--on-surface);
}
.social-card__foot {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-top: 1px dashed var(--outline-variant);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--outline);
}

/* --------------------------------------------------------------------------
   21. World Desk — Kenya Impact callout
   -------------------------------------------------------------------------- */
.world-impact {
    padding: 10px 12px;
    border-left: 3px solid var(--secondary);
    background: var(--surface-container);
    margin-top: 8px;
}
.world-impact__label {
    display: block;
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--secondary);
    margin-bottom: 4px;
}
.world-impact__body {
    font-family: var(--font-sans);
    font-size: 13px;
    line-height: 1.45;
    color: var(--on-surface);
}

/* --------------------------------------------------------------------------
   22. Timeline (Earlier on this Story)
   -------------------------------------------------------------------------- */
.timeline {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}
.timeline__item {
    position: relative;
    padding: 10px 12px 10px 28px;
    border-bottom: 1px solid var(--outline-variant);
}
.timeline__item:last-child { border-bottom: 0; }
.timeline__item::before {
    content: "";
    position: absolute;
    left: 12px;
    top: 16px;
    width: 8px; height: 8px;
    background: var(--on-surface);
    border-radius: 0;
}
.timeline__item::after {
    content: "";
    position: absolute;
    left: 15px;
    top: 24px;
    bottom: -1px;
    width: 2px;
    background: var(--outline-variant);
}
.timeline__item:last-child::after { display: none; }
.timeline__time {
    display: block;
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--outline);
    margin-bottom: 2px;
}
.timeline__title {
    font-family: var(--font-serif);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--on-surface);
    margin: 0;
}
.timeline__title a { color: inherit; text-decoration: none; }
.timeline__title a:hover { color: var(--secondary); text-decoration: none; }
.timeline__item--current::before {
    background: var(--secondary);
    outline: 3px solid var(--surface-bright);
    outline-offset: -1px;
}

/* --------------------------------------------------------------------------
   23. Executive Summary (two-column: label left, bullets right)
   -------------------------------------------------------------------------- */
.executive-summary {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    margin: 24px 0;
    padding: 20px 20px 24px;
    background: var(--surface-container);
    border: 2px solid var(--on-surface);
}
@media (min-width: 720px) {
    .executive-summary { grid-template-columns: 200px 1fr; gap: 24px; padding: 24px; }
}
.executive-summary__label {
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--on-surface);
    padding-right: 16px;
    border-right: 0;
}
@media (min-width: 720px) {
    .executive-summary__label { border-right: 2px solid var(--on-surface); }
}
.executive-summary__label strong {
    display: block;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-transform: none;
    color: var(--on-surface);
    margin-top: 6px;
    line-height: 1.1;
}
.executive-summary__bullets {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.executive-summary__bullets li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.45;
    color: var(--on-surface);
}
.executive-summary__bullets li .material-symbols-outlined {
    flex-shrink: 0;
    font-size: 18px;
    color: var(--secondary);
    font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

/* --------------------------------------------------------------------------
   24. Live blog (AP-style rolling coverage)
   -------------------------------------------------------------------------- */
.live-header__bar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 10px 24px;
    background: var(--on-surface);
    color: var(--surface-bright);
    border-bottom: var(--border-base) solid var(--on-surface);
}
.live-header__live {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: var(--secondary);
    color: var(--on-secondary);
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}
.live-header__signal {
    color: var(--outline-variant);
    opacity: 0.9;
}
.live-header__tools {
    margin-left: auto;
    display: inline-flex;
    gap: 4px;
}
.live-header__tools .icon-btn { color: var(--surface-bright); border-color: transparent; }
.live-header__tools .icon-btn:hover { background: rgba(255,255,255,0.08); }

.live-header {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 32px 24px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    background: var(--paper);
}
@media (min-width: 960px) {
    .live-header { grid-template-columns: 5fr 4fr; gap: 32px; padding: 48px 32px; }
}
.live-header__main h1 {
    font-family: var(--font-serif);
    font-size: clamp(34px, 5.2vw, 64px);
    line-height: 0.98;
    letter-spacing: -0.025em;
    font-weight: 800;
    margin: 10px 0 16px;
    color: var(--on-surface);
}
.live-header__main .lede {
    font-family: var(--font-serif);
    font-size: clamp(18px, 1.6vw, 22px);
    line-height: 1.45;
    color: var(--on-surface-variant);
    max-width: 56ch;
    margin: 0 0 20px;
}
.live-header__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding-top: 16px;
    border-top: 2px solid var(--on-surface);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}
.live-header__meta .sep { color: var(--outline-variant); }
.live-header__figure {
    margin: 0;
    border: var(--border-base) solid var(--topbar-border);
    background: var(--surface-container);
}
.live-header__figure img {
    display: block;
    width: 100%;
    aspect-ratio: 16/10;
    object-fit: cover;
}
.live-header__figure figcaption {
    padding: 10px 12px;
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    letter-spacing: 0.02em;
    color: var(--outline);
    border-top: 1px solid var(--outline-variant);
}
.live-header__figure figcaption .credit { text-transform: uppercase; margin-left: 8px; }

/* Catch-up module */
.live-catchup {
    margin: 24px;
    padding: 20px 24px 24px;
    background: var(--on-surface);
    color: var(--surface-bright);
    border: var(--border-base) solid var(--on-surface);
}
.live-catchup__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 12px;
    margin-bottom: 16px;
    border-bottom: 2px solid var(--secondary);
}
.live-catchup__head .eyebrow { color: var(--secondary); font-size: 13px; }
.live-catchup__head .data-mono { color: var(--outline-variant); opacity: 0.9; }
.live-catchup__list {
    list-style: none;
    margin: 0; padding: 0;
    display: grid;
    gap: 12px 24px;
    grid-template-columns: 1fr;
}
@media (min-width: 720px) {
    .live-catchup__list { grid-template-columns: 1fr 1fr; }
}
.live-catchup__list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-family: var(--font-serif);
    font-size: 16px;
    line-height: 1.45;
    color: var(--surface-bright);
}
.live-catchup__num {
    flex-shrink: 0;
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.1em;
    color: var(--secondary);
    padding-top: 2px;
    min-width: 24px;
}

/* Jump-to chip row */
.live-jump {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 24px;
    background: var(--surface-container);
    border-bottom: var(--border-base) solid var(--topbar-border);
    overflow-x: auto;
    white-space: nowrap;
    position: sticky;
    top: var(--topbar-h);
    z-index: 10;
}
.live-jump__label {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--outline);
    flex-shrink: 0;
}
.live-jump__chips { display: inline-flex; gap: 8px; }
.live-jump__chips a {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    background: var(--paper);
    color: var(--on-surface);
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 1px solid var(--on-surface);
    text-decoration: none;
}
.live-jump__chips a:hover { background: var(--on-surface); color: var(--surface-bright); text-decoration: none; }

/* Stream header */
.live-stream__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding: 0 0 16px;
    margin-bottom: 8px;
    border-bottom: 3px solid var(--on-surface);
}
.live-stream__head h2 {
    font-family: var(--font-serif);
    font-size: 28px;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0;
    color: var(--on-surface);
}
.live-stream__head .data-mono {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--secondary);
}

/* Posts */
.live-posts {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
}
.live-post {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 24px 0;
    border-bottom: 1px solid var(--outline-variant);
}
@media (min-width: 720px) {
    .live-post { grid-template-columns: 110px 1fr; gap: 24px; }
}
.live-post:last-child { border-bottom: 0; }

.live-post__rail {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-left: 20px;
}
.live-post__rail::before {
    content: "";
    position: absolute;
    left: 4px;
    top: 4px;
    width: 10px; height: 10px;
    background: var(--on-surface);
    border-radius: 0;
}
.live-post__rail::after {
    content: "";
    position: absolute;
    left: 8px;
    top: 16px;
    bottom: -24px;
    width: 2px;
    background: var(--outline-variant);
}
.live-post:last-child .live-post__rail::after { display: none; }
.live-post--current .live-post__rail::before {
    background: var(--secondary);
    box-shadow: 0 0 0 3px var(--surface-bright), 0 0 0 5px var(--secondary);
    animation: live-pulse 1.6s ease-in-out infinite;
}
@keyframes live-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.5; }
}
.live-post__time {
    font-family: var(--font-sans);
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--on-surface);
    line-height: 1;
}
.live-post__date {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--outline);
}

.live-post__flags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
    align-items: center;
}
.live-post__badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    background: var(--surface-container);
    color: var(--on-surface);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: 1px solid var(--on-surface);
}
.live-post__badge .material-symbols-outlined { font-size: 12px; }
.live-post__badge--pinned {
    background: var(--on-surface);
    color: var(--surface-bright);
}

.live-post__title {
    font-family: var(--font-serif);
    font-size: clamp(22px, 2.4vw, 28px);
    font-weight: 800;
    line-height: 1.12;
    letter-spacing: -0.015em;
    margin: 0 0 10px;
}
.live-post__title a { color: var(--on-surface); text-decoration: none; }
.live-post__title a:hover { color: var(--secondary); text-decoration: none; }

.live-post__byline {
    display: flex;
    gap: 8px;
    align-items: center;
    font-family: var(--font-sans);
    font-size: 12px;
    color: var(--outline);
    margin-bottom: 12px;
}
.live-post__byline .sep { color: var(--outline-variant); }

.live-post__media {
    margin: 12px 0;
    border: 1px solid var(--outline-variant);
    background: var(--surface-container);
}
.live-post__media img {
    display: block;
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
}
.live-post__media figcaption {
    padding: 8px 10px;
    font-family: var(--font-sans);
    font-size: 11px;
    letter-spacing: 0.02em;
    color: var(--outline);
    border-top: 1px solid var(--outline-variant);
}
.live-post__media figcaption .credit { text-transform: uppercase; }

.live-post__prose {
    font-family: var(--font-serif);
    font-size: 17px;
    line-height: 1.55;
    color: var(--on-surface);
    max-width: 68ch;
}
.live-post__prose > p { margin: 0 0 1em; }
.live-post__prose > p:last-child { margin-bottom: 0; }
.live-post__prose a { color: var(--on-surface); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 3px; }

.live-post__quote {
    margin: 16px 0 0;
    padding: 12px 0 12px 16px;
    border-left: 4px solid var(--secondary);
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 18px;
    line-height: 1.4;
    color: var(--on-surface);
}
.live-post__quote cite {
    display: block;
    margin-top: 8px;
    font-style: normal;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--outline);
}

.live-post__followup {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 16px;
    padding: 8px 12px;
    border: 1px solid var(--on-surface);
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--on-surface);
    text-decoration: none;
}
.live-post__followup:hover { background: var(--on-surface); color: var(--surface-bright); text-decoration: none; }
.live-post__followup .material-symbols-outlined { font-size: 14px; }

.live-post--pinned {
    background: var(--surface-container);
    padding: 24px 16px;
    border: 2px solid var(--on-surface);
    margin-bottom: 16px;
}

/* --------------------------------------------------------------------------
   25. Print
   -------------------------------------------------------------------------- */
@media print {
    .topbar, .drawer, .drawer-backdrop, .site-footer, .ticker, .ad-slot,
    .aside-module, .article__aside, .icon-btn, .speedread, .bottom-nav,
    .live-header__bar, .live-header__tools, .live-jump { display: none !important; }
    body, body.has-shell { padding: 0; background: #fff; color: #000; }
    .article { grid-template-columns: 1fr !important; border: 0 !important; }
    .article__main { padding: 0 !important; }
    .prose { max-width: none; }
}
