:root {
  --paper: #f2ece0;
  --paper-deep: #eae2d2;
  --ink: #17150f;
  --ink-soft: #403b2f;
  --ink-muted: #6a6354;
  --rule: #2a2720;
  --rule-soft: rgba(42, 39, 32, 0.22);
  --accent: oklch(0.52 0.17 25);
  --accent-ink: oklch(0.42 0.17 25);

  /* Aliases: CustomAudioPlayer resolves these via its injected <style>. */
  --paper-bg: var(--paper-deep);
  --body-bg: var(--paper);
  --border-gray: var(--rule-soft);
  --primary-dark: var(--ink);
  --secondary-gray: var(--ink-muted);
  --light-gray: var(--ink-muted);
  --font-masthead: "Playfair Display", "Old Standard TT", serif;
}

html[data-tone="white"] { --paper: #faf7f0; --paper-deep: #f0ebe0; }
html[data-tone="sepia"] { --paper: #ece0c8; --paper-deep: #e0d2b5; --ink: #2a200f; --rule: #3a2e19; }

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: "Source Serif 4", "Source Serif Pro", Georgia, serif;
  font-size: 15px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* subtle paper grain */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(rgba(0,0,0,0.025) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,0.015) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
  mix-blend-mode: multiply;
  z-index: 1;
}

.page { max-width: 1240px; margin: 0 auto; padding: 18px 32px 80px; position: relative; z-index: 2; }

/* ---------- Ticker ---------- */
.ticker {
  background: var(--paper); color: var(--ink);
  font-family: "IBM Plex Mono", ui-monospace, monospace;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  display: flex; align-items: center; overflow: hidden;
  border-bottom: 1px solid var(--rule-soft);
  border-top: 1px solid var(--rule-soft);
}
.ticker-track { flex: 1; overflow: hidden; position: relative; height: 32px; }
.ticker-strip { display: inline-flex; gap: 40px; padding: 0 40px; white-space: nowrap; animation: tick 60s linear infinite; align-items: center; height: 100%; }
.ticker-strip.paused { animation-play-state: paused; }
.ticker-item { display: inline-flex; align-items: center; gap: 12px; color: var(--ink-soft); }
.ticker-tag { color: var(--accent); font-weight: 700; }
.ticker-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--ink); opacity: 0.35; }
@keyframes tick { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---------- Masthead ---------- */
.masthead-wrap { border-bottom: 1px solid var(--ink); padding-bottom: 10px; margin-top: 10px; }
.masthead-topbar {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 20px; align-items: end;
  font-family: "IBM Plex Mono", monospace; font-size: 10.5px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft);
  padding: 10px 0 8px;
}
.masthead-topbar .left  { justify-self: start; }
.masthead-topbar .right { justify-self: end; text-align: right; }
.masthead-topbar .center { text-align: center; }
.mast-meta-line { display: flex; gap: 10px; align-items: center; }
.mast-meta-line span + span::before { content: "·"; margin-right: 10px; color: var(--ink-muted); }

.masthead-title {
  font-family: "Playfair Display", "Old Standard TT", serif;
  font-weight: 900;
  font-size: clamp(58px, 8.5vw, 118px);
  letter-spacing: -0.015em;
  line-height: 0.88;
  text-align: center;
  margin: 2px 0 6px;
  font-variant: small-caps;
}
.masthead-title .amp { font-style: italic; font-weight: 400; }

.masthead-motto {
  text-align: center;
  font-family: "IBM Plex Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.35em; text-transform: uppercase;
  color: var(--ink-soft);
  border-top: 1px solid var(--ink);
  border-bottom: 3px double var(--ink);
  padding: 8px 0; margin-top: 10px;
  display: flex; justify-content: space-between; gap: 18px;
}
.masthead-motto .dot { display: inline-block; width: 4px; height: 4px; background: var(--ink); border-radius: 50%; align-self: center; }

/* ---------- Section nav ---------- */
.nav {
  display: flex; gap: 0; align-items: stretch;
  border-bottom: 1px solid var(--ink);
  font-family: "IBM Plex Mono", monospace;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  overflow-x: auto;
}
.nav-btn {
  background: transparent; border: none; color: var(--ink);
  padding: 10px 18px; cursor: pointer; font: inherit; letter-spacing: inherit;
  text-transform: inherit; border-right: 1px solid var(--rule-soft); white-space: nowrap;
  transition: background 0.15s;
}
.nav-btn:hover { background: var(--paper-deep); }
.nav-btn.active { background: var(--ink); color: var(--paper); }
.nav-btn .count { opacity: 0.5; margin-left: 8px; font-size: 10px; }
.nav-search { margin-left: auto; display: flex; align-items: center; gap: 8px; padding: 0 8px; color: var(--ink-soft); }
.nav-search input {
  background: transparent; border: none; border-bottom: 1px solid var(--rule-soft);
  font: inherit; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink); padding: 4px 0; width: 160px; outline: none;
}
.nav-search input:focus { border-bottom-color: var(--ink); }

