/* ============================================================
   PodVCR — Application styles
   Imports tokens.css + shell.css (loaded before this).
   This file owns: alerts, empty states, page-specific blocks
   (dashboard, episode deck, waveform, transcript, clips,
   settings, admin, auth shell, notifications, modals).
   ============================================================ */

/* ---------- RESET HELPERS ---------- */
img { max-width: 100%; display: block; }
button { font-family: inherit; }
a { color: var(--amber); }
a:hover { color: var(--amber-glow); }

.container { max-width: 1400px; margin: 0 auto; padding: 0 32px; }
.hidden { display: none !important; }
.mobile-only { display: none; }
@media (max-width: 880px) {
  .mobile-only { display: inline-flex; }
  .desktop-only { display: none !important; }
}

/* ==========================================================
   ALERTS / BANNERS
   ========================================================== */
.alert {
  padding: 14px 18px;
  border: 1px solid var(--border);
  border-left: 3px solid var(--amber);
  background: var(--surface);
  color: var(--text-2);
  font-size: 14px;
  margin-bottom: 16px;
  display: flex; align-items: center; gap: 12px;
}
.alert .label {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em;
  color: var(--amber); text-transform: uppercase; flex-shrink: 0;
}
.alert.alert-info    { border-left-color: var(--amber); }
.alert.alert-info .label { color: var(--amber); }
.alert.alert-success { border-left-color: var(--green-led); }
.alert.alert-success .label { color: var(--green-led); }
.alert.alert-error   { border-left-color: var(--rec); }
.alert.alert-error .label { color: var(--rec); }
.alert.alert-warning { border-left-color: var(--amber); }
.alert .grow { flex: 1; }

/* ==========================================================
   EMPTY STATES
   ========================================================== */
.empty-state {
  text-align: center;
  padding: 64px 24px;
  border: 1px dashed var(--border-hi);
  background: var(--surface);
  color: var(--text-2);
}
.empty-state h2 {
  font-family: var(--font-display);
  font-size: 28px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--bone);
  margin: 0 0 8px;
}
.empty-state .ascii {
  font-family: var(--font-mono);
  color: var(--amber);
  font-size: 14px;
  letter-spacing: 0.08em;
  margin-bottom: 18px;
  white-space: pre;
  opacity: 0.7;
}
.empty-state p { max-width: 420px; margin: 0 auto 18px; font-size: 14px; color: var(--text-3); }

/* Spinner (LCD-style dotted ring) */
.spinner {
  display: inline-block;
  width: 16px; height: 16px;
  border: 2px solid rgba(245,181,68,0.25);
  border-top-color: var(--amber);
  border-radius: 50%;
  animation: reel-spin 0.8s linear infinite;
}
.spinner.lg { width: 28px; height: 28px; border-width: 3px; }

/* Skeleton shimmer */
@keyframes shimmer { 0% { background-position: -240px 0; } 100% { background-position: 240px 0; } }
.skeleton {
  background: linear-gradient(90deg, var(--surface) 0%, var(--ink-3) 50%, var(--surface) 100%);
  background-size: 480px 100%;
  animation: shimmer 1.4s linear infinite;
  min-height: 16px;
  border-radius: 2px;
}

/* ==========================================================
   IMPERSONATION BANNER
   ========================================================== */
.impersonation-banner {
  padding: 8px 24px;
  background: var(--rec);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  border-bottom: 1px solid #000;
  display: flex; justify-content: center; gap: 16px; align-items: center;
}
.impersonation-banner strong { color: #fff; }
.impersonation-banner .link-button {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.5);
  color: #fff;
  padding: 3px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}
.impersonation-banner .link-button:hover { background: rgba(255,255,255,0.1); }
.badge-admin {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--amber);
  border: 1px solid rgba(245,181,68,0.4);
  background: rgba(245,181,68,0.08);
  padding: 2px 6px;
  text-transform: uppercase;
  margin-left: 6px;
}

/* ==========================================================
   PODCAST SWITCHER (drops out of header button)
   ========================================================== */
.app-nav .podpicker-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 280px;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 8px 0 #000, 0 18px 40px rgba(0,0,0,0.6);
  z-index: 50;
  padding: 6px;
  display: none;
}
.app-nav .podpicker.open .podpicker-menu { display: block; }
.podpicker-item-form { margin: 0; }
.podpicker-item {
  width: 100%;
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--bone);
  font-family: var(--font-ui);
  font-size: 13px;
  text-align: left;
  cursor: pointer;
  text-decoration: none;
}
.podpicker-item:hover { background: var(--ink-3); border-color: var(--border); }
.podpicker-item.active { background: var(--ink); border-color: var(--border); }
.podpicker-item .art {
  width: 28px; height: 28px;
  background: var(--ink);
  border: 1px solid var(--border);
  object-fit: cover;
  flex-shrink: 0;
}
.podpicker-item .name { flex: 1; }
.podpicker-item .check { color: var(--green-led); font-family: var(--font-mono); }
.podpicker-item.add { color: var(--amber); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; }
.podpicker-divider { height: 1px; background: var(--border); margin: 6px 0; }

/* ==========================================================
   USER MENU (avatar in .app-nav .right)
   ========================================================== */
.user-menu { position: relative; }
.user-menu-btn {
  display: flex; align-items: center; gap: 8px;
  background: transparent; border: 0; cursor: pointer;
  padding: 0;
}
.user-menu-dropdown {
  position: absolute;
  right: 0; top: calc(100% + 8px);
  min-width: 240px;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 8px 0 #000, 0 18px 40px rgba(0,0,0,0.6);
  z-index: 50;
  padding: 6px;
  display: none;
}
.user-menu.open .user-menu-dropdown { display: block; }
.um-email {
  padding: 10px 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-3);
  letter-spacing: 0.06em;
  border-bottom: 1px solid var(--border);
  margin-bottom: 6px;
  word-break: break-all;
}
.um-item {
  display: block;
  padding: 8px 12px;
  color: var(--text-2);
  text-decoration: none;
  font-size: 13px;
  font-family: var(--font-ui);
}
.um-item:hover { background: var(--ink-3); color: var(--bone); }
.um-item--danger { color: var(--rec); }
.um-item--danger:hover { color: var(--rec-glow); background: rgba(229,52,31,0.08); }
.um-divider { height: 1px; background: var(--border); margin: 6px 0; }

/* ==========================================================
   NOTIFICATIONS (bell + dropdown in .app-nav)
   ========================================================== */
