/* ============================================================================
   Old Money — editorial / magazine theme
   Hand-written vanilla CSS. No build, no Tailwind. Dark, signal-green accent.
   Spine: a spacious centered editorial column, large Space Grotesk display
   headlines, generous whitespace, an accent rule under section labels.
   Class vocabulary is deliberately print-idiom (masthead / dispatch / colophon
   / standfirst / overline / ledger) so it shares no token namespace with the
   sibling sites.
   ============================================================================ */

:root {
    /* palette (fixed brand) */
    --page:        #0A0A0B;   /* near-black page */
    --surface:     #111114;   /* raised surface */
    --surface-2:   #16161A;   /* deeper card */
    --line:        #25252B;   /* hairline */
    --line-soft:   #1C1C21;   /* faint hairline */

    --ink:         #F4F4F2;   /* near-white text */
    --ink-dim:     #A6A6AD;   /* dimmed grey secondary */
    --ink-faint:   #6E6E76;   /* faintest meta */

    --accent:      #8AE9AA;   /* signal green */
    --accent-deep: #5FCB84;   /* hover / pressed green */
    --accent-2:    #7E93E3;   /* blue-violet secondary */

    /* type */
    --display: "Space Grotesk", system-ui, sans-serif;
    --body:    "IBM Plex Sans", system-ui, sans-serif;
    --label:   "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;

    /* layout */
    --measure: 940px;
    --gutter:  clamp(1.25rem, 5vw, 3rem);
    --card-radius: 14px;
}

/* ---- reset --------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
.paper {
    margin: 0;
    background: var(--page);
    color: var(--ink);
    font-family: var(--body);
    font-size: 1.0625rem;
    line-height: 1.65;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }

main { flex: 1 0 auto; }

/* subtle top sheen so the near-black page isn't flat */
.paper::before {
    content: "";
    position: fixed;
    inset: 0 0 auto 0;
    height: 60vh;
    pointer-events: none;
    background: radial-gradient(120% 80% at 50% -20%, rgba(138, 233, 170, 0.06), transparent 70%);
    z-index: 0;
}
.masthead, main, .colophon { position: relative; z-index: 1; }

/* ---- shared utilities ---------------------------------------------------- */
.col {
    width: 100%;
    max-width: var(--measure);
    margin-inline: auto;
    padding-inline: var(--gutter);
}

.sr-only {
    position: absolute !important;
    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: 1rem; top: -3rem;
    background: var(--accent);
    color: #08130C;
    font-family: var(--label);
    font-size: 0.8rem;
    font-weight: 600;
    padding: 0.6rem 1rem;
    border-radius: 8px;
    z-index: 100;
    transition: top 0.15s ease;
}
.skip-link:focus { top: 1rem; }

:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
    border-radius: 4px;
}

/* monospace section labels */
.overline,
.section-mark {
    font-family: var(--label);
    font-size: 0.74rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent);
    margin: 0;
}
.section-mark {
    color: var(--ink-faint);
    display: flex;
    align-items: center;
    gap: 0.9rem;
    margin-bottom: 1.6rem;
}
.section-mark::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--line);
}

/* ---- actions (buttons) --------------------------------------------------- */
.action {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--label);
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    padding: 0.78rem 1.35rem;
    border-radius: 999px;
    border: 1px solid transparent;
    transition: transform 0.12s ease, background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.action--fill {
    background: var(--accent);
    color: #07120B;
}
.action--fill:hover { background: var(--accent-deep); transform: translateY(-1px); }
.action--line {
    background: transparent;
    color: var(--ink);
    border-color: var(--line);
}
.action--line:hover { border-color: var(--accent); color: var(--accent); }

/* ============================================================================
   MASTHEAD (top header)
   ============================================================================ */