/* "Also In The News" stack under the briefing */
.also-stack { display: flex; flex-direction: column; }
.also-item {
  padding: 12px 0; border-bottom: 1px solid var(--rule-soft); cursor: pointer;
}
.also-item:last-child { border-bottom: none; }
.also-item:hover .also-headline { color: var(--accent-ink); }
.also-section {
  font-family: "IBM Plex Mono", monospace;
  font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-ink); margin-bottom: 4px; font-weight: 600;
}
.also-headline {
  font-family: "Playfair Display", serif; font-weight: 700;
  font-size: 16px; line-height: 1.15; margin: 0 0 6px; text-wrap: balance;
  transition: color 0.15s;
}
.also-summary {
  font-size: 12.5px; line-height: 1.42; color: var(--ink-soft);
  text-align: justify; hyphens: auto; margin-bottom: 6px;
}
.also-meta {
  font-family: "IBM Plex Mono", monospace;
  font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-muted); display: flex; justify-content: space-between;
}

/* "In Other News" tail list */
.tail-section { margin-top: 18px; padding-top: 14px; border-top: 3px double var(--ink); }
.tail-title {
  font-family: "Playfair Display", serif; font-weight: 800; font-style: italic;
  font-size: 18px; margin: 0 0 10px;
}
.tail-list { list-style: none; margin: 0; padding: 0; }
.tail-list li {
  display: grid; grid-template-columns: 14px 1fr; gap: 8px;
  padding: 7px 0; border-bottom: 1px dotted var(--rule-soft);
  font-size: 13px; line-height: 1.35; cursor: pointer;
  transition: color 0.15s;
}
.tail-list li:last-child { border-bottom: none; }
.tail-list li:hover { color: var(--accent-ink); }
.tail-bullet {
  font-family: "IBM Plex Mono", monospace; color: var(--accent);
  font-weight: 700; user-select: none;
}

/* ---------- Above-the-fold ---------- */
.above {
  display: grid;
  grid-template-columns: 1.35fr 1px 2.2fr 1px 1fr;
  gap: 0;
  padding: 28px 0 24px;
  border-bottom: 3px double var(--ink);
}
.above .vrule { background: var(--rule-soft); }
.above > section { padding: 0 22px; }
.above > section:first-child { padding-left: 0; }
.above > section:last-child  { padding-right: 0; }

/* left column: briefing */
.briefing-title {
  font-family: "Playfair Display", serif; font-style: italic;
  font-size: 22px; line-height: 1.1; font-weight: 500;
  border-bottom: 1px solid var(--ink); padding-bottom: 8px; margin: 0 0 12px;
}
.briefing-list { list-style: none; margin: 0; padding: 0; }
.briefing-list li { padding: 10px 0; border-bottom: 1px solid var(--rule-soft); display: grid; grid-template-columns: 28px 1fr; gap: 10px; }
.briefing-list li:last-child { border-bottom: none; }
.briefing-num { font-family: "IBM Plex Mono", monospace; font-size: 11px; color: var(--accent); font-weight: 700; padding-top: 2px; }
.briefing-text { font-size: 13.5px; line-height: 1.35; }
.briefing-text .kicker { font-family: "IBM Plex Mono", monospace; font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); display: block; margin-bottom: 2px; }

/* center: lead story */
.lead-kicker {
  font-family: "IBM Plex Mono", monospace;
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent); font-weight: 700; text-align: center;
  margin-bottom: 10px;
  display: flex; align-items: center; justify-content: center; gap: 12px;
}
.lead-kicker::before, .lead-kicker::after { content: ""; flex: 0 0 40px; height: 1px; background: var(--accent); }

