/* ==========================================================================
   Nyakundi Report — Editorial UI
   Brutalist editorial system. Inter + Newsreader. 0px radius, 2px borders.
   ========================================================================== */

/* --------------------------------------------------------------------------
   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 */
    --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 (zinc-950 canvas, white ink).
   Scoped to :root:not([data-theme]) so the manual toggle (data-theme="light"|"dark")
   can always override the OS preference. */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
        --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 */
.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
   -------------------------------------------------------------------------- */
.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__nav-live { color: var(--secondary) !important; }

.topbar__search {
    display: none;
    align-items: center;
    gap: 6px;
    border: 2px solid var(--on-surface);
    padding: 4px 8px;
    background: transparent;
    min-width: 220px;
}
@media (min-width: 1100px) {
    .topbar__search { display: inline-flex; }
}
.topbar__search:focus-within {
    border-color: var(--secondary);
}
.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);
    font-weight: 600;
    letter-spacing: 0;
    font-size: 12px;
}
.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 navigation
   -------------------------------------------------------------------------- */
.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: 14px 12px 14px 16px;
    border-bottom: var(--border-base) solid var(--topbar-border);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    background: var(--on-surface);
    color: var(--surface-bright);
}
.drawer__heading {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}
.drawer__title {
    font-family: var(--font-sans);
    font-size: 16px;
    font-weight: 900;
    letter-spacing: 0.04em;
    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__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    color: var(--surface-bright);
    border: 1px solid rgba(255, 255, 255, 0.35);
}
.drawer__close .material-symbols-outlined { font-size: 20px; }
.drawer__close:hover {
    background: rgba(255, 255, 255, 0.12);
}
@media (min-width: 960px) {
    .drawer__close { display: none; }
}

.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; } }
@media (max-width: 959px) {
    body.drawer-open { overflow: hidden; }
}

/* --------------------------------------------------------------------------
   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. 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 search list */
.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: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    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 (4 items, black bar, hidden on desktop)
   -------------------------------------------------------------------------- */
.bottom-nav {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    display: grid;
    grid-template-columns: repeat(4, 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: 4px;
    padding: 6px 4px;
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    border-right: 1px solid var(--surface-bright);
}
.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 updates (rolling coverage)
   -------------------------------------------------------------------------- */

/* Shell: mobile = single column; desktop ≥1024px = feed + side rail */
.live-shell {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}
@media (min-width: 1024px) {
    .live-shell {
        grid-template-columns: 1fr 24rem;
        background: var(--on-surface);  /* reveals 1px divider */
        gap: var(--border-base);
    }
    .live-shell > * { background: var(--paper); }
}

/* ── Feed column ──────────────────────────────────────────────────────── */
.live-feed {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.live-feed__header {
    padding: 24px;
    border-bottom: var(--border-base) solid var(--on-surface);
    background: var(--surface-bright);
}
.live-feed__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}
.live-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: var(--secondary);
    color: var(--on-secondary);
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}
.live-pill .live-dot {
    width: 7px; height: 7px;
    background: var(--on-secondary);
    border-radius: 999px;
}
.live-feed__updated {
    color: var(--on-surface-variant);
    font-size: var(--fs-data-mono);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.live-feed__title {
    font-family: var(--font-serif);
    font-size: clamp(32px, 5vw, 56px);
    line-height: 1.05;
    letter-spacing: -0.02em;
    font-weight: 800;
    margin: 8px 0 12px;
    color: var(--on-surface);
}
.live-feed__lede {
    font-family: var(--font-sans);
    font-size: clamp(16px, 1.4vw, 18px);
    line-height: 1.6;
    color: var(--on-surface-variant);
    max-width: 64ch;
    margin: 0;
}

/* ── Key Developments ─────────────────────────────────────────────────── */
/* .key-developments--inline shows on mobile inside the feed; hidden on desktop.
   .key-developments--side shows on desktop in the side rail; hidden on mobile. */
.key-developments {
    padding: 20px 24px 24px;
    background: var(--surface-container-low, var(--surface-container));
    border-bottom: 1px solid var(--outline-variant);
}
.key-developments--side {
    border-bottom: var(--border-base) solid var(--on-surface);
    background: var(--surface-bright);
}
.key-developments--inline { display: block; }
.key-developments--side   { display: none; }
@media (min-width: 1024px) {
    .key-developments--inline { display: none; }
    .key-developments--side   { display: block; }
}

.key-developments__title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--on-surface);
    padding-bottom: 10px;
    margin: 0 0 14px;
    border-bottom: 1px solid var(--outline);
}
.key-developments__title .material-symbols-outlined { font-size: 18px; }