.notif-wrapper { position: relative; }
.notif-bell {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--ink-3);
  border: 1px solid var(--border);
  color: var(--text-2);
  cursor: pointer;
  border-radius: var(--r-sm);
  position: relative;
}
.notif-bell:hover { color: var(--bone); border-color: var(--border-hi); }
.notif-badge {
  position: absolute;
  top: -4px; right: -4px;
  min-width: 18px; height: 18px; padding: 0 4px;
  background: var(--rec);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 18px;
  text-align: center;
  border-radius: 9px;
  border: 1px solid var(--ink);
  box-shadow: 0 0 6px rgba(229,52,31,0.6);
}
.notif-badge.hidden { display: none; }
.notif-dropdown {
  position: absolute;
  right: 0; top: calc(100% + 8px);
  min-width: 340px;
  max-width: 380px;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 8px 0 #000, 0 18px 40px rgba(0,0,0,0.6);
  z-index: 50;
  display: none;
}
.notif-dropdown.open { display: block; }
.notif-dropdown-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--amber);
  text-transform: uppercase;
}
.notif-clear-all {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 8px;
  cursor: pointer;
}
.notif-clear-all:hover { color: var(--bone); border-color: var(--border-hi); }
.notif-dropdown-body { max-height: 420px; overflow-y: auto; }
.notif-dropdown-empty { padding: 24px 14px; text-align: center; color: var(--text-3); font-size: 13px; }
.notif-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px dashed var(--ink-4);
  align-items: flex-start;
}
.notif-item:last-child { border-bottom: 0; }
.notif-item--unread { background: rgba(245,181,68,0.04); }
.notif-icon {
  width: 8px; height: 8px; border-radius: 50%;
  margin-top: 6px;
  background: var(--text-3);
}
.notif-icon--success { background: var(--green-led); box-shadow: var(--led-glow-green); }
.notif-icon--error { background: var(--rec); box-shadow: var(--led-glow-red); }
.notif-icon--info { background: var(--amber); box-shadow: var(--led-glow-amber); }
.notif-text-title { color: var(--bone); font-size: 13px; line-height: 1.35; }
.notif-text-time { color: var(--text-4); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; margin-top: 4px; }
.notif-dismiss {
  background: transparent;
  border: 0;
  color: var(--text-4);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  padding: 0 4px;
}
.notif-dismiss:hover { color: var(--rec); }

/* Hamburger (mobile) */
.hamburger-btn {
  width: 36px; height: 36px;
  display: none;
  align-items: center; justify-content: center;
  background: var(--ink-3); border: 1px solid var(--border); border-radius: var(--r-sm);
  cursor: pointer;
  padding: 0;
  flex-direction: column;
  gap: 4px;
}
.hamburger-btn span { width: 16px; height: 2px; background: var(--bone); }
@media (max-width: 880px) { .hamburger-btn { display: inline-flex; } }

/* ==========================================================
   TOOLBAR (search + count + sort)
   ========================================================== */
.toolbar {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.toolbar .search {
  display: flex; align-items: center; gap: 8px;
  height: 38px; padding: 0 12px; flex: 1; min-width: 220px; max-width: 420px;
  background: #08080a;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.6);
}
.toolbar .search svg { color: var(--text-3); flex-shrink: 0; }
.toolbar .search input {
  flex: 1; background: transparent; border: 0; outline: 0;
  color: var(--text); font-size: 14px; font-family: var(--font-ui);
}
.toolbar .search input::placeholder { color: var(--text-4); }
.toolbar .count {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--amber);
  letter-spacing: 0.14em;
  padding: 6px 10px;
  background: #050506;
  border: 1px solid #000;
  text-transform: uppercase;
}
.toolbar .right { margin-left: auto; display: flex; gap: 8px; flex-wrap: wrap; }

.sort-select {
  height: 30px;
  padding: 0 10px;
  background: var(--ink-3);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--bone);
  font-family: var(--font-ui);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}

/* Search-box utility (standalone, reused outside .toolbar) */
.search-box {
  width: 100%;
  max-width: 420px;
  height: 38px;
  padding: 0 12px;
  background: #08080a;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.6);
  color: var(--text);
  font-size: 14px;
  font-family: var(--font-ui);
  outline: none;
}
.search-box::placeholder { color: var(--text-4); }
.search-box:focus { border-color: var(--amber); box-shadow: 0 0 0 2px rgba(245,181,68,0.15); }

/* ==========================================================
   EPISODES TABLE (dashboard)
   ========================================================== */
.episodes {
  border: 1px solid var(--border);
  background: var(--surface);
}
.ep-head {
  display: grid;
  grid-template-columns: 60px 1fr 120px 140px 140px 80px 200px;
  padding: 14px 20px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--text-3);
  text-transform: uppercase;
  background: var(--ink);
  border-bottom: 1px solid var(--border);
}
.ep-row {
  display: grid;
  grid-template-columns: 60px 1fr 120px 140px 140px 80px 200px;
  padding: 16px 20px;
  align-items: center;
  border-bottom: 1px solid var(--border);
  gap: 12px;
}
.ep-row:last-child { border-bottom: 0; }
.ep-row:hover { background: rgba(239,232,216,0.015); }
.ep-row .num { font-family: var(--font-mono); color: var(--text-3); font-size: 13px; }
.ep-row .title { font-weight: 600; color: var(--bone); font-size: 15px; line-height: 1.35; }
.ep-row .title a { color: var(--bone); text-decoration: none; }
.ep-row .title a:hover { color: var(--amber); }
.ep-row .date { font-family: var(--font-mono); color: var(--text-3); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.ep-row .dur .timecode { font-size: 14px; padding: 3px 8px; }
.ep-row .clips { font-family: var(--font-mono); color: var(--amber); font-size: 16px; }
.ep-row .clips.none { color: var(--text-4); }
.ep-row .acts { display: flex; gap: 8px; justify-content: flex-end; }
.ep-row .ep-error-note {
  margin-top: 6px;
  display: flex; gap: 6px; align-items: flex-start;
  font-size: 11px; color: var(--rec);
  font-family: var(--font-mono);
}
.ep-row .ep-error-icon { line-height: 1; margin-top: 1px; }
.ep-row .ep-error-text { color: var(--text-3); }

/* Load-more footer */
.load-more-footer {
  text-align: center;
  margin-top: 24px;
  padding: 18px 0;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-4);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

@media (max-width: 1100px) {
  .ep-head { display: none; }
  .ep-row {
    grid-template-columns: 1fr auto;
    padding: 14px 14px;
  }
  .ep-row .num, .ep-row .date, .ep-row .dur, .ep-row .clips { display: none; }
  .ep-row > :nth-child(5) { grid-column: 1 / -1; justify-self: start; }
}

/* ==========================================================
   EPISODE DECK (episode.php)
   ========================================================== */
.deck-unit {
  background: linear-gradient(180deg, #18181c 0%, #0a0a0c 100%);
  border: 1px solid #000;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 -2px 0 rgba(0,0,0,0.6),
    0 4px 0 #000,
    0 14px 30px rgba(0,0,0,0.5);
  padding: 20px;
  margin-bottom: 28px;
}
.deck-unit .deck-top {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: center;
}
.deck-unit .lcd {
  background: #050506;
  border: 1px solid #000;
  box-shadow: inset 0 2px 6px rgba(0,0,0,0.8), inset 0 0 0 1px rgba(245,181,68,0.06);
  padding: 14px 20px;
  display: flex; flex-direction: column; gap: 6px;
  min-width: 260px;
}
.deck-unit .lcd .lbl { font-family: var(--font-mono); font-size: 10px; color: rgba(245,181,68,0.5); letter-spacing: 0.14em; text-transform: uppercase; }
.deck-unit .lcd .tc { font-family: var(--font-mono); font-size: 40px; color: var(--amber); line-height: 1; text-shadow: 0 0 10px rgba(245,181,68,0.5); letter-spacing: 0.04em; }
.deck-unit .lcd .tc .sm { font-size: 24px; opacity: 0.5; }
.deck-unit .lcd .st { font-family: var(--font-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.16em; text-transform: uppercase; opacity: 0.7; }

.deck-unit .transport-cluster {
  display: flex; gap: 8px; justify-content: center;
  flex-wrap: wrap;
}

.deck-unit .vu {
  display: flex; flex-direction: column; gap: 8px;
  min-width: 200px;
}
.deck-unit .vu .vu-row { display: flex; align-items: center; gap: 10px; }
.deck-unit .vu .chn { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); width: 14px; }
.deck-unit .vu .meter {
  flex: 1; height: 10px; background: #05050a;
  border: 1px solid #000; box-shadow: inset 0 1px 2px rgba(0,0,0,0.8);
  display: flex; gap: 1px; padding: 1px;
}
.deck-unit .vu .meter i { flex: 1; background: rgba(52,217,138,0.15); display: block; }
.deck-unit .vu .meter i.on  { background: var(--green-led); box-shadow: 0 0 4px rgba(52,217,138,0.6); }
.deck-unit .vu .meter i.hot { background: var(--amber);    box-shadow: 0 0 4px rgba(245,181,68,0.6); }
.deck-unit .vu .meter i.peak { background: var(--rec);     box-shadow: 0 0 4px rgba(229,52,31,0.7); }
.deck-unit .vu .scale { font-family: var(--font-mono); font-size: 10px; color: var(--text-4); letter-spacing: 0.14em; text-transform: uppercase; text-align: right; }

@media (max-width: 1100px) {
  .deck-unit .deck-top { grid-template-columns: 1fr; }
  .deck-unit .lcd { min-width: 0; }
}

/* ==========================================================
   WAVEFORM
   ========================================================== */
.wave-panel {
  margin-top: 20px;
  background: #050506;
  border: 1px solid #000;
  box-shadow: inset 0 2px 6px rgba(0,0,0,0.8);
  padding: 20px 16px 12px;
  position: relative;
}
.wave-ruler {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  font-family: var(--font-mono);
  font-size: 10px;
  color: rgba(245,181,68,0.4);
  letter-spacing: 0.1em;
  margin-bottom: 8px;
  padding: 0 4px;
}
.wave-ruler span { border-left: 1px solid rgba(245,181,68,0.2); padding-left: 4px; }
.wave-ruler span:first-child { border-left: 0; padding-left: 0; }
.wave {
  min-height: 120px;
  position: relative;
}
#waveform { min-height: 120px; }

.wave-btm {
  display: flex; justify-content: space-between;
  margin-top: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.1em;
  flex-wrap: wrap;
  gap: 10px;
}
.wave-btm .in-out { color: var(--rec); }

.zoom { display: flex; align-items: center; gap: 10px; }
.zoom input[type="range"] {
  appearance: none;
  -webkit-appearance: none;
  width: 160px; height: 6px;
  background: #000;
  border: 1px solid #000;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.8);
  border-radius: 2px;
}
.zoom input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  -webkit-appearance: none;
  width: 12px; height: 12px;
  background: var(--rec);
  border: 0;
  border-radius: 50%;
  box-shadow: 0 0 8px rgba(229,52,31,0.5);
  cursor: pointer;
}
.zoom input[type="range"]::-moz-range-thumb {
  width: 12px; height: 12px;
  background: var(--rec);
  border: 0;
  border-radius: 50%;
  box-shadow: 0 0 8px rgba(229,52,31,0.5);
  cursor: pointer;
}

/* Editor action bar (Create Clip / Your Clips) */
.editor-action-bar {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin: 28px 0;
  flex-wrap: wrap;
}

/* ==========================================================
   TRANSCRIPT
   ========================================================== */
.transcript-panel {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 20px;
}
@media (max-width: 1100px) { .transcript-panel { grid-template-columns: 1fr; } }

.transcript {
  background: var(--surface); border: 1px solid var(--border);
  padding: 0;
}
.transcript-fullwidth { /* episode.php full-width mode (no AI sidebar) */
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 16px;
}
.tp-head {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--ink);
  flex-wrap: wrap;
}
.tp-head .title { font-family: var(--font-display); font-size: 20px; text-transform: uppercase; letter-spacing: -0.01em; color: var(--bone); }
.tp-head .search {
  margin-left: auto;
  display: flex; align-items: center; gap: 8px;
  background: #08080a;
  border: 1px solid var(--border);
  padding: 4px 10px;
  border-radius: 2px;
  min-width: 240px;
}
.tp-head .search input {
  background: transparent; border: 0; outline: 0;
  color: var(--text); font-size: 13px; flex: 1; font-family: var(--font-ui);
}
.tp-body {
  padding: 12px 0;
  max-height: 520px;
  overflow-y: auto;
}

