/* =================================================================
   THE SEO BITS — Satirical SEO Newsroom
   Design system + layout + interaction styles
   ================================================================= */

/* -----------------------------------------------------------------
   1. TOKENS / THEME
   ----------------------------------------------------------------- */
:root {
  /* type */
  --font-display: 'Anton', 'Archivo Expanded', Impact, sans-serif;
  --font-expanded: 'Archivo Expanded', 'Archivo', sans-serif;
  --font-sans: 'Archivo', system-ui, sans-serif;
  --font-serif: 'IBM Plex Serif', Georgia, serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  /* type scale */
  --fs-hero: clamp(2.6rem, 7vw, 6rem);
  --fs-h2: clamp(1.8rem, 4vw, 3rem);
  --fs-h3: clamp(1.15rem, 2vw, 1.6rem);

  /* layout */
  --wrap: 1280px;
  --gut: clamp(1rem, 3vw, 2.5rem);
  --radius: 4px;
  --radius-lg: 10px;

  /* motion */
  --ease: cubic-bezier(.2,.7,.2,1);

  /* DARK (default) — the newsroom after hours */
  --bg: #110d0d;
  --bg-2: #1a1414;
  --bg-card: #1e1717;
  --bg-card-2: #241b1b;
  --ink: #f3ece1;          /* newspaper white, slightly warm */
  --ink-dim: #b8a99a;
  --ink-mute: #7d6f63;
  --rule: #3a2c2c;
  --rule-soft: #2a2020;

  --red: #e11919;          /* blood red */
  --red-bright: #ff2a2a;
  --red-deep: #8a0d0d;
  --green: #39ff7a;        /* toxic neon ranking green */
  --green-dim: #1fa84f;
  --orange: #ff7a1a;       /* electric orange */
  --yellow: #ffd11a;       /* warning yellow */

  --stamp-red: #d41616;
}

/* LIGHT MODE — the lights come on, harsh fluorescent */
[data-theme="light"] {
  --bg: #e9e3d6;           /* newsprint */
  --bg-2: #ddd5c4;
  --bg-card: #f4efe2;
  --bg-card-2: #efe8d8;
  --ink: #14100c;
  --ink-dim: #4a3f33;
  --ink-mute: #8a7b6a;
  --rule: #b8ac96;
  --rule-soft: #c9bda6;

  --red: #c11212;
  --red-bright: #e11919;
  --red-deep: #7a0808;
  --green: #0a8f3a;        /* less neon in light mode for legibility */
  --orange: #d65d00;
  --yellow: #c79a00;

  --stamp-red: #b81010;
}

/* -----------------------------------------------------------------
   2. RESET / BASE
   ----------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
  transition: background .5s var(--ease), color .5s var(--ease);
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
input { font: inherit; }

.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gut); }

::selection { background: var(--red); color: #fff; }

/* -----------------------------------------------------------------
   3. NEWSPAPER TEXTURE OVERLAYS (scan-lines + coffee stain + grain)
   ----------------------------------------------------------------- */
body::before {
  /* scan-lines */
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9000;
  background-image: repeating-linear-gradient(
    0deg,
    rgba(0,0,0,.06) 0px,
    rgba(0,0,0,.06) 1px,
    transparent 1px,
    transparent 3px
  );
  mix-blend-mode: multiply;
  opacity: .55;
}
[data-theme="light"] body::before { opacity: .35; }

body::after {
  /* film grain / paper noise */
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9001;
  opacity: .08;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* coffee stain — a fixed decorative ring near a corner */
.coffee-stain {
  position: fixed;
  top: 120px;
  right: 4vw;
  width: 220px;
  height: 220px;
  pointer-events: none;
  z-index: 1;
  opacity: .35;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, transparent 60%, rgba(90,50,20,.45) 62%, transparent 70%),
    radial-gradient(ellipse 70% 60% at 50% 50%, transparent 70%, rgba(70,40,15,.3) 73%, transparent 82%);
  filter: blur(.4px);
  transform: rotate(-12deg);
}
[data-theme="light"] .coffee-stain { opacity: .22; }

/* -----------------------------------------------------------------
   4. UTIL BAR (ticker)
   ----------------------------------------------------------------- */
.util-bar {
  background: #000;
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .04em;
  position: relative;
  z-index: 50;
}
.util-bar__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1.5rem;
  padding-block: .45rem;
}
.util-bar__date { color: var(--red-bright); font-weight: 700; white-space: nowrap; }

.util-bar__ticker {
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.ticker__track {
  display: inline-flex;
  gap: 3rem;
  white-space: nowrap;
  animation: ticker 38s linear infinite;
}
.ticker__track span { color: var(--ink-dim); }
@keyframes ticker { to { transform: translateX(-50%); } }

/* fluorescent light toggle */
.fluorescent-toggle {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .3rem .7rem;
  border: 1px solid var(--rule);
  border-radius: 999px;
  background: #0a0707;
  color: var(--ink-dim);
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .08em;
  transition: all .2s var(--ease);
}
.fluorescent-toggle:hover { border-color: var(--red); color: var(--ink); }
.fluorescent-toggle .bulb {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--yellow);
  box-shadow: 0 0 8px var(--yellow), 0 0 16px rgba(255,209,10,.6);
  flex-shrink: 0;
}
[data-theme="light"] .fluorescent-toggle .bulb {
  background: #555; box-shadow: none;
}
[data-theme="light"] .fluorescent-toggle { background: #2a2020; color: var(--ink-dim); }

/* flicker animation when toggling */
body.is-flickering,
body.is-flickering::before,
body.is-flickering::after { animation: flicker .55s steps(2) 1; }
@keyframes flicker {
  0%, 18%, 22%, 25%, 53%, 57%, 100% { opacity: 1; }
  20%, 24%, 55% { opacity: .25; }
}

/* -----------------------------------------------------------------
   5. MASTHEAD
   ----------------------------------------------------------------- */
.masthead {
  padding-block: clamp(1.2rem, 3vw, 2.2rem) .8rem;
  position: relative;
  z-index: 5;
}
.masthead__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: end;
  gap: 1rem;
}
.masthead__meta {
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .08em;
  color: var(--ink-mute);
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.masthead__meta--left { align-items: flex-start; }
.masthead__meta--right { align-items: flex-end; text-align: right; }
.edition-price { color: var(--red); }
.weather strong { color: var(--ink); }

.logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  line-height: .85;
}
.logo__seal {
  width: .9em;
  height: .9em;
  margin-right: .08em;
  vertical-align: baseline;
  display: inline-block;
  transform: translateY(.04em);
  filter: drop-shadow(0 2px 6px rgba(225, 25, 25, 0.35));
}
.logo__the {
  font-family: var(--font-display);
  font-size: clamp(1rem, 2.5vw, 1.6rem);
  letter-spacing: .35em;
  color: var(--ink-dim);
  padding-left: .35em;
}
.logo__out {
  font-family: var(--font-display);
  font-size: clamp(3rem, 11vw, 7.5rem);
  letter-spacing: -.01em;
  color: var(--ink);
  position: relative;
  display: inline-block;
}
.logo__link { color: var(--red); }
.logo__blast {
  color: var(--green);
  font-size: .5em;
  vertical-align: super;
  margin-left: .05em;
  display: inline-block;
  animation: blast 2.4s ease-in-out infinite;
}
@keyframes blast {
  0%,100% { transform: translate(0,0); }
  50% { transform: translate(4px,-4px); }
}
.logo__sub {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .22em;
  color: var(--ink-mute);
  margin-top: .5rem;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: .25rem 1rem;
}

.ink-rule {
  height: 6px;
  background: repeating-linear-gradient(90deg, var(--ink) 0 12px, transparent 12px 18px);
  opacity: .8;
  margin-top: .8rem;
}

/* -----------------------------------------------------------------
   6. CATEGORY NAV
   ----------------------------------------------------------------- */
.catnav {
  border-top: 2px solid var(--ink);
  border-bottom: 3px double var(--ink);
  background: var(--bg);
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(6px);
}
.catnav__inner {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding-block: .6rem;
  flex-wrap: wrap;
}
.catnav__chip {
  font-family: var(--font-display);
  font-size: .82rem;
  letter-spacing: .06em;
  padding: .4rem .85rem;
  border: 1px solid var(--rule);
  border-radius: 999px;
  color: var(--ink-dim);
  transition: all .18s var(--ease);
}
.catnav__chip:hover { color: var(--ink); border-color: var(--red); transform: translateY(-1px); }
.catnav__chip.is-active {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
  box-shadow: 3px 3px 0 var(--ink);
}
.catnav__search {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: .72rem;
  color: var(--ink-mute);
  letter-spacing: .05em;
}