.key-developments__title--side {
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 0;
    padding-bottom: 0;
    margin-bottom: 16px;
    font-family: var(--font-serif);
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.005em;
    text-transform: uppercase;
}
.key-developments__marker {
    width: 4px;
    align-self: stretch;
    background: var(--secondary);
    display: inline-block;
}

.key-developments__list {
    margin: 0;
    padding: 0 0 0 20px;
    list-style: disc;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.key-developments__list li {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.5;
    color: var(--on-surface);
}
.key-developments__list--arrows {
    list-style: none;
    padding: 0;
    gap: 14px;
}
.key-developments__list--arrows li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
}
.key-developments__list--arrows li .material-symbols-outlined {
    color: var(--secondary);
    font-size: 18px;
    margin-top: 1px;
    flex-shrink: 0;
    font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

/* ── Update cards ─────────────────────────────────────────────────────── */
.live-updates {
    display: flex;
    flex-direction: column;
    background: var(--on-surface);  /* shows through as 2px separators */
    gap: 2px;
}
.live-updates > * { background: var(--surface-bright); }

.live-update {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    padding: 24px;
}
@media (min-width: 720px) {
    .live-update {
        grid-template-columns: 80px 1fr;
        gap: 16px;
    }
}
.live-update:hover { background: var(--surface-container-low, var(--surface-container)); }

/* Left time column (desktop only) */
.live-update__time {
    display: none;
    flex-direction: column;
    gap: 2px;
    padding-top: 4px;
}
@media (min-width: 720px) {
    .live-update__time { display: flex; }
}
.live-update__time-hm {
    font-family: var(--font-sans);
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: var(--on-surface);
}
.live-update__time-zone {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--outline);
}

/* Header: title + mobile stamp on same row */
.live-update__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}
.live-update__title {
    font-family: var(--font-serif);
    font-size: clamp(20px, 2.2vw, 24px);
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: -0.005em;
    color: var(--on-surface);
    margin: 0;
    flex: 1 1 auto;
}
.live-update__stamp {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    margin-top: 3px;
    color: var(--outline);
    font-family: var(--font-sans);
    font-size: var(--fs-data-mono);
    font-weight: 500;
    letter-spacing: 0.02em;
}
.live-update__stamp .material-symbols-outlined { font-size: 15px; }
@media (min-width: 720px) {
    .live-update__stamp { display: none; }   /* replaced by left time column */
}

/* Optional image / map */
.live-update__media {
    margin: 0 0 12px;
    border: 1px solid var(--outline);
    position: relative;
    background: var(--surface-container);
}
.live-update__media img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    object-fit: cover;
}
.live-update__media figcaption {
    padding: 8px 10px;
    background: var(--surface-container);
    border-top: 1px solid var(--outline);
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--on-surface-variant);
}
@media (min-width: 720px) {
    .live-update__media img { aspect-ratio: auto; height: 256px; }
    .live-update__media { border-color: var(--on-surface); }
}

.live-update__media--map img { aspect-ratio: 16/9; }
.live-update__map-legend {
    position: absolute;
    bottom: 12px;
    left: 12px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 4px 8px;
    background: var(--surface-bright);
    border: 1px solid var(--on-surface);
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--on-surface);
}
.live-update__map-dot {
    width: 10px; height: 10px;
    background: var(--error, #ba1a1a);
}

/* Body */
.live-update__body {
    font-family: var(--font-sans);
    font-size: var(--fs-body-md);
    line-height: 1.55;
    color: var(--on-surface);
    margin: 0 0 12px;
    max-width: 72ch;
}
.live-update__body > p { margin: 0 0 0.9em; }
.live-update__body > p:last-child { margin-bottom: 0; }

/* Actions (share) */
.live-update__actions {
    display: flex;
    align-items: center;
    gap: 16px;
    color: var(--on-surface-variant);
}
.live-update__action {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 0;
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--on-surface-variant);
    background: transparent;
    border: 0;
    cursor: pointer;
}
.live-update__action:hover { color: var(--on-surface); }
.live-update__action .material-symbols-outlined { font-size: 16px; }