/* Transcript lines (formerly .segment) */
.line {
  display: grid;
  grid-template-columns: 80px 1fr;
  padding: 8px 18px;
  gap: 16px;
  font-size: 14px;
  line-height: 1.55;
  cursor: pointer;
}
.line:hover { background: rgba(239,232,216,0.02); }
.line.active { background: rgba(229,52,31,0.08); border-left: 2px solid var(--rec); padding-left: 16px; }
.line.selected { background: rgba(245,181,68,0.08); }
.line .tc { font-family: var(--font-mono); color: var(--amber); font-size: 13px; letter-spacing: 0.04em; }
.line .tx { color: var(--text); }
.line .tx mark { background: rgba(245,181,68,0.25); color: var(--bone); padding: 0 2px; }

/* Legacy alias — editor.js still renders .segment blocks */
.segment {
  display: block;
  padding: 8px 4px;
  border-bottom: 1px dashed var(--ink-4);
}
.segment:last-child { border-bottom: 0; }
.segment-time {
  font-family: var(--font-mono);
  color: var(--amber);
  font-size: 12px;
  letter-spacing: 0.04em;
  margin-right: 8px;
}

/* Word-level highlight */
.word { cursor: pointer; padding: 1px 2px; border-radius: 2px; transition: background 80ms; color: var(--text); }
.word:hover { background: rgba(239,232,216,0.06); }
.word.active { background: var(--rec); color: #fff; }
.word.in-region { background: rgba(245,181,68,0.25); color: var(--bone); }

/* Transcript mobile mode bar */
.transcript-mode-bar {
  display: none;
  gap: 8px;
  padding: 10px 12px;
  background: var(--ink);
  border: 1px solid var(--border);
  margin-bottom: 12px;
  align-items: center;
  flex-wrap: wrap;
}
.transcript-mode-bar .mode-indicator {
  font-family: var(--font-mono); font-size: 11px; color: var(--amber);
  letter-spacing: 0.12em; text-transform: uppercase;
  margin-left: auto;
}
@media (max-width: 880px) { .transcript-mode-bar { display: flex; } }

/* Sidebar */
.side { display: flex; flex-direction: column; gap: 16px; }
.side h3 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--text-3);
  text-transform: uppercase;
  margin: 0 0 10px;
  font-weight: 400;
}
.side-block {
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 18px;
}

/* AI suggestion card */
.suggest {
  padding: 14px 0;
  border-bottom: 1px dashed var(--ink-4);
}
.suggest:last-child { border-bottom: 0; padding-bottom: 0; }
.suggest:first-child { padding-top: 0; }
.suggest .hd { display: flex; justify-content: space-between; align-items: center; }
.suggest .tm { font-family: var(--font-mono); color: var(--amber); font-size: 12px; letter-spacing: 0.04em; }
.suggest .sc {
  font-family: var(--font-mono); font-size: 10px; color: var(--green-led);
  border: 1px solid var(--green-deep); padding: 2px 6px; letter-spacing: 0.08em; text-transform: uppercase;
}
.suggest .preview { margin: 8px 0; font-size: 13px; color: var(--text-2); line-height: 1.45; }
.suggest .acts { display: flex; gap: 6px; }

/* ==========================================================
   WIZARD / MODAL
   ========================================================== */