.lead-headline {
  font-family: "Playfair Display", serif;
  font-weight: 800; font-size: clamp(30px, 3.6vw, 48px);
  line-height: 1.03; text-align: center; text-wrap: balance;
  margin: 0 0 14px;
  letter-spacing: -0.01em;
}
.lead-deck {
  text-align: center; font-family: "Playfair Display", serif; font-style: italic;
  font-size: 17px; line-height: 1.35; color: var(--ink-soft);
  max-width: 58ch; margin: 0 auto 18px; text-wrap: pretty;
}
.lead-media {
  border: 1px solid var(--rule); position: relative; overflow: hidden;
  aspect-ratio: 16 / 9; background: var(--paper-deep);
}
.lead-media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.4) contrast(1.05); }
.lead-caption {
  font-family: "IBM Plex Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.05em; color: var(--ink-soft);
  padding-top: 8px; line-height: 1.4;
  border-bottom: 1px solid var(--rule-soft); padding-bottom: 10px;
}
.lead-byline {
  font-family: "IBM Plex Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-soft); text-align: center; margin: 12px 0 14px;
}
.lead-byline .bullet { display: inline-block; width: 3px; height: 3px; background: var(--ink-soft); border-radius: 50%; vertical-align: middle; margin: 0 10px; }

.lead-body {
  column-count: 2; column-gap: 22px; column-rule: 1px solid var(--rule-soft);
  font-size: 15px; line-height: 1.55;
  text-align: justify; hyphens: auto;
}
.lead-body p { margin: 0 0 10px; }
.lead-body p:first-child::first-letter {
  font-family: "Playfair Display", serif;
  font-size: 58px; line-height: 0.85; float: left;
  padding: 4px 8px 0 0; font-weight: 800;
  color: var(--ink);
}
.lead-continued {
  font-family: "IBM Plex Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent); margin-top: 10px;
  border-top: 1px solid var(--rule-soft); padding-top: 8px;
  cursor: pointer; background: none; border-left: none; border-right: none; border-bottom: none;
  display: inline-block;
}
.lead-continued:hover { text-decoration: underline; }

/* right column: swing */
.swing-kicker {
  font-family: "IBM Plex Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: 6px;
}
.swing-headline {
  font-family: "Playfair Display", serif;
  font-weight: 800; font-size: 26px; line-height: 1.05;
  margin: 0 0 10px; text-wrap: balance;
}
.swing-byline {
  font-family: "IBM Plex Mono", monospace;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-soft); padding-bottom: 10px;
  border-bottom: 1px solid var(--rule-soft); margin-bottom: 10px;
}
.swing-body p { margin: 0 0 9px; font-size: 14px; line-height: 1.5; text-align: justify; hyphens: auto; }

/* ---------- Below the fold grid ---------- */
.below {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  padding-top: 28px;
}
.below > .col {
  padding: 0 22px; border-right: 1px solid var(--rule-soft);
  display: flex; flex-direction: column;
}
.below > .col > * { flex: 0 0 auto; }
.below > .col > .tail-section { flex: 1 1 auto; }
.below > .col:first-child { padding-left: 0; }
.below > .col:last-child { padding-right: 0; border-right: none; }

.story { padding: 16px 0; border-bottom: 1px solid var(--rule-soft); }
.story:first-child { padding-top: 0; }
.story-section {
  font-family: "IBM Plex Mono", monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-ink); font-weight: 600; margin-bottom: 6px;
  display: flex; align-items: center; gap: 8px;
}
.story-section .sep { flex: 1; height: 1px; background: var(--rule-soft); }
.story-headline {
  font-family: "Playfair Display", serif; font-weight: 700;
  font-size: 19px; line-height: 1.12; margin: 0 0 8px; text-wrap: balance;
  cursor: pointer; transition: color 0.15s;
}
.story-headline:hover { color: var(--accent-ink); }
.story-summary { font-size: 13.5px; line-height: 1.48; color: var(--ink); margin-bottom: 10px; text-align: justify; hyphens: auto; }
.story-meta {
  font-family: "IBM Plex Mono", monospace;
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-muted); display: flex; justify-content: space-between; align-items: center;
}
.story-meta .byline { color: var(--ink-soft); }

/* media thumbnails within stories */
.media-thumb {
  position: relative; aspect-ratio: 16/10; background: var(--paper-deep);
  border: 1px solid var(--rule); margin-bottom: 10px; overflow: hidden; cursor: pointer;
}
.media-thumb img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.45) contrast(1.05); }
.media-thumb .play-overlay {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background: rgba(15, 13, 8, 0.25); transition: background 0.15s;
}
.media-thumb:hover .play-overlay { background: rgba(15, 13, 8, 0.42); }
.media-thumb .play-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--paper); display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--ink);
}
.media-thumb .play-icon::after {
  content: ""; width: 0; height: 0;
  border-left: 16px solid var(--ink); border-top: 10px solid transparent; border-bottom: 10px solid transparent;
  margin-left: 4px;
}
.media-thumb .video-chip {
  position: absolute; top: 8px; left: 8px;
  background: var(--ink); color: var(--paper);
  font-family: "IBM Plex Mono", monospace; font-size: 10px; letter-spacing: 0.12em;
  padding: 3px 8px; text-transform: uppercase;
}
.media-thumb .duration {
  position: absolute; bottom: 8px; right: 8px;
  background: rgba(0,0,0,0.78); color: #fff;
  font-family: "IBM Plex Mono", monospace; font-size: 10px; letter-spacing: 0.08em;
  padding: 3px 7px;
}