/* ── Load more CTA ────────────────────────────────────────────────────── */
.load-more {
    display: flex;
    justify-content: center;
    padding: 24px;
    border-top: 1px solid var(--outline-variant);
    background: var(--surface-container-low, var(--surface-container));
}
.load-more__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--on-surface);
    color: var(--surface-bright);
    font-family: var(--font-sans);
    font-size: var(--fs-label-caps);
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border: 1px solid var(--on-surface);
    cursor: pointer;
}
.load-more__btn:hover {
    background: var(--surface-bright);
    color: var(--on-surface);
}
.load-more__btn .material-symbols-outlined { font-size: 18px; }

/* ── Right side rail (desktop only) ───────────────────────────────────── */
.live-side {
    display: none;
    flex-direction: column;
    overflow-y: auto;
}
@media (min-width: 1024px) {
    .live-side { display: flex; }
}

.live-wire {
    padding: 20px 24px 24px;
    background: var(--surface-bright);
    flex: 1 1 auto;
}
.live-wire__title {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 20px;
    font-family: var(--font-serif);
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.005em;
    text-transform: uppercase;
    color: var(--on-surface);
}
.live-wire__marker {
    width: 4px;
    align-self: stretch;
    background: var(--on-surface);
    display: inline-block;
}
.live-wire__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}
.live-wire__list li {
    padding: 14px 0;
    border-bottom: 1px solid var(--outline-variant);
}
.live-wire__list li:first-child { padding-top: 0; }
.live-wire__list li:last-child { border-bottom: 0; padding-bottom: 0; }
.live-wire__time {
    display: block;
    margin-bottom: 6px;
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--secondary);
}
.live-wire__headline {
    font-family: var(--font-serif);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.35;
    letter-spacing: -0.005em;
    color: var(--on-surface);
    margin: 0;
}
.live-wire__headline a { color: inherit; text-decoration: none; }
.live-wire__headline a:hover { color: var(--secondary); }

/* --------------------------------------------------------------------------
   25. Wolfbrief borrows — reading progress, hot-rail, crests, countdown,
       ingest chip, section label, bottom-nav polish, curator-note,
       "you're caught up" completion state.
   -------------------------------------------------------------------------- */

/* Global reading-progress bar (2px, top of viewport, JS-driven) */
:root { --reading-progress: 0%; }
.reading-progress {
    position: fixed;
    top: 0; left: 0;
    height: 2px;
    width: var(--reading-progress);
    background: var(--secondary);
    z-index: 100;
    transition: width 80ms linear;
    pointer-events: none;
}

/* Hot-rail — AP/Wolfbrief-style pinned topic strip under the topbar.
   Always visible, horizontally scrollable on narrow screens. Scoped variants:
     .rail--global  → light surface
     .rail--thread  → inverted dark (used on live story pages)                */
.rail {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 24px;
    background: var(--paper);
    border-bottom: 1px solid var(--outline-variant);
    font-family: var(--font-sans);
    font-size: 13px;
    white-space: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    position: sticky;
    top: var(--topbar-h);
    z-index: 20;
}
.rail::-webkit-scrollbar { display: none; }
.rail--thread {
    background: var(--on-surface);
    color: var(--surface-bright);
    border-bottom: 1px solid var(--outline);
}
.rail__scope {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--on-surface);
    padding-right: 8px;
    flex-shrink: 0;
}
.rail--thread .rail__scope { color: var(--surface-bright); }
.rail__live {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--secondary);
    color: var(--on-secondary);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    flex-shrink: 0;
    text-decoration: none;
}
.rail__live .live-dot {
    width: 6px; height: 6px;
    background: var(--on-secondary);
    border-radius: 999px;
}
.rail__default {
    color: var(--on-surface);
    padding: 4px 0;
    border-bottom: 2px solid var(--on-surface);
    font-weight: 600;
    flex-shrink: 0;
    text-decoration: none;
}
.rail--thread .rail__default {
    color: var(--surface-bright);
    border-bottom-color: var(--surface-bright);
}
.rail__link {
    color: var(--on-surface-variant);
    padding: 4px 0;
    flex-shrink: 0;
    text-decoration: none;
}
.rail__link:hover {
    color: var(--on-surface);
    text-decoration: underline;
    text-underline-offset: 4px;
}
.rail--thread .rail__link { color: var(--outline-variant); }
.rail--thread .rail__link:hover { color: var(--surface-bright); }
.rail__sep { color: var(--outline); flex-shrink: 0; }