.overlay {
  position: fixed; inset: 0;
  background: rgba(5,5,6,0.78);
  backdrop-filter: blur(2px);
  display: flex; align-items: center; justify-content: center;
  padding: 40px 20px; z-index: 100;
}
.modal {
  width: 920px; max-width: 100%;
  max-height: calc(100vh - 80px);
  display: flex; flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 8px 0 #000,
    0 24px 60px rgba(0,0,0,0.7);
}
.modal.sm { width: 560px; }
.modal.lg { width: 1100px; }
.m-head {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 24px;
  border-bottom: 1px solid var(--border);
  background: var(--ink);
  flex-shrink: 0;
}
.m-head .title {
  font-family: var(--font-display);
  font-size: 22px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--bone);
}
.m-head .ep {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-3);
  letter-spacing: 0.1em;
  margin-left: 12px;
  text-transform: uppercase;
}
.m-head .x { margin-left: auto; }
.m-body { padding: 24px; overflow-y: auto; flex: 1; }
.m-foot {
  display: flex; justify-content: space-between; gap: 10px;
  padding: 16px 24px;
  border-top: 1px solid var(--border);
  background: var(--ink);
  flex-shrink: 0;
}
.m-foot .right { display: flex; gap: 10px; }

/* Stepper */
.stepper {
  display: flex; gap: 0; align-items: center;
  padding: 14px 18px;
  background: #050506;
  border: 1px solid #000;
  box-shadow: inset 0 2px 6px rgba(0,0,0,0.6);
  margin-bottom: 24px;
  overflow-x: auto;
}
.stepper .step {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 10px;
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.stepper .n {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 600;
  color: var(--text-3);
  flex-shrink: 0;
}
.stepper .step.active { color: var(--bone); }
.stepper .step.active .n { background: var(--rec); border-color: var(--rec); color: #fff; box-shadow: 0 0 10px rgba(229,52,31,0.5); }
.stepper .step.done { color: var(--text-2); }
.stepper .step.done .n { color: var(--amber); border-color: var(--amber); }
.stepper .dash { flex: 1; height: 1px; background: var(--border); margin: 0 6px; min-width: 20px; }

/* Picker cards */
.q {
  font-family: var(--font-display);
  font-size: 28px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 6px;
  color: var(--bone);
}
.sub-copy { color: var(--text-3); font-size: 13px; margin-bottom: 20px; }

.picks { display: grid; gap: 14px; }
.picks.cols-2 { grid-template-columns: repeat(2, 1fr); }
.picks.cols-3 { grid-template-columns: repeat(3, 1fr); }
.picks.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 880px) {
  .picks.cols-3, .picks.cols-4 { grid-template-columns: 1fr; }
  .picks.cols-2 { grid-template-columns: 1fr; }
}

.pick {
  border: 1px solid var(--border);
  background: var(--ink);
  padding: 20px;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 180px;
  position: relative;
  text-align: left;
  color: inherit;
  font: inherit;
}
.pick:hover { border-color: var(--border-hi); }
.pick.active, .pick.selected { border-color: var(--rec); box-shadow: inset 0 0 0 1px var(--rec), 0 0 20px rgba(229,52,31,0.2); }
.pick .btn-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--amber);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.pick .glyph { color: var(--bone); margin: 6px 0 10px; font-size: 28px; line-height: 1; }
.pick .name {
  font-family: var(--font-display);
  font-size: 22px;
  text-transform: uppercase;
  line-height: 1;
  letter-spacing: -0.01em;
  margin-bottom: 6px;
  color: var(--bone);
}
.pick .desc { font-size: 13px; color: var(--text-2); line-height: 1.5; flex: 1; }
.pick.active::before, .pick.selected::before {
  content: "● SELECTED";
  position: absolute; top: 10px; right: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--rec);
  letter-spacing: 0.14em;
}
.pick.disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

/* Field group */
.fld { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.fld .lb {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.fld .help { font-size: 12px; color: var(--text-3); margin-top: 6px; }
.fld .err  { font-size: 12px; color: var(--rec);     margin-top: 6px; }

.fld-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 640px) { .fld-row { grid-template-columns: 1fr; } }

/* Color swatches */
.color-preset-swatches {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.swatch {
  width: 36px; height: 36px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer;
  position: relative;
  padding: 0;
}
.swatch.active, .swatch--active { border-color: var(--bone); box-shadow: 0 0 0 2px rgba(245,181,68,0.4); }
.swatch-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  text-align: center;
  margin-top: 4px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* Summary table */
.summary-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px dashed var(--ink-4);
  font-size: 14px;
}
.summary-row:first-child { border-top: 0; }
.summary-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.summary-value { color: var(--bone); }

/* ==========================================================
   CLIPS PAGE
   ========================================================== */
.filter-pills {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 20px;
}
.filter-pill, .filt {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--border);
  background: var(--surface);
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: var(--r-sm);
}
.filter-pill--active, .filter-pill.active, .filt.active {
  background: var(--rec);
  color: #fff;
  border-color: var(--rec);
}
.filter-pill .n, .filt .n { color: var(--text-3); font-size: 11px; margin-left: 4px; }
.filter-pill--active .n, .filter-pill.active .n, .filt.active .n { color: rgba(255,255,255,0.8); }

.bin-head {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--text-3);
  text-transform: uppercase;
  margin: 28px 0 12px;
  display: flex; align-items: center; gap: 10px;
}
.bin-head .count {
  color: var(--amber);
  border: 1px solid rgba(245,181,68,0.4);
  padding: 2px 8px;
  background: rgba(245,181,68,0.06);
  border-radius: 2px;
}
.bin-head .line { flex: 1; height: 1px; background: var(--border); }

/* 9:16 grid */
.clips-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.clips-list { display: flex; flex-direction: column; gap: 8px; }
@media (max-width: 1100px) { .clips-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 880px)  { .clips-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .clips-grid { grid-template-columns: 1fr; } }

.card9 {
  background: var(--surface);
  border: 1px solid var(--border);
  overflow: hidden;
}
.card9 .preview, .card9 .clip-card-thumb {
  aspect-ratio: 9 / 16;
  background: #000;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
}
.card9 .preview::after, .card9 .clip-card-thumb::after {
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(to bottom, rgba(239,232,216,0.05) 0px, rgba(239,232,216,0.05) 1px, transparent 1px, transparent 3px);
  pointer-events: none;
}
.card9 .preview video, .card9 .clip-card-thumb video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 200ms;
}
.card9 .preview video.loaded, .card9 .clip-card-thumb video.loaded { opacity: 1; }
.card9 .duration-pill {
  position: absolute; bottom: 10px; left: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--amber);
  background: rgba(5,5,6,0.8);
  border: 1px solid var(--amber-deep);
  padding: 2px 6px;
  letter-spacing: 0.04em;
  z-index: 2;
}
.card9 .platform-tag {
  position: absolute; bottom: 10px; right: 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--bone);
  background: rgba(5,5,6,0.8);
  border: 1px solid var(--bone);
  padding: 2px 6px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  z-index: 2;
}
.card9 .play-overlay, .card9 .clip-card-overlay {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(11,11,12,0.6);
  border: 2px solid var(--bone);
  display: flex; align-items: center; justify-content: center;
  color: var(--bone);
  opacity: 0;
  transition: opacity 120ms;
  z-index: 2;
}
.card9:hover .play-overlay, .card9:hover .clip-card-overlay { opacity: 1; }
.card9 .meta, .card9 .clip-card-body { padding: 14px 16px; }
.card9 .meta .title, .card9 .clip-card-title { font-weight: 600; color: var(--bone); font-size: 15px; line-height: 1.3; margin-bottom: 4px; }
.card9 .meta .sub, .card9 .clip-card-episode, .card9 .clip-card-subtitle { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.06em; text-transform: uppercase; }
.card9 .meta .range, .card9 .clip-card-meta { font-family: var(--font-mono); font-size: 11px; color: var(--amber); margin-top: 6px; letter-spacing: 0.04em; }
.card9 .acts, .card9 .clip-card-actions { display: flex; gap: 6px; padding: 0 12px 12px; }
.card9 .acts .hw-btn, .card9 .clip-card-actions .hw-btn { flex: 1; }

