:root{
  --bg:#FAF7F0; --bg-deep:#F4EFE4; --surface:#FFFFFF; --surface-2:#F5F1E8;
  --line:#E4DCCA; --text:#1F2733; --ink:#1F2733; --muted:#6E7889;
  --amber:#FFB020; --amber-ink:#A96F00; --amber-soft:rgba(255,176,32,.16);
  --radius:14px;
  --font-display:'Righteous', system-ui, sans-serif;
  --font-body:'DM Sans', system-ui, sans-serif;
  --font-mono:'IBM Plex Mono', ui-monospace, monospace;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation:none !important; transition:none !important;}
}
body{background:var(--bg); color:var(--text); font-family:var(--font-body); line-height:1.55; min-height:100vh;}
a{color:inherit;}
button{font-family:inherit; cursor:pointer;}
:focus-visible{outline:2px solid var(--amber-ink); outline-offset:2px; border-radius:4px;}

/* ---------- Top bar ---------- */
.topbar{
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
  padding:18px clamp(16px,4vw,48px); border-bottom:1px solid var(--line);
  background:var(--surface); position:sticky; top:0; z-index:40;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none;}
.brand-name{font-family:var(--font-display); font-size:1.35rem; letter-spacing:.02em; line-height:1;}
.brand-name span{color:var(--amber-ink);}
.brand-tag{font-family:var(--font-mono); font-size:.62rem; letter-spacing:.14em; color:var(--muted); text-transform:uppercase; display:block; margin-top:3px;}
.topnav{margin-left:auto; display:flex; gap:4px; flex-wrap:wrap;}
.topnav a{
  text-decoration:none; font-weight:500; font-size:.92rem; color:var(--muted);
  padding:8px 14px; border-radius:999px; border:1px solid transparent;
}
.topnav a:hover{color:var(--text); border-color:var(--line); background:var(--bg);}

/* ---------- Heroes ---------- */
.hero{
  position:relative; overflow:hidden;
  padding:clamp(40px,7vw,84px) clamp(16px,4vw,48px) clamp(36px,6vw,72px);
  border-bottom:1px solid var(--line);
  background:radial-gradient(1100px 420px at 18% -10%, var(--hero-glow, rgba(255,176,32,.20)), transparent 62%), var(--bg-deep);
}
.hero::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(31,39,51,.02) 0 1px, transparent 1px 4px);
}
.hero-inner{max-width:1120px; margin:0 auto; position:relative; z-index:1;
  display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(24px,4vw,56px); align-items:center;}
.on-air{
  display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono);
  font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--amber-ink); border:1px solid var(--amber); border-radius:4px;
  background:var(--surface); padding:5px 10px; margin-bottom:18px;
}
.on-air .dot{width:7px; height:7px; border-radius:50%; background:var(--amber); animation:blink 1.6s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.25;}}
.hero h1{font-family:var(--font-display); font-weight:400; font-size:clamp(2.3rem,5.6vw,4.2rem); line-height:1.04; margin-bottom:14px;}
.hero h1 em, .page-hero h1 em{font-style:normal; color:color-mix(in srgb, var(--hero-accent, var(--amber-ink)) 75%, var(--ink));}
.lede{color:var(--muted); font-size:clamp(.98rem,1.5vw,1.12rem); max-width:52ch;}
.hero .lede{margin-bottom:26px;}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap;}
.btn-solid{
  background:var(--hero-accent, var(--amber)); color:#fff; border:none;
  border-radius:999px; padding:12px 24px; font-weight:700; font-size:.95rem;
  text-decoration:none; display:inline-block; transition:transform .12s ease, filter .12s ease;
  box-shadow:0 2px 10px color-mix(in srgb, var(--hero-accent, var(--amber)) 35%, transparent);
}
.btn-solid:hover{transform:translateY(-1px); filter:brightness(1.05);}
.btn-ghost{
  background:var(--surface); color:var(--text); border:1px solid var(--line);
  border-radius:999px; padding:12px 24px; font-weight:500; font-size:.95rem; text-decoration:none; display:inline-block;
}
.btn-ghost:hover{border-color:var(--muted);}

.page-hero{
  padding:clamp(32px,5vw,60px) clamp(16px,4vw,48px);
  border-bottom:1px solid var(--line);
  background:radial-gradient(900px 340px at 12% -20%, color-mix(in srgb, var(--c, var(--amber)) 18%, transparent), transparent 62%), var(--bg-deep);
}
.page-hero h1{font-family:var(--font-display); font-weight:400; font-size:clamp(1.8rem,4.2vw,3rem); line-height:1.1; margin:10px 0 12px; max-width:1120px;}
.page-hero h1 em{color:color-mix(in srgb, var(--c, var(--amber-ink)) 70%, var(--ink));}
.page-hero .crumb, .page-hero .lede{max-width:1120px;}
.page-hero-flex{display:flex; gap:24px; align-items:center; max-width:1120px;}
.crumb{font-family:var(--font-mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);}
.crumb a{color:var(--muted); text-decoration:none;}
.crumb a:hover{color:var(--amber-ink);}

