/* ═══════════════════════════════════════════════════════════════════════════
   stuart-thomas.com — v2 sitewide stylesheet
   Magazine / editorial. Cream paper, ink black, Fraunces display serif,
   sticker-pill nav, neobrutalist cards, bold colour-block section chips.
   Load this first; pages may add minimal page-specific styles after.
   Backout: snapshot at /home/stuart/_ping_snapshot_*/preV2sitewide_*/sitewide.tar.gz
   ═══════════════════════════════════════════════════════════════════════════ */

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

:root {
  --paper:     #f4ede0;
  --paper-2:   #ece4d2;
  --paper-3:   #e3dac3;
  --ink:       #131419;
  --ink-dim:   #5a5648;
  --ink-faint: #8c8773;
  --rule:      #d6cdb6;
  --accent:    #3b3fee;  /* electric cobalt */
  --hot:       #ff5037;  /* hot coral */
  --acid:      #d8e02a;  /* acid lime */
  --warm:      #f9b32a;  /* warm yellow */
  --good:      #10b981;
  --radius:    6px;
  --measure:   62ch;
}

html { background: var(--paper); color: var(--ink); scroll-behavior: smooth; }
/* Emoji-friendly font stack — Apple Color Emoji on mac/iOS, Segoe UI Emoji on Windows,
   Noto Color Emoji on Linux. Inter still wins for normal text. */
body { font-family: 'Inter', system-ui, -apple-system, 'Segoe UI',
                    'Apple Color Emoji', 'Segoe UI Emoji', 'Noto Color Emoji', sans-serif;
       line-height: 1.55; font-size: 16.5px;
       -webkit-font-smoothing: antialiased; counter-reset: section; }
