:root {
  --bg: #101316;
  --panel: #181d22;
  --card-edge: #2a323b;
  --ink: #e6eaee;
  --ink-dim: #9aa4ae;
  --ink-faint: #6b7680;
  --accent: #c9a861;
  --adjudicated: #3fa37c;
  --official: #5b8fc9;
  --reported: #c9a861;
  --allegation: #c97f4f;
  --unverified: #a05a5a;
  --clarification: #7d8fc9;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
[hidden] { display: none !important; }
body { background: #000; color: var(--ink); font: 15px/1.6 -apple-system, "Segoe UI", Helvetica, Arial, sans-serif; }
kbd { background: var(--panel); border: 1px solid var(--card-edge); border-radius: 3px; padding: 0 5px; font-size: 12px; }
a { color: var(--accent); }

/* ===== Setup ===== */
#setup { background: var(--bg); min-height: 100vh; padding: 30px 16px 60px; }
.setup-inner { max-width: 720px; margin: 0 auto; }
#setup h1 { font-family: Georgia, serif; font-size: 28px; }
.lede { color: var(--ink-dim); margin: 8px 0 24px; }
#setup h2 { font-size: 14px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent); margin: 26px 0 10px; }

.preset {
  display: block; width: 100%; text-align: left; cursor: pointer;
  background: var(--panel); border: 1px solid var(--card-edge); border-radius: 6px;
  color: var(--ink); padding: 12px 14px; margin-bottom: 8px; font-size: 14px;
}
.preset:hover { border-color: var(--accent); }
.preset .meta { color: var(--ink-faint); font-size: 12px; display: block; margin-top: 2px; }
.preset-actions { display: flex; gap: 6px; margin-top: 8px; }
.mini {
  background: var(--bg); border: 1px solid var(--card-edge); border-radius: 4px;
  color: var(--accent); font-size: 12px; font-weight: 600; padding: 4px 10px; cursor: pointer;
}
.mini:hover { border-color: var(--accent); }

/* ===== Export overlay ===== */
#export-overlay {
  position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,0.92);
  display: flex; align-items: center; justify-content: center; gap: 24px; padding: 20px;
}
#export-canvas { height: min(82vh, 1920px); aspect-ratio: 9 / 16; width: auto; border: 1px solid var(--card-edge); border-radius: 6px; }
.export-side { max-width: 280px; display: flex; flex-direction: column; gap: 14px; }
#export-status { color: var(--ink); font-size: 14px; line-height: 1.5; }
#export-status code { display: block; background: var(--panel); border-radius: 4px; padding: 6px 8px; font-size: 11.5px; margin-top: 6px; word-break: break-all; }
.export-note { color: var(--ink-faint); font-size: 12px; }
@media (max-width: 700px) {
  #export-overlay { flex-direction: column; }
  #export-canvas { height: 55vh; }
}

details { background: var(--panel); border: 1px solid var(--card-edge); border-radius: 6px; padding: 10px 14px; }
summary { cursor: pointer; color: var(--ink-dim); }
#custom-list { max-height: 320px; overflow-y: auto; margin: 12px 0; }
#custom-list label { display: block; font-size: 13px; color: var(--ink-dim); padding: 3px 0; cursor: pointer; }
#custom-list .group { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent); margin: 10px 0 4px; }
.btn {
  background: var(--accent); border: none; border-radius: 4px; color: #14181c;
  font-weight: 700; padding: 8px 16px; cursor: pointer; font-size: 14px;
}

.opts label { display: block; color: var(--ink-dim); font-size: 14px; margin-bottom: 8px; }
.opts input { background: var(--panel); border: 1px solid var(--card-edge); border-radius: 4px; color: var(--ink); padding: 5px 8px; font-size: 14px; }
.tips { padding-left: 20px; color: var(--ink-dim); font-size: 13.5px; }
.tips li { margin-bottom: 6px; }

/* ===== Player ===== */
#player { position: fixed; inset: 0; background: #000; display: flex; align-items: center; justify-content: center; }

#stage {
  position: relative;
  aspect-ratio: 9 / 16;
  height: 100vh;
  max-width: 100vw;
  background:
    radial-gradient(120% 60% at 50% 0%, #1a2027 0%, #0e1114 60%),
    #0e1114;
  overflow: hidden;
}