/* ---------- Feature card ---------- */
.feature-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px 24px; box-shadow:0 18px 44px rgba(31,39,51,.10);
}
.feature-card .label{font-family:var(--font-mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:12px; display:block;}
.fc-row{display:flex; justify-content:space-between; align-items:center; gap:10px;}
.fc-show{font-weight:700; font-size:1.05rem;}
.fc-title{font-family:var(--font-display); font-weight:400; font-size:1.5rem; line-height:1.2; margin:4px 0 10px;}
.fc-why{color:var(--muted); font-size:.94rem;}
.epcode{font-family:var(--font-mono); font-size:.72rem; font-weight:600; letter-spacing:.08em; color:#fff; background:var(--amber); border-radius:4px; padding:3px 8px; display:inline-block;}

/* ---------- Listings ---------- */
main{padding:clamp(28px,4vw,52px) clamp(16px,4vw,48px) 80px; max-width:1240px; margin:0 auto;}
.section-head{display:flex; align-items:baseline; gap:14px; margin:38px 0 18px;}
.section-head:first-child{margin-top:0;}
.section-head h2{font-family:var(--font-display); font-weight:400; font-size:clamp(1.4rem,2.6vw,1.9rem);}
.section-head h2 a{text-decoration:none;}
.section-head h2 a:hover{color:color-mix(in srgb, var(--c, var(--amber-ink)) 70%, var(--ink));}
.section-head .count{font-family:var(--font-mono); font-size:.72rem; color:var(--muted); letter-spacing:.1em;}
.section-head .bar{flex:1; height:2px; border-radius:2px; background:var(--c, var(--line)); opacity:.45;}
.grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:16px;}
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:18px 18px 16px; position:relative; overflow:hidden;
  display:flex; flex-direction:column; gap:8px; text-decoration:none;
  box-shadow:0 1px 3px rgba(31,39,51,.05);
  transition:transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.card::before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--c, var(--amber));}
.card:hover{transform:translateY(-2px); border-color:var(--c, var(--amber)); box-shadow:0 8px 22px rgba(31,39,51,.10);}
.card .row{display:flex; align-items:center; justify-content:space-between; gap:10px;}
.card .show{font-weight:700; font-size:.85rem; letter-spacing:.02em; color:var(--muted); text-transform:uppercase; text-decoration:none;}
a.show:hover{color:color-mix(in srgb, var(--c, var(--amber-ink)) 70%, var(--ink));}
.card .code{
  font-family:var(--font-mono); font-size:.7rem; font-weight:600; letter-spacing:.06em;
  color:color-mix(in srgb, var(--c, var(--amber-ink)) 70%, var(--ink));
  border:1px solid currentColor; border-radius:4px; padding:2px 7px;
}
.card h3{font-size:1.12rem; line-height:1.3; font-weight:700;}
.card h3 .yr{font-weight:400; color:var(--muted); font-size:.9rem;}
.card .why{color:var(--muted); font-size:.9rem; flex:1;}
.card .meta{font-family:var(--font-mono); font-size:.68rem; color:var(--muted); letter-spacing:.08em;}
.cat-card h3{font-family:var(--font-display); font-weight:400; font-size:1.3rem;}
.card.wide{max-width:820px;}