/* -----------------------------------------------------------------
   7. CARD BASE + PAPER CRUMPLE / ALERT HOVER
   ----------------------------------------------------------------- */
.card {
  background: var(--bg-card);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  position: relative;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
  outline: none;
}
.card::before {
  /* the red ALERT stamp — hidden until hover/focus */
  content: "ALERT";
  position: absolute;
  top: 14px; right: 14px;
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: .12em;
  color: var(--stamp-red);
  border: 3px solid var(--stamp-red);
  padding: .15rem .5rem;
  border-radius: 4px;
  transform: rotate(14deg) scale(.6);
  opacity: 0;
  pointer-events: none;
  z-index: 4;
  transition: opacity .2s var(--ease), transform .25s var(--ease);
  text-shadow: 0 0 1px var(--stamp-red);
}
.card:hover,
.card:focus-visible {
  transform: translate(-3px, -3px) rotate(-.4deg);
  box-shadow: 7px 7px 0 var(--ink);
  border-color: var(--red);
  z-index: 3;
}
.card:hover::before,
.card:focus-visible::before {
  opacity: .85;
  transform: rotate(14deg) scale(1);
}

/* cards filtered OUT by category nav */
.card.is-dimmed {
  opacity: .18;
  filter: grayscale(1) blur(1.5px);
  transform: scale(.97);
  pointer-events: none;
}
.card.is-dimmed::before { opacity: 0 !important; }

/* -----------------------------------------------------------------
   8. SECTION HEADS
   ----------------------------------------------------------------- */
.section { padding-block: clamp(2.5rem, 6vw, 4.5rem); position: relative; }
.section + .section { border-top: 1px solid var(--rule-soft); }

.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
  padding-bottom: .8rem;
  border-bottom: 2px solid var(--ink);
}
.section-head__title {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: 1;
  letter-spacing: -.005em;
  display: flex;
  align-items: baseline;
  gap: .4rem;
}
.section-head__title .hash {
  font-size: .7em;
  color: var(--red);
}
.section-head__sub {
  font-family: var(--font-mono);
  font-size: .76rem;
  color: var(--ink-mute);
  letter-spacing: .03em;
}
.section-head--big {
  align-items: flex-end;
  border-bottom: 2px solid var(--ink);
}
.section-head__eyebrow {
  display: block;
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .2em;
  color: var(--red);
  margin-bottom: .5rem;
}
.section-head__badge { display: flex; gap: .5rem; flex-wrap: wrap; }
.badge-pill {
  font-family: var(--font-mono);
  font-size: .72rem;
  padding: .3rem .7rem;
  border: 1px solid var(--rule);
  border-radius: 999px;
  color: var(--ink-dim);
}

/* -----------------------------------------------------------------
   9. HERO
   ----------------------------------------------------------------- */
.hero { padding-block: clamp(2rem, 5vw, 3.5rem) clamp(2.5rem,5vw,4rem); }
.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(0, 1fr);
  gap: clamp(1rem, 2.5vw, 2rem);
}
.hero__main { padding: clamp(1.2rem, 2.5vw, 2rem); }

.breaking {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--red);
  color: #fff;
  font-family: var(--font-display);
  font-size: .8rem;
  letter-spacing: .12em;
  padding: .35rem .8rem;
  border-radius: 3px;
  margin-bottom: 1.2rem;
}
.breaking__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #fff;
  animation: pulse 1s ease-in-out infinite;
}
@keyframes pulse { 50% { opacity: .25; transform: scale(.7); } }

.hero__media { position: relative; margin-bottom: 1.5rem; }
.hero__video { aspect-ratio: 16 / 9; border-radius: var(--radius); overflow: hidden; position: relative; }

/* fake autoplay video built from CSS/SVG */
.fakevid {
  position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 20%, #2a1d1d, #0a0606);
  overflow: hidden;
}
.fakevid__bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 70% 80%, rgba(225,25,25,.25), transparent 50%),
    radial-gradient(circle at 20% 30%, rgba(57,255,122,.08), transparent 40%);
}
.fakevid__chart {
  position: absolute;
  left: 8%; right: 8%; bottom: 22%; top: 30%;
  background:
    linear-gradient(180deg, transparent 60%, rgba(225,25,25,.15) 0),
    repeating-linear-gradient(90deg, transparent 0 11%, rgba(255,255,255,.05) 11% 12%),
    repeating-linear-gradient(0deg, transparent 0 19%, rgba(255,255,255,.05) 19% 20%);
  border-bottom: 1px solid rgba(225,25,25,.4);
  border-left: 1px solid rgba(225,25,25,.4);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 80' preserveAspectRatio='none'%3E%3Cpolyline points='0,10 20,12 40,8 60,55 80,62 100,70 120,30 140,74 160,76 180,78 200,79' fill='none' stroke='%23e11919' stroke-width='2' vector-effect='non-scaling-stroke'/%3E%3Cpolyline points='0,30 20,28 40,25 60,40 80,52 100,68 120,72 140,75 160,77 180,78 200,79' fill='none' stroke='%2339ff7a' stroke-width='2' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E") no-repeat;
  -webkit-mask-size: 100% 100%;
}
.fakevid__caption {
  position: absolute; top: 12px; left: 12px;
  font-family: var(--font-mono); font-size: .68rem;
  color: #fff; background: rgba(0,0,0,.6);
  padding: .2rem .5rem; border-radius: 3px;
}
.fakevid__play {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(225,25,25,.85);
  color: #fff; font-size: 1.4rem;
  display: grid; place-items: center;
  animation: pulse 2s infinite;
}
.fakevid__livechat {
  position: absolute; right: 10px; bottom: 10px;
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--font-mono); font-size: .58rem;
  max-width: 55%;
}
.fakevid__livechat span {
  background: rgba(0,0,0,.55);
  color: #cfe9d6;
  padding: .15rem .4rem;
  border-radius: 3px;
  animation: chatrise 5s linear infinite;
  opacity: 0;
}
.fakevid__livechat span:nth-child(1){ animation-delay: .3s; }
.fakevid__livechat span:nth-child(2){ animation-delay: 1.8s; }
.fakevid__livechat span:nth-child(3){ animation-delay: 3.3s; }
@keyframes chatrise {
  0% { opacity: 0; transform: translateY(8px); }
  10%,80% { opacity: 1; transform: translateY(0); }
  100% { opacity: 0; transform: translateY(-4px); }
}

/* ALERT / PENALIZED stamps on hero */
.hero__stamps { position: absolute; inset: 0; pointer-events: none; }
.stamp {
  position: absolute;
  font-family: var(--font-display);
  letter-spacing: .1em;
  border: 4px solid;
  padding: .25rem .7rem;
  border-radius: 4px;
  opacity: .9;
  transform: rotate(-8deg);
  text-shadow: 0 0 1px currentColor;
}
.stamp--alert { top: 18%; right: 6%; color: var(--stamp-red); border-color: var(--stamp-red); font-size: 1.3rem; transform: rotate(8deg); }
.stamp--penalty { bottom: 14%; left: 6%; color: var(--orange); border-color: var(--orange); font-size: 1rem; transform: rotate(-12deg); }

.hero__copy { max-width: 60ch; }
.hero__kicker {
  font-family: var(--font-mono); font-size: .72rem;
  letter-spacing: .2em; color: var(--red);
  margin-bottom: .6rem;
}
.hero__headline {
  font-family: var(--font-display);
  font-size: var(--fs-hero);
  line-height: .92;
  letter-spacing: -.015em;
  margin-bottom: 1rem;
  text-wrap: balance;
}
.hl { font-style: italic; }
.hl--red { color: var(--red); position: relative; }
.hl--red::after {
  content: ""; position: absolute; left: -.1em; right: -.1em; bottom: .06em; height: .12em;
  background: var(--green); z-index: -1; opacity: .8;
}
.hero__deck {
  font-family: var(--font-serif);
  font-size: clamp(1.05rem, 1.8vw, 1.3rem);
  line-height: 1.5;
  color: var(--ink-dim);
  margin-bottom: 1.2rem;
}
.hero__byline {
  font-family: var(--font-mono); font-size: .74rem;
  color: var(--ink-mute);
  display: flex; flex-wrap: wrap; gap: .5rem; align-items: center;
  margin-bottom: 1.4rem;
}
.hero__byline .dot { color: var(--rule); }
.hero__comments { color: var(--green); }