::selection { background: var(--accent); color: #fff; }
:focus-visible { outline: 3px solid var(--accent); outline-offset: 4px; border-radius: 2px; }
img { max-width: 100%; height: auto; display: block; }

/* Default link styling — scoped so nav/hero/footer pills aren't clobbered */
a { color: var(--accent); text-decoration: none; transition: all .15s; }
a:hover { color: #fff; }
/* Underline ONLY in flowing body copy (post body, hero subtitle, footer-box, sections) */
.post-body a, .hero-sub a, .hero-description a, .post-footer-box a, .section p a, .section-intro a {
    border-bottom: 2px solid var(--accent);
}
.post-body a:hover, .hero-sub a:hover, .hero-description a:hover,
.post-footer-box a:hover, .section p a:hover, .section-intro a:hover {
    background: var(--accent); color: #fff;
}

@media (prefers-reduced-motion: reduce) { *,*::before,*::after { transition: none !important; animation: none !important; } }

/* ── SKIP LINK ──────────────────────────────────────────────────────── */
.skip-link { position: absolute; top: -100%; left: 16px; z-index: 9999;
             background: var(--ink); color: var(--paper); padding: 10px 18px;
             font-weight: 700; text-decoration: none; border-bottom: 0; }
.skip-link:focus { top: 0; }

/* ── NAV ────────────────────────────────────────────────────────────── */
/* Works whether the page wraps children in .site-nav-inner OR puts them
   directly inside .site-nav (homepage uses wrapper; topic pages don't). */
.site-nav { background: var(--paper); border-bottom: 3px solid var(--ink); position: sticky; top: 0; z-index: 100;
            max-width: 1240px; margin: 0 auto; padding: 18px 36px;
            display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.site-nav-inner { display: contents; }   /* lets children participate in .site-nav's flex */
.nav-left { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.site-nav-logo, .nav-badge {
    font: 900 1rem/1 'Fraunces', Georgia, serif; color: var(--ink);
    text-decoration: none; letter-spacing: -0.02em; border-bottom: 0;
    background: var(--acid); padding: 8px 14px; border: 2px solid var(--ink);
    border-radius: 100px; transform: rotate(-1.5deg); display: inline-block;
    transition: transform .15s;
}
.site-nav-logo:hover, .nav-badge:hover { transform: rotate(-3deg) scale(1.05); background: var(--acid); color: var(--ink); }
.site-nav-links, .nav-links { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.site-nav-links a, .nav-links a, .nav-link {
    font: 700 0.78rem/1 'JetBrains Mono', ui-monospace, monospace;
    color: var(--ink); text-decoration: none; letter-spacing: 0.04em;
    padding: 9px 14px; background: var(--paper); border: 2px solid var(--ink);
    border-radius: 100px; text-transform: uppercase; transition: all .15s;
}
.site-nav-links a:hover, .nav-links a:hover, .nav-link:hover {
    background: var(--warm); color: var(--ink); transform: rotate(-2deg);
}
.theme-toggle, .theme-btn { display: none; }   /* v2 is light-only for now */

/* ── HERO ───────────────────────────────────────────────────────────── */
.hero { padding: 0; background: var(--paper); border-bottom: 3px solid var(--ink); }
.hero-inner { max-width: 1240px; margin: 0 auto; padding: 60px 36px 80px;
              display: grid; grid-template-columns: minmax(0, 1fr);
              gap: 56px; align-items: end; position: relative; }
/* Two-column hero only when there's a portrait to balance (homepage) */
.hero-inner:has(.hero-photo) { grid-template-columns: minmax(0, 5fr) minmax(0, 3fr); }
.hero-masthead {
    grid-column: 1 / -1;
    font: 700 0.72rem/1 'JetBrains Mono', ui-monospace, monospace;
    color: var(--ink); letter-spacing: 0.2em; text-transform: uppercase;
    padding: 14px 0; border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink);
    margin-bottom: 56px; text-align: center;
}
.hero-badge, .pre-title { display: inline-block;
    font: 700 0.75rem/1 'JetBrains Mono', monospace;
    background: var(--warm); color: var(--ink); padding: 8px 14px;
    border: 2px solid var(--ink); border-radius: 100px;
    letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 24px;
    transform: rotate(-1.5deg);
}
.hero h1, .hero-title {
    font: 900 clamp(2.5rem, 7vw, 6rem)/0.95 'Fraunces', Georgia, serif;
    font-variation-settings: "opsz" 144;
    letter-spacing: -0.035em; color: var(--ink); margin: 0 0 36px;
    overflow-wrap: break-word; hyphens: auto;
}
.hero h1 .gradient, .hero-title .gradient {
    color: var(--hot); background: none !important;
    -webkit-background-clip: initial !important;
    -webkit-text-fill-color: initial !important;
    font-style: italic;
}
.hero-description, .hero-text p, .hero-sub, .hero-desc, .standfirst {
    font: 500 1.18rem/1.5 'Inter'; color: var(--ink-dim);
    max-width: 56ch; margin-bottom: 32px;
}
.standfirst { font-size: 1.32rem; color: var(--ink); }
.hero-meta { display: flex; gap: 18px; align-items: baseline; color: var(--ink-faint);
             font: 600 0.78rem/1 'JetBrains Mono', monospace; flex-wrap: wrap; margin-top: 16px; }
.hero-links { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero-links a {
    font: 700 0.92rem/1 'Inter'; color: var(--ink); background: var(--paper);
    border: 2px solid var(--ink); border-radius: 100px;
    padding: 12px 22px; transition: all .15s; letter-spacing: -0.005em;
}
.hero-links a:first-child { background: var(--ink); color: var(--paper); }
.hero-links a:hover { background: var(--accent); border-color: var(--accent);
                      color: #fff; transform: translateY(-2px); }

.hero-photo { position: relative; align-self: end; max-width: 320px; justify-self: end;
              transform: rotate(2deg); }
.hero-photo::before {
    content: "Plate I"; position: absolute; top: -22px; left: -8px;
    background: var(--hot); color: #fff; padding: 4px 12px;
    font: 700 0.68rem/1 'JetBrains Mono', monospace; letter-spacing: 0.12em;
    text-transform: uppercase; border: 2px solid var(--ink);
    transform: rotate(-4deg); border-radius: 4px;
}
.hero-photo img { border: 3px solid var(--ink); border-radius: 4px;
                  box-shadow: 8px 8px 0 var(--ink); filter: grayscale(20%); }
@media (max-width: 820px) {
    .hero-inner { grid-template-columns: 1fr; gap: 40px; }
    .hero-photo { transform: none; max-width: 220px; justify-self: start; }
}

/* ── SECTIONS ──────────────────────────────────────────────────────── */
main { background: var(--paper); }
.section, .featured-section {
    max-width: 1240px; margin: 0 auto;
    padding: 96px 36px; counter-increment: section;
}
.section h2, .featured-section h2 {
    font: 900 clamp(2rem, 5.5vw, 4rem)/0.95 'Fraunces', Georgia, serif;
    font-variation-settings: "opsz" 144;
    letter-spacing: -0.025em; color: var(--ink); margin: 0 0 28px;
    max-width: 22ch;
}
.section-label, .post-label {
    display: inline-block; font: 700 0.72rem/1 'JetBrains Mono', monospace;
    color: var(--ink); background: var(--warm); padding: 8px 14px;
    border: 2px solid var(--ink); border-radius: 100px;
    letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 24px;
    transform: rotate(-1.5deg);
}
main > section:nth-of-type(3n+1) .section-label { background: var(--warm); }
main > section:nth-of-type(3n+2) .section-label { background: var(--acid); }
main > section:nth-of-type(3n+3) .section-label { background: #ffc7c7; }

.section-intro, .hero-desc + p {
    font: 400 1.1rem/1.55 'Inter'; color: var(--ink-dim);
    max-width: var(--measure); margin-bottom: 48px;
}

/* ── CARDS (homepage + blog index) ──────────────────────────────────── */
.post-card, .principle-card, .qualification-card, .about-card,
.building-card, .delivered-card, .craft-card, .bento-card, [class$="-card"]:not(.bento-card) {
    background: var(--paper-2); border: 2px solid var(--ink);
    border-radius: 8px; padding: 28px; display: block;
    transition: transform .15s, box-shadow .15s, background .15s;
    box-shadow: 4px 4px 0 var(--ink);
}
a.post-card, a.bento-card { text-decoration: none; color: var(--ink); border-bottom: 0; }
.post-card:hover, .principle-card:hover, .about-card:hover,
.building-card:hover, .delivered-card:hover, .craft-card:hover, .bento-card:hover {
    transform: translate(-3px, -3px); box-shadow: 7px 7px 0 var(--accent);
    background: var(--paper);
}
.post-card h2, .post-card h3, .bento-card h2, .bento-card h3 {
    font: 700 1.45rem/1.15 'Fraunces', Georgia, serif;
    font-variation-settings: "opsz" 28;
    margin: 14px 0; color: var(--ink); letter-spacing: -0.015em;
}
.post-card .excerpt, .post-card p, .bento-card p {
    font-size: 0.95rem; color: var(--ink-dim); line-height: 1.5;
}
.post-num { font: 900 0.72rem/1 'JetBrains Mono', monospace;
            background: var(--ink); color: var(--acid);
            padding: 4px 8px; border-radius: 4px;
            letter-spacing: 0.15em; display: inline-block; }
.post-meta { display: flex; gap: 12px; align-items: baseline; color: var(--ink-faint);
             font: 600 0.72rem/1 'JetBrains Mono', monospace; flex-wrap: wrap; }
.post-meta-sep { color: var(--ink-faint); }
.post-tags, .tags { display: flex; gap: 6px; margin-top: 16px; flex-wrap: wrap; }
.post-tag, .tag { font: 700 0.66rem/1 'JetBrains Mono', monospace; padding: 5px 9px;
                  border: 2px solid var(--ink); color: var(--ink); background: var(--paper);
                  border-radius: 100px; letter-spacing: 0.04em; text-transform: uppercase; }
/* Topic-tag colours — subtle background tints */
.post-tag.macos     { background: #e0f4ff; }
.post-tag.kernel    { background: #d6f0d8; }
.post-tag.bsd       { background: #ffe9d6; }
.post-tag.apple     { background: #f0e8ff; }
.post-tag.disclosure{ background: #ffd6d6; }
.post-tag.methodology{ background: #fff3cf; }
.post-tag.es        { background: #ddead4; }
.post-tag.crypto    { background: #d6e3ff; }
.post-tag.network   { background: #f5d6ff; }
.post-tag.infra     { background: #e9d6c5; }
.post-tag.appsec    { background: #ffe2e2; }
.post-tag.privacy   { background: #d6f0eb; }
.post-tag.compiler  { background: #f0f0c5; }
.post-tag.protocol  { background: #d6c5f0; }

/* Featured findings grid + bento grids */
.featured-grid, [class*="-grid"]:not(.creds-grid) {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px; margin-top: 16px;
}

/* ── BUTTONS / CTAs ─────────────────────────────────────────────────── */
.cta-primary, .cta-secondary, .button, button.button {
    display: inline-block; background: var(--ink); color: var(--paper);
    border: 2px solid var(--ink); border-radius: 100px; padding: 14px 24px;
    font: 700 0.9rem/1 'Inter'; cursor: pointer; transition: all .15s;
    text-decoration: none; letter-spacing: -0.005em;
    box-shadow: 4px 4px 0 var(--ink);
}
.cta-primary:hover, .cta-secondary:hover, .button:hover, button.button:hover {
    background: var(--accent); border-color: var(--accent); color: #fff;
    transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--ink);
}
.cta-secondary { background: var(--paper); color: var(--ink); }

/* ── PHOTO STRIP ────────────────────────────────────────────────────── */
.photo-strip figure { transition: transform .15s; }
.photo-strip figure:nth-child(1) { transform: rotate(-2deg); }
.photo-strip figure:nth-child(2) { transform: rotate(1deg); }
.photo-strip figure:nth-child(3) { transform: rotate(-1deg); }
.photo-strip figure:hover { transform: rotate(0) scale(1.02); z-index: 10; }
.photo-strip figure img { border: 3px solid var(--ink); border-radius: 4px;
                          box-shadow: 6px 6px 0 var(--ink); }
.photo-strip figcaption { color: var(--ink); font: 600 0.82rem/1.4 'JetBrains Mono', monospace; margin-top: 14px; }

/* ── CONTACT NAV ────────────────────────────────────────────────────── */
.contact-nav { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
.contact-nav a {
    font: 700 0.95rem/1 'Inter'; color: var(--ink); background: var(--paper);
    border: 2px solid var(--ink); border-radius: 100px;
    padding: 12px 20px; transition: all .15s;
}
.contact-nav a:hover { background: var(--hot); border-color: var(--ink);
                       color: #fff; transform: translate(-2px, -2px);
                       box-shadow: 4px 4px 0 var(--ink); }

/* ── FOOTER ─────────────────────────────────────────────────────────── */
/* Dark slab applies ONLY to the page-level site footer, NOT to in-article
   <footer> elements (some posts use <footer> for their disclosure box). */
body > footer, .site-footer { background: var(--ink); color: var(--paper);
                              padding: 64px 36px 80px; border-top: 3px solid var(--ink); }
body > footer > *, .site-footer > *, .footer-links { max-width: 1240px; margin: 0 auto; }
body > footer p, .site-footer p { font: 500 0.92rem/1.4 'Inter'; }

/* In-article footers (used by some posts for the disclosure/legal box) */
main footer, .post-body + footer, article > footer, .post-footer {
    background: var(--paper-2); color: var(--ink); border: 2px solid var(--ink);
    border-radius: 8px; padding: 24px 28px; margin: 40px auto 80px;
    max-width: 700px; box-shadow: 4px 4px 0 var(--ink);
    font-size: 0.9rem; line-height: 1.55;
}
main footer p, article > footer p { color: var(--ink); margin-bottom: 0.6em; }
main footer a, article > footer a, .post-footer a {
    color: var(--accent); border-bottom: 2px solid var(--accent);
}
main footer a:hover, article > footer a:hover, .post-footer a:hover {
    background: var(--accent); color: #fff;
}
.footer-links { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 18px; }
.footer-links a { color: var(--paper); font: 700 0.78rem/1 'JetBrains Mono', monospace;
                  letter-spacing: 0.08em; text-transform: uppercase;
                  border-bottom: 2px solid transparent; padding-bottom: 2px; background: transparent; }
.footer-links a:hover { color: var(--acid); border-bottom-color: var(--acid); background: transparent; }

/* ── BLOG POST PAGE LAYOUT ──────────────────────────────────────────── */
.post-header { padding: 80px 36px 60px; background: var(--paper); border-bottom: 3px solid var(--ink); }
.post-header-inner { max-width: 860px; margin: 0 auto; }
.post-kicker {
    display: inline-block; font: 700 0.72rem/1 'JetBrains Mono', monospace;
    color: var(--ink); background: var(--warm); padding: 8px 14px;
    border: 2px solid var(--ink); border-radius: 100px;
    letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 32px;
    transform: rotate(-1.5deg);
}
.post-title { font: 900 clamp(2.4rem, 6vw, 4.5rem)/0.96 'Fraunces', Georgia, serif;
              font-variation-settings: "opsz" 144;
              letter-spacing: -0.03em; color: var(--ink); margin: 0 0 28px; }
.post-title .gradient { color: var(--hot); background: none !important;
    -webkit-background-clip: initial !important; -webkit-text-fill-color: initial !important;
    font-style: italic; }
.post-lede { font: 500 1.3rem/1.5 'Inter'; color: var(--ink-dim);
             max-width: 60ch; margin-bottom: 32px; }
.post-meta { color: var(--ink-faint); font: 600 0.78rem/1 'JetBrains Mono', monospace;
             display: flex; gap: 12px; flex-wrap: wrap; align-items: baseline; }
.post-meta time { color: var(--ink-faint); }

.post-body { max-width: 700px; margin: 0 auto; padding: 80px 36px;
             font-size: 1.13rem; line-height: 1.72; color: var(--ink); }
.post-body p { margin-bottom: 1.4em; }
.post-body h2 { font: 800 2rem/1.15 'Fraunces', Georgia, serif;
                margin: 2.4em 0 0.8em; color: var(--ink); letter-spacing: -0.02em; }
.post-body h3 { font: 700 1.4rem/1.2 'Inter'; margin: 2em 0 0.6em; color: var(--ink); }
.post-body a { color: var(--accent); border-bottom: 2px solid var(--accent); }
.post-body a:hover { background: var(--accent); color: #fff; }
.post-body strong { color: var(--ink); font-weight: 700; }
.post-body code { font-family: 'JetBrains Mono', monospace; font-size: 0.92em;
                  background: var(--paper-2); padding: 2px 6px; border-radius: 4px;
                  border: 1px solid var(--rule); }
.post-body hr { border: 0; border-top: 2px solid var(--ink); margin: 3em 0; }
.post-body ul, .post-body ol { margin: 0 0 1.4em 1.4em; }
.post-body li { margin-bottom: 0.5em; }

/* Fact box (Technical Finding) */
.fact-box { background: var(--paper-2); border: 2px solid var(--ink);
            border-radius: 8px; padding: 24px 28px; margin: 32px 0;
            box-shadow: 4px 4px 0 var(--ink); }
.fact-box-label { display: inline-block; font: 700 0.7rem/1 'JetBrains Mono', monospace;
                  background: var(--ink); color: var(--acid); padding: 6px 12px;
                  border-radius: 4px; letter-spacing: 0.1em;
                  text-transform: uppercase; margin-bottom: 16px; }
.fact-box p { margin: 0 0 0.8em; font-size: 0.98rem; }
.fact-box p:last-child { margin-bottom: 0; }
.fact-box code { background: var(--paper); }

/* Opinion note */
.opinion-note { background: #fff7d6; border-left: 4px solid var(--warm);
                border: 2px solid var(--ink); border-left-width: 8px;
                border-radius: 6px; padding: 22px 26px; margin: 32px 0;
                box-shadow: 4px 4px 0 var(--ink); }
.opinion-note-label { display: inline-block; font: 700 0.7rem/1 'JetBrains Mono', monospace;
                      background: var(--warm); color: var(--ink); padding: 6px 12px;
                      border: 2px solid var(--ink); border-radius: 4px;
                      letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 14px; }

/* OK box — affirmative result */
.ok-box { background: #d6f0d8; border: 2px solid var(--ink); border-radius: 8px;
          padding: 22px 26px; margin: 32px 0; box-shadow: 4px 4px 0 var(--ink); }
.ok-label { display: inline-block; font: 700 0.7rem/1 'JetBrains Mono', monospace;
            background: var(--good); color: #fff; padding: 6px 12px;
            border-radius: 4px; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 12px; }
.ok-word { font-weight: 700; color: var(--good); }

/* Code block */
.code-block { background: var(--ink); color: var(--paper); border-radius: 6px;
              padding: 0; margin: 28px 0; overflow: hidden;
              border: 2px solid var(--ink); box-shadow: 4px 4px 0 var(--ink); }
.code-block-label { display: flex; justify-content: space-between; align-items: center;
                    padding: 10px 16px; background: rgba(255,255,255,0.05);
                    font: 600 0.72rem/1 'JetBrains Mono', monospace;
                    letter-spacing: 0.08em; color: var(--acid);
                    text-transform: uppercase; border-bottom: 1px solid rgba(255,255,255,0.1); }
.code-block pre { padding: 18px 20px; overflow-x: auto;
                  font: 400 0.86rem/1.55 'JetBrains Mono', monospace; color: var(--paper); }
.code-block code { background: transparent; border: 0; padding: 0; color: inherit; }

/* Method comparison table */
.method-table { width: 100%; border-collapse: collapse; margin: 24px 0;
                border: 2px solid var(--ink); }
.method-table th, .method-table td { padding: 10px 14px; text-align: left;
                                     border-bottom: 1px solid var(--rule);
                                     font-size: 0.92rem; }
.method-table th { background: var(--ink); color: var(--paper);
                    font: 700 0.78rem/1 'JetBrains Mono', monospace;
                    letter-spacing: 0.08em; text-transform: uppercase; }
.method-table td.gated { color: var(--good); font-weight: 600; }
.method-table td.ungated { color: var(--hot); font-weight: 700; }
.method-table tr:nth-child(even) td { background: var(--paper-2); }

/* Final thought, standfirst, divider */
.final-thought { font: 400 1.4rem/1.5 'Fraunces', Georgia, serif;
                 color: var(--ink-dim); font-style: italic;
                 margin: 56px 0; padding: 32px 0; border-top: 2px solid var(--ink);
                 border-bottom: 2px solid var(--ink); text-align: center; }
.divider { border: 0; border-top: 2px solid var(--ink); margin: 48px 0; }

/* Post footer (legal / AI / licence box) */
.post-footer { max-width: 700px; margin: 40px auto 80px; padding: 0 36px; }
.post-footer-box { background: var(--paper-2); border: 2px solid var(--ink);
                    border-radius: 8px; padding: 24px 28px; box-shadow: 4px 4px 0 var(--ink);
                    font-size: 0.88rem; color: var(--ink-dim); line-height: 1.55; }
.post-footer-box p { margin-bottom: 0.6em; }
.post-footer-box p:last-child { margin-bottom: 0; }
.post-footer-divider { border: 0; border-top: 1px solid var(--rule); margin: 14px 0; }

/* ── BLOG INDEX ─────────────────────────────────────────────────────── */
.search-wrap { margin: 32px 0 8px; max-width: 600px;
               border: 2px solid var(--ink); border-radius: 100px; background: var(--paper);
               display: flex; align-items: center; padding: 4px 4px 4px 18px;
               box-shadow: 4px 4px 0 var(--ink); }
.search-wrap input { flex: 1; background: transparent; border: 0; outline: 0;
                     font: 500 0.95rem/1 'Inter'; color: var(--ink); padding: 12px 8px; }
.search-status { font: 600 0.78rem/1 'JetBrains Mono', monospace;
                  color: var(--ink-dim); margin: 8px 0 24px; }
.clear-btn { background: var(--ink); color: var(--paper); border: 0;
             padding: 8px 14px; border-radius: 100px;
             font: 600 0.72rem/1 'JetBrains Mono', monospace;
             letter-spacing: 0.04em; text-transform: uppercase; cursor: pointer;
             display: none; }
.clear-btn.visible { display: inline-block; }
.no-results { display: none; padding: 32px; text-align: center;
              color: var(--ink-dim); font-style: italic; }
.no-results.visible { display: block; }

/* Post-card on blog index — full-card link, embargoed hidden */
.post-card[data-embargoed="true"], .post-card.search-hidden { display: none; }

/* ── SECURITY-RESEARCH page specifics ───────────────────────────────── */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
         gap: 14px; margin: 32px 0; }
/* Some pages wrap .stat items in .stats-inner. display:contents lets them
   participate in the parent .stats grid regardless. */
.stats-inner { display: contents; }
.stat { background: var(--paper-2); border: 2px solid var(--ink); border-radius: 8px;
        padding: 28px 18px; text-align: center; box-shadow: 4px 4px 0 var(--ink); }
/* Better emoji rendering inside stat-value, hero-badge, exp-icon, post-kicker */
.stat-value, .hero-badge, .exp-icon, .post-kicker, .nav-badge,
.section-label, .pre-title, .bento-emoji {
    font-family: 'Apple Color Emoji', 'Segoe UI Emoji', 'Noto Color Emoji',
                 'Fraunces', Georgia, 'Inter', sans-serif;
}
.exp-icon, .bento-emoji { font-size: 2rem; margin-bottom: 12px; display: inline-block; }
.stat-value { font: 900 2.2rem/1 'Fraunces', Georgia, serif; color: var(--accent);
              display: block; margin-bottom: 6px; }
.stat-label { font: 600 0.74rem/1.2 'JetBrains Mono', monospace;
              color: var(--ink-dim); letter-spacing: 0.05em; text-transform: uppercase; }

.creds-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
              gap: 20px; margin: 32px 0; }
.cred-group { background: var(--paper-2); border: 2px solid var(--ink); border-radius: 8px;
              padding: 24px; box-shadow: 4px 4px 0 var(--ink); }
.cred-item { padding: 12px 0; border-top: 1px solid var(--rule); }
.cred-item:first-child { border-top: 0; }
.cred-name { font: 700 1rem/1.3 'Inter'; color: var(--ink); display: block; }
.cred-issuer { font: 500 0.85rem/1.3 'Inter'; color: var(--ink-dim); }

.pub-list { list-style: none; margin: 0; padding: 0; }
.pub { background: var(--paper-2); border: 2px solid var(--ink); border-radius: 8px;
       padding: 20px 24px; margin-bottom: 14px; box-shadow: 4px 4px 0 var(--ink); }
.pub:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--accent); }
.pub-citation { font: 500 1rem/1.5 'Inter'; color: var(--ink); }
.pub-year, .pub-org { font: 600 0.78rem/1 'JetBrains Mono', monospace; color: var(--ink-dim); }

.split { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
@media (max-width: 720px) { .split { grid-template-columns: 1fr; } }
.panel-left, .panel-right { background: var(--paper-2); border: 2px solid var(--ink);
                            border-radius: 8px; padding: 28px; box-shadow: 4px 4px 0 var(--ink); }
.panel-footer { margin-top: 32px; padding-top: 24px; border-top: 2px solid var(--ink); color: var(--ink-dim); }

/* ── PRIVACY BANNER ─────────────────────────────────────────────────── */
.privacy-banner { position: fixed; bottom: 0; left: 0; right: 0;
                   background: var(--ink); color: var(--paper); padding: 16px 24px;
                   font: 500 0.88rem/1.45 'Inter'; z-index: 1000;
                   border-top: 3px solid var(--warm);
                   transform: translateY(100%); transition: transform .35s ease;
                   display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.privacy-banner.show { transform: translateY(0); }
.privacy-banner button { background: var(--warm); color: var(--ink); border: 2px solid var(--paper);
                          padding: 9px 16px; border-radius: 100px;
                          font: 700 0.78rem/1 'JetBrains Mono', monospace;
                          letter-spacing: 0.06em; text-transform: uppercase; cursor: pointer; }

/* ── REVEAL ─────────────────────────────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .5s ease, transform .5s ease; }
.reveal.visible { opacity: 1; transform: none; }
.reveal-delay-1, .reveal-delay-2, .reveal-delay-3, .reveal-delay-4 { transition-delay: 0s; }

/* ── PRINT (posts) ──────────────────────────────────────────────────── */
@media print {
    .site-nav, .site-footer, footer, .privacy-banner { display: none !important; }
    body { background: #fff; color: #000; }
    .post-body { max-width: none; padding: 0; }
    .code-block { background: #f5f5f5; color: #000; border: 1px solid #ccc; }
    .code-block pre { color: #000; }
}


/* ═══════════════════════════════════════════════════════════════════════ */
/* GAMES ROW (extracted from games-row.html) — snake + adventure on homepage */
/* ═══════════════════════════════════════════════════════════════════════ */

.games-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:stretch}
      /* Outer card — matches the rest of the page's box style (surface bg, soft border, generous padding) */
      .game-card{
        background:var(--paper-2);
        border:1px solid rgba(255,255,255,0.04);
        border-radius:var(--radius);
        padding:20px 22px;
        display:flex;
        flex-direction:column;
        gap:12px;
      }
      .game-bar{
        display:flex;justify-content:space-between;align-items:center;gap:10px;
        font:600 0.72rem/1 'JetBrains Mono',ui-monospace,monospace;color:var(--text-faint);
      }
      .game-bar .label{color:var(--text-dim);text-transform:uppercase;letter-spacing:0.08em}
      .game-bar .btns{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
      .gbtn{background:rgba(255,255,255,0.05);color:var(--text-dim);border:1px solid rgba(255,255,255,0.08);border-radius:5px;padding:4px 9px;font:600 0.68rem/1 inherit;cursor:pointer;font-family:inherit;transition:all .12s}
      .gbtn:hover{background:rgba(255,255,255,0.10);color:var(--text)}
      .gbtn.on{background:rgba(106,108,242,0.20);color:#a4a6ff;border-color:rgba(106,108,242,0.40)}
      /* Inner "screen" — fills the remaining card height; canvas keeps its
         native pixel grid via aspect-ratio, sized to match adventure-card height */
      .snake-canvas-sm{
        display:block;width:100%;height:auto;
        aspect-ratio:3/2;
        background:#08080d;
        border:1px solid rgba(255,255,255,0.06);
        border-radius:8px;
        image-rendering:pixelated;cursor:crosshair;touch-action:none;
        flex:1 1 auto;min-height:0;
      }
      .snake-score-sm{
        font:0.72rem/1 'JetBrains Mono',ui-monospace,monospace;color:var(--text-dim);
        padding-top:2px;
      }
      /* Adventure terminal — screen + input grouped into one bordered box that
         grows to fill the card so it visually matches the snake side */
      .adv-terminal{
        background:#070710;
        border:1px solid rgba(255,255,255,0.06);
        border-radius:8px;
        overflow:hidden;
        display:flex;
        flex-direction:column;
        flex:1 1 auto;min-height:240px;
      }
      .adv-screen-sm{
        padding:12px 14px;overflow-y:auto;
        font-family:'JetBrains Mono',ui-monospace,monospace;font-size:0.78rem;line-height:1.5;color:#cdd0d8;
        scrollbar-width:thin;scrollbar-color:#2a2a36 #070710;
        flex:1 1 auto;min-height:200px;
      }
      .adv-screen-sm::-webkit-scrollbar{width:5px}
      .adv-screen-sm::-webkit-scrollbar-thumb{background:#2a2a36;border-radius:3px}
      .adv-line{margin:0;white-space:pre-wrap;word-wrap:break-word}
      .adv-line.user{color:#a4a6ff}
      .adv-line.title{color:#e8e6f0;font-weight:600;margin-top:6px}
      .adv-line.note{color:#7a7a96;font-style:italic;font-size:0.74rem}
      .adv-line.win{color:#10b981;font-weight:600}
      .adv-line.bonk{color:#f59e0b}
      .adv-input-row{display:flex;align-items:center;border-top:1px solid rgba(255,255,255,0.06);padding:7px 12px;background:rgba(255,255,255,0.02)}
      .adv-prompt{color:#a4a6ff;font-family:'JetBrains Mono',ui-monospace,monospace;margin-right:6px;user-select:none;font-size:0.78rem}
      .adv-input{flex:1;background:transparent;border:0;outline:0;color:#e8e6f0;font:0.78rem/1.4 'JetBrains Mono',ui-monospace,monospace;padding:3px 0;caret-color:#a4a6ff}
      .games-foot{font-size:0.72rem;color:var(--text-faint);margin:14px 0 0;line-height:1.5}
      @media(max-width:760px){.games-grid{grid-template-columns:1fr;gap:16px}}/* ── BLOG POST LEGACY-CLASS ALIASES ───────────────────────────────────
   30 older posts use the pre-v2 class system: <main class="page"> with
   <article><header>, .post-label, .standfirst, .body, hr.div.
   These aliases map the old class names onto the same visual treatment as
   the modern .post-header / .post-kicker / .post-lede / .post-body classes,
   so all 54 posts read consistently without rewriting any post HTML. */

main.page { display: block; }
main.page > article { display: block; }
main.page > article > header {
  padding: 80px 36px 60px; max-width: 860px; margin: 0 auto;
  background: var(--paper); border-bottom: 3px solid var(--ink);
}
main.page > article > header > h1.post-title,
main.page > article > header > h1 {
  font: 900 clamp(2.4rem, 6vw, 4.5rem)/0.96 'Fraunces', Georgia, serif;
  letter-spacing: -0.03em; color: var(--ink); margin: 0 0 28px;
}
main.page .standfirst {
  font: 500 1.3rem/1.5 'Inter'; color: var(--ink-dim);
  max-width: 60ch; margin-bottom: 32px; display: block;
}
main.page .post-label {
  display: inline-block; font: 700 0.72rem/1 'JetBrains Mono', monospace;
  color: var(--ink); background: var(--warm); padding: 8px 14px;
  border: 2px solid var(--ink); border-radius: 100px;
  letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 32px;
  transform: rotate(-1.5deg);
}
main.page .body {
  max-width: 700px; margin: 0 auto; padding: 80px 36px;
  font-size: 1.13rem; line-height: 1.72; color: var(--ink);
}
main.page .body p { margin-bottom: 1.4em; }
main.page .body h2 {
  font: 800 2rem/1.15 'Fraunces', Georgia, serif;
  margin: 2.4em 0 0.8em; color: var(--ink); letter-spacing: -0.02em;
}
main.page .body h3 { font: 700 1.4rem/1.2 'Inter'; margin: 2em 0 0.6em; color: var(--ink); }
main.page .body a { color: var(--accent); border-bottom: 2px solid var(--accent); }
main.page .body a:hover { background: var(--accent); color: #fff; }
main.page .body strong { color: var(--ink); font-weight: 700; }
main.page .body code {
  font-family: 'JetBrains Mono', monospace; font-size: 0.92em;
  background: var(--paper-2); padding: 2px 6px; border-radius: 4px;
  border: 1px solid var(--rule);
}
main.page .body ul, main.page .body ol { margin: 0 0 1.4em 1.4em; }
main.page .body li { margin-bottom: 0.5em; }
main.page .body blockquote {
  border-left: 4px solid var(--accent); margin: 1.6em 0; padding: 0.4em 0 0.4em 1.4em;
  color: var(--ink-dim); font-style: italic;
}

/* old hr style used in legacy posts */
hr.div { border: 0; border-top: 2px solid var(--ink); margin: 3em 0; }

/* In legacy posts the post-meta line uses emoji prefixes — keep them legible */
main.page header .post-meta { color: var(--ink-faint); font: 600 0.78rem/1 'JetBrains Mono', monospace;
                              display: flex; gap: 14px; flex-wrap: wrap; align-items: baseline; margin-top: 8px; }

/* ── PRIVACY / LEGAL PAGES: missing classes ───────────────────────────
   privacy.html (and any future legal page) uses .hero-label, .highlight-box,
   .data-table, .data-table-wrap, .content. None of these had CSS rules in
   v2-style.css, so the page was rendering nearly unstyled. */

/* Kicker label above an H1 in a hero block */
.hero-label {
  display: inline-block; font: 700 0.72rem/1 'JetBrains Mono', monospace;
  color: var(--ink); background: var(--warm); padding: 8px 14px;
  border: 2px solid var(--ink); border-radius: 100px;
  letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 24px;
  transform: rotate(-1.5deg);
}

/* Main content wrapper for long-form legal/info pages */
main.content {
  max-width: 800px; margin: 0 auto; padding: 24px 36px 80px;
  font-size: 1rem; line-height: 1.65; color: var(--ink);
}
main.content h2 {
  font: 800 1.6rem/1.2 'Fraunces', Georgia, serif;
  margin: 2.2em 0 0.5em; color: var(--ink); letter-spacing: -0.02em;
}
main.content h3 {
  font: 700 1.1rem/1.2 'Inter'; margin: 1.6em 0 0.4em; color: var(--ink);
}
main.content p { margin-bottom: 1em; }
main.content ul, main.content ol { margin: 0 0 1em 1.4em; }
main.content li { margin-bottom: 0.35em; }
main.content a { color: var(--accent); border-bottom: 2px solid var(--accent); }
main.content a:hover { background: var(--accent); color: #fff; }
main.content strong { color: var(--ink); font-weight: 700; }

/* Section block — each numbered section on privacy.html */
main.content .section {
  margin-bottom: 8px;
  padding-bottom: 12px;
}
main.content .section:not(:last-child) { border-bottom: 1px solid var(--rule, #e8e0d0); }

/* Highlight callout — important standalone statements like "This website uses no cookies" */
.highlight-box {
  background: var(--paper-2); border: 2px solid var(--ink);
  border-radius: 8px; padding: 20px 24px; margin: 24px 0 28px;
  box-shadow: 4px 4px 0 var(--accent);
  font-size: 1.02rem; line-height: 1.6;
}
.highlight-box p { margin: 0; }
.highlight-box p + p { margin-top: 10px; }

/* Data table — the IP/date/page table */
.data-table-wrap { overflow-x: auto; margin: 18px 0 22px; }
.data-table {
  width: 100%; border-collapse: collapse;
  border: 2px solid var(--ink);
  font-size: 0.92rem;
  background: var(--paper-2);
}
.data-table th, .data-table td {
  padding: 10px 14px; text-align: left;
  border-bottom: 1px solid var(--rule, #e8e0d0);
  vertical-align: top;
}
.data-table th {
  background: var(--ink); color: var(--paper);
  font: 700 0.78rem/1 'JetBrains Mono', monospace;
  letter-spacing: 0.06em; text-transform: uppercase;
  border-bottom: 2px solid var(--ink);
}
.data-table tr:nth-child(even) td { background: var(--paper); }
.data-table td:first-child { font-weight: 600; }
.data-table code, .data-table td:nth-child(2) {
  font-family: 'JetBrains Mono', monospace; font-size: 0.88rem;
}

/* ── CODE-BLOCK OVERRIDE ─────────────────────────────────────────────
   The legacy main.page .body code rule (paper-2 pill for inline code)
   was leaking into <pre><code>...</code></pre> code-blocks, wrapping
   each line in a pill. Override with higher specificity. */
main.page .body .code-block code,
main.page .body pre code,
.code-block pre code,
.code-block code {
  background: transparent !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: var(--paper) !important;
}

/* ── HERO FALLBACK (when no .hero-inner child) ───────────────────────
   privacy.html and similar simple pages use <header class="hero"> with
   the H1/lede directly inside it, no .hero-inner wrapper. Without this
   fallback, those titles render flush against the viewport edges. */
.hero:not(:has(.hero-inner)) {
  padding: 60px 36px 80px;
  max-width: 1240px; margin: 0 auto;
}

/* ── PRIVACY BANNER (cream-ified) ─────────────────────────────────────
   Was dark ink slab; bring it into the v2 cream/paper aesthetic. */
.privacy-banner {
  background: var(--paper-2) !important;
  color: var(--ink) !important;
  border-top: 3px solid var(--warm) !important;
}
.privacy-banner a {
  color: var(--accent) !important;
  border-bottom: 2px solid var(--accent);
}
.privacy-banner a:hover {
  background: var(--accent); color: #fff;
}
.privacy-banner button {
  background: var(--ink) !important;
  color: var(--paper) !important;
  border: 2px solid var(--ink) !important;
}
.privacy-banner button:hover {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
}

/* ── BLOG SPLIT: left pane pinned, right pane scrolls naturally ──
   Left pane uses position:sticky with top:16px and a max-height
   capped at the viewport so it never overflows the screen.
   scrollbar-gutter:stable keeps the layout from shifting on hover. */
@media (min-width: 721px) {
  .split { align-items: flex-start; }
  .panel-left {
    position: sticky;
    top: 16px;
    align-self: start;
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
  }
}

/* ── PRIVACY BANNER: reserve body bottom space so it doesn't cover content ── */
body:has(.privacy-banner) { padding-bottom: 72px; }
@media (max-width: 600px) {
  body:has(.privacy-banner) { padding-bottom: 120px; }
}

/* ── SITE FOOTER: cream-ified (was dark ink slab) ─────────────────────
   Match the privacy-banner palette: paper-2 background, ink text,
   warm-orange top border, accent-cobalt links. */
body > footer, .site-footer {
  background: var(--paper-2) !important;
  color: var(--ink) !important;
  border-top: 3px solid var(--warm) !important;
}
body > footer p, .site-footer p {
  color: var(--ink) !important;
}
.footer-links a {
  color: var(--ink) !important;
  border-bottom-color: transparent;
}
.footer-links a:hover {
  color: var(--accent) !important;
  border-bottom-color: var(--accent) !important;
  background: transparent !important;
}

/* ── ACADEMIC PAPER LAYOUT ────────────────────────────────────────────
   /vendor-ethics/ uses an academic-paper class system that v2-style.css
   didn't know about. Sidebar + main column, paper-header with title/
   authors/affiliation, .sec / .subsec headings, .pull quotes, status
   pills, impact-table, refs and footnotes. Mirrors the v2 cream/paper
   palette so it sits alongside the rest of the site. */

.page-wrap {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 56px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 40px 32px 80px;
}
@media (max-width: 900px) {
  .page-wrap { grid-template-columns: 1fr; gap: 24px; padding: 24px 20px 60px; }
}

/* Left sidebar — contents nav */
.page-wrap > .sidebar {
  position: sticky; top: 24px;
  align-self: start;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  font-size: 0.88rem; line-height: 1.5;
  border-right: 1px solid var(--rule, #d8cdb4);
  padding-right: 24px;
}
@media (max-width: 900px) {
  .page-wrap > .sidebar {
    position: static; max-height: none; border-right: 0;
    border-bottom: 2px solid var(--ink); padding: 0 0 16px;
  }
}
.page-wrap > .sidebar .site-home {
  display: inline-block; font: 700 0.72rem/1 'JetBrains Mono', monospace;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink); margin-bottom: 18px;
  border-bottom: 2px solid transparent; padding-bottom: 2px;
}
.page-wrap > .sidebar .site-home:hover {
  color: var(--accent); border-bottom-color: var(--accent); background: transparent;
}
.page-wrap > .sidebar .sidebar-title {
  font: 700 0.72rem/1 'JetBrains Mono', monospace;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-faint); margin: 10px 0 12px;
}
.page-wrap > .sidebar nav { display: flex; flex-direction: column; gap: 8px; }
.page-wrap > .sidebar nav a {
  color: var(--ink-dim); border-bottom: 0; padding: 2px 0; font-size: 0.86rem;
}
.page-wrap > .sidebar nav a:hover {
  color: var(--accent); background: transparent;
}

/* Main column */
.page-wrap > .main {
  max-width: 720px;
  font-size: 1.02rem;
  line-height: 1.7;
  color: var(--ink);
}
.page-wrap > .main p { margin-bottom: 1.1em; }
.page-wrap > .main a { color: var(--accent); border-bottom: 2px solid var(--accent); }
.page-wrap > .main a:hover { background: var(--accent); color: #fff; }
.page-wrap > .main strong { color: var(--ink); font-weight: 700; }
.page-wrap > .main code {
  font-family: 'JetBrains Mono', monospace; font-size: 0.92em;
  background: var(--paper-2); padding: 2px 6px; border-radius: 4px;
  border: 1px solid var(--rule, #d8cdb4);
}

/* Paper header */
.paper-header { margin-bottom: 36px; }
.paper-header h1 {
  font: 800 clamp(2rem, 4vw, 2.8rem)/1.05 'Fraunces', Georgia, serif;
  letter-spacing: -0.025em; color: var(--ink); margin: 0 0 14px;
}
.paper-header .subtitle {
  font: 400 1.15rem/1.4 'Fraunces', Georgia, serif;
  color: var(--ink-dim); font-style: italic; margin-bottom: 22px;
}
.paper-header .authors {
  font: 600 0.95rem/1.3 'Inter';
  color: var(--ink); margin-bottom: 4px;
}
.paper-header .affiliation {
  font: 400 0.88rem/1.4 'Inter';
  color: var(--ink-dim); margin-bottom: 12px;
}
.paper-header .paper-meta {
  font: 500 0.78rem/1.4 'JetBrains Mono', monospace;
  color: var(--ink-faint); letter-spacing: 0.01em; margin-bottom: 0;
}
.paper-header .paper-meta a {
  color: var(--accent); border-bottom: 1px solid var(--accent);
}
.thick-rule {
  border: 0; border-top: 3px solid var(--ink); margin: 18px 0 32px;
}

/* Section headings */
h2.sec {
  font: 800 1.5rem/1.2 'Fraunces', Georgia, serif;
  margin: 2.4em 0 0.8em; color: var(--ink); letter-spacing: -0.018em;
  scroll-margin-top: 20px;
}
h3.subsec {
  font: 700 1.1rem/1.3 'Inter';
  margin: 1.8em 0 0.5em; color: var(--ink);
}

/* Pull-quote */
.pull {
  font: 500 1.18rem/1.5 'Fraunces', Georgia, serif;
  font-style: italic; color: var(--ink-dim);
  border-left: 3px solid var(--accent);
  padding: 0.3em 0 0.3em 1.4em; margin: 1.6em 0 1.8em;
}

/* Inline status pills (status-ok / status-warn) */
.status-ok, .status-warn {
  display: inline-block; font: 700 0.7rem/1 'JetBrains Mono', monospace;
  padding: 4px 8px; border: 2px solid var(--ink); border-radius: 100px;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.status-ok { background: #d6f0d8; color: var(--ink); }
.status-warn { background: #ffd6d6; color: var(--ink); }

/* Impact table */
.impact-table {
  width: 100%; border-collapse: collapse; margin: 22px 0;
  border: 2px solid var(--ink); font-size: 0.92rem;
  background: var(--paper-2);
}
.impact-table th, .impact-table td {
  padding: 10px 14px; text-align: left;
  border-bottom: 1px solid var(--rule, #d8cdb4);
  vertical-align: top;
}
.impact-table th {
  background: var(--ink); color: var(--paper);
  font: 700 0.78rem/1 'JetBrains Mono', monospace;
  letter-spacing: 0.06em; text-transform: uppercase;
}
.impact-table tr:nth-child(even) td { background: var(--paper); }

/* References + footnotes */
.references, .ref-list, .footnotes {
  font-size: 0.88rem; line-height: 1.55;
  border-top: 2px solid var(--ink);
  margin-top: 48px; padding-top: 24px;
}
.references ol, .ref-list ol, .footnotes ol {
  list-style: decimal; padding-left: 1.4em;
}
.references li, .ref-list li, .footnotes li {
  margin-bottom: 0.7em; padding-left: 0.2em;
}
.references h2, .ref-list h2, .footnotes h2 {
  font: 800 1.2rem/1.2 'Fraunces', Georgia, serif;
  margin: 0 0 14px; color: var(--ink); letter-spacing: -0.015em;
}
sup a { font-size: 0.75em; vertical-align: super; color: var(--accent); border-bottom: 0; }

/* Page footer for academic pages */
.page-footer {
  margin-top: 48px; padding-top: 20px;
  border-top: 1px solid var(--rule, #d8cdb4);
  font-size: 0.82rem; color: var(--ink-faint); line-height: 1.5;
}
.page-footer a { color: var(--accent); }

/* ── IMPACT-TABLE TWEAK: cleaner label cells, fixed column widths ──── */
.impact-table { table-layout: fixed; }
.impact-table th {
  font: 700 0.85rem/1.2 'Inter';
  letter-spacing: 0.005em;
  text-transform: none;
  padding: 12px 14px;
}
.impact-table th:first-child,
.impact-table td:first-child { width: 38%; }
.impact-table th:last-child,
.impact-table td:last-child  { width: 62%; }

/* ── VALUES BENTO (Principles section on homepage) ────────────────── */
.values-bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media (max-width: 900px) { .values-bento { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .values-bento { grid-template-columns: 1fr; } }
.value-card {
  background: var(--paper-2);
  border: 2px solid var(--ink);
  border-radius: 8px;
  padding: 22px 24px 24px;
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform .15s ease, box-shadow .15s ease;
  position: relative;
  overflow: hidden;
}
.value-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--accent);
}
.value-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 6px;
}
.value-card.v1::before { background: var(--accent); }
.value-card.v2::before { background: var(--hot); }
.value-card.v3::before { background: var(--acid); }
.value-card.v4::before { background: var(--warm); }
.value-card.v5::before { background: #d6f0eb; }
.value-card.v6::before { background: #d6e3ff; }
.value-emoji {
  font-size: 1.8rem; line-height: 1; margin: 6px 0 14px;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", system-ui, sans-serif;
}
.value-card h4 {
  font: 800 1.22rem/1.1 'Fraunces', Georgia, serif;
  letter-spacing: -0.018em; color: var(--ink); margin: 0 0 10px;
}
.value-card p {
  font: 500 0.95rem/1.5 'Inter'; color: var(--ink); margin: 0;
}

/* ── BARE <pre><code> in legacy .body — give it proper terminal styling
   (some posts use a bare <pre><code>...</code></pre> rather than a
   <div class="code-block"> wrapper. Style those directly.) */
main.page .body pre {
  background: var(--ink);
  color: var(--paper);
  padding: 18px 22px;
  margin: 26px 0;
  overflow-x: auto;
  border: 2px solid var(--ink);
  border-radius: 0;
  box-shadow: 4px 4px 0 var(--ink);
  font: 400 0.86rem/1.55 'JetBrains Mono', monospace;
}
main.page .body pre code {
  background: transparent !important;
  color: var(--paper) !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  font: inherit;
  white-space: pre;
}