/* Show posters & fallback tiles */
.show-card{flex-direction:row; align-items:center; gap:14px;}
.show-card .poster, .show-card .tile{flex:0 0 56px; width:56px; height:78px; border-radius:8px; object-fit:cover; border:1px solid var(--line);}
.show-card .tile{
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:1.6rem; color:#fff;
  background:linear-gradient(160deg, var(--amber), #E8842B);
}
.show-card .sc-body{display:flex; flex-direction:column; gap:5px; min-width:0;}
.poster-hero{width:92px; height:128px; border-radius:10px; object-fit:cover; border:1px solid var(--line); box-shadow:0 10px 26px rgba(31,39,51,.14); flex:0 0 auto;}

.ranked{list-style:none; display:flex; flex-direction:column; gap:14px; counter-reset:ep;}
.ranked li{counter-increment:ep; display:flex; gap:16px; align-items:stretch;}
.ranked li::before{
  content:counter(ep, decimal-leading-zero);
  font-family:var(--font-mono); font-size:.8rem; font-weight:600; color:var(--muted);
  padding-top:20px; min-width:28px;
}
.ranked .card{flex:1;}

.tag-cloud{display:flex; gap:10px; flex-wrap:wrap;}
.chip{
  display:inline-flex; align-items:center; gap:8px; white-space:nowrap;
  background:var(--surface); border:1px solid var(--line); color:var(--text);
  border-radius:999px; padding:8px 16px; font-size:.88rem; font-weight:500;
  text-decoration:none; transition:border-color .15s ease;
}
.chip .swatch{width:9px; height:9px; border-radius:50%; background:var(--c, var(--amber));}
.chip:hover{border-color:var(--c, var(--amber));}

.empty{text-align:center; color:var(--muted); padding:70px 20px; border:1px dashed var(--line); border-radius:var(--radius); background:var(--surface);}
.empty strong{color:var(--text); display:block; font-size:1.1rem; margin-bottom:6px;}
.empty a{color:var(--amber-ink) !important;}

footer{border-top:1px solid var(--line); padding:26px clamp(16px,4vw,48px); color:var(--muted); font-size:.85rem; text-align:center; background:var(--surface);}
footer a{color:var(--amber-ink);}

/* ---------- Admin ---------- */
.admin-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:24px;}
.panel{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px; box-shadow:0 1px 3px rgba(31,39,51,.05);}
.panel h3{font-family:var(--font-mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--amber-ink); margin-bottom:14px; font-weight:600;}
.login-box{max-width:380px; margin:60px auto;}
.field{margin-bottom:12px;}
.field label{display:block; font-size:.8rem; color:var(--muted); margin-bottom:5px; font-weight:500;}
.field input, .field select, .field textarea{
  width:100%; background:var(--surface-2); border:1px solid var(--line); color:var(--text);
  border-radius:8px; padding:9px 12px; font-family:var(--font-body); font-size:.92rem;
}
.field input[type=color]{height:38px; padding:3px;}
.field textarea{resize:vertical; min-height:64px;}
.field-row{display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px;}
.tv-results{display:flex; flex-direction:column; gap:6px; margin-top:10px; max-height:180px; overflow:auto;}
.tv-result{text-align:left; background:var(--surface-2); border:1px solid var(--line); color:var(--text); border-radius:8px; padding:8px 12px; font-size:.88rem;}
.tv-result:hover{border-color:var(--amber);}
.yr{color:var(--muted); font-family:var(--font-mono); font-size:.72rem; margin-left:6px;}
.hint{font-size:.8rem; color:var(--muted); margin-top:8px;}
.hint a{color:var(--amber-ink);}
.toast{font-size:.88rem; color:#2E7D46; font-weight:500;}
.toast.err{color:#C43E36;}
.toast.banner{display:block; background:var(--surface); border:1px solid var(--line); border-radius:8px; padding:10px 16px; margin-bottom:18px;}
.btn-sm{background:var(--surface-2); border:1px solid var(--line); color:var(--text); border-radius:8px; padding:8px 14px; font-size:.84rem; font-weight:500; text-decoration:none;}
.btn-sm:hover{border-color:var(--amber);}
.admin-table{width:100%; border-collapse:collapse; font-size:.88rem;}
.admin-table td{padding:7px 6px; border-bottom:1px solid var(--line); vertical-align:middle;}
.admin-table .swatch{display:inline-block; width:9px; height:9px; border-radius:50%; background:var(--c, var(--amber));}
.del-btn{background:none; border:1px solid var(--line); color:var(--muted); width:24px; height:24px; border-radius:50%; font-size:.75rem; line-height:1;}
.del-btn:hover{border-color:#C43E36; color:#C43E36;}

/* ---------- Review queue ---------- */
.queue-filter{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px;}
.queue-filter input[type=text]{
  flex:1 1 260px; background:var(--surface-2); border:1px solid var(--line); color:var(--text);
  border-radius:8px; padding:8px 12px; font-family:var(--font-body); font-size:.9rem;
}
.queue-table td.src{width:28px;}
.queue-table td.ep-info{min-width:220px;}
.queue-row{display:flex; gap:8px; align-items:center; flex-wrap:wrap;}
.queue-row select{max-width:170px; background:var(--surface-2); border:1px solid var(--line); color:var(--text); border-radius:8px; padding:7px 8px; font-size:.84rem;}
.queue-row input[type=text]{flex:1 1 180px; background:var(--surface-2); border:1px solid var(--line); color:var(--text); border-radius:8px; padding:7px 10px; font-size:.84rem;}
.btn-sm.ok{border-color:#2E7D46; color:#2E7D46;}
.btn-sm.ok:hover{background:#2E7D46; color:#fff;}
.btn-sm.danger{border-color:var(--line);}
.btn-sm.danger:hover{border-color:#C43E36; color:#C43E36;}
@media (max-width:700px){ .queue-table td.actions{display:block;} }

/* ---------- Starter pack log (stays dark, it's a console) ---------- */
.pack-log{
  margin-top:14px; max-height:220px; overflow:auto;
  background:#1F2733; border:1px solid #34404F; border-radius:8px;
  padding:12px 14px; font-family:var(--font-mono); font-size:.74rem; line-height:1.7;
  color:#B9C2CF; white-space:pre-wrap;
}
.pack-log .ok{color:#7BD88F;}
.pack-log .err{color:#F08A84;}

@media (max-width:860px){
  .hero-inner{grid-template-columns:1fr;}
  .admin-grid{grid-template-columns:1fr;}
  .field-row{grid-template-columns:1fr 1fr;}
}

/* ---------- Admin tabs & episode browser ---------- */
.admin-tabs{display:flex; gap:8px; margin-bottom:20px;}
.admin-tabs a{
  text-decoration:none; font-weight:600; font-size:.9rem; color:var(--muted);
  padding:9px 18px; border-radius:999px; border:1px solid var(--line); background:var(--surface);
}
.admin-tabs a.active{background:var(--amber); border-color:var(--amber); color:#fff;}
.admin-tabs a:not(.active):hover{border-color:var(--amber);}
.ep-list{display:flex; flex-direction:column; gap:8px;}
.ep-edit{
  display:flex; gap:6px; align-items:center; flex-wrap:wrap;
  padding:8px 10px 8px 14px; border:1px solid var(--line); border-radius:10px;
  background:var(--surface); position:relative; overflow:hidden;
}
.ep-edit::before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--c, var(--amber));}
.ep-edit input, .ep-edit select{
  background:var(--surface-2); border:1px solid var(--line); color:var(--text);
  border-radius:7px; padding:6px 8px; font-size:.82rem; font-family:var(--font-body);
}
.ep-edit select{max-width:150px;}
.ep-edit .grow{flex:1 1 150px; min-width:120px;}
.ep-edit .grow-2{flex:2 1 220px; min-width:150px;}
.ep-edit .w-code{width:78px; font-family:var(--font-mono); font-size:.74rem;}
.ep-edit .w-year{width:70px;}
.pager{display:flex; gap:12px; align-items:center; justify-content:center; margin-top:16px;}
@media (max-width:700px){ .ep-edit select{max-width:none; flex:1 1 45%;} }

/* ---------- Bulk approve bar ---------- */
.bulk-bar{
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
  background:var(--amber-soft); border:1px solid var(--amber); border-radius:10px;
  padding:10px 14px; margin-bottom:14px; font-size:.9rem;
}
.bulk-bar select{background:var(--surface); border:1px solid var(--line); border-radius:8px; padding:7px 10px; font-size:.86rem;}

/* ---------- Episode stills ---------- */
.ep-still{
  width:100%; aspect-ratio:16/9; object-fit:cover;
  border-radius:8px; border:1px solid var(--line); margin-bottom:4px; display:block;
}
.feature-card .ep-still{margin-bottom:12px;}

/* ---------- Search box + category filter toolbar ---------- */
.nav-search input{
  background:var(--surface-2); border:1px solid var(--line); color:var(--text);
  border-radius:999px; padding:8px 16px; font-family:var(--font-body); font-size:.88rem; width:190px;
}
.nav-search input:focus{outline:none; border-color:var(--amber);}
.cat-toolbar{
  display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:18px;
  background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:10px 14px;
}
.cat-toolbar input, .cat-toolbar select{
  background:var(--surface-2); border:1px solid var(--line); color:var(--text);
  border-radius:8px; padding:8px 12px; font-family:var(--font-body); font-size:.88rem;
}
.cat-toolbar input{flex:1 1 220px;}
@media (max-width:700px){ .nav-search{flex:1 1 100%;} .nav-search input{width:100%;} }

/* ---------- Category icons ---------- */
.cat-icon-wrap{display:inline-flex; vertical-align:-5px; margin-right:9px;}
.cat-icon-hero{display:inline-flex; vertical-align:-7px; margin-right:12px;}
.cat-icon{flex:0 0 auto;}

/* ---------- Where to watch ---------- */
.card-foot{display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap;}
.watch{
  font-size:.78rem; font-weight:600; color:var(--amber-ink); text-decoration:none;
  white-space:nowrap; border-bottom:1px solid transparent;
}
.watch:hover{border-bottom-color:var(--amber-ink);}
.feature-card .watch{display:inline-block; margin-top:12px; font-size:.86rem;}