.masthead {
    max-width: var(--measure);
    margin-inline: auto;
    padding: 1.4rem var(--gutter);
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1.5rem;
    border-bottom: 1px solid var(--line);
}
.masthead__flag {
    display: grid;
    grid-template-columns: auto auto;
    grid-template-rows: auto auto;
    column-gap: 0.7rem;
    align-items: center;
    text-decoration: none;
    color: var(--ink);
}
.masthead__monogram {
    grid-row: 1 / 3;
    font-family: var(--display);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.01em;
    color: var(--accent);
    border: 1.5px solid var(--accent);
    border-radius: 8px;
    width: 2.4rem; height: 2.4rem;
    display: inline-grid;
    place-items: center;
    line-height: 1;
}
.masthead__title {
    font-family: var(--display);
    font-weight: 600;
    font-size: 1.32rem;
    letter-spacing: -0.015em;
    line-height: 1.05;
}
.masthead__sub {
    font-family: var(--label);
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-faint);
}
.masthead__nav {
    display: flex;
    align-items: center;
    gap: 1.6rem;
    padding-bottom: 0.2rem;
}
.masthead__tab {
    font-family: var(--label);
    font-size: 0.8rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--ink-dim);
    padding-bottom: 2px;
    border-bottom: 1.5px solid transparent;
    transition: color 0.15s ease, border-color 0.15s ease;
}
.masthead__tab:hover { color: var(--ink); }
.masthead__tab.is-current { color: var(--accent); border-bottom-color: var(--accent); }
.masthead__watch {
    font-family: var(--label);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    color: var(--accent);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.4rem 0.95rem;
    transition: border-color 0.15s ease, background 0.15s ease;
}
.masthead__watch:hover { border-color: var(--accent); background: rgba(138, 233, 170, 0.08); }

/* ============================================================================
   SPLASH (home + 404 hero)
   ============================================================================ */
.splash { padding: clamp(3.5rem, 9vw, 7rem) 0 clamp(2.5rem, 6vw, 4.5rem); }
.splash--error { padding-top: clamp(4rem, 12vw, 9rem); }
.splash__inner { max-width: 760px; }
.splash .overline { margin-bottom: 1.4rem; }
.splash__headline {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(2.6rem, 7.5vw, 5rem);
    line-height: 1.03;
    letter-spacing: -0.03em;
    margin: 0 0 1.5rem;
}
.splash__headline em { font-style: normal; color: var(--accent); }
.splash__standfirst {
    font-size: clamp(1.08rem, 2.2vw, 1.3rem);
    line-height: 1.6;
    color: var(--ink-dim);
    max-width: 62ch;
    margin: 0 0 2.2rem;
}
.splash__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
}

/* ============================================================================
   LEAD STORY (featured episode)
   ============================================================================ */
.lead-story { padding-block: clamp(2rem, 5vw, 3.5rem); }

.lead {
    display: block;
    text-decoration: none;
    color: inherit;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--card-radius);
    padding: clamp(1.6rem, 4vw, 2.75rem);
    position: relative;
    overflow: hidden;
    transition: border-color 0.18s ease, transform 0.18s ease, background 0.18s ease;
}
.lead::before {
    content: "";
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: linear-gradient(var(--accent), var(--accent-2));
    opacity: 0.85;
}
.lead:hover {
    border-color: var(--accent);
    transform: translateY(-2px);
    background: var(--surface-2);
}
.lead__slug {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    margin: 0 0 1.1rem;
}
.lead__no {
    font-family: var(--label);
    font-size: 0.8rem;
    letter-spacing: 0.1em;
    color: var(--ink-faint);
}
.lead__tag {
    font-family: var(--label);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--accent-2);
    border: 1px solid rgba(126, 147, 227, 0.45);
    border-radius: 999px;
    padding: 0.18rem 0.6rem;
}
.lead__headline {
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(1.6rem, 4vw, 2.5rem);
    line-height: 1.12;
    letter-spacing: -0.02em;
    margin: 0 0 0.7rem;
}
.lead__byline {
    font-family: var(--label);
    font-size: 0.82rem;
    letter-spacing: 0.03em;
    color: var(--accent);
    margin: 0 0 1rem;
}
.lead__deck {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--ink-dim);
    max-width: 60ch;
    margin: 0 0 1.6rem;
}
.lead__credits {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 1.2rem;
    font-family: var(--label);
    font-size: 0.8rem;
    color: var(--ink-faint);
    margin: 0;
}
.lead__more {
    color: var(--accent);
    font-weight: 600;
    margin-left: auto;
}

