/* FKN Archive — shared styles
   Theme: dark space, cyan + amber accents
   Fonts: Space Grotesk (body), Space Mono (UI/headlines)
*/
:root{
  --bg:#070b14;
  --bg2:#0d1322;
  --card:#111a2e;
  --card-hover:#152138;
  --border:#1e2a44;
  --border-soft:rgba(56,189,248,.12);
  --text:#dde6f3;
  --muted:#7a8aa6;
  --dim:#4a5a78;
  --cyan:#38bdf8;
  --cyan-dim:#0ea5e9;
  --amber:#f59e0b;
  --amber-dim:#d97706;
  --green:#34d399;
  --red:#ef4444;
  --gold:#e8c547;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  background:radial-gradient(ellipse at top,#0a1428 0%,#070b14 60%);
  background-attachment:fixed;
  color:var(--text);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
a{color:var(--cyan);text-decoration:none;transition:.15s}
a:hover{color:var(--amber)}
code,pre,.mono{font-family:'Space Mono','JetBrains Mono',monospace}

/* --- Top crumb bar --- */
.crumbs{
  position:sticky;top:0;z-index:50;
  background:rgba(7,11,20,.92);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.crumbs-inner{
  max-width:1100px;margin:0 auto;padding:10px 18px;
  display:flex;align-items:center;gap:10px;
  font-family:'Space Mono',monospace;font-size:.78rem;
  color:var(--muted);
}
.crumbs a{color:var(--cyan)}
.crumbs .sep{color:var(--dim)}
.crumbs .official{
  margin-left:auto;display:flex;align-items:center;gap:6px;
  color:var(--gold);font-size:.7rem;letter-spacing:1px;text-transform:uppercase;
  border:1px solid rgba(232,197,71,.3);padding:3px 8px;border-radius:3px;
  background:rgba(232,197,71,.05);
}
.crumbs .official::before{content:'★';color:var(--gold)}

/* --- Page container --- */
.wrap{max-width:1100px;margin:0 auto;padding:32px 20px 80px}
.wrap-narrow{max-width:780px}

/* --- Hero --- */
.hero{margin:24px 0 36px}
.hero h1{
  font-family:'Space Mono',monospace;
  font-size:clamp(2rem,5vw,3.4rem);
  font-weight:700;
  letter-spacing:-.04em;
  line-height:1;
  margin-bottom:10px;
  color:#fff;
}
.hero h1 .fkn{color:var(--cyan)}
.hero h1 .archive{color:var(--amber)}
.hero .kicker{
  font-family:'Space Mono',monospace;font-size:.78rem;
  letter-spacing:2px;text-transform:uppercase;color:var(--muted);
  margin-bottom:14px;
}
.hero .lede{font-size:1.05rem;color:#bcc8db;line-height:1.65;max-width:680px}
.hero .lede em{color:var(--cyan);font-style:normal}

/* --- Stats strip --- */
.stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:10px;margin:20px 0 30px;
}
.stat{
  background:var(--card);border:1px solid var(--border);border-radius:8px;
  padding:14px 16px;text-align:center;
}
.stat .n{
  font-family:'Space Mono',monospace;font-size:1.55rem;font-weight:700;
  color:var(--cyan);letter-spacing:-.02em;
}
.stat .l{
  font-size:.7rem;color:var(--muted);text-transform:uppercase;
  letter-spacing:1.2px;margin-top:3px;
}

/* --- Card grid --- */
h2{
  font-family:'Space Mono',monospace;
  font-size:1.1rem;color:var(--amber);font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  margin:32px 0 14px;padding-bottom:6px;
  border-bottom:1px solid var(--border);
}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:18px 0}
.card{
  display:block;background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:18px 18px 16px;
  transition:.18s;text-decoration:none;color:var(--text);
  position:relative;overflow:hidden;
}
.card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cyan);
  opacity:.6;transition:.18s;
}
.card:hover{border-color:var(--cyan);background:var(--card-hover);transform:translateY(-1px)}
.card:hover::before{width:5px;opacity:1}
.card .icon{font-size:1.4rem;margin-bottom:6px;display:block}
.card .ti{
  font-family:'Space Mono',monospace;font-size:.95rem;font-weight:700;
  color:#fff;letter-spacing:-.01em;margin-bottom:4px;
}
.card .desc{font-size:.82rem;color:var(--muted);line-height:1.45}
.card .meta{
  font-family:'Space Mono',monospace;font-size:.66rem;
  color:var(--cyan);margin-top:8px;letter-spacing:1px;text-transform:uppercase;
}