/* Slide content — padded clear of TikTok UI: right-side buttons + bottom caption */
#slide {
  position: absolute; inset: 0;
  padding: 7% 16% 24% 8%;
  display: flex; flex-direction: column; justify-content: center;
  gap: 0.6vh;                   /* guaranteed spacing between every element */
  animation: slidein 0.45s ease both;
}
@keyframes slidein {
  from { opacity: 0; transform: translateY(26px); }
  to   { opacity: 1; transform: none; }
}

.s-kicker {
  font-family: ui-monospace, Menlo, monospace;
  font-size: clamp(11px, 1.6vh, 18px);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-faint); margin-bottom: 1.2vh;
}
.s-date {
  font-family: ui-monospace, Menlo, monospace;
  font-size: clamp(13px, 2vh, 24px);
  color: var(--accent); margin-bottom: 1vh;
}
.s-badge {
  display: inline-block; align-self: flex-start;
  flex: 0 0 auto;                /* never stretch/shrink within the flex column */
  width: auto; max-width: 100%;
  font-size: clamp(11px, 1.7vh, 20px);
  font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;
  border-radius: 4px; padding: 0.5vh 1.2vh; margin: 0 0 2vh 0;
  color: #14181c;
  white-space: nowrap;          /* keep the label on one line */
}
.s-badge.adjudicated { background: var(--adjudicated); }
.s-badge.official { background: var(--official); }
.s-badge.reported { background: var(--reported); }
.s-badge.allegation { background: var(--allegation); }
.s-badge.unverified { background: var(--unverified); color: #f4ecec; }
.s-badge.clarification { background: var(--clarification); }

.s-title {
  font-family: Georgia, serif;
  font-size: clamp(22px, 4.2vh, 52px);
  line-height: 1.18; margin: 0 0 2vh 0;
  flex: 0 0 auto;               /* keep full height; don't let flex compress it */
}
.s-body {
  font-size: clamp(14px, 2.3vh, 28px);
  line-height: 1.5; color: var(--ink-dim);
}
.s-body.long { font-size: clamp(12px, 1.85vh, 22px); }
.s-body.vlong { font-size: clamp(11px, 1.55vh, 18px); }

.s-source {
  position: absolute; left: 8%; right: 16%; bottom: 13%;
  font-family: ui-monospace, Menlo, monospace;
  font-size: clamp(10px, 1.4vh, 16px);
  color: var(--ink-faint);
  border-top: 1px solid var(--card-edge);
  padding-top: 1vh;
}
.s-source::before { content: "SOURCE — "; color: var(--accent); letter-spacing: 0.08em; }

/* Title & end cards */
.s-center { text-align: center; align-items: center; }
.s-center .s-title { font-size: clamp(28px, 5.2vh, 64px); }
.s-center .s-badge { align-self: center; }
.s-rule { width: 18%; height: 2px; background: var(--accent); margin: 2.4vh auto; }

#progress {
  position: absolute; top: 2.4%; left: 8%; right: 16%;
  display: flex; gap: 4px;
}
#progress i { flex: 1; height: 3px; background: #2a323b; border-radius: 2px; }
#progress i.done { background: var(--accent); }

#watermark {
  position: absolute; top: 4.2%; right: 16%;
  font-size: clamp(11px, 1.6vh, 18px);
  color: var(--ink-faint);
}

#controls {
  position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 8px; transition: opacity 0.4s;
}
#controls.faded { opacity: 0; pointer-events: none; }
#controls button {
  background: rgba(24,29,34,0.9); border: 1px solid var(--card-edge); border-radius: 6px;
  color: var(--ink-dim); padding: 8px 16px; cursor: pointer; font-size: 14px;
}
#controls button:hover { color: var(--ink); }
#controls button.on { color: var(--accent); border-color: var(--accent); }

body.hidecursor, body.hidecursor * { cursor: none !important; }

/* Record button in the player controls */
#controls button.rec-btn { color: #e05a5a; border-color: #6e4a4a; font-weight: 700; }
#controls button.rec-btn:hover { color: #fff; background: #e05a5a; border-color: #e05a5a; }
#controls button.rec-btn.recording { color: #fff; background: #e05a5a; border-color: #e05a5a; animation: livepulse 1.2s ease-in-out infinite; }
