/* CONSTRUCT — dialogue-lab theme.
 *
 * Loaded after style.css. The shared public-site layout, player, feed links,
 * episode ledger, source pages, and responsive rules stay reusable; this file
 * only swaps the show-level visual system and multi-host details.
 */

/* ---- Accent override ---- */
body.show-construct {
  --bg: #050708;
  --panel: #0d1114;
  --fg: #e8f4ee;
  --muted: #78918b;
  --dim: #b8c8c2;
  --line: #172327;
  --rule: #294045;
  --acc: #7ee7c2;
  --construct-blue: #5aa7ff;
  --construct-violet: #b29cff;
  --construct-amber: #f0d66a;
  --construct-red: #ff6b6b;
  background:
    linear-gradient(90deg, rgba(126, 231, 194, 0.055) 1px, transparent 1px),
    linear-gradient(180deg, rgba(90, 167, 255, 0.045) 1px, transparent 1px),
    var(--bg);
  background-size: 48px 48px, 48px 48px, auto;
}

/* Light mode — minimal palette swap. The construct-specific decorative
 * overlays (mast-braid, art-plate gridlines) still read as the rgba accent
 * lines they were; only the surface tokens change. */
@media (prefers-color-scheme: light) {
  html:not([data-theme="dark"]) body.show-construct {
    --bg: #f4faf7;
    --panel: #e6efeb;
    --fg: #0d1f1a;
    --muted: #4a655e;
    --dim: #2b3d38;
    --line: #d1e0db;
    --rule: #b5c8c2;
    --acc: #1f8c63;
  }
}
html[data-theme="light"] body.show-construct {
  --bg: #f4faf7;
  --panel: #e6efeb;
  --fg: #0d1f1a;
  --muted: #4a655e;
  --dim: #2b3d38;
  --line: #d1e0db;
  --rule: #b5c8c2;
  --acc: #1f8c63;
}
body.show-construct .mast {
  border-bottom: 1px solid var(--rule);
}
body.show-construct .mast-name {
  color: var(--fg);
  letter-spacing: 0;
}
body.show-construct .mast-kicker,
body.show-construct .kicker,
body.show-construct .stamp .acc {
  color: var(--acc);
}
body.show-construct .mast-lede-band {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(90deg, rgba(126, 231, 194, 0.08), transparent 28%, rgba(178, 156, 255, 0.07)),
    rgba(13, 17, 20, 0.72);
}
body.show-construct .mast-braid {
  color: var(--construct-blue);
  opacity: 0.2;
}
body.show-construct .mast-lede,
body.show-construct .crew-lede,
body.show-construct .sub-lede,
body.show-construct .foot-blurb {
  color: var(--dim);
}
body.show-construct .hero-title,
body.show-construct .rdr-headline {
  color: var(--fg);
  letter-spacing: 0;
  text-wrap: balance;
}
body.show-construct .sec-title,
body.show-construct .host-name,
body.show-construct .ep-title,
body.show-construct .foot-brand,
body.show-construct .sn h1,
body.show-construct .rdr-headline {
  letter-spacing: 0;
}
body.show-construct .hero-blurb {
  color: var(--fg);
  border-top-color: var(--rule);
}
body.show-construct .hero-quote,
body.show-construct .sn .sn-quote,
body.show-construct .rdr-pullquote {
  background: rgba(13, 17, 20, 0.86);
  border-left-color: var(--construct-violet);
  box-shadow: inset 0 0 0 1px rgba(178, 156, 255, 0.16);
}
body.show-construct .hero-quote cite,
body.show-construct .sn .sn-quote cite,
body.show-construct .rdr-pullquote cite {
  color: var(--construct-violet);
}
@media (prefers-color-scheme: light) {
  html:not([data-theme="dark"]) body.show-construct .hero-quote,
  html:not([data-theme="dark"]) body.show-construct .sn .sn-quote,
  html:not([data-theme="dark"]) body.show-construct .rdr-pullquote {
    background: color-mix(in srgb, var(--construct-violet) 12%, var(--panel));
    border-left-color: var(--construct-violet);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--construct-violet) 22%, transparent);
  }
  html:not([data-theme="dark"]) body.show-construct .mast-lede-band {
    background: color-mix(in srgb, var(--acc) 6%, var(--panel));
  }
  html:not([data-theme="dark"]) body.show-construct .player {
    background: var(--panel);
  }
  html:not([data-theme="dark"]) body.show-construct .sub-card {
    background: var(--panel);
  }
  html:not([data-theme="dark"]) body.show-construct .site-foot {
    background: transparent;
  }
}
html[data-theme="light"] body.show-construct .hero-quote,
html[data-theme="light"] body.show-construct .sn .sn-quote,
html[data-theme="light"] body.show-construct .rdr-pullquote {
  background: color-mix(in srgb, var(--construct-violet) 12%, var(--panel));
  border-left-color: var(--construct-violet);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--construct-violet) 22%, transparent);
}
html[data-theme="light"] body.show-construct .mast-lede-band {
  background: color-mix(in srgb, var(--acc) 6%, var(--panel));
}
html[data-theme="light"] body.show-construct .player {
  background: var(--panel);
}
html[data-theme="light"] body.show-construct .sub-card {
  background: var(--panel);
}
html[data-theme="light"] body.show-construct .site-foot {
  background: transparent;
}
body.show-construct .art-plate {
  background: #020405;
  border-color: rgba(126, 231, 194, 0.46);
  box-shadow: 0 0 0 1px rgba(90, 167, 255, 0.18), 0 24px 70px rgba(0, 0, 0, 0.38);
}
body.show-construct .art-plate::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(126, 231, 194, 0.16) 1px, transparent 1px),
    linear-gradient(180deg, rgba(126, 231, 194, 0.12) 1px, transparent 1px);
  background-size: 24px 24px;
  mix-blend-mode: screen;
  opacity: 0.14;
}
body.show-construct .art-plate img,
body.show-construct .host-portrait img,
body.show-construct .ep-thumb {
  filter: saturate(1.04) contrast(1.08);
}
body.show-construct .meta-val,
body.show-construct .stat-val,
body.show-construct .ep-num,
body.show-construct .foot-brand {
  color: var(--acc);
}
body.show-construct .player {
  background: rgba(13, 17, 20, 0.9);
  border-color: var(--rule);
}
body.show-construct .pl-btn,
body.show-construct .sub-card.big {
  background: var(--acc);
  color: #04100d;
}
body.show-construct .sub-card {
  background: rgba(13, 17, 20, 0.72);
}
body.show-construct .sub-card:hover {
  border-color: var(--acc);
  box-shadow: inset 0 -3px 0 var(--acc);
}
body.show-construct .ep {
  border-bottom-color: var(--line);
}
body.show-construct .ep-card {
  position: relative;
}
body.show-construct .ep-card::before {
  content: "";
  position: absolute;
  left: 72px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: linear-gradient(var(--acc), transparent);
  opacity: 0.26;
}
body.show-construct .ep-thumb {
  border-color: rgba(126, 231, 194, 0.38);
}
body.show-construct .site-foot {
  background: rgba(13, 17, 20, 0.42);
}