/* Source crests — stacked circular badges keyed by source slug.
   Use classes .crest.crest--c0 through .crest--c11 for deterministic colouring. */
.crest-stack { display: inline-flex; align-items: center; }
.crest {
    width: 26px; height: 26px;
    border-radius: 999px;
    border: 2px solid var(--surface-bright);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-sans);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: #fff;
    margin-left: -8px;
    flex-shrink: 0;
    position: relative;
    box-shadow: 0 0 0 0.5px var(--outline-variant);
}
.crest:first-child { margin-left: 0; }
.crest--small { width: 20px; height: 20px; font-size: 8px; border-width: 1.5px; }
.crest--more {
    background: var(--surface-container);
    color: var(--on-surface-variant);
    box-shadow: 0 0 0 0.5px var(--outline);
}
.crest--c0  { background: #1c1b1b; }
.crest--c1  { background: #0a0a0a; }
.crest--c2  { background: #25282c; }
.crest--c3  { background: #fa6400; color: #1b1b1b; }
.crest--c4  { background: #e2231a; }
.crest--c5  { background: #d71920; }
.crest--c6  { background: #004c54; }
.crest--c7  { background: #ed1c24; }
.crest--c8  { background: #f15822; }
.crest--c9  { background: #9a1b2f; }
.crest--c10 { background: #fff1e5; color: #990f3d; box-shadow: 0 0 0 0.5px #990f3d; }
.crest--c11 { background: #50625b; }

/* Crest-meta — "synthesized from N sources · updated 12m ago" */
.crest-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.crest-meta__label {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}

/* Masthead middle section label */
.topbar__section-label {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--on-surface);
    pointer-events: none;
    white-space: nowrap;
    display: none;
}
@media (min-width: 960px) {
    .topbar__section-label { display: block; }
}
.topbar__inner { position: relative; }

/* Theme toggle button (top bar) */
.topbar__theme {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    background: transparent;
    border: 0;
    color: var(--on-surface);
    cursor: pointer;
}
.topbar__theme:hover { background: var(--surface-container); }
.topbar__theme .material-symbols-outlined { font-size: 22px; }

/* Ingest health chip at bottom of drawer */
.drawer__ingest {
    margin-top: auto;
    padding: 14px 16px;
    border-top: 1px solid var(--outline-variant);
    background: var(--surface-container-low, var(--surface-container));
    font-family: var(--font-sans);
    font-size: 11px;
    color: var(--outline);
}
.drawer__ingest-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--on-surface);
    margin-bottom: 6px;
}
.drawer__ingest-dot {
    width: 8px; height: 8px;
    border-radius: 999px;
    background: var(--secondary);
    animation: wb-pulse 1.6s infinite;
}
.drawer__ingest-copy {
    font-size: 11px;
    line-height: 1.5;
    color: var(--outline);
    margin: 0;
}
@keyframes wb-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.45; } }

/* Coming-up countdown block (live-page sidebar) */
.coming-up {
    padding: 16px;
    background: var(--on-surface);
    color: var(--surface-bright);
    border: var(--border-base) solid var(--on-surface);
    margin-bottom: 16px;
}
.coming-up__label {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--outline-variant);
    opacity: 0.9;
    margin-bottom: 6px;
}
.coming-up__when {
    font-family: var(--font-serif);
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 4px;
    letter-spacing: -0.01em;
    line-height: 1.15;
}
.coming-up__detail {
    font-size: 11px;
    color: var(--outline-variant);
    opacity: 0.85;
    margin: 0 0 12px;
    letter-spacing: 0.02em;
}
.coming-up__countdown {
    display: flex;
    gap: 6px;
}
.coming-up__countdown div {
    flex: 1;
    text-align: center;
    padding: 6px 0;
    background: rgba(255,255,255,0.1);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.coming-up__countdown div strong {
    display: block;
    font-family: var(--font-serif);
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 4px;
}

/* "You're caught up" completion state */
.caught-up {
    margin: 48px auto 24px;
    padding: 40px 24px;
    max-width: 480px;
    text-align: center;
    border-top: 1px solid var(--outline-variant);
}
.caught-up__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px; height: 48px;
    border-radius: 999px;
    background: var(--surface-container);
    color: var(--on-surface-variant);
    margin: 0 auto 16px;
}
.caught-up__icon .material-symbols-outlined {
    font-size: 24px;
    font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}
.caught-up h3 {
    font-family: var(--font-serif);
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--on-surface);
    margin: 0 0 6px;
}
.caught-up p {
    font-family: var(--font-sans);
    font-size: 13px;
    line-height: 1.5;
    color: var(--on-surface-variant);
    margin: 0;
}

/* Curator-note (slim variant of editor's-note) */
.curator-note {
    margin: 16px 0;
    padding: 12px 14px 12px 16px;
    border-left: 3px solid var(--secondary);
    background: var(--surface-container-low, var(--surface-container));
}
.curator-note p {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 15px;
    line-height: 1.55;
    color: var(--on-surface-variant);
    margin: 0;
}

/* Bottom-nav polish — backdrop blur + iOS safe-area */
.bottom-nav {
    background: color-mix(in srgb, var(--on-surface) 92%, transparent);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding-bottom: env(safe-area-inset-bottom, 0px);
    height: calc(64px + env(safe-area-inset-bottom, 0px));
}
@media (max-width: 959px) {
    body.has-shell {
        padding-bottom: calc(64px + env(safe-area-inset-bottom, 0px));
    }
}

/* --------------------------------------------------------------------------
   26. Live-event list (index of rolling coverage)
   -------------------------------------------------------------------------- */
.live-list { padding: 24px; }
.live-list .section-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding-bottom: 10px;
    margin-bottom: 20px;
    border-bottom: 2px solid var(--on-surface);
}
.live-list .section-head h2 {
    font-family: var(--font-serif);
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.01em;
    margin: 0;
    color: var(--on-surface);
}
.live-list .section-head .data-mono {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--outline);
}

.live-list__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}
@media (min-width: 720px) {
    .live-list__grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1100px) {
    .live-list__grid { grid-template-columns: 1fr 1fr 1fr; }
}

.live-list__card {
    padding: 20px;
    border: 2px solid var(--on-surface);
    background: var(--surface-bright);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.live-list__pill {
    display: inline-flex;
    align-self: flex-start;
    align-items: center;
    gap: 6px;
    padding: 3px 8px;
    background: var(--secondary);
    color: var(--on-secondary);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    text-decoration: none;
}
.live-list__pill .live-dot {
    width: 6px; height: 6px;
    background: var(--on-secondary);
    border-radius: 999px;
}
.live-list__title {
    font-family: var(--font-serif);
    font-size: 20px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.01em;
    margin: 0;
}
.live-list__title a { color: var(--on-surface); text-decoration: none; }
.live-list__title a:hover { color: var(--secondary); }
.live-list__lede {
    font-family: var(--font-sans);
    font-size: 14px;
    line-height: 1.45;
    color: var(--on-surface-variant);
    margin: 0;
}
.live-list__meta {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    padding-top: 10px;
    border-top: 1px solid var(--outline-variant);
}
.live-list__meta .sep { color: var(--outline-variant); }

.live-list--closed { padding-top: 0; }
.live-list__archive { list-style: none; margin: 0; padding: 0; }
.live-list__archive li {
    border-bottom: 1px solid var(--outline-variant);
}
.live-list__archive li:last-child { border-bottom: 0; }
.live-list__archive a {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 14px 0;
    text-decoration: none;
}
.live-list__archive-date {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--outline);
}
.live-list__archive-title {
    font-family: var(--font-serif);
    font-size: 16px;
    font-weight: 600;
    color: var(--on-surface);
}
.live-list__archive a:hover .live-list__archive-title { color: var(--secondary); }
.live-list__archive-count {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}

/* -------------------------------------------------------------------------
   Extended platform surfaces: threads, entity trackers, video hub, archive
   ------------------------------------------------------------------------- */
.intel-surface {
    padding: 24px 0 0;
    display: grid;
    gap: 18px;
}
.intel-surface--split,
.intel-surface--three {
    display: grid;
    gap: 18px;
}
@media (min-width: 900px) {
    .intel-surface--split { grid-template-columns: 1fr 1fr; }
    .intel-surface--three { grid-template-columns: repeat(3, 1fr); }
}
.intel-grid {
    display: grid;
    gap: 18px;
}
@media (min-width: 900px) {
    .intel-grid--threads { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .intel-grid--videos { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.intel-card {
    display: grid;
    gap: 0;
    border: 1px solid var(--outline-variant);
    background: var(--paper);
}
.intel-card--thread {
    grid-template-columns: minmax(0, 1fr);
}
@media (min-width: 900px) {
    .intel-card--thread { grid-template-columns: minmax(0, 1fr) 220px; }
}
.intel-card__body {
    padding: 16px;
    display: grid;
    gap: 10px;
}
.intel-card__body h3 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 24px;
    line-height: 1.15;
}
.intel-card__body h3 a { color: var(--on-surface); text-decoration: none; }
.intel-card__body h3 a:hover { color: var(--secondary); }
.intel-card__body p {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    color: var(--on-surface-variant);
}
.intel-card__media {
    min-height: 180px;
    display: block;
    border-top: 1px solid var(--outline-variant);
}
@media (min-width: 900px) {
    .intel-card__media { border-top: 0; border-left: 1px solid var(--outline-variant); }
}
.intel-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.video-card { display: grid; gap: 12px; }
.entity-watch,
.archive-mini,
.thread-chapters {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
}
.entity-watch li,
.archive-mini li {
    border-bottom: 1px solid var(--outline-variant);
    padding-bottom: 10px;
}
.entity-watch li:last-child,
.archive-mini li:last-child { border-bottom: 0; padding-bottom: 0; }
.entity-watch a,
.archive-mini a {
    display: grid;
    gap: 4px;
    text-decoration: none;
    color: var(--on-surface);
}
.entity-watch a span,
.archive-mini span {
    font-size: 12px;
    color: var(--outline);
}
.beat-pulse {
    display: grid;
    gap: 12px;
}
.beat-pulse__row {
    display: grid;
    grid-template-columns: 90px 1fr 36px;
    align-items: center;
    gap: 12px;
    font-size: 13px;
}
.beat-pulse__bar {
    height: 8px;
    background: var(--outline-variant);
    display: block;
}
.beat-pulse__bar span {
    display: block;
    height: 100%;
    background: var(--on-surface);
}
.coming-up--home {
    border: 1px solid var(--outline-variant);
    padding: 16px;
}
.thread-layout {
    display: grid;
    gap: 24px;
}
.thread-hero {
    display: grid;
    gap: 16px;
}
.thread-hero__meta,
.thread-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    align-items: center;
    font-size: 12px;
    color: var(--outline);
}
.thread-hero h1,
.entity-hero h1 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(34px, 5vw, 56px);
    line-height: 0.98;
    letter-spacing: -0.03em;
}
.thread-grid {
    display: grid;
    gap: 24px;
}
@media (min-width: 1100px) {
    .thread-grid { grid-template-columns: minmax(0, 1fr) 320px; }
}
.thread-main,
.thread-side {
    display: grid;
    gap: 18px;
}
.thread-block {
    padding: 18px;
    border: 1px solid var(--outline-variant);
    background: var(--paper);
}
.thread-block h2 {
    margin: 0 0 12px;
    font-family: var(--font-serif);
    font-size: 24px;
}
.thread-block p {
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
}
.thread-chapters li {
    padding: 14px 0;
    border-bottom: 1px solid var(--outline-variant);
}
.thread-chapters li:last-child { border-bottom: 0; padding-bottom: 0; }
.thread-chapters__meta {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: baseline;
    margin-bottom: 8px;
}
.thread-chapters__meta span {
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--outline);
}
.entity-hero {
    display: grid;
    gap: 24px;
    align-items: start;
}
@media (min-width: 1100px) {
    .entity-hero { grid-template-columns: minmax(0, 1fr) 340px; }
}
.entity-hero__media img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border: 1px solid var(--outline-variant);
}
.archive-filter {
    padding: 18px;
    border: 1px solid var(--outline-variant);
    background: var(--paper);
    margin-bottom: 24px;
}
.archive-filter__row {
    display: grid;
    gap: 12px;
}
@media (min-width: 900px) {
    .archive-filter__row { grid-template-columns: 2fr 1fr 1fr auto; }
}
.archive-filter__row input,
.archive-filter__row select,
.archive-filter__row button {
    min-height: 44px;
    border: 1px solid var(--outline-variant);
    background: var(--surface);
    padding: 0 14px;
    font: inherit;
}
.archive-filter__row button {
    background: var(--on-surface);
    color: var(--surface);
    font-weight: 700;
    cursor: pointer;
}

@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; }
}