/* Draft/rendering row */
.draft-row, .clip-row {
  display: grid;
  grid-template-columns: 110px 1fr 200px 80px 80px auto;
  gap: 16px;
  align-items: center;
  padding: 14px 18px;
  background: var(--surface);
  border: 1px solid var(--border);
}
.draft-row + .draft-row, .clip-row + .clip-row { margin-top: 8px; }
.draft-row .t-title, .clip-row .clip-row-title { font-weight: 600; font-size: 15px; color: var(--bone); }
.draft-row .t-sub, .clip-row .clip-row-episode { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); margin-top: 3px; letter-spacing: 0.04em; text-transform: uppercase; }
.draft-row .range, .clip-row .clip-row-meta { font-family: var(--font-mono); color: var(--amber); font-size: 12px; letter-spacing: 0.04em; }
.draft-row .acts, .clip-row .clip-row-actions { display: flex; gap: 6px; justify-content: flex-end; }
.clip-row-reason { font-size: 11px; color: var(--rec); font-family: var(--font-mono); margin-top: 4px; }
@media (max-width: 880px) {
  .draft-row, .clip-row { grid-template-columns: 1fr; }
  .draft-row .acts, .clip-row .clip-row-actions { justify-content: flex-start; }
}

/* Clip viewer modal */
.modal.clip-viewer { width: 420px; }
.modal.clip-viewer video { width: 100%; display: block; background: #000; }

/* ==========================================================
   SETTINGS (2-col with left s-nav)
   ========================================================== */
.settings-wrap {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 28px;
}
@media (max-width: 880px) {
  .settings-wrap { grid-template-columns: 1fr; }
}

.s-nav {
  border-right: 1px solid var(--border);
  padding-right: 16px;
  display: flex; flex-direction: column; gap: 2px;
}
.s-nav a, .s-nav button {
  display: block;
  padding: 10px 12px;
  color: var(--text-2);
  text-decoration: none;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-left: 2px solid transparent;
  background: transparent;
  border-top: 0;
  border-right: 0;
  border-bottom: 0;
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-weight: normal;
}
.s-nav a:hover, .s-nav button:hover { color: var(--bone); }
.s-nav a.active, .s-nav button.active {
  color: var(--amber);
  border-left-color: var(--amber);
  background: rgba(245,181,68,0.04);
}
@media (max-width: 880px) {
  .s-nav {
    border-right: 0;
    border-bottom: 1px solid var(--border);
    padding-right: 0;
    padding-bottom: 12px;
    flex-direction: row;
    overflow-x: auto;
  }
  .s-nav a, .s-nav button {
    border-left: 0;
    border-bottom: 2px solid transparent;
    white-space: nowrap;
  }
  .s-nav a.active, .s-nav button.active {
    border-left: 0;
    border-bottom-color: var(--amber);
  }
}

.section {
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 24px;
  margin-bottom: 20px;
}
.section h3 {
  font-family: var(--font-display);
  font-size: 20px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 4px;
  color: var(--bone);
}
.section .sub { color: var(--text-3); font-size: 13px; margin-bottom: 20px; }
.section.danger { border-color: rgba(229,52,31,0.3); border-left: 3px solid var(--rec); }
.section.danger h3 { color: var(--rec); }

/* settings field rows (label / control) */
.field {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 20px;
  padding: 16px 0;
  border-top: 1px dashed var(--ink-4);
  align-items: start;
}
.field:first-of-type { border-top: 0; padding-top: 0; }
.field > .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding-top: 10px;
}
.field .ctrl { min-width: 0; }
.field .ctrl input[type="text"],
.field .ctrl input[type="email"],
.field .ctrl input[type="password"],
.field .ctrl input[type="number"],
.field .ctrl input[type="url"],
.field .ctrl textarea,
.field .ctrl select {
  width: 100%;
  background: #08080a;
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.5);
  padding: 10px 12px;
  font-family: var(--font-ui);
  font-size: 14px;
  border-radius: 2px;
  outline: none;
}
.field .ctrl input[type="color"] {
  width: 48px; height: 40px;
  padding: 2px;
  background: #08080a;
  border: 1px solid var(--border);
  border-radius: 2px;
  cursor: pointer;
}
.field .ctrl input:focus,
.field .ctrl textarea:focus,
.field .ctrl select:focus {
  border-color: var(--amber);
  box-shadow: 0 0 0 2px rgba(245,181,68,0.15), inset 0 1px 2px rgba(0,0,0,0.5);
}
.field .ctrl .hint { font-size: 12px; color: var(--text-3); margin-top: 6px; }
.field .ctrl .row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
@media (max-width: 640px) {
  .field { grid-template-columns: 1fr; }
  .field > .lbl { padding-top: 0; }
}

/* Generic form label / input used on non-settings pages */
.form-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 14px 0 6px;
}
.form-input, .form-select, .form-color {
  width: 100%;
  background: #08080a;
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.5);
  padding: 10px 12px;
  font-family: var(--font-ui);
  font-size: 14px;
  border-radius: 2px;
  outline: none;
}
.form-input:focus, .form-select:focus {
  border-color: var(--amber);
  box-shadow: 0 0 0 2px rgba(245,181,68,0.15), inset 0 1px 2px rgba(0,0,0,0.5);
}
.form-color { padding: 3px; height: 40px; cursor: pointer; }
.form-hint { font-size: 12px; color: var(--text-3); margin-top: 6px; }
.form-group { margin-bottom: 16px; }
.checkbox-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; color: var(--text-2);
  cursor: pointer;
  margin: 12px 0;
}
.checkbox-row input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: var(--amber);
  cursor: pointer;
}