/* ---- Crew section: multi-host grid (overrides .crew single-host card) ---- */
.crew-multihost .host-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  margin-top: 16px;
}
@media (max-width: 880px) {
  .crew-multihost .host-grid {
    grid-template-columns: 1fr;
  }
}
.crew-multihost .host-card-multi {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  background:
    linear-gradient(180deg, rgba(126, 231, 194, 0.055), transparent 42%),
    var(--panel);
  border: 1px solid rgba(126, 231, 194, 0.28);
  border-top: 4px solid var(--host-accent, var(--acc));
}
.crew-multihost .host-portrait {
  margin: 0;
  background: #020405;
  border: 1px solid rgba(126, 231, 194, 0.22);
}
.crew-multihost .host-portrait img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}
.crew-multihost .host-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.crew-multihost .host-swatch {
  width: 18px;
  height: 18px;
  display: inline-block;
  background: var(--host-accent, var(--acc));
  box-shadow: 0 0 0 4px rgba(126, 231, 194, 0.08);
}
.crew-multihost .host-name {
  margin: 0;
  font-family: var(--display);
  font-weight: 700;
  font-size: 20px;
  color: var(--fg);
}
.crew-multihost .host-role {
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--host-accent, var(--acc));
}
.crew-multihost .host-bio {
  margin: 6px 0 0;
  color: var(--dim);
}
.crew-multihost .host-stack {
  margin: 8px 0 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--muted);
  line-height: 1.6;
}
.crew-multihost .host-stack-label {
  display: inline-block;
  width: 64px;
  color: var(--acc);
  text-transform: uppercase;
}

