/* studio.css — extracted from inline <style> in static/index.html.
 * Generated by scripts/extract_inline_assets.py. Do not edit the
 * inline block in index.html and this file in parallel; re-run the
 * extractor to keep them in sync until index.html is fully retired
 * in favor of base.html + index.html (Jinja2).
 */

/* ── Design tokens ──────────────────────────────────────────────── */
:root {
  --bg:   #000000;
  --pu:   #003ebb;
  --gr:   #34c759;
  --re:   #ff453a;
  --gold: #c9a84c;
  --amber: #ff9f0a;

  /* Glass surfaces */
  --s1:  rgba(255,255,255,.04);
  --s2:  rgba(255,255,255,.07);
  --s3:  rgba(255,255,255,.11);
  --bd:  rgba(255,255,255,.09);
  --bd2: rgba(255,255,255,.17);

  /* Text */
  --t1: #f5f5f7;
  --t2: #8e8ea0;
  --t3: #767682;

  /* Tints */
  --pu-dim: #003ebb1f;
  --pu-bd:  #003ebb4d;
  --gr-dim: rgba(52,199,89,.10);
  --gr-bd:  rgba(52,199,89,.28);
  --re-dim: rgba(255,69,58,.10);
  --re-bd:  rgba(255,69,58,.28);

  --sidebar-w: 220px;
  --topbar-h: 52px;

  /* Waveform bar gradients */
  --wf-gray-edge: #505050;
  --wf-gray-mid:  #282828;
  --wf-green-edge: #44dd77;
  --wf-green-mid:  #00ff55;
}