/* Toggle switch */
.toggle {
  display: inline-flex; align-items: center; gap: 12px;
  cursor: pointer;
}
.toggle .sw {
  width: 44px; height: 22px;
  background: #050506;
  border: 1px solid #000;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.8);
  position: relative;
  border-radius: 2px;
  flex-shrink: 0;
}
.toggle .sw::after {
  content: "";
  position: absolute; top: 1px; left: 1px;
  width: 18px; height: 18px;
  background: linear-gradient(180deg, #4a4a52 0%, #2a2a30 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 1px 2px rgba(0,0,0,0.6);
  transition: left 120ms;
}
.toggle.on .sw {
  background: #2a1a08;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.8), inset 0 0 10px rgba(245,181,68,0.3);
}
.toggle.on .sw::after {
  left: 23px;
  background: linear-gradient(180deg, var(--amber) 0%, var(--amber-deep) 100%);
  box-shadow: 0 0 6px rgba(245,181,68,0.5);
}
.toggle input[type="checkbox"] { display: none; }
.toggle .name { font-size: 14px; color: var(--bone); }
.toggle .desc { font-size: 12px; color: var(--text-3); margin-top: 2px; }

/* RSS connected card */
.rss {
  display: flex; gap: 16px; align-items: center;
  padding: 20px;
  background: var(--ink);
  border: 1px solid var(--border);
  border-left: 3px solid var(--green-led);
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.rss .cover {
  width: 72px; height: 72px; flex: 0 0 72px;
  background: linear-gradient(135deg, #5a1a0a 0%, #140502 100%);
  border: 1px solid #000;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 26px;
  color: var(--bone);
  object-fit: cover;
}
.rss .info { flex: 1; min-width: 0; }
.rss .info .title { font-family: var(--font-display); font-size: 22px; text-transform: uppercase; letter-spacing: -0.01em; color: var(--bone); }
.rss .info .url { font-family: var(--font-mono); font-size: 12px; color: var(--amber); margin-top: 4px; letter-spacing: 0.04em; word-break: break-all; }
.rss .info .stats { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); margin-top: 6px; letter-spacing: 0.1em; text-transform: uppercase; }
.rss .led-group {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11px;
  color: var(--green-led);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* Template tile grid */
.tpl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 640px) { .tpl-grid { grid-template-columns: 1fr; } }
.tpl {
  background: var(--ink);
  border: 1px solid var(--border);
  overflow: hidden;
  cursor: pointer;
}
.tpl.active { border-color: var(--rec); box-shadow: inset 0 0 0 1px var(--rec); }
.tpl .mini {
  aspect-ratio: 9/16;
  background: #000;
  position: relative;
  background-size: cover;
}
.tpl .mini::after {
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(to bottom, rgba(239,232,216,0.05) 0px, rgba(239,232,216,0.05) 1px, transparent 1px, transparent 3px);
}
.tpl .lbl {
  padding: 10px 14px;
  display: flex; justify-content: space-between; align-items: center;
}
.tpl .lbl .n { font-family: var(--font-display); font-size: 16px; text-transform: uppercase; color: var(--bone); }
.tpl .lbl .d { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.1em; text-transform: uppercase; }

/* ==========================================================
   AUTH SHELL
   ========================================================== */
body.auth-shell { background: var(--ink); }
.auth-shell-wrap {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: 40px 20px;
  background:
    radial-gradient(circle at 50% 0%, rgba(245,181,68,0.04) 0%, transparent 60%),
    var(--ink);
}
.auth-card {
  width: 460px; max-width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 6px 0 #000,
    0 20px 50px rgba(0,0,0,0.6);
  padding: 40px 36px;
}
.auth-logo {
  display: flex; justify-content: center; margin-bottom: 24px;
  color: var(--bone);
}
.auth-logo svg { height: 56px; width: auto; }
.auth-title {
  font-family: var(--font-display);
  font-size: 32px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  text-align: center;
  color: var(--bone);
  margin: 0 0 6px;
}
.auth-sub {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-3);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.auth-form { display: flex; flex-direction: column; gap: 4px; }
.auth-form .hw-btn { margin-top: 12px; }
.auth-footer-links {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px dashed var(--ink-4);
  text-align: center;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-3);
  letter-spacing: 0.1em;
}
.auth-footer-links a { color: var(--amber); text-decoration: none; }
.auth-footer-links a:hover { color: var(--amber-glow); }
.auth-inline-link { color: var(--amber); text-decoration: none; }
.auth-inline-link:hover { color: var(--amber-glow); text-decoration: underline; }
.auth-success-panel {
  padding: 24px;
  background: rgba(52,217,138,0.06);
  border: 1px solid var(--green-deep);
  border-left: 3px solid var(--green-led);
  text-align: center;
  color: var(--text-2);
  margin-bottom: 20px;
}
.auth-success-panel .title {
  font-family: var(--font-display);
  font-size: 22px;
  text-transform: uppercase;
  color: var(--green-led);
  margin-bottom: 8px;
}

/* Password field with show/hide toggle */
.pw-field { position: relative; }
.pw-field input { padding-right: 42px; }
.pw-toggle {
  position: absolute; right: 8px; top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: 0;
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 4px 6px;
}
.pw-toggle:hover { color: var(--amber); }
.pw-hint {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.06em;
  margin-top: 6px;
}
.pw-hint--ok  { color: var(--green-led); }
.pw-hint--bad { color: var(--rec); }

/* ==========================================================
   ADMIN
   ========================================================== */
.admin-shell { display: grid; grid-template-columns: 240px 1fr; min-height: calc(100vh - 64px); }
@media (max-width: 880px) { .admin-shell { grid-template-columns: 1fr; } }
.admin-sidebar {
  background: var(--surface);
  border-right: 1px solid var(--border);
  padding: 20px 16px;
  display: flex; flex-direction: column;
  gap: 2px;
}
.admin-brand {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--amber);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 14px;
  padding: 0 12px;
}
.admin-brand-tag { color: var(--text-4); }
.admin-nav-link {
  display: block;
  padding: 10px 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-2);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border-left: 2px solid transparent;
}
.admin-nav-link:hover { color: var(--bone); }
.admin-nav-link--active, .admin-nav-link.active {
  color: var(--amber);
  border-left-color: var(--amber);
  background: rgba(245,181,68,0.04);
}
.admin-sidebar-foot {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px dashed var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-4);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 16px 12px 0;
}
.admin-main { padding: 32px; }

.admin-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
  border: 1px solid var(--border);
}
.admin-table th {
  text-align: left;
  padding: 12px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--text-3);
  text-transform: uppercase;
  background: var(--ink);
  border-bottom: 1px solid var(--border);
}
.admin-table td {
  padding: 12px 14px;
  font-size: 13px;
  color: var(--text-2);
  border-bottom: 1px solid var(--border);
}
.admin-table tr:last-child td { border-bottom: 0; }
.admin-table tr:hover td { background: rgba(239,232,216,0.015); }

.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; background: var(--border); border: 1px solid var(--border); margin-bottom: 28px; }
@media (max-width: 880px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
.stat-tile { background: var(--surface); padding: 20px; }
.stat-label { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 6px; }
.stat-value { font-family: var(--font-mono); font-size: 28px; color: var(--amber); text-shadow: 0 0 8px rgba(245,181,68,0.4); }

/* Usage bar (used inside usage-card and admin/usage) */
.usage-card {
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 20px;
  margin-bottom: 24px;
}
.usage-card--compact { padding: 14px 18px; }
.usage-card-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.usage-card-foot { text-align: right; font-family: var(--font-mono); font-size: 10px; color: var(--text-4); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 12px; }
.usage-card-reset { color: var(--amber); }
.usage-bars { display: grid; gap: 10px; }
.usage-card--compact .usage-bars { grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 880px) { .usage-card--compact .usage-bars { grid-template-columns: 1fr; } }
.usage-bar-row { display: flex; flex-direction: column; gap: 6px; padding: 6px 0; }
.usage-bar-label {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono); font-size: 11px; color: var(--text-3);
  letter-spacing: 0.12em; text-transform: uppercase;
}
.usage-bar-value { font-family: var(--font-mono); font-size: 14px; color: var(--amber); letter-spacing: 0.04em; text-transform: none; }
.usage-bar-pct { font-family: var(--font-mono); font-size: 10px; color: var(--text-3); margin-left: 6px; }
.usage-bar-track {
  height: 6px;
  background: #08080a;
  border: 1px solid #000;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.6);
  overflow: hidden;
}
.usage-bar-fill { height: 100%; background: var(--amber); }
.usage-bar-row--warn .usage-bar-fill { background: var(--amber); }
.usage-bar-row--danger .usage-bar-fill { background: var(--rec); }

/* ==========================================================
   PODCASTS MANAGEMENT TABLE
   ========================================================== */
.shows-table {
  border: 1px solid var(--border);
  background: var(--surface);
}
.shows-row {
  display: grid;
  grid-template-columns: 72px 1fr 120px 120px 200px;
  gap: 16px;
  padding: 16px 20px;
  align-items: center;
  border-bottom: 1px solid var(--border);
}
.shows-row:last-child { border-bottom: 0; }
.shows-row .art {
  width: 56px; height: 56px;
  object-fit: cover;
  border: 1px solid var(--border);
  background: var(--ink);
}
.shows-row .title { font-weight: 600; color: var(--bone); font-size: 15px; line-height: 1.3; }
.shows-row .meta { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 4px; }
.shows-row .num { font-family: var(--font-mono); color: var(--amber); font-size: 14px; }
.shows-row .acts { display: flex; gap: 8px; justify-content: flex-end; }
@media (max-width: 880px) {
  .shows-row { grid-template-columns: 56px 1fr auto; }
  .shows-row > :nth-child(3), .shows-row > :nth-child(4) { display: none; }
}