/* ---- Episode page: speaker badges + transcript turn blocks ---- */
body.construct-episode {
  background:
    linear-gradient(90deg, rgba(126, 231, 194, 0.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(90, 167, 255, 0.04) 1px, transparent 1px),
    var(--bg);
  background-size: 48px 48px, 48px 48px, auto;
}
body.show-construct .sn {
  max-width: 980px;
}
body.show-construct .sn h1 {
  color: var(--fg);
}
.sn-speaker-badges {
  list-style: none;
  padding: 0;
  margin: 16px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.sn-speaker-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: rgba(13, 17, 20, 0.88);
  border: 1px solid rgba(126, 231, 194, 0.22);
  border-left: 3px solid var(--host-accent, var(--acc));
  font-family: var(--mono);
  font-size: 12px;
  color: var(--fg);
}
.sn-speaker-swatch {
  width: 10px;
  height: 10px;
  display: inline-block;
  background: var(--host-accent, var(--acc));
}

.sn-transcript {
  margin: 32px 0;
}
.sn-turn-list {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.sn-turn {
  padding: 14px 18px;
  background: rgba(13, 17, 20, 0.88);
  border: 1px solid rgba(126, 231, 194, 0.18);
  border-left: 4px solid var(--host-accent, var(--acc));
  scroll-margin-top: 24px;
}
.sn-turn-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.sn-turn-swatch {
  width: 12px;
  height: 12px;
  display: inline-block;
  background: var(--host-accent, var(--acc));
}
.sn-turn-host {
  font-family: var(--display);
  font-weight: 700;
  color: var(--fg);
}
.sn-turn-time {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--muted);
}
.sn-turn-text {
  margin: 0;
  color: var(--dim);
  line-height: 1.65;
}
.sn-turn-sources {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
}
.sn-turn-sources li {
  padding: 2px 8px;
  background: rgba(126, 231, 194, 0.08);
  border: 1px solid rgba(126, 231, 194, 0.2);
}
.sn-turn-sources a {
  color: var(--acc);
}
.sn-source-ref {
  font-family: var(--mono);
  color: var(--muted);
}

.sn-hosts-foot {
  margin-top: 32px;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
}
.sn-host-runtime-list {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sn-host-runtime {
  display: grid;
  grid-template-columns: 14px 1fr 1fr 2fr;
  gap: 12px;
  align-items: center;
  padding: 8px 12px;
  background: rgba(13, 17, 20, 0.88);
  border: 1px solid rgba(126, 231, 194, 0.18);
  border-left: 3px solid var(--host-accent, var(--acc));
  font-family: var(--mono);
  font-size: 12px;
}
.sn-host-swatch {
  width: 12px;
  height: 12px;
  display: inline-block;
  background: var(--host-accent, var(--acc));
}
.sn-host-name {
  color: var(--fg);
}
.sn-host-role {
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--host-accent, var(--acc));
}
.sn-host-tech {
  color: var(--muted);
}

@media (max-width: 560px) {
  body.show-construct .ep-card::before {
    display: none;
  }
  .sn-host-runtime {
    grid-template-columns: 14px 1fr;
  }
  .sn-host-role,
  .sn-host-tech {
    grid-column: 2;
  }
}