/* ============================================================================
   DIGEST (home strip — more from the chronicle)
   ============================================================================ */
.digest { padding-block: clamp(2.5rem, 6vw, 4rem); }
.digest__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.4rem;
}
.digest__head .section-mark { flex: 1; margin-bottom: 0; }
.digest__index {
    font-family: var(--label);
    font-size: 0.78rem;
    color: var(--accent);
    text-decoration: none;
    white-space: nowrap;
}
.digest__index:hover { color: var(--accent-deep); text-decoration: underline; }
.digest__list {
    list-style: none;
    margin: 1.4rem 0 0;
    padding: 0;
}
.brief { border-top: 1px solid var(--line-soft); }
.brief:last-child { border-bottom: 1px solid var(--line-soft); }
.brief__link {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: baseline;
    gap: 0.4rem 1.4rem;
    text-decoration: none;
    color: inherit;
    padding: 1.15rem 0.25rem;
    transition: background 0.15s ease, padding-left 0.15s ease;
}
.brief__link:hover { background: rgba(255, 255, 255, 0.02); padding-left: 0.75rem; }
.brief__link[aria-disabled="true"] { cursor: default; opacity: 0.62; }
.brief__link[aria-disabled="true"]:hover { background: none; padding-left: 0.25rem; }
.brief__no {
    font-family: var(--label);
    font-size: 0.78rem;
    color: var(--ink-faint);
}
.brief__title {
    font-family: var(--display);
    font-weight: 500;
    font-size: 1.12rem;
    line-height: 1.3;
    letter-spacing: -0.01em;
}
.brief__link:hover .brief__title { color: var(--accent); }
.brief__by {
    grid-column: 2;
    font-family: var(--label);
    font-size: 0.74rem;
    color: var(--ink-dim);
}
.brief__state {
    font-family: var(--label);
    font-size: 0.74rem;
    color: var(--accent);
    white-space: nowrap;
}

/* ============================================================================
   PROMO (home CTA band)
   ============================================================================ */
.promo {
    padding-block: clamp(3rem, 8vw, 5.5rem);
    border-top: 1px solid var(--line-soft);
    margin-top: clamp(2rem, 5vw, 3.5rem);
}
.promo__headline {
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(1.7rem, 4.5vw, 2.6rem);
    line-height: 1.12;
    letter-spacing: -0.02em;
    margin: 0 0 0.7rem;
    max-width: 22ch;
}
.promo__deck {
    font-size: 1.1rem;
    color: var(--ink-dim);
    max-width: 56ch;
    margin: 0 0 1.8rem;
}

/* ============================================================================
   PAGE MASTHEADS (chronicle / toolkit / legal)
   ============================================================================ */
.masthead-page {
    padding-top: clamp(3rem, 8vw, 5.5rem);
    padding-bottom: clamp(1.5rem, 4vw, 2.75rem);
}
.masthead-page .overline { margin-bottom: 1.2rem; }
.masthead-page__headline {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(2.2rem, 6vw, 3.8rem);
    line-height: 1.06;
    letter-spacing: -0.03em;
    margin: 0 0 1.2rem;
    max-width: 16ch;
}
.masthead-page__headline em { font-style: normal; color: var(--accent); }
.masthead-page__standfirst {
    font-size: clamp(1.05rem, 2vw, 1.2rem);
    color: var(--ink-dim);
    max-width: 60ch;
    margin: 0;
}

/* ============================================================================
   CHRONICLE (episodes as dispatch rows)
   ============================================================================ */