/* ── Light theme overrides ──────────────────────────────────────── */
body.light-theme {
  --bg:   #f2f2f7;
  --s1:   rgba(0,0,0,.03);
  --s2:   rgba(0,0,0,.055);
  --s3:   rgba(0,0,0,.09);
  --bd:   rgba(0,0,0,.09);
  --bd2:  rgba(0,0,0,.17);
  --t1:   #1c1c1e;
  --t2:   #6e6e73;
  --t3:   #98989d;
  --pu:       #003ebb;
  --gold:     #a07825;
  --pu-dim:   rgba(0,62,187,.07);
  --pu-bd:    rgba(0,62,187,.20);
  --gr-dim:   rgba(52,199,89,.12);
  --gr-bd:    rgba(52,199,89,.35);
  --re-dim:   rgba(255,69,58,.10);
  --re-bd:    rgba(255,69,58,.30);

  /* Waveform bar gradients — lighter values for white background */
  --wf-gray-edge: #b0b0b0;
  --wf-gray-mid:  #888888;
  --wf-green-edge: #55bb77;
  --wf-green-mid:  #00aa33;
}
body.light-theme #topbar {
  background: linear-gradient(0deg, rgba(0,62,187,.06), transparent);
  border-bottom: 1px solid rgba(0,62,187,.18);
}
body.light-theme .brand-wordmark { color: #1c1c1e; }
body.light-theme #sidebar        { background: rgba(0,0,0,.025); }
body.light-theme #video-panel    { background: rgba(0,0,0,.018); }
body.light-theme .video-item     { border-bottom: 1px solid rgba(0,0,0,.06); }
body.light-theme .panel-header   { background: rgba(242,242,247,.92); }
body.light-theme .sp-header      { background: rgba(242,242,247,.95); }
body.light-theme .client-item.active { color: var(--pu); }
body.light-theme .brs-track { background: rgba(0,0,0,.06); }
body.light-theme .lang-tab              { background: rgba(0,0,0,.06); color: var(--t1); border-color: rgba(0,0,0,.14); }
body.light-theme .lang-tab:hover        { background: #003ebb !important; color: #fff !important; border-color: #003ebb !important; }
body.light-theme .lang-tab.active       { background: #003ebb; color: #fff; border-color: #003ebb; }
body.light-theme .lang-tab.active:hover { background: #003ebb !important; color: #fff !important; border-color: #003ebb !important; }
body.light-theme .lang-pill             { color: var(--pu); }
body.light-theme .lang-pill:hover       { background: #003ebb !important; color: #fff !important; }
body.light-theme .lang-pill.active      { background: var(--pu) !important; color: #fff !important; border-color: var(--pu) !important; }
body.light-theme .lang-pill.active:hover{ background: #003ebb !important; color: #fff !important; border-color: #003ebb !important; }
body.light-theme .lang-pill-add         { color: var(--t2); border-color: rgba(0,0,0,.18); }

/* ── Light-theme modal / popup overrides ────────────────────────── */
body.light-theme .lang-modal-box        { background: #fff; }
body.light-theme .nc-box                { background: #fff; }
body.light-theme .delete-modal-box      { background: #fff; }
body.light-theme .readiness-modal-box   { background: #fff; }
body.light-theme .readiness-scene-row   { border-bottom-color: rgba(0,0,0,.07); }
body.light-theme .acu-box               { background: #fff; }
body.light-theme .acu-input,
body.light-theme .acu-select,
body.light-theme .acu-textarea          { background: var(--s1); }
body.light-theme .le-modal-box          { background: #fff; }
body.light-theme #notif-panel           { background: rgba(255,255,255,.97); box-shadow:0 8px 36px rgba(0,0,0,.15); }
body.light-theme .le-canvas-wrap        { background: rgba(0,0,0,.04); outline-color: rgba(0,0,0,.1); }
body.light-theme .le-tab                { background: rgba(0,0,0,.05); }
body.light-theme .le-tab:hover          { background: rgba(0,0,0,.09); }
body.light-theme .vx-modal-panel        { background: #fff; }
body.light-theme .vx-modal-header       { border-bottom-color: rgba(0,0,0,.08); }
body.light-theme .vx-modal-footer       { border-top-color: rgba(0,0,0,.08); }
body.light-theme .vx-modal-select        { background: var(--s1); }
body.light-theme .vx-modal-select option { background: #fff; color: #1a1a1a; }
body.light-theme .vx-modal-close:hover   { background: rgba(0,0,0,.06); }
body.light-theme .acu-select option      { background: #fff; color: #1a1a1a; }
body.light-theme .qa-tip-popup           { background: #fff; }

/* ── Light-theme settings / avatar panel overrides ──────────────── */
body.light-theme .settings-panel-hd        { background: rgba(242,242,247,.95); }
body.light-theme #cp-pop                   { background: #fff; border-color: rgba(0,0,0,.12); }
body.light-theme .ql-snow .ql-picker-options { background: #fff; color: #1c1c1e; }
body.light-theme .le-sel option,
body.light-theme .type-sel option,
body.light-theme .scene-type-sel option    { background: #fff; color: #1c1c1e; }
body.light-theme .avatar-panel-hd:hover    { background: rgba(0,0,0,.04); }
body.light-theme .avatar-panel-title       { color: var(--pu); }
body.light-theme .avatar-upload-zone-label { color: var(--pu); }
body.light-theme .bg-upload-zone-label     { color: var(--pu); }
body.light-theme .bg-color-swatch          { border-color: rgba(0,0,0,.18); }
body.light-theme .bg-color-swatch:hover    { border-color: rgba(0,0,0,.35); }

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Sora', sans-serif;
  background: var(--bg);
  color: var(--t1);
  height: 100vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  font-size: 13px;
  -webkit-font-smoothing: antialiased;
}

/* ── Topbar ─────────────────────────────────────────────────────── */
#topbar {
  height: var(--topbar-h);
  background: linear-gradient(0deg, #0054ff3d, transparent);
  border-bottom: 1px solid #0054ffbb;
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 16px;
  flex-shrink: 0;
  z-index: 100;
}

.brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  text-decoration: none;
  color: inherit;
  user-select: none;
}
.brand-lockup:hover .brand-compass {
  border-color: #D4B85E;
}
.brand-compass {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
  transition: border-color 0.2s ease;
}
.brand-compass::before {
  content: '';
  position: absolute;
  width: 1.5px;
  height: 10px;
  background: linear-gradient(180deg, var(--gold) 50%, rgba(201,168,76,0.3) 50%);
  border-radius: 1px;
}
.brand-compass::after {
  content: '';
  position: absolute;
  width: 10px;
  height: 1.5px;
  background: linear-gradient(90deg, rgba(201,168,76,0.3) 50%, var(--gold) 50%);
  border-radius: 1px;
}
.brand-compass-dot {
  position: absolute;
  width: 3px;
  height: 3px;
  background: var(--gold);
  border-radius: 50%;
  z-index: 1;
}
.brand-wordmark {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: 1.50rem;
  letter-spacing: 0.15em;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1;
  padding-right: 0.16em;
}
.topbar-div { width: 1px; height: 22px; background: var(--bd); }
#topbar-right { margin-left: auto; display: flex; align-items: center; gap: 18px; }
.status-pill { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--t2); font-family: 'JetBrains Mono', monospace; }
.status-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--t3); transition: background .3s; }
.status-dot.online  { background: var(--gr); box-shadow: 0 0 5px rgba(52,199,89,.5); }
.status-dot.offline { background: var(--re); }
.status-dot.checking { background: var(--amber); animation: pulse 1s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }

/* ── Layout ─────────────────────────────────────────────────────── */
#main { display: flex; flex: 1; overflow: hidden; min-height: 0; }

/* ── Sidebar ────────────────────────────────────────────────────── */
#sidebar {
  width: var(--sidebar-w);
  background: rgba(255,255,255,.018);
  border-right: 1px solid var(--bd);
  display: flex; flex-direction: column;
  flex-shrink: 0; overflow-y: auto;
}
.sidebar-section { padding: 16px 12px 8px; }
.sidebar-label {
  font-size: 9px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--t3); font-weight: 600; padding: 0 8px; margin-bottom: 6px;
}
.client-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 6px; cursor: pointer;
  color: var(--t2); transition: all .15s; border: 1px solid transparent;
}
.client-item:hover { background: var(--s1); color: var(--t1); }
.client-item.active { background: var(--pu-dim); color: #ffffff; border-color: var(--pu-bd); }
.client-slash-icon { display: flex; gap: 1.5px; align-items: center; flex-shrink: 0; }
.cs { width: 2.5px; height: 10px; border-radius: 1px; transform: skewX(-16deg); }
.cs-1 { background: var(--pu); opacity: .7; }
.cs-2 { background: var(--gr); opacity: .7; }
.cs-3 { background: var(--re); opacity: .7; }
.client-item.active .cs-1, .client-item.active .cs-2, .client-item.active .cs-3 { opacity: 1; }
.client-icon { width: 14px; height: 14px; flex-shrink: 0; opacity: .6; color: var(--t2); }
.client-item.active .client-icon { opacity: 1; color: inherit; }
.client-name { font-size: 12px; font-weight: 500; line-height: 1.3; }
.client-vertical { font-size: 10px; color: var(--t3); margin-top: 1px; }
.sidebar-divider { border: none; border-top: 1px solid var(--bd); margin: 8px 12px; }

/* ── Content ────────────────────────────────────────────────────── */
#content { flex: 1; display: flex; overflow: hidden; min-height: 0; }

/* ── Video panel ────────────────────────────────────────────────── */
#video-panel {
  width: 260px; border-right: 1px solid var(--bd);
  display: flex; flex-direction: column;
  overflow-y: auto; background: rgba(255,255,255,.012); flex-shrink: 0;
}
.panel-header {
  padding: 14px 16px 12px; border-bottom: 1px solid var(--bd);
  position: sticky; top: 0;
  background: var(--s2); backdrop-filter: blur(10px); z-index: 10;
}
.sp-header {
  position: sticky; top: 0; z-index: 10; flex-shrink: 0;
  padding: 12px 16px 10px; border-bottom: 1px solid var(--bd);
  background: var(--s2); backdrop-filter: blur(12px);
}
.panel-title { font-family: 'Cormorant Garamond', serif; font-size: 16px; font-weight: 600; color: var(--t1); margin-bottom: 2px; }
.panel-subtitle { font-size: 11px; color: var(--t3); font-family: 'JetBrains Mono', monospace; }
.video-item { padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,.04); cursor: pointer; transition: background .15s; }
.video-item:hover { background: var(--s1); }
.video-item.active { background: var(--s2); border-left: 2px solid var(--pu); }
.video-name { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--pu); opacity: .8; margin-bottom: 4px; }
.video-item.active .video-name { opacity: 1; }
.video-title { font-size: 12px; font-weight: 500; color: var(--t1); margin-bottom: 6px; }
.video-meta { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; }

/* ── Language pills (video list) ────────────────────────────────── */
.lang-pill { font-size: 9px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 3px; cursor: pointer; border: 1px solid var(--pu-bd);
  background: var(--pu-dim); color: #b0c4ff; transition: background .12s, color .12s; }
.lang-pill:hover { background: var(--pu); color: #fff; }
.lang-pill.active { background: var(--pu); color: #fff; border-color: var(--pu); }
.lang-pill-add { background: transparent; color: var(--t3); border-color: var(--bd); font-size: 11px; padding: 1px 6px; }
.lang-pill-add:hover { background: var(--s2); color: var(--t1); border-color: var(--t3); }

/* ── Language switcher (scene panel header) ─────────────────────── */
.lang-switcher { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; margin-top: 6px; }
.lang-tab { font-size: 9px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 4px; cursor: pointer; border: 1px solid var(--bd);
  background: var(--s1); color: var(--t3); transition: all .12s; }
.lang-tab:hover { background: var(--s2); color: var(--t1); }
.lang-tab.active { background: var(--pu); color: #fff; border-color: var(--pu); }
.lang-tab-add { background: transparent; color: var(--t3); border-style: dashed; }
.lang-tab-add:hover { background: var(--s1); color: var(--t1); border-color: var(--t3); }

/* ── Add-language modal overlay ─────────────────────────────────── */
#lang-modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.7); z-index:200;
  align-items:center; justify-content:center; }
#lang-modal.open { display:flex; }
.lang-modal-box { background:#111; border:1px solid var(--bd2); border-radius:10px;
  padding:20px 24px; min-width:260px; max-width:340px; }
.lang-modal-title { font-size:13px; font-weight:600; color:var(--t1); margin-bottom:14px; }
.lang-option { display:flex; align-items:center; justify-content:space-between;
  padding:7px 10px; border-radius:6px; cursor:pointer; transition:background .12s; }
.lang-option:hover { background:var(--s3); }
.lang-option-name { font-size:12px; color:var(--t1); }
.lang-option-code { font-size:10px; font-family:'JetBrains Mono',monospace; color:var(--t3); text-transform:uppercase; }
.lang-option.adding { background: var(--s3); opacity: .7; cursor: not-allowed; }
.lang-option.adding .lang-option-code { display: none; }
.lang-option.adding .lang-option-name::after { content: ''; display:inline-block; width:10px; height:10px;
  border:2px solid rgba(196,176,255,.3); border-top-color:#b0c4ff; border-radius:50%;
  animation:spin .7s linear infinite; margin-left:8px; vertical-align:middle; }
.lang-modal-status { font-size:11px; color:var(--t3); margin-top:10px; text-align:center;
  display:none; font-style:italic; }
.lang-modal-status.visible { display:block; }
.lang-modal-cancel { margin-top:12px; width:100%; padding:7px; border-radius:6px;
  background:transparent; border:1px solid var(--bd); color:var(--t3); cursor:pointer; font-size:11px; }
.lang-modal-cancel:hover { background:var(--s1); color:var(--t1); }

/* ── Delete video button (hover on group card) ───────────────────── */
.video-item { position: relative; }
.video-delete-btn { position:absolute; top:8px; right:8px; opacity:0; transition:opacity .15s;
  background:transparent; border:none; color:var(--re); cursor:pointer; font-size:13px;
  padding:2px 5px; border-radius:4px; line-height:1; }
.video-item:hover .video-delete-btn { opacity:.6; }
.video-delete-btn:hover { opacity:1 !important; background:rgba(255,69,58,.12); }

/* ── Delete confirmation modal ───────────────────────────────────── */
#delete-modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:200;
  align-items:center; justify-content:center; }
#delete-modal.open { display:flex; }
.delete-modal-box { background:var(--s2); border:1px solid rgba(255,69,58,.3); border-radius:10px;
  padding:20px 24px; min-width:280px; max-width:360px; }
.delete-modal-title { font-size:13px; font-weight:600; color:var(--t1); margin-bottom:4px; }
.delete-modal-sub { font-size:11px; color:var(--t3); margin-bottom:16px; }
.delete-option-row { display:flex; flex-direction:column; gap:7px; margin-bottom:12px; }
.delete-opt { display:flex; align-items:center; justify-content:space-between;
  padding:9px 12px; border-radius:7px; cursor:pointer; border:1px solid var(--bd);
  background:var(--s1); transition:background .12s, border-color .12s; }
.delete-opt:hover { background:rgba(255,69,58,.1); border-color:rgba(255,69,58,.4); }
.delete-opt-label { font-size:12px; color:var(--t1); }
.delete-opt-scope { font-size:10px; font-family:'JetBrains Mono',monospace; color:var(--re); text-transform:uppercase; }
.delete-opt.danger { background:rgba(255,69,58,.08); border-color:rgba(255,69,58,.3); }
.delete-opt.danger:hover { background:rgba(255,69,58,.18); border-color:rgba(255,69,58,.6); }
.delete-modal-cancel { width:100%; padding:7px; border-radius:6px;
  background:transparent; border:1px solid var(--bd); color:var(--t3); cursor:pointer; font-size:11px; }
.delete-modal-cancel:hover { background:var(--s1); color:var(--t1); }

/* ── New Client Modal ───────────────────────────────────────────── */
#new-client-modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:200;
  align-items:center; justify-content:center; }
#new-client-modal.open { display:flex; }
.nc-box { background:#0e0e0e; border:1px solid var(--bd2); border-radius:12px;
  padding:24px 28px; width:480px; max-width:calc(100vw - 32px); max-height:90vh; overflow-y:auto; }
.nc-title { font-size:13px; font-weight:600; color:var(--t1); margin-bottom:20px; }
.nc-field { margin-bottom:14px; }
.nc-label { font-size:10px; font-weight:500; color:var(--t3); text-transform:uppercase;
  letter-spacing:.05em; margin-bottom:5px; }
.nc-input { width:100%; box-sizing:border-box; background:var(--s1); border:1px solid var(--bd);
  border-radius:6px; padding:7px 10px; font-size:12px; color:var(--t1); outline:none;
  transition:border-color .15s; }
.nc-input:focus { border-color:var(--pu-bd); }
.nc-color-row { display:flex; gap:10px; }
.nc-color-field { flex:1; }
.nc-swatch { display:flex; gap:6px; align-items:center; }
.nc-picker { width:28px; height:28px; border:1px solid var(--bd); border-radius:4px;
  padding:2px; cursor:pointer; background:var(--s1); flex-shrink:0; }
.nc-hex { flex:1; background:var(--s1); border:1px solid var(--bd); border-radius:6px;
  padding:6px 8px; font-size:11px; color:var(--t1); font-family:'JetBrains Mono',monospace;
  outline:none; width:100%; box-sizing:border-box; transition:border-color .15s; }
.nc-hex:focus { border-color:var(--pu-bd); }
.nc-footer { display:flex; gap:8px; margin-top:20px; }
.nc-cancel { flex:1; padding:8px; border-radius:6px; background:transparent;
  border:1px solid var(--bd); color:var(--t3); cursor:pointer; font-size:12px; }
.nc-cancel:hover { background:var(--s1); color:var(--t1); }
.nc-confirm { flex:2; padding:8px; border-radius:6px; background:var(--pu);
  border:none; color:#fff; cursor:pointer; font-size:12px; font-weight:500; }
.nc-confirm:hover:not(:disabled) { background:#8b62ff; }
.nc-confirm:disabled { opacity:.45; cursor:not-allowed; }
.nc-error { font-size:11px; color:var(--re); margin-top:10px; display:none; }
.nc-error.visible { display:block; }
.nc-add-btn { background:none; border:1px solid var(--bd); border-radius:4px; color:var(--t3);
  cursor:pointer; font-size:13px; line-height:1; padding:1px 6px; transition:all .12s; }
.nc-add-btn:hover { background:var(--pu-dim); border-color:var(--pu-bd); color:#b0c4ff; }

/* ── Badges ─────────────────────────────────────────────────────── */
.badge { font-size: 9px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; padding: 2px 6px; border-radius: 3px; }
.badge-lang { background: var(--pu-dim); color: #b0c4ff; border: 1px solid var(--pu-bd); }
.badge-cat  { background: var(--gr-dim); color: #6eea8a; border: 1px solid var(--gr-bd); }
.badge-ver  { background: var(--s1); color: var(--t3); border: 1px solid var(--bd); }
.badge-new  { background: rgba(52,199,89,.15); color: #6eea8a; border: 1px solid rgba(52,199,89,.30); }

/* ── Panel header row (title + button) ──────────────────────────── */
.panel-header-row { display: flex; align-items: center; gap: 8px; }
.panel-header-info { flex: 1; min-width: 0; }

/* ── Ingest drop zone ───────────────────────────────────────────── */
.ingest-zone {
  margin: 10px 12px 6px;
  border: 1px dashed rgba(52,199,89,.50);
  border-radius: 8px;
  background: rgba(52,199,89,.04);
  padding: 14px 12px 12px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  position: relative;
  overflow: hidden;
}
.ingest-zone:hover:not(.processing), .ingest-zone.drag-over:not(.processing) {
  border-color: transparent;
  background: rgba(123,82,245,.06);
  box-shadow:
    0 0  8px 2px rgba(123, 82, 245, 0.30),
    0 0 14px 4px rgba(  0,212, 160, 0.16),
    0 0 20px 6px rgba( 77,166, 255, 0.10);
}
.ingest-zone:hover:not(.processing)::before,
.ingest-zone.drag-over:not(.processing)::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 8px;
  padding: 2px;
  background: conic-gradient(
    from var(--ingest-angle),
    #7b52f5, #00d4a0, #4da6ff, #c9a84c, #7b52f5
  );
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: ingest-border-spin 5s linear infinite;
}
.ingest-zone.processing { cursor: not-allowed; pointer-events: none; border-color: rgba(52,199,89,.22); }
.ingest-zone-icon { font-size: 18px; color: var(--gr); opacity: .7; margin-bottom: 5px; line-height: 1; }
.ingest-zone-label { font-size: 11px; font-weight: 500; color: var(--t2); }
.ingest-zone-sub { font-size: 9px; color: var(--t3); margin-top: 3px; letter-spacing: .05em; text-transform: uppercase; }
.ingest-file-list { margin-top: 8px; display: flex; flex-direction: column; gap: 3px; text-align: left; }
.ingest-file-item {
  font-size: 9px; color: var(--t2); font-family: 'JetBrains Mono', monospace;
  background: rgba(52,199,89,.07); border-radius: 3px; padding: 2px 7px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ingest-status { font-size: 10px; color: var(--t2); margin-top: 8px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.ingest-spinner {
  width: 12px; height: 12px; border: 2px solid rgba(52,199,89,.2);
  border-top-color: var(--gr); border-radius: 50%;
  animation: spin .7s linear infinite; flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }
@property --ingest-angle { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
@keyframes ingest-border-spin { to { --ingest-angle: 360deg; } }
.ingest-progress-bar {
  position: absolute; bottom: 0; left: -60%; height: 2px;
  width: 50%; background: linear-gradient(90deg, transparent, var(--gr), transparent);
  animation: ingest-scan 1.6s ease-in-out infinite;
}
@keyframes ingest-scan { to { left: 110%; } }
.ingest-error { font-size: 10px; color: var(--re); margin-top: 8px; }

/* ── Video item title editing ───────────────────────────────────── */
.video-title-row { display: flex; align-items: center; gap: 4px; margin-bottom: 6px; }
.video-title-text {
  flex: 1; min-width: 0; font-size: 12px; font-weight: 500; color: var(--t1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.video-title-input {
  flex: 1; min-width: 0; background: transparent; border: none;
  border-bottom: 1px dashed transparent; color: var(--t1);
  font-size: 12px; font-weight: 500; font-family: inherit;
  outline: none; padding: 0 2px; transition: border-color .15s;
}
.video-title-input:hover { border-bottom-color: var(--bd2); }
.video-title-input:focus { border-bottom-color: var(--pu); }

/* ── Scene panel ────────────────────────────────────────────────── */
#scene-panel { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }

/* ── Music panel ────────────────────────────────────────────────── */
#music-panel {
  flex-shrink: 0;
  border-bottom: 1px solid var(--bd);
  background: rgba(201,168,76,.03);
}
.music-header {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 16px; cursor: pointer; user-select: none;
  transition: background .15s;
}
.music-header:hover { background: rgba(255,255,255,.02); }
.music-icon { font-size: 13px; opacity: .45; }
.music-title { font-size: 11px; font-weight: 600; color: var(--gold); letter-spacing: .06em; text-transform: uppercase; flex: 1; }
.music-chevron { font-size: 10px; color: var(--t3); transition: transform .2s; }
#music-panel.open .music-chevron { transform: rotate(180deg); }
.music-body {
  display: none;
  padding: 0 16px 14px;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
#music-panel.open .music-body { display: grid; }
.music-param { display: flex; flex-direction: column; gap: 4px; }
.music-label { font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); font-weight: 600; }
.music-input {
  background: var(--s2); border: 1px solid var(--bd); color: var(--t1);
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  padding: 5px 8px; border-radius: 4px; width: 100%;
  transition: border-color .15s;
}
.music-input:focus { outline: none; border-color: rgba(201,168,76,.5); }
.music-tags { grid-column: 1 / -1; }
.music-tags .music-input { font-family: 'Sora', sans-serif; font-size: 11px; resize: none; }
.music-footer { grid-column: 1 / -1; display: flex; justify-content: flex-end; }
.music-param-half { grid-column: span 2; }
.music-label-row { display: flex; justify-content: space-between; align-items: center; }
.music-slider-val { font-size: 10px; color: var(--t2); font-family: 'JetBrains Mono', monospace; }
.music-slider { -webkit-appearance: none; appearance: none; width: 100%; height: 3px; border-radius: 2px; background: var(--bd); outline: none; cursor: pointer; }
.music-slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 12px; height: 12px; border-radius: 50%; background: var(--gold); cursor: pointer; }
.music-adv-toggle { grid-column: 1 / -1; display: flex; align-items: center; gap: 6px; cursor: pointer; padding: 5px 0 2px; border-top: 1px solid var(--bd); margin-top: 2px; user-select: none; }
.music-adv-label { font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); font-weight: 600; flex: 1; }
.music-adv-chevron { font-size: 9px; color: var(--t3); transition: transform .2s; }
.music-adv-body { grid-column: 1 / -1; display: none; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.music-ap-slot { grid-column: 1 / -1; }
.music-ap-wrap {
  display: flex; align-items: center; gap: 8px;
  background: rgba(201,168,76,.06); border: 1px solid rgba(201,168,76,.2);
  border-radius: 6px; padding: 6px 10px;
}
.music-plb {
  width: 26px; height: 26px; flex-shrink: 0;
  border-radius: 50%; border: 1px solid rgba(201,168,76,.4);
  background: rgba(201,168,76,.12); color: var(--gold);
  font-size: 9px; cursor: pointer; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s; user-select: none;
}
.music-plb:hover { background: rgba(201,168,76,.22); border-color: var(--gold); }
.music-ap-none { font-size: 10px; color: var(--t3); font-style: italic; padding: 2px 0; }
.btn-gold {
  padding: 6px 14px; border-radius: 5px; border: 1px solid rgba(201,168,76,.35);
  background: rgba(201,168,76,.10); color: var(--gold);
  font-size: 11px; font-weight: 600; font-family: 'Sora', sans-serif;
  cursor: pointer; transition: all .15s; letter-spacing: .04em;
  position: relative; overflow: hidden;
}
.btn-gold:hover { background: rgba(201,168,76,.18); border-color: rgba(201,168,76,.55); }
.btn-gold:disabled { opacity: .5; cursor: not-allowed; }

/* ── Scene list ─────────────────────────────────────────────────── */
#scene-list { flex: 1; overflow-y: auto; min-height: 0; padding: 14px 16px 40px; display: flex; flex-direction: column; gap: 10px; }

.section-block { display: flex; flex-direction: column; gap: 10px; }
.section-label {
  font-size: 9px; letter-spacing: .13em; text-transform: uppercase;
  color: var(--t3); font-weight: 600; padding: 4px 0; margin-top: 4px;
  display: flex; align-items: center; gap: 6px;
}
.section-label::after { content: ''; flex: 1; height: 1px; background: var(--bd); }
.dnd-handle {
  cursor: grab; color: var(--t3); font-size: 14px; flex-shrink: 0;
  user-select: none; padding: 0 1px; line-height: 1; transition: color .15s;
  letter-spacing: 0; text-transform: none;
}
.dnd-handle:hover { color: var(--pu); }
.dnd-handle:active { cursor: grabbing; }
.dnd-dragging { opacity: 0.35; }
.drop-above { box-shadow: 0 -3px 0 0 var(--pu) !important; }
.drop-below { box-shadow: 0 3px 0 0 var(--pu) !important; }

/* ── Scene card ─────────────────────────────────────────────────── */
.scene-card {
  background: var(--s1); border: 1px solid var(--bd);
  border-radius: 10px; transition: border-color .15s;
  display: flex; flex-direction: column;
}
.scene-card:hover { border-color: var(--bd2); }
.scene-card.selected { border-color: var(--pu); }

.scene-header {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; cursor: pointer;
  border-bottom: 1px solid transparent; transition: border-color .15s;
}
.scene-card.selected .scene-header { border-bottom-color: var(--bd); }

.scene-id {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--t3);
  background: rgba(255,255,255,.06); padding: 2px 6px; border-radius: 3px;
  flex-shrink: 0; border: 1px solid var(--bd);
}
.scene-type-badge {
  font-size: 9px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 3px; flex-shrink: 0;
}
.type-intro_wide  { background: rgba(123,82,245,.2);  color: #b0c4ff; border: 1px solid rgba(123,82,245,.3); }
.type-intro_close { background: rgba(123,82,245,.12); color: #b09ef0; border: 1px solid rgba(123,82,245,.2); }
.type-intro       { background: rgba(123,82,245,.2);  color: #b0c4ff; border: 1px solid rgba(123,82,245,.3); }
.type-content     { background: var(--gr-dim); color: #6eea8a; border: 1px solid var(--gr-bd); }
.type-outro       { background: rgba(201,168,76,.1); color: var(--gold); border: 1px solid rgba(201,168,76,.25); }
.scene-type-sel {
  font-size: 9px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
  padding: 2px 5px; border-radius: 3px; flex-shrink: 0;
  background: rgba(255,255,255,.06); border: 1px solid var(--bd);
  color: var(--t2); cursor: pointer; appearance: none; -webkit-appearance: none;
}
.scene-type-sel:focus { outline: none; border-color: var(--pu); }
.slide-title-text { flex: 1; min-width: 0; font-size: 12px; font-weight: 500; color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.scene-title-input {
  background: transparent; border: none; border-bottom: 1px dashed transparent;
  color: var(--t1); font-size: 12px; font-weight: 500; font-family: inherit;
  outline: none; flex: 1; min-width: 0; padding: 0 2px; transition: border-color .15s;
}
.scene-title-input:hover { border-bottom-color: var(--bd2); }
.scene-title-input:focus { border-bottom-color: var(--pu); }
.btn-icon-edit {
  background: transparent; border: none; color: var(--t3); font-size: 11px;
  padding: 1px 4px; cursor: pointer; border-radius: 3px; flex-shrink: 0;
  transition: color .15s, background .15s; line-height: 1;
}
.btn-icon-edit:hover { color: var(--pu); background: var(--pu-dim); }
.btn-icon-action {
  background: transparent; border: 1px solid var(--bd); color: var(--t3);
  font-size: 9px; font-weight: 500; font-family: inherit; letter-spacing: 0;
  text-transform: none; padding: 1px 6px; cursor: pointer; border-radius: 3px;
  flex-shrink: 0; transition: all .15s;
}
.btn-icon-action:hover { border-color: var(--pu-bd); color: #b0c4ff; background: var(--pu-dim); }
.btn-icon-remove {
  background: transparent; border: none; color: var(--t3); font-size: 11px;
  padding: 1px 4px; cursor: pointer; border-radius: 3px; flex-shrink: 0;
  transition: color .15s, background .15s; line-height: 1;
}
.btn-icon-remove:hover { color: var(--re); background: var(--re-dim); }
.scene-dur { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--t3); flex-shrink: 0; }

/* Expanded body — two columns */
.scene-body { display: none; flex-direction: row; border-bottom: 1px solid var(--bd); }
.scene-card.selected .scene-body { display: flex; }
.editor .scene-card .scene-body { display: flex; }

/* ── Left column ────────────────────────────────────────────────── */
.scene-left {
  width: 178px; flex-shrink: 0;
  border-right: 1px solid var(--bd);
  display: flex; flex-direction: column;
}
.avatar-placeholder {
  margin: 10px; border-radius: 7px;
  border: 1.5px dashed var(--pu-bd);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 5px; padding: 16px 10px; min-height: 112px;
  cursor: pointer; transition: all .15s; text-align: center;
}
.avatar-placeholder:hover { border-color: var(--pu); background: var(--pu-dim); }
.avatar-placeholder.done { border-style: solid; border-color: var(--gr-bd); background: var(--gr-dim); cursor: default; }
.avatar-icon { font-size: 20px; opacity: .4; line-height: 1; }
.avatar-label { font-size: 9px; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; color: var(--pu); }
.avatar-placeholder.done .avatar-label { color: var(--gr); }
.avatar-sub { font-size: 9px; color: var(--t3); line-height: 1.4; }

.broll-strip { border-top: 1px solid var(--bd); padding: 8px; display: flex; flex-direction: column; gap: 5px; }
.broll-strip-hd { font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); font-weight: 600; padding: 0 2px; }
.broll-thumb-unit { display: flex; flex-direction: column; }
.broll-thumb {
  display: flex; flex-direction: column;
  background: var(--s2); border: 1px solid var(--bd);
  border-radius: 5px; overflow: hidden; cursor: default; transition: border-color .15s;
}
.broll-thumb:hover { border-color: var(--bd2); }
.broll-thumb.done { border-color: var(--gr-bd); }
.broll-thumb-img {
  width: 100%; aspect-ratio: 16/9;
  background: rgba(255,255,255,.06);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; color: var(--t3); overflow: hidden; cursor: pointer;
  position: relative;
}
.broll-thumb-img:hover { opacity: .88; }
.broll-thumb-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.brprog-shimmer {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(90deg, transparent 25%, rgba(255,255,255,.09) 50%, transparent 75%);
  background-size: 200% 100%;
  animation: brprog-shimmer 1.6s ease-in-out infinite;
}
@keyframes brprog-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.brprog-bar {
  position: absolute; bottom: 0; left: 0;
  height: 3px; width: 0; pointer-events: none;
  background: var(--gr, #34c759);
  transition: width 150ms ease-out;
  border-radius: 0 2px 2px 0;
}
.broll-thumb-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 4px 7px; gap: 6px; border-top: 1px solid var(--bd);
}
.broll-thumb-label {
  font-family: 'JetBrains Mono', monospace; font-size: 9px;
  color: var(--t2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.broll-thumb-edit {
  font-size: 9px; padding: 1px 5px; border-radius: 3px; border: 1px solid var(--bd2);
  background: transparent; color: var(--t2); cursor: pointer; flex-shrink: 0;
  transition: background .12s, color .12s;
}
.broll-thumb-edit:hover { background: var(--s3); color: var(--t1); }
.broll-add {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  background: transparent; border: 1px dashed var(--bd);
  border-radius: 5px; padding: 5px; cursor: pointer;
  font-size: 10px; color: var(--t3); transition: all .15s;
}
.broll-add:hover { border-color: var(--pu-bd); color: #b0c4ff; background: var(--pu-dim); }

/* ── Right column ───────────────────────────────────────────────── */
.scene-right { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.narration-section { padding: 11px 14px; border-bottom: 1px solid var(--bd); }
.field-label { font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); font-weight: 600; margin-bottom: 5px; }
.narration-ta {
  width: 100%; background: var(--s2); border: 1px solid var(--bd); color: var(--t1);
  font-family: 'Sora', sans-serif; font-size: 12px; line-height: 1.65;
  padding: 7px 9px; border-radius: 5px; resize: vertical; min-height: 76px;
  transition: border-color .15s;
}
.narration-ta:focus { outline: none; border-color: var(--pu-bd); }
.row-btns { display: flex; gap: 5px; margin-top: 6px; }

/* ── Narration block partial (scene-card__narration) ────────────────
   BEM-scoped styles for partials/narration_block.html.
   Mirrors .narration-section / .narration-ta / .row-btns for visual
   parity with the :8000 monolith while the two servers run side-by-side.
   ─────────────────────────────────────────────────────────────────── */
.scene-card__narration { padding: 11px 14px; border-bottom: 1px solid var(--bd); }

.scene-card__narration-label {
  font-size: 9px; text-transform: uppercase; letter-spacing: .1em;
  color: var(--t3); font-weight: 600; display: block; margin-bottom: 5px;
}

.scene-card__narration-input {
  width: 100%; background: var(--s2); border: 1px solid var(--bd); color: var(--t1);
  font-family: 'Sora', sans-serif; font-size: 12px; line-height: 1.65;
  padding: 7px 9px; border-radius: 5px; resize: vertical; min-height: 76px;
  box-sizing: border-box; transition: border-color .15s;
}
.scene-card__narration-input:focus { outline: none; border-color: var(--pu-bd); }

.scene-card__narration-actions { display: flex; gap: 5px; margin-top: 6px; align-items: center; }

/* .htmx-indicator: hidden by default, shown while request is in-flight */
.scene-card__narration-indicator { font-size: 10px; color: var(--t3); opacity: 0; transition: opacity .15s; }
.htmx-request .scene-card__narration-indicator,
.htmx-request.scene-card__narration-indicator { opacity: 1; }

.scene-card__narration-saved { font-size: 10px; color: var(--gr); margin-left: 4px; animation: narration-saved-fade 0.4s 3s forwards; }
@keyframes narration-saved-fade { to { opacity: 0; } }

/* Editor shell — wraps all scene cards rendered by editor.html */
.editor { padding: 16px; display: flex; flex-direction: column; gap: 12px; flex: 1; overflow-y: auto; min-height: 0; }
.editor__title {
  font-family: 'Cormorant Garamond', serif; font-size: 22px;
  color: var(--t1); margin-bottom: 8px;
}
.scene-card { background: var(--s1); border: 1px solid var(--bd); border-radius: 8px; overflow: hidden; flex-shrink: 0; }
.scene-card__title {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .08em; color: var(--t2); padding: 10px 14px;
  border-bottom: 1px solid var(--bd);
}

.section-title-input {
  background: transparent; border: none; border-bottom: 1px dashed transparent;
  color: var(--t3); font-size: 9px; font-weight: 600; letter-spacing: .13em;
  text-transform: uppercase; font-family: inherit; outline: none;
  width: 160px; padding: 0 2px; transition: border-color .15s;
}
.section-title-input:hover { border-bottom-color: var(--bd2); }
.section-title-input:focus { border-bottom-color: var(--pu); color: var(--t1); }
.btn-sec-save {
  font-size: 8px; padding: 1px 6px; border: 1px solid var(--bd);
  background: transparent; color: var(--t3); border-radius: 3px;
  cursor: pointer; font-family: inherit; transition: all .15s;
}
.btn-sec-save:hover { border-color: var(--bd2); color: var(--t2); }
.btn-sec-save.ok { border-color: var(--gr-bd); background: var(--gr-dim); color: #6eea8a; }

.btn-sm {
  padding: 4px 10px; border-radius: 4px; border: 1px solid var(--bd);
  background: var(--s1); color: var(--t2); font-size: 10px; font-weight: 500;
  font-family: 'Sora', sans-serif; cursor: pointer; transition: all .15s;
  position: relative; overflow: hidden;
}
.btn-sm:hover { border-color: var(--bd2); color: var(--t1); }
.btn-sm.pu   { border-color: var(--pu-bd); background: var(--pu-dim); color: #b0c4ff; }
.btn-sm.pu:hover { background: rgba(123,82,245,.2); border-color: var(--pu); }
.btn-sm.ok   { border-color: var(--gr-bd); background: var(--gr-dim); color: #6eea8a; }
.btn-sm.err  { border-color: var(--re-bd); background: var(--re-dim); color: var(--re); }
.btn-sm:disabled { opacity: .45; cursor: not-allowed; }

/* B-roll accordions */
.broll-accordions { padding: 8px 14px; border-top: 1px solid var(--bd); border-bottom: 1px solid var(--bd); display: flex; flex-direction: column; gap: 5px; }
.broll-accordions-hd { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); margin-bottom: 6px; }
.broll-accord { background: var(--s1); border: 1px solid var(--bd); border-radius: 6px; overflow: hidden; }
.broll-accord-hd {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 10px; cursor: pointer; transition: background .15s;
}
.broll-accord-hd:hover { background: var(--s2); }
.ba-id { font-family: 'JetBrains Mono', monospace; font-size: 9px; color: var(--t3); }
.ba-type { font-size: 9px; font-weight: 600; padding: 1px 5px; border-radius: 3px; background: var(--pu-dim); color: #b0c4ff; border: 1px solid var(--pu-bd); }
.ba-status { font-size: 9px; margin-left: auto; }
.ba-status.pending { color: var(--t3); }
.ba-status.done    { color: var(--gr); }
.ba-chev { font-size: 9px; color: var(--t3); transition: transform .2s; }
.broll-accord.open .ba-chev { transform: rotate(180deg); }
.broll-accord-body { display: none; padding: 0 10px 10px; flex-direction: column; gap: 7px; }
.broll-accord.open .broll-accord-body { display: flex; }
.broll-field { display: flex; flex-direction: column; gap: 3px; }
.broll-field-label { font-size: 9px; text-transform: uppercase; letter-spacing: .09em; color: var(--t3); font-weight: 600; }
.prompt-ta {
  width: 100%; background: var(--s2); border: 1px solid var(--bd); color: var(--t1);
  font-family: 'Sora', sans-serif; font-size: 11px; line-height: 1.55;
  padding: 6px 8px; border-radius: 4px; resize: vertical; min-height: 52px;
  transition: border-color .15s;
}
.prompt-ta:focus { outline: none; border-color: var(--pu-bd); }
.timing-row { display: flex; gap: 6px; align-items: center; }
.timing-input {
  width: 58px; background: var(--s2); border: 1px solid var(--bd);
  color: var(--t1); font-family: 'JetBrains Mono', monospace; font-size: 11px;
  padding: 4px 7px; border-radius: 4px; text-align: center; transition: border-color .15s;
}
.timing-input:focus { outline: none; border-color: var(--pu-bd); }
.timing-sep { font-size: 10px; color: var(--t3); }
.type-sel {
  flex: 1; background: var(--s2); border: 1px solid var(--bd); color: var(--t1);
  font-family: 'Sora', sans-serif; font-size: 11px; padding: 4px 7px; border-radius: 4px;
}
.type-sel:focus { outline: none; border-color: var(--pu-bd); }
.broll-accord-foot { display: flex; gap: 6px; align-items: center; }

/* Audio player */
.audio-section { padding: 10px 14px; border-bottom: 1px solid var(--bd); }
.audio-none { font-size: 11px; color: var(--t3); font-style: italic; }
.ap-wrap {
  display: flex; align-items: center; gap: 8px;
  background: var(--s2); border: 1px solid var(--bd);
  border-radius: 6px; padding: 6px 10px;
}
.plb {
  width: 26px; height: 26px; flex-shrink: 0;
  border-radius: 50%; border: 1px solid var(--pu-bd);
  background: var(--pu-dim); color: #b0c4ff;
  font-size: 9px; cursor: pointer; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s; user-select: none;
}
.plb:hover { background: rgba(123,82,245,.22); border-color: var(--pu); }
.ap-center { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.wf-svg { width: 100%; height: 32px; cursor: pointer; }
.ap-time { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--t3); flex-shrink: 0; }

/* ── Slide content editor (Quill) ───────────────────────────────── */
.slide-content-section { padding: 8px 14px; border-bottom: 1px solid var(--bd); }
.slide-content-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.ql-toolbar.ql-snow { background: var(--s2); border: 1px solid var(--bd); border-radius: 4px 4px 0 0; padding: 4px 6px; }
.ql-toolbar.ql-snow .ql-stroke { stroke: var(--t2); }
.ql-toolbar.ql-snow .ql-fill   { fill:   var(--t2); }
.ql-toolbar.ql-snow .ql-picker-label { color: var(--t2); }
.ql-toolbar.ql-snow button:hover .ql-stroke,
.ql-toolbar.ql-snow button.ql-active .ql-stroke { stroke: var(--t1); }
.ql-toolbar.ql-snow button:hover .ql-fill,
.ql-toolbar.ql-snow button.ql-active .ql-fill   { fill:   var(--t1); }
.ql-toolbar.ql-snow .ql-picker-label:hover,
.ql-toolbar.ql-snow .ql-picker-item:hover { color: var(--t1); }
.ql-container.ql-snow { background: var(--s1); border: 1px solid var(--bd); border-top: none; border-radius: 0 0 4px 4px; height: auto; max-height: 200px; overflow-y: auto; }
.ql-editor { color: var(--t1); font-family: 'Sora', sans-serif; font-size: 12px; min-height: 80px; padding: 8px 10px; }
.ql-editor.ql-blank::before { color: var(--t3); font-style: italic; }
.ql-editor ul > li::before { color: var(--t2); }
.ql-snow .ql-picker { color: var(--t2); }
.ql-snow .ql-picker-options { background: #1a1a2e; border: 1px solid var(--bd); border-radius: 4px; color: var(--t1); }
.ql-toolbar.ql-snow button.ql-header3 { color: var(--t2); width: auto; padding: 0 5px; font-size: 11px; font-weight: 700; letter-spacing: .04em; transition: color .1s; }
.ql-toolbar.ql-snow button.ql-header3:hover,
.ql-toolbar.ql-snow button.ql-header3.ql-active { color: var(--t1); }
.ql-snow .ql-color-picker .ql-picker-options { padding: 6px; width: 152px; }
.ql-snow .ql-color-picker .ql-picker-options .ql-picker-item { width: 16px; height: 16px; border-radius: 2px; margin: 2px; border: 1px solid rgba(255,255,255,.08); }
.ql-snow .ql-color-picker .ql-picker-options .ql-picker-item:hover { border-color: var(--t1); transform: scale(1.15); transition: transform .1s; }

/* ── B-roll timeline slider ─────────────────────────────────────── */
.brs-track {
  position: relative; width: 100%; height: 16px;
  background: rgba(255,255,255,.05); border-radius: 4px;
  display: none;
}
.brs-seg {
  position: absolute; top: 0; height: 100%; min-width: 50px;
  border-radius: 3px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  cursor: grab;
}
.brs-seg.seg-dragging { cursor: grabbing; }
.brs-playhead {
  position: absolute; top: -2px; bottom: -2px; width: 1px; left: 0%;
  background: rgba(255,255,255,.75); pointer-events: none; z-index: 3;
}
body.light-theme .brs-playhead { background: rgba(0,0,0,.45); }
.brs-seg-handle {
  position: absolute; top: 0; bottom: 0; width: 6px;
  cursor: ew-resize; border-radius: 2px; flex-shrink: 0;
}
.brs-seg-handle.left  { left: 0;  border-radius: 3px 1px 1px 3px; }
.brs-seg-handle.right { right: 0; border-radius: 1px 3px 3px 1px; }
.brs-seg-label {
  font-size: 8px; font-weight: 700; letter-spacing: .02em;
  white-space: nowrap; pointer-events: none; padding: 0 3px;
}
.brs-thumb {
  position: absolute; top: 50%;
  width: 14px; height: 14px; border-radius: 50%;
  background: #fff; border: 2px solid rgba(0,0,0,.12);
  box-shadow: 0 1px 5px rgba(0,0,0,.5);
  transform: translate(-50%, -50%);
  cursor: ew-resize; z-index: 5;
  transition: transform .1s;
}
.brs-thumb:hover, .brs-thumb.dragging { transform: translate(-50%, -50%) scale(1.2); }

/* QA section */
.qa-section { padding: 10px 14px; }
.qa-empty { font-size: 11px; color: var(--t3); font-style: italic; }
.qa-result { display: flex; flex-direction: column; gap: 7px; }
.qa-status { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.qa-metrics-row { display: flex; gap: 7px; flex-wrap: wrap; }
.qa-chip { background: var(--s2); border: 1px solid var(--bd); border-radius: 4px; padding: 4px 9px; }
.qa-chip-label { font-size: 9px; text-transform: uppercase; letter-spacing: .08em; color: var(--t3); }
.qa-chip-val { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; color: var(--t1); }
.qa-warn { font-size: 10px; color: var(--amber); }
.qa-terms { font-size: 10px; color: var(--re); margin-top: 3px; }
.qa-words-toggle { font-size: 10px; color: var(--t3); cursor: pointer; user-select: none; display: inline-flex; align-items: center; gap: 4px; }
.qa-words-toggle:hover { color: var(--t1); }
.qa-words-strip { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 4px; }
.qa-word { font-size: 10px; font-family: 'JetBrains Mono', monospace; padding: 2px 5px; border-radius: 3px; border: 1px solid var(--bd); cursor: pointer; background: var(--s1); color: var(--t2); transition: opacity .1s; }
.qa-word:hover { opacity: .75; }
.qa-word-amber { border-color: var(--amber); color: var(--amber); }
.qa-word-red   { border-color: var(--re);    color: var(--re); }
.qa-word-ins   { border-style: dashed; }
.qa-checking { font-size: 10px; color: var(--t3); }
/* QA tooltip (? badge) */
.qa-tip { display:inline-flex; align-items:center; justify-content:center; width:13px; height:13px; border-radius:50%; border:1px solid var(--t3); font-size:9px; color:var(--t3); cursor:help; margin-left:4px; vertical-align:middle; }
.qa-tip-wrap { position:relative; display:inline-block; }
.qa-tip-popup { display:none; position:fixed; background:#1a1a1a; border:1px solid var(--bd); border-radius:6px; padding:8px 10px; font-size:10px; color:var(--t2); line-height:1.5; width:230px; z-index:9999; pointer-events:none; white-space:normal; }
.qa-tip-wrap:hover .qa-tip-popup { display:block; }
/* TTS voice selector panel */
.tts-voice-section { padding-top:10px; border-top:1px solid var(--bd); margin-top:8px; }
.tts-voice-grid { display:grid; grid-template-columns:1fr 1fr; gap:5px; margin-top:4px; }
.tts-voice-group-label { grid-column:1/-1; font-size:9px; color:var(--t3); text-transform:uppercase; letter-spacing:.06em; padding:4px 0 2px; }
.tts-voice-card { background:var(--s2); border:1px solid var(--bd); border-radius:6px; padding:6px 8px; cursor:pointer; position:relative; transition:border-color .15s; }
.tts-voice-card:hover { border-color:var(--pu); }
.tts-voice-card.selected { border-color:var(--pu); background:rgba(123,82,245,.12); }
.tts-voice-name { font-size:11px; color:var(--t1); font-weight:500; }
.tts-voice-gender { font-size:9px; margin-top:2px; }
.tts-voice-gender.female { color:#f472b6; }
.tts-voice-gender.male   { color:#60a5fa; }
.tts-play-btn { position:absolute; top:5px; right:5px; background:transparent; border:1px solid var(--bd); border-radius:4px; color:var(--t2); font-size:9px; padding:2px 5px; cursor:pointer; line-height:1; }
.tts-play-btn:hover { border-color:var(--pu); color:var(--pu); }
.tts-style-inp { width:100%; background:var(--s2); border:1px solid var(--bd); color:var(--t1); border-radius:6px; padding:6px 8px; font-size:11px; resize:vertical; font-family:inherit; box-sizing:border-box; }
.tts-lang-sel { width:auto; flex:1; background:var(--s2); border:1px solid var(--bd); color:var(--t1); border-radius:6px; padding:4px 8px; font-size:11px; }

/* Scene footer */
.scene-footer { display: none; padding: 8px 14px; gap: 6px; align-items: center; flex-wrap: wrap; }
.scene-card.selected .scene-footer { display: flex; }
.footer-spacer { flex: 1; }

.prod-btn {
  display: flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 4px; border: 1px solid var(--bd);
  background: var(--s1); color: var(--t3); font-size: 10px; font-weight: 500;
  font-family: 'Sora', sans-serif; cursor: pointer; transition: all .15s;
  position: relative; overflow: hidden;
}
.prod-btn:hover { border-color: var(--bd2); color: var(--t1); background: var(--s2); }
.prod-btn.done  { border-color: var(--gr-bd); color: var(--gr); background: var(--gr-dim); }
.prod-btn.error { border-color: var(--re-bd); color: var(--re); background: var(--re-dim); }
.prod-btn:disabled { opacity: .45; cursor: not-allowed; }
.prod-btn.pbr-active:disabled,
.btn-sm.pbr-active:disabled { opacity: 1; }
.prod-icon { font-size: 11px; line-height: 1; }

/* ── Readiness dot ──────────────────────────────────────────────── */
.readiness-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
  cursor: default; transition: background .25s, box-shadow .25s;
}
.readiness-dot.ready   { background: var(--gr); box-shadow: 0 0 5px rgba(52,199,89,.7); }
.readiness-dot.missing { background: #f5a623; box-shadow: 0 0 5px rgba(245,166,35,.6); }

/* ── Render Video button ─────────────────────────────────────────── */
.render-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 13px; border-radius: 6px; font-size: 10px; font-weight: 600;
  font-family: 'Sora', sans-serif; cursor: pointer; transition: all .2s;
  border: 1px solid rgba(123,82,245,.55);
  background: rgba(123,82,245,.1); color: #b89eff;
  box-shadow: 0 0 10px rgba(123,82,245,.28), 0 0 22px rgba(34,204,68,.08);
}
.render-btn:hover {
  background: rgba(123,82,245,.2);
  box-shadow: 0 0 16px rgba(123,82,245,.48), 0 0 32px rgba(34,204,68,.12);
}
.render-btn.rendering {
  border-color: rgba(245,166,35,.55); color: #f5a623;
  background: rgba(245,166,35,.08);
  box-shadow: 0 0 12px rgba(245,166,35,.38);
  cursor: default;
}
.render-btn.done {
  border-color: var(--gr-bd); color: var(--gr);
  background: var(--gr-dim);
  box-shadow: 0 0 10px rgba(52,199,89,.28);
}
.render-btn.error { border-color:var(--re-bd); color:var(--re); background:var(--re-dim); }

/* ── Render actions row (download + watch buttons) ───────────────── */
.render-actions {
  display: inline-flex; align-items: center; gap: 6px;
}
.render-action-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 5px; font-size: 10px; font-weight: 500;
  font-family: 'Sora', sans-serif; cursor: pointer; transition: all .15s;
  border: 1px solid var(--bd); background: var(--s2); color: var(--t2);
  text-decoration: none;
}
.render-action-btn:hover { border-color: var(--bd2); color: var(--t1); background: var(--s3); }

/* ── Video overlay ───────────────────────────────────────────────── */
#video-overlay {
  display: none; position: fixed; inset: 0; z-index: 1002;
  background: rgba(0,0,0,.96); backdrop-filter: blur(12px);
  flex-direction: column; align-items: center; justify-content: center; gap: 16px;
}
#video-overlay.open { display: flex; }
.video-overlay-header {
  display: flex; align-items: center; gap: 12px;
  width: min(96vw, 1200px);
}
.video-overlay-caption { font-size: 12px; color: var(--t2); flex: 1; }
#overlay-video {
  width: min(96vw, 1200px); border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08); background: #000;
  outline: none;
}

/* ── Readiness modal ─────────────────────────────────────────────── */
#readiness-modal {
  display: none; position: fixed; inset: 0; z-index: 1003;
  background: rgba(0,0,0,.75); backdrop-filter: blur(6px);
  align-items: center; justify-content: center;
}
#readiness-modal.open { display: flex; }
.readiness-modal-box {
  background: var(--s2); border: 1px solid var(--bd2); border-radius: 12px;
  padding: 24px 28px; width: min(90vw, 480px); animation: fadeIn .15s ease;
}
.readiness-modal-title {
  font-size: 14px; font-weight: 600; color: var(--t1); margin-bottom: 16px;
  display: flex; align-items: center; gap: 8px;
}
.readiness-scene-row {
  display: flex; align-items: flex-start; gap: 10px; padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,.05); font-size: 11px;
}
.readiness-scene-row:last-child { border-bottom: none; }
.readiness-scene-label { color: var(--t2); flex-shrink: 0; min-width: 130px; }
.readiness-scene-status.ok   { color: var(--gr); }
.readiness-scene-status.warn { color: #f5a623; }

/* ── Empty / Loading ────────────────────────────────────────────── */
.empty-state {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 10px; color: var(--t3); padding: 40px; text-align: center;
}
.empty-title { font-family: 'Cormorant Garamond', serif; font-size: 18px; color: var(--t2); }
.empty-sub { font-size: 12px; line-height: 1.6; }

/* ── Dashboard ──────────────────────────────────────────────────── */
#dashboard { flex: 1; overflow-y: auto; padding: 36px; }
.dash-greeting { font-family: 'Cormorant Garamond', serif; font-size: 30px; font-weight: 600; color: var(--t1); margin-bottom: 4px; }
.dash-sub { font-size: 13px; color: var(--t3); margin-bottom: 32px; }
.dash-section-title {
  font-size: 9px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--t3); font-weight: 600; margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
}
.dash-section-title::after { content:''; flex:1; height:1px; background:var(--bd); }
.dash-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(150px,1fr)); gap: 10px; margin-bottom: 28px; }
.stat-card { background: var(--s1); border: 1px solid var(--bd); border-radius: 8px; padding: 14px; }
.stat-label { font-size: 10px; color: var(--t3); letter-spacing: .08em; text-transform: uppercase; margin-bottom: 6px; }
.stat-value { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 600; color: var(--t1); }
.stat-unit  { font-size: 11px; color: var(--t3); margin-top: 2px; }
.service-row { display: flex; flex-direction: column; gap: 7px; margin-bottom: 28px; }
.service-item { display: flex; align-items: center; gap: 12px; background: var(--s1); border: 1px solid var(--bd); border-radius: 6px; padding: 9px 14px; }
.service-name { font-size: 12px; font-weight: 500; flex: 1; }
.service-url  { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--t3); }
.svc-status { font-size: 11px; }
.svc-status.online  { color: var(--gr); }
.svc-status.offline { color: var(--re); }
.svc-status.checking { color: var(--amber); }

/* ── Scrollbars ─────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.07); border-radius: 2px; }

/* ── Animations ─────────────────────────────────────────────────── */
.fade-in { animation: fadeIn .18s ease; }
@keyframes fadeIn { from{opacity:0;transform:translateY(3px)} to{opacity:1;transform:translateY(0)} }
.loading-dots::after { content:'.'; animation: dots 1.2s infinite; }
@keyframes dots { 0%{content:'.'} 33%{content:'..'} 66%{content:'...'} }

/* ── Lightbox ───────────────────────────────────────────────────── */
#lightbox {
  display: none; position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.85); backdrop-filter: blur(8px);
  align-items: center; justify-content: center;
}
#lightbox.open { display: flex; }
.lb-inner {
  display: flex; flex-direction: column; gap: 14px;
  max-width: min(92vw, 1400px); max-height: 92vh;
  animation: fadeIn .15s ease;
}
.lb-header {
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
.lb-bc {
  font-size: 11px; color: var(--t2);
  font-family: 'JetBrains Mono', monospace; letter-spacing: .03em;
}
.lb-bc .lb-sep { margin: 0 6px; color: var(--t3); }
.lb-close {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  border: 1px solid var(--bd2); background: var(--s2);
  color: var(--t2); font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.lb-close:hover { background: var(--s3); color: var(--t1); }
.lb-img-wrap {
  border-radius: 8px; overflow: hidden; border: 1px solid var(--bd);
  background: #000; display: flex; align-items: center; justify-content: center;
  max-height: calc(92vh - 60px); position: relative;
}
.lb-img {
  max-width: 100%; max-height: calc(92vh - 60px);
  display: block; object-fit: contain;
}

/* ── Preview strip overlay ──────────────────────────────────────── */
#strip-overlay {
  display: none; position: fixed; inset: 0; z-index: 1001;
  background: rgba(0,0,0,.93); backdrop-filter: blur(10px);
  align-items: center; justify-content: center;
}
#strip-overlay.open { display: flex; }
.strip-box {
  display: flex; flex-direction: column; gap: 14px;
  width: min(96vw, 1560px); animation: fadeIn .15s ease;
}
.strip-header { display: flex; align-items: center; gap: 12px; }
.strip-counter {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--t2); background: var(--s2); border: 1px solid var(--bd);
  border-radius: 4px; padding: 3px 9px; flex-shrink: 0;
}
.strip-stage { display: flex; align-items: center; gap: 10px; }
.strip-img-wrap {
  flex: 1; position: relative; border-radius: 8px; overflow: hidden;
  border: 1px solid var(--bd); background: #000; aspect-ratio: 16/9;
}
.strip-img {
  width: 100%; height: 100%; display: block; object-fit: contain;
  transition: opacity .16s ease;
}
.strip-shimmer {
  position: absolute; inset: 0; display: none;
  background: var(--s2); overflow: hidden; pointer-events: none;
}
.strip-shimmer.active { display: block; }
.strip-shimmer::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent);
  animation: pbr-shimmer 1.4s linear infinite;
}
.strip-chev {
  width: 40px; flex-shrink: 0; align-self: stretch;
  background: var(--s2); border: 1px solid var(--bd); border-radius: 6px;
  color: var(--t2); font-size: 24px; cursor: pointer; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.strip-chev:hover:not(:disabled) { background: var(--s3); color: var(--t1); border-color: var(--bd2); }
.strip-chev:disabled { opacity: .22; cursor: not-allowed; }
.strip-caption {
  text-align: center; font-size: 12px; color: var(--t2);
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.strip-id {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  background: var(--s2); border: 1px solid var(--bd);
  border-radius: 3px; padding: 2px 6px; color: var(--t3);
}

/* ── Preview audio sections ─────────────────────────────────────── */
.preview-audio-section { margin-top: 8px; }
#strip-audio { border-top: 1px solid rgba(255,255,255,.07); padding-top: 10px; margin-top: 4px; }
.preview-audio-grid { display: flex; flex-direction: column; gap: 10px; }
.preview-track-label {
  font-size: 9px; text-transform: uppercase; letter-spacing: .1em;
  color: var(--t3); font-weight: 600; margin-bottom: 5px;
  display: flex; align-items: center; gap: 8px;
}
.preview-vol-row { display: flex; align-items: center; gap: 5px; margin-left: auto; }
.preview-vol-slider {
  -webkit-appearance: none; appearance: none;
  width: 128px; height: 3px; border-radius: 2px; background: var(--bd);
  outline: none; cursor: pointer;
}
.preview-vol-slider::-webkit-slider-thumb {
  -webkit-appearance: none; width: 10px; height: 10px;
  border-radius: 50%; background: var(--gold); cursor: pointer;
}
.preview-warn { font-size: 10px; color: var(--amber); font-style: italic; padding: 6px 0; }
/* ── B-roll canvas overlay ──────────────────────────────────────── */
.broll-canvas-overlay { position: absolute; inset: 0; pointer-events: none; z-index: 2; }
.broll-overlay-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; opacity: 0; transition: opacity 1.0s ease;
}
/* ── Preview b-roll combined track (inside narration player) ─────── */
.preview-broll-track {
  position: relative; height: 16px; border-radius: 4px;
  background: rgba(255,255,255,.05); cursor: crosshair; user-select: none; margin-top: 5px;
}
.preview-broll-seg {
  position: absolute; top: 0; height: 100%; min-width: 50px; border-radius: 3px;
  background: rgba(201,168,76,.35); border: 1px solid rgba(201,168,76,.6); cursor: grab;
}
.preview-broll-seg.pending {
  background: rgba(255,255,255,.08); border: 1px dashed rgba(255,255,255,.22); cursor: default;
}
.preview-broll-seg:active { cursor: grabbing; }
.preview-broll-seg-label {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: 8px; color: var(--gold); font-family: 'JetBrains Mono', monospace;
  pointer-events: none; white-space: nowrap; overflow: hidden;
}
.preview-broll-handle {
  position: absolute; top: 0; bottom: 0; width: 6px; cursor: ew-resize;
  background: rgba(201,168,76,.8); border-radius: 2px;
}
.preview-broll-handle.left  { left: 0; border-radius: 3px 1px 1px 3px; }
.preview-broll-handle.right { right: 0; border-radius: 1px 3px 3px 1px; }
.preview-broll-playhead {
  position: absolute; top: -2px; bottom: -2px; width: 1px; left: 0%;
  background: rgba(255,255,255,.75); pointer-events: none; z-index: 3;
}

/* ── Avatar panel (client settings) ────────────────────────────── */
.avatar-panel { flex-shrink: 0; border-bottom: 1px solid var(--bd); }
.avatar-panel-hd {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 16px; cursor: pointer; user-select: none; transition: background .15s;
}
.avatar-panel-hd:hover { background: rgba(255,255,255,.02); }
.avatar-panel-icon { font-size: 13px; opacity: .45; }
.avatar-panel-title {
  font-size: 11px; font-weight: 600; color: #b0c4ff;
  letter-spacing: .06em; text-transform: uppercase; flex: 1;
}
.avatar-panel-badge { font-size: 10px; color: var(--t3); font-family: 'JetBrains Mono', monospace; }
.avatar-panel-chev { font-size: 10px; color: var(--t3); transition: transform .2s; }
.avatar-panel.open .avatar-panel-chev { transform: rotate(180deg); }
.avatar-panel-body { display: none; padding: 10px 16px 14px; flex-direction: column; gap: 12px; }
.avatar-panel.open .avatar-panel-body { display: flex; }

.avatar-library { display: flex; flex-wrap: wrap; gap: 8px; }
.avatar-lib-item { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.avatar-lib-img {
  width: 72px; height: 72px; border-radius: 6px; overflow: hidden;
  border: 1.5px solid var(--pu-bd); background: var(--pu-dim);
  display: flex; align-items: center; justify-content: center; transition: border-color .15s;
}
.avatar-lib-img:hover { border-color: var(--pu); }
.avatar-lib-img img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.avatar-lib-label {
  font-size: 8px; font-family: 'JetBrains Mono', monospace; color: var(--t3);
  text-align: center; max-width: 72px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.avatar-lib-none { font-size: 11px; color: var(--t3); font-style: italic; padding: 2px 0; }

.avatar-id-row { display: flex; align-items: center; gap: 6px; }
.avatar-id-lbl { font-size: 9px; text-transform: uppercase; letter-spacing: .09em; color: var(--t3); font-weight: 600; flex-shrink: 0; }
.avatar-id-inp {
  flex: 1; background: var(--s2); border: 1px solid var(--bd);
  color: var(--t1); font-family: 'JetBrains Mono', monospace; font-size: 11px;
  padding: 4px 8px; border-radius: 4px;
}
.avatar-id-inp:focus { outline: none; border-color: var(--pu-bd); }

.avatar-upload-zone {
  border: 1.5px dashed var(--pu-bd); border-radius: 7px;
  background: var(--pu-dim); padding: 12px; text-align: center;
  cursor: pointer; transition: border-color .2s, background .2s;
  position: relative; overflow: hidden;
}
.avatar-upload-zone:hover, .avatar-upload-zone.drag-over {
  border-color: var(--pu); background: rgba(123,82,245,.15);
}
.avatar-upload-zone-icon { font-size: 16px; opacity: .45; color: var(--pu); line-height: 1; margin-bottom: 4px; }
.avatar-upload-zone-label { font-size: 11px; color: #b0c4ff; font-weight: 500; }
.avatar-upload-zone-sub { font-size: 9px; color: var(--t3); margin-top: 2px; }

.avatar-comfyui-ph { border: 1px solid var(--bd); border-radius: 6px; padding: 10px 12px; background: var(--s1); }
.avatar-comfyui-ph-title { font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); font-weight: 600; margin-bottom: 8px; }
.avatar-comfyui-btns { display: flex; gap: 6px; flex-wrap: wrap; }
.avatar-comfyui-btn {
  padding: 4px 10px; border-radius: 4px; border: 1px solid var(--bd);
  background: transparent; color: var(--t3); font-size: 10px;
  font-family: 'Sora', sans-serif; cursor: not-allowed; opacity: .4;
}

/* ── Scene background panel ──────────────────────────────────────── */
.bg-panel { flex-shrink: 0; border-bottom: 1px solid var(--bd); }
.bg-panel-hd { display: flex; align-items: center; gap: 8px; padding: 9px 16px; cursor: pointer; user-select: none; }
.bg-panel-hd:hover { background: rgba(255,255,255,.02); }
.bg-panel-icon { font-size: 13px; opacity: .45; }
.bg-panel-title { font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--t2); flex: 1; }
.bg-panel-chev { font-size: 10px; color: var(--t3); transition: transform .2s; }
.bg-panel.open .bg-panel-chev { transform: rotate(180deg); }
.bg-panel-body { display: none; padding: 10px 16px 14px; flex-direction: column; gap: 12px; }
.bg-panel.open .bg-panel-body { display: flex; }
.bg-type-tabs { display: flex; gap: 3px; }
.bg-type-tab { flex: 1; background: rgba(255,255,255,.05); border: 1px solid var(--bd); border-radius: 4px;
  color: var(--t2); font-size: 10px; font-weight: 500; padding: 3px 0; cursor: pointer; text-transform: capitalize; transition: all .15s; }
.bg-type-tab:hover { background: rgba(255,255,255,.09); color: var(--t1); }
.bg-type-tab.on { background: rgba(123,82,245,.15); border-color: var(--pu); color: var(--pu); }
.bg-color-row { display: flex; align-items: center; gap: 8px; }
.bg-color-swatch { width: 28px; height: 28px; }
.bg-color-inp { flex: 1; background: var(--s2); border: 1px solid var(--bd); color: var(--t1); font-family: 'JetBrains Mono', monospace; font-size: 12px; padding: 5px 8px; border-radius: 4px; transition: border-color .15s; }
.bg-color-inp:focus { outline: none; border-color: var(--pu-bd); }
.bg-upload-zone { border: 1.5px dashed var(--pu-bd); border-radius: 7px; background: var(--pu-dim); padding: 12px; text-align: center; cursor: pointer; transition: border-color .2s, background .2s; }
.bg-upload-zone:hover, .bg-upload-zone.drag-over { border-color: var(--pu); background: rgba(123,82,245,.15); }
.bg-upload-zone-icon { font-size: 16px; opacity: .45; color: var(--pu); line-height: 1; margin-bottom: 4px; }
.bg-upload-zone-label { font-size: 11px; color: #b0c4ff; font-weight: 500; }
.bg-upload-zone-sub { font-size: 9px; color: var(--t3); margin-top: 2px; }
.bg-current-row { display: flex; align-items: center; gap: 6px; font-size: 10px; color: var(--t3); margin-bottom: 8px; }
.bg-current-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: 'JetBrains Mono', monospace; }

/* ── Scene Layout panel ─────────────────────────────────────────── */
.layout-panel { flex-shrink:0; border-bottom:1px solid var(--bd); }
.layout-panel-hd { display:flex; align-items:center; gap:8px; padding:9px 16px; cursor:pointer; user-select:none; }
.layout-panel-hd:hover { background:rgba(255,255,255,.02); }
.layout-panel-icon { font-size:13px; opacity:.45; }
.layout-panel-title { font-size:11px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--t2); flex:1; }
.layout-panel-chev { font-size:10px; color:var(--t3); transition:transform .2s; }
.layout-panel.open .layout-panel-chev { transform:rotate(180deg); }
.layout-panel-body { display:none; padding:10px 16px 14px; flex-direction:column; gap:8px; }
.layout-panel.open .layout-panel-body { display:flex; }
.layout-open-btn { width:100%; padding:7px; border-radius:6px; background:rgba(123,82,245,.12);
  border:1px solid var(--pu-bd); color:#b0c4ff; font-size:11px; cursor:pointer; transition:background .15s; }
.layout-open-btn:hover { background:rgba(123,82,245,.22); }

/* ── Layout Editor Modal ─────────────────────────────────────────── */
#layout-editor-modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:300;
  align-items:center; justify-content:center; overflow:auto; padding:16px; }
#layout-editor-modal.open { display:flex; }
.le-modal-box { background:#0e0e0e; border:1px solid var(--bd); border-radius:10px;
  display:flex; flex-direction:column; width:1280px; max-width:100%; max-height:calc(100vh - 32px); overflow:hidden; }
.le-modal-hd { display:flex; align-items:center; gap:10px; padding:10px 18px;
  border-bottom:1px solid var(--bd); flex-shrink:0; }
.le-modal-title { font-size:13px; font-weight:600; color:var(--t1); }
.le-tabs { display:flex; gap:3px; flex:1; justify-content:center; }
.le-tab { background:rgba(255,255,255,.05); border:1px solid var(--bd); border-radius:4px;
  color:var(--t2); font-size:11px; font-weight:500; padding:3px 14px; cursor:pointer; transition:all .15s; }
.le-tab:hover { background:rgba(255,255,255,.09); color:var(--t1); }
.le-tab.on { background:var(--pu-dim,rgba(123,82,245,.15)); border-color:var(--pu); color:var(--pu); }
.le-close-btn { background:transparent; border:none; color:var(--t3); cursor:pointer; font-size:16px; line-height:1; padding:2px 6px; }
.le-close-btn:hover { color:var(--t1); }
.le-upload-zone {
  border:1px dashed rgba(255,255,255,.18); border-radius:5px; padding:8px 10px;
  cursor:pointer; margin-top:5px; transition:border-color .15s, opacity .15s;
}
.le-upload-zone:hover, .le-upload-zone.drag-over { border-color:var(--pu); background:rgba(123,82,245,.07); }
.le-modal-body { display:flex; flex:1; min-height:0; gap:0; }
.le-canvas-wrap { position:relative; width:960px; height:540px; flex-shrink:0;
  background:rgba(255,255,255,.04); border-right:1px solid var(--bd);
  overflow:visible; margin:16px; border-radius:6px;
  outline:1px dashed rgba(255,255,255,.08); }
.le-zone { position:absolute; border-radius:3px; cursor:move; user-select:none; min-width:8px; min-height:8px; }
.le-zone:hover { outline:1px solid rgba(100,140,255,.7); outline-offset:0px; }
.le-zone-hdl { position:absolute; width:8px; height:8px; background:#fff; border:1.5px solid rgba(0,0,0,.6); border-radius:0; z-index:3; box-shadow:0 1px 3px rgba(0,0,0,.35); }
.le-hdl-nw { left:-5px;  top:-5px;    cursor:nw-resize; }
.le-hdl-n  { left:50%;   top:-5px;    transform:translateX(-50%); cursor:n-resize; }
.le-hdl-ne { right:-5px; top:-5px;    cursor:ne-resize; }
.le-hdl-e  { right:-5px; top:50%;     transform:translateY(-50%); cursor:e-resize; }
.le-hdl-se { right:-5px; bottom:-5px; cursor:se-resize; }
.le-hdl-s  { left:50%;   bottom:-5px; transform:translateX(-50%); cursor:s-resize; }
.le-hdl-sw { left:-5px;  bottom:-5px; cursor:sw-resize; }
.le-hdl-w  { left:-5px;  top:50%;     transform:translateY(-50%); cursor:w-resize; }
.le-zone:hover .le-zone-hdl { border-color:rgba(0,0,0,.85); }
.le-ctrl-panel { flex:1; overflow-y:auto; padding:12px 14px 16px; display:flex; flex-direction:column; gap:4px; min-width:280px; }
.le-sect-hd { font-size:9px; font-weight:700; letter-spacing:.09em; text-transform:uppercase;
  color:var(--pu); margin-top:10px; margin-bottom:4px; padding-bottom:4px; border-bottom:1px solid rgba(123,82,245,.25); }
.le-sect-hd:first-child { margin-top:0; }
.le-inp-row { display:flex; align-items:center; gap:6px; min-height:24px; }
.le-inp-lbl { font-size:10px; color:var(--t3); width:60px; flex-shrink:0; }
.le-num-inp { width:70px; background:var(--s2); border:1px solid var(--bd); color:var(--t1);
  font-family:'JetBrains Mono',monospace; font-size:11px; padding:3px 6px; border-radius:4px; }
.le-num-inp:focus { outline:none; border-color:var(--pu-bd); }
.le-sel { flex:1; background:var(--s2); border:1px solid var(--bd); color:var(--t1); font-size:11px;
  padding:3px 6px; border-radius:4px; cursor:pointer; }
.le-sel:focus { outline:none; border-color:var(--pu-bd); }
.le-sel option, .type-sel option, .scene-type-sel option { background:#111; color:#f5f5f7; }
.le-color-row { display:flex; align-items:center; gap:6px; }
.le-color-swatch { width:26px; height:26px; }
.le-color-text { width:72px; background:var(--s2); border:1px solid var(--bd); color:var(--t1);
  font-family:'JetBrains Mono',monospace; font-size:11px; padding:3px 6px; border-radius:4px; }
.le-color-text:focus { outline:none; border-color:var(--pu-bd); }
.le-color-swatch { width:26px; height:26px; border-radius:4px; border:1px solid rgba(255,255,255,.18); cursor:pointer; padding:0; flex-shrink:0; }
.le-color-swatch:hover { border-color:rgba(255,255,255,.4); }
.bg-color-swatch { width:28px; height:28px; border-radius:4px; border:1px solid rgba(255,255,255,.18); cursor:pointer; flex-shrink:0; padding:0; }
.bg-color-swatch:hover { border-color:rgba(255,255,255,.4); }
/* Custom color picker popup */
#cp-pop { position:fixed; z-index:10000; background:#1c1c1e; border:1px solid var(--bd); border-radius:10px; padding:12px; box-shadow:0 16px 48px rgba(0,0,0,.85); width:216px; user-select:none; }
.cp-sv { position:relative; width:100%; height:116px; border-radius:5px; overflow:hidden; cursor:crosshair; margin-bottom:10px; }
.cp-sv-inner { position:absolute; inset:0; }
.cp-sv-inner::before { content:''; position:absolute; inset:0; background:linear-gradient(to right,#fff,transparent); }
.cp-sv-inner::after  { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,transparent,#000); }
.cp-cursor { position:absolute; width:12px; height:12px; border-radius:50%; border:2px solid #fff; box-shadow:0 0 0 1px rgba(0,0,0,.5); transform:translate(-50%,-50%); pointer-events:none; z-index:1; }
.cp-row { display:flex; align-items:center; gap:8px; margin-bottom:9px; }
.cp-preview { width:28px; height:28px; border-radius:4px; border:1px solid rgba(255,255,255,.15); flex-shrink:0; }
.cp-hue-sl { flex:1; -webkit-appearance:none; appearance:none; height:10px; border-radius:5px; background:linear-gradient(to right,#f00,#ff0,#0f0,#0ff,#00f,#f0f,#f00); outline:none; cursor:pointer; border:none; }
.cp-hue-sl::-webkit-slider-thumb { -webkit-appearance:none; width:16px; height:16px; border-radius:50%; background:#fff; border:2px solid rgba(0,0,0,.25); box-shadow:0 1px 4px rgba(0,0,0,.5); cursor:grab; }
.cp-hue-sl::-moz-range-thumb { width:16px; height:16px; border-radius:50%; background:#fff; border:2px solid rgba(0,0,0,.25); cursor:grab; border:none; }
.cp-hex-row { display:flex; align-items:center; gap:6px; }
.cp-hex-hash { color:var(--t3); font-family:'JetBrains Mono',monospace; font-size:12px; }
.cp-hex { flex:1; background:var(--s2); border:1px solid var(--bd); color:var(--t1); font-family:'JetBrains Mono',monospace; font-size:12px; padding:4px 7px; border-radius:4px; outline:none; }
.cp-hex:focus { border-color:rgba(123,82,245,.6); }
.le-clear-btn { background:transparent; border:none; color:var(--t3); cursor:pointer; font-size:11px; padding:2px 4px; }
.le-clear-btn:hover { color:var(--re); }
.le-toggle-grp { display:flex; gap:3px; }
.le-tog { background:var(--s2); border:1px solid var(--bd); color:var(--t3); font-size:10px;
  padding:3px 9px; border-radius:4px; cursor:pointer; transition:background .12s, color .12s; }
.le-tog.on { background:rgba(123,82,245,.2); border-color:var(--pu-bd); color:#b0c4ff; }
.le-tog:hover:not(.on) { background:var(--s3); color:var(--t2); }
.le-checkbox-row { display:flex; align-items:center; gap:6px; font-size:10px; color:var(--t2); cursor:pointer; }
.le-checkbox-row input[type=checkbox] { width:13px; height:13px; cursor:pointer; accent-color:var(--pu); }
.le-modal-ft { display:flex; align-items:center; gap:10px; padding:10px 18px;
  border-top:1px solid var(--bd); flex-shrink:0; }

/* Toast notification */
#le-toast { position:fixed; bottom:28px; left:50%; transform:translateX(-50%);
  background:rgba(30,30,30,.96); border:1px solid var(--bd); border-radius:7px;
  color:var(--t1); font-size:12px; padding:8px 18px; pointer-events:none;
  opacity:0; transition:opacity .25s; z-index:400; white-space:nowrap; }
#le-toast.show { opacity:1; }

/* ── Theme toggle ────────────────────────────────────────────────── */
#theme-toggle {
  background: transparent; border: none; cursor: pointer;
  color: var(--t2); display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 6px;
  transition: background .15s, color .15s;
}
#theme-toggle:hover { background: var(--s2); color: var(--t1); }

/* ── Notification bell ───────────────────────────────────────────── */
#notif-wrap { position:relative; }
#notif-bell {
  background:var(--s2); border:1px solid var(--bd);
  border-radius:8px; padding:7px 11px; cursor:pointer; color:var(--t1);
  position:relative; display:flex; align-items:center; gap:6px;
  font-size:12px; transition:background .15s;
}
#notif-bell:hover { background:var(--s3); }
#notif-badge {
  position:absolute; top:-5px; right:-5px; min-width:18px; height:18px;
  background:var(--re); border-radius:9px; font-size:10px; font-weight:700;
  display:flex; align-items:center; justify-content:center; padding:0 4px;
  color:#fff; border:1.5px solid var(--bg);
}
#notif-panel {
  display:none; position:absolute; top:42px; right:0; width:320px;
  background:rgba(16,16,20,.97); backdrop-filter:blur(16px);
  border:1px solid var(--bd); border-radius:12px;
  box-shadow:0 8px 36px rgba(0,0,0,.7); overflow:hidden;
}
#notif-panel.open { display:block; }
.notif-head {
  display:flex; justify-content:space-between; align-items:center;
  padding:11px 16px; border-bottom:1px solid var(--bd);
  font-size:12px; font-weight:600; color:var(--t2);
}
.notif-head button {
  background:none; border:none; color:var(--t2); font-size:11px;
  cursor:pointer; padding:2px 6px; border-radius:4px;
}
.notif-head button:hover { background:var(--s2); color:var(--t1); }
.notif-item {
  padding:11px 16px; border-bottom:1px solid var(--bd);
  display:flex; flex-direction:column; gap:3px;
}
.notif-item:last-child { border-bottom:none; }
.notif-item-title { font-size:12px; color:var(--t1); display:flex; align-items:center; gap:6px; }
.notif-dot { font-size:10px; }
.notif-item.generating .notif-dot { color:var(--gold); }
.notif-item.done        .notif-dot { color:var(--gr); }
.notif-item.error       .notif-dot { color:var(--re); }
.notif-item-sub  { font-size:10px; color:var(--t2); padding-left:16px; }
.notif-item-link { font-size:11px; color:var(--pu); cursor:pointer; padding-left:16px; }
.notif-item-link:hover { text-decoration:underline; }
.notif-empty { padding:20px 16px; font-size:12px; color:var(--t2); text-align:center; }

/* ── Scene preview thumbnail ─────────────────────────────────────── */
.scene-preview-wrap {
  margin: 10px; border-radius: 6px; overflow: hidden;
  border: 1px solid var(--bd); background: var(--s2);
  position: relative; flex-shrink: 0; aspect-ratio: 16/9;
  cursor: default; transition: border-color .15s;
}
.scene-preview-wrap[data-state="loaded"] { cursor: pointer; }
.scene-preview-wrap[data-state="loaded"]:hover { border-color: var(--pu-bd); }
.scene-preview-wrap img { width: 100%; height: 100%; display: none; object-fit: cover; }
.scene-preview-wrap[data-state="loaded"] img { display: block; }
/* shimmer */
.spt-shimmer {
  position: absolute; inset: 0; display: none;
  background: var(--s2); overflow: hidden;
}
.spt-shimmer::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent);
  animation: pbr-shimmer 1.4s linear infinite;
}
.scene-preview-wrap[data-state="loading"] .spt-shimmer,
.scene-preview-wrap[data-state="regen"]   .spt-shimmer { display: block; }
/* no-preview */
.spt-none {
  position: absolute; inset: 0; display: none;
  align-items: center; justify-content: center;
  font-size: 9px; color: var(--t3); letter-spacing: .08em; text-transform: uppercase;
}
.scene-preview-wrap[data-state="error"] .spt-none { display: flex; }
/* hover regen overlay */
.spt-overlay {
  position: absolute; inset: 0; opacity: 0; pointer-events: none;
  display: flex; align-items: flex-end; justify-content: flex-end; padding: 5px;
  background: linear-gradient(to top, rgba(0,0,0,.45) 0%, transparent 55%);
  transition: opacity .15s;
}
.scene-preview-wrap[data-state="loaded"]:hover .spt-overlay { opacity: 1; pointer-events: auto; }
.spt-regen {
  width: 22px; height: 22px; border-radius: 50%; padding: 0;
  background: rgba(0,0,0,.6); border: 1px solid rgba(255,255,255,.25);
  color: #fff; font-size: 13px; cursor: pointer; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, transform .2s;
}
.spt-regen:hover { background: var(--pu); transform: rotate(-30deg); }
/* avatar-done badge */
.spt-av-badge {
  position: absolute; top: 5px; left: 5px; pointer-events: none;
  background: var(--gr-dim); border: 1px solid var(--gr-bd);
  border-radius: 3px; padding: 2px 5px;
  font-size: 8px; font-weight: 700; color: var(--gr);
  letter-spacing: .05em; text-transform: uppercase;
}

/* ── In-button progress bars ────────────────────────────────────── */
.pbr {
  position: absolute; bottom: 0; left: 0;
  height: 3px; width: 0; pointer-events: none;
  background: var(--gold);
  transition: width 120ms ease-out;
}
.pbr-ind-track {
  position: absolute; top: 0; left: 0;
  width: 100%; height: 100%;
  overflow: hidden; pointer-events: none; border-radius: inherit;
}
.pbr-ind-seg {
  position: absolute; top: 0; left: -60%;
  width: 55%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,.22), transparent);
  animation: pbr-shimmer 1.4s linear infinite;
}
@keyframes pbr-shimmer {
  from { left: -60%; }
  to   { left: 110%; }
}

/* ── Mux upload control (sticky header) ─────────────────────────── */
.mux-control { display: inline-flex; flex-direction: column; align-items: stretch; gap: 3px; max-width: 240px; }
.mux-status {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 4px; border: 1px solid var(--bd);
  background: var(--s1); color: var(--t2);
  font-family: 'Sora', sans-serif; font-size: 10px; font-weight: 500;
  letter-spacing: .02em; white-space: nowrap;
}
.mux-status.ready     { color: #c9a84c; border-color: rgba(201,168,76,.42); background: rgba(201,168,76,.08); }
.mux-status.preparing { color: #ff9f0a; border-color: rgba(255,159,10,.32); background: rgba(255,159,10,.07); }
.mux-status.errored   { color: #ff9f0a; border-color: rgba(255,159,10,.5);  background: rgba(255,159,10,.12); }
.mux-status .pulse-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; animation: mux-pulse 1.4s ease-in-out infinite; }
@keyframes mux-pulse { 0%, 100% { opacity: .25; } 50% { opacity: 1; } }
.mux-replace {
  background: none; border: none; color: var(--t3);
  font-family: 'Sora', sans-serif; font-size: 9px; letter-spacing: .04em;
  cursor: pointer; padding: 0 0 0 2px; align-self: flex-start;
  text-decoration: underline; text-underline-offset: 2px;
}

/* ── Editor scene card (Wiring #2) ──────────────────────────────── */
.editor { display: flex; flex-direction: column; gap: 18px; padding: 24px; max-width: 960px; margin: 0 auto; }
.editor__title { font-size: 15px; font-weight: 600; color: var(--t1); margin-bottom: 6px; }

.scene-card {
  background: var(--s1); border: 1px solid var(--bd); border-radius: 10px;
  overflow: hidden;
}
.scene-card__header {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px 8px; border-bottom: 1px solid var(--bd);
}
.scene-card__id { font-size: 10px; font-weight: 600; color: var(--t3); letter-spacing: .06em; text-transform: uppercase; }
.scene-card__title { font-size: 13px; font-weight: 500; color: var(--t1); margin: 0; flex: 1; }

/* ── Readiness dot (BEM editor) ─────────────────────────────────── */
.scene-card__readiness {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
  background: var(--bd); transition: background .25s, box-shadow .25s;
}
.scene-card__readiness[data-state="has_audio"]  { background: var(--gr); box-shadow: 0 0 5px rgba(52,199,89,.6); }
.scene-card__readiness[data-state="validated"]  { background: #c9a84c; box-shadow: 0 0 5px rgba(201,168,76,.6); }
.scene-card__readiness[data-state="pending"]    { background: var(--bd); }

/* ── Narration block ────────────────────────────────────────────── */
.scene-card__narration { padding: 12px 14px; border-bottom: 1px solid var(--bd); }
.scene-card__narration-label { font-size: 10px; font-weight: 600; color: var(--t3); letter-spacing: .05em; text-transform: uppercase; display: block; margin-bottom: 6px; }
.scene-card__narration-input { width: 100%; background: var(--s2); border: 1px solid var(--bd); border-radius: 6px; color: var(--t1); font-family: 'Sora', sans-serif; font-size: 12px; line-height: 1.55; padding: 8px 10px; resize: vertical; box-sizing: border-box; }
.scene-card__narration-actions { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.scene-card__narration-save { font-size: 11px; padding: 4px 10px; }
.scene-card__narration-indicator { font-size: 10px; color: var(--t3); opacity: 0; transition: opacity .15s; }
.htmx-request .scene-card__narration-indicator,
.htmx-request.scene-card__narration-indicator { opacity: 1; }
.scene-card__narration-saved { font-size: 10px; color: var(--gr); margin-left: 4px; animation: narration-saved-fade 0.4s 3s forwards; }

/* ── Audio region ───────────────────────────────────────────────── */
.scene-card__audio { padding: 12px 14px; border-bottom: 1px solid var(--bd); }
.scene-card__audio-label { font-size: 10px; font-weight: 600; color: var(--t3); letter-spacing: .05em; text-transform: uppercase; margin-bottom: 8px; }
.scene-card__audio-empty { font-size: 11px; color: var(--t3); font-style: italic; }
.scene-card__audio-player { display: flex; align-items: center; gap: 8px; }
.scene-card__audio-play {
  flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%;
  background: var(--s2); border: 1px solid var(--bd); color: var(--t2);
  font-size: 10px; cursor: pointer; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.scene-card__audio-play:hover { background: var(--pu); color: #fff; border-color: var(--pu); }
.scene-card__audio-center { flex: 1; min-width: 0; }
.scene-card__audio-waveform { width: 100%; height: 32px; }
.scene-card__audio-waveform .wf-svg { width: 100%; height: 32px; display: block; cursor: pointer; }
.scene-card__audio-time { font-size: 10px; color: var(--t3); font-family: 'JetBrains Mono', monospace; flex-shrink: 0; min-width: 28px; text-align: right; }
.scene-card__qa-trigger { display: none; }

/* ── QA metrics ─────────────────────────────────────────────────── */
.scene-card__qa { padding: 10px 14px; border-bottom: 1px solid var(--bd); }
.scene-card__qa-label { font-size: 10px; font-weight: 600; color: var(--t3); letter-spacing: .05em; text-transform: uppercase; margin-bottom: 6px; display: flex; align-items: center; gap: 4px; }
.scene-card__qa-tip { cursor: help; color: var(--t3); font-size: 10px; }
.scene-card__qa-content { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.scene-card__qa-badge {
  font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 4px; border: 1px solid;
}
.scene-card__qa-badge--excellent { color: var(--gr);  background: rgba(52,199,89,.1);  border-color: rgba(52,199,89,.35); }
.scene-card__qa-badge--good      { color: #a8e063;    background: rgba(168,224,99,.08); border-color: rgba(168,224,99,.35); }
.scene-card__qa-badge--acceptable { color: #ff9f0a;   background: rgba(255,159,10,.09); border-color: rgba(255,159,10,.35); }
.scene-card__qa-badge--poor      { color: var(--re);  background: rgba(255,69,58,.1);   border-color: rgba(255,69,58,.35); }
.scene-card__qa-regen-flag { font-size: 10px; color: #ff9f0a; }
.scene-card__qa-chips { display: flex; gap: 4px; }
.scene-card__qa-chip {
  font-size: 10px; padding: 1px 6px; border-radius: 3px;
  background: var(--s2); border: 1px solid var(--bd); color: var(--t2);
  font-family: 'JetBrains Mono', monospace;
}
.scene-card__qa-critical { font-size: 10px; color: var(--re); width: 100%; }
.scene-card__qa-words { width: 100%; margin-top: 4px; }
.scene-card__qa-words summary { font-size: 10px; color: var(--t3); cursor: pointer; }
.scene-card__qa-words-strip { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 6px; }
.scene-card__qa-word {
  font-size: 11px; padding: 1px 4px; border-radius: 3px; cursor: pointer;
  background: var(--s2); color: var(--t1); border: 1px solid transparent;
  transition: background .1s;
}
.scene-card__qa-word:hover { background: rgba(123,82,245,.15); border-color: rgba(123,82,245,.3); }
.scene-card__qa-word--low  { background: rgba(255,69,58,.12);  color: var(--re); }
.scene-card__qa-word--mid  { background: rgba(255,159,10,.10); color: #ff9f0a; }
.scene-card__qa-word--off  { text-decoration: underline wavy rgba(255,159,10,.7); }

/* ── Scene card actions ─────────────────────────────────────────── */
.scene-card__actions {
  display: flex; gap: 8px; padding: 10px 14px;
  background: var(--s2); border-top: 1px solid var(--bd);
}
.mux-replace:hover { color: var(--t1); }
.mux-error-text {
  font-family: 'Sora', sans-serif; font-size: 9px; line-height: 1.35;
  color: #ff9f0a; opacity: .85; padding-top: 1px; max-width: 240px;
  word-break: break-word;
}
.btn-sm.mux-disabled { opacity: .45; cursor: not-allowed; }

/* ── Client settings buttons (above video list) ──────────────────── */
.client-settings-btns { display:flex; gap:5px; padding:8px 12px 10px; border-bottom:1px solid var(--bd); flex-shrink:0; }
.client-settings-btn {
  flex:1; padding:7px 8px; border-radius:6px; border:1px solid var(--bd);
  background:var(--s1); color:var(--t2); font-size:10px; font-weight:600;
  font-family:'Sora',sans-serif; cursor:pointer; transition:all .15s;
  display:flex; align-items:center; justify-content:center; gap:5px;
  letter-spacing:.04em; text-transform:uppercase;
}
.client-settings-btn:hover { background:var(--s2); color:var(--t1); border-color:var(--bd2); }
.client-settings-btn.active { background:var(--pu-dim); border-color:var(--pu-bd); color:#b0c4ff; }

/* ── Settings panel (shown in scene-panel area) ───────────────────── */
.settings-panel { flex:1; display:flex; flex-direction:column; overflow:hidden; min-height:0; }
.settings-panel-hd {
  padding:12px 20px; border-bottom:1px solid var(--bd); flex-shrink:0;
  background:var(--s2); backdrop-filter:blur(12px);
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.settings-panel-title { font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:600; color:var(--t1); flex-shrink:0; }
.settings-panel-body { flex:1; overflow-y:auto; padding:24px 28px 40px; min-height:0; }

/* ── Avatar settings (right panel) ───────────────────────────────── */
.av-settings-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; }
@media (max-width:900px) { .av-settings-grid { grid-template-columns:1fr; } }
.av-sect { display:flex; flex-direction:column; gap:14px; }
.av-lib-grid { display:flex; flex-wrap:wrap; gap:12px; }
.av-lib-item-lg { display:flex; flex-direction:column; align-items:center; gap:5px; cursor:pointer; }
.av-lib-img-lg {
  width:96px; height:96px; border-radius:8px; overflow:hidden; position:relative;
  border:1.5px solid var(--pu-bd); background:var(--pu-dim);
  display:flex; align-items:center; justify-content:center; transition:border-color .15s;
}
.av-lib-img-lg:hover { border-color:var(--pu); }
.av-lib-item-lg.selected .av-lib-img-lg { border-color:var(--pu); box-shadow:0 0 0 2px rgba(123,82,245,.25); }
.av-lib-img-lg img { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }
.av-lib-label-lg { font-size:9px; font-family:'JetBrains Mono',monospace; color:var(--t3); text-align:center; max-width:96px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.chroma-dot {
  position:absolute; bottom:4px; right:4px;
  width:10px; height:10px; border-radius:50%;
  border:1.5px solid rgba(0,0,0,.5); pointer-events:none;
}
.chroma-key-row { padding-top:10px; border-top:1px solid var(--bd); margin-top:4px; }

/* ── Scene settings (right panel) ────────────────────────────────── */
.ss-body-row { display:flex; gap:20px; align-items:flex-start; }
.ss-canvas-col { flex-shrink:0; }
.ss-canvas-outer { overflow:auto; border-radius:6px; border:1px solid var(--bd); }
.ss-ctrl-col { flex:1; min-width:260px; max-width:360px; display:flex; flex-direction:column; gap:4px; overflow-y:auto; max-height:calc(100vh - 160px); padding-right:4px; }

/* ── Verticals admin section ──────────────────────────────────── */
body.vx-active #main { display: none !important; }
#verticals-section {
  display: none; flex: 1; flex-direction: column;
  overflow: hidden; min-height: 0;
}
body.vx-active #verticals-section { display: flex !important; }

.vx-gold-bar { height: 2px; background: linear-gradient(90deg,#B8972B 0%,#e8c86a 50%,#B8972B 100%); flex-shrink: 0; }
.vx-topbar { padding: 10px 24px; border-bottom: 1px solid var(--bd); display: flex; align-items: center; gap: 10px; flex-shrink: 0; background: rgba(185,151,43,.04); }
.vx-admin-label { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: #B8972B; font-weight: 600; border: 1px solid rgba(185,151,43,.3); padding: 2px 6px; border-radius: 3px; flex-shrink: 0; }
.vx-bc-btn { background: none; border: none; color: #e8c870; font-family: 'Sora',sans-serif; font-size: 12px; cursor: pointer; padding: 0; opacity: .8; }
.vx-bc-btn:hover { opacity: 1; }
.vx-bc-sep { color: var(--t3); font-size: 11px; }
.vx-bc-title { font-size: 12px; color: var(--t1); font-weight: 500; }

.vx-body { flex: 1; overflow-y: auto; padding: 24px; min-height: 0; }
.vx-section-title { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); margin-bottom: 16px; font-weight: 600; }
.vx-card { background: var(--s1); border: 1px solid var(--bd); border-radius: 10px; padding: 18px 20px; margin-bottom: 10px; cursor: pointer; transition: background .15s,border-color .15s; }
.vx-card:hover { background: var(--s2); border-color: rgba(185,151,43,.3); }
.vx-card-slug { font-family: 'JetBrains Mono',monospace; font-size: 10px; color: #B8972B; margin-bottom: 4px; }
.vx-card-name { font-size: 15px; font-weight: 600; color: var(--t1); margin-bottom: 6px; }
.vx-card-desc { font-size: 11px; color: var(--t2); line-height: 1.5; }
.vx-card-stats { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
.vx-stat { display: flex; flex-direction: column; align-items: center; background: rgba(255,255,255,.04); border: 1px solid var(--bd); border-radius: 6px; padding: 8px 14px; min-width: 64px; }
.vx-stat-val { font-size: 22px; font-weight: 600; color: var(--t1); line-height: 1; }
.vx-stat-lbl { font-size: 9px; color: var(--t3); text-transform: uppercase; letter-spacing: .1em; margin-top: 3px; }
.vx-empty { padding: 48px 24px; text-align: center; color: var(--t3); font-size: 12px; }
.vx-loading { padding: 40px 24px; text-align: center; color: var(--t3); font-size: 12px; }

.vx-detail-inner { display: flex; flex-direction: column; flex: 1; overflow: hidden; min-height: 0; }
.vx-detail-header { padding: 20px 24px 0; flex-shrink: 0; }
.vx-detail-name { font-family: 'Cormorant Garamond',serif; font-size: 28px; font-weight: 600; color: var(--t1); line-height: 1.2; }
.vx-detail-slug { font-family: 'JetBrains Mono',monospace; font-size: 11px; color: #B8972B; margin-top: 4px; }
.vx-detail-desc { font-size: 12px; color: var(--t2); margin-top: 8px; line-height: 1.6; max-width: 600px; }
.vx-lock-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; font-weight: 600; color: #B8972B; border: 1px solid rgba(185,151,43,.4); border-radius: 4px; padding: 2px 8px; margin-top: 10px; letter-spacing: .06em; }

.vx-tab-bar { display: flex; border-bottom: 1px solid var(--bd); padding: 0 24px; margin-top: 16px; flex-shrink: 0; }
.vx-tab { background: none; border: none; border-bottom: 2px solid transparent; color: var(--t2); font-family: 'Sora',sans-serif; font-size: 12px; font-weight: 500; padding: 10px 16px; cursor: pointer; transition: color .15s,border-color .15s; margin-bottom: -1px; }
.vx-tab:hover { color: var(--t1); }
.vx-tab.active { color: #e8c870; border-bottom-color: #B8972B; }

.vx-tab-body { flex: 1; overflow-y: auto; padding: 24px; min-height: 0; }
.vx-sub-tab-bar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 16px; }
.vx-sub-tab { background: var(--s1); border: 1px solid var(--bd); border-radius: 5px; color: var(--t2); font-family: 'JetBrains Mono',monospace; font-size: 10px; padding: 5px 10px; cursor: pointer; transition: all .12s; }
.vx-sub-tab:hover { background: var(--s2); color: var(--t1); }
.vx-sub-tab.active { background: rgba(185,151,43,.15); border-color: rgba(185,151,43,.4); color: #e8c870; }
.vx-prompt-meta { font-family: 'JetBrains Mono',monospace; font-size: 10px; color: var(--t3); margin-bottom: 12px; padding: 8px 12px; background: var(--s1); border-radius: 6px; border: 1px solid var(--bd); }
.vx-pre { background: rgba(255,255,255,.03); border: 1px solid var(--bd); border-radius: 8px; padding: 16px; font-family: 'JetBrains Mono',monospace; font-size: 11px; line-height: 1.7; color: var(--t1); white-space: pre-wrap; word-break: break-word; margin: 0; }
.vx-json-pre { background: rgba(255,255,255,.03); border: 1px solid var(--bd); border-radius: 8px; padding: 16px; font-family: 'JetBrains Mono',monospace; font-size: 11px; line-height: 1.7; color: var(--t1); white-space: pre; overflow-x: auto; margin: 0; }
.vx-table-note { font-size: 11px; color: var(--t3); margin-bottom: 14px; }
.vx-table-header { display: flex; font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: var(--t3); font-weight: 600; padding: 0 12px 8px; border-bottom: 1px solid var(--bd); margin-bottom: 4px; }
.vx-row { display: flex; align-items: center; padding: 10px 12px; border-bottom: 1px solid rgba(255,255,255,.04); border-radius: 6px; transition: background .12s; }
.vx-row:hover { background: var(--s1); }
.vx-row-slug { font-family: 'JetBrains Mono',monospace; font-size: 11px; color: var(--t2); flex: 1; }
.vx-row-name { font-size: 12px; color: var(--t1); flex: 2; }
.vx-row-num { font-size: 11px; color: var(--t3); width: 60px; text-align: right; }
.vx-client-row { cursor: pointer; }
.vx-client-row:hover .vx-row-name { color: var(--pu); }
.vx-status-badge { display: inline-block; padding: 1px 8px; border-radius: 10px; font-size: 11px; font-weight: 600; letter-spacing: .03em; text-transform: uppercase; white-space: nowrap; }
.vx-status-prospect { background: rgba(184,151,43,.15); color: #e8c870; border: 1px solid rgba(184,151,43,.4); }
.vx-status-active   { background: rgba(52,199,89,.12);  color: var(--gr); border: 1px solid rgba(52,199,89,.3); }
.vx-status-churned  { background: rgba(120,120,130,.12); color: #888; border: 1px solid rgba(120,120,130,.3); }
.vx-status-paused   { background: rgba(120,120,130,.08); color: #777; border: 1px solid rgba(120,120,130,.2); }
.vx-status-unknown  { background: transparent; color: #555; border: 1px dashed #444; font-style: italic; }
.vx-lead-source-label { font-size: 11px; color: #888; font-family: monospace; }
.client-item.vx-nav-active { background: rgba(185,151,43,.12); color: #e8c870; border-color: rgba(185,151,43,.3); }
.vx-nav-icon { font-size: 13px; width: 16px; text-align: center; flex-shrink: 0; opacity: .8; }
.client-item.vx-nav-active .vx-nav-icon { opacity: 1; }

/* Verticals admin — edit affordances */
.vx-edit-form { display: flex; flex-direction: column; gap: 16px; max-width: 720px; }
.vx-edit-field { display: flex; flex-direction: column; gap: 6px; }
.vx-edit-label { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--t3); font-weight: 600; }
.vx-edit-caption { font-size: 10px; color: var(--t3); margin-top: 2px; line-height: 1.4; }
.vx-edit-input { background: rgba(255,255,255,.04); border: 1px solid var(--bd); border-radius: 6px; padding: 9px 12px; color: var(--t1); font-family: 'Sora',sans-serif; font-size: 12px; transition: border-color .15s, background .15s; }
.vx-edit-input:focus { outline: none; border-color: rgba(185,151,43,.5); background: rgba(255,255,255,.06); }
.vx-edit-textarea { background: rgba(255,255,255,.04); border: 1px solid var(--bd); border-radius: 6px; padding: 10px 12px; color: var(--t1); font-family: 'Sora',sans-serif; font-size: 12px; line-height: 1.5; resize: vertical; min-height: 80px; transition: border-color .15s, background .15s; }
.vx-edit-textarea:focus { outline: none; border-color: rgba(185,151,43,.5); background: rgba(255,255,255,.06); }
.vx-edit-locked { display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,.03); border: 1px solid var(--bd); border-radius: 6px; padding: 9px 12px; font-family: 'JetBrains Mono',monospace; font-size: 11px; color: #B8972B; }
.vx-edit-locked-icon { opacity: .85; font-size: 12px; }
.vx-edit-meta { display: flex; flex-direction: column; gap: 4px; padding: 12px 14px; margin-top: 4px; background: rgba(255,255,255,.02); border: 1px dashed var(--bd); border-radius: 6px; }
.vx-edit-meta-row { font-family: 'JetBrains Mono',monospace; font-size: 10px; color: var(--t3); line-height: 1.6; word-break: break-word; }
.vx-edit-meta-key { color: var(--t3); }
.vx-edit-meta-val { color: var(--t2); }
.vx-save-row { display: flex; align-items: center; gap: 14px; margin-top: 4px; }
.vx-save-button { background: linear-gradient(180deg, #c9a84c 0%, #B8972B 100%); border: 1px solid rgba(185,151,43,.7); border-radius: 6px; color: #fff; font-family: 'Sora',sans-serif; font-size: 12px; font-weight: 600; padding: 8px 18px; cursor: pointer; box-shadow: 0 1px 3px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.18); transition: filter .12s, transform .04s; letter-spacing: .02em; }
.vx-save-button:hover:not(:disabled) { filter: brightness(1.08); }
.vx-save-button:active:not(:disabled) { transform: translateY(1px); }
.vx-save-button:disabled { opacity: .3; cursor: not-allowed; box-shadow: none; }
.vx-saved-toast { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: #34c759; opacity: 0; transition: opacity .25s; pointer-events: none; }
.vx-saved-toast.show { opacity: 1; }
.vx-saved-check { font-weight: bold; font-size: 12px; }
.vx-inline-error { font-size: 11px; color: #ff8a80; margin-top: 8px; padding: 8px 12px; background: rgba(255,69,58,.08); border: 1px solid rgba(255,69,58,.25); border-radius: 6px; line-height: 1.5; }
.vx-sub-tab.vx-dirty { font-style: italic; }
.vx-sub-tab.vx-dirty::after { content: '●'; color: #B8972B; margin-left: 6px; font-size: 9px; vertical-align: middle; }
.vx-prompt-textarea { width: 100%; min-height: 600px; box-sizing: border-box; background: rgba(255,255,255,.03); border: 1px solid var(--bd); border-radius: 8px; padding: 16px; font-family: 'JetBrains Mono',monospace; font-size: 11px; line-height: 1.7; color: var(--t1); resize: vertical; transition: border-color .15s; }
.vx-prompt-textarea:focus { outline: none; border-color: rgba(185,151,43,.5); }

/* Verticals admin — taxonomy CRUD (Categories + Topics) */
.vx-tax-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.vx-tax-count { font-size: 11px; color: var(--t3); }
.vx-tax-add-trigger { background: linear-gradient(180deg,#c9a84c 0%,#B8972B 100%); border: 1px solid rgba(185,151,43,.7); border-radius: 6px; color: #fff; font-family: 'Sora',sans-serif; font-size: 11px; font-weight: 600; padding: 6px 14px; cursor: pointer; box-shadow: 0 1px 2px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.18); transition: filter .12s, transform .04s; letter-spacing: .02em; }
.vx-tax-add-trigger:hover { filter: brightness(1.1); }
.vx-tax-add-trigger:active { transform: translateY(1px); }
.vx-tax-row { padding: 10px 12px; gap: 12px; }
.vx-tax-row-expanded { display: block; padding: 16px 18px; background: rgba(185,151,43,.04); border: 1px solid rgba(185,151,43,.18); border-radius: 8px; margin: 8px 0; }
.vx-tax-actions { display: flex; gap: 6px; justify-content: flex-end; flex-shrink: 0; }
.vx-tax-edit-button { background: rgba(255,255,255,.05); border: 1px solid var(--bd); border-radius: 5px; color: var(--t2); font-family: 'Sora',sans-serif; font-size: 10px; font-weight: 500; padding: 4px 11px; cursor: pointer; transition: background .12s, color .12s, border-color .12s; }
.vx-tax-edit-button:hover { background: rgba(255,255,255,.09); color: var(--t1); border-color: rgba(255,255,255,.18); }
.vx-tax-delete-button { background: transparent; border: 1px solid rgba(255,69,58,.35); border-radius: 5px; color: rgba(255,138,128,.9); font-family: 'Sora',sans-serif; font-size: 10px; font-weight: 500; padding: 4px 11px; cursor: pointer; transition: background .12s, color .12s, border-color .12s; }
.vx-tax-delete-button:hover { background: rgba(255,69,58,.12); color: #ff8a80; border-color: rgba(255,69,58,.55); }
.vx-tax-cancel-button { background: transparent; border: 1px solid var(--bd); border-radius: 6px; color: var(--t2); font-family: 'Sora',sans-serif; font-size: 12px; font-weight: 500; padding: 7px 14px; cursor: pointer; transition: background .12s, color .12s; }
.vx-tax-cancel-button:hover { background: rgba(255,255,255,.05); color: var(--t1); }
.vx-tax-add-form { background: rgba(185,151,43,.04); border: 1px solid rgba(185,151,43,.18); border-radius: 8px; padding: 16px 18px; margin-bottom: 14px; display: flex; flex-direction: column; gap: 12px; }
.vx-tax-edit-form { display: flex; flex-direction: column; gap: 12px; }
.vx-input-invalid { border-color: rgba(255,69,58,.55) !important; background: rgba(255,69,58,.04) !important; }
.vx-input-error-msg { font-size: 10px; color: #ff8a80; min-height: 14px; line-height: 1.4; }

/* Verticals admin — New Vertical modal */
.vx-list-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.vx-new-btn { background: linear-gradient(180deg,#c9a84c 0%,#B8972B 100%); border: 1px solid rgba(185,151,43,.7); border-radius: 6px; color: #fff; font-family: 'Sora',sans-serif; font-size: 11px; font-weight: 600; padding: 6px 14px; cursor: pointer; box-shadow: 0 1px 2px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.18); transition: filter .12s, transform .04s; letter-spacing: .02em; }
.vx-new-btn:hover { filter: brightness(1.1); }
.vx-new-btn:active { transform: translateY(1px); }
.vx-modal-overlay { position: fixed; inset: 0; z-index: 9000; background: rgba(0,0,0,.72); backdrop-filter: blur(5px); display: flex; align-items: center; justify-content: center; }
.vx-modal-panel { background: #0d0d0d; border: 1px solid rgba(185,151,43,.3); border-radius: 12px; box-shadow: 0 24px 64px rgba(0,0,0,.8); width: min(580px,90vw); max-height: 90vh; display: flex; flex-direction: column; overflow: hidden; }
.vx-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px 16px; border-bottom: 1px solid rgba(255,255,255,.06); flex-shrink: 0; }
.vx-modal-title { font-family: 'Cormorant Garamond',serif; font-size: 20px; font-weight: 600; color: var(--t1); }
.vx-modal-close { background: none; border: none; color: var(--t3); font-size: 16px; cursor: pointer; padding: 4px 8px; border-radius: 4px; transition: color .12s, background .12s; line-height: 1; }
.vx-modal-close:hover { color: var(--t1); background: rgba(255,255,255,.07); }
.vx-modal-body { padding: 20px 22px; overflow-y: auto; flex: 1; display: flex; flex-direction: column; gap: 16px; }
.vx-modal-footer { display: flex; align-items: center; justify-content: flex-end; gap: 10px; padding: 14px 22px 18px; border-top: 1px solid rgba(255,255,255,.06); flex-shrink: 0; }
.vx-modal-select { background: rgba(255,255,255,.04); border: 1px solid var(--bd); border-radius: 6px; padding: 9px 12px; color: var(--t1); font-family: 'Sora',sans-serif; font-size: 12px; width: 100%; transition: border-color .15s; appearance: none; cursor: pointer; }
.vx-modal-select:focus { outline: none; border-color: rgba(185,151,43,.5); background: rgba(255,255,255,.06); }
.vx-modal-select option { background: #1a1a1a; color: var(--t1); }

/* ── Add-Client-via-URL modal (acu) ──────────────────────────────── */
#acu-modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.82); z-index:300;
  align-items:flex-start; justify-content:center; padding:40px 16px 40px; overflow-y:auto; }
#acu-modal.open { display:flex; }
.acu-box { background:#0e0e0e; border:1px solid var(--bd2); border-radius:12px;
  width:700px; max-width:100%; display:flex; flex-direction:column; }
.acu-header { padding:20px 24px 14px; flex-shrink:0; border-bottom:1px solid var(--bd); }
.acu-title { font-size:13px; font-weight:600; color:var(--t1); margin-bottom:3px; }
.acu-subtitle { font-size:11px; color:var(--t3); }
.acu-body { overflow-y:auto; padding:16px 24px 8px; max-height:calc(90vh - 160px); }
.acu-footer { padding:12px 24px; border-top:1px solid var(--bd); flex-shrink:0;
  display:flex; align-items:center; gap:8px; justify-content:flex-end; }
.acu-field { margin-bottom:12px; }
.acu-label { font-size:10px; font-weight:600; color:var(--t3); text-transform:uppercase;
  letter-spacing:.08em; margin-bottom:4px; }
.acu-label .acu-req { color:var(--re); margin-left:2px; }
.acu-input,.acu-select,.acu-textarea { width:100%; box-sizing:border-box;
  background:rgba(255,255,255,.06); border:1px solid var(--bd); border-radius:6px;
  color:var(--t1); font-size:12px; padding:7px 10px; font-family:'Sora',sans-serif;
  outline:none; }
.acu-input:focus,.acu-select:focus,.acu-textarea:focus { border-color:rgba(123,82,245,.6); }
.acu-select option { background:#1a1a1a; }
.acu-textarea { resize:vertical; min-height:56px; }
.acu-error { font-size:11px; color:var(--re); margin-top:8px; display:none; }
.acu-error.visible { display:block; }
.acu-cancel { background:none; border:1px solid var(--bd); border-radius:6px; color:var(--t3);
  font-size:11px; font-weight:500; font-family:'Sora',sans-serif; padding:6px 14px; cursor:pointer; }
.acu-cancel:hover { background:rgba(255,255,255,.05); color:var(--t1); }
.acu-confirm { background:var(--pu-dim); border:1px solid var(--pu-bd); border-radius:6px;
  color:#b0c4ff; font-size:11px; font-weight:600; font-family:'Sora',sans-serif; padding:6px 16px;
  cursor:pointer; position:relative; overflow:hidden; transition:background .15s; }
.acu-confirm:hover { background:rgba(123,82,245,.2); }
.acu-confirm:disabled { opacity:.45; cursor:not-allowed; }
/* Review screen */
.acu-section-title { font-size:9px; font-weight:700; text-transform:uppercase;
  letter-spacing:.12em; color:var(--t3); margin:16px 0 8px;
  padding-bottom:5px; border-bottom:1px solid var(--bd); }
.acu-field-row { display:grid; grid-template-columns:130px 1fr 52px;
  align-items:center; gap:8px; margin-bottom:8px; }
.acu-field-label { font-size:10px; color:var(--t2); font-weight:500; }
.acu-confidence { font-size:9px; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  opacity:.65; padding:2px 4px; border-radius:3px; background:rgba(255,255,255,.05);
  color:var(--t3); text-align:center; white-space:nowrap; }
.acu-report-toggle { font-size:11px; color:var(--pu); cursor:pointer; padding:10px 0 4px;
  display:flex; align-items:center; gap:5px; user-select:none; }
.acu-report-toggle:hover { color:#b0c4ff; }
.acu-report-wrap { display:none; margin-top:4px; margin-bottom:8px; }
.acu-report-wrap.open { display:block; }
.acu-report-pre { background:rgba(255,255,255,.03); border:1px solid var(--bd); border-radius:6px;
  padding:12px; font-size:10px; line-height:1.55; color:var(--t2); white-space:pre-wrap;
  word-break:break-word; max-height:220px; overflow-y:auto;
  font-family:'JetBrains Mono',monospace; }
.acu-discard { background:none; border:1px solid var(--bd); border-radius:6px; color:var(--re);
  font-size:11px; font-weight:500; font-family:'Sora',sans-serif; padding:6px 14px;
  cursor:pointer; margin-right:auto; }
.acu-discard:hover { background:var(--re-dim); border-color:var(--re-bd); }
.acu-discard:disabled { opacity:.45; cursor:not-allowed; }


/* ── B-Roll section (Wiring #3) ─────────────────────────────────── */
.scene-card__brolls { margin: 12px 0 0; border-top: 1px solid var(--bd); padding: 10px 14px; }
.scene-card__brolls-header { font-size: 9px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--t3); margin-bottom: 8px; }

.scene-card__broll { margin-bottom: 10px; border: 1px solid var(--bd); border-radius: 8px;
  overflow: hidden; background: rgba(255,255,255,.02); }

/* Thumbnail */
.scene-card__broll-thumb { position: relative; width: 100%; aspect-ratio: 16/9;
  background: rgba(255,255,255,.04); display: flex; align-items: center;
  justify-content: center; overflow: hidden; border-radius: 8px 8px 0 0; }
.scene-card__broll-thumb--done { background: #000; cursor: pointer; }
.scene-card__broll-thumb--error { background: var(--re-dim); }
/* Thumbnail footer (status badge — sibling to HTMX swap target) */
.scene-card__broll-thumb-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 3px 7px; background: rgba(255,255,255,.04);
  border-radius: 0 0 8px 8px; border-top: 1px solid rgba(255,255,255,.06);
}
.scene-card__broll-thumb-badge { font-size: 9px; font-weight: 700; letter-spacing: .05em; color: var(--t3); }
.scene-card__broll-thumb-si { font-size: 9px; font-weight: 700; }
.scene-card__broll-thumb-si--done  { color: var(--gr); }
.scene-card__broll-thumb-si--error { color: var(--re); }
.scene-card__broll-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.scene-card__broll-placeholder { font-size: 20px; font-weight: 700; color: var(--pu);
  opacity: .5; user-select: none; }
.scene-card__broll-error-icon { font-size: 18px; color: var(--re); }

/* Generating spinner */
.scene-card__broll-spinner { width: 24px; height: 24px; border: 2px solid rgba(255,255,255,.12);
  border-top-color: var(--gold); border-radius: 50%;
  animation: broll-spin .7s linear infinite; }
@keyframes broll-spin { to { transform: rotate(360deg); } }

/* brprog overlays (targeted by _setBRollProgress from studio.js) */
.brprog-shimmer { position: absolute; inset: 0; background: linear-gradient(
    90deg, transparent 0%, rgba(201,168,76,.18) 50%, transparent 100%);
  background-size: 200% 100%; animation: brprog-sh 1.2s ease-in-out infinite; }
@keyframes brprog-sh { 0%,100% { background-position: 200% 0; } 50% { background-position: -200% 0; } }
.brprog-bar { position: absolute; bottom: 0; left: 0; height: 3px;
  background: var(--gold); width: 0; transition: width .25s ease; border-radius: 0 2px 2px 0; }

/* Accordion */
.scene-card__broll-accordion { border-top: 1px solid var(--bd); }
.scene-card__broll-accordion-summary { display: flex; align-items: center; gap: 6px;
  padding: 7px 10px; cursor: pointer; list-style: none; font-size: 11px;
  color: var(--t2); user-select: none; }
.scene-card__broll-accordion-summary::-webkit-details-marker { display: none; }
.scene-card__broll-accordion[open] .scene-card__broll-accordion-summary { color: var(--t1); }
.scene-card__broll-id-badge { font-size: 10px; font-weight: 700; padding: 1px 5px;
  border-radius: 3px; background: rgba(255,255,255,.07); color: var(--t2);
  border: 1px solid var(--bd); }
.scene-card__broll-type { font-size: 10px; color: var(--t3); }
.scene-card__broll-status { font-size: 9px; font-weight: 600; margin-left: auto; }
.scene-card__broll-status--done { color: var(--gr); }
.scene-card__broll-status--pending { color: var(--t3); }
.scene-card__broll-status--error { color: var(--re); }

/* Accordion body */
.scene-card__broll-body { padding: 10px 12px 12px; display: flex; flex-direction: column; gap: 8px; }
.scene-card__broll-prompt-label { font-size: 9px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .08em; color: var(--t3); }
.scene-card__broll-prompt { width: 100%; box-sizing: border-box; resize: vertical;
  background: rgba(255,255,255,.05); border: 1px solid var(--bd); border-radius: 5px;
  color: var(--t1); font-size: 11px; line-height: 1.5; padding: 6px 8px;
  font-family: 'Sora', sans-serif; outline: none; }
.scene-card__broll-prompt:focus { border-color: rgba(123,82,245,.5); }
.scene-card__broll-generate { align-self: flex-start; }

/* Regen overlay button on thumbnail */
.scene-card__broll-regen {
  position: absolute; bottom: 6px; right: 6px;
  width: 26px; height: 26px; border-radius: 50%;
  background: rgba(0,0,0,.6); border: 1px solid rgba(255,255,255,.15);
  color: #fff; font-size: 13px; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .15s, background .15s;
  padding: 0;
}
.scene-card__broll-thumb:hover .scene-card__broll-regen { opacity: 1; }
.scene-card__broll-regen:hover { background: rgba(123,82,245,.7); border-color: rgba(123,82,245,.5); }

/* B-roll done pulse */
@keyframes broll-done-pulse {
  0%, 100% { text-shadow: none; }
  50%      { text-shadow: 0 0 6px rgba(52,199,89,.9), 0 0 12px rgba(52,199,89,.5); }
}
.scene-card__broll-status--pulse { animation: broll-done-pulse .7s ease-out; }