/* --- Episode list --- */
.ep-list{margin:18px 0;display:flex;flex-direction:column;gap:2px}
.ep-row{
  display:flex;gap:12px;align-items:center;
  padding:8px 12px;border-radius:5px;
  font-size:.86rem;transition:.1s;
  border:1px solid transparent;
}
.ep-row:hover{background:var(--card);border-color:var(--border-soft)}
.ep-row .date{
  font-family:'Space Mono',monospace;font-size:.72rem;color:var(--cyan);
  width:90px;flex-shrink:0;
}
.ep-row .title{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ep-row .title a{color:inherit}
.ep-row .title a:hover{color:var(--amber)}
.ep-row .pills{display:flex;gap:3px;flex-shrink:0}
.pill{
  font-family:'Space Mono',monospace;font-size:.6rem;
  padding:2px 6px;border-radius:3px;letter-spacing:.5px;
  border:1px solid var(--border);color:var(--muted);
}
.pill.v{color:var(--amber);border-color:rgba(245,158,11,.3);background:rgba(245,158,11,.05)}
.pill.a{color:var(--cyan);border-color:rgba(56,189,248,.3);background:rgba(56,189,248,.05)}
.pill.t{color:var(--green);border-color:rgba(52,211,153,.3);background:rgba(52,211,153,.05)}

/* --- Search box --- */
.search{
  width:100%;padding:10px 14px;
  background:var(--bg2);border:1px solid var(--border);border-radius:6px;
  color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:.95rem;
  margin:8px 0 14px;
}
.search:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(56,189,248,.1)}

/* --- Year tabs --- */
.tabs{display:flex;gap:6px;margin:14px 0;flex-wrap:wrap}
.tab{
  font-family:'Space Mono',monospace;font-size:.78rem;
  padding:6px 14px;background:var(--card);border:1px solid var(--border);
  border-radius:4px;color:var(--muted);cursor:pointer;transition:.1s;
  letter-spacing:.5px;
}
.tab:hover{color:var(--cyan);border-color:var(--cyan)}
.tab.active{color:var(--amber);border-color:var(--amber);background:rgba(245,158,11,.08)}

/* --- Bio / prose --- */
.bio{
  margin:18px 0;padding:18px 20px;
  background:var(--card);border:1px solid var(--border);border-radius:10px;
  font-size:.95rem;line-height:1.7;color:#cad4e6;
}
.bio strong{color:var(--cyan)}
.bio em{color:var(--amber);font-style:normal}

/* --- Footer --- */
footer{
  margin-top:60px;padding:28px 20px;
  border-top:1px solid var(--border);
  text-align:center;color:var(--muted);font-size:.78rem;
  font-family:'Space Mono',monospace;letter-spacing:.5px;
}
footer .license{color:var(--gold);margin-bottom:6px}
footer a{color:var(--cyan)}