.chronicle {
    padding-bottom: clamp(3rem, 8vw, 5rem);
    display: flex;
    flex-direction: column;
}
.dispatch {
    display: grid;
    grid-template-columns: 7.5rem 1fr;
    gap: 0 2rem;
    padding: clamp(1.6rem, 4vw, 2.4rem) 0;
    border-top: 1px solid var(--line-soft);
}
.dispatch:last-child { border-bottom: 1px solid var(--line-soft); }
.dispatch__file {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    align-items: flex-start;
}
.dispatch__no {
    font-family: var(--label);
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    color: var(--ink-faint);
}
.dispatch__tag {
    font-family: var(--label);
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--accent-2);
    border: 1px solid rgba(126, 147, 227, 0.4);
    border-radius: 999px;
    padding: 0.15rem 0.55rem;
}
.dispatch__headline {
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(1.35rem, 3.2vw, 1.95rem);
    line-height: 1.16;
    letter-spacing: -0.02em;
    margin: 0 0 0.55rem;
}
.dispatch__headline a { text-decoration: none; color: inherit; transition: color 0.15s ease; }
.dispatch__headline a:hover { color: var(--accent); }
.dispatch__byline {
    font-family: var(--label);
    font-size: 0.8rem;
    letter-spacing: 0.03em;
    color: var(--accent);
    margin: 0 0 0.85rem;
}
.dispatch__deck {
    font-size: 1.02rem;
    line-height: 1.6;
    color: var(--ink-dim);
    max-width: 64ch;
    margin: 0 0 1.1rem;
}
.dispatch__credits {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem 1.2rem;
    font-family: var(--label);
    font-size: 0.78rem;
    color: var(--ink-faint);
    margin: 0;
}
.dispatch__more {
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
    margin-left: auto;
}
.dispatch__more:hover { text-decoration: underline; }
.dispatch__pending {
    color: var(--ink-faint);
    margin-left: auto;
}

/* ============================================================================
   LEDGER (toolkit — annotated editorial list)
   ============================================================================ */
.ledger { padding-bottom: clamp(3rem, 8vw, 5rem); }

.ftc-disclosure {
    font-family: var(--label);
    font-size: 0.78rem;
    line-height: 1.55;
    color: var(--ink-dim);
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-left: 3px solid var(--accent-2);
    border-radius: 10px;
    padding: 0.95rem 1.15rem;
    margin: 0 0 2.2rem;
    max-width: 70ch;
}

.sieve {
    margin-bottom: 1.6rem;
    max-width: 24rem;
}
.sieve__label {
    display: block;
    font-family: var(--label);
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-faint);
    margin-bottom: 0.5rem;
}
.sieve__field {
    width: 100%;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 10px;
    color: var(--ink);
    font-family: var(--body);
    font-size: 1rem;
    padding: 0.7rem 0.95rem;
    transition: border-color 0.15s ease;
}
.sieve__field::placeholder { color: var(--ink-faint); }
.sieve__field:focus { outline: none; border-color: var(--accent); }

.ledger__list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.kit {
    display: grid;
    grid-template-columns: 3rem 1fr auto;
    align-items: center;
    gap: 1.2rem;
    padding: 1.05rem 0.5rem 1.05rem 0;
    border-top: 1px solid var(--line-soft);
    transition: padding-left 0.15s ease, background 0.15s ease;
}
.kit:last-child { border-bottom: 1px solid var(--line-soft); }
.kit:hover { padding-left: 0.6rem; background: rgba(255, 255, 255, 0.018); }
.kit__no {
    font-family: var(--label);
    font-size: 0.82rem;
    color: var(--ink-faint);
}
.kit__name {
    font-family: var(--display);
    font-weight: 500;
    font-size: 1.18rem;
    letter-spacing: -0.01em;
}
.kit__open {
    font-family: var(--label);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--accent);
    text-decoration: none;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.42rem 0.95rem;
    white-space: nowrap;
    transition: border-color 0.15s ease, background 0.15s ease;
}
.kit__open:hover { border-color: var(--accent); background: rgba(138, 233, 170, 0.08); }
.ledger__none {
    font-family: var(--label);
    font-size: 0.85rem;
    color: var(--ink-dim);
    padding: 1.4rem 0;
}