.story.featured .media-thumb img { filter: grayscale(0.35) contrast(1.08); }

/* saved toggle */
.save-btn {
  background: none; border: none; cursor: pointer; color: var(--ink-muted);
  padding: 2px 6px; font-family: "IBM Plex Mono", monospace; font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase;
}
.save-btn.saved { color: var(--accent); font-weight: 700; }

/* ---------- Sidebar boxes ---------- */
.box {
  border: 1px solid var(--ink);
  padding: 14px; margin: 16px 0;
  background: var(--paper-deep);
}
.box-title {
  font-family: "Playfair Display", serif; font-weight: 800;
  font-size: 15px; letter-spacing: 0.04em; text-transform: uppercase;
  border-bottom: 1px solid var(--ink); padding-bottom: 6px; margin: 0 0 10px;
  display: flex; justify-content: space-between; align-items: baseline;
}
.box-title .chip {
  font-family: "IBM Plex Mono", monospace; font-size: 9.5px; letter-spacing: 0.14em;
  color: var(--accent); font-weight: 700;
}

.markets-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 14px; }
.markets-row { display: flex; justify-content: space-between; font-family: "IBM Plex Mono", monospace; font-size: 11.5px; border-bottom: 1px dotted var(--rule-soft); padding: 4px 0; }
.markets-row .t { font-weight: 700; }
.markets-row .ch.up { color: #1f5a1f; }
.markets-row .ch.down { color: var(--accent-ink); }

.weather-row { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; padding: 6px 0; border-bottom: 1px dotted var(--rule-soft); font-size: 12px; }
.weather-row:last-child { border-bottom: none; }
.weather-row .city { font-family: "IBM Plex Mono", monospace; font-size: 10.5px; letter-spacing: 0.08em; }
.weather-row .temps { font-family: "Playfair Display", serif; font-weight: 700; font-size: 14px; }
.weather-row .cond { font-style: italic; color: var(--ink-soft); font-size: 11.5px; text-align: right; }

.opinion-item { padding: 8px 0; border-bottom: 1px solid var(--rule-soft); }
.opinion-item:last-child { border-bottom: none; }
.opinion-title { font-family: "Playfair Display", serif; font-weight: 700; font-size: 15px; line-height: 1.15; margin: 0 0 4px; cursor: pointer; }
.opinion-title:hover { color: var(--accent-ink); }
.opinion-author { font-family: "IBM Plex Mono", monospace; font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-muted); margin-bottom: 4px; }
.opinion-excerpt { font-size: 12.5px; font-style: italic; color: var(--ink-soft); }

/* ---------- Video modal ---------- */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(15, 13, 8, 0.85);
  z-index: 50; display: flex; align-items: center; justify-content: center; padding: 40px;
  animation: fadein 0.2s ease;
}
@keyframes fadein { from { opacity: 0; } to { opacity: 1; } }
.modal {
  background: var(--paper); border: 1px solid var(--ink);
  max-width: 920px; width: 100%; max-height: 92vh; overflow: auto;
  padding: 32px 40px; position: relative;
  box-shadow: 0 20px 80px rgba(0,0,0,0.4);
}
.modal-close {
  position: absolute; top: 14px; right: 16px; background: none; border: none;
  font-family: "IBM Plex Mono", monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  cursor: pointer; color: var(--ink); padding: 6px 10px;
}
.modal-close:hover { background: var(--ink); color: var(--paper); }
.modal h2 {
  font-family: "Playfair Display", serif; font-weight: 800;
  font-size: 34px; line-height: 1.05; margin: 18px 0 10px; text-wrap: balance;
}
.modal .kicker {
  font-family: "IBM Plex Mono", monospace; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent); font-weight: 700;
}
.modal .body { column-count: 2; column-gap: 28px; column-rule: 1px solid var(--rule-soft); font-size: 15px; line-height: 1.6; text-align: justify; hyphens: auto; margin-top: 18px; }
.modal .body p { margin: 0 0 12px; }
.modal .video-surface {
  aspect-ratio: 16/9; background: #000; border: 1px solid var(--ink); position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.modal .video-surface .playing-chip {
  position: absolute; top: 10px; left: 10px; color: #fff; background: var(--accent);
  font-family: "IBM Plex Mono", monospace; font-size: 10px; padding: 4px 8px; letter-spacing: 0.14em; text-transform: uppercase;
  display: flex; align-items: center; gap: 6px;
}
.modal .video-surface .playing-chip::before { content: ""; width: 6px; height: 6px; background: #fff; border-radius: 50%; animation: pulse 1.2s infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.modal .video-bars {
  position: absolute; inset: 0; display: flex; align-items: flex-end; gap: 2px; padding: 20px;
  opacity: 0.7;
}
.modal .video-bars span {
  flex: 1; background: linear-gradient(180deg, rgba(255,255,255,0.1), rgba(255,255,255,0.4));
  height: 40%; animation: bar 1.6s ease-in-out infinite;
}
@keyframes bar { 0%, 100% { height: 30%; } 50% { height: 80%; } }