/* ==========================================================
   FEED PREVIEW CARD (RSS validate UI)
   ========================================================== */
.feed-preview-card {
  background: var(--ink);
  border: 1px solid var(--border);
  border-left: 3px solid var(--amber);
  padding: 16px;
  margin-top: 14px;
}
.feed-title { font-family: var(--font-display); font-size: 18px; text-transform: uppercase; color: var(--bone); margin-bottom: 4px; letter-spacing: -0.01em; }
.feed-meta { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.08em; text-transform: uppercase; }

/* ==========================================================
   MISC / UTILITIES
   ========================================================== */
.link-button {
  background: none; border: 0; padding: 0;
  color: var(--amber); text-decoration: underline;
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
}
.link-button:hover { color: var(--amber-glow); }

.time-badge, .time-badge--duration {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 2px 6px;
  background: #050506;
  border: 1px solid #000;
  color: var(--amber);
  letter-spacing: 0.04em;
}

/* Legacy badge aliases — editor.js / dashboard.js references .badge-* */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  font-family: var(--font-ui);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-2);
  background: var(--ink-3);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}
.badge-none      { color: var(--text-3); }
.badge-queued    { color: var(--amber);    border-color: rgba(245,181,68,0.35);   background: rgba(245,181,68,0.08); }
.badge-processing{ color: var(--amber);    border-color: rgba(245,181,68,0.35);   background: rgba(245,181,68,0.08); }
.badge-completed { color: var(--green-led);border-color: rgba(52,217,138,0.35);  background: rgba(52,217,138,0.08); }
.badge-failed    { color: var(--rec);      border-color: rgba(229,52,31,0.35);   background: rgba(229,52,31,0.08); }
.badge-draft     { color: var(--amber);    border-color: rgba(245,181,68,0.35);   background: rgba(245,181,68,0.08); }
.badge-pending   { color: var(--text-3); }
.badge-rendering { color: var(--rec);      border-color: rgba(229,52,31,0.35);   background: rgba(229,52,31,0.08); }
.badge-platform  { color: var(--text-2); }
.badge-orient-portrait  { color: var(--text-2); }
.badge-orient-landscape { color: var(--text-2); }

/* Legacy btn-* aliases so existing `btn btn-primary btn-sm` markup (in .m-foot
   of old wizards, and inside JS-emitted HTML) still renders using the new
   hardware-button look until we finish the rename pass. */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 44px;
  height: 38px;
  padding: 0 14px;
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bone);
  background: linear-gradient(180deg, #2A2A30 0%, #16161a 100%);
  border: 1px solid #000;
  border-radius: var(--r-sm);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 -2px 0 rgba(0,0,0,0.5),
    0 2px 0 #000,
    0 3px 6px rgba(0,0,0,0.6);
  cursor: pointer;
  text-decoration: none;
}
.btn:hover { background: linear-gradient(180deg, #32323a 0%, #16161a 100%); }
.btn-primary { background: linear-gradient(180deg, #E5341F 0%, #9B1E0E 100%); color: #fff; }
.btn-primary:hover { background: linear-gradient(180deg, #ff442c 0%, #9B1E0E 100%); }
.btn-secondary { background: linear-gradient(180deg, #2A2A30 0%, #16161a 100%); color: var(--bone); }
.btn-danger { background: linear-gradient(180deg, #E5341F 0%, #6a1006 100%); color: #fff; }
.btn-sm { height: 30px; font-size: 11px; padding: 0 10px; }
.btn-lg { height: 48px; font-size: 13px; padding: 0 20px; }
.btn-icon { width: 36px; padding: 0; }
.btn:disabled, .btn.disabled { opacity: 0.45; cursor: not-allowed; }

/* Row-flex helper */
.row-flex { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.row-flex.end { justify-content: flex-end; }

/* Toolbar group helper — dashboard/clips toolbars */
.toolbar-group { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* Toast */
.toast {
  position: fixed;
  bottom: 24px; right: 24px;
  min-width: 240px;
  padding: 14px 18px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--green-led);
  box-shadow: 0 6px 0 #000, 0 18px 40px rgba(0,0,0,0.5);
  font-size: 14px;
  color: var(--text);
  z-index: 200;
}
.toast.error { border-left-color: var(--rec); }
.toast.info  { border-left-color: var(--amber); }

/* Suggestion card (inside wizard) */
.suggestion-card {
  border: 1px solid var(--border);
  background: var(--ink);
  padding: 14px;
  margin-bottom: 10px;
  cursor: pointer;
}
.suggestion-card:hover { border-color: var(--border-hi); }
.suggestion-card.selected { border-color: var(--rec); box-shadow: inset 0 0 0 1px var(--rec); }
.suggestion-title { font-weight: 600; color: var(--bone); font-size: 14px; margin-bottom: 4px; }
.suggestion-reason { font-size: 12px; color: var(--text-3); line-height: 1.5; margin-bottom: 6px; }
.suggestion-time { font-family: var(--font-mono); color: var(--amber); font-size: 11px; letter-spacing: 0.04em; }
.suggestion-actions { display: flex; gap: 6px; margin-top: 8px; }

/* Image search grid (wizard background picker) */
.image-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
  max-height: 360px; overflow-y: auto;
}
.image-grid-portrait { grid-template-columns: repeat(4, 1fr); }
.image-grid-landscape { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 640px) { .image-grid, .image-grid-portrait, .image-grid-landscape { grid-template-columns: repeat(2, 1fr); } }
.image-candidate {
  background: var(--ink);
  border: 1px solid var(--border);
  cursor: pointer;
  position: relative;
}
.image-candidate img {
  width: 100%;
  aspect-ratio: 2/3;
  object-fit: cover;
  display: block;
}
.image-candidate.selected, .image-candidate img.selected { border-color: var(--rec); box-shadow: inset 0 0 0 1px var(--rec); }
.image-candidate-meta {
  padding: 6px 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.image-candidate-source { color: var(--amber); }
.image-candidate-orient { color: var(--text-4); }
.image-candidate-dims { color: var(--text-4); }

/* Preview frame (wizard — shows mock rendered clip) */
.wizard-preview-frame-wrapper {
  display: flex; justify-content: center; margin: 20px 0;
}
.wizard-preview-frame {
  width: 240px;
  aspect-ratio: 9/16;
  background: #000;
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.wizard-preview-frame::after {
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(to bottom, rgba(239,232,216,0.05) 0px, rgba(239,232,216,0.05) 1px, transparent 1px, transparent 3px);
  pointer-events: none;
}
.preview-bg-layer, .preview-overlay-layer, .preview-caption-layer, .preview-title-layer, .preview-waveform-layer, .preview-platform-badge {
  position: absolute;
}
.preview-bg-layer { inset: 0; background-size: cover; background-position: center; }
.preview-overlay-layer { inset: 0; background: rgba(0,0,0,0.4); }
.preview-caption-layer {
  left: 10px; right: 10px;
  text-align: center;
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 13px;
  color: #fff;
  line-height: 1.2;
  text-transform: uppercase;
  z-index: 3;
}
.preview-caption-layer.pos-top    { top: 24px; }
.preview-caption-layer.pos-center { top: 50%; transform: translateY(-50%); }
.preview-caption-layer.pos-bottom { bottom: 24px; }
.preview-caption-layer .hi { background: rgba(229,52,31,0.6); padding: 0 3px; }
.preview-title-layer {
  top: 12px; left: 12px; right: 12px;
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--bone);
  text-transform: uppercase;
  line-height: 1; letter-spacing: -0.01em;
  z-index: 2;
  text-shadow: 0 1px 4px rgba(0,0,0,0.9);
}
.preview-platform-badge {
  bottom: 10px; right: 10px;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--bone);
  background: rgba(5,5,6,0.8);
  border: 1px solid var(--bone);
  padding: 2px 5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  z-index: 3;
}

/* Clips drawer (episode.php side panel / slide-over) */
.clips-drawer {
  position: fixed;
  right: 0; top: 0; bottom: 0;
  width: 420px; max-width: 100vw;
  background: var(--surface);
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 30px rgba(0,0,0,0.6);
  z-index: 60;
  display: flex; flex-direction: column;
}
.clips-drawer-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--ink);
  display: flex; align-items: center; gap: 12px;
}
.clips-drawer-header h3 {
  font-family: var(--font-display);
  font-size: 20px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--bone);
  margin: 0;
  flex: 1;
}
.clips-drawer-body { padding: 14px 20px; overflow-y: auto; flex: 1; }
.clips-drawer-handle {
  display: none;
  width: 40px; height: 4px;
  background: var(--border);
  border-radius: 2px;
  margin: 0 auto 10px;
}

/* Clip list item (inside drawer) */
.clip-list-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--ink-4);
}
.clip-list-item:last-child { border-bottom: 0; }
.clip-list-item .clip-info { min-width: 0; }
.clip-list-item .clip-title { font-weight: 600; color: var(--bone); font-size: 14px; margin-bottom: 4px; line-height: 1.3; }
.clip-list-item .clip-meta { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.06em; }
.clip-list-item .clip-actions-mini { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }

/* Close button in drawer/modal headers */
.x-btn, .wizard-close-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-3);
  width: 28px; height: 28px;
  border-radius: 2px;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0;
}
.x-btn:hover, .wizard-close-btn:hover { color: var(--bone); border-color: var(--border-hi); }

/* Clip queue note (shown on episode.php under a just-created clip) */
.clip-queue-note {
  padding: 10px 14px;
  background: rgba(245,181,68,0.06);
  border: 1px solid rgba(245,181,68,0.35);
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  margin-bottom: 12px;
  text-transform: uppercase;
}

/* Clip stats (editor drawer header) */
.clips-stats { display: flex; gap: 14px; padding: 10px 0; font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.1em; text-transform: uppercase; }
.clips-stats b { color: var(--amber); font-weight: 400; }

/* Resume wizard pill */
.resume-wizard-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  background: rgba(245,181,68,0.08);
  border: 1px solid rgba(245,181,68,0.35);
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Section heading helpers */
.section-heading {
  font-family: var(--font-display);
  font-size: 20px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 10px;
  color: var(--bone);
}
.section-empty {
  padding: 40px 24px;
  text-align: center;
  color: var(--text-3);
  font-size: 14px;
  border: 1px dashed var(--border);
  background: var(--surface);
}

/* Video preview (used in wizard review + clip modals) */
.video-preview { background: #000; }
.video-preview video { width: 100%; display: block; }

/* Too long badge */
.too-long-badge {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--rec);
  border: 1px solid rgba(229,52,31,0.35);
  padding: 2px 6px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(229,52,31,0.06);
}

/* Wizard-specific helpers */
.wizard-time-display {
  font-family: var(--font-mono);
  color: var(--amber);
  font-size: 22px;
  text-shadow: 0 0 8px rgba(245,181,68,0.4);
  padding: 10px 14px;
  background: #050506;
  border: 1px solid #000;
  display: inline-block;
  letter-spacing: 0.04em;
}
.wizard-time-inputs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 12px;
}
.wizard-summary .summary-row + .summary-row { border-top: 1px dashed var(--ink-4); }
.wizard-hint { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.08em; margin-top: 4px; }
.wizard-input, .wizard-label {
  /* aliases — map to .fld / .vcr-input visually */
}
.wizard-input {
  width: 100%;
  background: #08080a;
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.5);
  padding: 10px 12px;
  font-family: var(--font-ui);
  font-size: 14px;
  border-radius: 2px;
  outline: none;
}
.wizard-input:focus { border-color: var(--amber); box-shadow: 0 0 0 2px rgba(245,181,68,0.15); }
.wizard-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 14px 0 6px;
}