/* --- Buttons --- */
.btn{
  display:inline-block;padding:9px 16px;
  background:var(--card);border:1px solid var(--border);border-radius:5px;
  font-family:'Space Mono',monospace;font-size:.85rem;
  color:var(--cyan);text-decoration:none;transition:.15s;letter-spacing:.5px;
  cursor:pointer;
}
.btn:hover{background:rgba(56,189,248,.1);border-color:var(--cyan);color:#fff}
.btn.amber{color:var(--amber);border-color:rgba(245,158,11,.3)}
.btn.amber:hover{background:rgba(245,158,11,.1);border-color:var(--amber);color:#fff}
.btn.primary{background:var(--cyan);color:#001220;border-color:var(--cyan)}
.btn.primary:hover{background:#7dd3fc;color:#001220}

/* --- Video / audio elements --- */
video,audio{width:100%;background:#000;border-radius:6px}
.video-wrap{margin:16px 0;background:#000;border:1px solid var(--border);border-radius:8px;overflow:hidden}

/* --- Transcript --- */
.transcript{
  margin:24px 0;padding:18px 22px;
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  font-size:.92rem;line-height:1.7;color:#cad4e6;
  max-height:560px;overflow-y:auto;
}
.transcript p{margin:0 0 12px 0}
.transcript p:last-child{margin-bottom:0}
.transcript .speaker{
  display:block;font-family:'Space Mono',monospace;font-size:.72rem;
  color:var(--cyan);letter-spacing:.5px;text-transform:uppercase;
  margin:10px 0 4px;
}
.transcript .timestamp{
  display:block;font-family:'Space Mono',monospace;font-size:.7rem;
  color:var(--muted);margin:4px 0;
}
.transcript-note{font-size:.72rem;color:var(--muted);margin-bottom:10px;font-style:italic}

/* --- Top quotes (Part 1) --- */
.top-quotes{
  margin:18px 0;padding:14px 18px;
  background:rgba(56,189,248,.05);
  border-left:3px solid var(--cyan);border-radius:6px;
}
.top-quotes h3{
  font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--cyan);margin:0 0 8px;
}
.top-quotes blockquote{
  margin:6px 0;padding:2px 0;
  font-family:'Space Grotesk',sans-serif;font-style:italic;
  color:#cad4e6;font-size:.95rem;line-height:1.5;
}

/* --- Themes / TF-IDF pills (Part 2) --- */
.themes{
  margin:24px 0;padding:16px 20px;
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
}
.themes h2{font-size:1.05rem;margin:0 0 10px;color:#fff}
.themes-pills{display:flex;flex-wrap:wrap;gap:6px}
.theme-pill{
  font-family:'Space Mono',monospace;font-size:.72rem;
  padding:4px 10px;border-radius:14px;text-decoration:none;
  border:1px solid rgba(56,189,248,.3);
  background:rgba(56,189,248,.06);color:var(--cyan);
  transition:.12s;
}
.theme-pill:hover{
  background:rgba(56,189,248,.16);
  border-color:rgba(56,189,248,.6);
}
.theme-pill.amber{
  color:var(--amber);
  border-color:rgba(245,158,11,.3);
  background:rgba(245,158,11,.06);
}
.theme-pill.amber:hover{
  background:rgba(245,158,11,.16);
  border-color:rgba(245,158,11,.6);
}

/* --- Analysis essay (Part 3) --- */
.analysis-essay{
  margin:24px 0;padding:18px 22px;
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
}
.analysis-essay h2{font-size:1.05rem;margin:0 0 10px;color:#fff}
.analysis-essay p{margin:0 0 12px;line-height:1.7;color:#cad4e6;font-size:.93rem}
.analysis-essay p:last-child{margin-bottom:0}
.analysis-essay a{color:var(--cyan)}
.essay-pending{
  color:var(--muted);font-style:italic;font-size:.85rem;
  padding:6px 0;
}

/* --- Posters --- */
.posters{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin:14px 0}
.poster{
  display:block;background:var(--card);border:1px solid var(--border);
  border-radius:6px;overflow:hidden;text-decoration:none;color:inherit;
  transition:.15s;
}
.poster:hover{border-color:var(--cyan);transform:translateY(-2px)}
.poster .thumb{
  aspect-ratio:16/12;background:#000 center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;
  color:var(--dim);font-family:'Space Mono',monospace;font-size:1.4rem;
  border-bottom:1px solid var(--border);
}
.poster .info{padding:8px 10px}
.poster .info .d{font-family:'Space Mono',monospace;font-size:.66rem;color:var(--cyan);margin-bottom:2px}
.poster .info .t{font-size:.78rem;color:var(--text);line-height:1.35;height:34px;overflow:hidden}

@media(max-width:640px){
  .wrap{padding:20px 14px 60px}
  .hero h1{font-size:2rem}
  .cards{grid-template-columns:1fr 1fr}
  .ep-row .date{width:70px;font-size:.66rem}
  .ep-row .title{font-size:.78rem}
}


/* =========================================================
   Episode page: YouTube-style layout (hero + sidebar)
   ========================================================= */
.ep-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:24px;
  margin-top:8px;
}
@media(min-width:1024px){
  .ep-layout{grid-template-columns:minmax(0,1fr) 340px}
}
.ep-main{min-width:0}
.ep-sidebar{min-width:0}
.ep-sidebar h2{
  margin-top:0;
  font-size:.85rem;
  color:var(--cyan);
}

.suggest-list{display:flex;flex-direction:column;gap:10px}
.suggest-card{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:10px;
  padding:6px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  text-decoration:none;
  color:var(--text);
  transition:.15s;
}
.suggest-card:hover{
  border-color:var(--cyan);
  background:var(--card-hover);
  transform:translateX(-2px);
}
.suggest-card .thumb{
  aspect-ratio:16/10;
  background:#000 center/cover no-repeat;
  border-radius:5px;
  display:flex;align-items:center;justify-content:center;
  color:var(--dim);
  font-family:'Space Mono',monospace;
  font-size:.7rem;
  position:relative;
  overflow:hidden;
}
.suggest-card .thumb .thumb-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  background:#000;
}
.suggest-card .thumb .play-badge{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;
  border-radius:50%;
  background:rgba(0,0,0,.55);
  color:#fff;
  font-size:.7rem;
  line-height:1;
  padding-left:2px; /* visual centering of ▶ glyph */
  opacity:.85;
  transition:opacity .15s, background .15s;
  z-index:2;
  pointer-events:none;
}
.suggest-card:hover .thumb .play-badge{
  opacity:1;
  background:rgba(56,189,248,.85);
  color:#000;
}
.suggest-card .thumb .play-badge.ph{
  /* placeholder fallback: bigger, plain (no image behind) */
  position:static;
  transform:none;
  background:transparent;
  color:var(--dim);
  width:auto;height:auto;
  font-size:.85rem;
  opacity:1;
}
.suggest-card .thumb::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(56,189,248,.12),rgba(245,158,11,.06));
  pointer-events:none;
  z-index:1;
}
.suggest-card .thumb .dur{
  position:absolute;bottom:4px;right:4px;
  background:rgba(0,0,0,.7);
  color:#fff;
  font-family:'Space Mono',monospace;
  font-size:.62rem;
  padding:1px 5px;
  border-radius:3px;
  z-index:1;
}
.suggest-card .meta{display:flex;flex-direction:column;justify-content:flex-start;padding:2px 4px 2px 0}
.suggest-card .meta .ttl{
  font-size:.78rem;
  line-height:1.3;
  color:var(--text);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  margin-bottom:4px;
}
.suggest-card .meta .d{
  font-family:'Space Mono',monospace;
  font-size:.66rem;
  color:var(--muted);
}
.suggest-card .meta .badge{
  display:inline-block;
  font-family:'Space Mono',monospace;
  font-size:.6rem;
  color:var(--amber);
  letter-spacing:.5px;
  margin-top:3px;
  text-transform:uppercase;
}

/* =========================================================
   Autoplay countdown overlay (sits over the video on end)
   ========================================================= */
.player-shell{position:relative}
.autoplay-overlay{
  position:absolute;
  inset:0;
  background:rgba(7,11,20,.86);
  backdrop-filter:blur(6px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:20px;
  text-align:center;
  z-index:10;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s;
}
.autoplay-overlay.active{opacity:1;pointer-events:auto}
.autoplay-overlay .label{
  font-family:'Space Mono',monospace;
  font-size:.7rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:8px;
}
.autoplay-overlay .nxt{
  font-size:1.05rem;
  color:#fff;
  font-weight:600;
  max-width:520px;
  margin-bottom:12px;
  line-height:1.35;
}
.autoplay-overlay .ring{
  width:78px;height:78px;
  border-radius:50%;
  border:3px solid var(--border);
  position:relative;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
  background:rgba(0,0,0,.4);
}
.autoplay-overlay .ring .countdown{
  font-family:'Space Mono',monospace;
  font-size:2rem;
  color:var(--amber);
  font-weight:700;
  line-height:1;
}
.autoplay-overlay .ring svg{
  position:absolute;inset:-3px;
  transform:rotate(-90deg);
}
.autoplay-overlay .ring svg circle{
  fill:none;
  stroke:var(--cyan);
  stroke-width:3;
  stroke-linecap:round;
  stroke-dasharray:252;
  stroke-dashoffset:0;
  transition:stroke-dashoffset 1s linear;
}
.autoplay-overlay .actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.autoplay-overlay .btn{font-size:.78rem;padding:8px 14px}

/* Autoplay toggle (sits under the player) */
.autoplay-bar{
  display:flex;align-items:center;gap:10px;
  margin:8px 0 0;
  padding:8px 12px;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:6px;
  font-family:'Space Mono',monospace;
  font-size:.74rem;
  color:var(--muted);
}
.autoplay-bar label{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.autoplay-bar .switch{
  position:relative;
  width:34px;height:18px;
  background:var(--border);
  border-radius:9px;
  transition:.15s;
  flex-shrink:0;
}
.autoplay-bar .switch::after{
  content:'';position:absolute;
  top:2px;left:2px;
  width:14px;height:14px;
  background:#fff;border-radius:50%;
  transition:.15s;
}
.autoplay-bar input{display:none}
.autoplay-bar input:checked + .switch{background:var(--cyan)}
.autoplay-bar input:checked + .switch::after{left:18px}
.autoplay-bar .nxt-preview{
  margin-left:auto;color:var(--cyan);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  font-size:.7rem;
}

/* =========================================================
   Inline audio player (Task 4 — mp3 plays inline)
   ========================================================= */
.audio-wrap{
  margin:18px 0 6px;
  padding:14px 16px;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:8px;
}
.audio-wrap .audio-label{
  font-family:'Space Mono',monospace;
  font-size:.74rem;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:8px;
}
.audio-wrap audio{width:100%;height:36px}
.audio-wrap .audio-foot{
  margin-top:6px;
  font-family:'Space Mono',monospace;
  font-size:.7rem;
  color:var(--muted);
}
.audio-wrap .audio-foot a{color:var(--muted);text-decoration:underline}
.audio-wrap .audio-foot a:hover{color:var(--cyan)}
.dl-row{
  display:flex;gap:14px;flex-wrap:wrap;
  margin:14px 0 6px;
  font-family:'Space Mono',monospace;font-size:.72rem;
  color:var(--muted);
}
.dl-row a{color:var(--muted);text-decoration:underline}
.dl-row a:hover{color:var(--cyan)}

/* =========================================================
   Hub homepage — YouTube-style layout (hero + shelves)
   ========================================================= */

/* Wide-mode wrap for the hub (overrides the 1100px max) */
.wrap.wide{max-width:1320px}

/* --- Hero featured video --- */
.hero-feat{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:22px;
  margin:18px 0 44px;
}
@media(min-width:900px){
  .hero-feat{grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);align-items:center}
}
.hero-feat .player{
  position:relative;
  background:#000;
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  aspect-ratio:16/9;
}
.hero-feat .player video{
  width:100%;height:100%;
  display:block;background:#000;
  object-fit:contain;
}
.hero-feat .feat-meta{min-width:0;padding:6px 4px}
.hero-feat .feat-kicker{
  font-family:'Space Mono',monospace;
  font-size:.7rem;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:var(--amber);
  margin-bottom:10px;
}
.hero-feat .feat-kicker .dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--amber);margin-right:6px;vertical-align:middle;
  box-shadow:0 0 8px var(--amber);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.55}50%{opacity:1}}
.hero-feat .feat-title{
  font-family:'Space Mono',monospace;
  font-size:clamp(1.4rem,2.7vw,2.1rem);
  font-weight:700;
  line-height:1.1;
  letter-spacing:-.02em;
  color:#fff;
  margin:0 0 10px;
}
.hero-feat .feat-sub{
  font-family:'Space Mono',monospace;
  font-size:.78rem;color:var(--cyan);
  margin-bottom:14px;letter-spacing:.5px;
}
.hero-feat .feat-sub .dotsep{color:var(--dim);margin:0 8px}
.hero-feat .feat-desc{
  font-size:.95rem;color:#bcc8db;line-height:1.6;
  margin-bottom:18px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.hero-feat .feat-cta{display:flex;gap:8px;flex-wrap:wrap}

/* --- Shelves (YouTube-style horizontal scrolling rows) --- */
.shelf{margin:26px 0 30px}
.shelf-head{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:12px;gap:14px;
}
.shelf-head h2{
  margin:0;padding:0;border:0;
  font-family:'Space Mono',monospace;
  font-size:1rem;color:var(--amber);
  letter-spacing:.05em;text-transform:uppercase;
}
.shelf-head h2 .yr{color:var(--cyan);margin-right:6px}
.shelf-head .seeall{
  font-family:'Space Mono',monospace;font-size:.74rem;
  color:var(--cyan);text-decoration:none;
  letter-spacing:1px;text-transform:uppercase;
  white-space:nowrap;
}
.shelf-head .seeall:hover{color:var(--amber)}

.shelf-wrap{position:relative}
.shelf-row{
  display:flex;gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:2px 2px 14px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent;
}
.shelf-row::-webkit-scrollbar{height:8px}
.shelf-row::-webkit-scrollbar-track{background:transparent}
.shelf-row::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.shelf-row::-webkit-scrollbar-thumb:hover{background:var(--cyan-dim)}

.shelf-arrow{
  position:absolute;top:calc(50% - 30px);
  width:36px;height:36px;border-radius:50%;
  background:rgba(13,19,34,.92);border:1px solid var(--border);
  color:var(--cyan);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
  transition:.15s;
  z-index:5;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.shelf-arrow:hover{background:var(--cyan);color:#001220;border-color:var(--cyan)}
.shelf-arrow:disabled{opacity:.25;cursor:default}
.shelf-arrow:disabled:hover{background:rgba(13,19,34,.92);color:var(--cyan);border-color:var(--border)}
.shelf-arrow.prev{left:-8px}
.shelf-arrow.next{right:-8px}
@media(max-width:700px){.shelf-arrow{display:none}}

/* --- Tile (video card in shelf) --- */
.tile{
  flex:0 0 220px;
  scroll-snap-align:start;
  display:flex;flex-direction:column;
  background:transparent;
  text-decoration:none;color:inherit;
  border-radius:8px;
  transition:.15s;
}
.tile:hover{transform:translateY(-2px)}
.tile .tile-thumb{
  position:relative;
  aspect-ratio:16/9;
  background:#000 center/cover no-repeat;
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
}
.tile:hover .tile-thumb{border-color:var(--cyan)}
.tile .tile-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
  background:#000;
}
.tile .tile-thumb::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(56,189,248,.10),rgba(245,158,11,.04));
  pointer-events:none;
}
.tile .tile-thumb .play-glyph{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,.55);
  color:#fff;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  padding-left:3px;
  opacity:0;
  transition:.18s;
  z-index:2;
  pointer-events:none;
}
.tile:hover .tile-thumb .play-glyph{opacity:1;background:rgba(56,189,248,.92);color:#001220}
.tile .tile-thumb .badge-date{
  position:absolute;top:6px;left:6px;
  background:rgba(0,0,0,.78);
  color:var(--cyan);
  font-family:'Space Mono',monospace;font-size:.6rem;
  padding:2px 6px;border-radius:3px;
  letter-spacing:.4px;
  z-index:2;
}
.tile .tile-body{padding:9px 4px 4px}
.tile .tile-title{
  font-size:.86rem;color:#fff;line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  min-height:2.2em;
  margin-bottom:4px;
}
.tile:hover .tile-title{color:var(--cyan)}
.tile .tile-sub{
  font-family:'Space Mono',monospace;font-size:.66rem;
  color:var(--muted);letter-spacing:.4px;
}

/* --- Theme spotlight --- */
.theme-row{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:12px;
  margin:6px 0;
}
.theme-tile{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:10px;
  text-decoration:none;color:inherit;
  transition:.15s;
  position:relative;overflow:hidden;
}
.theme-tile:hover{border-color:var(--cyan);background:var(--card-hover);transform:translateY(-1px)}
.theme-tile .theme-info{flex:1;min-width:0}
.theme-tile .theme-term{
  font-family:'Space Mono',monospace;font-size:.95rem;font-weight:700;
  color:#fff;letter-spacing:-.01em;
  text-transform:lowercase;
}
.theme-tile:hover .theme-term{color:var(--cyan)}
.theme-tile .theme-count{
  font-family:'Space Mono',monospace;font-size:.66rem;
  color:var(--muted);letter-spacing:.5px;text-transform:uppercase;
  margin-top:2px;
}
.theme-tile .theme-thumbs{
  display:flex;gap:3px;flex-shrink:0;
}
.theme-tile .theme-thumbs .mini{
  width:42px;height:28px;border-radius:3px;
  background:#000 center/cover no-repeat;
  border:1px solid var(--border);
  display:block;
}
.theme-tile .theme-thumbs .mini img{
  width:100%;height:100%;object-fit:cover;display:block;border-radius:2px;
}

/* --- Compact nav row at bottom --- */
.compact-nav{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:10px;
  margin:14px 0 6px;
}
.compact-nav .cn{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  text-decoration:none;color:inherit;
  transition:.15s;
}
.compact-nav .cn:hover{
  border-color:var(--cyan);background:var(--card-hover);
}
.compact-nav .cn .ic{
  font-size:1.15rem;width:30px;height:30px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg2);border-radius:6px;
  border:1px solid var(--border);
}
.compact-nav .cn-text{min-width:0;line-height:1.2}
.compact-nav .cn .cn-ti{
  font-family:'Space Mono',monospace;font-size:.78rem;
  font-weight:700;color:#fff;letter-spacing:-.01em;
}
.compact-nav .cn:hover .cn-ti{color:var(--cyan)}
.compact-nav .cn .cn-sub{
  font-family:'Space Mono',monospace;font-size:.62rem;
  color:var(--muted);letter-spacing:.4px;margin-top:2px;
  text-transform:uppercase;
}

/* --- Stats strip (bottom) --- */
.stats-strip{
  margin:30px 0 8px;
  padding:14px 20px;
  background:rgba(56,189,248,.04);
  border:1px solid var(--border-soft);
  border-radius:8px;
  font-family:'Space Mono',monospace;font-size:.78rem;
  color:var(--muted);letter-spacing:.4px;
  text-align:center;line-height:1.7;
}
.stats-strip strong{color:var(--cyan);font-weight:700}
.stats-strip .sep{color:var(--dim);margin:0 8px}
.stats-strip .badge{
  display:inline-block;
  color:var(--gold);letter-spacing:1.5px;text-transform:uppercase;
  font-size:.66rem;
  border:1px solid rgba(232,197,71,.3);padding:2px 8px;border-radius:3px;
  background:rgba(232,197,71,.05);
  margin-left:6px;
}

/* --- Section banner under hero (bio + permission) --- */
.bio-row{
  display:grid;grid-template-columns:1fr;gap:14px;margin:0 0 26px;
}
@media(min-width:760px){.bio-row{grid-template-columns:1.6fr 1fr}}
.bio-row .bio{margin:0}

/* mobile tweaks for hub */
@media(max-width:640px){
  .hero-feat{gap:14px;margin:6px 0 26px}
  .hero-feat .feat-title{font-size:1.25rem}
  .tile{flex-basis:180px}
  .shelf-head h2{font-size:.88rem}
  .stats-strip{font-size:.7rem;padding:12px 14px}
  .stats-strip .sep{margin:0 4px}
}


/* ============================================================
   Era + Topic pages — added 2026-06 (visual expansion)
   ============================================================ */

/* News ticker (old-school CRT chrome) */
.news-ticker{
  position:relative;
  background:linear-gradient(180deg,#0c0c0c 0%,#000 100%);
  border-bottom:1px solid rgba(251,191,36,.35);
  overflow:hidden;
  font-family:"Space Mono",monospace;
  font-size:.78rem;
  letter-spacing:.08em;
  color:var(--amber,#fbbf24);
  text-transform:uppercase;
}
.news-ticker-inner{
  display:flex;align-items:center;gap:10px;
  padding:6px 14px;
  white-space:nowrap;overflow-x:auto;
  scrollbar-width:none;
}
.news-ticker-inner::-webkit-scrollbar{display:none}
.news-ticker .tick-dot{color:#ef4444;animation:tick-blink 1.6s steps(2,end) infinite}
.news-ticker .tick-brand{font-weight:700;color:#fff;text-shadow:0 0 8px rgba(251,191,36,.35)}
.news-ticker .tick-sep{color:rgba(251,191,36,.45)}
.news-ticker .tick-text{color:rgba(255,255,255,.85)}
.news-ticker .tick-live{
  margin-left:auto;color:#ef4444;
  border:1px solid rgba(239,68,68,.4);
  padding:1px 8px;border-radius:2px;
  animation:tick-blink 1.8s steps(2,end) infinite;
}
@keyframes tick-blink{50%{opacity:.35}}
@media (max-width:600px){
  .news-ticker-inner{padding:5px 10px;font-size:.7rem;gap:7px}
  .news-ticker .tick-live{margin-left:8px}
}

/* Era navigation strip */
.era-nav{
  display:flex;flex-wrap:wrap;gap:6px;
  margin:10px 0 6px;
  font-family:"Space Mono",monospace;
  font-size:.78rem;
}
.era-nav a{
  display:inline-block;
  padding:5px 10px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:3px;
  color:var(--muted,#9aa1ab);
  text-decoration:none;
  letter-spacing:.04em;
}
.era-nav a:hover{border-color:var(--amber,#fbbf24);color:#fff}
.era-nav a.active{
  border-color:var(--amber,#fbbf24);
  color:var(--amber,#fbbf24);
  background:rgba(251,191,36,.06);
}

/* Long-form synthesis prose */
.prose{
  max-width:72ch;
  color:rgba(255,255,255,.85);
  font-size:1rem;line-height:1.62;
}
.prose p{margin:0 0 14px}
.prose h1,.prose h2,.prose h3{color:#fff;margin:24px 0 10px}
.prose h1{font-size:1.45rem}
.prose h2{font-size:1.2rem}
.prose h3{font-size:1.05rem}
.prose a{color:var(--amber,#fbbf24);text-decoration:none;border-bottom:1px dotted rgba(251,191,36,.5)}
.prose a:hover{border-bottom-style:solid}
.prose code{
  background:rgba(255,255,255,.06);
  padding:1px 5px;border-radius:3px;
  font-family:"Space Mono",monospace;font-size:.9em;
}
.prose ul{margin:0 0 14px 0;padding-left:1.2em}
.prose li{margin:0 0 6px 0}

/* Episode thumbnail grid (used by era + topic + gallery pages) */
.ep-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:14px;
  margin:14px 0 24px;
}
.ep-card{
  display:block;
  text-decoration:none;color:inherit;
  border:1px solid rgba(255,255,255,.07);
  border-radius:4px;
  overflow:hidden;
  background:rgba(255,255,255,.02);
  transition:transform .15s,border-color .15s;
}
.ep-card:hover{
  border-color:var(--amber,#fbbf24);
  transform:translateY(-2px);
}
.ep-card-thumb{
  position:relative;
  aspect-ratio:16/9;
  background:#0a0a0a;
  overflow:hidden;
}
.ep-card-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.ep-card-date{
  position:absolute;top:6px;left:6px;
  font-family:"Space Mono",monospace;
  font-size:.66rem;letter-spacing:.04em;
  background:rgba(0,0,0,.78);
  color:var(--amber,#fbbf24);
  padding:2px 6px;border-radius:2px;
}
.ep-card-play{
  position:absolute;right:6px;bottom:6px;
  font-size:.85rem;
  background:rgba(0,0,0,.78);
  color:#fff;
  padding:1px 7px 2px;border-radius:2px;
  opacity:.85;
}
.ep-card-title{
  padding:8px 10px 10px;
  font-size:.86rem;line-height:1.32;
  color:rgba(255,255,255,.92);
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:3.5em;
}
@media (max-width:600px){
  .ep-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
  .ep-card-title{font-size:.78rem;padding:6px 8px 8px}
}

/* Era hub: big editorial cards */
.era-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:18px;
  margin:14px 0 24px;
}
.era-card{
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  border:1px solid rgba(255,255,255,.08);
  border-radius:5px;overflow:hidden;
  background:rgba(255,255,255,.02);
  transition:transform .15s,border-color .15s;
}
.era-card:hover{
  border-color:var(--amber,#fbbf24);
  transform:translateY(-2px);
}
.era-card-thumb{aspect-ratio:16/9;background:#0a0a0a;overflow:hidden}
.era-card-thumb img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.8) brightness(.85)}
.era-card-body{padding:14px 16px 16px}
.era-card-kicker{
  font-family:"Space Mono",monospace;
  font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--amber,#fbbf24);margin-bottom:6px;
}
.era-card-title{
  font-size:1.3rem;font-weight:700;color:#fff;
  margin-bottom:8px;letter-spacing:.02em;
}
.era-card-lede{
  font-size:.88rem;line-height:1.5;
  color:rgba(255,255,255,.7);
}
@media (max-width:600px){
  .era-grid{grid-template-columns:1fr;gap:12px}
  .era-card-title{font-size:1.15rem}
}

/* Topic hub mini-cards */
.topic-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:12px;
  margin:14px 0 24px;
}
.topic-card{
  display:block;text-decoration:none;color:inherit;
  border:1px solid rgba(255,255,255,.08);
  border-radius:4px;padding:14px 16px;
  background:rgba(255,255,255,.02);
  transition:border-color .15s,background .15s;
}
.topic-card:hover{
  border-color:var(--amber,#fbbf24);
  background:rgba(251,191,36,.05);
}
.topic-card-name{
  font-family:"Space Mono",monospace;
  font-size:1.05rem;color:var(--amber,#fbbf24);
  font-weight:700;letter-spacing:.05em;
  text-transform:lowercase;
}
.topic-card-name::before{content:"#";opacity:.6;margin-right:1px}
.topic-card-count{
  display:block;margin-top:4px;
  font-size:.78rem;color:var(--muted,#9aa1ab);
  font-family:"Space Mono",monospace;
}
.topic-card-blurb{
  margin-top:6px;font-size:.82rem;line-height:1.4;
  color:rgba(255,255,255,.7);
}

/* Episode page: era badge + topic chips row */
.ep-meta-row{
  display:flex;flex-wrap:wrap;gap:6px;align-items:center;
  margin:10px 0 14px;
  font-family:"Space Mono",monospace;
  font-size:.78rem;
}
.ep-meta-row .ep-era-badge{
  background:rgba(251,191,36,.12);
  color:var(--amber,#fbbf24);
  border:1px solid rgba(251,191,36,.4);
  padding:4px 9px;border-radius:3px;
  text-decoration:none;letter-spacing:.05em;
  text-transform:uppercase;
}
.ep-meta-row .ep-era-badge:hover{background:rgba(251,191,36,.22)}
.ep-meta-row .ep-topic-chip{
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.12);
  padding:3px 8px;border-radius:3px;
  text-decoration:none;
}
.ep-meta-row .ep-topic-chip::before{content:"#";opacity:.5;margin-right:1px}
.ep-meta-row .ep-topic-chip:hover{
  border-color:var(--amber,#fbbf24);
  color:var(--amber,#fbbf24);
}
.ep-meta-row .ep-meta-label{color:var(--muted,#9aa1ab);margin-right:4px}
