/* ════════════════════════════════════════════════════════════════════════
   RUNDOWN STUDIO — theme
   Re-skin of the standalone ShowPilot prototype's CSS onto Corkboard's
   design tokens (public/css/phase0-core.css :root). Structure/layout is
   kept as-is (it was already clean); only colors/radii/shadows/buttons are
   swapped to Corkboard's vocabulary so this reads as a native tool.
   Deliberate exception: .rd-on-air and .rd-prompter stay dark broadcast
   surfaces regardless of light/dark mode — that's how every real on-air
   console and teleprompter looks (vMix, ATEM, ProPresenter stage display),
   and it's how ShowPilot itself already designed those two surfaces.
   ════════════════════════════════════════════════════════════════════════ */

#rundown-app { --rd-radius: var(--radius, 10px); --rd-shadow: var(--shadow-soft, 0 6px 18px rgba(0,0,0,.10)); }

.rd-shell {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: 100%;
  height: 100%;
  background: var(--bg-cork, #d4b483);
  color: var(--ink);
  font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* ── Sidebar ────────────────────────────────────────────────────────────── */
.rd-sidebar {
  position: sticky; top: 0; z-index: 6;
  display: grid; grid-template-columns: auto minmax(0, 1fr) auto auto; align-items: center; gap: 12px; padding: 10px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.55));
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(12px);
}
.rd-brand { display: flex; align-items: center; gap: 10px; min-width: 210px; padding: 0; border-bottom: 0; }
.rd-brand-mark { display: grid; place-items: center; width: 36px; height: 36px; border-radius: var(--rd-radius); background: linear-gradient(135deg, var(--brand, #2563eb), var(--brand-hover, #1d4ed8)); color: #fff; font-weight: 900; }
.rd-brand strong { display: block; font-size: 15px; }
.rd-brand span { display: block; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }

.rd-nav { display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none; }
.rd-nav::-webkit-scrollbar { display: none; }
.rd-nav button {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px; min-height: 34px; padding: 7px 10px; white-space: nowrap;
  border: 1px solid transparent; border-radius: var(--rd-radius); background: transparent; color: var(--ink);
  font-weight: 800; font-size: .8rem; cursor: pointer; text-align: center;
}
.rd-nav button:hover { background: rgba(0,0,0,.05); }
.rd-nav button.active { background: linear-gradient(135deg, var(--brand, #2563eb), var(--brand-hover, #1d4ed8)); color: #fff; border-color: var(--brand, #2563eb); }
.rd-nav-ic { font-size: 1rem; }

.rd-side-card { min-width: 136px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 8px 10px; background: var(--paper, #fff); box-shadow: none; }
.rd-side-card strong { display: block; margin-top: 2px; font-size: 18px; line-height: 1; }
.rd-side-card span { display: block; color: var(--muted); font-size: 11px; }
.rd-readiness { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; font-weight: 800; font-size: .72rem; }
.rd-readiness span { width: fit-content; }
.rd-eyebrow { margin: 0; color: var(--brand, #2563eb); font-size: 11px; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }

/* ── Workspace / topbar ────────────────────────────────────────────────── */
.rd-workspace { min-width: 0; min-height: 0; padding: 14px; overflow-y: auto; }
.rd-topbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; min-height: 64px; margin-bottom: 8px; }
.rd-topbar h1 { margin: 2px 0 0; font-size: clamp(20px, 2.4vw, 30px); line-height: 1.1; }
.rd-top-actions { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.rd-hidden-input { display: none; }

.rd-btn {
  display: inline-flex; align-items: center; gap: 7px; min-height: 36px; padding: 7px 12px;
  border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); color: var(--ink);
  font-weight: 700; font-size: .82rem; cursor: pointer;
}
.rd-btn:hover { background: rgba(0,0,0,.04); }
.rd-btn.primary { background: linear-gradient(135deg, var(--brand, #2563eb), var(--brand-hover, #1d4ed8)); color: #fff; border-color: var(--brand, #2563eb); }
.rd-btn.ghost { justify-content: center; width: 100%; background: transparent; }

/* ── Metric strip ──────────────────────────────────────────────────────── */
.rd-metric-strip { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 12px; margin: 10px 0 16px; }
.rd-metric, .rd-run-health, .rd-crew-sheet, .rd-feature, .rd-quick, .rd-template-card, .rd-template-control,
.rd-snapshot-panel, .rd-presence-panel, .rd-api-panel, .rd-export-panel {
  min-height: 108px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 14px;
  background: var(--paper, #fff); box-shadow: var(--rd-shadow);
}
.rd-metric-ic { font-size: 1.1rem; }
.rd-metric span.rd-metric-label, .rd-metric small { display: block; color: var(--muted); }
.rd-metric .rd-metric-label { margin-top: 12px; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.rd-metric strong { display: block; margin: 2px 0; font-size: 22px; }
.rd-metric.good { border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.06); }
.rd-metric.danger { border-color: rgba(185,28,28,.35); background: rgba(185,28,28,.06); }
.rd-metric.danger strong, .danger { color: var(--danger, #b91c1c); }
.good { color: var(--ok, #16a34a); }
.warn { color: #9a5b00; }

.rd-mode-build .rd-topbar { min-height: 0; margin-bottom: 6px; }
.rd-mode-build .rd-metric-strip { gap: 8px; margin: 6px 0 10px; }
.rd-mode-build .rd-metric {
  min-height: 66px; display: grid; grid-template-columns: auto minmax(0, 1fr); grid-template-rows: auto auto;
  column-gap: 9px; align-items: center; padding: 9px 11px;
}
.rd-mode-build .rd-metric-ic { grid-row: 1 / 3; }
.rd-mode-build .rd-metric .rd-metric-label { margin-top: 0; }
.rd-mode-build .rd-metric strong { margin: 0; font-size: 17px; }
.rd-mode-build .rd-metric small { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Grids ──────────────────────────────────────────────────────────────── */
.rd-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
.rd-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.rd-build { display: grid; grid-template-columns: minmax(0, 1fr); gap: 14px; align-items: start; }
.rd-crew-layout { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }

.rd-hero {
  grid-column: span 2; min-height: 220px; display: flex; flex-direction: column; justify-content: space-between;
  border: 1px solid rgba(0,0,0,.15); border-radius: var(--rd-radius); padding: 20px; color: #fff;
  background: linear-gradient(135deg, rgba(20,16,10,.92), rgba(37,99,235,.55)), var(--bg-cork, #d4b483);
  box-shadow: var(--rd-shadow);
}
.rd-hero h2 { max-width: 640px; margin: 6px 0 8px; font-size: clamp(26px, 3.6vw, 42px); line-height: 1; }
.rd-hero p { max-width: 560px; color: rgba(255,255,255,.85); margin: 0; }
.rd-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }

.rd-feature-ic { font-size: 1.3rem; }
.rd-feature h2, .rd-standards h2, .rd-live-card h2, .rd-live-card h3 { margin: 6px 0 0; font-size: 17px; }
.rd-feature p, .rd-standards p, .rd-live-card p { margin: 4px 0 0; color: var(--muted); }

.rd-quick { background: #14181f; color: #fff; display: grid; align-content: start; gap: 12px; }
.rd-quick .rd-eyebrow { color: #5fd0de; }
.rd-quick-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
.rd-quick-grid button { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 40px; border: 1px solid rgba(255,255,255,.18); border-radius: var(--rd-radius); background: rgba(255,255,255,.08); color: #fff; font-weight: 800; cursor: pointer; }

/* ── Build grid / table ────────────────────────────────────────────────── */
.rd-panel, .rd-inspector { border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); overflow: hidden; box-shadow: var(--rd-shadow); }
.rd-panel-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; padding: 14px; border-bottom: 1px solid var(--line); }
.rd-panel-head.compact { align-items: flex-start; }
.rd-panel-head h2 { margin: 0; font-size: 17px; }
.rd-panel-head p { margin: 4px 0 0; color: var(--muted); font-size: .82rem; }
.rd-panel-tools { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.rd-panel-tools select { max-width: 170px; }
.rd-search { display: inline-flex; align-items: center; gap: 7px; min-width: min(300px,100%); border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 7px 10px; background: var(--paper, #fff); }
.rd-search input { width: 100%; border: 0; outline: 0; font: inherit; background: transparent; }

.rd-timeline { display: flex; gap: 4px; padding: 10px 12px; border-bottom: 1px solid var(--line); background: rgba(0,0,0,.02); overflow-x: auto; }
.rd-tl-seg { min-width: 40px; height: 36px; border: 1px solid rgba(0,0,0,.1); border-radius: 8px; color: #fff; font-size: 10px; font-weight: 900; cursor: pointer; }
.rd-tl-seg.active { outline: 3px solid rgba(245,158,11,.65); }
.rd-type-open, .rd-type-close { background: #0f766e; }
.rd-type-story { background: var(--brand, #2563eb); }
.rd-type-package { background: #7c3aed; }
.rd-type-live { background: #e11d48; }
.rd-type-ad { background: #b45309; }
.rd-type-break { background: #475569; }

.rd-table { max-height: calc(100vh - 320px); overflow: auto; }
.rd-row {
  display: grid; grid-template-columns: 44px 80px 42px 70px minmax(220px,1.5fr) 64px 84px 110px minmax(160px,1fr);
  align-items: center; gap: 8px; width: 100%; min-width: 920px; padding: 9px 12px; border: 0;
  border-bottom: 1px solid var(--line); background: var(--paper, #fff); text-align: left; cursor: pointer; font: inherit; color: inherit;
}
.rd-row:not(.rd-row-header):hover, .rd-row.selected { background: rgba(37,99,235,.06); }
.rd-row-header { position: sticky; top: 0; z-index: 1; color: var(--muted); font-size: 10px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; background: var(--paper, #fff); cursor: default; }
.rd-row strong, .rd-row small { display: block; }
.rd-row small { color: var(--muted); font-size: 11px; }
.rd-move, .rd-cue-sum { display: inline-flex; align-items: center; gap: 5px; }
.rd-mono { font-family: "JetBrains Mono", "SFMono-Regular", Consolas, monospace; }
.rd-slug, .rd-status { display: inline-flex; justify-content: center; align-items: center; min-height: 26px; width: fit-content; border-radius: 999px; padding: 0 9px; font-size: 11px; font-weight: 900; }
.rd-slug { background: var(--ink); color: #fff; }
.rd-status { background: #edf2f7; color: #334155; }
.rd-status-ready, .rd-status-done { background: rgba(22,163,74,.14); color: #116746; }
.rd-status-hold { background: #fff3d7; color: #8a5b00; }
.rd-status-float { background: #edf4ff; color: #225da8; }
.rd-empty-row { padding: 24px; text-align: center; color: var(--muted); }

/* ── Run health + detail tray ───────────────────────────────────────────── */
.rd-detail-tray { display: grid; grid-template-columns: minmax(240px, .28fr) minmax(0, 1fr); gap: 14px; align-items: stretch; }
.rd-run-health { display: grid; gap: 10px; padding: 14px; }
.rd-health-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
.rd-health-grid span, .rd-next-stack span { display: inline-flex; align-items: center; gap: 6px; min-height: 32px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 5px 8px; background: rgba(0,0,0,.02); font-size: 11px; font-weight: 900; }
.rd-run-health ul, .rd-crew-sheet ul { display: grid; gap: 6px; margin: 0; padding-left: 16px; color: var(--muted); font-size: 12px; line-height: 1.35; }

.rd-icon-row { display: flex; gap: 6px; }
.rd-icon-row button { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; padding: 0; border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); cursor: pointer; }
.rd-form-grid { display: grid; grid-template-columns: repeat(5, minmax(190px,1fr)); gap: 10px; padding: 14px; max-height: none; overflow: visible; }
.rd-form-section { display: grid; align-content: start; gap: 10px; min-width: 0; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 10px; background: rgba(0,0,0,.018); }
.rd-form-section h3 { margin: 0 0 2px; font-size: 12px; color: var(--ink); text-transform: uppercase; letter-spacing: .06em; }
.rd-form-grid label { display: grid; gap: 5px; color: var(--muted); font-size: 11px; font-weight: 900; text-transform: uppercase; }
.rd-form-grid .wide { grid-column: 1 / -1; }
.rd-check-row { display: flex !important; align-items: center; text-transform: none !important; gap: 8px; }
.rd-check-row input { width: auto; }
.rd-meta-stack { display: grid; gap: 5px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 9px; background: rgba(0,0,0,.02); color: var(--muted); font-size: 12px; }
.rd-meta-stack strong { color: var(--ink); }

#rundown-app input, #rundown-app select, #rundown-app textarea {
  width: 100%; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 8px 9px; color: var(--ink); background: var(--paper, #fff); font: 500 13px/1.4 inherit;
}
#rundown-app textarea { resize: vertical; }

/* ── Live mode — deliberately stays a dark broadcast console ──────────── */
.rd-live { display: grid; grid-template-columns: 1.1fr .9fr; gap: 14px; }
.rd-live-card { border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); padding: 16px; box-shadow: var(--rd-shadow); }
.rd-on-air { background: #0f172a; color: #fff; border-color: #1e293b; }
.rd-on-air p { color: #cbd5e1; }
.rd-on-air.over { border-color: #ef4444; box-shadow: 0 0 0 2px rgba(239,68,68,.5), 0 0 24px rgba(239,68,68,.35); animation: rd-pulse 1.1s infinite; }
@keyframes rd-pulse { 0%, 100% { box-shadow: 0 0 0 2px rgba(239,68,68,.5), 0 0 24px rgba(239,68,68,.35); } 50% { box-shadow: 0 0 0 2px rgba(239,68,68,.15), 0 0 8px rgba(239,68,68,.1); } }
.rd-live-clock { margin: 16px 0; font-family: "JetBrains Mono", monospace; font-size: clamp(48px, 7vw, 100px); line-height: 1; }
.rd-progress { height: 9px; overflow: hidden; border-radius: 999px; background: rgba(255,255,255,.18); }
.rd-progress span { display: block; height: 100%; border-radius: inherit; background: #2dd4bf; transition: width .25s linear; }
.rd-live-controls { display: flex; flex-wrap: wrap; justify-content: flex-start; gap: 8px; margin-top: 16px; }
.rd-live-controls button { display: inline-flex; align-items: center; gap: 7px; min-height: 38px; padding: 8px 12px; border: 1px solid rgba(255,255,255,.18); border-radius: var(--rd-radius); background: rgba(255,255,255,.08); color: #fff; font-weight: 700; cursor: pointer; }
.rd-on-air ~ * .rd-live-controls button, .rd-live-card:not(.rd-on-air) .rd-live-controls button { background: var(--paper, #fff); color: var(--ink); border-color: var(--line); }
.rd-next-stack { display: grid; gap: 7px; margin-top: 16px; }
.rd-cue-wall { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1px; overflow: hidden; background: var(--line); border-radius: var(--rd-radius); }
.rd-cue-wall article { display: grid; align-content: start; gap: 7px; min-height: 130px; padding: 14px; background: var(--paper, #fff); }
.rd-cue-wall span, .rd-cue-ic { color: var(--muted); font-size: 11px; font-weight: 900; text-transform: uppercase; }

/* ── Prompter — deliberately stays black, like a real teleprompter ──────── */
.rd-shell-prompter .rd-workspace { display: flex; flex-direction: column; }
.rd-shell-prompter .rd-sidebar,
.rd-shell-prompter .rd-topbar { display: none; }
.rd-shell-prompter .rd-metric-strip { display: none; }
.rd-shell-prompter #rd-mode-body { display: flex; flex: 1 1 auto; min-height: 0; }
.rd-prompter-layout { display: grid; grid-template-rows: auto minmax(0, 1fr) auto; flex: 1 1 auto; min-height: calc(100vh - 98px); width: 100%; border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); overflow: hidden; box-shadow: var(--rd-shadow); }
.rd-prompter-tools { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; padding: 9px 10px; border-bottom: 1px solid var(--line); }
.rd-prompter-tools button { min-height: 32px; padding: 5px 10px; border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); cursor: pointer; font-weight: 800; }
.rd-prompter-tools button.primary { background: var(--brand, #2563eb); border-color: var(--brand, #2563eb); color: #fff; }
.rd-prompter-tools .rd-prompter-back { background: #111827; border-color: #111827; color: #fff; }
.rd-prompter-tools span { margin-left: auto; min-width: 180px; color: var(--muted); font-weight: 800; text-align: right; }
.rd-speed-control { display: inline-flex; align-items: center; gap: 7px; min-height: 32px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 4px 8px; background: var(--paper, #fff); color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.rd-speed-control input[type="number"] { width: 58px !important; padding: 3px 5px !important; font-size: 12px !important; }
.rd-speed-control input[type="range"] { width: 100px !important; padding: 0 !important; }
.rd-prompter { min-height: 0; overflow-y: auto; padding: clamp(20px, 4vw, 56px); background: #050505; color: #fff; font-weight: 700; line-height: 1.55; text-align: left; }
.rd-prompter.mirror { transform: scaleX(-1); }
.rd-cue-card-strip { display: grid; grid-template-columns: 1.4fr .6fr; gap: 1px; background: var(--line); }
.rd-cue-card-strip article { display: grid; gap: 7px; padding: 14px; background: var(--paper, #fff); }
#rundown-app.rd-prompter-focus { position: fixed !important; inset: 0 !important; z-index: 99999 !important; width: 100vw !important; height: 100vh !important; background: #050505 !important; }
#rundown-app.rd-prompter-focus .rd-shell { min-height: 100vh; height: 100vh; background: #050505; }
#rundown-app.rd-prompter-focus .rd-sidebar,
#rundown-app.rd-prompter-focus .rd-topbar { display: none !important; }
#rundown-app.rd-prompter-focus .rd-workspace { padding: 0; }
#rundown-app.rd-prompter-focus .rd-prompter-layout { min-height: 100vh; border: 0; border-radius: 0; }
body[data-active-view="rundown-app"] #find-replace-bar,
body[data-active-view="rundown-app"] #scene-jump-bar,
#rundown-app.rd-prompter-focus ~ #find-replace-bar,
#rundown-app.rd-prompter-focus ~ #scene-jump-bar {
  display: none !important;
}

/* ── Crew / templates / collab / integrations / standards ─────────────── */
.rd-feature, .rd-quick, .rd-crew-sheet, .rd-standards article, .rd-template-card { min-height: 200px; padding: 16px; }
.rd-sheet-head { display: flex; align-items: center; gap: 9px; margin-bottom: 12px; }
.rd-sheet-head h2 { margin: 0; font-size: 17px; }
.rd-template-ic { font-size: 1.2rem; }
.rd-template-control, .rd-template-builder, .rd-api-panel, .rd-export-panel { grid-column: span 2; min-width: 0; display: grid; align-content: start; gap: 10px; }
.rd-template-builder { min-height: 200px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 16px; background: var(--paper, #fff); box-shadow: var(--rd-shadow); }
.rd-template-builder label { display: grid; gap: 5px; color: var(--muted); font-size: 11px; font-weight: 900; text-transform: uppercase; }
.rd-template-control p, .rd-template-card p { color: var(--muted); }
.rd-template-card ul, .rd-snapshot-panel ul { display: grid; gap: 7px; margin: 0; padding-left: 16px; color: var(--muted); }
.rd-api-panel pre { overflow: auto; max-height: 360px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 10px; background: #14181f; color: #d1fae5; font-size: 11px; }
.rd-export-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
.rd-export-grid button { min-height: 36px; border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); color: var(--ink); font-weight: 800; cursor: pointer; }
.rd-snapshot-panel, .rd-presence-panel { display: grid; align-content: start; gap: 10px; }
.rd-presence-panel span { display: inline-flex; align-items: center; gap: 6px; }

.rd-standards { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; }
.rd-standards article { border: 1px solid var(--line); border-radius: var(--rd-radius); background: var(--paper, #fff); box-shadow: var(--rd-shadow); }
.rd-feature-matrix { grid-column: 1 / -1; }
.rd-feature-matrix div { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 8px; margin-top: 12px; }
.rd-feature-matrix span { display: grid; gap: 4px; min-height: 100px; border: 1px solid var(--line); border-radius: var(--rd-radius); padding: 9px; background: rgba(0,0,0,.02); }
.rd-feature-matrix small { color: var(--muted); }
.rd-feature-matrix em { width: fit-content; border-radius: 999px; padding: 2px 7px; font-size: 10px; font-style: normal; font-weight: 900; }
.rd-feature-matrix em.live { background: rgba(22,163,74,.14); color: #116746; }
.rd-feature-matrix em.proto { background: rgba(245,158,11,.16); color: #9a5b00; }

.rd-note,
.rd-muted {
  color: var(--muted);
  font-size: 12px;
}

/* Student newsroom workflow */
.rd-assignment-layout,
.rd-review-layout {
  display: grid;
  gap: 14px;
}

.rd-assignment-tools,
.rd-review-panel {
  border: 1px solid var(--line);
  border-radius: var(--rd-radius);
  padding: 14px;
  background: var(--paper, #fff);
  box-shadow: var(--rd-shadow);
}

.rd-assignment-tools h2,
.rd-review-panel h2 {
  margin: 3px 0 10px;
  font-size: 18px;
}

.rd-form-grid.tight {
  grid-template-columns: repeat(4, minmax(170px, 1fr));
  padding: 0;
}

.rd-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.rd-action-row select {
  width: min(260px, 100%) !important;
}

.rd-kanban {
  display: grid;
  grid-template-columns: repeat(4, minmax(230px, 1fr));
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.rd-assignment-column {
  display: grid;
  align-content: start;
  gap: 10px;
  min-width: 230px;
  border: 1px solid var(--line);
  border-radius: var(--rd-radius);
  padding: 10px;
  background: rgba(0, 0, 0, .025);
}

.rd-assignment-column h2 {
  margin: 0;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.rd-assignment-card {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: var(--rd-radius);
  padding: 10px;
  background: var(--paper, #fff);
}

.rd-assignment-card strong,
.rd-assignment-card span {
  display: block;
}

.rd-assignment-card span {
  color: var(--muted);
  font-size: 12px;
}

.rd-assignment-card label,
.rd-review-panel label,
.rd-rubric-grid label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.rd-review-layout {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.rd-review-hero,
.rd-wide-panel {
  grid-column: 1 / -1;
}

.rd-review-panel ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 13px;
}

.rd-review-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.rd-review-table th,
.rd-review-table td {
  border-bottom: 1px solid var(--line);
  padding: 9px 8px;
  text-align: left;
  vertical-align: top;
}

.rd-review-table th {
  color: var(--muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.rd-mini-check {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  margin: 0 4px 4px 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 2px 8px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.rd-mini-check.ok {
  border-color: rgba(22, 163, 74, .3);
  background: rgba(22, 163, 74, .12);
  color: #116746;
}

.rd-rubric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.rd-rubric-grid label {
  border: 1px solid var(--line);
  border-radius: var(--rd-radius);
  padding: 10px;
  background: rgba(0, 0, 0, .02);
}

.rd-rubric-grid label span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
  text-transform: none;
}

.rd-rehearsal-list li {
  display: grid;
  gap: 3px;
}

.rd-ready-card {
  border-color: rgba(22, 163, 74, .35);
  background: rgba(22, 163, 74, .08);
}

.rd-block-card {
  border-color: rgba(185, 28, 28, .35);
  background: rgba(185, 28, 28, .08);
}

.rd-empty { padding: 40px 24px; text-align: center; color: var(--muted); font-weight: 700; }

/* ── Dark mode — everything except the deliberately-dark broadcast surfaces ── */
body.dark .rd-shell { background: #1a1f29; color: #e8eefc; }
body.dark .rd-sidebar { background: linear-gradient(180deg, rgba(11,17,32,.96), rgba(15,23,42,.94)); border-color: rgba(148,163,184,.18); }
body.dark .rd-side-card, body.dark .rd-metric, body.dark .rd-run-health, body.dark .rd-crew-sheet,
body.dark .rd-feature, body.dark .rd-template-card, body.dark .rd-template-control, body.dark .rd-snapshot-panel,
body.dark .rd-presence-panel, body.dark .rd-api-panel, body.dark .rd-export-panel, body.dark .rd-template-builder, body.dark .rd-panel,
body.dark .rd-inspector, body.dark .rd-row, body.dark .rd-row-header, body.dark .rd-btn, body.dark .rd-search,
body.dark .rd-standards article, body.dark .rd-cue-wall article, body.dark .rd-cue-card-strip article,
body.dark .rd-live-card:not(.rd-on-air), body.dark .rd-assignment-tools, body.dark .rd-review-panel,
body.dark .rd-assignment-card { background: rgba(15,23,42,.92); color: #e8eefc; border-color: rgba(148,163,184,.18); }
body.dark .rd-assignment-column,
body.dark .rd-rubric-grid label { background: rgba(15,23,42,.62); border-color: rgba(148,163,184,.18); }
body.dark #rundown-app input, body.dark #rundown-app select, body.dark #rundown-app textarea { background: rgba(15,23,42,.92); color: #e8eefc; border-color: rgba(148,163,184,.18); }
body.dark .rd-eyebrow { color: #5fd0de; }
body.dark .rd-nav button { color: #e8eefc; }

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 1180px) {
  .rd-sidebar { grid-template-columns: 1fr; align-items: stretch; }
  .rd-brand { min-width: 0; }
  .rd-side-card-readiness { display: none; }
  .rd-side-card { min-width: 160px; }
  .rd-detail-tray, .rd-live { grid-template-columns: 1fr; }
  .rd-form-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .rd-metric-strip, .rd-grid-4, .rd-grid-2, .rd-crew-layout, .rd-cue-wall, .rd-standards, .rd-review-layout { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .rd-kanban { grid-template-columns: repeat(2, minmax(230px, 1fr)); }
  .rd-form-grid.tight { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .rd-hero, .rd-template-control, .rd-api-panel, .rd-export-panel { grid-column: 1 / -1; }
  .rd-feature-matrix div { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .rd-table { max-height: none; }
}
@media (max-width: 720px) {
  .rd-workspace, .rd-sidebar { padding: 10px; }
  .rd-topbar, .rd-panel-head { align-items: stretch; flex-direction: column; }
  .rd-top-actions, .rd-live-controls { justify-content: stretch; }
  .rd-top-actions button, .rd-live-controls button { justify-content: center; flex: 1 1 130px; }
  .rd-mode-build .rd-top-actions { display: none; }
  .rd-mode-build .rd-side-card,
  .rd-mode-build .rd-metric-strip { display: none; }
  .rd-metric-strip, .rd-grid-4, .rd-grid-2, .rd-crew-layout, .rd-cue-wall, .rd-standards, .rd-form-grid, .rd-cue-card-strip, .rd-review-layout, .rd-form-grid.tight, .rd-rubric-grid { grid-template-columns: 1fr; }
  .rd-kanban { grid-template-columns: repeat(1, minmax(230px, 1fr)); }
  .rd-prompter-layout { min-height: calc(100vh - 74px); }
  .rd-prompter-tools { gap: 5px; padding: 7px; }
  .rd-prompter-tools button { flex: 1 1 auto; min-width: 62px; padding: 5px 7px; font-size: 12px; }
  .rd-prompter-tools span { flex: 1 1 100%; min-width: 0; margin-left: 0; text-align: left; font-size: 12px; }
  .rd-speed-control { flex: 1 1 100%; }
  .rd-speed-control input[type="range"] { flex: 1 1 auto; width: auto !important; }
  .rd-health-grid { grid-template-columns: 1fr; }
  .rd-feature-matrix div, .rd-export-grid { grid-template-columns: 1fr; }
}
@media print {
  .rd-sidebar, .rd-top-actions, .rd-metric-strip, .rd-inspector, .rd-run-health, .rd-prompter-tools { display: none; }
  .rd-shell, .rd-workspace, .rd-build { display: block; min-height: auto; padding: 0; background: #fff; }
  .rd-panel, .rd-row { border-color: #111827; }
  .rd-table { max-height: none; overflow: visible; }
}