/* Method card / platform card / caption card — aliases of .pick used by editor.js */
.method-card, .platform-card, .caption-card {
  border: 1px solid var(--border);
  background: var(--ink);
  padding: 18px;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 140px;
  position: relative;
}
.method-card:hover, .platform-card:hover, .caption-card:hover { border-color: var(--border-hi); }
.method-card.selected, .platform-card.selected, .caption-card.selected {
  border-color: var(--rec);
  box-shadow: inset 0 0 0 1px var(--rec), 0 0 20px rgba(229,52,31,0.2);
}
.method-card.disabled, .platform-card.disabled, .caption-card.disabled { opacity: 0.5; cursor: not-allowed; }
.method-icon { color: var(--bone); font-size: 24px; }
.method-label, .platform-name, .caption-card-label {
  font-family: var(--font-display);
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--bone);
}
.method-desc, .platform-meta, .caption-card-desc {
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.5;
}
.caption-card-preview {
  margin-top: 10px;
  aspect-ratio: 9/16;
  max-height: 140px;
  background: #000;
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.aspect-preview {
  width: 80px; height: 120px;
  margin: 8px 0;
  border: 1px solid var(--border);
  background: #000;
  position: relative;
}

/* Position picker (caption placement) */
.position-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 6px;
  min-width: 80px;
  height: 70px;
  padding: 8px;
  background: var(--ink);
  border: 1px solid var(--border);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-2);
}
.position-btn.active { border-color: var(--rec); box-shadow: inset 0 0 0 1px var(--rec); color: var(--bone); }
.position-indicator {
  width: 40px; height: 50px;
  background: #000;
  border: 1px solid var(--border);
  position: relative;
  margin-bottom: 4px;
}
.position-indicator::after {
  content: "";
  position: absolute; left: 4px; right: 4px; height: 2px;
  background: var(--bone);
}
.position-indicator--top::after    { top: 4px; }
.position-indicator--center::after { top: 50%; transform: translateY(-50%); }
.position-indicator--bottom::after { bottom: 4px; }

/* Feature card (onboarding) */
.feature-card {
  padding: 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 10px;
}
.feature-icon { font-size: 24px; color: var(--amber); }
.feature-title { font-family: var(--font-display); font-size: 18px; text-transform: uppercase; color: var(--bone); }
.feature-body { font-size: 13px; color: var(--text-2); line-height: 1.55; }

/* Manual search row (background image lookup) */
.manual-search-row {
  display: flex; gap: 8px; margin: 10px 0;
  flex-wrap: wrap;
}
.manual-search-row input { flex: 1; min-width: 200px; }

/* Modal overlay alias (older markup uses .modal-overlay) */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(5,5,6,0.78);
  backdrop-filter: blur(2px);
  display: flex; align-items: center; justify-content: center;
  padding: 40px 20px; z-index: 100;
}
.modal-actions {
  display: flex; gap: 10px; justify-content: flex-end;
  padding-top: 16px;
}

/* UM helpers */
.um-btn { /* legacy, mapped to user-menu-btn */ }
