/* ════════════════════════════════════════════════════════════
   fcc.cc /media — base styles
   Ported from Claude Design's redesign.
   Wrapped in @scope (.media-app) so theme tokens, bare element
   rules, and the no-radius aesthetic don't fight sitewide
   chrome (auth dialog, version popup, search overlay, chatbot).
   ════════════════════════════════════════════════════════════ */

@keyframes mediaPulse { 50% { transform: scale(.6); opacity: .5; } }
@keyframes mediaEq {
  0%, 100% { height: 4px; }
  50%      { height: 14px; }
}

@scope (.media-app) {
  :scope {
    /* Theme: bone (default underground/pirate) */
    --bg: #ece7df;
    --paper: #f4efe7;
    --ink: #11100e;
    --ink-2: #353330;
    --dim: #6b6863;
    --rule: #11100e;
    --hairline: rgba(17,16,14,.18);
    --accent: #ff3b1f;
    --accent-ink: #11100e;
    --live: #ff3b1f;
    --offair: #6b6863;

    /* Type stacks */
    --mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, monospace;
    --display: "Archivo Black", "Archivo", "Space Grotesk", system-ui, sans-serif;
    --sans: "Space Grotesk", system-ui, sans-serif;
    --serif: "Instrument Serif", Georgia, serif;

    /* Density */
    --row-h: 44px;
    --gap: 16px;
    --pad: 20px;
    --tile: 220px;
    --base: 14px;

    /* Apply tokens to scope root */
    background: var(--bg);
    color: var(--ink);
    font-family: var(--sans);
    font-size: var(--base);
    line-height: 1.45;
    -webkit-font-smoothing: antialiased;
    font-feature-settings: "ss01","ss02","cv11";
    display: block;
    min-height: 100vh;
  }
  :scope, * { box-sizing: border-box; }

  /* Themes — applied to scope root via data-theme attr on .media-app */
  :scope[data-theme="ink"] {
    --bg: #0a0a09;
    --paper: #121210;
    --ink: #f3eee4;
    --ink-2: #d4cfc4;
    --dim: #8a857c;
    --rule: #f3eee4;
    --hairline: rgba(243,238,228,.16);
    --accent: #ff3b1f;
    --accent-ink: #0a0a09;
    --live: #ff3b1f;
    --offair: #6a665e;
  }
  :scope[data-theme="acid"] {
    --bg: #0a0a09;
    --paper: #11110f;
    --ink: #d8ff2a;
    --ink-2: #b8de1c;
    --dim: #6f7a3a;
    --rule: #d8ff2a;
    --hairline: rgba(216,255,42,.20);
    --accent: #d8ff2a;
    --accent-ink: #0a0a09;
    --live: #ff3b1f;
    --offair: #585b3c;
  }
  :scope[data-theme="pirate"] {
    --bg: #181410;
    --paper: #1f1a14;
    --ink: #f0e3cc;
    --ink-2: #d4c5aa;
    --dim: #8a7f6c;
    --rule: #f0e3cc;
    --hairline: rgba(240,227,204,.18);
    --accent: #ff7a3a;
    --accent-ink: #181410;
    --live: #ff7a3a;
    --offair: #7a705f;
  }

  /* Density presets */
  :scope[data-density="compact"]  { --row-h: 36px; --gap: 10px; --pad: 12px; --tile: 180px; --base: 13px; }
  :scope[data-density="comfy"]    { --row-h: 44px; --gap: 16px; --pad: 20px; --tile: 220px; --base: 14px; }
  :scope[data-density="spacious"] { --row-h: 56px; --gap: 24px; --pad: 28px; --tile: 280px; --base: 15px; }

  /* Type presets */
  :scope[data-type="mono"]      { --display: "Archivo Black","Archivo",sans-serif; --sans: var(--mono); }
  :scope[data-type="grotesk"]   { --display: "Archivo Black","Archivo",sans-serif; --sans: "Space Grotesk", system-ui, sans-serif; }
  :scope[data-type="serif"]     { --display: "Instrument Serif", Georgia, serif; --sans: "Space Grotesk", system-ui, sans-serif; }
  :scope[data-type="condensed"] { --display: "Archivo Black","Archivo",sans-serif; --sans: "Archivo", system-ui, sans-serif; }

  button, input, select, textarea { font: inherit; color: inherit; }
  button { cursor: pointer; background: none; border: 0; padding: 0; }
  a { color: inherit; text-decoration: none; }
  :focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

  /* Enforce no border-radius (intentional aesthetic) */
  :scope, * { border-radius: 0; }
  /* Exception: brand dot, drawer pill, EQ bars, range thumbs need it */
  .brand__dot, .live-pill::before, .tile__live::before, .poster__live::before,
  .browse__fave__dot, .reader__row__dot, .playbar__live::before,
  .playbar__vol input[type=range]::-webkit-slider-thumb,
  .play-btn { border-radius: 50%; }

  /* ─── Top header ─── */
  .topbar {
    position: sticky; top: 0; z-index: 50;
    background: var(--bg);
    border-bottom: 1px solid var(--rule);
  }
  .topbar__inner {
    max-width: 1480px; margin: 0 auto;
    padding: 10px var(--pad);
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: var(--gap);
  }
  .brand {
    font-family: var(--display);
    font-size: 22px;
    letter-spacing: -0.02em;
    text-transform: lowercase;
    display: inline-flex; align-items: center; gap: 8px;
  }
  .brand__dot {
    width: 10px; height: 10px;
    background: var(--accent);
    box-shadow: 0 0 0 3px var(--bg), 0 0 0 4px var(--accent);
    animation: mediaPulse 1.6s ease-in-out infinite;
  }
  .brand small {
    font-family: var(--mono);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .12em;
    color: var(--dim);
    text-transform: uppercase;
    margin-left: 4px;
  }

  .topnav {
    display: flex; gap: 4px;
    font-family: var(--mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .12em;
  }
  .topnav a { padding: 6px 10px; color: var(--dim); border: 1px solid transparent; }
  .topnav a:hover { color: var(--ink); }
  .topnav a[aria-current="page"] {
    color: var(--ink); border-color: var(--rule);
  }

  .tickerstrip {
    font-family: var(--mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--dim);
    display: flex; align-items: center; gap: 14px;
    white-space: nowrap; overflow: hidden;
  }
  .tickerstrip .clock { color: var(--ink); }
  .tickerstrip .now-on-air {
    display: flex; align-items: center; gap: 8px;
    color: var(--ink);
  }
  .live-pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 3px 8px; border: 1px solid var(--accent); color: var(--accent);
    font-family: var(--mono); font-weight: 700; font-size: 10px;
    text-transform: uppercase; letter-spacing: .14em;
  }
  .live-pill::before {
    content: ""; width: 6px; height: 6px;
    background: var(--accent); animation: mediaPulse 1.4s infinite;
  }

  /* ─── Section heads ─── */
  .section-head {
    display: flex; justify-content: space-between; align-items: end;
    border-bottom: 1px solid var(--rule);
    padding-bottom: 8px;
    margin: var(--gap) 0;
  }
  .section-head h2 {
    margin: 0;
    font-family: var(--display);
    font-size: clamp(28px, 4.4vw, 56px);
    letter-spacing: -0.025em;
    line-height: .95;
    text-transform: lowercase;
  }
  .section-head .meta {
    font-family: var(--mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--dim);
  }
  .eyebrow {
    font-family: var(--mono);
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .18em;
    color: var(--dim);
  }

  /* ─── App layout shells ─── */
  .app {
    max-width: 1480px;
    margin: 0 auto;
    padding: var(--gap) var(--pad) 140px;
  }

  /* === HERO STRIP === */
  .hero {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: var(--gap);
    border: 1px solid var(--rule);
    background: var(--paper);
    margin-bottom: var(--gap);
  }
  .hero__big {
    padding: clamp(20px, 3vw, 40px);
    border-right: 1px solid var(--rule);
    display: flex; flex-direction: column; justify-content: space-between;
    gap: 16px;
    min-height: 260px;
  }
  .hero__top {
    display: flex; justify-content: space-between; gap: 20px;
    font-family: var(--mono); font-size: 11px;
    letter-spacing: .14em; text-transform: uppercase; color: var(--dim);
  }
  .hero h1 {
    margin: 0;
    font-family: var(--display);
    font-weight: 900;
    font-size: clamp(40px, 7vw, 96px);
    letter-spacing: -0.035em;
    line-height: .92;
    text-transform: lowercase;
  }
  .hero h1 em {
    font-style: italic;
    font-family: var(--serif);
    font-weight: 400;
    font-size: 0.95em;
    letter-spacing: -.02em;
    color: var(--accent);
  }
  .hero__sub {
    max-width: 56ch;
    font-size: clamp(14px, 1.2vw, 17px);
    line-height: 1.45;
    color: var(--ink-2);
  }
  .hero__stats {
    display: flex; gap: 28px; flex-wrap: wrap;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--dim);
  }
  .hero__stats b { color: var(--ink); font-weight: 700; font-size: 22px; display: block; letter-spacing: 0; }

  .hero__feat {
    padding: clamp(16px, 2vw, 24px);
    display: flex; flex-direction: column; gap: 14px;
    background: var(--bg);
  }
  .hero__feat .eyebrow { display: flex; justify-content: space-between; }

  /* ─── On-air now (featured) ─── */
  .onair {
    display: flex; flex-direction: column; gap: 8px;
    border: 1px solid var(--rule);
    padding: 14px 16px;
    background: var(--paper);
  }
  .onair__head { display: flex; justify-content: space-between; align-items: center; }
  .onair__title { font-family: var(--display); font-size: 22px; line-height: 1.1; letter-spacing: -.02em; }
  .onair__dj { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--dim); }
  .onair__track { font-family: var(--serif); font-size: 19px; line-height: 1.2; }
  .onair__meta { font-family: var(--mono); font-size: 11px; color: var(--dim); letter-spacing: .08em; text-transform: uppercase; }

  /* ─── Filter bar ─── */
  .filterbar {
    display: flex; gap: 6px; flex-wrap: wrap;
    margin: 14px 0 var(--gap);
    align-items: center;
  }
  .chip {
    padding: 5px 10px;
    border: 1px solid var(--rule);
    font-family: var(--mono);
    font-size: 11px;
    text-transform: lowercase;
    letter-spacing: 0;
    color: var(--ink);
    background: transparent;
  }
  .chip:hover { background: var(--ink); color: var(--bg); }
  .chip[aria-pressed="true"], .chip.is-on {
    background: var(--accent); color: var(--accent-ink); border-color: var(--accent);
  }
  .searchwrap {
    flex: 1; min-width: 220px;
    display: flex; align-items: center;
    border: 1px solid var(--rule);
    padding: 0 10px;
    height: 34px;
  }
  .searchwrap input {
    flex: 1; height: 100%; border: 0; outline: 0;
    background: transparent; color: var(--ink);
    font-family: var(--mono); font-size: 13px;
  }
  .searchwrap input::placeholder { color: var(--dim); }
  .searchwrap .kbd {
    font-family: var(--mono); font-size: 10px; color: var(--dim);
    padding: 2px 5px; border: 1px solid var(--hairline);
  }

  /* ─── Tabs ─── */
  .tabs {
    max-width: 1480px; margin: 18px auto 0; padding: 0 var(--pad);
    display: flex; align-items: baseline; gap: 22px;
    border-bottom: 1px solid var(--hairline);
  }
  .tabs__tab {
    padding: 12px 0 10px;
    font-family: var(--display); font-size: 22px; line-height: 1;
    letter-spacing: -0.01em;
    text-transform: lowercase;
    color: var(--dim);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color .12s ease, border-color .12s ease;
  }
  .tabs__tab:hover { color: var(--ink); }
  .tabs__tab.is-on {
    color: var(--ink);
    border-bottom-color: var(--ink);
  }

  /* ─── /media ribbon ─── */
  .ribbon {
    max-width: 1480px; margin: 14px auto 0;
    padding: 0 var(--pad);
    display: flex; align-items: baseline; gap: 18px;
    font-family: var(--mono); font-size: 12px;
    letter-spacing: .04em;
  }
  .ribbon__label {
    font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--dim);
  }
  .ribbon__here {
    color: var(--ink);
    border-bottom: 1.5px solid var(--accent);
    padding-bottom: 1px;
  }
  .ribbon__link {
    color: var(--dim);
    transition: color .12s ease;
  }
  .ribbon__link:hover { color: var(--ink); }
  .ribbon__meta { color: var(--dim); opacity: .7; }

  /* ═════════════ LAYOUT A: GRID ═════════════ */
  .grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(var(--tile), 1fr));
    gap: var(--gap);
  }
  .tile {
    position: relative;
    border: 1px solid var(--rule);
    background: var(--paper);
    padding: 14px 16px 16px;
    display: flex; flex-direction: column; gap: 8px;
    cursor: pointer;
    transition: transform .12s ease, background .12s;
    min-height: 168px;
  }
  .tile:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--rule); }
  .tile.is-active { background: var(--ink); color: var(--bg); }
  .tile.is-active .dim { color: rgba(255,255,255,.55); }
  .tile.is-active .tile__num { color: var(--bg); }
  .tile__top {
    display: flex; justify-content: space-between; align-items: start;
    font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em;
    text-transform: uppercase; color: var(--dim);
  }
  .tile__num { color: var(--ink); }
  .tile__name {
    font-family: var(--display);
    font-size: clamp(18px, 1.6vw, 24px);
    line-height: 1; letter-spacing: -.02em;
    text-transform: lowercase;
    word-break: break-word;
  }
  .tile__genre { font-family: var(--serif); font-size: 16px; color: var(--ink-2); }
  .tile.is-active .tile__genre { color: rgba(255,255,255,.75); }
  .tile__bottom {
    margin-top: auto;
    display: flex; justify-content: space-between; align-items: end;
    font-family: var(--mono); font-size: 10.5px; letter-spacing: .12em;
    text-transform: uppercase;
  }
  .tile__listeners { color: var(--dim); }
  .tile.is-active .tile__listeners { color: rgba(255,255,255,.7); }
  .tile__live {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--accent); font-weight: 700;
  }
  .tile__live::before {
    content: ""; width: 6px; height: 6px;
    background: var(--accent); animation: mediaPulse 1.4s infinite;
  }
  .tile__off { color: var(--dim); }
  .tile__bg {
    position: absolute; inset: 0;
    pointer-events: none;
    background: repeating-linear-gradient(135deg, transparent 0 6px, currentColor 6px 7px);
    opacity: .035;
  }

  /* ═════════════ LAYOUT B: BROADSHEET (table) ═════════════ */
  .broadsheet { background: var(--paper); border: 1px solid var(--rule); }
  .broadsheet__head {
    display: grid;
    grid-template-columns: 60px 2fr 1.2fr 1fr 80px 80px;
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: .16em; text-transform: uppercase;
    color: var(--dim);
    padding: 10px 16px;
    border-bottom: 1px solid var(--rule);
  }
  .row {
    display: grid;
    grid-template-columns: 60px 2fr 1.2fr 1fr 80px 80px;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--hairline);
    cursor: pointer;
    position: relative;
    transition: background .1s;
  }
  .row:hover { background: var(--bg); }
  .row.is-active { background: var(--ink); color: var(--bg); }
  .row.is-active .dim, .row.is-active .row__genre { color: rgba(255,255,255,.6); }
  .row__num { font-family: var(--mono); font-size: 12px; color: var(--dim); }
  .row.is-active .row__num { color: rgba(255,255,255,.5); }
  .row__name {
    font-family: var(--display); font-size: 22px; letter-spacing: -.02em;
    line-height: 1; text-transform: lowercase;
    display: flex; align-items: center; gap: 10px;
  }
  .row__dj { font-family: var(--serif); font-size: 16px; }
  .row__genre { font-family: var(--mono); font-size: 11px; color: var(--dim); text-transform: uppercase; letter-spacing: .1em; }
  .row__listeners { font-family: var(--mono); font-size: 12px; text-align: right; }
  .row__status { font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; text-align: right; text-transform: uppercase; }
  .row.is-active .row__status { color: var(--accent); }

  /* ═════════════ LAYOUT C: ZINE (collage / posters) ═════════════ */
  .zine {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--gap);
  }
  .poster {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--rule);
    background: var(--paper);
    cursor: pointer;
    padding: 16px;
    display: flex; flex-direction: column;
    min-height: 200px;
    isolation: isolate;
  }
  .poster::before {
    content: ""; position: absolute; inset: 0;
    background: var(--poster-color, var(--accent));
    opacity: .85; z-index: -1;
  }
  .poster::after {
    content: ""; position: absolute; inset: 0;
    background:
      radial-gradient(circle at 30% 20%, rgba(255,255,255,.15), transparent 50%),
      repeating-linear-gradient(45deg, rgba(0,0,0,.04) 0 2px, transparent 2px 6px);
    z-index: -1;
    mix-blend-mode: multiply;
  }
  .poster--xl { grid-column: span 8; min-height: 360px; }
  .poster--lg { grid-column: span 6; min-height: 280px; }
  .poster--md { grid-column: span 4; min-height: 220px; }
  .poster--sm { grid-column: span 3; min-height: 180px; }
  .poster--text { grid-column: span 4; background: var(--paper); border: 1px solid var(--rule); color: var(--ink); }
  .poster--text::before, .poster--text::after { display: none; }

  .poster__num {
    font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em;
    text-transform: uppercase; color: rgba(0,0,0,.55);
    display: flex; justify-content: space-between;
  }
  .poster--text .poster__num { color: var(--dim); }
  .poster__name {
    margin-top: auto;
    font-family: var(--display);
    font-size: clamp(28px, 4vw, 60px);
    letter-spacing: -.03em;
    line-height: .92;
    color: #11100e;
    text-transform: lowercase;
    text-shadow: 1px 1px 0 rgba(255,255,255,.25);
  }
  .poster--text .poster__name { color: var(--ink); text-shadow: none; }
  .poster__sub { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: rgba(0,0,0,.7); margin-top: 6px; }
  .poster--text .poster__sub { color: var(--dim); }
  .poster__live {
    position: absolute; top: 12px; right: 12px;
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--mono); font-size: 10px; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    background: #11100e; color: #fff; padding: 4px 7px;
  }
  .poster__live::before {
    content: ""; width: 6px; height: 6px; background: var(--accent);
    animation: mediaPulse 1.4s infinite;
  }
  .poster__off { position: absolute; top: 12px; right: 12px; font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: rgba(0,0,0,.55); }

  /* ═════════════ LAYOUT D: STAGE ═════════════ */
  .stage {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--gap);
  }
  .stage__main {
    border: 1px solid var(--rule);
    background: var(--ink);
    color: var(--bg);
    padding: clamp(20px, 3vw, 40px);
    min-height: 480px;
    display: flex; flex-direction: column; justify-content: space-between;
    gap: 24px;
    position: relative;
    overflow: hidden;
  }
  .stage__main[data-color] {
    background: var(--stage-color);
    color: var(--ink);
  }
  .stage__main::after {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background: repeating-linear-gradient(0deg, transparent 0 2px, rgba(0,0,0,.05) 2px 3px);
    mix-blend-mode: overlay;
  }
  .stage__head { display: flex; justify-content: space-between; gap: 16px; font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; }
  .stage__name {
    font-family: var(--display);
    font-size: clamp(48px, 9vw, 140px);
    letter-spacing: -.04em;
    line-height: .9;
    text-transform: lowercase;
  }
  .stage__nowtitle {
    font-family: var(--serif); font-size: clamp(24px, 3vw, 40px);
    line-height: 1.1; max-width: 18ch;
  }
  .stage__nowby { font-family: var(--mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; opacity: .8; }
  .stage__rail { display: flex; flex-direction: column; gap: 10px; }
  .stage__rail .row { padding: 10px 12px; }
  .stage__rail__head { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--dim); padding-bottom: 6px; border-bottom: 1px solid var(--rule); }
  .stage__bullet {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 12px; border: 1px solid var(--rule); cursor: pointer;
    background: var(--paper);
    transition: background .1s, transform .1s;
  }
  .stage__bullet:hover { background: var(--ink); color: var(--bg); transform: translateX(-2px); }
  .stage__bullet__num { font-family: var(--mono); font-size: 11px; color: var(--dim); width: 22px; }
  .stage__bullet:hover .stage__bullet__num { color: rgba(255,255,255,.6); }
  .stage__bullet__name { font-family: var(--display); font-size: 16px; line-height: 1; letter-spacing: -.01em; text-transform: lowercase; }
  .stage__bullet__meta { margin-left: auto; font-family: var(--mono); font-size: 10.5px; color: var(--dim); }
  .stage__bullet:hover .stage__bullet__meta { color: rgba(255,255,255,.6); }

  /* ═════════════ STATION DRAWER ═════════════ */
  .drawer-backdrop {
    position: fixed; inset: 0; background: rgba(10,10,9,.55);
    z-index: 900; opacity: 0; pointer-events: none;
    transition: opacity .25s ease;
    backdrop-filter: blur(2px);
  }
  .drawer-backdrop.is-open { opacity: 1; pointer-events: auto; }
  .drawer {
    position: fixed; top: 0; right: 0; bottom: 0;
    width: min(92vw, 880px);
    background: var(--bg);
    border-left: 1px solid var(--rule);
    z-index: 901;
    transform: translateX(100%);
    transition: transform .3s cubic-bezier(.2,.7,.2,1);
    display: flex; flex-direction: column;
    box-shadow: -10px 0 0 rgba(0,0,0,.06);
  }
  .drawer.is-open { transform: translateX(0); }
  .drawer__head {
    position: sticky; top: 0; z-index: 2;
    background: var(--bg);
    padding: 14px 20px; border-bottom: 1px solid var(--rule);
    display: flex; justify-content: space-between; align-items: center; gap: 12px;
  }
  .drawer__close {
    font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--dim); padding: 6px 8px; border: 1px solid var(--rule);
  }
  .drawer__close:hover { background: var(--ink); color: var(--bg); }
  .drawer__body { flex: 1; overflow-y: auto; padding: 20px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 24px; }
  .drawer__body section { display: flex; flex-direction: column; gap: 10px; }

  .station-card-hero {
    border: 1px solid var(--rule);
    padding: 24px;
    background: var(--paper);
    position: relative;
    overflow: hidden;
  }
  .station-card-hero::before {
    content: ""; position: absolute; inset: 0; z-index: 0;
    background: var(--station-color, var(--accent));
    opacity: .92;
  }
  .station-card-hero > * { position: relative; z-index: 1; }
  .station-card-hero__name {
    font-family: var(--display);
    font-size: clamp(36px, 5vw, 72px);
    letter-spacing: -.03em; line-height: .9; text-transform: lowercase;
    color: #11100e;
  }
  .station-card-hero__sub { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(0,0,0,.7); margin-bottom: 8px; display: flex; gap: 12px; }
  .station-card-hero__bio { font-family: var(--serif); font-size: 18px; line-height: 1.35; color: rgba(0,0,0,.85); margin-top: 8px; max-width: 38ch; }

  .kv {
    display: grid; grid-template-columns: 110px 1fr;
    gap: 4px 14px;
    font-family: var(--mono); font-size: 12px;
    padding: 12px 0; border-top: 1px solid var(--hairline);
  }
  .kv:first-of-type { border-top: 0; }
  .kv dt { color: var(--dim); text-transform: uppercase; letter-spacing: .12em; font-size: 10.5px; align-self: center; }
  .kv dd { margin: 0; font-size: 13px; }

  /* Drawer player */
  .player {
    border: 1px solid var(--rule);
    padding: 18px;
    background: var(--paper);
    display: flex; flex-direction: column; gap: 14px;
  }
  .player__top { display: flex; justify-content: space-between; align-items: center; }
  .player__title { font-family: var(--serif); font-size: 22px; line-height: 1.2; max-width: 22ch; }
  .player__by { font-family: var(--mono); font-size: 11px; color: var(--dim); letter-spacing: .12em; text-transform: uppercase; }

  .player__progress {
    display: flex; align-items: center; gap: 10px;
    font-family: var(--mono); font-size: 11px; color: var(--dim);
  }
  .barwrap { flex: 1; height: 4px; background: var(--hairline); position: relative; }
  .barfill { position: absolute; inset: 0; width: var(--p, 0%); background: var(--ink); }

  .player__controls { display: flex; gap: 6px; align-items: center; }
  .btn {
    font-family: var(--mono); font-size: 11px; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    padding: 9px 14px;
    border: 1px solid var(--rule);
    background: var(--bg);
    color: var(--ink);
    display: inline-flex; align-items: center; gap: 8px;
    transition: background .1s, color .1s;
  }
  .btn:hover { background: var(--ink); color: var(--bg); }
  .btn--primary { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }
  .btn--primary:hover { background: var(--ink); border-color: var(--ink); color: var(--bg); }
  .btn--icon { padding: 9px 11px; min-width: 36px; justify-content: center; }
  .play-btn {
    width: 56px; height: 56px;
    border: 2px solid var(--ink);
    background: var(--ink); color: var(--bg);
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background .15s, transform .1s;
  }
  .play-btn:hover { transform: scale(1.04); background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }
  .play-btn svg { display: block; }

  /* Chat in drawer */
  .chat {
    border: 1px solid var(--rule);
    background: var(--paper);
    display: flex; flex-direction: column;
    height: 320px;
  }
  .chat__head {
    padding: 10px 14px; border-bottom: 1px solid var(--rule);
    font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
    display: flex; justify-content: space-between;
  }
  .chat__msgs { flex: 1; overflow-y: auto; padding: 10px 14px; font-family: var(--mono); font-size: 12.5px; line-height: 1.55; }
  .msg { display: grid; grid-template-columns: 38px 1fr; gap: 8px; padding: 2px 0; }
  .msg__time { color: var(--dim); font-size: 10.5px; padding-top: 2px; }
  .msg__nick { font-weight: 700; margin-right: 6px; color: var(--accent); }
  .msg__bot .msg__nick { color: var(--dim); }
  .msg__bot .msg__text { color: var(--dim); font-style: italic; }
  .chat__input { display: flex; border-top: 1px solid var(--rule); }
  .chat__input input {
    flex: 1; padding: 10px 14px; border: 0; outline: 0; background: transparent;
    font-family: var(--mono); font-size: 12.5px;
  }
  .chat__input button {
    font-family: var(--mono); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
    padding: 0 16px; border-left: 1px solid var(--rule);
  }
  .chat__input button:hover { background: var(--ink); color: var(--bg); }

  .queue { border: 1px solid var(--rule); background: var(--paper); }
  .queue__row {
    display: grid; grid-template-columns: 24px 1fr auto;
    gap: 10px; align-items: center;
    padding: 8px 14px;
    border-bottom: 1px solid var(--hairline);
    font-size: 13px;
  }
  .queue__row:last-child { border-bottom: 0; }
  .queue__num { font-family: var(--mono); font-size: 11px; color: var(--dim); }
  .queue__title { font-weight: 600; }
  .queue__artist { font-family: var(--serif); color: var(--ink-2); font-size: 14px; }
  .queue__by { font-family: var(--mono); font-size: 10.5px; color: var(--accent); letter-spacing: .12em; text-transform: uppercase; }

  /* Sticky play bar */
  .playbar {
    position: fixed; bottom: 0; left: 0; right: 0;
    z-index: 80;
    background: var(--ink); color: var(--bg);
    border-top: 1px solid var(--rule);
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--gap);
    padding: 10px 20px;
    transform: translateY(100%);
    transition: transform .25s ease;
  }
  .playbar.is-open { transform: translateY(0); }
  .playbar.size-mini { padding: 6px 14px; font-size: 12px; }
  .playbar.size-mini .playbar__name { font-size: 14px; }
  .playbar.size-mini .play-btn { width: 38px; height: 38px; }
  .playbar.size-xl { padding: 18px 26px; }
  .playbar.size-xl .playbar__name { font-size: 22px; }
  .playbar.size-xl .play-btn { width: 64px; height: 64px; }

  .playbar__left { display: flex; align-items: center; gap: 14px; min-width: 0; }
  .playbar__swatch { width: 48px; height: 48px; flex-shrink: 0; background: var(--swatch, var(--accent)); }
  .playbar__name { font-family: var(--display); font-size: 18px; line-height: 1; letter-spacing: -.01em; text-transform: lowercase; }
  .playbar__track {
    font-family: var(--serif); font-size: 14px; color: rgba(255,255,255,.85);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .playbar__center { display: flex; align-items: center; gap: 14px; }
  .playbar__right { display: flex; align-items: center; gap: 14px; justify-content: flex-end; min-width: 0; }
  .playbar__live { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }
  .playbar__live::before { content: ""; width: 6px; height: 6px; background: var(--accent); animation: mediaPulse 1.4s infinite; }
  .playbar__progress { font-family: var(--mono); font-size: 11px; color: rgba(255,255,255,.6); }
  .playbar__vol {
    display: flex; align-items: center; gap: 8px;
    font-family: var(--mono); font-size: 10.5px; color: rgba(255,255,255,.6);
  }
  .playbar__vol input[type=range] {
    -webkit-appearance: none; appearance: none;
    width: 80px; height: 2px; background: rgba(255,255,255,.25);
  }
  .playbar__vol input[type=range]::-webkit-slider-thumb {
    -webkit-appearance: none; width: 10px; height: 10px; background: var(--accent);
  }
  .playbar__close { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: rgba(255,255,255,.5); padding: 6px 8px; }
  .playbar__close:hover { color: var(--bg); }

  .eq { display: inline-flex; align-items: end; gap: 2px; height: 14px; }
  .eq i { display: block; width: 2px; background: var(--accent); animation: mediaEq 1s ease-in-out infinite; }
  .eq i:nth-child(2) { animation-delay: .15s; }
  .eq i:nth-child(3) { animation-delay: .3s; }
  .eq i:nth-child(4) { animation-delay: .45s; }

  /* Layout switcher */
  .layout-switcher {
    display: inline-flex;
    border: 1px solid var(--rule);
    font-family: var(--mono); font-size: 10.5px;
    text-transform: uppercase; letter-spacing: .14em;
  }
  .layout-switcher button {
    padding: 6px 9px;
    color: var(--dim);
    border-right: 1px solid var(--rule);
  }
  .layout-switcher button:last-child { border-right: 0; }
  .layout-switcher button[aria-pressed="true"] { background: var(--ink); color: var(--bg); }
  .layout-switcher button:hover { color: var(--ink); }
  .layout-switcher button[aria-pressed="true"]:hover { color: var(--bg); }

  /* ─── Browse Radio panel ─── */
  .browse {
    max-width: 1480px; margin: 0 auto;
    padding: 24px var(--pad) 120px;
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 40px;
  }
  .browse__side {
    display: flex; flex-direction: column; gap: 22px;
    position: sticky; top: 90px;
    align-self: start;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
    padding-right: 6px;
  }
  .browse__side::-webkit-scrollbar { width: 6px; }
  .browse__side::-webkit-scrollbar-thumb { background: var(--hairline); }
  .browse__search {
    position: relative;
    display: flex; align-items: center;
    border: 1px solid var(--rule);
    background: var(--bg);
  }
  .browse__search__icon { padding: 0 10px; font-size: 16px; color: var(--dim); }
  .browse__search input {
    flex: 1; padding: 10px 12px 10px 0;
    border: 0; background: transparent;
    font-family: var(--mono); font-size: 13px;
  }
  .browse__search input:focus { outline: none; }
  .browse__select { display: flex; flex-direction: column; gap: 6px; }
  .browse__select label {
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: .14em; text-transform: uppercase; color: var(--dim);
  }
  .browse__select select {
    padding: 9px 10px; border: 1px solid var(--rule);
    background: var(--bg);
    font-family: var(--mono); font-size: 12.5px;
    appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--ink) 50%),
                      linear-gradient(-45deg, transparent 50%, var(--ink) 50%);
    background-position: calc(100% - 14px) 50%, calc(100% - 9px) 50%;
    background-size: 5px 5px; background-repeat: no-repeat;
  }
  .browse__facet {
    display: flex; flex-direction: column; gap: 8px;
    border-top: 1px solid var(--hairline);
    padding-top: 16px;
  }
  .browse__facet__head {
    display: flex; justify-content: space-between; align-items: baseline;
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: .14em; text-transform: uppercase; color: var(--dim);
  }
  .browse__count { color: var(--ink); }
  .browse__clear {
    font-family: var(--mono); font-size: 10px;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--accent);
  }
  .browse__genres {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column;
    max-height: 260px; overflow-y: auto;
  }
  .browse__genre {
    display: flex; justify-content: space-between; align-items: baseline;
    width: 100%; padding: 5px 4px;
    font-family: var(--mono); font-size: 12px;
    border-bottom: 1px dotted var(--hairline);
    text-align: left;
    color: var(--ink);
  }
  .browse__genre:hover { background: var(--bg); color: var(--accent); }
  .browse__genre.is-on {
    background: var(--ink); color: var(--bg);
    padding-left: 8px; padding-right: 8px;
  }
  .browse__genre__count {
    font-size: 10.5px; color: var(--dim);
    font-variant-numeric: tabular-nums;
  }
  .browse__genre.is-on .browse__genre__count { color: var(--bg); opacity: .6; }
  .browse__faves, .browse__recent {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 2px;
  }
  .browse__fave {
    display: flex; align-items: center; gap: 8px;
    width: 100%; padding: 6px 4px;
    font-size: 12.5px; text-align: left;
  }
  .browse__fave:hover { background: var(--bg); }
  .browse__fave__star { color: var(--accent); }
  .browse__fave__name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .browse__fave__dot {
    width: 6px; height: 6px;
    background: var(--live); animation: mediaPulse 1.6s infinite;
  }
  .browse__rss-export {
    display: inline-flex; align-items: center; gap: 6px;
    margin-top: 6px;
    padding: 7px 9px;
    border: 1px dashed var(--rule);
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--ink);
    align-self: flex-start;
  }
  .browse__rss-export:hover { background: var(--accent); color: var(--accent-ink); border-style: solid; }
  .browse__recent button {
    display: flex; flex-direction: column; align-items: flex-start;
    gap: 1px; width: 100%; padding: 6px 4px;
    text-align: left;
  }
  .browse__recent button:hover { background: var(--bg); }
  .browse__recent__name { font-size: 12.5px; }
  .browse__recent__meta { font-family: var(--mono); font-size: 10.5px; color: var(--dim); }
  .browse__empty {
    font-family: var(--mono); font-size: 11px;
    color: var(--dim); padding: 4px 0;
  }
  .browse__main { min-width: 0; }
  .browse__bar {
    display: flex; align-items: baseline; gap: 8px;
    padding: 4px 0 18px;
    margin-bottom: 8px;
  }
  .browse__bar__count {
    font-family: var(--display); font-size: 18px;
    letter-spacing: -0.01em;
  }
  .browse__bar__label {
    font-family: var(--mono); font-size: 11px;
    text-transform: lowercase; color: var(--dim);
    letter-spacing: .04em;
  }
  .browse__bar__reset {
    margin-left: auto;
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--accent);
  }
  .browse__bar__chips { display: inline-flex; gap: 6px; flex-wrap: wrap; }
  .browse__chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 8px;
    background: var(--ink); color: var(--bg);
    font-family: var(--mono); font-size: 11px;
    letter-spacing: .04em;
  }
  .browse__chip button { color: var(--bg); opacity: .7; font-size: 13px; line-height: 1; }
  .browse__chip button:hover { opacity: 1; }
  .browse__source {
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--dim);
  }
  .browse__source:hover { color: var(--ink); }
  .browse__noresults {
    padding: 60px 20px; text-align: center;
    color: var(--dim);
    font-family: var(--mono); text-transform: uppercase;
    letter-spacing: .14em; font-size: 12px;
  }
  .browse__noresults button { color: var(--accent); text-decoration: underline; }
  .netgroup { margin-bottom: 32px; }
  .netgroup__head {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: 18px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--hairline);
    margin-bottom: 12px;
  }
  .netgroup__name {
    font-family: var(--display); font-size: 22px;
    margin: 0; line-height: 1; letter-spacing: -0.01em;
    text-transform: lowercase;
  }
  .netgroup__tag {
    margin: 4px 0 0;
    font-family: var(--mono); font-size: 11.5px;
    color: var(--dim); letter-spacing: .04em;
  }
  .netgroup__count {
    font-family: var(--mono); font-size: 11px;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--dim);
    white-space: nowrap;
  }
  .netgroup__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 0;
  }
  .netcard {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: baseline;
    gap: 10px;
    padding: 10px 4px;
    border-bottom: 1px dotted var(--hairline);
    text-align: left;
    transition: background .1s ease, padding .1s ease;
  }
  .netcard:hover { padding-left: 10px; padding-right: 10px; }
  .netcard.is-active { background: var(--ink); color: var(--bg); padding-left: 10px; padding-right: 10px; }
  .netcard__icon { display: none; }
  .netcard.is-active .netcard__icon { background: transparent; color: var(--bg); border-color: rgba(255,255,255,.2); }
  .netcard:hover .netcard__icon { color: var(--accent); border-color: var(--accent); }
  .netcard__body { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
  .netcard__name {
    font-family: var(--sans); font-weight: 600;
    font-size: 14px; line-height: 1.2;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .netcard__meta {
    font-family: var(--mono); font-size: 10.5px;
    color: var(--dim); letter-spacing: .04em;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .netcard.is-active .netcard__meta { color: rgba(255,255,255,.65); }
  .netcard__fav {
    font-size: 14px; color: var(--hairline);
    width: 22px; height: 22px;
    display: inline-flex; align-items: center; justify-content: center;
  }
  .netcard:hover .netcard__fav { color: var(--accent); }

  /* ─── Reader: shared layout for /pods and /rss ─── */
  .reader {
    max-width: 1480px; margin: 0 auto;
    padding: 24px var(--pad) 120px;
    display: grid; grid-template-columns: 240px 1fr; gap: 40px;
  }
  .reader__side {
    display: flex; flex-direction: column; gap: 6px;
    position: sticky; top: 90px; align-self: start;
    max-height: calc(100vh - 110px); overflow-y: auto; padding-right: 6px;
  }
  .reader__side__head {
    display: flex; justify-content: space-between; align-items: baseline;
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: .14em; text-transform: uppercase; color: var(--dim);
    padding: 6px 0;
  }
  .reader__side__count { color: var(--ink); }
  .reader__side__add {
    font-family: var(--mono); font-size: 10.5px; color: var(--accent);
    text-transform: uppercase; letter-spacing: .12em;
  }
  .reader__side__group {
    font-family: var(--mono); font-size: 10px; color: var(--dim);
    text-transform: uppercase; letter-spacing: .14em;
    padding: 10px 0 4px;
  }
  .reader__feeds { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
  .reader__feed {
    display: flex; align-items: center; gap: 8px; width: 100%;
    padding: 5px 4px; text-align: left; font-size: 12.5px;
    border-bottom: 1px dotted var(--hairline);
  }
  .reader__feed:hover { background: var(--bg); }
  .reader__feed.is-on { background: var(--ink); color: var(--bg); padding-left: 8px; padding-right: 8px; }
  .reader__feed__swatch { width: 10px; height: 10px; flex-shrink: 0; }
  .reader__feed__name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .reader__feed__count {
    font-family: var(--mono); font-size: 10.5px; color: var(--dim);
    font-variant-numeric: tabular-nums;
  }
  .reader__feed.is-on .reader__feed__count { color: var(--bg); opacity: .6; }
  .reader__feed__add { font-family: var(--mono); font-size: 10px; color: var(--accent); text-transform: uppercase; letter-spacing: .1em; }
  .reader__main { min-width: 0; }
  .reader__bar {
    display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
    padding: 4px 0 18px; margin-bottom: 8px;
    border-bottom: 1px dotted var(--hairline);
  }
  .reader__bar__count { font-family: var(--display); font-size: 18px; }
  .reader__bar__label { font-family: var(--mono); font-size: 11px; color: var(--dim); text-transform: lowercase; }
  .reader__bar__chips { margin-left: auto; display: inline-flex; gap: 4px; }
  .reader__chip {
    padding: 4px 8px; font-family: var(--mono); font-size: 10.5px;
    text-transform: uppercase; letter-spacing: .1em; color: var(--dim);
    border: 1px solid transparent;
  }
  .reader__chip:hover { color: var(--ink); }
  .reader__chip.is-on { color: var(--ink); border-color: var(--ink); }
  .reader__bar__act {
    font-family: var(--mono); font-size: 10.5px; color: var(--dim);
    text-transform: uppercase; letter-spacing: .12em;
  }
  .reader__bar__act:hover { color: var(--accent); }
  .reader__list { list-style: none; padding: 0; margin: 0; }
  .reader__row {
    display: grid; grid-template-columns: auto 1fr auto;
    align-items: flex-start; gap: 14px;
    padding: 14px 4px; border-bottom: 1px dotted var(--hairline);
    transition: padding .1s ease;
  }
  .reader__row:hover { padding-left: 10px; padding-right: 10px; background: var(--bg); }
  .reader__row.is-read { opacity: .55; }
  .reader__row__play {
    width: 32px; height: 32px; border: 1px solid var(--rule);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--ink); flex-shrink: 0;
  }
  .reader__row__play:hover { background: var(--ink); color: var(--bg); }
  .reader__row__open {
    display: flex; gap: 12px; text-align: left; width: 100%;
    grid-column: 1 / span 3;
  }
  .reader__row__dot {
    width: 7px; height: 7px;
    background: var(--accent);
    margin-top: 8px; flex-shrink: 0;
  }
  .reader__row__body { min-width: 0; flex: 1; }
  .reader__row__title { font-weight: 600; font-size: 14.5px; line-height: 1.3; }
  .reader__row__excerpt {
    font-size: 13px; color: var(--ink-2); margin-top: 3px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .reader__row__meta {
    font-family: var(--mono); font-size: 10.5px; color: var(--dim);
    margin-top: 4px; letter-spacing: .04em;
    display: flex; align-items: center; gap: 6px;
  }
  .reader__row__swatch { width: 8px; height: 8px; display: inline-block; }
  .reader__row__progress { color: var(--accent); }
  .reader__row__done { color: var(--dim); }
  .reader__row__bar {
    height: 2px; background: var(--hairline); margin-top: 6px; max-width: 320px;
  }
  .reader__row__bar__fill { height: 100%; background: var(--accent); }
  .reader__row__actions { display: flex; gap: 4px; }
  .reader__row__actions button {
    width: 24px; height: 24px; color: var(--dim); font-size: 13px;
  }
  .reader__row__actions button:hover { color: var(--ink); }
  .reader__article { max-width: 680px; margin: 0 auto; padding: 8px 0; }
  .reader__back {
    font-family: var(--mono); font-size: 11px; color: var(--dim);
    letter-spacing: .12em; text-transform: uppercase; margin-bottom: 24px;
  }
  .reader__back:hover { color: var(--ink); }
  .reader__article__src {
    font-family: var(--mono); font-size: 11px; color: var(--dim);
    text-transform: uppercase; letter-spacing: .14em; margin-bottom: 8px;
  }
  .reader__article__title {
    font-family: var(--display); font-size: 38px; line-height: 1.05;
    letter-spacing: -0.02em; margin: 0 0 16px;
  }
  .reader__article__lede { font-size: 17px; color: var(--ink-2); }
  .reader__article p { font-size: 15px; line-height: 1.65; }
  .reader__article__actions { display: flex; gap: 8px; margin-top: 24px; }

  /* Tab content visibility (router toggles [hidden]) */
  [data-tab][hidden] { display: none; }

  /* ─── Responsive ─── */
  @media (max-width: 1100px) {
    .hero { grid-template-columns: 1fr; }
    .hero__big { border-right: 0; border-bottom: 1px solid var(--rule); }
    .stage { grid-template-columns: 1fr; }
    .drawer__body { grid-template-columns: 1fr; }
  }
  @media (max-width: 700px) {
    .topbar__inner { grid-template-columns: 1fr; gap: 10px; }
    .tickerstrip { display: none; }
    .topnav { justify-content: flex-start; flex-wrap: wrap; }
    .broadsheet__head { display: none; }
    .row { grid-template-columns: 1fr auto; gap: 4px 12px; }
    .row__num, .row__genre { display: none; }
    .row__name { font-size: 18px; }
    .row__dj { font-size: 14px; grid-column: 1; }
    .row__listeners, .row__status { font-size: 10.5px; grid-column: 2; }
    .zine .poster { grid-column: span 12 !important; }
    .playbar { grid-template-columns: 1fr auto; padding: 8px 12px; }
    .playbar__center { display: none; }
    .browse { grid-template-columns: 1fr; }
    .browse__side { position: static; }
    .reader { grid-template-columns: 1fr; }
    .reader__side { position: static; }
    .tabs { flex-wrap: wrap; }
  }
}