/* hero rail */
.hero__rail {
  display: flex; flex-direction: column; gap: 1rem;
}
.rail-title {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: .04em;
  color: var(--red);
  border-bottom: 2px solid var(--red);
  padding-bottom: .3rem;
}
.railcard { padding: 1rem 1.1rem; }
.railcard__cat { margin-bottom: .5rem; }
.railcard__h {
  font-family: var(--font-expanded);
  font-weight: 700;
  font-size: 1.05rem;
  line-height: 1.2;
  margin-bottom: .5rem;
}
.railcard__meta { font-family: var(--font-mono); font-size: .68rem; color: var(--ink-mute); }

/* category tags */
.cat-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .14em;
  padding: .2rem .5rem;
  border-radius: 3px;
  font-weight: 700;
}
.cat-tag--satire { background: var(--red); color: #fff; }
.cat-tag--news { background: var(--green); color: #082; }
.cat-tag--case { background: var(--orange); color: #1a0a00; }
.cat-tag--tools { background: var(--yellow); color: #1a1400; }
[data-theme="light"] .cat-tag--news { color: #fff; }

/* -----------------------------------------------------------------
   10. BUTTONS
   ----------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-display);
  font-size: .92rem;
  letter-spacing: .05em;
  padding: .7rem 1.3rem;
  border-radius: var(--radius);
  border: 2px solid var(--ink);
  transition: all .18s var(--ease);
  cursor: pointer;
}
.btn--primary { background: var(--red); color: #fff; border-color: var(--red); }
.btn--primary:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--ink); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--bg); transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--red); }
.btn--big { padding: .95rem 1.6rem; font-size: 1rem; }

/* -----------------------------------------------------------------
   11. HEADLINES GRID
   ----------------------------------------------------------------- */
.headlines__grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(1rem, 2vw, 1.5rem);
}
.news-card { overflow: hidden; display: flex; flex-direction: column; }
.news-card:nth-child(1) { grid-column: span 5; }
.news-card:nth-child(2) { grid-column: span 4; }
.news-card:nth-child(3) { grid-column: span 3; }
.news-card:nth-child(4) { grid-column: span 3; }
.news-card:nth-child(5) { grid-column: span 5; }
.news-card:nth-child(6) { grid-column: span 4; }

.news-card__media {
  aspect-ratio: 16 / 9;
  border-bottom: 1px solid var(--rule);
  position: relative;
  overflow: hidden;
  display: grid; place-items: center;
  background: #0a0606;
}
.media__chip {
  position: absolute; top: 8px; left: 8px;
  font-family: var(--font-mono); font-size: .62rem;
  background: rgba(0,0,0,.6); color: #fff;
  padding: .15rem .4rem; border-radius: 3px;
}

/* chart media */
.media--chart { background: linear-gradient(135deg, #120a0a, #1d1010); }
.mini-chart { width: 80%; height: auto; }
.mini-chart polyline {
  fill: none; stroke: var(--green); stroke-width: 3;
  filter: drop-shadow(0 0 4px var(--green));
}
.mini-chart circle { fill: var(--red); }

/* before / after */
.media--before-after { background: #0a0606; }
.ba { display: flex; width: 100%; height: 100%; }
.ba__before, .ba__after {
  flex: 1; display: grid; place-items: center; text-align: center;
  font-family: var(--font-mono); font-size: .72rem; letter-spacing: .1em; color: var(--ink-mute);
}
.ba__before { background: repeating-linear-gradient(135deg, #1a0d0d 0 8px, #150a0a 8px 16px); }
.ba__before b { display:block; font-family: var(--font-display); font-size: 1.6rem; color: var(--red); margin-top: .3rem; }
.ba__after { background: linear-gradient(135deg, #0d1a10, #12241a); }
.ba__after b { display:block; font-family: var(--font-display); font-size: 1.6rem; color: var(--green); margin-top: .3rem; }

/* meme media */
.media--meme { background: #0a0606; }
.meme {
  display: flex; flex-direction: column; justify-content: space-between;
  width: 100%; height: 100%; padding: .6rem .5rem;
  text-align: center;
}
.meme span {
  font-family: var(--font-display); font-size: .85rem; line-height: 1; letter-spacing: .02em;
  color: #fff;
  text-shadow: -2px -2px 0 #000, 2px -2px 0 #000, -2px 2px 0 #000, 2px 2px 0 #000;
}
.meme__mid { font-size: 1.3rem; color: var(--yellow); padding: .5rem 0; }
.meme__bot { color: var(--green); }

/* tool screenshot */
.media--tool { background: #0a0606; padding: .8rem; }
.toolshot { width: 100%; }
.toolshot__bar { display:flex; gap:5px; margin-bottom:.6rem; }
.toolshot__bar span { width:9px; height:9px; border-radius:50%; background:#3a2222; }
.toolshot__rows { font-family: var(--font-mono); font-size: .6rem; }
.toolshot__rows div {
  display:flex; justify-content:space-between; padding:.25rem 0;
  border-bottom: 1px dashed #2a1818; color: var(--ink-dim);
}
.toolshot__rows b { color: var(--green); font-weight: 600; }
.toolshot__rows i { color: var(--yellow); font-style: normal; }

/* serp shot */
.media--serp { background: #0a0606; padding: .8rem; font-family: var(--font-mono); font-size: .58rem; }
.serpshot > div { padding:.3rem .4rem; border-radius:3px; margin-bottom:.3rem; }
.serpshot__ad { background: #1d1010; color: var(--ink-mute); border:1px solid #3a2222; }
.serpshot__ai { background: #11261a; color: var(--green); border:1px solid #1fa84f; }
.serpshot__ai span { color: var(--ink-dim); }
.serpshot__res { background: #150e0e; color: var(--ink-dim); }

/* panic face media */
.media--panic { background: radial-gradient(circle at 50% 40%, #2a1414, #0a0606); }
.panic-face {
  font-size: 3.5rem; text-align: center; line-height: 1;
}
.panic-face small {
  display:block; font-family: var(--font-mono); font-size:.55rem;
  color: var(--ink-mute); letter-spacing:.1em; margin-top:.6rem;
}

/* news card body */
.news-card__body { padding: 1rem 1.1rem 1.2rem; display:flex; flex-direction:column; gap:.6rem; flex: 1; }
.news-card__h {
  font-family: var(--font-expanded);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: 1.15;
  letter-spacing: -.01em;
}
.news-card__excerpt { font-family: var(--font-serif); font-size: .92rem; color: var(--ink-dim); line-height: 1.45; }
.news-card__meta {
  margin-top: auto;
  display:flex; justify-content:space-between;
  font-family: var(--font-mono); font-size: .66rem; color: var(--ink-mute);
  padding-top: .5rem; border-top: 1px dashed var(--rule);
}

.headlines__loadmore { text-align: center; margin-top: 2rem; }

/* -----------------------------------------------------------------
   12. PENALIZED AD BANNER
   ----------------------------------------------------------------- */
.ad-banner {
  position: relative;
  border-block: 2px dashed var(--rule);
  background:
    repeating-linear-gradient(45deg, var(--bg-2) 0 20px, var(--bg) 20px 40px);
  overflow: hidden;
  transition: max-height .8s var(--ease), opacity .6s var(--ease);
  max-height: 200px;
}
.ad-banner.is-penalized {
  max-height: 64px;
}
.ad-banner.is-penalized .ad-banner__inner { opacity: 0; transform: translateY(-20px); }
.ad-banner__inner {
  padding: 1.2rem var(--gut);
  display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap;
  transition: opacity .4s var(--ease), transform .4s var(--ease);
}
.ad-banner__tag {
  font-family: var(--font-mono); font-size: .62rem; letter-spacing: .14em;
  color: var(--ink-mute); border:1px solid var(--rule); padding:.2rem .5rem; border-radius:3px;
}
.ad-banner__content { font-family: var(--font-serif); font-size: 1.1rem; flex: 1; }
.ad-banner__content strong { color: var(--yellow); font-family: var(--font-display); }
.ad-banner__x { font-size: 1.4rem; color: var(--ink-mute); padding: 0 .4rem; }
.ad-banner__x:hover { color: var(--red); }
.ad-banner__penalty {
  position: absolute; inset: 0;
  display: none; place-items: center;
  font-family: var(--font-display); font-size: 1rem; letter-spacing: .08em;
  color: var(--orange);
  background: repeating-linear-gradient(45deg, #1a0d0d 0 20px, #0f0808 20px 40px);
}
.ad-banner.is-penalized .ad-banner__penalty { display: grid; }

/* -----------------------------------------------------------------
   13. THE SERP REPORT (long-form)
   ----------------------------------------------------------------- */
.serp-report { background: var(--bg-2); }
.report-layout {
  display: grid;
  grid-template-columns: 220px minmax(0,1fr);
  gap: clamp(1.5rem, 3vw, 3rem);
  align-items: start;
}

/* sticky SEO score meter */
.scoremeter {
  position: sticky;
  top: 90px;
  background: var(--bg-card);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 1.2rem 1rem;
  text-align: center;
}
.scoremeter__head {
  font-family: var(--font-mono); font-size: .62rem; letter-spacing: .14em;
  color: var(--ink-mute); margin-bottom: .8rem;
}
.scoremeter__ring { position: relative; width: 130px; height: 130px; margin: 0 auto .6rem; }
.ring-svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.ring-bg { fill: none; stroke: var(--rule); stroke-width: 9; }
.ring-fg {
  fill: none; stroke: var(--red); stroke-width: 9; stroke-linecap: round;
  stroke-dasharray: 326.7; /* 2*pi*52 */
  stroke-dashoffset: 189; /* ~42% */
  transition: stroke-dashoffset .5s var(--ease), stroke .5s var(--ease);
}
.scoremeter__num {
  position: absolute; inset: 0; display: grid; place-items: center;
  font-family: var(--font-display); font-size: 2.6rem; line-height: 1;
}
.scoremeter__label {
  font-family: var(--font-display); font-size: .85rem; letter-spacing: .12em;
  color: var(--red); margin-bottom: 1rem;
}
.scoremeter__stats { list-style: none; text-align: left; margin-bottom: .8rem; }
.scoremeter__stats li {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: .68rem; color: var(--ink-mute);
  padding: .25rem 0; border-bottom: 1px dashed var(--rule);
}
.scoremeter__stats b { color: var(--ink); font-weight: 700; }
.scoremeter__note { font-family: var(--font-mono); font-size: .58rem; color: var(--ink-mute); font-style: italic; }

/* report body */
.report-body { display: flex; flex-direction: column; gap: 1.5rem; min-width: 0; }
.report-card { padding: clamp(1.3rem, 3vw, 2.2rem); }
.report-card__kicker {
  font-family: var(--font-mono); font-size: .68rem; letter-spacing: .16em;
  color: var(--red); margin-bottom: .7rem;
}
.report-card__title {
  font-family: var(--font-display); font-size: clamp(1.6rem, 3.5vw, 2.6rem);
  line-height: 1; letter-spacing: -.01em; margin-bottom: .8rem; text-wrap: balance;
}
.report-card__byline {
  font-family: var(--font-mono); font-size: .72rem; color: var(--ink-mute);
  padding-bottom: 1rem; border-bottom: 1px solid var(--rule); margin-bottom: 1.2rem;
}
.report-card__lead {
  font-family: var(--font-serif); font-size: 1.15rem; line-height: 1.6;
  color: var(--ink); margin-bottom: 1.3rem;
}
.report-card p {
  font-family: var(--font-serif); font-size: 1.02rem; line-height: 1.65;
  color: var(--ink-dim); margin-bottom: 1.2rem;
}
.report-card p strong { color: var(--green); }

/* charts */
.chart-block {
  background: var(--bg-card-2);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 1.2rem;
  margin: 1.5rem 0;
}
.chart-block__title {
  font-family: var(--font-mono); font-size: .72rem; letter-spacing: .05em;
  color: var(--ink-dim); margin-bottom: .8rem;
}
.chart-block__viz { width: 100%; }
.big-chart { width: 100%; height: auto; }
.big-chart .grid line { stroke: var(--rule); stroke-width: 1; }
.big-chart .line-vol { fill: none; stroke: var(--red); stroke-width: 2.5; filter: drop-shadow(0 0 3px var(--red)); }
.big-chart .line-ref { fill: none; stroke: var(--orange); stroke-width: 2.5; stroke-dasharray: 5 4; }
.chart-legend { font-family: var(--font-mono); font-size: 9px; fill: var(--ink-mute); }
.chart-legend--orange { fill: var(--orange); }
.chart-block__cap {
  font-family: var(--font-serif); font-style: italic; font-size: .85rem;
  color: var(--ink-mute); margin-top: .8rem;
}

/* bar chart */
.barchart { display: flex; flex-direction: column; gap: .6rem; }
.bar { display: grid; grid-template-columns: 180px 1fr; align-items: center; gap: .8rem; }
.bar__label { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-dim); text-align: right; }
.bar__fill {
  height: 22px; background: var(--bg-2); border-radius: 3px; position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: flex-end; padding-right: .5rem;
}
.bar__fill::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--w);
  background: linear-gradient(90deg, var(--red-deep), var(--red));
  transition: width 1s var(--ease);
}
.bar__fill b { position: relative; font-family: var(--font-mono); font-size: .7rem; color: #fff; }
.bar__fill--me::before { background: linear-gradient(90deg, var(--green-dim), var(--green)); }
.bar__fill--me b { color: #062; }

/* pull quote */
.report-pull {
  border-left: 5px solid var(--red);
  padding: .5rem 0 .5rem 1.5rem;
  margin: 1.8rem 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.2rem, 2.5vw, 1.7rem);
  line-height: 1.35;
  color: var(--ink);
}
.report-pull cite {
  display: block; font-style: normal;
  font-family: var(--font-mono); font-size: .72rem; color: var(--ink-mute);
  margin-top: .8rem;
}

.report-card__inline-tags { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom: 1.2rem; }
.report-card__inline-tags span {
  font-family: var(--font-mono); font-size: .68rem; color: var(--green);
  background: rgba(57,255,122,.08); border:1px solid rgba(57,255,122,.25);
  padding: .2rem .5rem; border-radius: 3px;
}
.report-card__cta {
  display: inline-block;
  font-family: var(--font-display); font-size: .95rem; letter-spacing: .04em;
  color: var(--red); border-bottom: 2px solid var(--red); padding-bottom: .15rem;
  margin-top: .5rem;
  transition: letter-spacing .2s var(--ease);
}
.report-card__cta:hover { letter-spacing: .1em; }

/* -----------------------------------------------------------------
   14. KEYWORD GRAVEYARD
   ----------------------------------------------------------------- */
.graveyard {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(225,25,25,.06), transparent 60%);
}
.graves {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(1.5rem, 3vw, 2.5rem) clamp(1rem, 2vw, 1.5rem);
}
.grave { display: flex; flex-direction: column; align-items: center; gap: .8rem; }
.grave__stone {
  width: 100%; max-width: 240px;
  background: linear-gradient(180deg, #6b6258, #4a423a);
  color: #e9e3d6;
  border-radius: 140px 140px 8px 8px;
  padding: 1.4rem 1rem 1.1rem;
  text-align: center;
  position: relative;
  box-shadow:
    inset 0 -8px 16px rgba(0,0,0,.4),
    inset 0 2px 4px rgba(255,255,255,.15),
    4px 8px 16px rgba(0,0,0,.4);
  font-family: var(--font-serif);
  transition: transform .3s var(--ease);
}
.grave:hover .grave__stone { transform: translateY(-6px) rotate(-1deg); }
.grave__rip { font-family: var(--font-display); font-size: 1rem; letter-spacing: .15em; opacity: .8; }
.grave__name { font-family: var(--font-display); font-size: 1.2rem; letter-spacing: .02em; margin: .4rem 0; line-height: 1; }
.grave__years { font-family: var(--font-mono); font-size: .68rem; opacity: .7; letter-spacing: .05em; }
.grave__epitaph { font-style: italic; font-size: .82rem; margin-top: .7rem; opacity: .85; line-height: 1.3; }
.grave__stone--moss { background: linear-gradient(180deg, #5a6147, #3d4233); }
.grave__stone--crack {
  background: linear-gradient(135deg, #5a5248 0%, #2a2218 50%, #5a5248 100%);
}
.grave__stone--crack::after {
  content: ""; position: absolute; top: 20px; bottom: 30px; left: 48%;
  width: 3px; background: #1a140e; transform: rotate(4deg);
  box-shadow: 8px 30px 0 -1px #1a140e, -6px 60px 0 -1px #1a140e;
}
.grave__stone--fresh {
  background: linear-gradient(180deg, #7a6a52, #5a4a3a);
}
.grave__stone--fresh .grave__rip { color: var(--green); }
.grave__cause {
  font-family: var(--font-mono); font-size: .72rem; color: var(--ink-mute); text-align: center;
}
.grave__cause b { color: var(--red); }

/* -----------------------------------------------------------------
   15. TOOL & GUIDE HUB
   ----------------------------------------------------------------- */
.toolhub__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}
.guide { padding: 1.5rem; display: flex; flex-direction: column; gap: .8rem; }
.guide__h { font-family: var(--font-expanded); font-weight: 800; font-size: 1.35rem; line-height: 1.1; }
.guide__d { font-family: var(--font-serif); font-size: .95rem; color: var(--ink-dim); line-height: 1.45; }

.compare-table { margin: .5rem 0; font-family: var(--font-mono); font-size: .72rem; }
.compare-table__head, .compare-table__row {
  display: grid; grid-template-columns: 1.2fr 1fr .6fr .8fr;
  gap: .5rem; padding: .4rem 0; border-bottom: 1px dashed var(--rule);
  align-items: center;
}
.compare-table__head { color: var(--ink-mute); letter-spacing: .06em; font-size: .62rem; border-bottom: 1px solid var(--rule); }
.verdict { font-family: var(--font-display); font-size: .72rem; letter-spacing: .05em; text-align: center; padding: .15rem .3rem; border-radius: 3px; }
.verdict--good { background: rgba(57,255,122,.15); color: var(--green); }
.verdict--bad { background: rgba(225,25,25,.15); color: var(--red); }

.checklist { list-style: none; display:flex; flex-direction: column; gap: .35rem; margin: .5rem 0; }
.checklist li {
  font-family: var(--font-mono); font-size: .78rem; color: var(--ink-dim);
  padding-left: 1.4rem; position: relative;
}
.checklist li::before { content: "☐"; position: absolute; left: 0; color: var(--ink-mute); }
.checklist li.done { color: var(--ink); }
.checklist li.done::before { content: "☑"; color: var(--green); }

.timeline { display: flex; flex-direction: column; gap: .3rem; margin: .5rem 0; border-left: 2px solid var(--orange); padding-left: 1rem; }
.timeline__item { font-family: var(--font-mono); font-size: .76rem; color: var(--ink-dim); }
.timeline__item b { color: var(--orange); margin-right: .5rem; }

.guide__link {
  margin-top: auto; font-family: var(--font-display); font-size: .85rem; letter-spacing: .04em;
  color: var(--red); align-self: flex-start;
  border-bottom: 2px solid var(--red); padding-bottom: .1rem;
}
.guide__link:hover { letter-spacing: .08em; }

/* -----------------------------------------------------------------
   16. MEME GALLERY
   ----------------------------------------------------------------- */
.memes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
}
.meme-thumb {
  aspect-ratio: 1;
  background: linear-gradient(135deg, #1a1010, #0a0606);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .4rem;
  padding: .8rem;
  transition: all .2s var(--ease);
  cursor: zoom-in;
}
.meme-thumb:hover { border-color: var(--red); transform: scale(1.03) rotate(-1deg); box-shadow: 4px 4px 0 var(--ink); }
.meme-thumb__face { font-size: 2.4rem; }
.meme-thumb__cap { font-family: var(--font-display); font-size: .68rem; letter-spacing: .05em; color: var(--ink-dim); text-align: center; }

/* lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0,0,0,.92);
  display: none; place-items: center;
  padding: 2rem;
}
.lightbox.is-open { display: grid; animation: fadein .25s var(--ease); }
@keyframes fadein { from { opacity: 0; } }
.lightbox__panel {
  background: var(--bg-card);
  border: 2px solid var(--red);
  border-radius: var(--radius-lg);
  padding: 2rem;
  max-width: 500px;
  position: relative;
  box-shadow: 8px 8px 0 var(--ink);
}
.lightbox__close {
  position: absolute; top: .5rem; right: .8rem;
  font-size: 1.8rem; color: var(--ink-mute); line-height: 1;
}
.lightbox__close:hover { color: var(--red); }
.lightbox__meme {
  background: #000; border-radius: var(--radius); padding: 1.5rem;
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
  text-align: center;
}
.lightbox__face { font-size: 5rem; }
.lightbox__cap {
  font-family: var(--font-display); font-size: 1.4rem; letter-spacing: .03em;
  color: #fff;
  text-shadow: -2px -2px 0 #000, 2px -2px 0 #000, -2px 2px 0 #000, 2px 2px 0 #000;
}
.lightbox__caption {
  margin-top: 1rem; font-family: var(--font-serif); font-style: italic;
  color: var(--ink-dim); text-align: center;
}

/* -----------------------------------------------------------------
   17. NEWSLETTER
   ----------------------------------------------------------------- */
.newsletter {
  background: var(--red-deep);
  background-image:
    radial-gradient(circle at 10% 20%, rgba(57,255,122,.1), transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(255,209,10,.1), transparent 40%);
  color: #fff;
  padding-block: clamp(2.5rem, 6vw, 4.5rem);
  border-top: 4px solid var(--ink);
}
.newsletter__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: center;
}
.newsletter__eyebrow { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .2em; color: var(--yellow); margin-bottom: .6rem; }
.newsletter__h { font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1; margin-bottom: 1rem; }
.newsletter__d { font-family: var(--font-serif); font-size: 1.1rem; line-height: 1.5; color: rgba(255,255,255,.85); margin-bottom: 1.2rem; }
.newsletter__bullets { list-style: none; display: flex; flex-direction: column; gap: .4rem; }
.newsletter__bullets li { font-family: var(--font-mono); font-size: .82rem; color: rgba(255,255,255,.9); }

.newsletter__form { display: flex; flex-direction: column; gap: 1rem; }
.newsletter__field { position: relative; }
.newsletter__field input {
  width: 100%;
  background: #1a0808;
  border: 2px solid #4a1414;
  border-radius: var(--radius);
  color: #fff;
  padding: 1.1rem 1rem;
  font-family: var(--font-mono);
  font-size: 1rem;
  outline: none;
  transition: border-color .2s var(--ease);
}
.newsletter__field input:focus { border-color: var(--yellow); }
.newsletter__placeholder {
  position: absolute;
  left: 1.1rem; top: 50%; transform: translateY(-50%);
  font-family: var(--font-mono);
  color: rgba(255,255,255,.4);
  pointer-events: none;
  transition: opacity .2s var(--ease);
}
.newsletter__field input:focus + .newsletter__placeholder,
.newsletter__field input:not(:placeholder-shown) + .newsletter__placeholder { opacity: 0; }
.newsletter__field input::placeholder { color: transparent; }

.newsletter .btn--primary { background: var(--yellow); color: #1a1400; border-color: var(--yellow); align-self: flex-start; }
.newsletter .btn--primary:hover { box-shadow: 4px 4px 0 #fff; }
.newsletter__fineprint { font-family: var(--font-mono); font-size: .68rem; color: rgba(255,255,255,.5); }
.newsletter__success {
  font-family: var(--font-mono); font-size: .85rem;
  color: var(--green); background: rgba(57,255,122,.1);
  border: 1px solid var(--green);
  padding: .8rem 1rem; border-radius: var(--radius);
}

/* -----------------------------------------------------------------
   18. FOOTER
   ----------------------------------------------------------------- */
.footer { background: #0a0606; color: var(--ink-dim); padding-top: 3rem; border-top: 1px solid var(--rule); }
.footer__inner {
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: clamp(2rem, 4vw, 3rem);
  padding-bottom: 2rem;
}
.footer__logo { font-family: var(--font-display); font-size: 2rem; color: var(--ink); letter-spacing: -.01em; }
.footer__tag { font-family: var(--font-serif); font-size: .9rem; margin-top: .6rem; max-width: 36ch; line-height: 1.5; }
.footer__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.footer__cols h4 { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .14em; color: var(--red); margin-bottom: .8rem; }
.footer__cols a { display: block; font-size: .85rem; padding: .2rem 0; color: var(--ink-dim); transition: color .15s; }
.footer__cols a:hover { color: var(--green); }
.footer__legal {
  border-top: 1px solid var(--rule);
  padding: 1.2rem var(--gut);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: .6rem;
  max-width: var(--wrap); margin-inline: auto;
  font-family: var(--font-mono); font-size: .66rem; color: var(--ink-mute);
}
.footer__discl { color: var(--red); }

/* -----------------------------------------------------------------
   19. REPRINT ANIMATION OVERLAY
   ----------------------------------------------------------------- */
.reprint-overlay {
  position: fixed; inset: 0; z-index: 9500;
  background: rgba(10,6,6,.7);
  display: none; place-items: center;
  pointer-events: none;
}
.reprint-overlay.is-running { display: grid; }
.reprint-overlay__paper {
  background: var(--bg-card);
  border: 2px solid var(--ink);
  padding: 2rem 3rem;
  font-family: var(--font-display);
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
  box-shadow: 8px 8px 0 var(--red);
  animation: reprintShake .6s var(--ease);
}
.reprint-overlay__bar {
  width: 200px; height: 18px; background: var(--bg-2); border-radius: 3px; overflow: hidden; position: relative;
}
.reprint-overlay__bar::after {
  content: ""; position: absolute; inset: 0; width: 0;
  background: repeating-linear-gradient(45deg, var(--red) 0 10px, var(--red-deep) 10px 20px);
  animation: reprintBar .6s var(--ease) forwards;
}
.reprint-overlay__txt { letter-spacing: .08em; color: var(--ink); }
@keyframes reprintBar { to { width: 100%; } }
@keyframes reprintShake {
  0%,100% { transform: translate(0,0) rotate(0); }
  25% { transform: translate(-2px,1px) rotate(-.5deg); }
  75% { transform: translate(2px,-1px) rotate(.5deg); }
}

/* -----------------------------------------------------------------
   20. REVEAL ON SCROLL
   ----------------------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }

/* -----------------------------------------------------------------
   21. INTERNAL PAGE: ARTICLE (single satirical article)
   ----------------------------------------------------------------- */
.article-hero {
  padding-block: clamp(1.5rem, 4vw, 2.5rem) 1rem;
  border-bottom: 1px solid var(--rule-soft);
}
.article-breadcrumb {
  font-family: var(--font-mono); font-size: .7rem; letter-spacing: .05em;
  color: var(--ink-mute); margin-bottom: 1rem;
}
.article-breadcrumb a:hover { color: var(--red); }
.article-breadcrumb .sep { margin-inline: .4rem; color: var(--rule); }
.article-cat { display:inline-block; margin-bottom: .9rem; }

.article-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 4.5rem);
  line-height: .95;
  letter-spacing: -.015em;
  margin-bottom: 1rem;
  text-wrap: balance;
  max-width: 22ch;
}
.article-deck {
  font-family: var(--font-serif);
  font-size: clamp(1.1rem, 2vw, 1.45rem);
  line-height: 1.45;
  color: var(--ink-dim);
  margin-bottom: 1.5rem;
  max-width: 60ch;
}
.article-byline {
  display: flex; flex-wrap: wrap; align-items: center; gap: .8rem;
  font-family: var(--font-mono); font-size: .76rem; color: var(--ink-mute);
  padding-block: 1rem; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
}
.authorchip { display: inline-flex; align-items: center; gap: .6rem; }
.authorchip__avatar {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--red-deep); color: #fff;
  display: grid; place-items: center;
  font-family: var(--font-display); font-size: .85rem;
  border: 2px solid var(--ink);
}
.authorchip b { color: var(--ink); }
.byline-dot { color: var(--rule); }
.byline-meta { color: var(--ink-mute); }

.article-feature {
  margin: clamp(1.5rem, 4vw, 2.5rem) 0;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  background: radial-gradient(circle at 30% 20%, #2a1d1d, #0a0606);
  border: 1px solid var(--rule);
}
.article-feature__caption {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.8));
  padding: 2rem 1rem .8rem;
  font-family: var(--font-mono); font-size: .68rem; color: var(--ink-dim);
}

/* article layout: body + sticky share rail */
.article-layout {
  display: grid;
  grid-template-columns: 56px minmax(0,1fr) 220px;
  gap: clamp(1.5rem, 3vw, 3rem);
  align-items: start;
  padding-block: clamp(1.5rem, 4vw, 2.5rem);
}

/* sticky share rail */
.sharerail {
  position: sticky; top: 90px;
  display: flex; flex-direction: column; gap: .6rem; align-items: center;
}
.sharerail__label {
  font-family: var(--font-mono); font-size: .56rem; letter-spacing: .14em;
  color: var(--ink-mute); writing-mode: vertical-rl; margin-bottom: .4rem;
}
.sharebtn {
  width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid var(--rule); background: var(--bg-card);
  display: grid; place-items: center; font-size: 1rem;
  transition: all .18s var(--ease);
}
.sharebtn:hover { border-color: var(--red); transform: translateY(-2px); box-shadow: 0 4px 0 var(--red); }
.sharebtn--copy { font-family: var(--font-mono); font-size: .7rem; }
/* share-intent links (a.sharebtn) inherit the circle button look */
a.sharebtn { color: inherit; text-decoration: none; }
a.sharebtn:hover { color: var(--red); }

/* article body prose */
.prose { max-width: 68ch; }
.prose > * { margin-bottom: 1.3rem; }
.prose p {
  font-family: var(--font-serif); font-size: 1.12rem; line-height: 1.7;
  color: var(--ink);
}
.prose p:first-of-type::first-letter {
  font-family: var(--font-display); font-size: 3.6rem; line-height: .8;
  float: left; padding: .25rem .5rem .1rem 0; color: var(--red);
}
.prose h2 {
  font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.1rem);
  line-height: 1.05; margin-top: 2rem; margin-bottom: 1rem;
  letter-spacing: -.005em;
}
.prose h2::before { content: "§ "; color: var(--red); }
.prose h3 {
  font-family: var(--font-expanded); font-weight: 800;
  font-size: 1.25rem; margin-top: 1.5rem; margin-bottom: .7rem;
}
.prose blockquote {
  border-left: 5px solid var(--red);
  padding: .6rem 0 .6rem 1.5rem;
  font-family: var(--font-serif); font-style: italic;
  font-size: 1.3rem; line-height: 1.4; color: var(--ink);
}
.prose blockquote cite {
  display: block; font-style: normal; margin-top: .6rem;
  font-family: var(--font-mono); font-size: .74rem; color: var(--ink-mute);
}
.prose ul, .prose ol { padding-left: 1.4rem; font-family: var(--font-serif); font-size: 1.1rem; line-height: 1.7; }
.prose ul li, .prose ol li { margin-bottom: .4rem; }
.prose a { color: var(--green); border-bottom: 1px solid var(--green-dim); }
.prose a:hover { color: var(--red); border-color: var(--red); }
.prose strong { color: var(--ink); background: linear-gradient(transparent 60%, rgba(57,255,122,.25) 0); }
.prose em { color: var(--ink-dim); }
.prose .inline-meme {
  margin: 2rem 0; text-align: center;
  background: #000; border: 1px solid var(--rule); border-radius: var(--radius); padding: 1.5rem;
}
.prose .inline-meme .im-text {
  display:block; font-family: var(--font-display); font-size: 1.5rem; color: #fff;
  text-shadow: -2px -2px 0 #000, 2px -2px 0 #000, -2px 2px 0 #000, 2px 2px 0 #000;
}
.prose .inline-meme .im-cap {
  display:block; font-family: var(--font-mono); font-size: .66rem; color: var(--ink-mute); margin-top: .8rem;
}

/* article inline ad that gets penalized */
.inline-ad {
  margin: 2rem 0; padding: 1rem; border: 1px dashed var(--rule);
  background: repeating-linear-gradient(45deg, var(--bg-2) 0 14px, var(--bg) 14px 28px);
  font-family: var(--font-mono); font-size: .76rem; color: var(--ink-mute); text-align: center;
  position: relative; overflow: hidden; transition: max-height .6s var(--ease), opacity .4s var(--ease);
  max-height: 120px;
}
.inline-ad.is-penalized { max-height: 36px; opacity: .5; }
.inline-ad.is-penalized .inline-ad__content { display: none; }
.inline-ad.is-penalized::after { content: "⚠ AD PENALIZED"; color: var(--orange); }
.inline-ad__tag { display:block; font-size: .58rem; letter-spacing: .14em; margin-bottom: .4rem; }
.inline-ad__content strong { color: var(--yellow); }

/* tags row + share bottom */
.article-footer-row {
  display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; align-items: center;
  padding-block: 1.5rem; border-top: 2px solid var(--ink); margin-top: 2rem;
}
.tagrow { display: flex; flex-wrap: wrap; gap: .5rem; }
.tagrow a {
  font-family: var(--font-mono); font-size: .72rem; color: var(--green);
  background: rgba(57,255,122,.08); border: 1px solid rgba(57,255,122,.25);
  padding: .25rem .55rem; border-radius: 3px;
}
.tagrow a:hover { background: var(--green); color: #062; }

/* author bio card */
.authorbox {
  display: grid; grid-template-columns: auto 1fr; gap: 1.2rem;
  background: var(--bg-card); border: 1px solid var(--rule); border-radius: var(--radius);
  padding: 1.4rem; margin-top: 2rem;
}
.authorbox__avatar {
  width: 70px; height: 70px; border-radius: 50%;
  background: var(--red-deep); color: #fff; display: grid; place-items: center;
  font-family: var(--font-display); font-size: 1.6rem; border: 3px solid var(--ink);
}
.authorbox__name { font-family: var(--font-display); font-size: 1.3rem; }
.authorbox__role { font-family: var(--font-mono); font-size: .7rem; color: var(--red); letter-spacing: .06em; margin-bottom: .5rem; }
.authorbox__bio { font-family: var(--font-serif); font-size: .95rem; color: var(--ink-dim); line-height: 1.5; }
.authorbox__stats { display:flex; gap: 1rem; margin-top: .6rem; font-family: var(--font-mono); font-size: .68rem; color: var(--ink-mute); }

/* comments */
.comments { margin-top: clamp(2rem, 4vw, 3rem); }
.comments__head {
  font-family: var(--font-display); font-size: 1.5rem; margin-bottom: 1rem;
  display: flex; align-items: center; gap: .6rem;
}
.comments__list { display: flex; flex-direction: column; }
.comments__count { font-family: var(--font-mono); font-size: .8rem; color: var(--red); }
.comment {
  display: grid; grid-template-columns: auto 1fr; gap: .9rem;
  padding: 1rem 0; border-bottom: 1px solid var(--rule-soft);
}
.comment__avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--bg-card-2); display: grid; place-items: center; font-size: 1.2rem;
  border: 1px solid var(--rule);
}
.comment__meta { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-mute); margin-bottom: .3rem; }
.comment__meta b { color: var(--ink); }
.comment__badge { color: var(--green); font-size: .62rem; border:1px solid var(--green-dim); padding: .05rem .3rem; border-radius: 3px; margin-left: .4rem; }
.comment__text { font-family: var(--font-serif); font-size: .98rem; line-height: 1.55; color: var(--ink-dim); }
.comment__actions { margin-top: .4rem; font-family: var(--font-mono); font-size: .66rem; color: var(--ink-mute); }
.comment__actions span { margin-right: 1rem; cursor: pointer; }
.comment__actions span:hover { color: var(--red); }
.comment-form {
  margin-top: 1.5rem; display: flex; flex-direction: column; gap: .8rem;
}
.comment-form textarea {
  width: 100%; min-height: 90px; resize: vertical;
  background: var(--bg-card); border: 1px solid var(--rule); border-radius: var(--radius);
  color: var(--ink); padding: .9rem; font-family: var(--font-serif); font-size: 1rem;
  outline: none; transition: border-color .2s var(--ease);
}
.comment-form textarea:focus { border-color: var(--red); }
.comment-form__hint { font-family: var(--font-mono); font-size: .68rem; color: var(--ink-mute); }
.comment-form__hint b { color: var(--red); }

/* read-next */
.readnext { margin-top: clamp(2.5rem, 5vw, 4rem); }
.readnext__head { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: 1.2rem; border-bottom: 2px solid var(--ink); padding-bottom: .5rem; }
.readnext__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }

/* -----------------------------------------------------------------
   21b. HOMEPAGE: TRENDING NOW (real-chatter satirized)
   ----------------------------------------------------------------- */
.trending {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(225,25,25,.07), transparent 55%);
}
.trending__featured {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: clamp(1rem, 2vw, 2rem);
  align-items: stretch;
}
.trending__lead .news-card__h { font-size: clamp(1.4rem, 2.8vw, 2rem); line-height: 1.05; }
.trending__rail { display: flex; flex-direction: column; gap: 1rem; }
.trending__grid .news-card:nth-child(n) { grid-column: span 4; }

/* -----------------------------------------------------------------
   22. INTERNAL PAGE: SERP REPORT (long-form data)
   ----------------------------------------------------------------- */
.report-page { padding-block: clamp(1.5rem, 4vw, 2.5rem); }
.report-page__hero {
  border-bottom: 1px solid var(--rule); padding-bottom: 1.5rem; margin-bottom: 1.5rem;
}
.report-page__eyebrow { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .2em; color: var(--red); margin-bottom: .7rem; }
.report-page__title {
  font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.6rem); line-height: .98;
  letter-spacing: -.01em; max-width: 24ch; margin-bottom: 1rem; text-wrap: balance;
}
.report-page__deck { font-family: var(--font-serif); font-size: clamp(1.1rem, 1.8vw, 1.35rem); line-height: 1.5; color: var(--ink-dim); max-width: 62ch; }
.report-page__meta {
  display: flex; flex-wrap: wrap; gap: 1rem; align-items: center;
  margin-top: 1.2rem; font-family: var(--font-mono); font-size: .74rem; color: var(--ink-mute);
}
.report-page__meta .badge-pill { color: var(--ink-dim); }

/* layout: TOC + body + score meter */
.report-page__layout {
  display: grid;
  grid-template-columns: 240px minmax(0,1fr) 220px;
  gap: clamp(1.5rem, 3vw, 3rem);
  align-items: start;
}
.toc {
  position: sticky; top: 90px;
  font-family: var(--font-mono); font-size: .76rem;
}
.toc__title {
  font-family: var(--font-display); font-size: .85rem; letter-spacing: .1em;
  color: var(--red); border-bottom: 2px solid var(--red); padding-bottom: .3rem; margin-bottom: .8rem;
}
.toc ul { list-style: none; display: flex; flex-direction: column; gap: .15rem; }
.toc a {
  display: block; padding: .35rem .5rem; border-left: 2px solid var(--rule);
  color: var(--ink-mute); line-height: 1.3; transition: all .15s var(--ease);
}
.toc a:hover { color: var(--ink); border-left-color: var(--orange); }
.toc a.is-active { color: var(--green); border-left-color: var(--green); background: rgba(57,255,122,.06); font-weight: 700; }

.report-prose { max-width: 72ch; }
.report-prose > * { margin-bottom: 1.4rem; }
.report-prose p { font-family: var(--font-serif); font-size: 1.08rem; line-height: 1.72; color: var(--ink); }
.report-prose h2 {
  font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.2rem); line-height: 1.05;
  margin-top: 2.5rem; margin-bottom: 1rem; scroll-margin-top: 100px;
}
.report-prose h2 .h2-num { color: var(--red); margin-right: .5rem; }
.report-prose h3 { font-family: var(--font-expanded); font-weight: 800; font-size: 1.2rem; margin-top: 1.6rem; }
.report-prose strong { color: var(--green); }
.report-prose ul, .report-prose ol { padding-left: 1.4rem; font-family: var(--font-serif); font-size: 1.05rem; line-height: 1.7; }

/* methodology box */
.methodology {
  background: var(--bg-card); border: 1px solid var(--rule); border-left: 5px solid var(--orange);
  border-radius: var(--radius); padding: 1.3rem 1.5rem; margin: 2rem 0;
}
.methodology__title { font-family: var(--font-display); font-size: 1rem; letter-spacing: .05em; color: var(--orange); margin-bottom: .6rem; }
.methodology p { font-family: var(--font-mono); font-size: .78rem; line-height: 1.6; color: var(--ink-dim); }

/* key takeaway callout */
.takeaway {
  background: linear-gradient(135deg, rgba(57,255,122,.08), rgba(57,255,122,.02));
  border: 1px solid var(--green-dim); border-radius: var(--radius);
  padding: 1.3rem 1.5rem; margin: 2rem 0; position: relative;
}
.takeaway__label { font-family: var(--font-display); font-size: .8rem; letter-spacing: .12em; color: var(--green); margin-bottom: .5rem; }
.takeaway p { font-family: var(--font-serif); font-size: 1.1rem; line-height: 1.5; color: var(--ink); margin: 0; }

/* -----------------------------------------------------------------
   23. INTERNAL PAGE: SECTION ARCHIVE
   ----------------------------------------------------------------- */
.archive { padding-block: clamp(1.5rem, 4vw, 2.5rem); }
.archive__head { margin-bottom: clamp(1.5rem, 3vw, 2rem); }
.archive__kicker { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .2em; color: var(--red); margin-bottom: .6rem; }
.archive__title { font-family: var(--font-display); font-size: clamp(2.5rem, 7vw, 5rem); line-height: .92; letter-spacing: -.015em; }
.archive__desc { font-family: var(--font-serif); font-size: 1.15rem; line-height: 1.5; color: var(--ink-dim); max-width: 60ch; margin-top: .8rem; }

.archive__featured {
  display: grid; grid-template-columns: minmax(0,1.3fr) minmax(0,1fr); gap: clamp(1rem, 2vw, 2rem);
  margin-bottom: clamp(2rem, 4vw, 3rem); padding-bottom: clamp(2rem, 4vw, 3rem);
  border-bottom: 2px solid var(--ink);
}
.archive__featured .news-card__media { aspect-ratio: 16/9; }
.archive__featured .news-card__h { font-size: clamp(1.5rem, 3vw, 2.2rem); }

.archive__subhead {
  font-family: var(--font-display); font-size: 1.3rem; margin-bottom: 1.2rem;
  display: flex; align-items: baseline; gap: .5rem; border-bottom: 1px solid var(--rule); padding-bottom: .5rem;
}
.archive__subhead .count { font-family: var(--font-mono); font-size: .8rem; color: var(--red); }

.archive__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
.archive__grid .news-card { grid-column: auto; }

/* archive sub-filter pills */
.subfilter { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom: 1.5rem; }
.subfilter__pill {
  font-family: var(--font-mono); font-size: .72rem; letter-spacing: .04em;
  padding: .35rem .8rem; border: 1px solid var(--rule); border-radius: 999px; color: var(--ink-dim);
  transition: all .15s var(--ease);
}
.subfilter__pill:hover { color: var(--ink); border-color: var(--orange); }
.subfilter__pill.is-active { background: var(--ink); color: var(--bg); border-color: var(--ink); }

/* pagination */
.pagination { display: flex; justify-content: center; align-items: center; gap: .5rem; margin-top: 2.5rem; }
.pagination a, .pagination span {
  font-family: var(--font-display); font-size: .9rem;
  width: 40px; height: 40px; border-radius: 4px;
  display: grid; place-items: center;
  border: 1px solid var(--rule); color: var(--ink-dim);
  transition: all .15s var(--ease);
}
.pagination a:hover { border-color: var(--red); color: var(--ink); transform: translateY(-2px); }
.pagination .is-current { background: var(--red); color: #fff; border-color: var(--red); }
.pagination .is-disabled { opacity: .35; pointer-events: none; }

/* -----------------------------------------------------------------
   24. INTERNAL PAGE: ABOUT / MASTHEAD
   ----------------------------------------------------------------- */
.about { padding-block: clamp(1.5rem, 4vw, 2.5rem); }
.about__hero { text-align: center; max-width: 800px; margin: 0 auto clamp(2rem, 5vw, 3.5rem); }
.about__kicker { font-family: var(--font-mono); font-size: .74rem; letter-spacing: .2em; color: var(--red); margin-bottom: .8rem; }
.about__title { font-family: var(--font-display); font-size: clamp(2.5rem, 7vw, 5rem); line-height: .9; margin-bottom: 1rem; }
.about__deck { font-family: var(--font-serif); font-size: 1.25rem; line-height: 1.5; color: var(--ink-dim); }

.about__cols { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(2rem, 4vw, 3.5rem); margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.about__col h2 { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.2rem); margin-bottom: 1rem; }
.about__col p { font-family: var(--font-serif); font-size: 1.08rem; line-height: 1.7; color: var(--ink-dim); margin-bottom: 1rem; }
.about__col p strong { color: var(--ink); background: linear-gradient(transparent 60%, rgba(225,25,25,.25) 0); }

/* editorial standards — satirical numbered list */
.standards { counter-reset: std; list-style: none; }
.standards li {
  counter-increment: std;
  font-family: var(--font-serif); font-size: 1.08rem; line-height: 1.5; color: var(--ink-dim);
  padding: 1rem 0 1rem 3.5rem; border-bottom: 1px dashed var(--rule); position: relative;
}
.standards li::before {
  content: counter(std, decimal-leading-zero);
  position: absolute; left: 0; top: 1rem;
  font-family: var(--font-display); font-size: 1.6rem; color: var(--red);
}

/* team grid */
.team { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: clamp(1rem, 2vw, 1.5rem); }
.team-card {
  background: var(--bg-card); border: 1px solid var(--rule); border-radius: var(--radius);
  padding: 1.5rem; text-align: center; transition: all .2s var(--ease);
}
.team-card:hover { border-color: var(--red); transform: translate(-2px,-2px); box-shadow: 5px 5px 0 var(--ink); }
.team-card__avatar {
  width: 80px; height: 80px; border-radius: 50%; margin: 0 auto .8rem;
  background: var(--red-deep); color: #fff; display: grid; place-items: center;
  font-family: var(--font-display); font-size: 1.8rem; border: 3px solid var(--ink);
}
.team-card__name { font-family: var(--font-display); font-size: 1.2rem; }
.team-card__role { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .08em; color: var(--red); margin-bottom: .6rem; }
.team-card__bio { font-family: var(--font-serif); font-size: .88rem; color: var(--ink-dim); line-height: 1.4; }

/* tipline */
.tipline {
  background: var(--red-deep); color: #fff; border-radius: var(--radius-lg);
  padding: clamp(2rem, 4vw, 3rem); text-align: center; margin-top: clamp(2rem, 4vw, 3rem);
}
.tipline__h { font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 2.8rem); margin-bottom: .6rem; }
.tipline__p { font-family: var(--font-serif); font-size: 1.1rem; color: rgba(255,255,255,.85); margin-bottom: 1.2rem; }
.tipline__email {
  display: inline-block; font-family: var(--font-mono); font-size: 1.1rem;
  background: #1a0808; border: 2px dashed var(--yellow); color: var(--yellow);
  padding: .6rem 1.4rem; border-radius: 4px;
}

/* read progress bar */
.readprogress {
  position: fixed; top: 0; left: 0; height: 4px; width: 0;
  background: linear-gradient(90deg, var(--red), var(--orange), var(--yellow));
  z-index: 9999; transition: width .1s linear;
  box-shadow: 0 0 8px var(--red);
}

/* clickable card (whole card is a link) */
.news-card.is-clickable { cursor: pointer; }
.railcard.is-clickable { cursor: pointer; }
.guide.is-clickable { cursor: pointer; }

/* active nav item */
.catnav__chip[data-nav] { }

/* -----------------------------------------------------------------
   25. RESPONSIVE
   ----------------------------------------------------------------- */
@media (max-width: 1100px) {
  .article-layout { grid-template-columns: 48px minmax(0,1fr); }
  .article-layout .scoremeter { display: none; }
  .report-page__layout { grid-template-columns: minmax(0,1fr); }
  .report-page__layout .toc { position: static; margin-bottom: 1.5rem; }
  .report-page__layout .scoremeter { position: static; }
}
@media (max-width: 980px) {
  .hero__grid { grid-template-columns: 1fr; }
  .report-layout { grid-template-columns: 1fr; }
  .scoremeter { position: static; display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: center; text-align: left; }
  .scoremeter__ring { grid-row: span 3; margin: 0; }
  .scoremeter__head, .scoremeter__note { grid-column: 2; }
  .newsletter__inner { grid-template-columns: 1fr; }
  .footer__inner { grid-template-columns: 1fr; }
  .footer__cols { grid-template-columns: repeat(2, 1fr); }
  .news-card:nth-child(n) { grid-column: span 6; }
  .archive__featured { grid-template-columns: 1fr; }
  .archive__grid { grid-template-columns: repeat(2, 1fr); }
  .readnext__grid { grid-template-columns: 1fr; }
  .about__cols { grid-template-columns: 1fr; }
  .trending__featured { grid-template-columns: 1fr; }
  .trending__grid .news-card:nth-child(n) { grid-column: span 6; }
}
@media (max-width: 640px) {
  .masthead__inner { grid-template-columns: 1fr; }
  .masthead__meta { align-items: center !important; text-align: center !important; flex-direction: row; justify-content: center; gap: 1rem; }
  .util-bar__date { display: none; }
  .util-bar__inner { grid-template-columns: 1fr auto; }
  .news-card:nth-child(n) { grid-column: span 12; }
  .archive__grid { grid-template-columns: 1fr; }
  .trending__grid .news-card:nth-child(n) { grid-column: span 12; }
  .bar { grid-template-columns: 1fr; }
  .bar__label { text-align: left; }
  .compare-table__head, .compare-table__row { grid-template-columns: 1fr .8fr .6fr; font-size: .62rem; }
  .compare-table__head span:nth-child(2), .compare-table__row span:nth-child(2) { display: none; }
  .fluorescent-toggle .toggle-label { display: none; }
  .coffee-stain { display: none; }
  .section-head { flex-direction: column; align-items: flex-start; }
  .article-layout { grid-template-columns: 1fr; }
  .sharerail { position: static; flex-direction: row; justify-content: center; flex-wrap: wrap; }
  .sharerail__label { display: none; }
  .authorbox { grid-template-columns: 1fr; text-align: center; justify-items: center; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
}