/* ============================================================================
   LONGFORM (legal prose)
   ============================================================================ */
.longform {
    max-width: 68ch;
    padding-bottom: clamp(3rem, 8vw, 5rem);
}
.longform h2 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 1.3rem;
    letter-spacing: -0.01em;
    margin: 2.4rem 0 0.6rem;
    color: var(--ink);
}
.longform h2:first-child { margin-top: 0; }
.longform p {
    color: var(--ink-dim);
    margin: 0 0 1rem;
}
.longform a {
    color: var(--accent);
    text-decoration: none;
    border-bottom: 1px solid rgba(138, 233, 170, 0.35);
}
.longform a:hover { border-bottom-color: var(--accent); }

/* ============================================================================
   VOID (empty states)
   ============================================================================ */
.void {
    border: 1px dashed var(--line);
    border-radius: var(--card-radius);
    padding: clamp(2rem, 5vw, 3rem);
    text-align: left;
}
.void--tall { padding: clamp(2.5rem, 6vw, 4rem); }
.void__line {
    font-size: 1.1rem;
    color: var(--ink-dim);
    margin: 0 0 1.4rem;
    max-width: 50ch;
}

/* ============================================================================
   COLOPHON (footer)
   ============================================================================ */
.colophon {
    border-top: 1px solid var(--line-soft);
    margin-top: auto;
    background: var(--surface);
}
.colophon__top {
    max-width: var(--measure);
    margin-inline: auto;
    padding: clamp(2.5rem, 6vw, 3.5rem) var(--gutter) 1.8rem;
    display: grid;
    grid-template-columns: 1.6fr repeat(auto-fit, minmax(8rem, 1fr));
    gap: 2rem;
    align-items: start;
}
.colophon__flag {
    font-family: var(--display);
    font-weight: 600;
    font-size: 1.2rem;
    letter-spacing: -0.01em;
    display: block;
    margin-bottom: 0.6rem;
}
.colophon__line {
    font-size: 0.95rem;
    color: var(--ink-faint);
    margin: 0;
    max-width: 30ch;
}
.colophon__group { display: flex; flex-direction: column; gap: 0.55rem; }
.colophon__head {
    font-family: var(--label);
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    color: var(--ink-faint);
    margin-bottom: 0.25rem;
}
.colophon__link {
    font-size: 0.92rem;
    color: var(--ink-dim);
    text-decoration: none;
    transition: color 0.15s ease;
}
.colophon__link:hover { color: var(--accent); }
.colophon__base {
    max-width: var(--measure);
    margin-inline: auto;
    padding: 1.4rem var(--gutter);
    border-top: 1px solid var(--line-soft);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
}
.colophon__copy {
    font-family: var(--label);
    font-size: 0.76rem;
    color: var(--ink-faint);
}
.colophon__legal { display: flex; gap: 1.4rem; }
.colophon__legal a {
    font-family: var(--label);
    font-size: 0.76rem;
    color: var(--ink-dim);
    text-decoration: none;
}
.colophon__legal a:hover { color: var(--accent); }

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
@media (max-width: 720px) {
    .masthead { flex-wrap: wrap; align-items: flex-start; gap: 1rem 1.2rem; }
    .masthead__nav { gap: 1.1rem; flex-wrap: wrap; }
    .dispatch { grid-template-columns: 1fr; gap: 0.9rem; }
    .dispatch__file { flex-direction: row; align-items: center; }
    .lead__more, .dispatch__more, .dispatch__pending { margin-left: 0; }
    .brief__link { grid-template-columns: auto 1fr; }
    .brief__state { grid-column: 2; }
    .kit { grid-template-columns: 2.2rem 1fr; }
    .kit__open { grid-column: 2; justify-self: start; margin-top: 0.4rem; }
}

@media (max-width: 460px) {
    .splash__actions .action { width: 100%; justify-content: center; }
}

/* ============================================================================
   MOTION
   ============================================================================ */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
}