/* ---------- Tweaks panel ---------- */
.tweaks {
  position: fixed; right: 22px; bottom: 22px; z-index: 60;
  background: var(--paper); border: 1px solid var(--ink);
  padding: 16px 18px; width: 260px;
  font-family: "IBM Plex Mono", monospace; font-size: 11px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.25);
}
.tweaks h4 { margin: 0 0 12px; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; border-bottom: 1px solid var(--ink); padding-bottom: 6px; }
.tweaks label { display: block; margin: 8px 0 4px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); }
.tweaks .opts { display: flex; gap: 4px; }
.tweaks .opts button {
  flex: 1; background: transparent; border: 1px solid var(--rule-soft);
  padding: 6px 4px; cursor: pointer; font: inherit; color: var(--ink);
  letter-spacing: 0.06em; text-transform: uppercase;
}
.tweaks .opts button.on { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.tweaks .close { position: absolute; top: 8px; right: 10px; background: none; border: none; cursor: pointer; font: inherit; color: var(--ink-soft); }

/* density */
html[data-density="compact"] { font-size: 14px; }
html[data-density="compact"] .above { padding: 18px 0 16px; }
html[data-density="compact"] .below { padding-top: 18px; }
html[data-density="compact"] .story { padding: 11px 0; }
html[data-density="compact"] .story-summary { font-size: 12.5px; }
html[data-density="compact"] .story-headline { font-size: 17px; }

html[data-photos="off"] .media-thumb { display: none; }
html[data-photos="off"] .lead-media { display: none; }
html[data-photos="off"] .lead-caption { display: none; }

/* footer */
.footer {
  margin-top: 50px; padding-top: 14px;
  border-top: 3px double var(--ink);
  font-family: "IBM Plex Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-soft);
  display: flex; justify-content: space-between; gap: 20px;
  flex-wrap: wrap;
}

/* responsive fallback */
@media (max-width: 1020px) {
  .above { grid-template-columns: 1fr; }
  .above .vrule { display: none; }
  .above > section { padding: 20px 0; border-bottom: 1px solid var(--rule-soft); }
  .below { grid-template-columns: repeat(2, 1fr); }
  .below > .col { padding: 0 16px; }
  .below > .col:nth-child(2n) { padding-right: 0; border-right: none; }
}
@media (max-width: 640px) {
  .below { grid-template-columns: 1fr; }
  .below > .col { padding: 0; border-right: none; }
  .lead-body { column-count: 1; }
}

/* ---------- Audio box (sticky within its column) ---------- */
.audio-box {
  position: sticky;
  top: 12px;
  margin: 16px 0;
  z-index: 3;
}
.audio-box .box-title {
  font-family: "Playfair Display", serif; font-weight: 800;
  font-size: 15px; letter-spacing: 0.04em; text-transform: uppercase;
  border-bottom: 1px solid var(--ink); padding-bottom: 6px; margin: 0 0 10px;
  display: flex; justify-content: space-between; align-items: baseline;
}
.audio-box .box-title .chip {
  font-family: "IBM Plex Mono", monospace; font-size: 9.5px; letter-spacing: 0.14em;
  color: var(--accent); font-weight: 700;
}
/* Disarm the old full-page sticky treatment; column sticky handles it now. */
.sticky-audio-player { position: static !important; box-shadow: none !important; }

@media (max-width: 1020px) {
  .audio-box { position: static; }
}

/* ---------- Filter result bar (shown when a section/query is active) ---------- */
.result-bar {
  padding: 22px 0 10px;
  border-bottom: 1px solid var(--rule-soft);
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.result-bar strong { color: var(--ink); }
.result-bar strong.accent { color: var(--accent); }
