/* ═══════════════════════════════════════════════════════════════════
   T-LEGAL SUITE — Design System Foundation
   T-Server Design System · T-Legal Color Flavor
   ═══════════════════════════════════════════════════════════════════ */

/* ── Design System Tokens ── */
:root {
  /* T-Legal color palette */
  --bg-deep: #0a0a0f;
  --bg-mid: #0d1117;
  --bg-warm: #0a0f1a;
  --accent: #4f8ef7;
  --accent2: #6c63ff;
  --gold: #d4a847;
  --emerald: #22c55e;
  --amber: #f59e0b;
  --red: #ef4444;
  --text: #e2e8f0;
  --text2: #8892a4;
  --text3: #4a5568;

  /* Glass morphism */
  --glass-bg: rgba(255,255,255,0.08);
  --glass-border: rgba(255,255,255,0.10);
  --glass-hover: rgba(255,255,255,0.10);
  --accent-border: rgba(79,142,247,0.3);

  /* Radii & spacing */
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;

  /* Typography */
  --font-display: 'Rajdhani', 'Segoe UI', sans-serif;
  --font-mono: 'Share Tech Mono', 'Consolas', monospace;
  --font-body: 'Segoe UI', system-ui, sans-serif;

  /* Layout widths */
  --nav-w: 52px;
  --subjects-w: 230px;
  --context-w: 290px;

  /* ── Backward-compatible aliases ──
     Old variable names mapped to new design system values.
     Every existing class that uses var(--glass-bg) etc. keeps working. */
  --bg: var(--bg-deep);
  --surface: var(--bg-mid);
  --surface2: rgba(255,255,255,0.10);
  --border: var(--glass-border);
  --success: var(--emerald);
  --warning: var(--amber);
  --danger: var(--red);
  --sidebar-w: 300px;
}


/* ═══════════════════════════════════════════════════════════════════
   THEMES
   ═══════════════════════════════════════════════════════════════════ */

/* Theme 1: Midnight (default — values already in :root) */

/* Theme 2: Slate — Professional grey, like VS Code */
body.theme-slate {
  --bg-deep: #1e1e2e;
  --bg-mid: #252536;
  --bg-warm: #1e2030;
  --text: #cdd6f4;
  --text2: #7f849c;
  --text3: #585b70;
  --glass-bg: rgba(255,255,255,0.09);
  --glass-border: rgba(255,255,255,0.12);
  --glass-hover: rgba(255,255,255,0.11);
  --surface2: rgba(255,255,255,0.11);
}
body.theme-slate { background: linear-gradient(135deg, #1e1e2e 0%, #252536 50%, #1e1e2e 100%); }
body.theme-slate::before { background-image: linear-gradient(rgba(79,142,247,0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(79,142,247,0.025) 1px, transparent 1px); }

/* ═══ LIGHT THEMES (from design-system-light.html) ═══ */

/* Shared light theme overrides */
/* ═══ LIGHT THEME — White surfaces floating on tinted background ═══
   Theme color = atmosphere (body gradient, grid, gaps between panels).
   Panels = white/frosted glass with shadow — NOT tinted.
   AI chat = pure white cards. The tint is BEHIND, not ON content. */
.light-theme { --surface: #fff; --border: var(--glass-border); --success: var(--emerald); --danger: var(--red); }

/* Structural — frosted glass over body gradient */
.light-theme header, .light-theme .chat-topbar, .light-theme .chat-input-wrap { background: rgba(255,255,255,0.85); backdrop-filter:blur(12px); box-shadow:0 1px 0 var(--glass-border); }
.light-theme aside, .light-theme .subjects-panel { background: rgba(255,255,255,0.75); box-shadow:1px 0 0 var(--glass-border); }
.light-theme .nav-rail { background: rgba(255,255,255,0.8); box-shadow:1px 0 0 var(--glass-border); }
.light-theme .chat-input-area { background: rgba(255,255,255,0.6); }
.light-theme .voice-bar { background: rgba(255,255,255,0.45) !important; backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-top: 1px solid rgba(255,255,255,0.3) !important; }
.light-theme .vb-btn { border-color:rgba(0,0,0,0.12); background:rgba(0,0,0,0.05); color:var(--text); }
.light-theme .vb-timeline, .light-theme .voice-timeline { background:rgba(0,0,0,0.15); }
.light-theme .status-bar { background: rgba(255,255,255,0.85); backdrop-filter:blur(12px); }
.light-theme .tabs { background: rgba(255,255,255,0.5); }
.light-theme .doc-panel-inner { background: rgba(255,255,255,0.75); box-shadow:-1px 0 0 var(--glass-border); }

/* Chat — pure white cards */
.light-theme .msg.user .msg-bubble { color: #fff; }
.light-theme .msg.assistant .msg-bubble { background: #fff; border-color: var(--glass-border); box-shadow:0 1px 4px rgba(0,0,0,0.06); }
.light-theme .typing-indicator { background: #fff; border-color: var(--glass-border); }
.light-theme .typing-dot { background: var(--text3); }

/* Scrollbars */
.light-theme * { scrollbar-color: var(--scrollbar, rgba(79,142,247,0.18)) transparent; }
.light-theme *::-webkit-scrollbar-thumb { background: var(--scrollbar, rgba(79,142,247,0.18)); }

/* Cards, modals — white with shadow */
.light-theme .card, .light-theme .modal, .light-theme .wizard-modal, .light-theme .brief-me-modal,
.light-theme .help-guide-box, .light-theme .archive-viewer,
.light-theme .obl-dialog { background: #fff; box-shadow:0 4px 20px rgba(0,0,0,0.08); }
.light-theme .modal-box { background: #fff; }
.light-theme .doc-item, .light-theme .suggest-item, .light-theme .change-card { background: #fff; border-color: var(--glass-border); box-shadow:0 1px 3px rgba(0,0,0,0.04); }
.light-theme .cq-btn, .light-theme .quick-btn { background: #fff; border-color: var(--glass-border); }

/* Inputs — white */
.light-theme input[type=text], .light-theme input[type=password], .light-theme textarea, .light-theme select { background: #fff; border-color: var(--glass-border); }
.light-theme .chat-textarea { background: #fff; border-color: var(--glass-border); }
.light-theme .session-card { background: #fff; border-color: var(--glass-border); box-shadow:0 1px 3px rgba(0,0,0,0.04); }
.light-theme .session-card:hover { border-color: var(--accent-border); }
.light-theme .rec-mc-right input, .light-theme .rec-mc-right textarea, .light-theme .rec-mc-left input, .light-theme .rec-mc-right select { background: #fff; border-color: var(--glass-border); }

/* AI Studio */
.light-theme .as-chat-header { background: rgba(255,255,255,0.85); backdrop-filter:blur(12px); }
.light-theme .as-chat-input-wrap { background: rgba(255,255,255,0.6); }
.light-theme .as-history-bar { background: rgba(255,255,255,0.5); }

/* Redline modal — transparent, let gradient show */
.light-theme .ws-rl-modal { background: transparent; }
.light-theme .ws-rl-header { background: rgba(255,255,255,0.85); backdrop-filter:blur(20px); box-shadow:0 1px 0 var(--glass-border); }
.light-theme .ws-rl-status-bar { background: rgba(255,255,255,0.7); }
.light-theme .ws-rl-changes-tabs { background: rgba(255,255,255,0.5); }
/* (rl-cr-chat-pane, input wraps — overridden in WF1 light theme section below) */
.light-theme .rl-chat-textarea { background: #fff; border-color: var(--glass-border); }
.light-theme .rl-mic-btn { background: #fff; border-color: var(--glass-border); }

/* Redline chat */
.light-theme #rlCrMessages .msg.assistant .msg-bubble,
.light-theme #rlChatTab .msg.assistant .msg-bubble { background: #fff !important; border-color: var(--glass-border) !important; box-shadow:0 1px 4px rgba(0,0,0,0.06); }
.light-theme #rlCrMessages .msg.user .msg-bubble,
.light-theme #rlChatTab .msg.user .msg-bubble { color: #fff !important; }

/* Quick actions — white pills */
.light-theme .rl-qa-bar { background: transparent; }
.light-theme .rl-qa-pill { background:#fff; border-color:var(--glass-border); color:var(--text2); box-shadow:0 1px 2px rgba(0,0,0,0.04); }
.light-theme .rl-qa-pill:hover { border-color:var(--accent); color:var(--accent); }

/* Buttons */
.light-theme .rl-word-mode-btn { background: transparent !important; border: 1px solid rgba(79,142,247,0.25) !important; color: var(--accent) !important; box-shadow: none !important; }
.light-theme .rl-word-mode-btn:hover { border-color: var(--accent) !important; background: rgba(79,142,247,0.06) !important; }
.light-theme .ai-tool-btn { background:#fff; border-color:rgba(79,142,247,0.25); color:var(--accent); box-shadow:0 1px 2px rgba(0,0,0,0.04); }
.light-theme .ai-tool-btn:hover { background:rgba(79,142,247,0.06); border-color:rgba(79,142,247,0.4); }

/* Context */
.light-theme .ctx-btn { border-color:rgba(79,142,247,0.25); background:#fff; color:var(--accent); box-shadow:0 1px 2px rgba(0,0,0,0.04); }
.light-theme .ctx-btn:hover { background:rgba(79,142,247,0.06); }
.light-theme .ctx-btn.open { background:rgba(79,142,247,0.08); border-color:rgba(79,142,247,0.4); }

/* Misc */
.light-theme .toast { background: #fff; box-shadow:0 4px 16px rgba(0,0,0,0.1); }
.light-theme .nav-item[data-tip]:hover::after { background: #fff; border-color: var(--glass-border); color: var(--text); box-shadow:0 2px 8px rgba(0,0,0,0.08); }
.light-theme .theme-swatch[data-tip]:hover::after,
.light-theme .ctx-mini-btn[data-tip]:hover::before { background: #fff; border-color: rgba(0,0,0,0.12); color: var(--text); box-shadow:0 2px 8px rgba(0,0,0,0.08); }
.light-theme .ai-tool-tip-float { background: #fff; border-color: rgba(0,0,0,0.12); color: var(--text2); box-shadow:0 4px 16px rgba(0,0,0,0.1); }
.light-theme .project-dropdown { background: #fff; box-shadow:0 4px 16px rgba(0,0,0,0.1); }

/* Theme 3: Ivory — Warm White (refined) */
body.theme-ivory {
  --bg-deep: #eae6df; --bg-mid: #e4e0d8; --bg-surface: #ffffff; --bg-warm: #f0ede7;
  --text: #1a1a2e; --text2: #4a4a5e; --text3: #6b6b80;
  --glass-bg: rgba(0,0,0,0.06); --glass-border: rgba(0,0,0,0.14); --glass-hover: rgba(0,0,0,0.08);
  --accent: #2563b8; --accent2: #4338a8; --accent-border: rgba(37,99,184,0.25);
  --emerald: #0f7a3a; --red: #dc2626; --gold: #b8860b;
  --surface2: rgba(0,0,0,0.06); --shadow: rgba(0,0,0,0.06); --shadow-lg: rgba(0,0,0,0.1);
  --scrollbar: rgba(37,99,184,0.18);
}
body.theme-ivory { background: linear-gradient(160deg, #ede8e0 0%, #e6dfd5 25%, #ddd6ca 50%, #e6dfd5 75%, #ede8e0 100%); }
body.theme-ivory::before { background-image: linear-gradient(rgba(79,142,247,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(79,142,247,0.04) 1px, transparent 1px); }

/* Theme 3b: Snow — Crisp blue-white, modern corporate */
body.theme-snow {
  --bg-deep: #e6ecf4; --bg-mid: #dfe6f0; --bg-surface: #ffffff; --bg-warm: #eef2f8;
  --text: #111827; --text2: #374151; --text3: #6b7280;
  --glass-bg: rgba(30,64,120,0.06); --glass-border: rgba(30,64,120,0.14); --glass-hover: rgba(30,64,120,0.08);
  --accent: #1d4ed8; --accent2: #3730a3; --accent-border: rgba(29,78,216,0.2);
  --emerald: #047857; --red: #dc2626; --gold: #b45309;
  --surface2: rgba(30,64,120,0.06); --shadow: rgba(30,64,120,0.05); --shadow-lg: rgba(30,64,120,0.08);
  --scrollbar: rgba(29,78,216,0.15);
}
body.theme-snow { background: linear-gradient(160deg, #eaf0f8 0%, #e0e8f4 25%, #d6dfee 50%, #e0e8f4 75%, #eaf0f8 100%); }
body.theme-snow::before { background-image: linear-gradient(rgba(29,78,216,0.035) 1px, transparent 1px), linear-gradient(90deg, rgba(29,78,216,0.035) 1px, transparent 1px); }

/* Theme 3c: Pearl — Soft lavender-grey, sophisticated */
body.theme-pearl {
  --bg-deep: #e4e2ea; --bg-mid: #dddae4; --bg-surface: #ffffff; --bg-warm: #eceaf0;
  --text: #1e1b2e; --text2: #3d3952; --text3: #5a5670;
  --glass-bg: rgba(60,50,90,0.06); --glass-border: rgba(60,50,90,0.14); --glass-hover: rgba(60,50,90,0.08);
  --accent: #6d52d4; --accent2: #4338a8; --accent-border: rgba(109,82,212,0.2);
  --emerald: #0f7a3a; --red: #ef4444; --gold: #d4a847;
  --surface2: rgba(60,50,90,0.06); --shadow: rgba(60,50,90,0.05); --shadow-lg: rgba(60,50,90,0.08);
  --scrollbar: rgba(109,82,212,0.15);
}
body.theme-pearl { background: linear-gradient(160deg, #eae8f0 0%, #e0dde9 25%, #d5d1e0 50%, #e0dde9 75%, #eae8f0 100%); }
body.theme-pearl::before { background-image: linear-gradient(rgba(109,82,212,0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(109,82,212,0.03) 1px, transparent 1px); }

/* Theme 3d: Linen — Warm paper, amber/editorial */
body.theme-linen {
  --bg-deep: #ebe4d6; --bg-mid: #e5dccb; --bg-surface: #fffefb; --bg-warm: #f0ead8;
  --text: #2c2418; --text2: #4d4235; --text3: #6b5e4f;
  --glass-bg: rgba(44,36,24,0.065); --glass-border: rgba(44,36,24,0.15); --glass-hover: rgba(44,36,24,0.08);
  --accent: #8b6e14; --accent2: #725a10; --accent-border: rgba(139,110,20,0.2);
  --emerald: #15652e; --red: #b91c1c; --gold: #b8860b;
  --surface2: rgba(44,36,24,0.065); --shadow: rgba(44,36,24,0.06); --shadow-lg: rgba(44,36,24,0.1);
  --scrollbar: rgba(139,110,20,0.15);
}
body.theme-linen { background: linear-gradient(160deg, #f0e8d8 0%, #e8deca 25%, #dfd2bc 50%, #e8deca 75%, #f0e8d8 100%); }
body.theme-linen::before { background-image: linear-gradient(rgba(184,134,11,0.035) 1px, transparent 1px), linear-gradient(90deg, rgba(184,134,11,0.035) 1px, transparent 1px); }

/* Theme 3e: Frost — Cool mint-teal, refreshing */
body.theme-frost {
  --bg-deep: #dce8e8; --bg-mid: #d4e2e2; --bg-surface: #ffffff; --bg-warm: #e6efee;
  --text: #0f2020; --text2: #2d4a48; --text3: #46665f;
  --glass-bg: rgba(10,60,55,0.06); --glass-border: rgba(10,60,55,0.14); --glass-hover: rgba(10,60,55,0.08);
  --accent: #0d7377; --accent2: #0e6e6e; --accent-border: rgba(13,115,119,0.2);
  --emerald: #047857; --red: #dc2626; --gold: #b45309;
  --surface2: rgba(10,60,55,0.06); --shadow: rgba(10,60,55,0.06); --shadow-lg: rgba(10,60,55,0.1);
  --scrollbar: rgba(13,115,119,0.15);
}
body.theme-frost { background: linear-gradient(160deg, #e2edec 0%, #d8e6e4 25%, #ccddd9 50%, #d8e6e4 75%, #e2edec 100%); }
body.theme-frost::before { background-image: linear-gradient(rgba(13,115,119,0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(13,115,119,0.03) 1px, transparent 1px); }

/* Apply light-theme class to all light variants */
body.theme-ivory, body.theme-snow, body.theme-pearl, body.theme-linen, body.theme-frost { }

/* Theme 4: Warm — Dark with brown/amber undertones, gold accents */
body.theme-warm {
  --bg-deep: #181210;
  --bg-mid: #1f1915;
  --bg-warm: #1a1412;
  --text: #e8ddd0;
  --text2: #9a8b7a;
  --text3: #5e5248;
  --glass-bg: rgba(255,245,230,0.08);
  --glass-border: rgba(255,245,230,0.10);
  --glass-hover: rgba(255,245,230,0.10);
  --accent: #d4a847;
  --accent2: #b8860b;
  --accent-border: rgba(212,168,71,0.3);
  --surface2: rgba(255,245,230,0.10);
}
body.theme-warm { background: linear-gradient(135deg, #181210 0%, #1f1915 30%, #1a1412 60%, #181210 100%); }
body.theme-warm::before { background-image: linear-gradient(rgba(212,168,71,0.02) 1px, transparent 1px), linear-gradient(90deg, rgba(212,168,71,0.02) 1px, transparent 1px); }
body.theme-warm .subj-item.active { background: rgba(212,168,71,0.08); color: var(--gold); border-color: rgba(212,168,71,0.2); }
body.theme-warm .tab.active { color: var(--gold); background: rgba(212,168,71,0.08); border-bottom-color: var(--gold); }
body.theme-warm .msg.user .msg-bubble { background: linear-gradient(135deg, #b8860b, #d4a847); }
body.theme-warm * { scrollbar-color: rgba(212,168,71,0.15) transparent; }
body.theme-warm *::-webkit-scrollbar-thumb { background: rgba(212,168,71,0.15); }

/* Theme 5: Ocean — Deep navy with teal accents */
body.theme-ocean {
  --bg-deep: #0a1628;
  --bg-mid: #0f1d32;
  --bg-warm: #0c192c;
  --text: #d4e4f7;
  --text2: #7a9cc0;
  --text3: #4a6a8a;
  --glass-bg: rgba(100,180,255,0.08);
  --glass-border: rgba(100,180,255,0.10);
  --glass-hover: rgba(100,180,255,0.10);
  --accent: #38b2ac;
  --accent2: #2c7a7b;
  --accent-border: rgba(56,178,172,0.35);
  --surface2: rgba(100,180,255,0.10);
}
body.theme-ocean { background: linear-gradient(135deg, #0a1628 0%, #0f1d32 30%, #0c192c 60%, #0a1628 100%); }
body.theme-ocean::before { background-image: linear-gradient(rgba(56,178,172,0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(56,178,172,0.025) 1px, transparent 1px); }
body.theme-ocean .subj-item.active { background: rgba(56,178,172,0.08); color: #38b2ac; border-color: rgba(56,178,172,0.2); }
body.theme-ocean .tab.active { color: #38b2ac; background: rgba(56,178,172,0.08); border-bottom-color: #38b2ac; }
body.theme-ocean .msg.user .msg-bubble { background: linear-gradient(135deg, #2c7a7b, #38b2ac); }
body.theme-ocean * { scrollbar-color: rgba(56,178,172,0.15) transparent; }
body.theme-ocean *::-webkit-scrollbar-thumb { background: rgba(56,178,172,0.15); }


/* ═══════════════════════════════════════════════════════════════════
   GLOBAL RESET · SCROLLBAR · GRID OVERLAY
   ═══════════════════════════════════════════════════════════════════ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

/* Scrollbar — design system thin accent */
* { scrollbar-width: thin; scrollbar-color: rgba(79,142,247,0.15) transparent; }
*::-webkit-scrollbar { width: 6px; height: 6px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb { background: rgba(79,142,247,0.15); border-radius: 3px; }
*::-webkit-scrollbar-thumb:hover { background: rgba(79,142,247,0.25); }

html, body { width: 100%; height: 100%; overflow: hidden; }
body {
  font-family: var(--font-body);
  background: linear-gradient(135deg, var(--bg-deep) 0%, var(--bg-mid) 30%, var(--bg-warm) 60%, var(--bg-deep) 100%);
  color: var(--text);
  display: flex;
  flex-direction: column;
}

/* Subtle grid overlay — design system atmospheric detail */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(79,142,247,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,142,247,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}

/* Theme picker swatches */
.theme-picker {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-right: 8px;
}
.theme-swatch {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer; transition: all 0.2s;
  position: relative;
}
.theme-swatch:hover { transform: scale(1.15); }
.theme-swatch.active { border-color: var(--accent) !important; box-shadow: 0 0 0 2px rgba(79,142,247,0.25); }
.theme-swatch[data-tip]:hover::after {
  content: attr(data-tip);
  position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 9px;
  padding: 3px 8px; border-radius: 4px;
  background: rgba(13,17,23,0.95); border: 1px solid var(--glass-border);
  color: var(--text); white-space: nowrap; pointer-events: none; z-index: 100;
}


/* ═══════════════════════════════════════════════════════════════════
   ALL EXISTING CLASSES — Preserved for backward compatibility
   ═══════════════════════════════════════════════════════════════════ */

/* ── TLegal Custom Dialog ── */
#oblDialogBackdrop { position:fixed; inset:0; background:rgba(0,0,0,0.4); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); z-index:10001; display:none; align-items:center; justify-content:center; }
#oblDialogBackdrop.open { display:flex; }
.obl-dialog { background:var(--bg-mid); border:1px solid var(--glass-border); border-radius:var(--radius-lg); padding:28px 28px 22px; width:390px; max-width:92vw; box-shadow:0 24px 64px rgba(0,0,0,0.3); display:flex; flex-direction:column; align-items:center; animation:modalIn 0.25s ease; }
.obl-dialog-logo { display:flex; align-items:center; gap:8px; margin-bottom:18px; }
.obl-dialog-logo-name { font-family:var(--font-display); font-size:13px; font-weight:600; color:var(--text); letter-spacing:0.5px; }
.obl-dialog-msg { font-family:var(--font-display); font-size:14px; color:var(--text); text-align:center; font-weight:500; line-height:1.55; margin-bottom:6px; }
.obl-dialog-detail { font-family:var(--font-mono); font-size:11px; color:var(--text3); text-align:center; line-height:1.6; margin-bottom:16px; }
.obl-dialog-btns { display:flex; gap:10px; justify-content:center; width:100%; margin-top:14px; }

.hdr-suite-label { font-family:var(--font-mono);font-size:10px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;margin-left:4px; }
.theme-divider { width:1px;height:16px;background:var(--glass-border);margin:0 2px;display:inline-block; }

/* ── Header ── */
header { background: rgba(10,10,15,0.7); border-bottom: 1px solid var(--glass-border); padding: 0 16px; height: 48px; display: flex; align-items: center; gap: 16px; flex-shrink: 0; position: relative; z-index: 10; backdrop-filter: blur(20px); }
.logo { display: flex; align-items: center; gap: 8px; font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--gold); letter-spacing: 1px; flex-shrink: 0; }
.logo svg { opacity: 0.85; }
.header-actions, .header-right { display: flex; gap: 8px; align-items: center; flex-shrink: 0; margin-left: auto; }
.hdr-btn {
  font-family:var(--font-mono); font-size:10px; letter-spacing:1px;
  padding:5px 12px; border-radius:6px;
  border:1px solid var(--glass-border); background:transparent;
  color:var(--text2); cursor:pointer; transition:all 0.2s;
  display:flex; align-items:center; gap:5px;
}
.hdr-btn:hover { border-color:var(--accent-border); color:var(--text); }
.hdr-btn.ai-suite {
  background:rgba(79,142,247,0.1);
  border-color:rgba(79,142,247,0.3); color:rgba(79,142,247,0.9);
}
.hdr-btn.ai-suite:hover { background:rgba(79,142,247,0.15); }
/* Search bar (from prototype lines 236-259) */
.search-wrap { position:absolute; left:50%; transform:translateX(-50%); width:460px; max-width:calc(100% - 400px); }
.search-input {
  width:100%; background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:8px;
  padding:7px 14px 7px 34px; font-family:var(--font-mono);
  font-size:12px; color:var(--text); outline:none;
  transition:border-color 0.3s, background 0.3s;
}
.search-input::placeholder { color:var(--text3); letter-spacing:1px; }
.search-input:focus { border-color:var(--accent-border); background:var(--glass-hover); }
.search-icon { position:absolute; left:10px; top:50%; transform:translateY(-50%); color:var(--text3); pointer-events:none; }
.search-shortcut {
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  font-family:var(--font-mono); font-size:9px; color:var(--text3);
  border:1px solid var(--glass-border); border-radius:4px; padding:1px 5px;
  pointer-events:none;
}
body.theme-ivory .search-input { background:rgba(255,255,255,0.4); border-color:rgba(0,0,0,0.08); }

/* ── Import Progress Bar ── */
#importProgressBar { display:none; background:var(--glass-bg); border-bottom:1px solid var(--glass-border); padding:0 20px; height:28px; align-items:center; gap:10px; flex-shrink:0; }
#importProgressBar.active { display:flex; }
#importProgressBar .ip-label { font-size:11px; color:var(--text2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:300px; }
#importProgressBar .ip-label strong { color:var(--text); font-weight:600; }
#importProgressBar .ip-track { flex:1; height:4px; background:var(--surface2); border-radius:2px; overflow:hidden; min-width:80px; }
#importProgressBar .ip-fill { height:100%; width:0%; background:linear-gradient(90deg,#22c55e,#4ade80); border-radius:2px; transition:width 0.3s ease; }
#importProgressBar .ip-count { font-size:10px; color:var(--text2); flex-shrink:0; }
#importProgressBar.done .ip-fill { background:linear-gradient(90deg,#22c55e,#86efac); }

/* ── Layout ── */
.layout { display: flex; flex: 1; overflow: hidden; }

/* ── Nav Rail ── */
.nav-rail {
  width: var(--nav-w, 52px); flex-shrink: 0;
  background: rgba(10,10,15,0.5);
  border-right: 1px solid var(--glass-border);
  display: flex; flex-direction: column;
  align-items: center;
  padding: 8px 0; gap: 2px;
}
.nav-item {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text3);
  transition: all 0.2s; position: relative;
  border: none; background: none; padding: 0;
}
.nav-item:hover { color: var(--text2); background: rgba(255,255,255,0.03); }
.nav-item.active { color: var(--accent); background: rgba(79,142,247,0.08); }
.nav-item.active::before {
  content: ''; position: absolute;
  left: -6px; top: 8px; bottom: 8px;
  width: 3px; border-radius: 0 2px 2px 0;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(79,142,247,0.4);
}
.nav-item svg { width: 18px; height: 18px; }
.nav-item .nav-badge {
  position: absolute; top: 4px; right: 4px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--red); border: 2px solid var(--bg-mid);
}
.nav-sep { width: 24px; height: 1px; background: var(--glass-border); margin: 6px 0; }
.nav-item.gold { color: var(--gold); }
.nav-item.gold.active { color: var(--gold); background: rgba(212,168,71,0.08); }
.nav-item.gold.active::before { background: var(--gold); box-shadow: 0 0 8px rgba(212,168,71,0.4); }
.nav-item.purple { }
.nav-item.purple.active { color: var(--accent); background: rgba(79,142,247,0.08); }
.nav-item.purple.active::before { background: var(--accent); box-shadow: 0 0 8px rgba(79,142,247,0.4); }
/* Nav tooltip */
.nav-item[data-tip]:hover::after {
  content: attr(data-tip);
  position: absolute; left: calc(100% + 8px); top: 50%; transform: translateY(-50%);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.5px;
  padding: 4px 10px; border-radius: 6px;
  background: rgba(13,17,23,0.95); border: 1px solid var(--glass-border);
  color: var(--text); white-space: nowrap; z-index: 100;
  pointer-events: none;
}
/* Theme overrides for nav rail */
/* nav-rail + status-bar use var(--bg-mid) which is theme-aware */
body.theme-ivory .nav-item[data-tip]:hover::after { background: rgba(230,226,220,0.97); border-color: rgba(0,0,0,0.08); color: var(--text); }
body.theme-warm .nav-item.active { color: var(--gold); background: rgba(212,168,71,0.08); }
body.theme-warm .nav-item.active::before { background: var(--gold); box-shadow: 0 0 8px rgba(212,168,71,0.4); }
body.theme-ocean .nav-item.active { color: #38b2ac; background: rgba(56,178,172,0.08); }
body.theme-ocean .nav-item.active::before { background: #38b2ac; box-shadow: 0 0 8px rgba(56,178,172,0.4); }

/* ── Sidebar ── */
aside { width: var(--sidebar-w); background: var(--bg-mid); border-right: 1px solid var(--glass-border); display: flex; flex-direction: column; flex-shrink: 0; }
.sidebar-header { padding: 14px 16px 10px; font-size: 11px; font-weight: 600; color: var(--text2); text-transform: uppercase; letter-spacing: 1px; border-bottom: 1px solid var(--glass-border); }
.project-list { flex: 1; overflow-y: auto; padding: 6px; }
.project-item { padding: 8px 10px; border-radius: 6px; cursor: pointer; font-size: 13px; color: var(--text2); display: flex; align-items: center; gap: 8px; transition: all 0.15s; border: 1px solid transparent; }
.project-item:hover { background: var(--surface2); color: var(--text); }
.project-item.active { background: rgba(79,142,247,0.12); color: var(--accent); border-color: rgba(79,142,247,0.3); font-weight: 500; }
.project-item .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--glass-border); flex-shrink: 0; }
.project-item.active .dot { background: var(--accent); }
.project-item .more-btn { margin-left: auto; opacity: 0; font-size: 15px; line-height: 1; padding: 0 4px; background: none; border: none; color: var(--text2); cursor: pointer; flex-shrink: 0; border-radius: 4px; }
.project-item:hover .more-btn { opacity: 1; }
.project-item .more-btn:hover { background: var(--surface2); }
.proj-menu { position: fixed; background: var(--bg-mid); border: 1px solid var(--glass-border); border-radius: 8px; padding: 4px; z-index: 300; box-shadow: 0 4px 16px var(--shadow-lg, rgba(0,0,0,0.2)); min-width: 140px; display: none; }
.proj-menu.open { display: block; }
.proj-menu-item { padding: 7px 12px; font-size: 13px; border-radius: 5px; cursor: pointer; color: var(--text); transition: background 0.12s; }
.proj-menu-item:hover { background: var(--surface2); }
.proj-menu-item.danger { color: var(--danger); }
.proj-menu-item.danger:hover { background: rgba(239,68,68,0.1); }
.sidebar-footer { padding: 10px 8px; border-top: 1px solid var(--glass-border); }
/* Sidebar mode toggle */
.sidebar-toggle { display:flex; margin:8px 8px 0; background:var(--surface2); border-radius:8px; padding:3px; gap:2px; flex-shrink:0; }
.sidebar-toggle-btn { flex:1; text-align:center; padding:5px 6px; font-size:11px; font-weight:600; border-radius:6px; cursor:pointer; color:var(--text2); transition:all 0.15s; user-select:none; }
.sidebar-toggle-btn.active { background:var(--glass-bg); color:var(--text); box-shadow:0 1px 4px rgba(0,0,0,0.3); }
/* Archive item */
.archive-item { padding:8px 10px; border-radius:6px; font-size:12px; color:var(--text2); border:1px solid transparent; margin-bottom:4px; }
.archive-item-name { font-weight:500; color:var(--text); font-size:13px; margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.archive-item-date { font-size:11px; color:var(--text2); margin-bottom:6px; }
.archive-item-actions { display:flex; gap:5px; }
.archive-empty { padding:16px 10px; font-size:12px; color:var(--text2); text-align:center; line-height:1.6; }
/* Archive viewer modal */
.archive-viewer { background:var(--bg-mid); border:1px solid var(--glass-border); border-radius:16px; width:760px; max-width:96vw; max-height:88vh; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 24px 64px rgba(0,0,0,0.5); animation: modalIn 0.25s ease; }
.archive-viewer-hdr { padding:18px 24px 14px; border-bottom:1px solid var(--glass-border); display:flex; align-items:flex-start; justify-content:space-between; flex-shrink:0; }
.archive-viewer-body { flex:1; overflow-y:auto; padding:20px 24px; display:flex; flex-direction:column; gap:18px; }
.archive-viewer-footer { padding:12px 24px; border-top:1px solid var(--glass-border); display:flex; justify-content:flex-end; gap:8px; flex-shrink:0; }
.av-section { }
.av-section-title { font-size:11px; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:1px; margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.av-section-title::after { content:''; flex:1; height:1px; background:var(--glass-border); }
.av-chip { display:inline-flex; align-items:center; gap:5px; padding:4px 10px; background:var(--surface2); border:1px solid var(--glass-border); border-radius:6px; font-size:12px; color:var(--text); margin:0 5px 5px 0; }
.av-chip .count { font-size:10px; color:var(--text2); background:rgba(255,255,255,0.06); border-radius:10px; padding:1px 6px; }
.av-issue { display:flex; align-items:center; gap:8px; padding:6px 10px; background:var(--surface2); border-radius:6px; margin-bottom:4px; font-size:12px; }
.av-brief { background:var(--surface2); border:1px solid var(--glass-border); border-radius:8px; padding:14px 16px; font-size:13px; line-height:1.7; max-height:220px; overflow-y:auto; }
.av-brief h1,.av-brief h2,.av-brief h3 { color:var(--accent); margin:10px 0 5px; }
.av-brief ul { padding-left:18px; }
.av-brief li { margin-bottom:3px; }
.av-context { background:var(--surface2); border:1px solid var(--glass-border); border-radius:8px; padding:12px 14px; font-size:12px; color:var(--text2); line-height:1.6; white-space:pre-wrap; max-height:100px; overflow-y:auto; }

/* ── Main ── */
main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

/* ── Tabs ── */
.tabs { display: flex; background: var(--glass-bg); border-bottom: 1px solid var(--glass-border); flex-shrink: 0; }
.tab { padding: 8px 14px; font-size: 12px; font-weight: 600; cursor: pointer; color: var(--text2); border-bottom: 2px solid transparent; transition: all 0.15s; white-space: nowrap; user-select: none; }
.tab:hover { color: var(--text); background: var(--surface2); }
.tab.active { color: var(--accent); background: rgba(79,142,247,0.1); border-bottom-color: var(--accent); font-weight: 700; }
.tab-sub { padding: 9px 16px; font-size: 13px; cursor: pointer; color: var(--text2); white-space: nowrap; transition: all 0.15s; }
.tab-sub:hover { background: var(--surface2); color: var(--text); }
.tab-sub.active { color: var(--accent); background: rgba(79,142,247,0.08); font-weight: 500; }

/* ── Content ── */
.content { flex: 1; overflow-y: auto; padding: 20px; }
.panel { display: none; }
.panel.active { display: block; }
#panel-ai-suite.active { display: flex; flex-direction: column; flex: 1; min-height: 0; overflow: hidden; }
#panel-dd.active { display: flex; flex-direction: column; flex: 1; min-height: 0; overflow: hidden; }

/* ── Model toggle pill ── */
/* Model toggle — prototype design (simple two-option pill) */
.model-toggle {
  display:inline-flex; border-radius:14px;
  border:1px solid rgba(79,142,247,0.3);
  background:rgba(79,142,247,0.06);
  padding:2px; cursor:pointer;
}
.model-opt {
  font-family:var(--font-mono); font-size:10px; font-weight:700;
  padding:3px 10px; border-radius:12px;
  color:var(--text3); transition:all 0.2s;
}
.model-opt.active { color:var(--text); background:rgba(79,142,247,0.2); }
/* Old model toggle classes — kept for redline/AI studio pill toggles */
.model-toggle-old { display:inline-flex;align-items:center;border-radius:20px;overflow:hidden;cursor:pointer;user-select:none;flex-shrink:0;position:relative; }
.model-toggle-track { display:flex;border-radius:20px;border:1px solid rgba(79,142,247,0.4);background:rgba(79,142,247,0.08);position:relative;overflow:hidden; }
.model-toggle-opt { padding:3px 10px;font-size:10px;font-weight:700;letter-spacing:0.3px;border-radius:18px;transition:color 0.2s;z-index:1;white-space:nowrap; }
.model-toggle-opt.sonnet { color:rgba(255,255,255,0.4); }
.model-toggle-opt.opus   { color:rgba(255,255,255,0.4); }
.model-toggle-opt.active-s { color:#e2e8f0; }
.model-toggle-opt.active-o { color:var(--accent); }
.model-toggle-pill { position:absolute;top:2px;bottom:2px;border-radius:16px;transition:left 0.2s,width 0.2s;pointer-events:none; }
.model-toggle.light .model-toggle-track { border-color:var(--glass-border);background:var(--surface2); }
.model-toggle.light .model-toggle-opt.sonnet { color:var(--text2); }
.model-toggle.light .model-toggle-opt.opus   { color:var(--text2); }
.model-toggle.light .model-toggle-opt.active-s { color:var(--text); }
.model-toggle.light .model-toggle-opt.active-o { color:var(--accent); }

/* ── Cards ── */
.card { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: 10px; padding: 18px; margin-bottom: 16px; }
.card-title { font-size: 13px; font-weight: 600; color: var(--text2); text-transform: uppercase; letter-spacing: 0.8px; margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }

/* ── Buttons ── */
btn, .btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 7px; font-size: 13px; font-weight: 500; cursor: pointer; border: none; transition: all 0.15s; text-decoration: none; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: #3d7be8; }
.btn-secondary { background: var(--surface2); color: var(--text); border: 1px solid var(--glass-border); }
.btn-secondary:hover { background: var(--glass-hover); }
.btn-success { background: var(--success); color: #fff; }
.btn-success:hover { background: #16a34a; }
.btn-danger { background: var(--danger); color: #fff; }
.btn-sm { padding: 5px 10px; font-size: 12px; }
.btn-icon { width: 32px; height: 32px; padding: 0; border-radius: 6px; justify-content: center; }

/* ── Inputs ── */
input[type=text], input[type=password], textarea, select {
  background: var(--surface2); border: 1px solid var(--glass-border); color: var(--text);
  border-radius: 7px; padding: 8px 12px; font-size: 13px; font-family: inherit;
  transition: border 0.15s, background 0.15s; width: 100%;
}
select option { background: var(--bg-mid); color: var(--text); }
input[type=text]:focus, input[type=password]:focus, textarea:focus, select:focus {
  outline: none; border-color: var(--accent);
}
textarea { resize: vertical; line-height: 1.5; }
textarea.rl-chat-textarea, textarea.rl-cr-textarea { resize: none !important; }
label { font-size: 12px; color: var(--text2); display: block; margin-bottom: 5px; }

/* ── File grid ── */
.file-grid { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.file-grid .session-card.selected { border-color: var(--accent-border); background: rgba(79,142,247,0.06); }
.badge-done { background: rgba(34,197,94,0.15); color: var(--success); }
.badge-none { background: rgba(239,68,68,0.1); color: var(--text2); }

/* ── Progress ── */
.progress-wrap { background: var(--surface2); border-radius: 6px; height: 8px; overflow: hidden; margin: 10px 0; }
.progress-bar { height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent2)); border-radius: 6px; transition: width 0.3s; }
.progress-label { font-size: 12px; color: var(--text2); margin-top: 6px; }

/* ── Transcript ── */
.speaker-map { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 14px; }
.speaker-row { display: flex; align-items: center; gap: 8px; }
.speaker-id { font-size: 11px; color: var(--text2); width: 90px; flex-shrink: 0; font-family: var(--font-mono); }
.transcript-body { background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 8px; padding: 16px; max-height: 500px; overflow-y: auto; font-size: 13px; line-height: 1.7; }
.seg-block { margin-bottom: 16px; }
.seg-header { display: flex; align-items: baseline; gap: 10px; margin-bottom: 4px; }
.seg-time { font-size: 11px; color: var(--text2); font-family: var(--font-mono); flex-shrink: 0; }
.seg-speaker { font-size: 12px; font-weight: 700; }
.seg-text { color: var(--text); padding-left: 4px; }
.s0 { color: #4f8ef7; } .s1 { color: #f59e0b; } .s2 { color: #22c55e; }
.s3 { color: #a78bfa; } .s4 { color: #f472b6; } .s5 { color: #34d399; }

/* ── Analysis ── */
.quick-prompts { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.quick-btn { padding: 5px 12px; border-radius: 20px; font-size: 12px; cursor: pointer; background: var(--surface2); border: 1px solid var(--glass-border); color: var(--text2); transition: all 0.15s; }
.quick-btn:hover { border-color: var(--accent); color: var(--accent); }
.analysis-output { background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 8px; padding: 16px; font-size: 13px; line-height: 1.7; min-height: 100px; white-space: pre-wrap; }
.analysis-output h1, .analysis-output h2, .analysis-output h3 { color: var(--accent); margin: 14px 0 8px; }
.analysis-output strong { color: var(--text); }
.analysis-output ul { padding-left: 20px; }
.analysis-output li { margin-bottom: 4px; }

/* ── Upload ── */
.drop-zone { border: 2px dashed var(--glass-border); border-radius: 10px; padding: 30px; text-align: center; cursor: pointer; transition: all 0.15s; color: var(--text2); }
.drop-zone:hover, .drop-zone.drag { border-color: var(--accent); color: var(--accent); background: rgba(79,142,247,0.05); }
.drop-zone input { display: none; }

/* ── Design System Drop Zone (from prototype) ── */
.wiz-drop { border:2px dashed var(--glass-border); border-radius:12px; padding:28px; text-align:center; cursor:pointer; transition:all 0.2s; color:var(--text3); font-family:var(--font-mono); font-size:11px; letter-spacing:1px; margin-bottom:14px; }
.wiz-drop:hover { border-color:var(--accent-border); color:var(--accent); background:rgba(79,142,247,0.03); }
.wiz-drop svg { margin-bottom:8px; opacity:0.4; }
.wiz-drop input { display:none; }

/* ── Design System Modal (from prototype lines 1057-1117) ── */
.modal-box {
  background:var(--bg-mid);
  border:1px solid var(--glass-border);
  border-radius:16px;
  box-shadow:0 24px 64px rgba(0,0,0,0.5);
  display:flex; flex-direction:column;
  animation:modalIn 0.25s ease;
  max-height:90vh;
}
.modal-header {
  padding:20px 24px 14px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--glass-border);
  flex-shrink:0;
}
.modal-title {
  font-family:var(--font-display);
  font-size:18px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase;
  color:var(--text);
}
.modal-close {
  width:30px; height:30px; border-radius:8px;
  border:1px solid var(--glass-border); background:none;
  color:var(--text3); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; transition:all 0.15s;
}
.modal-close:hover { border-color:rgba(239,68,68,0.3); color:var(--red); background:rgba(239,68,68,0.05); }
.modal-body { flex:1; overflow-y:auto; padding:20px 24px; }
.modal-footer {
  padding:14px 24px;
  border-top:1px solid var(--glass-border);
  display:flex; justify-content:space-between; align-items:center;
  flex-shrink:0;
}
/* Modal buttons */
.m-btn {
  font-family:var(--font-display); font-size:13px; font-weight:600;
  letter-spacing:1px; text-transform:uppercase;
  padding:9px 20px; border-radius:8px;
  cursor:pointer; transition:all 0.2s;
  display:inline-flex; align-items:center; gap:6px;
  border:1px solid var(--glass-border); background:var(--glass-bg); color:var(--text2);
}
.m-btn:hover { border-color:var(--accent-border); color:var(--text); }
.m-btn-primary { background:linear-gradient(135deg, var(--accent), var(--accent2)); border-color:transparent; color:#fff; }
.m-btn-primary:hover { box-shadow:0 4px 16px rgba(79,142,247,0.3); transform:translateY(-1px); }
.m-btn-gold { background:linear-gradient(135deg, #b8860b, var(--gold)); border-color:transparent; color:#fff; }
.m-btn-gold:hover { box-shadow:0 4px 16px rgba(212,168,71,0.3); }
.m-btn-danger { border-color:rgba(239,68,68,0.3); color:var(--red); }
.m-btn-danger:hover { background:rgba(239,68,68,0.08); }

/* Wizard header h3 (wizard.js expects .wizard-header h3) */
.wizard-header h3 { font-family:var(--font-display); font-size:18px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text); margin:0; }

/* ── Settings modal ── */
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.65); z-index: 100; display: none; align-items: center; justify-content: center; backdrop-filter: blur(6px); }
.modal-backdrop.open { display: flex; }
.modal { background: var(--bg-mid); border: 1px solid var(--glass-border); border-radius: 16px; padding: 24px; width: 420px; max-width: 95vw; box-shadow: 0 24px 64px rgba(0,0,0,0.5); animation: modalIn 0.25s ease; }
@keyframes modalIn { from{opacity:0;transform:scale(0.96) translateY(8px)} to{opacity:1;transform:scale(1) translateY(0)} }
.modal h3 { margin-bottom: 16px; font-size: 15px; font-family: var(--font-display); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.form-group { margin-bottom: 14px; }

/* ── Project Wizard (design system) ── */
.wizard { width:680px; max-width:96vw; max-height:95vh; }
.wizard .modal-body { overflow-y:auto; padding:20px 24px; }
.wizard-steps { display:flex; align-items:center; padding:0 24px 20px; }
.wiz-step { display:flex; flex-direction:column; align-items:center; gap:5px; flex-shrink:0; }
.wiz-circle {
  width:32px; height:32px; border-radius:50%;
  border:2px solid var(--glass-border);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:13px; font-weight:700;
  color:var(--text3); transition:all 0.3s;
}
.wiz-step.active .wiz-circle { border-color:var(--accent); background:var(--accent); color:#fff; box-shadow:0 0 12px rgba(79,142,247,0.3); }
.wiz-step.done .wiz-circle { border-color:var(--emerald); background:var(--emerald); color:#fff; }
.wiz-label { font-family:var(--font-mono); font-size:10px; letter-spacing:1px; color:var(--text3); white-space:nowrap; }
.wiz-step.active .wiz-label { color:var(--accent); }
.wiz-step.done .wiz-label { color:var(--emerald); }
.wiz-line { flex:1; height:2px; background:var(--glass-border); margin:0 10px; margin-bottom:18px; }
.wiz-line.done { background:var(--emerald); }
.wiz-pane { display:none; }
.wiz-pane.active { display:block; }
.wiz-section { margin-bottom:18px; }
.wiz-section-title {
  font-family:var(--font-mono); font-size:10px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--text3); margin-bottom:10px;
}
.wiz-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.wiz-field { margin-bottom:0; }
.wiz-label {
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:1px; text-transform:uppercase;
  color:var(--text2); margin-bottom:5px; display:block;
}
.wiz-input {
  width:100%; background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:8px;
  padding:10px 14px; font-family:var(--font-body);
  font-size:13px; color:var(--text); outline:none;
  transition:border-color 0.2s; margin-bottom:14px;
}
.wiz-input::placeholder { color:var(--text3); }
.wiz-input:focus { border-color:var(--accent-border); }
.wiz-select {
  width:100%; background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:8px;
  padding:10px 14px; font-family:var(--font-mono); font-size:12px;
  color:var(--text); outline:none; cursor:pointer;
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center;
  margin-bottom:14px;
}
.wiz-select option { background:var(--bg-mid); color:var(--text); }
.wiz-hint { font-family:var(--font-mono); font-size:10px; color:var(--text3); margin-top:3px; font-style:italic; }
.wiz-textarea {
  width:100%; background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:8px;
  padding:10px 14px; font-family:var(--font-body);
  font-size:13px; color:var(--text); outline:none;
  resize:vertical; transition:border-color 0.2s; line-height:1.6;
}
.wiz-textarea::placeholder { color:var(--text3); }
.wiz-textarea:focus { border-color:var(--accent-border); }
.wiz-quickstart {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:8px;
  background:rgba(79,142,247,0.05); border:1px solid rgba(79,142,247,0.15);
  margin-bottom:18px; cursor:pointer; transition:all 0.15s;
}
.wiz-quickstart:hover { background:rgba(79,142,247,0.08); }
.wiz-quickstart input[type="checkbox"] { width:16px; height:16px; accent-color:var(--accent); cursor:pointer; flex-shrink:0; }
.wiz-qs-title { font-size:13px; font-weight:600; color:var(--accent); }
.wiz-qs-desc { font-size:11px; color:var(--text2); line-height:1.5; }
.wiz-add-btn {
  font-family:var(--font-mono); font-size:9px;
  padding:2px 8px; border-radius:4px;
  border:1px solid var(--glass-border); background:none;
  color:var(--accent); cursor:pointer; transition:all 0.15s;
}
.wiz-add-btn:hover { background:rgba(79,142,247,0.08); border-color:var(--accent-border); }
.wiz-party-list { display:flex; flex-direction:column; gap:8px; }
.wiz-party-row { display:grid; grid-template-columns:140px 1fr; gap:8px; align-items:center; }
.wiz-party-label { font-size:12px; color:var(--text2); white-space:nowrap; }
.wiz-party-row .wiz-input { margin:0; }
.wiz-info-bar {
  display:flex; align-items:center; gap:8px;
  padding:10px 12px; border-radius:8px;
  background:rgba(79,142,247,0.05); border:1px solid rgba(79,142,247,0.15);
  margin-top:18px; font-size:12px; color:var(--accent);
}
.wiz-info-bar svg { flex-shrink:0; color:var(--emerald); }
.wiz-archive {
  display:flex; align-items:center; gap:12px;
  margin-top:18px; padding:14px 16px;
  border:1px solid rgba(239,68,68,0.15); border-radius:10px;
  background:rgba(239,68,68,0.03);
}
.wiz-archive-title { font-size:12px; font-weight:600; color:var(--red); margin-bottom:2px; }
.wiz-ready {
  text-align:center; padding:24px 0;
  display:flex; flex-direction:column; align-items:center; gap:12px;
}
.wiz-ready-title { font-family:var(--font-display); font-size:18px; font-weight:700; color:var(--text); }
.wiz-ready-summary { font-size:13px; color:var(--text2); line-height:1.7; }
.wiz-context-preview {
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:10px; padding:14px 16px; margin-top:16px;
}
.wiz-context-body { font-size:12px; color:var(--text); line-height:1.7; white-space:pre-wrap; margin-top:8px; }
.wiz-progress { font-family:var(--font-mono); font-size:10px; color:var(--text3); letter-spacing:0.5px; }
.subj-check { display:flex; align-items:center; gap:8px; padding:8px 10px; border-radius:6px; background:var(--glass-bg); border:1px solid var(--glass-border); cursor:pointer; margin-bottom:6px; transition:border 0.15s; }
.subj-check:hover { border-color:var(--accent); }
.subj-check input { width:auto; margin:0; cursor:pointer; }
.subj-check span { font-size:13px; color:var(--text); }

/* ── Toast ── */
.toast { position: fixed; bottom: 20px; right: 20px; background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: 8px; padding: 10px 16px; font-size: 13px; z-index: 100000; opacity: 0; transition: opacity 0.2s; pointer-events: none; backdrop-filter: blur(16px); }
.toast.show { opacity: 1; }
.toast.success { border-color: var(--success); }
.toast.error { border-color: var(--danger); }

/* ── Export ── */
.export-options { display: flex; gap: 10px; flex-wrap: wrap; }
.export-file { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 7px; margin-bottom: 6px; }
.export-file .fname { font-size: 13px; }

/* ── Empty state ── */
.empty { text-align: center; padding: 60px 20px; color: var(--text2); }
.empty svg { opacity: 0.3; margin-bottom: 12px; }
.empty p { font-size: 14px; }

/* ── Workspace ── */
.content.workspace-active { padding: 0; overflow: hidden; display: flex; flex-direction: column; }
#panel-workspace { display: none; }
#panel-workspace.active { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.workspace-layout { display: flex; flex: 1; min-height: 0; overflow: hidden; }
.chat-area { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }
.chat-messages { flex: 1; overflow-y: auto; padding: 20px 20px 56px; display: flex; flex-direction: column; gap: 16px; min-height: 0; }
.subjects-panel { width: var(--subjects-w); flex-shrink: 0; border-right: 1px solid var(--glass-border); display: flex; flex-direction: column; background: rgba(10,10,15,0.3); }
.subjects-hdr { padding: 10px 12px 8px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--glass-border); }
.subjects-hdr span { font-size: 11px; font-weight: 600; color: var(--text2); text-transform: uppercase; letter-spacing: 1px; }
.subject-list { flex: 1; overflow-y: auto; padding: 6px; }
.subj-item {
  padding:8px 10px; border-radius:8px;
  cursor:pointer; font-size:13px; color:var(--text2);
  font-family:var(--font-body);
  transition:all 0.15s; border:1px solid transparent;
  display:flex; align-items:center; gap:8px;
  margin-bottom:2px;
}
.subj-item:hover { background:var(--glass-bg); color:var(--text); }
.subj-item.active {
  background:rgba(79,142,247,0.08);
  color:var(--accent); border-color:rgba(79,142,247,0.2);
  font-weight:500;
}
.subj-dot { width:5px; height:5px; border-radius:50%; background:var(--text3); flex-shrink:0; }
.subj-item.active .subj-dot { background:var(--accent); box-shadow:0 0 6px rgba(79,142,247,0.4); }
.subj-del {
  background:none; border:none; color:var(--text3);
  cursor:pointer; font-size:9px; padding:2px 4px;
  opacity:0; transition:all 0.15s; flex-shrink:0;
}
.subj-item:hover .subj-del { opacity:0.6; }
.subj-del:hover { opacity:1; color:var(--red); }
/* Project dropdown (from prototype lines 1363-1394) */
.project-dropdown {
  position:absolute; top:100%; left:0; right:0;
  background:var(--bg-mid); border:1px solid var(--glass-border);
  border-radius:10px; margin-top:4px;
  box-shadow:0 8px 24px var(--shadow-lg, rgba(0,0,0,0.2));
  z-index:200; display:none; overflow:hidden;
  max-height:320px; overflow-y:auto;
}
.project-dropdown.open { display:block; }
.pd-header {
  padding:10px 12px; border-bottom:1px solid var(--glass-border);
  display:flex; align-items:center; justify-content:space-between;
}
.pd-item {
  padding:8px 12px; display:flex; align-items:center; gap:8px;
  cursor:pointer; transition:all 0.12s; font-size:13px; color:var(--text2);
}
.pd-item:hover { background:var(--glass-hover); color:var(--text); }
.pd-item.active { color:var(--accent); background:rgba(79,142,247,0.06); }
.pd-item .pd-dot { width:6px; height:6px; border-radius:50%; background:var(--text3); flex-shrink:0; }
.pd-item.active .pd-dot { background:var(--accent); box-shadow:0 0 4px rgba(79,142,247,0.4); }
.pd-new {
  padding:10px 12px; border-top:1px solid var(--glass-border);
  display:flex; align-items:center; gap:8px;
  cursor:pointer; color:var(--accent); font-size:12px;
  font-family:var(--font-mono); letter-spacing:0.5px; transition:background 0.12s;
}
.pd-new:hover { background:rgba(79,142,247,0.04); }
.subjects-footer { padding: 8px; border-top: 1px solid var(--glass-border); display: flex; flex-direction: column; gap: 5px; }

/* Chat */
.chat-tb-btn { font-family:var(--font-mono);font-size:10px;padding:4px 10px;border-radius:5px;border:1px solid var(--glass-border);background:none;color:var(--text3);cursor:pointer;transition:all 0.15s; }
.chat-tb-btn:hover { border-color:var(--accent-border);color:var(--text2); }
.chat-topbar {
  padding:8px 16px; display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--glass-border); background:rgba(10,10,15,0.3); flex-shrink:0;
}
.chat-font-btn { padding: 2px 7px; font-size: 11px; font-weight: 700; border: 1px solid var(--glass-border); border-radius: 5px; background: var(--surface2); color: var(--text2); cursor: pointer; line-height: 1.4; transition: background 0.12s; }
.chat-font-btn:hover { background: var(--glass-hover); color: var(--text); }
.cr-vresize { display: none; }
.light-theme #rlCrVResizer {
  display: none !important;
}
.light-theme #rlCrResizer {
  width: 0 !important;
  flex-basis: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  cursor: col-resize;
  position: relative;
  z-index: 10;
}
.light-theme #rlCrResizer::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: -3px;
  width: 6px;
  cursor: col-resize;
}
.light-theme #rlCrResizer:hover::before {
  background: var(--accent);
  opacity: 0.3;
}
.cr-vresize:hover, .cr-vresize.dragging { background: var(--accent); }
#rlCrMessages { user-select: text; }
.rl-msg-bubble { user-select: text; }
.rl-msg-del { display:none; position:absolute; top:4px; right:4px; width:20px; height:20px; border-radius:5px; border:none; background:rgba(0,0,0,0.2); color:rgba(255,255,255,0.5); font-size:11px; cursor:pointer; align-items:center; justify-content:center; z-index:10; }
.rl-msg-del:hover { background:rgba(239,68,68,0.3); color:#ef4444; }
.chat-topbar-title {
  font-family:var(--font-display); font-size:16px; font-weight:600;
  color:var(--text); letter-spacing:0.5px;
}
.chat-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--text2); gap: 8px; }
.chat-empty p { font-size: 13px; }

/* Messages — enhanced with design system gradient bubbles */
.msg { display: flex; flex-direction: column; max-width: 91%; animation: msgIn 0.3s ease; }
@keyframes msgIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.msg.user { align-self: flex-end; align-items: flex-end; }
.msg.assistant { align-self: flex-start; align-items: flex-start; }
.msg-bubble {
  padding:12px 16px; border-radius:14px;
  font-size:13px; line-height:1.7;
  font-family:var(--font-body);
}
.msg.user .msg-bubble { background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff; border-bottom-right-radius: 3px; }
.msg.assistant .msg-bubble { background: var(--glass-bg); color: var(--text); border-bottom-left-radius: 3px; border: 1px solid var(--glass-border); }
.msg.assistant .msg-bubble h1, .msg.assistant .msg-bubble h2, .msg.assistant .msg-bubble h3 { color: var(--accent); margin: 10px 0 5px; }
.msg.assistant .msg-bubble strong { color: var(--text); }
.msg.assistant .msg-bubble ul { padding-left: 18px; }
.msg.assistant .msg-bubble li { margin-bottom: 3px; }

/* AI Studio */
.as-node { padding:14px;border-radius:10px;text-align:center;transition:transform 0.15s,box-shadow 0.15s; }
.as-node:hover { transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,0.15); }
.as-node-persona { background:linear-gradient(135deg,rgba(79,142,247,0.12),rgba(79,142,247,0.06));border:1.5px solid rgba(79,142,247,0.4);color:var(--text);min-width:220px; }
.as-node-chat { background:rgba(79,142,247,0.08);border:1px solid rgba(79,142,247,0.3);color:var(--text); }
.as-node-redline { background:rgba(79,142,247,0.08);border:1px solid rgba(79,142,247,0.25);color:var(--text); }
.as-node-risk { background:rgba(239,68,68,0.06);border:1px solid rgba(239,68,68,0.25);color:var(--text); }
.as-node-context { background:rgba(16,185,129,0.07);border:1px solid rgba(16,185,129,0.25);color:var(--text); }
.as-model-badge { display:inline-block;margin-top:6px;font-size:10px;padding:2px 6px;border-radius:8px;font-weight:700; }
.as-output-node { padding:5px 10px;border-radius:6px;font-size:11px;font-weight:600;background:var(--surface2);border:1px solid var(--glass-border);color:var(--text2);text-align:center;white-space:nowrap; }
.as-chat-starter { width:100%;text-align:left;padding:7px 10px;border-radius:7px;border:1px solid var(--glass-border);background:var(--surface2);color:var(--text2);cursor:pointer;font-size:11px;line-height:1.4;transition:background 0.1s; }
.as-chat-starter:hover { background:var(--glass-hover); }
.as-ex-block { margin-bottom:24px;padding:14px;border-radius:10px;border:1px solid var(--glass-border);background:var(--surface2); }
.as-ex-title { font-size:12px;font-weight:700;color:var(--text);margin-bottom:10px; }
.as-ex-row { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px; }
.as-ex-bad { padding:10px;border-radius:7px;background:rgba(239,68,68,0.06);border:1px solid rgba(239,68,68,0.2); }
.as-ex-good { padding:10px;border-radius:7px;background:rgba(16,185,129,0.06);border:1px solid rgba(16,185,129,0.2); }
.as-ex-label { font-size:10px;font-weight:700;letter-spacing:0.5px;margin-bottom:5px; }
.as-ex-bad .as-ex-label { color:#ef4444; }
.as-ex-good .as-ex-label { color:#10b981; }
.as-ex-text { font-size:11px;color:var(--text);line-height:1.5;font-style:italic; }
.rl-qpick { font-family:var(--font-mono);font-size:12px;padding:4px 12px;border-radius:14px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.03);color:var(--text2);cursor:pointer;transition:all 0.15s;letter-spacing:0.5px; }
.rl-qpick:hover { border-color:var(--accent-border);color:var(--accent); }
.rl-qpick.active { border-color:var(--accent);color:var(--accent);background:rgba(79,142,247,0.1);font-weight:700; }
.msg-meta { display:flex; align-items:center; gap:8px; margin-top:4px; }
.msg-time { font-family:var(--font-mono); font-size:10px; color:var(--text3); }
.msg-action-btn {
  font-family:var(--font-mono); font-size:10px;
  padding:2px 7px; border-radius:4px;
  border:1px solid var(--glass-border); background:none;
  color:var(--text3); cursor:pointer; transition:all 0.15s;
}
.msg-action-btn:hover { border-color:var(--accent-border); color:var(--accent); }
.msg-action-btn.read-playing { border-color:rgba(34,197,94,0.3); color:var(--emerald); }
.msg-action-btn.read-paused { border-color:rgba(245,158,11,0.3); color:var(--amber); }
.typing-wrap, .typing { align-self:flex-start; }
.typing-indicator, .typing-dots {
  display:inline-flex; gap:5px;
  padding:14px 18px; background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:14px; border-bottom-left-radius:4px;
}
.typing-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--text3); animation:tdot 1.2s infinite;
}
.typing-dot:nth-child(2) { animation-delay: 0.2s; }
.typing-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes tdot { 0%,80%,100% { transform: scale(0.7); opacity: 0.3; } 40% { transform: scale(1); opacity: 1; } }

/* ── Voice / TTS / STT ── */
.voice-mic-btn { transition: all 0.15s; }
.voice-mic-btn.recording { background: #dc2626 !important; border-color: #dc2626 !important; color: #fff !important; animation: voice-pulse 1s ease-in-out infinite; }
@keyframes voice-pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(220,38,38,0.4); } 50% { box-shadow: 0 0 0 8px rgba(220,38,38,0); } }
.voice-playing { position: relative; }
.voice-playing::after { content: ''; position: absolute; top: -2px; right: -2px; width: 8px; height: 8px; border-radius: 50%; background: #22c55e; animation: voice-dot 0.8s ease-in-out infinite alternate; }
@keyframes voice-dot { from { opacity: 0.4; } to { opacity: 1; } }
.voice-read-btn { padding: 2px 8px; font-size: 11px; cursor: pointer; background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 4px; color: var(--text2); transition: all 0.15s; }
.voice-read-btn:hover { border-color: var(--accent); color: var(--accent); }
.voice-stop-btn { padding: 2px 8px; font-size: 11px; cursor: pointer; background: #dc2626; border: 1px solid #dc2626; border-radius: 4px; color: #fff; }

/* ── Voice Player Bar ── */
.voice-player-bar { display:none; align-items:center; gap:10px; padding:4px 14px; background:var(--surface2); border-top:1px solid var(--glass-border); height:36px; box-sizing:border-box; flex-shrink:0; }
.voice-player-bar.active { display:flex; }
@keyframes voiceBarSlideUp { from { transform:translateY(100%); opacity:0; } to { transform:translateY(0); opacity:1; } }
.voice-player-btn { background:none; border:1px solid var(--glass-border); border-radius:5px; color:var(--text2); cursor:pointer; font-size:13px; width:28px; height:26px; display:flex; align-items:center; justify-content:center; padding:0; transition:all 0.12s; line-height:1; }
.voice-player-btn:hover { border-color:var(--accent); color:var(--accent); background:rgba(79,142,247,0.08); }
.voice-player-btn.vp-stop:hover { border-color:#ef4444; color:#ef4444; background:rgba(239,68,68,0.08); }
.voice-player-counter { font-size:11px; color:var(--text2); font-weight:600; min-width:42px; text-align:center; font-variant-numeric:tabular-nums; }
.voice-player-speed { font-size:10px; color:var(--accent); font-weight:700; min-width:36px; text-align:center; cursor:default; }
.voice-player-sep { width:1px; height:18px; background:var(--glass-border); flex-shrink:0; }
.voice-timeline { flex:1; height:6px; background:rgba(255,255,255,0.2); border-radius:3px; cursor:pointer; position:relative; min-width:60px; margin:0 6px; }
.voice-timeline-fill { height:100%; background:var(--accent); border-radius:3px; width:0%; transition:width 0.2s; }
.voice-timeline-dot { position:absolute; top:50%; width:12px; height:12px; background:var(--accent); border:2px solid var(--glass-bg); border-radius:50%; transform:translate(-50%,-50%); left:0%; transition:left 0.2s; box-shadow:0 0 4px rgba(79,142,247,0.5); }
.voice-timeline:hover .voice-timeline-dot { width:14px; height:14px; box-shadow:0 0 8px rgba(79,142,247,0.7); }
/* Voice highlight overlays are positioned absolutely via JS — no DOM mutation */
.voice-radio { display:flex;align-items:center;gap:6px;padding:3px 8px;border-radius:6px;cursor:pointer;font-size:11px;color:var(--text2);transition:background 0.12s; }
.voice-radio:hover { background:var(--surface2); }
.voice-radio.selected { background:rgba(79,142,247,0.15);color:var(--accent);font-weight:600; }
.voice-radio input { width:auto;margin:0; }

/* Toggle switch */
#voiceMasterToggle:checked + span { background: #22c55e; }
#voiceMasterToggle:checked + span + span { transform: translateX(20px); }
.chat-resize-handle { display:none; }
.chat-resize-handle:hover,.chat-resize-handle.dragging { background:var(--surface2); border-top-color:var(--accent); }
.chat-resize-grip { display:flex; flex-direction:column; gap:4px; pointer-events:none; }
.chat-resize-grip i { display:block; width:44px; height:2px; background:var(--text2); border-radius:2px; opacity:0.35; transition:opacity 0.12s; }
.chat-resize-handle:hover .chat-resize-grip i,.chat-resize-handle.dragging .chat-resize-grip i { opacity:0.85; background:var(--accent); }
/* Chat input — EXACT COPY from prototype lines 597-642 */
.chat-input-area {
  padding:10px 16px 12px;
  border-top:1px solid var(--glass-border);
  background:rgba(10,10,15,0.3);
  flex-shrink:0;
  position:relative;
}
.chat-input-row {
  display:flex; align-items:flex-end; gap:8px;
}
.mic-btn {
  width:40px; height:40px; border-radius:10px;
  border:1px solid var(--glass-border); background:var(--glass-bg);
  color:var(--text3); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all 0.2s; flex-shrink:0;
}
.mic-btn:hover { border-color:var(--accent-border); color:var(--accent); }
.mic-btn.recording {
  background:#dc2626; border-color:#dc2626; color:#fff;
  animation:micPulse 1s ease-in-out infinite;
}
@keyframes micPulse { 0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,0.4);} 50%{box-shadow:0 0 0 8px rgba(220,38,38,0);} }
.mic-btn svg { width:16px; height:16px; }

.chat-textarea {
  flex:1; background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:10px;
  padding:10px 14px; font-family:var(--font-body);
  font-size:13px; color:var(--text); resize:none;
  outline:none; min-height:40px; max-height:120px;
  transition:border-color 0.2s;
  line-height:1.5; box-sizing:border-box;
}
.chat-textarea::placeholder { color:var(--text3); }
.chat-textarea:focus { border-color:var(--accent-border); }

.send-btn {
  width:40px; height:40px; border-radius:10px;
  border:none; background:linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all 0.2s; flex-shrink:0;
}
.send-btn:hover { transform:scale(1.05); box-shadow:0 4px 16px rgba(79,142,247,0.3); }
.send-btn:active { transform:scale(0.95); }
.send-btn svg { width:16px; height:16px; }
/* Context Ribbon — shown above each AI bubble so the user sees what context the model actually got */
.ws-ctx-ribbon {
  margin: 6px 0 8px 0; padding: 6px 10px;
  border-radius: 8px;
  background: rgba(79,142,247,0.05);
  border: 1px solid rgba(79,142,247,0.18);
  font-size: 11px; line-height: 1.4;
}
.ws-ctx-chips { display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.ws-ctx-label { color: var(--text2); font-weight: 600; margin-right: 4px; }
.ws-ctx-chip {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 7px; border-radius: 10px;
  background: rgba(79,142,247,0.12);
  color: #4f8ef7;
  border: 1px solid rgba(79,142,247,0.25);
  font-size: 10.5px; white-space: nowrap;
  max-width: 280px; overflow: hidden; text-overflow: ellipsis;
}
.ws-ctx-warns { margin-top: 4px; }
.ws-ctx-warn {
  color: #d97706; padding: 2px 0; font-size: 10.5px;
  border-top: 1px dashed rgba(217,119,6,0.3); padding-top: 4px; margin-top: 4px;
}
.ws-ctx-warn:first-child { border-top: none; padding-top: 0; margin-top: 0; }

/* Report-modify scope pill above chat input */
.report-scope-pill {
  display: flex; align-items: center; gap: 8px;
  margin: 0 8px 6px 8px;
  padding: 6px 10px;
  border: 1px solid var(--accent);
  border-radius: 999px;
  background: rgba(var(--accent-rgb, 0, 200, 255), 0.08);
  color: var(--accent);
  font-family: 'Share Tech Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.04em;
}
.report-scope-pill-label { opacity: 0.75; text-transform: uppercase; }
.report-scope-pill-name {
  font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 280px;
  color: var(--text);
}
.report-scope-pill-x {
  margin-left: auto;
  background: transparent; border: none;
  color: var(--accent); cursor: pointer;
  font-size: 16px; line-height: 1;
  padding: 0 4px;
  opacity: 0.7;
}
.report-scope-pill-x:hover { opacity: 1; }

/* Docs pane sub-toggle: Source Docs / Reports */
.ws-docs-subtoggle {
  display: flex; gap: 0;
  padding: 6px 8px 0 8px;
  border-bottom: 1px solid var(--glass-border);
  flex-shrink: 0;
}
.ws-docs-subtab {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text2);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.4px;
  padding: 6px 10px 7px 10px;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
}
.ws-docs-subtab:hover { color: var(--text); }
.ws-docs-subtab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.ws-docs-subcount {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 16px; height: 14px; padding: 0 4px;
  border-radius: 7px;
  background: rgba(79,142,247,0.18);
  color: var(--accent);
  font-size: 9.5px; font-weight: 600;
}
.ws-docs-subcount:empty { display: none; }
.ws-docs-subpane { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.ws-docs-subpane.hidden { display: none; }

/* AI Report cards */
.ws-report-card {
  display: flex; flex-direction: column; gap: 4px;
  padding: 8px 10px;
  margin: 4px 0;
  border: 1px solid var(--glass-border);
  border-radius: 6px;
  background: var(--glass-bg);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.ws-report-card:hover { border-color: rgba(79,142,247,0.4); background: rgba(79,142,247,0.04); }
.ws-report-card.missing { opacity: 0.55; }
.ws-report-head { display: flex; align-items: center; gap: 6px; }
.ws-report-icon { color: #4f8ef7; flex-shrink: 0; }
.ws-report-name {
  flex: 1; font-size: 12px; font-weight: 600; color: var(--text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ws-report-version {
  font-family: var(--font-mono); font-size: 9.5px;
  color: var(--accent);
  background: rgba(79,142,247,0.12);
  padding: 1px 6px; border-radius: 8px;
  flex-shrink: 0;
}
.ws-report-meta {
  display: flex; gap: 8px; font-size: 10px; color: var(--text3);
  font-family: var(--font-mono);
}
.ws-report-actions {
  display: flex; gap: 4px; margin-top: 4px;
  opacity: 0; transition: opacity 0.15s;
}
.ws-report-card:hover .ws-report-actions { opacity: 1; }
.ws-report-btn {
  flex: 1;
  background: transparent;
  border: 1px solid var(--glass-border);
  border-radius: 4px;
  color: var(--text2);
  font-size: 10px;
  padding: 3px 6px;
  cursor: pointer;
  transition: all 0.15s;
}
.ws-report-btn:hover { border-color: var(--accent); color: var(--accent); }
.ws-report-btn.danger:hover { border-color: #d97706; color: #d97706; }
.ws-report-missing-tag {
  font-size: 9.5px; color: #d97706;
  padding: 1px 6px; border-radius: 8px;
  background: rgba(217,119,6,0.12);
  border: 1px solid rgba(217,119,6,0.3);
  flex-shrink: 0;
}

/* Context bar */
.ctx-bar { display:flex; align-items:center; gap:8px; margin-top:10px; position:relative; }
.ctx-btn {
  font-family:var(--font-mono); font-size:11px;
  padding:3px 10px; border-radius:5px;
  border:1px solid rgba(79,142,247,0.25);
  background:rgba(79,142,247,0.04);
  color:var(--accent); cursor:pointer;
  transition:all 0.15s; display:flex; align-items:center; gap:5px;
}
.ctx-btn:hover { background:rgba(79,142,247,0.08); }
.ctx-btn.open { background:rgba(79,142,247,0.1); border-color:rgba(79,142,247,0.4); }
.ctx-dot { width:5px; height:5px; border-radius:50%; background:var(--emerald); box-shadow:0 0 4px var(--emerald); }
.ctx-info { font-family:var(--font-mono); font-size:10px; color:var(--text3); letter-spacing:0.5px; }
.ctx-stat-value { color:var(--accent); font-weight:700; }

/* Context picker panel (from prototype lines 644-787) */
.ctx-picker {
  display:none; position:absolute; bottom:100%; left:0; right:0;
  margin-bottom:8px;
  background:var(--bg-mid);
  border:1px solid rgba(79,142,247,0.2);
  border-radius:12px;
  box-shadow:0 8px 32px rgba(0,0,0,0.5);
  max-height:55vh; overflow-y:auto;
  z-index:50;
  animation:ctxPickerIn 0.2s ease;
}
.ctx-picker.open { display:block; }
@keyframes ctxPickerIn { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
.ctx-picker-header {
  padding:10px 14px;
  display:flex; align-items:center; gap:8px;
  border-bottom:1px solid rgba(79,142,247,0.1);
  background:rgba(79,142,247,0.03);
  flex-shrink:0; position:sticky; top:0; z-index:2;
}
.ctx-picker-title {
  font-family:var(--font-mono); font-size:12px;
  font-weight:700; color:var(--accent); letter-spacing:0.5px; flex:1;
}
/* Context picker sections + items (from prototype lines 467-513) */
.ctx-section { border-bottom:1px solid var(--glass-border); }
.ctx-section:last-child { border-bottom:none; }
.ctx-section-header {
  padding:8px 14px;
  display:flex; align-items:center; gap:8px;
  cursor:pointer; transition:background 0.12s;
}
.ctx-section-header:hover { background:rgba(255,255,255,0.02); }
.ctx-section-label {
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--text3); flex:1;
}
.ctx-section-count { font-family:var(--font-mono); font-size:10px; color:var(--text3); }
.ctx-section-toggle {
  font-family:var(--font-mono); font-size:10px;
  padding:2px 6px; border-radius:4px;
  border:1px solid var(--glass-border); background:none;
  color:var(--text3); cursor:pointer; transition:all 0.12s;
}
.ctx-section-toggle:hover { border-color:rgba(79,142,247,0.3); color:var(--accent); }
.ctx-items { padding:0 8px 8px; }
.ctx-item {
  display:flex; align-items:center; gap:8px;
  padding:6px 8px; border-radius:6px;
  transition:background 0.12s; cursor:pointer;
}
.ctx-item:hover { background:rgba(255,255,255,0.02); }
.ctx-item input[type="checkbox"] {
  accent-color:var(--accent); flex-shrink:0;
  width:14px; height:14px; cursor:pointer;
}
.ctx-item-icon { font-size:13px; flex-shrink:0; width:16px; text-align:center; }
.ctx-item-name {
  font-size:13px; color:var(--text); flex:1;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.ctx-item-size { font-family:var(--font-mono); font-size:11px; color:var(--text3); flex-shrink:0; }
.ctx-item-tokens { font-family:var(--font-mono); font-size:11px; color:rgba(79,142,247,0.6); flex-shrink:0; }

/* ── Context Picker Tree View ────────────────────────────────────────────── */
.ctx-tree-folder { margin-bottom:2px; }
.ctx-tree-folder-hdr {
  display:flex; align-items:center; gap:6px;
  padding:6px 8px; border-radius:6px;
  cursor:pointer; transition:background 0.12s;
  user-select:none;
}
.ctx-tree-folder-hdr:hover { background:rgba(79,142,247,0.06); }
.ctx-tree-chevron {
  font-size:10px; color:var(--text3); width:10px; text-align:center; flex-shrink:0;
  transition:transform 0.15s;
}
.ctx-tree-folder-icon { font-size:13px; flex-shrink:0; }
.ctx-tree-folder-label {
  font-family:var(--font-mono); font-size:11px; font-weight:700;
  letter-spacing:0.5px; color:var(--text2); flex:1;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.ctx-tree-folder-meta {
  font-family:var(--font-mono); font-size:10px; color:var(--text3); flex-shrink:0;
}
.ctx-tree-folder-body { padding-left:8px; }
.ctx-tree-doc { margin-bottom:1px; }
.ctx-tree-doc-row {
  display:flex; align-items:center; gap:7px;
  padding:5px 8px; border-radius:6px;
  cursor:pointer; transition:background 0.12s;
  min-width:0;
}
.ctx-tree-doc-row:hover { background:rgba(79,142,247,0.06); }
.ctx-tree-doc-name {
  font-size:12px; font-weight:600; color:var(--text); flex:1;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.ctx-tree-doc-tokens {
  font-family:var(--font-mono); font-size:10px; color:rgba(79,142,247,0.6); flex-shrink:0;
}
.ctx-tree-children { padding-left:20px; }
.ctx-tree-child-row {
  display:flex; align-items:center; gap:6px;
  padding:3px 6px; border-radius:5px;
  cursor:pointer; transition:background 0.12s;
  min-width:0;
}
.ctx-tree-child-row:hover { background:rgba(245,158,11,0.06); }
.ctx-tree-branch {
  font-family:var(--font-mono); font-size:11px; color:var(--text3);
  flex-shrink:0; width:12px; text-align:center; opacity:0.4;
}
.ctx-tree-child-name {
  font-size:11px; color:var(--text2); flex:1;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.ctx-tree-child-tokens {
  font-family:var(--font-mono); font-size:10px; color:rgba(245,158,11,0.5); flex-shrink:0;
}

/* Stats bar */
.ctx-stats {
  padding:8px 14px; display:flex; align-items:center; gap:12px;
  border-bottom:1px solid var(--glass-border); flex-wrap:wrap;
}
.ctx-stat-item { font-family:var(--font-mono); font-size:11px; color:var(--text3); display:flex; align-items:center; gap:4px; }
.ctx-progress-bar { flex:1; min-width:80px; height:4px; background:rgba(255,255,255,0.04); border-radius:2px; overflow:hidden; }
.ctx-progress-fill { height:100%; border-radius:2px; background:linear-gradient(90deg, var(--accent), var(--accent)); transition:width 0.3s; }
/* Presets */
.ctx-presets { padding:8px 14px; display:flex; gap:6px; border-bottom:1px solid var(--glass-border); }
.ctx-preset {
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.5px;
  padding:4px 10px; border-radius:10px;
  border:1px solid var(--glass-border); background:none;
  color:var(--text3); cursor:pointer; transition:all 0.15s;
}
.ctx-preset:hover { border-color:rgba(79,142,247,0.3); color:var(--text2); }
.ctx-preset.active { border-color:var(--accent); color:var(--accent); background:rgba(79,142,247,0.06); }
/* Voice bar — design system (from prototype lines 792-822) */
.voice-bar {
  display:none; align-items:center; gap:10px;
  padding:6px 16px; border-bottom:1px solid var(--glass-border);
  background:rgba(10,10,15,0.7); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  flex-shrink:0; border-radius:8px 8px 0 0;
}
.voice-bar.active { display:flex; }
.vb-btn {
  width:26px; height:26px; border-radius:5px;
  border:1px solid rgba(255,255,255,0.15); background:rgba(255,255,255,0.08);
  color:var(--text); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all 0.15s; flex-shrink:0;
}
.vb-btn:hover { border-color:var(--accent-border); color:var(--accent); }
.vb-btn.stop:hover { border-color:rgba(239,68,68,0.3); color:var(--red); }
.vb-btn svg { width:14px; height:14px; }
.vb-time { font-family:var(--font-mono); font-size:11px; color:var(--text); min-width:36px; text-align:center; }
.vb-timeline {
  flex:1; height:4px; background:rgba(255,255,255,0.2);
  border-radius:2px; cursor:pointer; position:relative;
}
.vb-fill { height:100%; background:var(--accent); border-radius:2px; width:0%; transition:width 0.2s; }
.vb-dot {
  position:absolute; top:50%; left:0%;
  width:10px; height:10px; background:var(--accent);
  border:2px solid var(--bg-mid); border-radius:50%;
  transform:translate(-50%,-50%);
  box-shadow:0 0 6px rgba(79,142,247,0.4);
}
.vb-speed { font-family:var(--font-mono); font-size:9px; color:var(--accent); font-weight:700; }
.vb-sep { width:1px; height:16px; background:var(--glass-border); }
body.theme-ivory .voice-bar { background:rgba(206,201,194,0.7); backdrop-filter:blur(12px); }
/* Theme overrides for chat input — handled in main .light-theme block */
body.theme-warm .send-btn { background:linear-gradient(135deg, #b8860b, #d4a847); }
body.theme-ocean .send-btn { background:linear-gradient(135deg, #2c7a7b, #38b2ac); }
.chat-quick { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 8px; flex-shrink:0; }
.cq-btn { padding: 4px 10px; border-radius: 14px; font-size: 11px; cursor: pointer; background: var(--surface2); border: 1px solid var(--glass-border); color: var(--text2); transition: all 0.15s; white-space: nowrap; }
.cq-btn:hover { border-color: var(--accent); color: var(--accent); }
.cq-email { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; }
.cq-email:hover { background: #3a7de0; border-color: #3a7de0; color: #fff; }
.chat-row { display: flex; gap: 8px; align-items: flex-end; flex: 1; min-height: 0; }
.chat-row textarea { flex: 1; align-self: stretch; min-height: 60px; resize: none; }

/* Doc panel — pushes chat area, never overlays */
.doc-panel { width: 0; overflow: hidden; flex-shrink: 0; display: flex; transition: width 0.25s ease; position: relative; }
.doc-panel.open { width: 320px; border-left: 1px solid var(--glass-border); overflow: visible; }
.doc-panel-inner { width: 320px; flex-shrink: 0; display: flex; flex-direction: column; background: rgba(10,10,15,0.5); height: 100%; }
.doc-panel-hdr { padding: 10px 14px; border-bottom: 1px solid var(--glass-border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
.doc-panel-hdr span { font-family: var(--font-mono); font-size: 10px; font-weight: 600; color: var(--text2); text-transform: uppercase; letter-spacing: 2px; }
.doc-list { flex: 1; overflow-y: auto; padding: 10px; }
/* Document category headers */
.doc-cat-header {
  display:flex; align-items:center; gap:6px;
  padding:6px 10px; cursor:pointer; user-select:none;
  border-bottom:1px solid var(--glass-border); margin-bottom:4px;
}
.doc-cat-header:hover { background:rgba(255,255,255,0.03); }
.doc-cat-chevron { font-size:8px; color:var(--text3); width:10px; flex-shrink:0; }
.doc-cat-name { font-family:var(--font-mono); font-size:9px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text3); }
.doc-cat-count { font-family:var(--font-mono); font-size:9px; color:var(--text3); margin-left:auto; opacity:0.6; }
.light-theme .doc-cat-header:hover { background:rgba(0,0,0,0.03); }

/* Compare source docs */
.doc-expand-btn { background:none; border:none; color:var(--text3); cursor:pointer; padding:2px; flex-shrink:0; transition:color 0.15s; }
.doc-expand-btn:hover { color:var(--accent); }
.doc-compare-sources { padding-left:20px; }
.doc-compare-src-item {
  display:flex; align-items:center; gap:6px; padding:4px 10px;
  border-radius:6px; cursor:pointer; font-size:11px; color:var(--text2);
  transition:background 0.15s; border-left:2px solid var(--glass-border); margin-left:8px; margin-bottom:2px;
}
.doc-compare-src-item:hover { background:rgba(255,255,255,0.04); color:var(--text); }
.doc-compare-src-label { font-family:var(--font-mono); font-size:10px; letter-spacing:0.5px; text-transform:uppercase; color:var(--text3); flex-shrink:0; min-width:44px; }
.doc-compare-src-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.light-theme .doc-compare-src-item:hover { background:rgba(0,0,0,0.04); }

.doc-item {
  display:flex; align-items:center; gap:8px;
  padding:8px 10px; border-radius:8px;
  margin-bottom:4px; cursor:pointer; transition:all 0.15s;
}
.doc-item:hover { background:var(--glass-bg); }
.doc-icon {
  width:28px; height:28px; border-radius:6px;
  background:rgba(79,142,247,0.08); border:1px solid rgba(79,142,247,0.15);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.doc-icon svg { width:14px; height:14px; color:var(--accent); }
.doc-info { flex:1; min-width:0; }
.doc-name { font-size:12px; font-weight:500; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.doc-meta { font-family:var(--font-mono); font-size:9px; color:var(--text3); margin-top:1px; }
.doc-item.has-session { border-left:2px solid var(--accent); padding-left:8px; }
.doc-lbl { padding:2px 6px; border-radius:4px; font-size:10px; font-weight:700; background:rgba(79,142,247,0.15); color:var(--accent); flex-shrink:0; font-family:var(--font-mono); }
.doc-del {
  background:none; border:none; color:var(--text3);
  cursor:pointer; opacity:0; font-size:11px;
  padding:2px; flex-shrink:0; transition:all 0.15s;
}
.doc-item:hover .doc-del { opacity:1; }
.doc-del:hover { color:var(--red); }
.doc-panel-footer { padding:10px; border-top:1px solid var(--glass-border); }

/* Right panel — pane structure (from prototype) */
/* Right panel content + pane structure — EXACT COPY from prototype */
.ctx-content { flex:1; overflow:hidden; padding:10px; display:flex; flex-direction:column; }
.ctx-pane { display:none; }
.ctx-pane-scroll { flex:1; overflow-y:auto; }
.ctx-add-bar {
  flex-shrink:0;
  border-top:1px solid var(--glass-border);
  padding:6px 0 0;
}
.ctx-add-toggle {
  width:100%; padding:6px 0; border:none; background:none;
  color:var(--accent); cursor:pointer;
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.5px;
  display:flex; align-items:center; justify-content:center; gap:5px;
  transition:all 0.15s; border-radius:6px;
}
.ctx-add-toggle:hover { background:rgba(79,142,247,0.06); }
.ctx-add-panel {
  display:none; flex-direction:column; gap:6px;
  padding:8px 0 2px;
  animation:ctxPanelIn 0.15s ease;
}
.ctx-add-panel.open { display:flex; }
@keyframes ctxPanelIn { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:translateY(0)} }
.ctx-add-input {
  width:100%; background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:6px;
  padding:7px 10px; font-family:var(--font-body);
  font-size:11px; color:var(--text); outline:none;
  transition:border-color 0.2s; box-sizing:border-box;
}
.ctx-add-input::placeholder { color:var(--text3); }
.ctx-add-input:focus { border-color:var(--accent-border); }
.ctx-add-select {
  background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:6px;
  padding:6px 8px; font-family:var(--font-mono);
  font-size:10px; color:var(--text2); outline:none;
  cursor:pointer; box-sizing:border-box;
}
.ctx-add-submit {
  flex:1; padding:6px 0; border:none; border-radius:6px;
  background:linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff; font-family:var(--font-mono); font-size:10px;
  font-weight:700; letter-spacing:0.5px; cursor:pointer;
  transition:all 0.15s;
}
.ctx-add-submit:hover { box-shadow:0 2px 10px rgba(79,142,247,0.3); }
.ctx-add-cancel {
  flex:1; padding:6px 0; border:1px solid var(--glass-border); border-radius:6px;
  background:none; color:var(--text3); font-family:var(--font-mono);
  font-size:10px; cursor:pointer; transition:all 0.15s;
}
.ctx-add-cancel:hover { border-color:var(--accent-border); color:var(--text2); }
/* Summary display area */
.ctx-summary {
  margin:0 10px; padding:8px 10px; border-radius:6px;
  background:var(--glass-bg); border:1px solid var(--glass-border);
  font-family:var(--font-mono); font-size:11px;
  color:var(--text2); line-height:1.5;
  white-space:pre-wrap; max-height:200px; overflow-y:auto;
}

/* Issue items (from prototype lines 897-908) */
.issue-item {
  padding:10px 12px; border-radius:8px;
  background:var(--glass-bg); border:1px solid var(--glass-border);
  margin-bottom:6px;
}
.issue-header { display:flex; align-items:center; gap:8px; }
.issue-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.issue-dot.open { background:var(--red); box-shadow:0 0 4px rgba(239,68,68,0.4); }
.issue-dot.progress { background:var(--amber); box-shadow:0 0 4px rgba(245,158,11,0.4); }
.issue-dot.resolved { background:var(--emerald); box-shadow:0 0 4px rgba(34,197,94,0.4); }
.issue-title { font-size:12px; font-weight:500; color:var(--text); flex:1; }
.issue-owner { font-family:var(--font-mono); font-size:9px; color:var(--text3); margin-top:4px; }

/* Note items (from prototype lines 911-929) */
.note-item {
  padding:10px 12px; border-radius:8px;
  background:var(--glass-bg); border:1px solid var(--glass-border);
  margin-bottom:6px;
}
.note-type {
  font-family:var(--font-mono); font-size:9px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; margin-bottom:4px;
}
.note-type.action { color:var(--accent); }
.note-type.flag { color:var(--amber); }
.note-type.general { color:var(--text3); }
.note-text { font-size:12px; color:var(--text2); line-height:1.5; }
.note-status {
  font-family:var(--font-mono); font-size:9px;
  color:var(--text3); margin-top:4px;
  display:flex; align-items:center; gap:4px;
}

/* Transcript items (from prototype) */
.transcript-item {
  padding:8px 10px; border-radius:8px;
  margin-bottom:4px; cursor:pointer; transition:all 0.15s;
}
.transcript-item:hover { background:var(--glass-bg); }
.transcript-header { display:flex; align-items:center; gap:8px; }
.transcript-header svg { color:var(--accent); flex-shrink:0; opacity:0.6; }
.transcript-name { font-size:12px; font-weight:500; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.transcript-meta { font-family:var(--font-mono); font-size:10px; color:var(--text3); margin-top:2px; margin-left:22px; }

/* Checklist groups + items (from prototype lines 1002-1060) */
.cl-group {
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:8px; margin-bottom:8px; overflow:hidden;
}
.cl-group-header {
  padding:10px 12px; display:flex; align-items:center; gap:8px;
  cursor:pointer; transition:background 0.12s;
}
.cl-group-header:hover { background:rgba(255,255,255,0.02); }
.cl-group-name { font-size:12px; font-weight:600; color:var(--text); flex:1; }
.cl-group-count { font-family:var(--font-mono); font-size:9px; color:var(--text3); }
.cl-progress { width:40px; height:3px; background:rgba(255,255,255,0.06); border-radius:2px; overflow:hidden; }
.cl-progress-fill { height:100%; background:var(--emerald); border-radius:2px; transition:width 0.3s; }
.cl-group-chevron { font-size:10px; color:var(--text3); transition:transform 0.2s; }
.cl-group.collapsed .cl-group-chevron { transform:rotate(-90deg); }
.cl-group.collapsed .cl-group-items { display:none; }
.cl-group-items { border-top:1px solid var(--glass-border); padding:6px 10px; }
.cl-item {
  display:flex; align-items:flex-start; gap:8px;
  padding:6px 0; border-bottom:1px solid var(--glass-border);
}
.cl-item:last-of-type { border-bottom:none; }
.cl-status {
  font-family:var(--font-mono); font-size:10px;
  padding:2px 4px; border:1px solid var(--glass-border);
  border-radius:4px; background:var(--glass-bg);
  color:var(--text3); width:95px; cursor:pointer; flex-shrink:0;
}
.cl-status.completed { color:var(--emerald); }
.cl-status.in_progress { color:var(--amber); }
.cl-status.pending { color:var(--text3); }
.cl-status.waived { color:var(--text3); font-style:italic; }
.cl-status option { background:var(--bg-mid); color:var(--text); }
.cl-text { flex:1; font-size:12px; color:var(--text); line-height:1.4; word-break:break-word; min-width:0; }
.cl-meta { font-family:var(--font-mono); font-size:10px; color:var(--text3); }
.cl-del {
  background:none; border:none; color:var(--text3);
  cursor:pointer; font-size:10px; opacity:0; transition:all 0.15s;
}
.cl-item:hover .cl-del { opacity:1; }
.cl-del:hover { color:var(--red); }
.cl-add-row {
  display:flex; gap:6px; padding:6px 0; align-items:center;
}
.ctx-add-btn {
  width:24px; height:24px; border-radius:6px;
  border:1px solid var(--glass-border); background:none;
  color:var(--accent); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all 0.15s;
}
.ctx-add-btn:hover { background:rgba(79,142,247,0.08); border-color:var(--accent-border); }

/* Email draft modal */
.email-approach-btn { padding:6px 10px;border-radius:7px;border:1px solid var(--glass-border);background:var(--surface2);color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;text-align:left;transition:all 0.15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px; }
.email-approach-btn:hover { border-color:var(--accent);color:var(--accent); }
.email-approach-btn.active { border-color:var(--accent);background:rgba(79,142,247,0.15);color:var(--accent);font-weight:700; }
.email-tone-btn { padding:5px 12px;border-radius:6px;border:1px solid var(--glass-border);background:var(--surface2);color:var(--text2);font-size:12px;cursor:pointer;white-space:nowrap; }
.email-tone-btn.active { border-color:var(--accent);background:rgba(79,142,247,0.12);color:var(--accent);font-weight:600; }
.edm-tab { padding:5px 14px;border-radius:6px;border:none;background:transparent;color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;transition:all 0.15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px; }
.edm-tab.active { background:var(--glass-bg);color:var(--text);font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,0.25); }

/* EML drag-over */
.eml-dragover { outline: 2px dashed var(--accent); outline-offset: -4px; background: rgba(79,142,247,0.05); }
.rl-wf2-drop-over { border-color: var(--accent) !important; background: rgba(79,142,247,0.08) !important; }

/* Suggested issues */
.suggest-item { background:var(--surface2); border:1px solid rgba(79,142,247,0.2); border-radius:8px; padding:10px 12px; margin-bottom:8px; }
.suggest-item-title { font-size:13px; font-weight:600; color:var(--text); margin-bottom:4px; }
.suggest-item-reason { font-size:11px; color:var(--text2); line-height:1.5; margin-bottom:8px; }
.suggest-item-actions { display:flex; gap:6px; }
.priority-high { border-color:rgba(239,68,68,0.4); }
.priority-medium { border-color:rgba(245,158,11,0.3); }
.priority-low { border-color:rgba(79,142,247,0.2); }
.priority-tag { font-size:10px; font-weight:700; padding:1px 6px; border-radius:10px; margin-left:6px; }
.priority-tag.high { background:rgba(239,68,68,0.15); color:var(--danger); }
.priority-tag.medium { background:rgba(245,158,11,0.15); color:var(--warning); }
.priority-tag.low { background:rgba(79,142,247,0.1); color:var(--accent); }

/* transcript panel doc items */
.doc-item.transcript-item { cursor: default; }
.doc-item .view-transcript-btn { background: none; border: 1px solid var(--glass-border); color: var(--accent); cursor: pointer; border-radius: 4px; font-size: 11px; padding: 2px 7px; flex-shrink: 0; white-space: nowrap; }
.doc-item .view-transcript-btn:hover { background: rgba(79,142,247,0.1); }

/* AI Tool buttons — elevated styling */
.ai-tool-btn { font-family:var(--font-mono);font-size:10px;letter-spacing:0.5px; background:rgba(79,142,247,0.15); border:1px solid rgba(79,142,247,0.35); color:var(--accent); border-radius:14px;padding:4px 12px; position:relative; cursor:pointer;transition:all 0.15s;white-space:nowrap; }
.ai-tool-btn:hover { background:rgba(79,142,247,0.25); border-color:rgba(79,142,247,0.5); color:#fff; }
.ai-tool-btn > span { display:none; }
/* Tooltip popup on hover */
.ai-tool-tip-float { position:fixed; width:220px; padding:8px 10px; background:var(--bg-mid); border:1px solid rgba(79,142,247,0.3); border-radius:8px; box-shadow:0 8px 24px rgba(0,0,0,0.5); z-index:99999; pointer-events:none; opacity:0; transition:opacity 0.2s; font-family:var(--font-mono); font-size:10px; color:var(--text2); line-height:1.5; }
.ai-tool-tip-float.visible { opacity:1; }
.ai-tool-btn .ai-tool-tip { display:none; }
.lib-badge { padding: 2px 6px; border-radius: 4px; font-size: 10px; font-weight: 700; background: rgba(34,197,94,0.15); color: var(--success); flex-shrink: 0; }

/* ── Misc ── */
.row { display: flex; gap: 10px; align-items: center; }
.flex-1 { flex: 1; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.sep { height: 1px; background: var(--glass-border); margin: 16px 0; }
.spinner { width: 16px; height: 16px; border: 2px solid var(--glass-border); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.spinner-dots::after { content:'...'; animation: dotPulse 1.2s infinite; }
@keyframes dotPulse { 0% { content:'.'; } 33% { content:'..'; } 66% { content:'...'; } }
@keyframes recPulse { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:0.3; transform:scale(0.8); } }

/* AI Tool Running Banner */
.rl-tool-banner-pulse { animation: toolBannerPulse 2s ease-in-out infinite; }
@keyframes toolBannerPulse { 0%,100% { opacity:1; } 50% { opacity:0.75; } }
.rl-tool-banner-spinner { width:14px;height:14px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.6s linear infinite;flex-shrink:0; }
.rl-qa-pill-ai.rl-tool-running { background:rgba(79,142,247,0.15) !important;border-color:rgba(79,142,247,0.4) !important;animation:toolBtnPulse 1.5s ease-in-out infinite;pointer-events:none; }

/* Analysis dropdown button — prominent */
.rl-analysis-btn { color:var(--accent) !important;border-color:rgba(79,142,247,0.4) !important;background:rgba(79,142,247,0.08) !important;font-weight:600 !important;padding:5px 14px !important;font-size:11px !important; }
.rl-analysis-btn:hover { background:rgba(79,142,247,0.15) !important;border-color:rgba(79,142,247,0.6) !important; }
.light-theme .rl-analysis-btn { background:rgba(79,142,247,0.1) !important;border-color:rgba(79,142,247,0.3) !important;box-shadow:0 1px 4px rgba(79,142,247,0.12) !important; }

/* Tool doc dropdown rows */
.rl-tool-doc-row { display:flex;align-items:center;gap:6px;padding:6px 10px;border-bottom:1px solid var(--glass-border); }
.rl-tool-doc-row:last-child { border-bottom:none; }
.rl-tool-doc-label { flex:1;font-size:11px;font-weight:600;color:var(--text);cursor:pointer;padding:2px 0; }
.rl-tool-doc-label:hover { color:var(--accent); }
.rl-tool-doc-action { font-family:var(--font-mono);font-size:9px;padding:2px 8px;border:1px solid var(--glass-border);border-radius:4px;background:transparent;color:var(--accent);cursor:pointer;white-space:nowrap; }
.rl-tool-doc-action:hover { background:rgba(79,142,247,0.1);border-color:rgba(79,142,247,0.3); }
@keyframes toolBtnPulse { 0%,100% { opacity:1;box-shadow:0 0 0 0 rgba(79,142,247,0.3); } 50% { opacity:0.7;box-shadow:0 0 12px 2px rgba(79,142,247,0.2); } }

/* ── Severity badges in AI responses ── */
.sev-badge    { display:inline-block; padding:2px 7px; border-radius:4px; font-family:var(--font-mono); font-size:9px; font-weight:700; letter-spacing:.5px; vertical-align:middle; line-height:1.6; white-space:nowrap; }
.sev-redflag  { background:rgba(239,68,68,0.15); color:#f87171; border:1px solid rgba(239,68,68,0.25); }
.sev-critical { background:rgba(239,68,68,0.12); color:#f87171; border:1px solid rgba(239,68,68,0.2); }
.sev-flag     { background:rgba(239,68,68,0.12); color:#fb923c; border:1px solid rgba(239,68,68,0.2); }
.sev-high     { background:rgba(245,158,11,0.12); color:#fbbf24; border:1px solid rgba(245,158,11,0.2); }
.sev-issue    { background:rgba(245,158,11,0.1); color:#fb923c; border:1px solid rgba(245,158,11,0.2); }
.sev-alert    { background:rgba(239,68,68,0.12); color:#f87171; border:1px solid rgba(239,68,68,0.2); }
.sev-blocker  { background:rgba(239,68,68,0.15); color:#fca5a5; border:1px solid rgba(239,68,68,0.25); }
.sev-medium   { background:rgba(245,158,11,0.1); color:#fbbf24; border:1px solid rgba(245,158,11,0.2); }
.sev-concern  { background:rgba(245,158,11,0.1); color:#fbbf24; border:1px solid rgba(245,158,11,0.2); }
.sev-warning  { background:rgba(245,158,11,0.1); color:#f59e0b; border:1px solid rgba(245,158,11,0.2); }
.sev-low      { background:rgba(34,197,94,0.1); color:#22c55e; border:1px solid rgba(34,197,94,0.2); }
.sev-ok       { background:rgba(34,197,94,0.1); color:#22c55e; border:1px solid rgba(34,197,94,0.2); }
.sev-action   { background:rgba(79,142,247,0.1); color:var(--accent); border:1px solid rgba(79,142,247,0.2); }
.sev-risk     { background:rgba(79,142,247,0.1); color:var(--accent); border:1px solid rgba(79,142,247,0.2); }
.sev-note     { background:rgba(79,142,247,0.1); color:var(--accent); border:1px solid rgba(79,142,247,0.2); }
.sev-info     { background:rgba(255,255,255,0.06); color:var(--text2); border:1px solid rgba(255,255,255,0.08); }

/* ── AI response typography ── */
.ai-h1,.ai-h2,.ai-h3 { margin:.8em 0 .35em; font-weight:700; line-height:1.3; color:var(--accent); }
.ai-h1 { font-size:1.15em; border-bottom:1px solid var(--glass-border); padding-bottom:4px; }
.ai-h2 { font-size:1.05em; }
.ai-h3 { font-size:.95em; color:var(--text); opacity:0.95; }
.ai-h1:first-child,.ai-h2:first-child,.ai-h3:first-child { margin-top:0; }
.ai-p  { margin:.4em 0; }
.ai-ul { margin:.4em 0 .4em 1.2em; padding:0; }
.ai-ul li { margin:.25em 0; line-height:1.55; }
.ai-ul li strong { color:var(--text); }
.ai-numbered { padding:.3em 0 .3em .6em; border-left:3px solid var(--accent); margin:.35em 0; }
.ai-hr { border:none; border-top:1px solid var(--glass-border); margin:.8em 0; opacity:0.5; }

/* ── AI Markdown Tables ── */
.ai-table-wrap { overflow-x:auto; margin:.6em 0; border-radius:8px; border:1px solid var(--glass-border); }
.ai-table { width:100%; border-collapse:collapse; font-size:0.88em; line-height:1.45; table-layout:auto; }
.ai-table thead th { background:rgba(79,142,247,0.12); color:var(--accent); font-weight:700; text-align:left; padding:8px 14px; border-bottom:2px solid var(--glass-border); font-size:0.92em; letter-spacing:0.2px; }
.ai-table tbody td { padding:7px 14px; border-bottom:1px solid var(--glass-border); color:var(--text); vertical-align:top; text-align:left; word-break:break-word; }
.ai-table tbody tr:last-child td { border-bottom:none; }
.ai-table tbody tr:nth-child(even) { background:rgba(255,255,255,0.02); }
.ai-table tbody tr:hover { background:rgba(79,142,247,0.05); }
.ai-table td strong, .ai-table th strong { color:var(--text); }
.ai-table .sev-badge { font-size:9px; padding:1px 6px; }

/* ── Brief Me modal ── */
.brief-me-modal { background:var(--bg-mid); border:1px solid var(--glass-border); border-radius:16px; width:800px; max-width:96vw; max-height:88vh; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 24px 64px rgba(0,0,0,0.5); animation: modalIn 0.25s ease; }
.brief-me-hdr { padding:20px 24px 14px; border-bottom:1px solid var(--glass-border); display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.brief-me-tabs { display:flex; border-bottom:1px solid var(--glass-border); flex-shrink:0; padding:0 20px; gap:4px; }
.brief-me-tab { padding:10px 16px; font-size:13px; cursor:pointer; color:var(--text2); border-bottom:2px solid transparent; transition:all 0.15s; }
.brief-me-tab:hover { color:var(--text); }
.brief-me-tab.active { color:var(--accent); border-bottom-color:var(--accent); font-weight:500; }
.brief-me-pane { flex:1; overflow-y:auto; display:flex; flex-direction:column; min-height:0; }
.brief-me-pane.active { display:flex; }
.brief-me-footer { padding:14px 24px; border-top:1px solid var(--glass-border); display:flex; align-items:center; justify-content:space-between; flex-shrink:0; gap:10px; }
.brief-me-body { flex:1; overflow-y:auto; padding:24px 28px; font-size:14px; line-height:1.8; color:var(--text); }
.brief-me-loading { display:flex; align-items:center; gap:12px; color:var(--text3); font-family:var(--font-mono); font-size:11px; letter-spacing:0.5px; padding:20px 0; }
.brief-me-body h1 { font-size:17px; font-weight:700; color:var(--accent); margin:20px 0 10px; padding-bottom:6px; border-bottom:1px solid var(--glass-border); }
.brief-me-body h2 { font-size:15px; font-weight:700; color:var(--accent); margin:18px 0 8px; }
.brief-me-body h3 { font-size:14px; font-weight:600; color:var(--text); margin:14px 0 6px; }
.brief-me-body strong { color:var(--text); font-weight:600; }
.brief-me-body ul { padding-left:20px; margin:6px 0 10px; }
.brief-me-body li { margin-bottom:6px; }
.brief-me-body p { margin:0 0 10px; }
/* History list */
.brief-history-item { border-bottom:1px solid var(--glass-border); }
.brief-history-hdr { padding:14px 24px; display:flex; align-items:center; justify-content:space-between; cursor:pointer; transition:background 0.15s; }
.brief-history-hdr:hover { background:var(--surface2); }
.brief-history-date { font-size:13px; font-weight:600; color:var(--text); }
.brief-history-preview { font-size:12px; color:var(--text2); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:500px; }
.brief-history-body { display:none; padding:0 28px 20px; border-top:1px solid var(--glass-border); background:var(--surface2); }
.brief-history-body.open { display:block; }
.brief-history-body .brief-me-body { padding:16px 0; }

/* ── Help mode ── */
body.help-mode { cursor: help; }
body.help-mode [data-help], body.help-mode .cq-btn { cursor: help !important; }
#helpToggleBtn.help-active { background: var(--warning); color: #000; border-color: var(--warning); box-shadow: 0 0 0 3px rgba(245,158,11,0.3); font-weight: 600; }

/* ── Help Guide Modal ── */
#helpGuideModal { position: fixed; inset: 0; background: rgba(0,0,0,0.75); z-index: 500; display: none; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(4px); }
#helpGuideModal.open { display: flex; }
.help-guide-box { background: var(--bg-mid); border: 1px solid var(--glass-border); border-radius: 16px; width: 900px; max-width: 96vw; height: 85vh; display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 24px 64px rgba(0,0,0,0.5); animation: modalIn 0.25s ease; }
.help-guide-hdr { padding: 16px 24px 0; border-bottom: 1px solid var(--glass-border); display: flex; flex-direction: column; flex-shrink: 0; }
.help-guide-hdr-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.help-guide-hdr h2 { font-size: 16px; font-weight: 700; color: var(--gold); display: flex; align-items: center; gap: 10px; margin: 0; }
.help-tab-bar { display: flex; gap: 0; }
.help-tab-btn { padding: 9px 18px; font-size: 12px; font-weight: 600; border: none; background: none; cursor: pointer; color: var(--text2); border-bottom: 2px solid transparent; transition: color 0.15s, border-color 0.15s; white-space: nowrap; }
.help-tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
.help-tab-btn:hover:not(.active) { color: var(--text); }
.help-guide-body { flex: 1; overflow-y: auto; padding: 0; }
.help-pane { display: none; padding: 24px 28px; }
.help-pane.active { display: block; }
.help-guide-footer { padding: 12px 24px; border-top: 1px solid var(--glass-border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; gap: 10px; }
.help-card-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 4px; }
.help-card { background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 10px; padding: 14px 16px; }
.help-card-icon { font-size: 20px; margin-bottom: 6px; }
.help-card-title { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.help-card-desc { font-size: 12px; color: var(--text2); line-height: 1.6; }
.help-card-desc strong { color: var(--accent); }
.help-ai-badge { display: inline-block; font-size: 9px; font-weight: 700; padding: 2px 7px; border-radius: 10px; background: rgba(79,142,247,0.15); color: var(--accent); text-transform: uppercase; letter-spacing: 0.6px; margin-left: 6px; vertical-align: middle; }
.help-section { margin-bottom: 28px; }
.help-section:last-child { margin-bottom: 0; }
.help-section-title { font-size: 11px; font-weight: 700; color: var(--warning); text-transform: uppercase; letter-spacing: 1.2px; margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.help-section-title::after { content: ''; flex: 1; height: 1px; background: var(--glass-border); }
.help-step { display: flex; gap: 14px; margin-bottom: 12px; align-items: flex-start; }
.help-step-num { width: 26px; height: 26px; border-radius: 50%; background: var(--accent); color: #fff; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.help-step-num.gold { background: var(--gold); color: #000; }
.help-step-body { flex: 1; }
.help-step-label { font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 3px; }
.help-step-desc { font-size: 12px; color: var(--text2); line-height: 1.6; }
.help-step-desc strong { color: var(--accent); font-weight: 600; }
/* Fix: when all step classes are on one parent element, reset parent and style children */
.help-step.help-step-num { width: auto; height: auto; border-radius: 0; background: none; color: inherit; font-size: inherit; font-weight: inherit; margin-top: 0; }
.help-step.help-step-num > div:first-child { width: 26px; height: 26px; border-radius: 50%; background: var(--accent); color: #fff; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.help-step.help-step-num > div:last-child { flex: 1; }
.help-step.help-step-num > div:last-child > div:first-child { font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 3px; }
.help-step.help-step-num > div:last-child > div:last-child { font-size: 12px; color: var(--text2); line-height: 1.6; }
.help-step.help-step-num > div:last-child > div:last-child strong { color: var(--accent); font-weight: 600; }
/* Fix: when all card classes are on one parent element, style children */
.help-card.help-card-icon { font-size: inherit; margin-bottom: 0; }
.help-card.help-card-icon > div:first-child { font-size: 20px; margin-bottom: 6px; }
.help-card.help-card-icon > div:nth-child(2) { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.help-card.help-card-icon > div:last-child { font-size: 12px; color: var(--text2); line-height: 1.6; }
.help-card.help-card-icon > div:last-child strong { color: var(--accent); }
/* Variant: step with fs-11 override */
.help-step.help-step-num.fs-11 > div:last-child > div:last-child { font-size: 11px; }
.help-tip { background: rgba(79,142,247,0.08); border: 1px solid rgba(79,142,247,0.2); border-radius: 8px; padding: 10px 14px; font-size: 12px; color: var(--text2); line-height: 1.6; margin-bottom: 10px; }
.help-tip strong { color: var(--accent); }
.help-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.help-feature { background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 8px; padding: 10px 12px; }
.help-feature-name { font-size: 12px; font-weight: 600; color: var(--text); margin-bottom: 3px; }
.help-feature-desc { font-size: 11px; color: var(--text2); line-height: 1.5; }
#helpPopover { position: fixed; z-index: 9999; background: var(--glass-bg); border: 1px solid var(--warning); border-radius: 10px; padding: 16px 18px; width: 340px; box-shadow: 0 8px 32px rgba(0,0,0,0.6); display: none; }
#helpPopover.show { display: block; }
.help-pop-hdr { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 8px; }
.help-pop-title { font-size: 14px; font-weight: 700; color: var(--warning); flex: 1; }
.help-pop-close { background: none; border: none; color: var(--text2); cursor: pointer; font-size: 18px; line-height: 1; padding: 0; flex-shrink: 0; }
.help-pop-close:hover { color: var(--text); }
.help-pop-desc { font-size: 13px; color: var(--text); line-height: 1.6; margin-bottom: 10px; }
.help-pop-workflow { font-size: 12px; color: var(--text2); border-top: 1px solid var(--glass-border); padding-top: 8px; line-height: 1.55; }
.help-pop-workflow strong { color: var(--accent); }

/* ── Mammoth Word HTML viewer ── */
.mammoth-doc { font-family: 'Calibri', Georgia, serif; font-size: 14px; line-height: 1.8; color: var(--text); }
.mammoth-doc h1 { font-size: 18px; font-weight: 700; margin: 0 0 16px; text-align: left; }
.mammoth-doc h2 { font-size: 16px; font-weight: 700; margin: 24px 0 10px; border-bottom: 1px solid var(--glass-border); padding-bottom: 4px; }
.mammoth-doc h3 { font-size: 14px; font-weight: 700; margin: 18px 0 8px; }
.mammoth-doc h4, .mammoth-doc h5, .mammoth-doc h6 { font-size: 13px; font-weight: 600; margin: 14px 0 6px; }
.mammoth-doc p  { margin: 0 0 10px; text-align: justify; }
.mammoth-doc ul  { padding-left: 26px; margin: 6px 0 10px 0; list-style-type: disc; }
.mammoth-doc ol  { padding-left: 26px; margin: 6px 0 10px 0; list-style-type: decimal; }
.mammoth-doc ol ol { list-style-type: lower-alpha; }
.mammoth-doc ol ol ol { list-style-type: lower-roman; }
.mammoth-doc li  { margin-bottom: 4px; padding-left: 4px; }
.mammoth-doc table { border-collapse: collapse; width: 100%; margin: 16px 0; font-size: 13px; }
.mammoth-doc td, .mammoth-doc th { border: 1px solid var(--glass-border); padding: 7px 10px; vertical-align: top; }
.mammoth-doc th { background: var(--surface2); font-weight: 700; }
.mammoth-doc strong, .mammoth-doc b { font-weight: 700; }
.mammoth-doc em, .mammoth-doc i { font-style: italic; }
.mammoth-doc u { text-decoration: underline; }
.mammoth-doc a { color: var(--accent); }

/* Page separator */
.doc-page-sep { display: flex; align-items: center; gap: 12px; margin: 28px 0 20px; user-select: none; }
.doc-page-sep::before, .doc-page-sep::after { content: ''; flex: 1; height: 2px; background: var(--glass-border); }
.doc-page-label { font-size: 11px; font-weight: 700; color: var(--text2); background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 12px; padding: 3px 12px; white-space: nowrap; letter-spacing: 0.5px; text-transform: uppercase; }

/* ── Redline viewer ── */
.rl-del { text-decoration: line-through; color: #e53e3e; background: rgba(229,62,62,0.1); padding: 0 2px; border-radius: 2px; }
.rl-ins { text-decoration: underline; color: #38a169; background: rgba(56,161,105,0.1); padding: 0 2px; border-radius: 2px; }
.rl-pending .rl-del { color: #e07b2e; background: rgba(224,123,46,0.1); }
.rl-pending .rl-ins { color: #e07b2e; background: rgba(224,123,46,0.1); }
.rl-comment-ref { display: inline-flex; align-items: center; justify-content: center; width: 15px; height: 15px; background: var(--accent); color: white; border-radius: 50%; font-size: 8px; font-weight: 700; cursor: pointer; vertical-align: super; margin: 0 2px; }
.change-card { background: var(--surface2); border: 1px solid var(--glass-border); border-radius: 8px; padding: 10px 12px; margin-bottom: 8px; transition: border-color 0.15s; cursor: pointer; }
.change-card:hover { border-color: var(--accent); }
.change-card.accepted { border-color: rgba(56,161,105,0.6); background: rgba(56,161,105,0.06); }
.change-card.rejected { opacity: 0.38; border-style: dashed; }
.change-card.editing { border-color: var(--accent); background: rgba(79,142,247,0.06); }
.change-card.rl-card-active { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(79,142,247,0.25); }
.change-type-badge { font-size: 9px; font-weight: 700; padding: 2px 7px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.5px; display: inline-block; }
.change-type-replace { background: rgba(237,137,54,0.18); color: #dd8b2a; }
.change-type-insert  { background: rgba(56,161,105,0.18); color: #2f9e68; }
.change-type-delete  { background: rgba(229,62,62,0.18);  color: #c93030; }

/* ── Redline workflow selector ── */
.rl-workflow-card { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: 10px; padding: 18px 20px; cursor: pointer; transition: border-color 0.15s, background 0.15s; display: flex; flex-direction: column; gap: 6px; }
.rl-workflow-card:hover { border-color: var(--accent); background: rgba(79,142,247,0.06); }
.rl-workflow-card .wf-icon { font-size: 24px; }
.rl-workflow-card .wf-title { font-size: 14px; font-weight: 700; color: var(--text); }
.rl-workflow-card .wf-desc { font-size: 12px; color: var(--text2); line-height: 1.5; }
.rl-oo-frame { width: 100%; height: 100%; border: none; flex: 1; }
#rlCrResizer:hover, #rlCrResizer:active { background: var(--accent) !important; }
.rl-scroll-area { flex:1; overflow-y:auto; background:#fff; padding:0; }
.rl-page { background:#fff; padding:40px 56px; max-width:860px; width:100%; margin:0 auto; box-sizing:border-box; }
.rl-doc-text { font-family: 'Times New Roman', Times, serif; font-size: 12pt; line-height: 1.9; color: #111; }
.rl-doc-text div[class*="Section"], .rl-doc-text div[class*="WordSection"] { width:auto !important; margin:0 !important; padding:0 !important; }
.rl-doc-text .dv-h1 { font-size: 13pt; font-weight: 800; text-transform: uppercase; letter-spacing: 0.6px; text-align: center; margin: 0 0 20px; padding-bottom: 10px; border-bottom: 2px solid #333; }
.rl-doc-text .dv-h2 { font-size: 12pt; font-weight: 700; letter-spacing: 0.3px; margin: 24px 0 8px; }
.rl-ins-block { background: rgba(56,161,105,0.08); border-left: 3px solid #38a169; padding: 8px 12px; margin: 6px 0; border-radius: 0 4px 4px 0; }
.rl-ins-block.rl-pending { opacity: 0.75; }
.rl-doc-text .dv-h3 { font-size: 12pt; font-weight: 700; margin: 16px 0 6px; }
.rl-doc-text .dv-para { margin: 0 0 10px; text-align: justify; }
.rl-doc-text .dv-list { margin: 2px 0 2px 36px; }
.rl-doc-text .dv-sig  { margin: 20px 0 4px; font-style: italic; }
.rl-doc-text .dv-rule { border: none; border-top: 1px solid #ccc; margin: 20px 0; }
.rl-doc-text .dv-spacer { height: 8px; }

/* ── docxjs rendered output ── */
.docx-viewer-wrap { background:#e8e8e8; min-height:200px; padding:16px 8px; border-radius:6px; overflow-x:auto; }
.docx-viewer-wrap .docx-wrapper { display:flex; flex-direction:column; align-items:center; gap:20px; }
.docx-viewer-wrap section.docx { background:#fff; box-shadow:0 2px 16px rgba(0,0,0,0.22); margin:0 auto; overflow:visible !important; }

/* ══════════════════════════════════════════════════════════════════
   REDLINE MODAL — Design System Overhaul
   ══════════════════════════════════════════════════════════════════ */

/* Main modal container */
#redlineModal {
  background: linear-gradient(135deg, var(--bg-deep) 0%, var(--bg-mid) 30%, var(--bg-warm) 60%, var(--bg-deep) 100%) !important;
}
#redlineModal::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(79,142,247,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,142,247,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: -1;
}

/* Instruction panel (workflow selector) */
#rlInstructPanel {
  background: transparent !important;
}
#rlWorkflowSelector {
  max-width: 900px !important;
}

/* Review area status bar */
#rlReviewArea > div:first-child {
  border-bottom-color: var(--glass-border) !important;
}

/* Changes panel */
#rlChangesPanel {
  background: transparent !important;
  border-right-color: var(--glass-border) !important;
}

/* Redline tabs — design system styling */
#rlChangesPanel > div:first-child,
#rlCrChatPane > div:first-child {
  border-bottom-color: var(--glass-border) !important;
}
#rlChangesPanel button[onclick^="switchRlTab"],
#rlCrChatPane button[onclick^="switchCrTab"] {
  font-family: var(--font-mono) !important;
  font-size: 10px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase;
  transition: all 0.2s;
}


/* WF1 Chat pane */
#rlCrChatPane {
  background: transparent !important;
  border-right-color: var(--glass-border) !important;
}

/* WF1 OO editor pane */
#rlCrOoPane {
  background: transparent !important;
}

/* Document panel in WF2/WF3 */
#rlDocPanel {
  background: transparent !important;
}

/* Redline chat messages — same gradient bubbles as workspace */
#rlCrMessages .msg.user .msg-bubble,
#rlChatTab .msg.user .msg-bubble,
.rl-msg-bubble.user-bubble {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
  color: #fff !important;
  border-radius: 14px !important;
  border-bottom-right-radius: 3px !important;
}
#rlCrMessages .msg.assistant .msg-bubble,
#rlChatTab .msg.assistant .msg-bubble,
.rl-msg-bubble:not(.user-bubble) {
  background: var(--glass-bg) !important;
  color: var(--text) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 14px !important;
  border-bottom-left-radius: 3px !important;
}
#rlCrMessages .msg.assistant .msg-bubble strong,
#rlChatTab .msg.assistant .msg-bubble strong { color: var(--text); }
#rlCrMessages .msg.assistant .msg-bubble h1,
#rlCrMessages .msg.assistant .msg-bubble h2,
#rlCrMessages .msg.assistant .msg-bubble h3,
#rlChatTab .msg.assistant .msg-bubble h1,
#rlChatTab .msg.assistant .msg-bubble h2,
#rlChatTab .msg.assistant .msg-bubble h3 { color: var(--accent); }

/* Redline chat input areas */
#rlCrInput, #rlInput {
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  transition: border-color 0.2s;
}
#rlCrInput:focus, #rlInput:focus {
  border-color: var(--accent-border) !important;
  outline: none;
}

/* Redline send buttons — gradient */
#rlCrSendBtn, #rlSendBtn {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
  border: none !important;
  border-radius: 10px !important;
  color: #fff !important;
  font-weight: 600;
  transition: all 0.2s;
}
#rlCrSendBtn:hover, #rlSendBtn:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 16px rgba(79,142,247,0.3);
}

/* Quick action buttons in redline */
/* rl-qpick duplicate removed — defined earlier */

/* AI Redline panel */
#rlAiRedlinePanel {
  border-color: var(--glass-border) !important;
  background: var(--glass-bg) !important;
}

/* Context panel */
#rlContextPanel {
  border-color: var(--glass-border) !important;
  background: var(--glass-bg) !important;
}

/* Context picker in redline */
#rlCtxPickerPanel {
  background: var(--bg-mid) !important;
  border-color: rgba(79,142,247,0.2) !important;
  border-radius: 12px !important;
}

/* Redline token bars */
#rlCrTokenBar, [id$="TokenBar"] {
  background: transparent;
}

/* Change cards in review area */
.change-card {
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
  transition: all 0.15s;
}
.change-card:hover {
  border-color: var(--accent-border) !important;
}
.change-card.accepted {
  border-color: rgba(34,197,94,0.4) !important;
  background: rgba(34,197,94,0.04) !important;
}
.change-card.rl-card-active {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 2px rgba(79,142,247,0.2) !important;
}

/* Workflow cards */
.rl-workflow-card {
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  transition: all 0.2s;
}
.rl-workflow-card:hover {
  border-color: var(--accent-border) !important;
  background: var(--glass-hover) !important;
  transform: translateY(-1px);
}
.rl-workflow-card .wf-title {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px;
}
.rl-workflow-card .wf-desc {
  font-family: var(--font-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.3px;
}

/* Redline resize handles */
#rlPanelResizer, #rlCrResizer, .cr-vresize, #rlCrVResizer {
  background: var(--glass-border) !important;
}
#rlPanelResizer:hover, #rlCrResizer:hover, .cr-vresize:hover, #rlCrVResizer:hover {
  background: var(--accent) !important;
}

/* WF badge styling */
.rl-wf-badge, [class*="wf-badge"] {
  font-family: var(--font-mono);
  letter-spacing: 0.5px;
}

/* ── Redline extracted inline styles ── */

/* ── Info Tab — design system ── */
.rl-info-pane { display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto;padding:20px;gap:16px; }
.rl-info-heading { font-family:var(--font-mono);font-size:9px;letter-spacing:3px;text-transform:uppercase;color:#475569; }
.rl-info-section { display:flex;flex-direction:column;gap:6px; }
.rl-info-section-hdr { display:flex;align-items:center;justify-content:space-between; }
.rl-info-label { font-family:var(--font-mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#475569; }
.rl-info-add-btn { font-family:var(--font-mono);font-size:9px;letter-spacing:0.5px;padding:3px 10px;border-radius:5px;border:1px solid var(--glass-border);background:none;color:#475569;cursor:pointer;transition:all 0.15s; }
.rl-info-add-btn:hover { border-color:rgba(56,189,248,0.3);color:#64748b; }
.rl-rep-list { display:flex;flex-direction:column;gap:5px; }
.rl-info-party-row { display:flex;align-items:center;gap:8px; }
select.rl-info-party-select, .rl-info-pane .rl-info-party-select { font-family:var(--font-mono);font-size:11px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:6px;padding:7px 10px;color:var(--text);outline:none;appearance:none;-webkit-appearance:none;width:110px; }
input.rl-info-party-name, .rl-info-pane .rl-info-party-name { flex:1;font-family:var(--font-body);font-size:12px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:6px;padding:7px 10px;color:var(--text);outline:none;transition:border-color 0.2s; }
.rl-info-party-name::placeholder { color:#475569; }
.rl-info-party-name:focus { border-color:rgba(56,189,248,0.3); }
.rl-info-remove-btn { width:24px;height:24px;border-radius:6px;border:1px solid rgba(248,113,113,0.15);background:none;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all 0.15s;flex-shrink:0; }
.rl-info-remove-btn:hover { border-color:rgba(248,113,113,0.3);color:#f87171; }
input.rl-info-input, .rl-info-pane .rl-info-input { width:100%;font-family:var(--font-display);font-size:14px;font-weight:600;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:10px 14px;color:var(--text);outline:none;transition:border-color 0.2s; }
.rl-info-input::placeholder { color:#475569;font-weight:400; }
.rl-info-input:focus { border-color:rgba(56,189,248,0.3); }
.rl-info-option { padding:8px 12px;border-radius:6px;cursor:pointer;font-family:var(--font-mono);font-size:11px;color:#64748b;border:1px solid var(--glass-border);background:none;transition:all 0.15s;text-align:left; }
.rl-info-option:hover { background:var(--glass-bg);color:var(--text); }
.rl-info-option.selected { background:rgba(79,142,247,0.04);border-color:rgba(79,142,247,0.25);border-left:3px solid var(--accent);color:var(--accent); }
.rl-info-prompt-box { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:12px 14px;font-family:var(--font-body);font-size:12px;color:#64748b;line-height:1.7; }
.rl-rep-warning { display:none;font-size:11px;color:#f59e0b;margin-top:4px; }
.rl-action-row { display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid var(--glass-border); }
.rl-info-btn-primary { font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:0.5px;padding:8px 18px;border-radius:8px;border:none;background:linear-gradient(135deg,#38bdf8,#818cf8);color:#fff;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px; }
.rl-info-btn-primary:hover { transform:scale(1.02);box-shadow:0 4px 16px rgba(56,189,248,0.3); }
.rl-info-btn-secondary { font-family:var(--font-mono);font-size:11px;letter-spacing:0.5px;padding:8px 14px;border-radius:8px;border:1px solid var(--glass-border);background:none;color:#475569;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px; }
.rl-info-btn-secondary:hover { border-color:rgba(56,189,248,0.3);color:#64748b; }
.rl-info-btn-skip { font-family:var(--font-mono);font-size:11px;padding:8px 14px;border:none;background:none;color:#475569;cursor:pointer;transition:color 0.15s;margin-left:auto; }
.rl-info-btn-skip:hover { color:#64748b; }

/* ── Quick Action Pills — design system ── */
.rl-qa-bar { padding:8px 14px;border-bottom:1px solid rgba(255,255,255,0.06);flex-shrink:0; }
.rl-qa-heading { font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#475569;margin-bottom:8px; }
.rl-text-size { display:inline-flex;border-radius:6px;border:1px solid rgba(255,255,255,0.06);overflow:hidden;flex-shrink:0; }
.rl-text-size-btn { font-family:'Rajdhani','Segoe UI',sans-serif;font-size:12px;font-weight:700;padding:4px 10px;border:none;background:none;color:#475569;cursor:pointer;transition:all 0.15s;border-left:1px solid rgba(255,255,255,0.06); }
.rl-text-size-btn:hover { color:#e6edf3;background:rgba(255,255,255,0.04); }
.rl-qa-row { display:flex;flex-wrap:wrap;gap:6px; }
.rl-qa-pill { font-family:'Share Tech Mono',monospace;font-size:12px;letter-spacing:0.5px;padding:5px 12px;border-radius:14px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.02);color:#64748b;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:5px; }
.rl-qa-pill:hover { border-color:rgba(56,189,248,0.25);color:#e6edf3;background:rgba(255,255,255,0.04); }
.rl-qa-pill svg { width:12px;height:12px;flex-shrink:0; }
.rl-qa-pill-ai { font-family:'Share Tech Mono',monospace;font-size:12px;letter-spacing:0.5px;padding:5px 12px;border-radius:14px;border:1px solid rgba(79,142,247,0.2);background:rgba(79,142,247,0.04);color:var(--accent);cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:5px; }
.rl-qa-pill-ai:hover { border-color:rgba(79,142,247,0.4);background:rgba(79,142,247,0.08);color:var(--accent); }
.rl-qa-pill-ai svg { width:12px;height:12px;flex-shrink:0; }

/* Input wrapper at bottom of chat panes */
.rl-input-wrap { padding:10px 16px 12px; border-top:1px solid var(--glass-border); flex-shrink:0; display:flex; flex-direction:column; gap:6px; background:rgba(10,10,15,0.3); }

/* Chat textarea */
textarea.rl-chat-textarea { resize:none; min-height:40px; max-height:120px; padding:10px 14px; border:1px solid var(--glass-border); border-radius:10px; background:var(--glass-bg); color:var(--text); font-family:var(--font-body); font-size:13px; line-height:1.5; width:100%; box-sizing:border-box; outline:none; transition:border-color 0.2s; }
textarea.rl-chat-textarea:focus { border-color: var(--accent-border); }
textarea.rl-chat-textarea::placeholder { color:var(--text3); }

/* Send button gradient */
.rl-send-btn { width:40px;height:40px;border-radius:10px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;flex-shrink:0;font-size:0; }
.rl-send-btn:hover { transform:scale(1.05);box-shadow:0 4px 16px rgba(79,142,247,0.3); }
.rl-send-btn:active { transform:scale(0.95); }
.rl-send-btn svg { width:16px;height:16px; }

/* Stop button */
.rl-stop-btn { width:40px;height:40px;background:#dc2626;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;font-weight:700; }

/* Notes list area */
.rl-notes-list { flex:1; overflow-y:auto; padding:12px 14px; min-height:0; background:var(--glass-bg); }
.light-theme .rl-notes-list { background:rgba(255,255,255,0.5); }

/* Notes input footer — design system */
.rl-notes-footer {
  border-top:1px solid var(--glass-border);
  padding:12px 14px;
  display:flex; flex-direction:column; gap:8px;
  background:var(--glass-bg);
}
.light-theme .rl-notes-footer { background:rgba(255,255,255,0.6); }
input.rl-notes-input-title, .rl-notes-footer .rl-notes-input-title {
  width:100%; font-family:var(--font-display);
  font-size:13px; font-weight:600; color:var(--text);
  background:var(--bg-surface, rgba(255,255,255,0.06)); border:1px solid var(--glass-border);
  border-radius:8px; padding:8px 12px; outline:none;box-sizing:border-box;
  transition:border-color 0.2s;
}
.light-theme .rl-notes-input-title { background:#fff; }
.rl-notes-input-title::placeholder { color:var(--text3); }
.rl-notes-input-title:focus { border-color:var(--accent-border); }
textarea.rl-notes-input-body, .rl-notes-footer .rl-notes-input-body {
  width:100%; font-family:var(--font-body);
  font-size:12px; color:var(--text);
  background:var(--bg-surface, rgba(255,255,255,0.06)); border:1px solid var(--glass-border);
  border-radius:8px; padding:8px 12px; outline:none;
  resize:vertical; line-height:1.5; transition:border-color 0.2s;
  box-sizing:border-box;
}
.light-theme .rl-notes-input-body { background:#fff; }
.rl-notes-input-body::placeholder { color:var(--text3); }
.rl-notes-input-body:focus { border-color:var(--accent-border); }
.rl-notes-row {
  display:flex; gap:6px; align-items:center;
}
select.rl-notes-input-select, .rl-notes-footer .rl-notes-input-select {
  font-family:'Share Tech Mono',monospace; font-size:10px;
  color:#e6edf3; background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.06); border-radius:6px;
  padding:6px 10px; outline:none; flex:1;
  appearance:none; -webkit-appearance:none;
}
input.rl-notes-input-date, .rl-notes-footer .rl-notes-input-date {
  font-family:'Share Tech Mono',monospace; font-size:10px;
  color:#e6edf3; background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.06); border-radius:6px;
  padding:6px 10px; outline:none; flex:1;
}
.rl-notes-btn-primary {
  flex:1; font-family:'Share Tech Mono',monospace;
  font-size:11px; font-weight:600; letter-spacing:0.5px;
  padding:7px 14px; border-radius:8px; border:none;
  background:linear-gradient(135deg,#38bdf8,#818cf8);
  color:#fff; cursor:pointer; transition:all 0.15s;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
}
.rl-notes-btn-primary:hover { transform:scale(1.02); box-shadow:0 4px 16px rgba(56,189,248,0.3); }
.rl-notes-btn-secondary {
  flex:1; font-family:'Share Tech Mono',monospace;
  font-size:11px; letter-spacing:0.5px;
  padding:7px 14px; border-radius:8px;
  border:1px solid rgba(255,255,255,0.06);
  background:none; color:#475569; cursor:pointer; transition:all 0.15s;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
}
.rl-notes-btn-secondary:hover { border-color:rgba(56,189,248,0.3); color:#64748b; }

/* Notes summary box */
.rl-notes-summary { display:none; font-size:11px; line-height:1.5; color:var(--text); background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06); border-radius:6px; padding:8px; white-space:pre-wrap; max-height:120px; overflow-y:auto; }

/* Panel resize handle */
.rl-panel-resizer { width:5px; flex-shrink:0; cursor:col-resize; background:var(--glass-border); transition:background 0.15s; }

/* Document panel */
.rl-doc-panel { flex:1; display:flex; flex-direction:column; min-width:0; overflow:hidden; }

/* WF1 view container */
.rl-wf1-view { display:flex; flex-direction:column; flex:1; min-height:0; overflow:hidden; }

/* OO tabs bar */
.rl-oo-tabs-bar { display:none; flex-shrink:0; border-bottom:1px solid var(--glass-border); background:var(--glass-bg); }

/* OO tab button base */
.rl-oo-tab-btn { padding:10px 16px; font-size:12px; font-weight:600; border:none; background:none; cursor:pointer; border-bottom:2px solid transparent; color:var(--text2); }

/* OO tab active state */
.rl-oo-tab-btn.active { border-bottom-color:var(--accent); color:var(--accent); }

/* Review bar */
.rl-review-bar { display:none; flex-shrink:0; padding:6px 14px; background:var(--glass-bg); border-bottom:1px solid var(--glass-border); align-items:center; gap:8px; font-size:12px; }

/* Review bar label */
.rl-review-label { font-weight:600; color:var(--text2); margin-right:4px; }

/* Review nav buttons */
.rl-review-nav-btn { font-size:12px; padding:3px 10px; }

/* Accept change button */
.rl-accept-btn { font-size:12px; padding:3px 12px; background:#276749; color:#fff; border:none; border-radius:5px; cursor:pointer; }

/* Reject change button */
.rl-reject-btn { font-size:12px; padding:3px 12px; background:#9b2335; color:#fff; border:none; border-radius:5px; cursor:pointer; }

/* Connector status */
.rl-connector-status { margin-left:8px; font-size:11px; color:var(--text2); }

/* OO placeholder */
.rl-oo-placeholder { flex:1; min-height:0; }

/* Contract review header bar */
.rl-cr-header { padding:8px 16px; border-bottom:1px solid var(--glass-border); display:flex; align-items:center; gap:10px; flex-shrink:0; position:relative; z-index:200; }

/* Back button mono */
.rl-back-btn { font-size:11px; font-family:var(--font-mono); letter-spacing:0.5px; }

/* Doc title span */
.rl-doc-title { font-family:'Share Tech Mono',monospace; font-size:13px; color:#64748b; letter-spacing:0.5px; }

/* Topic badge */
.rl-topic-badge { display:none; font-family:var(--font-mono); font-size:9px; color:var(--text2); background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:10px; padding:2px 10px; white-space:nowrap; cursor:pointer; }

/* Sessions dropdown */
.rl-sessions-drop { position:absolute; top:100%; left:0; z-index:200; background:rgba(13,17,23,0.97); border:1px solid rgba(255,255,255,0.06); border-radius:8px; box-shadow:0 8px 32px rgba(0,0,0,0.4); min-width:220px; max-height:280px; overflow-y:auto; padding:6px; margin-top:4px; }

/* PDF buttons wrapper */
.rl-pdf-btns { display:none; align-items:center; gap:6px; }

/* Word mode button */
.rl-word-mode-btn { display:none; font-family:var(--font-mono); font-size:10px; font-weight:600; background:none; color:var(--accent); border:1px solid rgba(79,142,247,0.3); border-radius:6px; padding:5px 14px; gap:6px; cursor:pointer; box-shadow:none; transition:all 0.15s; }
.rl-word-mode-btn svg { flex-shrink:0; }
.rl-word-mode-btn:hover { border-color:var(--accent-border); color:var(--text); }

/* New session button */
.rl-new-session-btn { font-size:11px; display:none; }

/* Export wrapper */
.rl-export-wrap { display:none; gap:4px; }

/* Sync group container */
.rl-sync-group { display:flex; border:1px solid var(--glass-border); border-radius:6px; overflow:hidden; align-items:center; }

/* Sync button */
.rl-sync-btn { font-size:11px; border:none; border-radius:0; padding:4px 10px; }

/* Auto-sync toggle */
.rl-autosync-toggle { display:flex; align-items:center; gap:3px; padding:0 8px; border-left:1px solid var(--glass-border); cursor:pointer; height:100%; }

/* Auto-sync dot */
.rl-autosync-dot { width:7px; height:7px; border-radius:50%; background:var(--text2); transition:background 0.2s; }

/* Version dropdown button */
.rl-version-drop-btn { font-size:11px; border:none; border-left:1px solid var(--glass-border); border-radius:0; padding:4px 6px; }

/* Version history dropdown */
.rl-versions-drop { display:none; position:absolute; top:100%; right:0; z-index:300; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:8px; box-shadow:0 4px 16px rgba(0,0,0,0.4); min-width:260px; max-height:300px; overflow-y:auto; padding:6px 0; margin-top:4px; }

/* Version history header */
.rl-versions-header { padding:6px 12px; font-size:10px; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:0.7px; border-bottom:1px solid var(--glass-border); margin-bottom:4px; }

/* Version list */
.rl-versions-list { padding:4px 0; }

/* Version list loading text */
.rl-versions-loading { padding:8px 12px; font-size:11px; color:var(--text2); }

/* CR body flex */
.rl-cr-body { display:flex; flex:1; min-height:0; overflow:hidden; }

/* CR chat pane */
.rl-cr-chat-pane { flex:0 0 35%; min-width:200px; max-width:70%; overflow:hidden; display:flex; flex-direction:column; min-height:0; }

/* Tab switcher bar */
.rl-tab-bar { display:flex; border-bottom:1px solid var(--glass-border); flex-shrink:0; }

/* Tab button */
.rl-tab-btn { flex:1; padding:10px 4px; font-family:var(--font-mono); font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; border:none; background:none; cursor:pointer; border-bottom:2px solid transparent; color:var(--text3); transition:all 0.2s; }

/* Tab button active */
.rl-tab-btn.active { border-bottom-color:var(--accent); color:var(--accent); }

/* Notes count badge */
.rl-notes-count > span { display:none; background:rgba(245,158,11,0.15); color:var(--amber); border-radius:8px; padding:0 5px; font-size:10px; margin-left:2px; }

/* Prompt edit wrapper */
.rl-prompt-edit-wrap { display:none; margin-top:6px; }

/* Prompt edit textarea */
textarea.rl-prompt-textarea, .rl-info-pane .rl-prompt-textarea { width:100%;box-sizing:border-box;resize:none;overflow:hidden;font-family:var(--font-body);font-size:12px;line-height:1.7;padding:12px 14px;border:1px solid rgba(255,255,255,0.06);border-radius:8px;background:rgba(255,255,255,0.03);color:#64748b;min-height:60px; }

/* Chat content pane (hidden by default) */
.rl-chat-content { display:none; flex-direction:column; flex:1; min-height:0; overflow:hidden; position:relative; }

/* Quick actions heading (no bottom margin variant) */
.rl-qa-heading-no-mb { font-family:var(--font-mono); font-size:11px; text-transform:uppercase; letter-spacing:2px; color:var(--text3); }

/* Text size label */
.rl-text-size-label { font-size:11px; color:var(--text2); margin-right:2px; }

/* Messages pane */
.rl-messages-pane { flex:1; overflow-y:auto; padding:10px 10px 56px; display:flex; flex-direction:column; gap:10px; min-height:0; }
.light-theme .rl-messages-pane {
  padding: 14px 8px 160px 14px !important;
  background: transparent !important;
}

/* AI Redline panel */
.rl-ai-panel { display:none; margin-top:8px; padding:8px; background:var(--bg-deep); border:1px solid rgba(212,168,71,0.2); border-radius:8px; }

/* AI Redline panel heading */
.rl-ai-panel-heading { font-family:var(--font-mono);font-size:9px; color:var(--gold); text-transform:uppercase; letter-spacing:2px; margin-bottom:8px; }

/* ── AI Redline Launch Button ─────────────────────────────────────────────── */
.rl-redline-launch-btn {
  display:flex; align-items:center; gap:10px; width:100%;
  padding:12px 16px; border:1px solid rgba(212,168,71,0.3);
  border-radius:10px; background:linear-gradient(135deg,rgba(212,168,71,0.08),rgba(212,168,71,0.02));
  color:var(--gold,#d4a847); cursor:pointer; transition:all 0.2s;
  font-family:var(--font-mono); font-size:12px; font-weight:700; letter-spacing:0.5px;
}
.rl-redline-launch-btn:hover {
  background:linear-gradient(135deg,rgba(212,168,71,0.15),rgba(212,168,71,0.05));
  border-color:rgba(212,168,71,0.5); transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(212,168,71,0.15);
}
.light-theme .rl-redline-launch-btn {
  background:linear-gradient(135deg,rgba(212,168,71,0.12),rgba(180,140,50,0.06));
  border-color:rgba(212,168,71,0.35); color:#a07828;
  box-shadow:0 2px 8px rgba(212,168,71,0.1);
}
.light-theme .rl-redline-launch-btn:hover {
  background:linear-gradient(135deg,rgba(212,168,71,0.2),rgba(180,140,50,0.1));
  border-color:rgba(212,168,71,0.5); box-shadow:0 4px 16px rgba(212,168,71,0.15);
}

/* ── AI Redline Modal ─────────────────────────────────────────────────────── */
.rl-redline-modal {
  position:fixed; top:0; left:0; right:0; bottom:0; z-index:10001;
  display:flex; align-items:center; justify-content:center;
}
.rl-redline-modal-backdrop {
  position:absolute; top:0; left:0; right:0; bottom:0;
  background:rgba(0,0,0,0.6); backdrop-filter:blur(4px);
}
.rl-redline-modal-content {
  position:relative; width:92%; max-width:640px; max-height:92vh;
  overflow-y:auto; background:var(--bg2,#161b22);
  border:1px solid rgba(212,168,71,0.25); border-radius:16px;
  box-shadow:0 16px 64px rgba(0,0,0,0.4);
  animation:rlRedlineIn 0.25s ease;
}
.rl-redline-modal-content::-webkit-scrollbar { width:4px; }
.rl-redline-modal-content::-webkit-scrollbar-track { background:transparent; }
.rl-redline-modal-content::-webkit-scrollbar-thumb { background:rgba(212,168,71,0.2); border-radius:2px; }
@keyframes rlRedlineIn { from{opacity:0;transform:scale(0.95) translateY(10px)} to{opacity:1;transform:scale(1) translateY(0)} }
.light-theme .rl-redline-modal-content {
  background:#fff; border-color:rgba(212,168,71,0.3);
  box-shadow:0 16px 64px rgba(0,0,0,0.12), 0 0 0 1px rgba(212,168,71,0.1);
}
.light-theme .rl-redline-modal-header { color:#a07828; border-bottom-color:rgba(212,168,71,0.15); }
.light-theme .rl-redline-step-num { background:linear-gradient(135deg,#c49a30,#a07828); }
.light-theme .rl-redline-step-action { color:#a07828; border-color:rgba(212,168,71,0.3); background:rgba(212,168,71,0.06); }
.light-theme .rl-redline-step-action:hover { background:rgba(212,168,71,0.12); }
.light-theme .rl-redline-go-btn { background:linear-gradient(135deg,#c49a30,#a07828); }
.light-theme .rl-redline-textarea { background:rgba(0,0,0,0.02); border-color:rgba(0,0,0,0.1); }
.light-theme .rl-redline-textarea:focus { border-color:rgba(212,168,71,0.4); }

.rl-redline-modal-header {
  display:flex; align-items:center; gap:10px;
  padding:16px 20px; border-bottom:1px solid rgba(212,168,71,0.15);
  font-family:var(--font-mono); font-size:13px; font-weight:700;
  color:var(--gold,#d4a847); letter-spacing:0.5px;
}

.rl-redline-step {
  padding:16px 20px; border-bottom:1px solid var(--glass-border);
}
.rl-redline-step:last-of-type { border-bottom:none; }
.rl-redline-step-header {
  display:flex; align-items:center; gap:8px; margin-bottom:10px; flex-wrap:wrap;
}
.rl-redline-step-num {
  width:22px; height:22px; border-radius:50%;
  background:linear-gradient(135deg,var(--gold,#d4a847),#b8952e);
  color:#fff; font-family:var(--font-mono); font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.rl-redline-step-title {
  font-family:var(--font-mono); font-size:11px; font-weight:700;
  color:var(--text); letter-spacing:0.5px;
}
.rl-redline-step-desc {
  font-size:10px; color:var(--text3); flex:1;
}
.rl-redline-step-action {
  font-family:var(--font-mono); font-size:9px; font-weight:700;
  padding:4px 10px; border-radius:6px;
  border:1px solid rgba(212,168,71,0.3); background:rgba(212,168,71,0.08);
  color:var(--gold,#d4a847); cursor:pointer; transition:all 0.15s;
  margin-left:auto;
}
.rl-redline-step-action:hover { background:rgba(212,168,71,0.15); border-color:rgba(212,168,71,0.5); }

.rl-redline-textarea {
  width:100%; padding:10px 12px; border:1px solid var(--glass-border);
  border-radius:8px; background:var(--glass); color:var(--text);
  font-family:var(--font); font-size:13px; line-height:1.5;
  resize:vertical; outline:none; transition:border-color 0.2s;
  min-height:80px;
}
.rl-redline-textarea:focus { border-color:rgba(212,168,71,0.4); }
.rl-redline-textarea::placeholder { color:var(--text3); }

.rl-redline-modal-footer {
  display:flex; align-items:center; justify-content:flex-end; gap:8px;
  padding:12px 20px; border-top:1px solid var(--glass-border);
}
.rl-redline-cancel {
  padding:8px 20px; border:1px solid var(--glass-border); border-radius:8px;
  background:none; color:var(--text2); font-size:12px; font-weight:600;
  cursor:pointer; transition:all 0.15s;
}
.rl-redline-cancel:hover { border-color:var(--text2); color:var(--text); }
.rl-redline-go-btn {
  display:flex; align-items:center; gap:6px;
  padding:10px 24px; border:none; border-radius:8px;
  background:linear-gradient(135deg,var(--gold,#d4a847),#b8952e);
  color:#fff; font-size:13px; font-weight:700; cursor:pointer;
  transition:all 0.2s; letter-spacing:0.3px;
}
.rl-redline-go-btn:hover { transform:translateY(-1px); box-shadow:0 4px 16px rgba(212,168,71,0.3); }
.rl-redline-apply-btn {
  padding:6px 14px; border:none; border-radius:6px;
  background:linear-gradient(135deg,#22c55e,#16a34a);
  color:#fff; font-size:11px; font-weight:700; cursor:pointer;
  margin-left:auto; transition:all 0.15s;
}
.rl-redline-apply-btn:hover { transform:translateY(-1px); box-shadow:0 4px 12px rgba(34,197,94,0.3); }

/* Quick pick row */
.rl-qpick-row { display:flex; flex-wrap:wrap; gap:4px; margin-bottom:8px; }

/* Last run wrapper */
.rl-last-run-wrap { display:none; margin-bottom:6px; padding:5px 7px; background:rgba(212,168,71,0.06); border-radius:5px; border:1px solid rgba(212,168,71,0.12); }

/* Last run heading */
.rl-last-run-heading { font-family:var(--font-mono);font-size:9px; color:var(--gold); letter-spacing:1px; text-transform:uppercase; margin-bottom:2px; }

/* Last run text */
.rl-last-run-text { font-size:11px; color:var(--text2); white-space:pre-wrap; line-height:1.4; }

/* Reuse button */
.rl-reuse-btn { font-size:9px; color:var(--accent); background:none; border:none; cursor:pointer; padding:2px 0; margin-top:2px; }

/* AI Redline textarea */
.rl-ai-textarea { width:100%; box-sizing:border-box; resize:none; padding:6px 8px; border:1px solid var(--glass-border); border-radius:6px; background:var(--glass-bg); color:var(--text); font-size:11px; line-height:1.4; }

/* Risk preview panel */
.rl-risk-preview { display:none; margin-top:8px; border:1px solid rgba(239,68,68,0.3); border-radius:6px; overflow:hidden; background:var(--bg-deep); }

/* Risk preview header */
.rl-risk-header { padding:5px 8px; background:rgba(239,68,68,0.12); display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid rgba(239,68,68,0.2); }

/* Risk scan label */
.rl-risk-label { font-size:10px; font-weight:700; color:rgba(239,68,68,0.9); letter-spacing:0.4px; }

/* Risk apply button override */
.rl-risk-apply { font-family:var(--font-mono);font-size:10px; padding:4px 12px; background:rgba(212,168,71,0.1); border:1px solid rgba(212,168,71,0.3); color:var(--gold);border-radius:6px; }

/* Risk list */
.rl-risk-list { padding:6px 8px; max-height:200px; overflow-y:auto; }

/* AI redline action row */
.rl-ai-action-row { display:flex; justify-content:space-between; align-items:center; gap:6px; margin-top:6px; }

/* Improve AI feedback button */
.rl-improve-btn { font-size:10px; background:rgba(245,158,11,0.1); border:1px solid rgba(245,158,11,0.3); color:#f59e0b; }

/* AI Redline scan button */
.rl-scan-btn { font-family:var(--font-mono);font-size:10px; padding:4px 12px; background:rgba(212,168,71,0.1); border:1px solid rgba(212,168,71,0.3); color:var(--gold);border-radius:6px; }

/* Context panel */
.rl-context-panel { display:none; margin-top:8px; padding:8px; background:rgba(34,211,238,0.04); border:1px solid rgba(34,211,238,0.2); border-radius:8px; }

/* Context panel heading */
.rl-context-heading { font-family:var(--font-mono); font-size:9px; color:rgba(34,211,238,0.9); font-weight:700; letter-spacing:1px; text-transform:uppercase; }

/* Context textarea */
.rl-context-textarea { width:100%; box-sizing:border-box; resize:vertical; padding:6px 8px; border:1px solid var(--glass-border); border-radius:6px; background:var(--glass-bg); color:var(--text); font-size:11px; line-height:1.5; font-family:inherit; }

/* Context footer row */
.rl-context-footer { display:flex; justify-content:space-between; align-items:center; margin-top:4px; }

/* CR input wrap */
.rl-cr-input-wrap { padding:10px 16px 12px; border-top:1px solid var(--glass-border); flex-shrink:0; min-height:80px; display:flex; flex-direction:column; gap:6px; background:rgba(10,10,15,0.3); position:relative; }

/* CR chat textarea (taller default) */
textarea.rl-cr-textarea { flex:1; min-height:40px; max-height:120px; resize:none; padding:10px 14px; border:1px solid var(--glass-border); border-radius:10px; background:var(--glass-bg); color:var(--text); font-family:var(--font-body); font-size:13px; line-height:1.5; width:100%; box-sizing:border-box; outline:none; transition:border-color 0.2s; }
textarea.rl-cr-textarea:focus { border-color: var(--accent-border); }
textarea.rl-cr-textarea::placeholder { color:var(--text3); }

/* Token counter bar */
.rl-token-bar { display:flex; align-items:center; gap:6px; flex-shrink:0; }

/* Token progress track */
.rl-token-track { flex:1; height:5px; border-radius:3px; background:var(--glass-bg); overflow:hidden; }

/* Token progress fill */
.rl-token-fill { height:100%; width:0%; background:linear-gradient(90deg,var(--accent),var(--accent2)); border-radius:3px; transition:width 0.4s; }

/* Token percentage text */
.rl-token-pct { font-family:var(--font-mono); font-size:10px; color:var(--text3); white-space:nowrap; min-width:32px; }

/* Token count text */
.rl-token-count { font-family:var(--font-mono); font-size:10px; font-weight:600; color:var(--accent); white-space:nowrap; min-width:50px; }

/* Input footer row */
.rl-input-footer { display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }

/* Ctrl-Enter hint */
.rl-shortcut-hint { font-family:var(--font-mono); font-size:9px; color:var(--text3); }

/* Compact / Clear button */
.rl-mini-btn { font-family:var(--font-mono); font-size:9px; padding:2px 6px; color:var(--text3); }

/* Context picker button style */
.rl-ctx-btn { padding:4px 8px; line-height:1; position:relative; }

/* Context picker dot */
.rl-ctx-dot > span { display:none; position:absolute; top:2px; right:2px; width:7px; height:7px; border-radius:50%; background:var(--accent); }

/* Voice mic button */
.rl-mic-btn { width:40px;height:40px;border-radius:10px;border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;flex-shrink:0;padding:0; }
.rl-mic-btn:hover { border-color:var(--accent-border);color:var(--accent); }
.rl-mic-btn svg { width:16px;height:16px; }

/* CR resize handle */
.rl-cr-resizer { flex:0 0 5px; cursor:col-resize; background:var(--glass-border); transition:background 0.15s; z-index:10; }

/* CR OO pane */
.rl-cr-oo-pane { flex:1; min-width:200px; overflow:hidden; display:flex; flex-direction:column; height:100%; background:transparent; }

/* OO placeholder (full size) */
.rl-cr-oo-placeholder { width:100%; flex:1; min-height:0; height:100%; }

/* OO fallback panel */
.rl-cr-oo-fallback { display:none; flex:1; align-items:center; justify-content:center; flex-direction:column; gap:16px; padding:40px; text-align:center; }

/* Word panel icon */
.rl-word-icon { font-size:48px; margin-bottom:8px; }

/* Word panel title */
.rl-word-title { font-family:var(--font-display); font-size:16px; font-weight:700; color:var(--text); margin-bottom:4px; }

/* Word panel description */
.rl-word-desc { font-family:var(--font-mono); font-size:11px; color:var(--text3); max-width:380px; margin:0 auto 16px; }

/* Word open button */
.rl-word-open-btn { font-size:13px; padding:10px 28px; border-radius:10px; }

/* Word active status row */
.rl-word-active-row { display:flex; align-items:center; justify-content:center; gap:6px; margin-bottom:12px; }

/* Green dot indicator */
.rl-green-dot { width:8px; height:8px; border-radius:50%; background:#22c55e; display:inline-block; }

/* Green status text */
.rl-green-status { font-size:12px; color:#22c55e; font-weight:600; }

/* Word action buttons row */
.rl-word-actions { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; }

/* Word sync button */
.rl-word-sync-btn { font-size:12px; background:rgba(79,142,247,0.15); border:1px solid rgba(79,142,247,0.4); color:var(--accent); }

/* Word AI redline button */
.rl-word-ai-btn { font-size:12px; background:rgba(79,142,247,0.15); border:1px solid rgba(79,142,247,0.35); color:var(--accent); }

/* Word close button */
.rl-word-close-btn { font-size:12px; background:rgba(220,38,38,0.1); border:1px solid rgba(220,38,38,0.3); color:#ef4444; }

/* Word status text */
.rl-word-status { font-size:11px; color:var(--text2); margin-top:10px; }

/* Transcript pane */
.rl-transcript-pane { display:none; flex-direction:column; flex:1; overflow-y:auto; background:var(--glass-bg); padding:24px 32px; box-sizing:border-box; }

/* Transcript player (WF1) */
.rl-transcript-player { display:none; max-width:800px; width:100%; margin:0 auto 16px; border-radius:var(--radius); overflow:hidden; }
.rl-transcript-player video { width:100%; max-height:40vh; display:block; background:#000; }
.rl-transcript-player audio { width:100%; display:block; }

/* Transcript body */
.rl-transcript-body { font-size:13px; line-height:1.7; max-width:800px; margin:0 auto; }
.rl-transcript-bubble {
  margin-bottom:14px;padding:14px 18px;
}
.rl-transcript-speaker { font-size:11px;font-weight:700;margin-bottom:4px;text-transform:uppercase;letter-spacing:0.5px; }
.rl-transcript-text { color:var(--text);line-height:1.7; }
.rl-transcript-fallback { white-space:pre-wrap;font-family:inherit; }
.rl-transcript-body-wrap {
  background:var(--bg-surface, rgba(255,255,255,0.06));
  border:1px solid var(--glass-border);border-radius:var(--radius);
  padding:20px 24px;
}
.light-theme .rl-transcript-body-wrap { background:#fff;box-shadow:0 1px 4px rgba(0,0,0,0.05); }

/* Context picker panel — matches workspace ctx-picker */
.rl-ctx-picker { display:none; position:absolute; bottom:90px; left:4px; right:4px; background:rgba(13,17,23,0.97); border:1px solid rgba(79,142,247,0.2); border-radius:12px; box-shadow:0 8px 32px rgba(0,0,0,0.4); max-height:50vh; overflow-y:auto; z-index:50; animation:ctxPickerIn 0.2s ease; }
.rl-ctx-picker-header { padding:10px 14px; display:flex; align-items:center; gap:8px; border-bottom:1px solid rgba(79,142,247,0.1); background:rgba(79,142,247,0.03); flex-shrink:0; position:sticky; top:0; z-index:2; }
.rl-ctx-picker-title { font-family:var(--font-mono); font-size:11px; font-weight:700; color:var(--accent); letter-spacing:0.5px; flex:1; }
.rl-ctx-mode-toggle { display:flex; border:1px solid rgba(79,142,247,0.25); border-radius:10px; overflow:hidden; cursor:pointer; flex-shrink:0; }
.rl-ctx-mode-opt { padding:2px 8px; font-family:var(--font-mono); font-size:10px; font-weight:700; letter-spacing:0.3px; transition:all 0.2s; }
.rl-token-badge { font-family:var(--font-mono); font-size:11px; font-weight:700; color:var(--accent); background:rgba(79,142,247,0.1); padding:2px 8px; border-radius:8px; }
.rl-ctx-close { background:none; border:none; color:var(--text2); cursor:pointer; font-size:14px; padding:0 2px; }
.rl-ctx-picker-body { max-height:240px; overflow-y:auto; padding:8px; }
.rl-ctx-picker-footer { padding:6px 12px; border-top:1px solid rgba(79,142,247,0.1); display:flex; align-items:center; gap:8px; }
.rl-progress-track { flex:1; height:4px; border-radius:2px; background:rgba(255,255,255,0.04); overflow:hidden; }
.rl-progress-fill { height:100%; width:0%; background:linear-gradient(90deg,var(--accent),var(--accent)); border-radius:2px; transition:width 0.3s; }
.rl-cost-badge { font-family:var(--font-mono); font-size:9px; color:var(--text3); }
/* Context picker sections — matches workspace */
.rl-ctx-section { border-bottom:1px solid var(--glass-border); }
.rl-ctx-section:last-child { border-bottom:none; }
.rl-ctx-section-header { padding:8px 14px; display:flex; align-items:center; gap:8px; }
.rl-ctx-section-label { font-family:var(--font-mono); font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text3); flex:1; }
.rl-ctx-section-count { font-family:var(--font-mono); font-size:9px; color:var(--text3); }
.rl-ctx-section-toggle { font-family:var(--font-mono); font-size:8px; padding:2px 6px; border-radius:4px; border:1px solid var(--glass-border); background:none; color:var(--text3); cursor:pointer; transition:all 0.12s; }
.rl-ctx-section-toggle:hover { border-color:rgba(79,142,247,0.3); color:var(--accent); }
.rl-ctx-items { padding:0 8px 8px; }
.rl-ctx-item { display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:6px; transition:background 0.12s; cursor:pointer; min-width:0; }
.rl-ctx-item:hover { background:rgba(255,255,255,0.02); }
.rl-ctx-item input[type="checkbox"] { accent-color:var(--accent); flex-shrink:0; width:14px; height:14px; cursor:pointer; }
.rl-ctx-item-icon { font-family:var(--font-mono); font-size:8px; flex-shrink:0; text-align:center; padding:2px 6px; border-radius:3px; background:rgba(79,142,247,0.12); color:var(--accent); white-space:nowrap; letter-spacing:0.3px; border:1px solid rgba(79,142,247,0.2); }
.light-theme .rl-ctx-item-icon { background:rgba(79,142,247,0.08); border-color:rgba(79,142,247,0.15); }
.light-theme .rl-ctx-picker { background:#fff !important; border-color:rgba(79,142,247,0.2) !important; box-shadow:0 8px 32px rgba(0,0,0,0.12) !important; }
.light-theme .rl-ctx-picker-header { background:rgba(79,142,247,0.04) !important; border-bottom-color:rgba(79,142,247,0.1) !important; }
.light-theme .rl-ctx-picker-footer { border-top-color:rgba(79,142,247,0.1) !important; }
.light-theme .rl-ctx-item:hover { background:rgba(79,142,247,0.04) !important; }
.light-theme .rl-ctx-section { border-bottom-color:var(--glass-border) !important; }
.light-theme .rl-ctx-section-header:hover { background:rgba(79,142,247,0.04) !important; }
.rl-ctx-item-name { font-size:12px; color:var(--text); flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.rl-ctx-item-size { font-family:var(--font-mono); font-size:9px; color:var(--text3); flex-shrink:0; }
.rl-ctx-item-tokens { font-family:var(--font-mono); font-size:9px; color:rgba(79,142,247,0.6); flex-shrink:0; }

/* Notes in redline */
#rlNotesList .note-item, #rlCrNotesList .note-item,
#rlNotesTab .doc-item, #rlCrNotesContent .doc-item {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
}

/* Redline OO tabs */
#rlWf1OoTabs button {
  font-family: var(--font-mono) !important;
  font-size: 10px !important;
  letter-spacing: 1px;
}

/* Version dropdown */
#rlVersionsDrop {
  background: var(--bg-mid) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5) !important;
}

/* Session dropdown in redline */
#rlReviewSessionsDrop, #rlCrSessionsDrop {
  background: var(--bg-mid) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5) !important;
}

/* Word mode panel */
#rlWordPanel {
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
}

/* Light theme overrides for redline — gradient body, frosted glass panels on top */
.light-theme #redlineModal {
  background: linear-gradient(160deg, var(--bg-deep) 0%, var(--bg-mid) 35%, var(--bg-warm, var(--bg-deep)) 65%, var(--bg-deep) 100%) !important;
}
/* Light grid overlay — softer than dark, still gives texture */
.light-theme #redlineModal::before {
  background-image:
    linear-gradient(rgba(79,142,247,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,142,247,0.045) 1px, transparent 1px) !important;
}
.light-theme .change-card { background: #fff !important; border-color: var(--glass-border) !important; box-shadow:0 1px 3px rgba(0,0,0,0.04); }

/* ═══════════════════════════════════════════════════════════════
   WF1 LIGHT THEME — Full glass architecture
   Layer 1: Gradient background + grid texture on #redlineModal
   Layer 2: Frosted glass panels — everything is glass, blur shows through
   Layer 3: Content floats on the glass (bubbles, pills)
   Layer 4: Input area = solid white — no distraction when typing
   ═══════════════════════════════════════════════════════════════ */

/* Layer 1 — Modal background: gradient + grid baked into one background
   Grid is ON the element (not ::before) so backdrop-filter can blur it */
/* Base light-theme fallback (Ivory) — prevents flash before theme-specific rule loads */
.light-theme #redlineModal {
  background:
    linear-gradient(rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(160deg, #d0cac0 0%, #c4bcb0 25%, #b8b0a4 50%, #c4bcb0 75%, #d0cac0 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-ivory #redlineModal {
  background:
    linear-gradient(rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(160deg, #d0cac0 0%, #c4bcb0 25%, #b8b0a4 50%, #c4bcb0 75%, #d0cac0 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-snow #redlineModal {
  background:
    linear-gradient(rgba(37,99,235,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #e0e0e8 0%, #d8d8e2 25%, #d0d0dc 50%, #d8d8e2 75%, #e0e0e8 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-pearl #redlineModal {
  background:
    linear-gradient(rgba(59,130,246,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(59,130,246,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #d5d9df 0%, #cdd1d8 25%, #c5c9d1 50%, #cdd1d8 75%, #d5d9df 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-linen #redlineModal {
  background:
    linear-gradient(rgba(184,134,11,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(184,134,11,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #dfd6c9 0%, #d8cfc1 25%, #d0c6b8 50%, #d8cfc1 75%, #dfd6c9 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-frost #redlineModal {
  background:
    linear-gradient(rgba(2,132,199,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(2,132,199,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #d0d8e2 0%, #c8d0dc 25%, #c0c8d4 50%, #c8d0dc 75%, #d0d8e2 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
/* Hide the dark-theme ::before grid so it doesn't double up */
.light-theme #redlineModal::before {
  display: none !important;
}

/* Layer 2 — ALL panels are glass */
/* Left panel — grid background (same pattern as dark theme modal) */
.light-theme #rlChangesPanel {
  background: transparent !important;
  border-right: 1px solid rgba(0,0,0,0.08) !important;
}
/* WF1 CR chat pane — transparent so modal grid shows through */
.light-theme #rlCrChatPane {
  background: transparent !important;
  position: relative;
}

/* Header bar (Back · NDA · Sessions) — frosted glass over grid */
.light-theme .ws-rl-header {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255,255,255,0.4) !important;
  box-shadow: 0 1px 8px rgba(0,0,0,0.04) !important;
}

/* Status bar (PDF · Convert to Word · Clear All etc.) — frosted glass */
.light-theme .ws-rl-status-bar {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
}

/* Tab bar — frosted glass, text scrolls under and blurs */
.light-theme .ws-rl-changes-tabs {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,0.4) !important;
  position: relative;
  z-index: 2;
}

/* Quick actions bar — frosted glass */
.light-theme #rlQABar {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
  position: relative;
  z-index: 2;
}
.light-theme .rl-qa-pill {
  background: rgba(255,255,255,0.75) !important;
  border-color: rgba(0,0,0,0.08) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05) !important;
}
.light-theme .rl-qa-pill:hover {
  background: #fff !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  box-shadow: 0 1px 6px rgba(79,142,247,0.15) !important;
}
.light-theme .rl-qa-pill-ai {
  background: rgba(255,255,255,0.75) !important;
  border-color: rgba(79,142,247,0.15) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05) !important;
}

/* AI Redline panel — solid white in light theme */
.light-theme .rl-ai-panel { background: rgba(255,255,255,0.92) !important; border-color: rgba(0,0,0,0.12) !important; backdrop-filter: blur(12px); }
.light-theme .rl-risk-preview { background: #fff !important; border-color: rgba(239,68,68,0.25) !important; }
.light-theme .rl-risk-header { background: rgba(239,68,68,0.06) !important; }

/* Tab bar — frosted glass (same as v3.0.0) */
.light-theme .rl-tab-bar {
  background: rgba(255,255,255,0.28) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,0.2) !important;
  position: relative;
  z-index: 3;
}

/* QA bar — frosted glass, overlays content, slides down */
.light-theme .rl-qa-bar {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 4;
  max-height: 300px;
  overflow: hidden;
  transition: max-height 0.25s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease, padding 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  opacity: 1;
}
.rl-qa-bar.qa-collapsed {
  max-height: 0 !important;
  opacity: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  border-bottom-width: 0 !important;
  transition: max-height 0.2s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.15s ease, padding 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Chat content wrapper — transparent, relative for QA overlay */
.light-theme .rl-chat-content {
  background: transparent !important;
  position: relative;
}

/* Info pane — transparent so grid shows */
/* ── Info tab — light theme ── */
.light-theme .rl-info-pane {
  background: transparent !important;
}
.light-theme .rl-info-section {
  background: rgba(255,255,255,0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 10px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,0.3);
}
.light-theme .rl-info-input,
.light-theme .rl-info-party-name,
.light-theme .rl-info-party-select,
.light-theme .rl-info-pane textarea {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.12) !important;
  color: var(--text) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.light-theme .rl-info-input::placeholder,
.light-theme .rl-info-party-name::placeholder {
  color: var(--text3) !important;
}
.light-theme .rl-info-input:focus,
.light-theme .rl-info-party-name:focus,
.light-theme .rl-info-party-select:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(79,142,247,0.10);
}
.light-theme .rl-info-option {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  color: var(--text2) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.light-theme .rl-info-option:hover {
  border-color: var(--accent) !important;
  color: var(--text) !important;
}
.light-theme .rl-info-option.selected {
  background: rgba(79,142,247,0.06) !important;
  border-color: rgba(79,142,247,0.25) !important;
  color: var(--accent) !important;
}
.light-theme .rl-info-add-btn {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  color: var(--text2) !important;
}
.light-theme .rl-info-add-btn:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}
.light-theme .rl-info-remove-btn {
  border-color: rgba(220,38,38,0.15) !important;
  color: var(--text3) !important;
}
.light-theme .rl-info-remove-btn:hover {
  border-color: rgba(220,38,38,0.3) !important;
  color: #dc2626 !important;
}
.light-theme .rl-info-btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
  border: none !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(79,142,247,0.25);
}
.light-theme .rl-info-btn-skip {
  color: var(--text2) !important;
}
.light-theme .rl-info-btn-skip:hover {
  color: var(--accent) !important;
}

/* (consolidated into rule above) */

/* ── Notes tab — light theme (frosted glass, matching Info) ── */
.light-theme .rl-notes-list {
  background: transparent;
}
.light-theme .rl-notes-footer {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid rgba(255,255,255,0.3) !important;
  border-radius: 12px;
  margin: 0 8px 8px;
  padding: 14px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.light-theme .rl-notes-input-title,
.light-theme .rl-notes-input-body {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.12) !important;
  color: var(--text) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.light-theme .rl-notes-input-title::placeholder,
.light-theme .rl-notes-input-body::placeholder {
  color: var(--text3) !important;
}
.light-theme .rl-notes-input-title:focus,
.light-theme .rl-notes-input-body:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(79,142,247,0.10);
}
.light-theme .rl-notes-input-select,
.light-theme .rl-notes-input-date {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.12) !important;
  color: var(--text) !important;
}
.light-theme .rl-notes-btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
  border: none !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(79,142,247,0.25);
}

/* ── Chat bubbles — same as workspace ── */
/* User — blue gradient, white text */
.light-theme #rlChatTab .msg.user .msg-bubble,
.light-theme #rlCrMessages .msg.user .msg-bubble {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
  color: #fff !important;
  border-radius: 14px !important;
  border-bottom-right-radius: 3px !important;
}
/* AI — white card */
.light-theme #rlChatTab .msg.assistant .msg-bubble,
.light-theme #rlCrMessages .msg.assistant .msg-bubble {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
  border-radius: 14px !important;
  border-bottom-left-radius: 3px !important;
}

/* ── Input area — frosted glass frame, textarea itself is solid ── */
.light-theme .rl-input-wrap {
  background: transparent !important;
  border-top: none !important;
  position: relative;
  z-index: 3;
}
.light-theme .rl-cr-input-wrap {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid rgba(255,255,255,0.3) !important;
  position: absolute !important;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 3;
}
.light-theme .rl-chat-textarea,
.light-theme .rl-cr-textarea,
.light-theme textarea#rlCrInput,
.light-theme textarea#rlInput {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
  min-height: 44px !important;
  max-height: 44px !important;
  height: 44px !important;
  resize: none !important;
  padding: 12px 14px !important;
  overflow: hidden !important;
  line-height: 1.4 !important;
}

/* Input wrap — compact, fixed at bottom, equal padding top/bottom of ctx bar */
.light-theme .rl-cr-input-wrap {
  min-height: auto !important;
  padding: 10px 16px 10px !important;
  gap: 4px !important;
}
.light-theme .rl-chat-textarea:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(79,142,247,0.10) !important;
}

/* Send button */
.light-theme .rl-send-btn,
.light-theme #rlCrSendBtn {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
  box-shadow: 0 2px 8px rgba(79,142,247,0.25);
  color: #fff !important;
  display: flex !important;
  width: 44px !important;
  height: 44px !important;
}

/* (status bar rules consolidated above) */

/* Typing dots */
.light-theme #rlChatTab .typing-dots {
  background: rgba(255,255,255,0.5) !important;
  border-color: rgba(0,0,0,0.04) !important;
}

/* Message timestamps */
.light-theme #rlChatTab .msg-meta { opacity: 0.45; }

/* ── Archive Viewer — inline style replacements ── */
.av-hdr-row { display:flex; align-items:center; gap:8px; margin-bottom:4px; }
.av-archived-badge { font-size:11px; font-weight:700; background:rgba(245,158,11,0.15); color:var(--amber); border:1px solid rgba(245,158,11,0.3); border-radius:10px; padding:2px 8px; text-transform:uppercase; letter-spacing:0.5px; }

/* ── Email Workshop (edm-) — inline style replacements ── */
.edm-modal { display:none; position:fixed; inset:0; background:linear-gradient(135deg, var(--bg-deep) 0%, var(--bg-mid) 30%, var(--bg-warm) 60%, var(--bg-deep) 100%); z-index:9000; flex-direction:column; overflow:hidden; }
.edm-modal::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(79,142,247,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,142,247,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: -1;
}
.edm-inner { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.edm-header { padding:12px 20px; border-bottom:1px solid var(--glass-border); display:flex; align-items:center; gap:14px; flex-shrink:0; background:var(--glass-bg); }
.edm-back-btn { font-size:12px; flex-shrink:0; }
.edm-title { font-size:14px; font-weight:600; color:var(--text); flex-shrink:0; letter-spacing:0.3px; }
.edm-tab-group { display:flex; gap:2px; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:8px; padding:3px; margin-left:8px; }
.edm-project-badge { font-size:12px; color:var(--text2); text-align:right; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.edm-controls-bar { padding:9px 20px; border-bottom:2px solid var(--glass-border); background:var(--glass-bg); flex-shrink:0; display:flex; flex-direction:column; gap:7px; }
.edm-approach-row { display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.edm-approach-label { font-size:11px; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:0.8px; flex-shrink:0; margin-right:3px; }
.edm-tone-row { display:flex; align-items:center; gap:7px; }
.edm-divider-v { width:1px; height:20px; background:var(--glass-border); flex-shrink:0; margin:0 3px; }
.edm-instructions-input { flex:1; font-size:12px; }
.edm-gen-btn { flex-shrink:0; background:var(--accent); border:none; font-weight:700; font-size:13px; padding:8px 22px; white-space:nowrap; }
/* Email context popup picker — positioned above the footer bar */
.edm-ctx-popup { bottom:32px!important; left:0!important; right:auto!important; min-width:400px; max-width:600px; }

.edm-workspace { flex:1; display:flex; overflow:hidden; min-height:0; }
.edm-left-panel { flex:1; display:flex; flex-direction:column; border-right:2px solid var(--glass-border); min-width:0; }
.edm-pane-col { display:flex; flex-direction:column; flex:1; min-height:0; }
.edm-section-bar { padding:8px 14px; border-bottom:1px solid var(--glass-border); background:var(--glass-bg); flex-shrink:0; display:flex; align-items:center; gap:7px; }
.edm-section-bar-plain { padding:8px 14px; border-bottom:1px solid var(--glass-border); background:var(--glass-bg); flex-shrink:0; }
.edm-select { flex:1; font-size:12px; padding:3px 8px; margin-left:auto; max-width:340px; }
.edm-clear-btn { font-size:12px; padding:3px 8px; flex-shrink:0; }
.edm-header-card { display:none; padding:10px 16px; border-bottom:1px solid var(--glass-border); background:rgba(79,142,247,0.05); flex-shrink:0; }
.edm-scroll-area { flex:1; overflow-y:auto; padding:16px 18px; }
.edm-body-pre { white-space:pre-wrap; font-family:inherit; font-size:13px; line-height:1.75; color:var(--text); margin:0; }
.edm-source-textarea { display:none; width:100%; min-height:260px; resize:none; font-size:13px; line-height:1.75; background:transparent; border:none; outline:none; color:var(--text); font-family:inherit; }
.edm-footer-bar { padding:7px 14px; border-top:1px solid var(--glass-border); background:var(--glass-bg); flex-shrink:0; display:flex; align-items:center; gap:8px; }
.edm-left-new { display:none; flex-direction:column; flex:1; min-height:0; overflow-y:auto; padding:18px 20px; gap:12px; }
.edm-help-text { font-size:12px; color:var(--text2); line-height:1.5; margin-bottom:4px; }
.edm-help-text-nomargin { font-size:12px; color:var(--text2); line-height:1.5; }
.edm-keypoints-group { margin:0; flex:1; display:flex; flex-direction:column; }
.edm-keypoints-textarea { flex:1; min-height:220px; resize:none; font-size:13px; line-height:1.65; }
.edm-left-refine { display:none; flex-direction:column; flex:1; min-height:0; }
.edm-refine-body { flex:1; overflow-y:auto; padding:14px 18px; display:flex; flex-direction:column; gap:10px; }
.edm-refine-textarea { flex:1; min-height:300px; resize:none; font-size:13px; line-height:1.75; font-family:inherit; }
.edm-right-panel { flex:1; display:flex; flex-direction:column; min-width:0; }
.edm-right-header { padding:8px 14px; border-bottom:1px solid var(--glass-border); background:var(--glass-bg); flex-shrink:0; display:flex; align-items:center; gap:8px; }
.edm-section-label { font-size:12px; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:0.8px; flex:1; }
.edm-my-draft-label { display:flex; align-items:center; gap:6px; cursor:pointer; font-size:12px; color:var(--text2); flex-shrink:0; user-select:none; }
.edm-checkbox { width:auto; accent-color:var(--accent); }
.edm-copy-bar { display:none; gap:5px; align-items:center; }

/* ── Drafts History Drawer ─────────────────────────────────────────────── */
.edm-drafts-drawer {
  position:absolute; top:0; left:0; bottom:0; width:320px;
  background:var(--glass-bg); border-right:1px solid var(--glass-border);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  display:none; flex-direction:column; z-index:10; overflow:hidden;
  box-shadow:4px 0 24px rgba(0,0,0,0.25);
}
.edm-drafts-drawer.open { display:flex; }
.edm-drafts-drawer-header {
  padding:12px 16px; display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--glass-border); background:rgba(79,142,247,0.05);
  flex-shrink:0;
}
.edm-drafts-drawer-title {
  display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700;
  color:var(--text); text-transform:uppercase; letter-spacing:0.6px;
}
.edm-drafts-count-badge {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:20px; height:20px; padding:0 6px;
  background:var(--accent); color:#fff; font-size:11px; font-weight:700;
  border-radius:10px;
}
.edm-drafts-drawer-close {
  background:transparent; border:none; color:var(--text2); cursor:pointer;
  font-size:22px; line-height:1; padding:0 6px;
}
.edm-drafts-drawer-close:hover { color:var(--text); }
.edm-drafts-filter-bar {
  display:flex; gap:4px; padding:8px 12px;
  border-bottom:1px solid var(--glass-border); flex-shrink:0;
}
.edm-drafts-filter-btn {
  flex:1; padding:5px 8px; background:transparent; border:1px solid var(--glass-border);
  border-radius:6px; color:var(--text2); font-size:11px; font-weight:600;
  cursor:pointer; text-transform:uppercase; letter-spacing:0.5px;
}
.edm-drafts-filter-btn:hover { color:var(--text); border-color:var(--accent); }
.edm-drafts-filter-btn.active {
  background:rgba(79,142,247,0.15); color:var(--accent); border-color:var(--accent);
}
.edm-drafts-list {
  flex:1; overflow-y:auto; padding:8px; display:flex; flex-direction:column; gap:6px;
}
.edm-drafts-empty {
  padding:24px 16px; text-align:center; color:var(--text2); font-size:12px; font-style:italic;
}
.edm-draft-item {
  padding:10px 12px; background:rgba(255,255,255,0.03); border:1px solid var(--glass-border);
  border-radius:8px; cursor:pointer; transition:all 0.15s;
}
.edm-draft-item:hover {
  background:rgba(79,142,247,0.08); border-color:var(--accent);
  transform:translateX(2px);
}
.edm-draft-item.active {
  background:rgba(79,142,247,0.12); border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent);
}
.edm-draft-item-subject {
  font-size:12px; font-weight:700; color:var(--text); line-height:1.3;
  overflow:hidden; text-overflow:ellipsis; display:-webkit-box;
  -webkit-line-clamp:2; -webkit-box-orient:vertical;
}
.edm-draft-item-meta {
  display:flex; align-items:center; gap:6px; margin-top:6px;
  font-size:10px; color:var(--text2);
}
.edm-draft-item-badges { display:flex; gap:4px; margin-top:4px; flex-wrap:wrap; }
.edm-draft-badge {
  padding:1px 6px; font-size:9px; font-weight:700; border-radius:8px;
  text-transform:uppercase; letter-spacing:0.5px;
}
.edm-draft-badge.active { background:rgba(16,185,129,0.15); color:#10b981; }
.edm-draft-badge.sent   { background:rgba(79,142,247,0.15); color:var(--accent); }
.edm-draft-badge.archived { background:rgba(148,163,184,0.15); color:#94a3b8; }
.edm-draft-badge.version { background:rgba(139,92,246,0.15); color:#8b5cf6; }
.edm-draft-badge.mode   { background:rgba(148,163,184,0.10); color:var(--text2); }
.edm-draft-item-actions {
  display:flex; gap:4px; margin-top:6px; opacity:0; transition:opacity 0.15s;
}
.edm-draft-item:hover .edm-draft-item-actions { opacity:1; }
.edm-draft-item-action {
  font-size:10px; padding:2px 6px; background:transparent; border:1px solid var(--glass-border);
  color:var(--text2); border-radius:4px; cursor:pointer;
}
.edm-draft-item-action:hover { color:var(--text); border-color:var(--accent); }

.edm-drafts-btn-badge {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:18px; height:16px; padding:0 5px;
  background:var(--accent); color:#fff; font-size:10px; font-weight:700;
  border-radius:8px; margin-left:4px;
}

.edm-version-tag {
  font-size:10px; font-weight:700; padding:2px 7px; border-radius:10px;
  background:rgba(139,92,246,0.15); color:#8b5cf6; text-transform:uppercase;
  letter-spacing:0.5px;
}
.edm-sent-tag {
  font-size:10px; font-weight:700; padding:2px 7px; border-radius:10px;
  background:rgba(16,185,129,0.15); color:#10b981; text-transform:uppercase;
  letter-spacing:0.5px;
}

/* ── Inline chat draft badge (replaces <email_draft> blocks) ──────────── */
.chat-draft-badge {
  display:flex; align-items:center; gap:8px;
  margin:10px 0; padding:10px 14px;
  background:linear-gradient(135deg, rgba(79,142,247,0.10), rgba(139,92,246,0.08));
  border:1px solid rgba(79,142,247,0.4); border-radius:10px;
  cursor:pointer; transition:all 0.2s;
  font-size:13px; color:var(--text);
}
.chat-draft-badge:hover {
  background:linear-gradient(135deg, rgba(79,142,247,0.18), rgba(139,92,246,0.14));
  border-color:var(--accent);
  transform:translateX(2px);
}
.chat-draft-badge strong { color:var(--accent); font-weight:700; }
.chat-draft-badge-open {
  margin-left:auto; padding:3px 10px; background:var(--accent); color:#fff;
  font-size:11px; font-weight:700; border-radius:6px; text-transform:uppercase;
  letter-spacing:0.6px;
}
.edm-user-draft-pane { display:none; flex-direction:column; flex:1; border-bottom:3px solid var(--glass-border); min-height:0; max-height:50%; }
.edm-user-draft-bar { padding:6px 14px; background:rgba(79,142,247,0.06); border-bottom:1px solid var(--glass-border); flex-shrink:0; }
.edm-user-draft-label { font-size:11px; font-weight:700; color:#8b5cf6; text-transform:uppercase; letter-spacing:0.8px; }
.edm-user-draft-textarea { flex:1; resize:none; font-size:13px; line-height:1.75; padding:14px 18px; background:transparent; border:none; outline:none; color:var(--text); font-family:inherit; }
.edm-claude-pane { flex:1; display:flex; flex-direction:column; min-height:0; overflow:hidden; }
.edm-claude-label { display:none; padding:6px 14px; background:rgba(79,142,247,0.06); border-bottom:1px solid var(--glass-border); flex-shrink:0; }
.edm-claude-label-text { font-size:11px; font-weight:700; color:var(--accent); text-transform:uppercase; letter-spacing:0.8px; }
.edm-output-scroll { flex:1; overflow-y:auto; padding:18px 20px 52px; position:relative; }
.edm-placeholder { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; gap:14px; color:var(--text2); user-select:none; }
.edm-placeholder-icon { font-size:52px; opacity:0.12; }
.edm-placeholder-text { font-size:13px; text-align:center; line-height:1.6; max-width:260px; }
.edm-output-pre { display:none; white-space:pre-wrap; font-family:inherit; font-size:13px; line-height:1.8; color:var(--text); margin:0; }
.edm-output-footer { display:none; padding:10px 14px; border-top:1px solid var(--glass-border); background:var(--glass-bg); flex-shrink:0; justify-content:flex-end; gap:8px; }
.edm-refine-bar { display:flex; align-items:center; gap:8px; padding:8px 14px; border-top:1px solid var(--glass-border); background:var(--glass-bg); flex-shrink:0; }
.edm-refine-input { flex:1; font-size:12px; padding:7px 12px; border-radius:8px; border:1px solid var(--glass-border); background:var(--surface2); color:var(--text); outline:none; font-family:inherit; }
.edm-refine-input:focus { border-color:var(--accent-border); }
.edm-refine-input::placeholder { color:var(--text3); }
.edm-refine-send { background:var(--accent); border:none; color:#fff; border-radius:8px; padding:6px 10px; cursor:pointer; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.edm-refine-send:hover { opacity:0.85; }

/* Redline panel resizer hover */
.rl-panel-resizer:hover { background:var(--accent); }

/* ── Playbook ── */
/* panel-playbook layout handled by #panel-playbook.active rule */

/* ── Precedent Database ── */
#panel-precedent { padding:0; }
/* ── Precedent Database — design system ── */
.prec-layout { display:flex; height:100%; overflow:hidden; }

/* Tree panel */
.prec-tree-panel {
  width:280px; flex-shrink:0;
  background:var(--glass-bg);
  border-right:1px solid var(--glass-border);
  display:flex; flex-direction:column; overflow:hidden;
}
.prec-tree-header {
  padding:14px 16px 12px; border-bottom:1px solid var(--glass-border);
  display:flex; align-items:center; justify-content:space-between; flex-shrink:0;
}
.prec-tree-title {
  font-family:var(--font-mono); font-size:10px; font-weight:700;
  color:var(--text2); text-transform:uppercase; letter-spacing:2px;
}
.prec-tree-body { flex:1; overflow-y:auto; padding:10px 8px; }

/* Tree nodes — spacious, large click targets */
.prec-node {
  display:flex; align-items:center; gap:6px;
  padding:8px 10px; border-radius:8px; cursor:pointer;
  font-size:13px; color:var(--text);
  border:1px solid transparent; transition:all 0.15s;
  margin-bottom:2px;
}
.prec-node:hover { background:var(--glass-bg); }
.prec-node.selected {
  background:rgba(79,142,247,0.08);
  border-color:rgba(79,142,247,0.2); color:var(--accent);
}
.prec-node-icon { flex-shrink:0; font-size:14px; opacity:0.7; }
.prec-node-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-weight:500; }
.prec-node-actions { display:none; gap:2px; flex-shrink:0; }
.prec-node:hover .prec-node-actions { display:flex; }
.prec-node-btn {
  background:none; border:none; cursor:pointer;
  color:var(--text3); font-size:11px; padding:3px 5px;
  border-radius:4px; line-height:1; transition:all 0.12s;
}
.prec-node-btn:hover { background:var(--glass-bg); color:var(--text); }
.prec-node-count {
  font-family:var(--font-mono); font-size:9px; color:var(--text3);
  background:rgba(79,142,247,0.08); border-radius:8px;
  padding:2px 6px; flex-shrink:0;
}

/* Content panel */
.prec-content-panel { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.prec-content-header {
  padding:20px 24px 16px; border-bottom:1px solid var(--glass-border);
  display:flex; align-items:center; gap:12px; flex-shrink:0;
}

/* Body */
.prec-body { flex:1; overflow-y:auto; padding:24px; }

/* Project cards — spacious glass cards */
.prec-proj-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.prec-proj-card {
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:12px; padding:20px; transition:all 0.15s; cursor:pointer;
}
.prec-proj-card:hover { border-color:var(--accent-border); background:var(--glass-hover); }
.prec-proj-name { font-size:14px; font-weight:600; margin-bottom:8px; color:var(--text); }
.prec-proj-meta { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:10px; }
.prec-proj-badge {
  font-family:var(--font-mono); font-size:9px; font-weight:700;
  background:rgba(79,142,247,0.08); border:1px solid rgba(79,142,247,0.15);
  border-radius:4px; padding:3px 8px; color:var(--accent);
}
.prec-proj-field { font-family:var(--font-mono); font-size:11px; color:var(--text3); margin-bottom:3px; }
.prec-proj-field span { color:var(--text2); }
.prec-proj-actions {
  display:flex; gap:6px; margin-top:12px; padding-top:10px;
  border-top:1px solid var(--glass-border);
}

/* Drop zone */
.prec-drop-zone {
  border:2px dashed var(--glass-border); border-radius:12px;
  padding:32px; text-align:center; cursor:pointer;
  color:var(--text3); font-family:var(--font-mono); font-size:11px;
  transition:all 0.2s; margin-bottom:16px;
}
.prec-drop-zone:hover, .prec-drop-zone.drag-over {
  border-color:var(--accent-border); background:rgba(79,142,247,0.06); color:var(--accent);
}

/* Doc cards */
.prec-doc-card {
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:10px; padding:14px 16px;
  display:flex; align-items:center; gap:12px; margin-bottom:8px;
  transition:all 0.15s;
}
.prec-doc-card:hover { border-color:var(--accent-border); }
.prec-doc-icon { font-size:20px; flex-shrink:0; }
.prec-doc-info { flex:1; min-width:0; }
.prec-doc-title { font-size:13px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:var(--text); }
.prec-doc-meta { font-family:var(--font-mono); font-size:9px; color:var(--text3); margin-top:2px; }

/* Empty state */
.prec-empty {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:60px 24px; text-align:center;
}

/* Inline input */
.prec-node-inline-input {
  background:var(--glass-bg); border:1px solid var(--accent-border);
  border-radius:6px; padding:4px 8px; font-size:12px;
  color:var(--text); outline:none; width:140px;
}

/* Ref project detail modal */
#refProjModal .modal { width:640px; max-width:96vw; }
#refProjModal .form-2col { display:grid; grid-template-columns:1fr 1fr; gap:12px; }


/* ═══════════════════════════════════════════════════════════════════
   DESIGN SYSTEM — New component classes for future steps
   These are the T-Server design system classes adapted for T-Legal.
   Used alongside old classes — no conflicts.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Context Panel Tabs ── */
.ctx-tabs { display:flex; border-bottom:1px solid var(--glass-border); flex-shrink:0; overflow:hidden; }
.ctx-tab {
  flex:1; padding:10px 4px;
  font-family:var(--font-mono); font-size:9px;
  letter-spacing:0.5px; text-transform:uppercase;
  text-align:center; cursor:pointer;
  color:var(--text3); border:none; background:none;
  transition:all 0.15s; position:relative; white-space:nowrap;
}
.ctx-tab:hover { color:var(--text2); }
.ctx-tab.active { color:var(--accent); }
.ctx-tab.active::after {
  content:''; position:absolute;
  bottom:-1px; left:0; right:0;
  height:2px; background:var(--accent);
  box-shadow:0 0 6px rgba(79,142,247,0.3);
}
.ctx-tab .tab-count {
  font-size:8px; padding:1px 5px; border-radius:8px;
  background:rgba(79,142,247,0.1); color:var(--accent);
  margin-left:3px;
}
body.theme-warm .ctx-tab.active { color:var(--gold); }
body.theme-warm .ctx-tab.active::after { background:var(--gold); box-shadow:0 0 6px rgba(212,168,71,0.3); }
body.theme-ocean .ctx-tab.active { color:#38b2ac; }
body.theme-ocean .ctx-tab.active::after { background:#38b2ac; box-shadow:0 0 6px rgba(56,178,172,0.3); }

/* ── Context Panel Collapse ── */
.ctx-collapse-btn {
  position:absolute; left:-14px; top:12px;
  width:14px; height:32px;
  background:var(--bg-mid); border:1px solid var(--glass-border);
  border-right:none; border-radius:6px 0 0 6px;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  color:var(--text3); font-size:10px;
  transition:color 0.2s; z-index:5;
}
.ctx-collapse-btn:hover { color:var(--text); }

/* Mini icon rail when collapsed */
.ctx-mini-rail {
  position:absolute; right:0; top:0; bottom:0;
  width:40px;
  display:none; flex-direction:column;
  align-items:center; padding:8px 0; gap:2px;
  background:rgba(10,10,15,0.5);
  border-left:1px solid var(--glass-border);
  z-index:6;
}
.ctx-mini-btn {
  width:32px; height:32px; border-radius:8px;
  border:none; background:none;
  color:var(--text3); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all 0.15s; position:relative;
}
.ctx-mini-btn:hover { color:var(--text2); background:var(--glass-bg); }
.ctx-mini-btn svg { width:15px; height:15px; }
.ctx-mini-btn .mini-count {
  position:absolute; top:2px; right:2px;
  font-family:var(--font-mono); font-size:7px; font-weight:700;
  background:rgba(79,142,247,0.2); color:var(--accent);
  padding:0 4px; border-radius:6px; line-height:1.6;
}
.ctx-mini-btn[data-tip]:hover::before {
  content:attr(data-tip);
  position:absolute; right:calc(100% + 6px); top:50%; transform:translateY(-50%);
  font-family:var(--font-mono); font-size:9px;
  padding:3px 8px; border-radius:4px;
  background:rgba(13,17,23,0.95); border:1px solid var(--glass-border);
  color:var(--text); white-space:nowrap; pointer-events:none;
}

/* Collapsed state */
.context-panel.collapsed .ctx-mini-rail { display:flex; }
.context-panel.collapsed { width:40px !important; opacity:1; overflow:visible; }
.context-panel.collapsed .ctx-tabs,
.context-panel.collapsed .ctx-content,
.context-panel.collapsed .ctx-collapse-btn { display:none; }

.light-theme .ctx-mini-rail { background:rgba(255,255,255,0.8); box-shadow:-1px 0 0 var(--glass-border); }
body.theme-ivory .ctx-mini-rail { background:rgba(230,226,220,0.8); }

/* ── Quick Action Pills ── */
.qa-pill {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.5px;
  padding: 4px 12px; border-radius: 14px;
  border: 1px solid var(--glass-border); background: var(--glass-bg);
  color: var(--text3); cursor: pointer; transition: all 0.15s;
  white-space: nowrap;
}
.qa-pill:hover { border-color: var(--accent-border); color: var(--text); }
.qa-pill.warn {
  border-color: rgba(245,158,11,0.25); color: rgba(245,158,11,0.7);
  background: rgba(245,158,11,0.04);
}
.qa-pill.warn:hover { background: rgba(245,158,11,0.08); color: var(--amber); }
body.theme-ivory .qa-pill { background: rgba(255,255,255,0.4); border-color: rgba(0,0,0,0.08); }

/* ── DS Buttons ── */
.ts-btn {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 10px 20px; border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: var(--glass-bg);
  color: var(--text); cursor: pointer;
  transition: all 0.25s;
  backdrop-filter: blur(10px);
}
.ts-btn:hover {
  border-color: var(--accent-border);
  background: var(--glass-hover);
  box-shadow: 0 4px 16px rgba(79,142,247,0.08);
  transform: translateY(-1px);
}
.ts-btn:active { transform: translateY(0); }
.ts-btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-color: transparent; color: #fff;
}
.ts-btn-primary:hover {
  box-shadow: 0 4px 20px rgba(79,142,247,0.25);
  border-color: transparent;
}
.ts-btn-danger { border-color: rgba(239,68,68,0.3); color: var(--red); }
.ts-btn-danger:hover { background: rgba(239,68,68,0.08); border-color: rgba(239,68,68,0.5); }
.ts-btn-success { border-color: rgba(34,197,94,0.3); color: var(--emerald); }
.ts-btn-success:hover { background: rgba(34,197,94,0.08); border-color: rgba(34,197,94,0.5); }
.ts-btn-sm { font-size: 11px; padding: 6px 14px; }
.ts-btn-lg { font-size: 15px; padding: 14px 28px; }
.ts-btn-icon { display: inline-flex; align-items: center; gap: 8px; }
.ts-btn-icon svg { width: 16px; height: 16px; }

/* ── DS Badges ── */
.ts-badge {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px;
  display: inline-flex; align-items: center; gap: 6px;
}
.ts-badge-default { background: rgba(255,255,255,0.06); color: var(--text3); }
.ts-badge-accent { background: rgba(79,142,247,0.1); color: var(--accent); border: 1px solid rgba(79,142,247,0.2); }
.ts-badge-emerald { background: rgba(34,197,94,0.1); color: var(--emerald); border: 1px solid rgba(34,197,94,0.2); }
.ts-badge-amber { background: rgba(245,158,11,0.1); color: var(--amber); border: 1px solid rgba(245,158,11,0.2); }
.ts-badge-red { background: rgba(239,68,68,0.1); color: var(--red); border: 1px solid rgba(239,68,68,0.2); }
.ts-badge-gold { background: rgba(212,168,71,0.1); color: var(--gold); border: 1px solid rgba(212,168,71,0.2); }

/* ── DS Progress ── */
.ts-progress { width: 100%; height: 4px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.ts-progress-fill { height: 100%; border-radius: 2px; background: linear-gradient(90deg, var(--accent), var(--accent2)); transition: width 0.5s ease-out; }

/* ── DS Input ── */
.ts-input {
  width: 100%; background: var(--glass-bg);
  border: 1px solid var(--glass-border); border-radius: 8px;
  padding: 10px 14px; font-family: var(--font-mono);
  font-size: 13px; color: var(--text); outline: none;
  transition: border-color 0.3s, background 0.3s, box-shadow 0.3s;
}
.ts-input::placeholder { color: var(--text3); letter-spacing: 1px; }
.ts-input:focus {
  border-color: var(--accent-border);
  background: var(--glass-hover);
  box-shadow: 0 0 0 3px rgba(79,142,247,0.06);
}

/* ── DS Select ── */
.ts-select {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border); border-radius: 8px;
  padding: 10px 36px 10px 14px; font-family: var(--font-mono);
  font-size: 13px; color: var(--text); outline: none; cursor: pointer;
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
  transition: border-color 0.3s, background 0.3s;
}
.ts-select:focus { border-color: var(--accent-border); background: var(--glass-hover); }
.ts-select option { background: var(--bg-mid); color: var(--text); }
.ts-select-sm {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border); border-radius:6px;
  padding:6px 28px 6px 8px; font-family:var(--font-mono);
  font-size:10px; color:var(--text2); outline:none; cursor:pointer;
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 6px center;
  transition:border-color 0.2s; box-sizing:border-box;
}
.ts-select-sm:focus { border-color:var(--accent-border); }
.ts-select-sm option { background:var(--bg-mid); color:var(--text); }

/* ── DS Tabs ── */
.ts-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--glass-border); }
.ts-tab {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 10px 20px; border: none; background: none;
  color: var(--text3); cursor: pointer;
  position: relative; transition: color 0.2s;
}
.ts-tab:hover { color: var(--text); }
.ts-tab.active { color: var(--accent); }
.ts-tab.active::after {
  content: ''; position: absolute;
  bottom: -1px; left: 0; right: 0;
  height: 2px; background: var(--accent);
  box-shadow: 0 0 8px rgba(79,142,247,0.4);
}

/* ── DS Toast ── */
.ts-toast {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; border-radius: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.5px;
  border: 1px solid; animation: tsToastIn 0.4s ease;
}
@keyframes tsToastIn { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }
.ts-toast-info { background: rgba(79,142,247,0.06); border-color: rgba(79,142,247,0.15); color: var(--accent); }
.ts-toast-success { background: rgba(34,197,94,0.06); border-color: rgba(34,197,94,0.15); color: var(--emerald); }
.ts-toast-warning { background: rgba(245,158,11,0.06); border-color: rgba(245,158,11,0.15); color: var(--amber); }
.ts-toast-error { background: rgba(239,68,68,0.06); border-color: rgba(239,68,68,0.15); color: var(--red); }
.ts-toast-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; background: currentColor; box-shadow: 0 0 6px currentColor; }

/* ── DS Spinner ── */
.ts-spinner { width: 24px; height: 24px; border: 2px solid var(--glass-border); border-top-color: var(--accent); border-radius: 50%; animation: tsSpin 0.8s linear infinite; }
.ts-spinner-lg { width: 40px; height: 40px; border-width: 3px; }
@keyframes tsSpin { to { transform: rotate(360deg); } }

/* ── DS Skeleton ── */
.ts-skeleton {
  background: linear-gradient(90deg, rgba(255,255,255,0.03) 25%, rgba(255,255,255,0.06) 50%, rgba(255,255,255,0.03) 75%);
  background-size: 200% 100%; animation: tsShimmer 1.5s infinite; border-radius: 6px;
}
@keyframes tsShimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ── DS Stat Card ── */
.ts-stat {
  background: var(--glass-bg); border: 1px solid var(--glass-border);
  border-radius: 12px; padding: 20px; backdrop-filter: blur(10px);
}
.ts-stat-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--text3); margin-bottom: 8px; }
.ts-stat-value { font-family: var(--font-display); font-size: 36px; font-weight: 700; color: var(--text); line-height: 1; }
.ts-stat-trend { font-family: var(--font-mono); font-size: 11px; margin-top: 6px; }
.ts-stat-trend.up { color: var(--emerald); }
.ts-stat-trend.down { color: var(--red); }

/* ── DS Alert ── */
.ts-alert {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-radius: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.5px;
  border: 1px solid;
}
.ts-alert svg { width: 18px; height: 18px; flex-shrink: 0; }
.ts-alert-info { background: rgba(79,142,247,0.04); border-color: rgba(79,142,247,0.12); color: var(--accent); }
.ts-alert-success { background: rgba(34,197,94,0.04); border-color: rgba(34,197,94,0.12); color: var(--emerald); }
.ts-alert-warning { background: rgba(245,158,11,0.04); border-color: rgba(245,158,11,0.12); color: var(--amber); }
.ts-alert-error { background: rgba(239,68,68,0.04); border-color: rgba(239,68,68,0.12); color: var(--red); }

/* ── Page Panels (non-workspace) ── */
.panel .card { background: var(--glass-bg); border: 1px solid var(--glass-border); }
.panel .card-title { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2px; }

/* Session cards — design system glass style */
.panel .rl-workflow-card { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: 10px; transition: all 0.15s; }
.panel .rl-workflow-card:hover { border-color: var(--accent-border); background: var(--glass-hover); }

/* ── Status Bar ── */
.status-bar {
  height: 28px; flex-shrink: 0;
  display: flex; align-items: center;
  padding: 0 16px; gap: 20px;
  background: rgba(10,10,15,0.5);
  border-top: 1px solid var(--glass-border);
  font-family: var(--font-mono); font-size: 10px;
  color: var(--text3); letter-spacing: 0.5px;
  position: relative; z-index: 10;
}
.sb-dot > div { width: 6px; height: 6px; border-radius: 50%; flex-shrink:0; }
.sb-dot.green > div { background: var(--emerald); box-shadow: 0 0 4px var(--emerald); }
.sb-dot.blue > div { background: var(--accent); box-shadow: 0 0 4px var(--accent); }
.sb-item { display: flex; align-items: center; gap: 5px; }
.sb-sep { width: 1px; height: 12px; background: var(--glass-border); }
.sb-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }

/* Page panels — from prototype lines 1136-1174 */
.page-header {
  padding:20px 24px 16px;
  border-bottom:1px solid var(--glass-border);
}
.page-title {
  font-family:var(--font-display);
  font-size:22px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--text);
}
.page-desc {
  font-family:var(--font-mono); font-size:11px;
  color:var(--text3); margin-top:4px; letter-spacing:0.5px;
}
.page-body { flex:1; overflow-y:auto; padding:20px 24px; }

/* Session cards — from prototype lines 1157-1174 */
.session-card {
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:10px; padding:14px 16px; margin-bottom:8px;
  display:flex; align-items:center; gap:12px;
  transition:all 0.15s; cursor:pointer;
}
.session-card:hover { border-color:var(--accent-border); background:var(--glass-hover); }
.session-wf {
  font-family:var(--font-mono); font-size:9px; font-weight:700;
  padding:3px 8px; border-radius:4px; flex-shrink:0;
}
.session-wf.wf1 { background:rgba(79,142,247,0.1); color:var(--accent); border:1px solid rgba(79,142,247,0.2); }
.session-wf.wf3 { background:rgba(212,168,71,0.1); color:var(--gold); border:1px solid rgba(212,168,71,0.2); }
.session-wf.wf-redline { background:rgba(0,0,0,0.7); color:#fff; border:1px solid rgba(0,0,0,0.3); }
.light-theme .session-wf.wf-redline { background:rgba(0,0,0,0.85); color:#fff; border:1px solid rgba(0,0,0,0.2); }
.session-wf.chat { background:rgba(255,255,255,0.04); color:var(--text2); border:1px solid var(--glass-border); }
.session-info { flex:1; min-width:0; }
.session-name { font-size:13px; font-weight:500; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.session-meta { font-family:var(--font-mono); font-size:10px; color:var(--text3); margin-top:2px; }
.session-actions { display:flex; gap:4px; flex-shrink:0; }
body.theme-ivory .session-card { background:rgba(255,255,255,0.4); border-color:rgba(0,0,0,0.06); }

/* Session group (document grouping) */
.session-group {
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:10px; margin-bottom:8px; overflow:hidden;
}
.session-group-header {
  display:flex; align-items:center; gap:8px;
  padding:10px 14px; cursor:pointer;
  transition:background 0.12s;
}
.session-group-header:hover { background:rgba(255,255,255,0.02); }
.session-group-name {
  flex:1; font-size:13px; font-weight:600; color:var(--text);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.session-group-count { font-family:var(--font-mono); font-size:9px; color:var(--text3); }
.session-group-chevron { font-size:10px; color:var(--text3); transition:transform 0.15s; display:inline-block; }
.session-group.collapsed .session-group-chevron { transform:rotate(-90deg); }
.session-group.collapsed .session-group-body { display:none; }
.session-group-body { padding:6px 8px; }

/* ── Staggered entrance animation ── */
@keyframes fadeSlideIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
.subj-item { animation: fadeSlideIn 0.2s ease both; }
.subj-item:nth-child(1) { animation-delay: 0.02s; }
.subj-item:nth-child(2) { animation-delay: 0.04s; }
.subj-item:nth-child(3) { animation-delay: 0.06s; }
.subj-item:nth-child(4) { animation-delay: 0.08s; }
.subj-item:nth-child(5) { animation-delay: 0.10s; }

/* ── SP action btn hover ── */
.sp-action-btn:hover { background: var(--glass-bg); color: var(--text); }

/* ── DS Table ── */
.ts-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 12px; }
.ts-table th { text-align: left; padding: 10px 14px; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--text3); border-bottom: 1px solid var(--glass-border); font-weight: 400; }
.ts-table td { padding: 10px 14px; color: var(--text); border-bottom: 1px solid rgba(255,255,255,0.03); }
.ts-table tr:hover td { background: rgba(255,255,255,0.02); }
.ts-table tr:last-child td { border-bottom: none; }

/* ── Recording Cards (migrated from embedded <style> in index.html) ── */
@keyframes recBlink { 0%,100%{opacity:1} 50%{opacity:0.3} }
@keyframes recCardPulse {
  0%,100% { box-shadow:0 0 0 0 var(--rec-pulse,rgba(220,38,38,0.4)); }
  50% { box-shadow:0 0 0 10px transparent; }
}
.rec-cards-grid { display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:24px;max-width:700px }
.rec-card {
  background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);
  padding:20px;text-align:center;cursor:pointer;transition:all 0.3s ease;position:relative;
}
.rec-card:hover:not(.dimmed) { border-color:var(--accent-border) }
.rec-card-icon { margin-bottom:8px }
.rec-card-title { font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text) }
.rec-card-sub { font-family:var(--font-mono);font-size:9px;color:var(--text3);margin-top:4px }
.rec-card-live { display:none;margin-top:16px;text-align:center }
.rec-cards-grid.recording { grid-template-columns:1fr }
.rec-card.active {
  border-color:rgba(220,38,38,0.5);animation:recCardPulse 2s ease-in-out infinite;
  padding:24px;
}
.rec-card.active .rec-card-live { display:block }
.rec-card.active .rec-card-sub::after { content:' — click to stop';color:var(--text3); }
.rec-card.dimmed { display:none }
.rec-mc-layout { display:flex;gap:24px }
.rec-mc-left { flex:1;min-width:0;max-width:700px }
.rec-mc-right { flex:1;min-width:320px;display:flex;flex-direction:column;gap:14px;position:sticky;top:16px;align-self:flex-start }
@media (max-width:1100px) { .rec-mc-layout{flex-direction:column} .rec-mc-right{width:100%;max-width:700px} }

/* ── Transcript Player & Segments (migrated from embedded <style>) ── */
@keyframes segSlideIn { from { opacity:0; transform:translateX(-8px) } to { opacity:1; transform:translateX(0) } }
@keyframes segGlow { 0%,100% { box-shadow:inset 0 0 12px rgba(79,142,247,0.06) } 50% { box-shadow:inset 0 0 20px rgba(79,142,247,0.12) } }
#transcriptPlayer { border-radius:var(--radius);overflow:hidden;margin-bottom:16px;position:relative;box-shadow:0 4px 20px rgba(0,0,0,0.2) }
#transcriptPlayer video, #transcriptPlayer audio { border-radius:var(--radius) }
#transcriptBody .seg-block {
  padding:8px 12px;border-radius:var(--radius-sm);border-left:3px solid transparent;
  transition:all 0.3s ease;cursor:pointer;margin:2px 0;
  position:relative;overflow:hidden;
}
#transcriptBody .seg-block:hover { background:var(--glass-hover);border-left-color:var(--glass-border); }
#transcriptBody .seg-block.seg-active {
  background:rgba(79,142,247,0.08);border-left-color:var(--accent);
  box-shadow:0 2px 8px rgba(79,142,247,0.08);animation:segGlow 3s ease-in-out infinite;
}
#transcriptBody .seg-block.seg-active .seg-time { color:var(--accent);font-weight:700; }
#transcriptBody .seg-block.seg-active .seg-text { color:var(--text) }
#transcriptBody .seg-block.seg-active::before {
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent2));
}
#transcriptBody .seg-block .seg-text { transition:color 0.3s }
#rlCrTranscriptPlayer { position:relative;border-radius:var(--radius);box-shadow:0 4px 20px rgba(0,0,0,0.2) }
#rlCrTranscriptPlayer video { display:block;width:100%;max-height:35vh;border-radius:var(--radius) }
#rlCrTranscriptPlayer audio { width:100%;border-radius:var(--radius) }
#rlCrTranscriptBody .seg-block { padding:6px 10px;border-radius:6px;border-left:2px solid transparent;transition:all 0.3s ease;cursor:pointer;margin:1px 0; }
#rlCrTranscriptBody .seg-block:hover { background:var(--glass-hover) }
#rlCrTranscriptBody .seg-block.seg-active { background:rgba(79,142,247,0.08);border-left-color:var(--accent) }
#rlCrTranscriptBody .seg-block.seg-active .seg-time { color:var(--accent);font-weight:700 }
.transcript-sync-badge {
  display:inline-flex;align-items:center;gap:6px;padding:3px 10px;
  background:rgba(79,142,247,0.1);border:1px solid rgba(79,142,247,0.2);
  border-radius:20px;font-family:var(--font-mono);font-size:8px;color:var(--accent);font-weight:600;
  letter-spacing:1px;text-transform:uppercase;
}
.transcript-sync-badge .sync-dot { width:5px;height:5px;background:var(--accent);border-radius:50%;animation:recBlink 1.5s infinite; }

/* ═══════════════════════════════════════════════════════════════════
   UTILITY CLASSES (from FIX_PROMPT_11)
   ═══════════════════════════════════════════════════════════════════ */

/* Layout utilities */
.flex { display:flex; }
.flex-col { flex-direction:column; }
.flex-1 { flex:1; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }
.items-center { align-items:center; }
.gap-4 { gap:4px; }
.gap-6 { gap:6px; }
.gap-8 { gap:8px; }
.gap-10 { gap:10px; }
.gap-12 { gap:12px; }
.gap-16 { gap:16px; }
.shrink-0 { flex-shrink:0; }
.min-h-0 { min-height:0; }
.overflow-hidden { overflow:hidden; }
.overflow-auto { overflow-y:auto; }
.hidden { display:none; }
.text-center { text-align:center; }
.w-full { width:100%; }
.cursor-pointer { cursor:pointer; }
.min-w-0 { min-width:0; }
.gap-3 { gap:3px; }
.gap-5 { gap:5px; }
.flex-gap-4 { display:flex;gap:4px; }
.flex-gap-8 { display:flex;gap:8px; }
.relative { position:relative; }
.inline-block { display:inline-block; }
.mb-5 { margin-bottom:5px; }
.mb-6 { margin-bottom:6px; }
.mb-20 { margin-bottom:20px; }
.justify-end { justify-content:flex-end; }
.svg-inline-sm { vertical-align:-2px;margin-right:4px; }
.flex-gap-12 { display:flex;align-items:center;gap:12px; }
.divider-v { width:1px;height:18px;background:var(--glass-border);margin:0 4px; }
.px-16 { padding-left:16px;padding-right:16px; }
.py-8 { padding-top:8px;padding-bottom:8px; }
.empty-state-mono { padding:12px;font-family:var(--font-mono);font-size:11px;color:var(--text3);text-align:center; }
.muted-tag { background:var(--glass-bg);color:var(--text2);font-size:10px; }
.p-0 { padding:0; }
.mb-10 { margin-bottom:10px; }
.mb-14 { margin-bottom:14px; }
.fw-500 { font-weight:500; }
.max-w-700 { max-width:700px; }
.icon-close-btn { width:26px;height:26px;border-radius:6px;border:1px solid var(--glass-border);background:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all 0.15s; }
.icon-close-btn:hover { border-color:rgba(239,68,68,0.3);color:var(--red); }
.icon-close-btn-lg { width:30px;height:30px;border-radius:8px;border:1px solid var(--glass-border);background:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all 0.15s; }
.icon-close-btn-lg:hover { border-color:rgba(239,68,68,0.3);color:var(--red); }
.mc-clear-btn { background:none;border:none;font-family:var(--font-mono);font-size:10px;color:var(--text3);cursor:pointer;padding:2px 6px;transition:color 0.15s; }
.mc-clear-btn:hover { color:var(--red); }
.qa-toggle-btn { padding:4px 8px;font-size:11px;border:1px solid var(--glass-border);background:none;border-radius:6px;margin:4px 4px 4px 6px;cursor:pointer;color:var(--text3);flex-shrink:0;transition:all 0.15s; }
.qa-toggle-btn:hover { border-color:var(--accent-border);color:var(--text2); }
.drop-zone { border:2px dashed var(--glass-border);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:all 0.2s;color:var(--text3);font-family:var(--font-mono);font-size:11px; }
.drop-zone:hover, .drop-zone.dragover { border-color:var(--accent-border);color:var(--accent);background:rgba(79,142,247,0.06); }

/* Spacing */
.mt-4 { margin-top:4px; }
.mt-8 { margin-top:8px; }
.mt-12 { margin-top:12px; }
.mt-16 { margin-top:16px; }
.mb-4 { margin-bottom:4px; }
.mb-8 { margin-bottom:8px; }
.mb-12 { margin-bottom:12px; }
.mb-16 { margin-bottom:16px; }
.p-8 { padding:8px; }
.p-12 { padding:12px; }
.p-16 { padding:16px; }

/* Typography */
.mono-xs { font-family:var(--font-mono); font-size:9px; color:var(--text3); letter-spacing:0.5px; }
.mono-sm { font-family:var(--font-mono); font-size:10px; color:var(--text3); }
.mono-label { font-family:var(--font-mono); font-size:10px; font-weight:700; color:var(--text3); letter-spacing:0.8px; }
.display-sm { font-family:var(--font-display); font-size:14px; font-weight:700; color:var(--text); }
.display-md { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--text); }
.body-sm { font-family:var(--font-body); font-size:11px; color:var(--text2); }
.body-md { font-family:var(--font-body); font-size:12px; color:var(--text2); }

/* Additional utilities — inline style removal */
.fs-11 { font-size:11px; }
.fs-12 { font-size:12px; }
.fs-13 { font-size:13px; }
.fs-14 { font-size:14px; }
.fs-10 { font-size:10px; }
.fs-15 { font-size:15px; }
.m-0 { margin:0; }
.flex-gap-6 { display:flex;gap:6px; }
.flex-gap-8 { display:flex;gap:8px; }
.flex-gap-10 { display:flex;align-items:center;gap:10px; }
.grid-2col { display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px; }
.section-label-sm { font-size:11px;text-transform:uppercase;letter-spacing:0.6px;color:var(--text2); }
.field-label { font-size:11px;text-transform:uppercase;letter-spacing:0.6px;color:var(--text2);margin-bottom:4px;display:block; }
.field-label-2 { font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:0.6px;margin-bottom:4px;display:block; }
.help-text { font-size:10px;color:var(--text2);line-height:1.5; }
.sub-text { font-size:11px;color:var(--text2);margin-top:2px; }
.text-muted { color:var(--text2); }
.flex-center-justify { flex:1;justify-content:center; }
.close-btn-plain { background:none;border:none;color:var(--text2);cursor:pointer;font-size:18px; }
.fw-400-dim { font-weight:400;opacity:0.6;font-size:11px; }
.heading-lg { font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text); }
.field-heading { font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;display:block; }
.mono-section-hdr { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:14px; }
.section-label-upper { font-family:var(--font-mono);font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px; }
.badge-amber { font-size:11px;background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.3);color:#f59e0b; }
.code-inline { background:var(--glass-bg);padding:1px 4px;border-radius:3px; }
.tag-sm { font-size:10px;padding:2px 8px; }
.flex-input-sm { flex:1;font-size:11px;padding:3px 6px; }
.gradient-sep { flex:1;height:1px;background:linear-gradient(90deg,var(--glass-border),transparent); }
.w-auto-m0 { width:auto;margin:0; }
.offscreen { position:absolute;left:-9999px;width:0;height:0;overflow:hidden; }
.tab-btn { padding:8px 18px;font-size:12px;font-weight:600;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;color:var(--text2); }
.tab-btn-display { padding:12px 16px;font-family:var(--font-display);font-size:13px;font-weight:600;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;color:var(--text3);transition:all 0.2s; }
.svg-inline { vertical-align:-2px;margin-right:6px; }
.modal-backdrop-dark { position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9999;justify-content:center;align-items:center; }
.modal-backdrop-darker { position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9999;align-items:center;justify-content:center; }
.modal-backdrop-darkest { position:fixed;inset:0;background:rgba(0,0,0,0.85);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9999;align-items:center;justify-content:center; }
.modal-panel { background:var(--bg-mid);border:1px solid var(--glass-border);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,0.5);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);animation:modalIn 0.25s ease; }
.light-theme .modal-panel { background:#fff;box-shadow:0 4px 20px rgba(0,0,0,0.08); }
.modal-header { padding:14px 20px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:10px;flex-shrink:0; }
.modal-header-between { padding:14px 20px;border-bottom:1px solid var(--glass-border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0; }
.modal-title { font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.modal-meta { font-size:11px;color:var(--text2);margin-top:2px; }
.modal-body-scroll { flex:1;overflow-y:auto;padding:16px 20px; }
.modal-footer { padding:12px 20px;border-top:1px solid var(--glass-border);display:flex;gap:8px;justify-content:flex-end;align-items:center;flex-shrink:0; }
.badge-purple { padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;background:rgba(79,142,247,0.15);color:var(--accent); }
.badge-blue { padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;background:rgba(79,142,247,0.15);color:var(--accent);flex-shrink:0; }
/* Additional label/heading variants */
.section-label-purple { font-size:10px;font-weight:700;color:var(--accent);margin-bottom:4px; }
.field-heading-sm { font-family:var(--font-mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);display:block;margin-bottom:6px; }
.field-heading-sm2 { font-size:12px;font-weight:600;display:block;margin-bottom:4px; }
.fw-600-12 { font-size:12px;font-weight:600; }
.field-label-dim { font-size:10px;font-weight:700;color:rgba(255,255,255,0.4);letter-spacing:0.5px;margin-bottom:4px;display:block; }
.meta-xs { font-size:9px;color:var(--text2);white-space:nowrap; }

.form-select-sm { font-size:11px;padding:3px 4px;flex:1;border-radius:4px;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text2); }

.display-sub { font-family:var(--font-display);font-size:13px;color:var(--text2); }
.eml-body { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:12px;font-size:13px;white-space:pre-wrap;line-height:1.6;max-height:300px;overflow-y:auto;color:var(--text); }

/* Help guide callouts */
.help-callout-blue { background:rgba(79,142,247,0.06);border:1px solid rgba(79,142,247,0.2);border-radius:10px;padding:14px 18px;margin-bottom:20px;font-size:12px;color:var(--text2);line-height:1.7; }
.help-callout-green { background:linear-gradient(135deg,rgba(56,161,105,0.08),rgba(229,62,62,0.06));border:1px solid rgba(56,161,105,0.2);border-radius:10px;padding:14px 18px;margin-bottom:20px;font-size:12px;color:var(--text2);line-height:1.7; }
.help-callout-purple { margin-top:4px;padding:12px 16px;background:rgba(167,139,250,0.07);border:1px solid rgba(167,139,250,0.2);border-radius:8px;font-size:12px;color:var(--text2);line-height:1.7; }
.help-summary-box { margin-top:16px;padding:12px 16px;background:var(--glass-bg);border-radius:8px;font-size:12px;color:var(--text2);line-height:1.7; }
.help-card-span-blue { grid-column:span 2;border-color:rgba(79,142,247,0.3);background:rgba(79,142,247,0.04); }
.help-card-span-purple { grid-column:span 2;border-color:rgba(79,142,247,0.3);background:rgba(79,142,247,0.04); }
.help-card-span-teal { grid-column:span 2;border-color:rgba(56,178,172,0.3);background:rgba(56,178,172,0.04); }
.mt-14 { margin-top:14px; }

/* ── Workspace / Chat inline-style migrations ── */

/* Settings active tab (JS toggles this) */
.tab-btn-active { padding:8px 18px;font-size:12px;font-weight:600;border:none;background:none;cursor:pointer;border-bottom:2px solid var(--accent);color:var(--accent); }

/* Settings general tab pane */
.ws-settings-pane { flex:1;overflow-y:auto;padding:4px 8px; }

/* AI mode / option card */
.ws-option-card { display:flex;align-items:center;gap:10px;cursor:pointer;padding:10px 12px;border-radius:8px;border:1px solid var(--glass-border);background:var(--glass-bg); }

/* Temp group glass card */
.ws-glass-card { margin-top:14px;padding:12px;border-radius:8px;border:1px solid var(--glass-border);background:var(--glass-bg); }

/* Temp label with badge */
.ws-temp-label { font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;display:flex;align-items:center;gap:8px; }

/* Temp badge */
.ws-temp-badge { font-size:10px;padding:2px 8px;border-radius:10px;font-weight:700;letter-spacing:0.3px; }

/* Temp value display */
.ws-temp-val { font-size:12px;font-weight:600;color:var(--accent);margin-bottom:6px; }

/* Temp note at bottom */
.ws-temp-note { font-size:10px;color:var(--text2);margin-top:8px;opacity:0.7; }

/* Theme swatches row */
.ws-swatch-row { display:flex;gap:10px;flex-wrap:wrap;align-items:center; }
.settings-theme-label { font-family:var(--font-mono);font-size:9px;color:var(--text3);letter-spacing:0.5px;margin-bottom:6px; }
.settings-theme-section { margin-top:4px; }

/* Theme swatch button */
.ws-theme-swatch { width:44px;height:44px;border-radius:10px;border:2px solid transparent;cursor:pointer;padding:0; }

/* Hint text below a control */
.ws-hint { font-size:11px;color:var(--text2);margin-top:6px; }
.ws-hint-4 { font-size:11px;color:var(--text2);margin-top:4px;line-height:1.5; }

/* Connections section block label */
.ws-conn-label { font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;display:block; }

/* Connections section hint */
.ws-conn-hint { font-size:11px;color:var(--text2);margin-bottom:10px;line-height:1.6; }

/* Connections bordered section */
.ws-conn-section { border-top:1px solid var(--glass-border);padding-top:12px;margin-top:12px; }

/* IMAP grid */
.ws-grid-email-port { display:grid;grid-template-columns:1fr 80px;gap:8px;margin-bottom:8px; }

/* Profile 2-col grid */
.ws-grid-2col-gap10 { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px; }
.ws-grid-2col-gap10-nomargin { display:grid;grid-template-columns:1fr 1fr;gap:10px; }

/* Team member list */
.ws-team-list { display:flex;flex-direction:column;gap:6px;margin-bottom:16px; }

/* Add member form card */
.ws-add-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:12px; }

/* Voice master toggle row */
.ws-voice-toggle-row { display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:10px;border:1px solid var(--glass-border);background:var(--glass-bg); }

/* Toggle switch wrapper */
.ws-toggle-switch { position:relative;display:inline-block;width:44px;height:24px;cursor:pointer;flex-shrink:0;margin-left:12px; }

/* Toggle hidden input */
.ws-toggle-input { opacity:0;width:0;height:0; }

/* Toggle track */
.ws-toggle-track { position:absolute;inset:0;background:var(--glass-border);border-radius:12px;transition:all 0.2s; }

/* Toggle knob */
.ws-toggle-knob { position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:all 0.2s;box-shadow:0 1px 3px rgba(0,0,0,0.3); }

/* Voice test result */
.ws-test-result { font-size:11px;margin-left:8px; }

/* Voice option label */
.ws-voice-option { display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--text);margin-bottom:6px; }

/* Voice sub-note */
.ws-voice-sub-note { font-size:11px;color:var(--text2);margin:-2px 0 4px 24px; }

/* Speed label */
.ws-speed-label { font-size:12px;color:var(--text);white-space:nowrap; }

/* Speed value display */
.ws-speed-val { font-size:12px;color:var(--text2);min-width:32px; }

/* Kbd key */
.ws-kbd { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:4px;padding:2px 6px;font-size:11px; }

/* Settings footer */
.ws-settings-footer { display:flex;gap:8px;justify-content:flex-end;margin-top:12px;flex-shrink:0;border-top:1px solid var(--glass-border);padding-top:12px; }

/* Contacts modal */
.ws-contacts-modal { width:760px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden; }

/* Contacts tab bar */
.ws-contacts-tabs { display:flex;border-bottom:1px solid var(--glass-border);margin-bottom:14px;flex-shrink:0; }

/* Contacts active tab */
.ws-contacts-tab-active { padding:8px 18px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:600;border-bottom:2px solid var(--accent);color:var(--accent);margin-bottom:-1px; }

/* Contacts inactive tab */
.ws-contacts-tab { padding:8px 18px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:600;border-bottom:2px solid transparent;color:var(--text2);margin-bottom:-1px; }

/* Contacts pane flex container */
.ws-contacts-pane { display:flex;flex-direction:column;flex:1;overflow:hidden; }

/* Contacts search row */
.ws-contacts-search-row { display:flex;gap:8px;margin-bottom:12px;flex-shrink:0; }

/* Contact list / book list */
.ws-contact-list { flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px; }

/* Add contact form card */
.ws-add-contact-form { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:14px;margin-bottom:12px;flex-shrink:0; }

/* Contact edit modal */
.ws-contact-edit-modal { width:520px; }

/* Contact edit header */
.ws-modal-header-flex { display:flex;align-items:center;justify-content:space-between;margin-bottom:14px; }

/* Contact edit textarea */
.ws-textarea-notes { resize:vertical;margin-bottom:10px; }

/* Contact edit checkbox label */
.ws-checkbox-label { display:flex;align-items:center;gap:8px;margin-bottom:14px;cursor:pointer;font-size:13px;color:var(--text2); }

/* Contact edit checkbox */
.ws-checkbox-md { width:16px;height:16px;cursor:pointer; }

/* Redline modal full screen */
.ws-rl-modal { position:fixed;inset:0;z-index:10000;flex-direction:column; }

/* ── Modal Header — design system ── */
.ws-rl-header { display:flex;align-items:center;gap:14px;padding:10px 20px;background:rgba(10,10,15,0.7);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,0.06);flex-shrink:0;position:relative;z-index:200; }
.ws-rl-logo { display:flex;align-items:center;gap:10px;flex-shrink:0; }
.ws-rl-logo svg { width:18px;height:18px; }
.ws-rl-title { font-family:'Rajdhani','Segoe UI',sans-serif;font-size:18px;font-weight:700;color:#d4a847;letter-spacing:1px; }
.ws-rl-docname { font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:0.5px;padding:3px 10px;border-radius:6px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px; }
.ws-rl-close { width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:none;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all 0.15s;flex-shrink:0; }
.ws-rl-close:hover { border-color:rgba(248,113,113,0.3);color:#f87171; }

/* Legacy — keep for export btn until migrated */
.ws-rl-export-btn { font-family:var(--font-mono);font-size:11px;font-weight:600;background:linear-gradient(135deg,var(--emerald),#2f9e68);border:none;border-radius:8px;padding:5px 14px;color:#fff;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px; }

/* Redline instruct panel */
.ws-rl-instruct { flex:1;overflow-y:auto;display:flex;flex-direction:column;justify-content:flex-start; }

/* Redline workflow selector */
.ws-rl-workflow { max-width:900px;width:100%;margin:0 auto;padding:32px; }

/* Redline workflow heading */
.ws-rl-wf-heading { font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:1px; }

/* Redline workflow subtext */
.ws-rl-wf-sub { font-family:var(--font-mono);font-size:11px;color:var(--text3);margin-bottom:22px;letter-spacing:0.5px; }

/* Prior sessions section */
.ws-rl-prior { border-top:1px solid var(--glass-border);padding-top:18px; }

/* Prior sessions header row */
.ws-rl-prior-hdr { display:flex;align-items:center;gap:10px;margin-bottom:12px; }

/* Prior sessions label */
.ws-rl-prior-label { font-family:var(--font-mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text3); }

/* Show archived label */
.ws-rl-archive-label { display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text2);cursor:pointer; }

/* ── Toolbar / Action Bar — design system ── */
.ws-rl-status-bar { display:flex;align-items:center;gap:8px;padding:7px 16px;background:rgba(10,10,15,0.3);border-bottom:1px solid rgba(255,255,255,0.06);flex-shrink:0;position:relative;z-index:200; }
.ws-rl-btn { font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:0.5px;padding:5px 12px;border-radius:6px;border:1px solid rgba(255,255,255,0.06);background:none;color:#475569;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap; }
.ws-rl-btn:hover { border-color:rgba(56,189,248,0.3);color:#64748b; }
.ws-rl-btn svg { width:12px;height:12px;flex-shrink:0; }
.ws-rl-back-btn { padding-left:8px; }
.ws-rl-spacer { flex:1; }
.ws-rl-sep { width:1px;height:18px;background:rgba(255,255,255,0.06);flex-shrink:0; }
.ws-rl-btn-accent { color:var(--accent);border-color:rgba(79,142,247,0.3); }
.ws-rl-btn-accent:hover { border-color:rgba(79,142,247,0.5);background:rgba(79,142,247,0.06); }
.ws-rl-btn-success { color:var(--emerald);border-color:rgba(52,211,153,0.3); }
.ws-rl-btn-success:hover { border-color:rgba(52,211,153,0.5);color:var(--emerald); }
.ws-rl-btn-danger { color:var(--red);border-color:rgba(248,113,113,0.3); }
.ws-rl-btn-danger:hover { border-color:rgba(248,113,113,0.5);color:var(--red); }
.ws-rl-btn-warn { color:var(--amber, #d97706);border-color:rgba(217,119,6,0.3); }
.ws-rl-btn-warn:hover { border-color:rgba(217,119,6,0.5);background:rgba(217,119,6,0.06); }
.rl-word-mode-btn { font-family:'Share Tech Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.5px;padding:5px 14px;border-radius:6px;border:1px solid rgba(56,189,248,0.25);background:rgba(56,189,248,0.06);color:#38bdf8;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap; }
.rl-word-mode-btn:hover { border-color:rgba(56,189,248,0.4);background:rgba(56,189,248,0.1); }
.rl-word-mode-btn svg { width:14px;height:14px;flex-shrink:0; }
.ws-rl-dropdown { position:relative;display:inline-block;z-index:200; }
.ws-rl-drop-btn { font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:0.5px;padding:5px 12px;border-radius:6px;border:1px solid rgba(255,255,255,0.06);background:none;color:#475569;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap; }
.ws-rl-drop-btn:hover { border-color:rgba(56,189,248,0.3);color:#64748b; }
.ws-rl-sessions-drop { position:absolute;top:calc(100% + 4px);right:0;min-width:200px;max-height:240px;overflow-y:auto;background:rgba(13,17,23,0.97);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:6px;box-shadow:0 8px 32px rgba(0,0,0,0.4);z-index:200;scrollbar-width:thin;scrollbar-color:rgba(56,189,248,0.15) transparent; }
.light-theme .ws-rl-sessions-drop { background:#fff;border-color:rgba(0,0,0,0.12);box-shadow:0 4px 16px rgba(0,0,0,0.1); }
.ws-rl-drop-item { font-family:'Share Tech Mono',monospace;font-size:10px;color:#64748b;padding:7px 10px;border-radius:6px;cursor:pointer;transition:all 0.12s;display:flex;align-items:center;gap:8px;white-space:nowrap; }
.ws-rl-drop-item:hover { background:rgba(255,255,255,0.04);color:#e6edf3; }
.ws-rl-drop-item.active { background:rgba(56,189,248,0.06);color:#38bdf8;border-left:2px solid #38bdf8; }
.ws-rl-drop-badge { font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:0.5px;padding:2px 6px;border-radius:4px;background:rgba(79,142,247,0.1);color:var(--accent);flex-shrink:0;border:1px solid rgba(79,142,247,0.2); }
.ws-rl-drop-badge.compare { background:rgba(212,168,71,0.1);color:var(--gold);border-color:rgba(212,168,71,0.2); }
.ws-rl-drop-badge.redline { background:rgba(0,0,0,0.7);color:#fff;border-color:rgba(0,0,0,0.3); }
.ws-rl-drop-name { font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1; }
.ws-rl-drop-date { font-family:var(--font-mono);font-size:9px;color:var(--text3);flex-shrink:0; }
.ws-rl-drop-active { font-family:var(--font-mono);font-size:10px;font-weight:600;padding:7px 10px;border-radius:6px;margin-top:4px;background:rgba(79,142,247,0.08);border:1px solid rgba(79,142,247,0.2);color:var(--accent);text-align:center;cursor:pointer; }
.ws-rl-drop-new { font-family:var(--font-mono);font-size:10px;letter-spacing:0.5px;padding:7px 10px;border-radius:6px;margin-top:4px;border:1px dashed var(--glass-border);background:none;color:var(--text2);cursor:pointer;transition:all 0.15s;text-align:center;width:100%; }
.ws-rl-drop-new:hover { border-color:var(--accent);color:var(--accent); }
.light-theme .ws-rl-drop-item { color:var(--text2); }
.light-theme .ws-rl-drop-item:hover { background:rgba(0,0,0,0.04);color:var(--text); }
.light-theme .ws-rl-drop-item.active { background:rgba(79,142,247,0.06);color:var(--accent);border-left-color:var(--accent); }
.light-theme .ws-rl-drop-badge.redline { background:rgba(0,0,0,0.85);color:#fff; }
.light-theme .ws-rl-drop-new { border-color:rgba(0,0,0,0.12); }
.rl-model-toggle { display:inline-flex;border-radius:14px;border:1px solid rgba(255,255,255,0.06);overflow:hidden;flex-shrink:0; }
.rl-model-opt { font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:0.5px;padding:4px 12px;border:none;background:none;color:#475569;cursor:pointer;transition:all 0.15s; }
.rl-model-opt.active { background:rgba(56,189,248,0.1);color:#38bdf8; }

/* Review body flex row */
.ws-rl-body { display:flex;flex:1;min-height:0;overflow:hidden; }

/* Changes panel */
.ws-rl-changes-panel { flex:0 0 50%;display:flex;flex-direction:column;border-right:1px solid var(--glass-border);overflow:hidden; }

/* Changes panel tabs */
.ws-rl-changes-tabs { display:flex;border-bottom:1px solid var(--glass-border);flex-shrink:0;padding:0 8px;overflow-x:auto;background:rgba(10,10,15,0.3); }

/* Redline tab button (active) */
.ws-rl-tab-active { padding:10px 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;border:none;background:none;cursor:pointer;border-bottom:2px solid var(--accent);color:var(--accent);transition:color 0.2s;position:relative;white-space:nowrap;flex-shrink:0; }

/* Redline tab button (inactive) */
.ws-rl-tab { padding:10px 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;color:var(--text3);transition:color 0.2s;position:relative;white-space:nowrap;flex-shrink:0; }
.ws-rl-tab:hover { color:var(--text2); }

/* Notes count badge — style the span inside, not the button */
.ws-rl-notes-count span { background:rgba(245,158,11,0.15);color:var(--amber);border-radius:8px;padding:0px 5px;font-size:10px;margin-left:2px; }

/* Contact filter select */
.ws-contact-filter { min-width:160px; }

/* Margin-right auto */
.mr-auto { margin-right:auto; }

/* White-space nowrap */
.nowrap { white-space:nowrap; }

/* Font-size utilities */
.fs-9 { font-size:9px; }
.fs-10 { font-size:10px; }

/* Margin 6px */
.m-6 { margin:6px; }

/* Margin-bottom 10px */
.mb-10 { margin-bottom:10px; }

/* Contacts modal header flex row */
.ws-modal-header-between { display:flex;align-items:center;justify-content:space-between;flex-shrink:0;margin-bottom:12px; }

/* ── Right Panel inline-style extractions ── */
.rp-subjects-width { width:var(--subjects-w,230px); }
.rp-project-selector { padding:8px 10px;border-bottom:1px solid var(--glass-border);position:relative; }
.rp-project-current { display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;background:rgba(212,168,71,0.04);border:1px solid rgba(212,168,71,0.12);cursor:pointer;transition:all 0.2s; }
.rp-project-dot { width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 6px rgba(212,168,71,0.4);flex-shrink:0; }
.rp-project-name { font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.rp-dropdown-arrow { color:var(--text3);font-size:10px; }
.rp-subjects-hdr-label { font-family:var(--font-mono);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text2); }
.rp-sp-add-btn { width:24px;height:24px;border-radius:6px;border:1px solid var(--glass-border);background:rgba(79,142,247,0.08);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all 0.2s; }
.rp-search-wrap { padding:8px 10px;border-bottom:1px solid var(--glass-border); }
input.rp-subject-search { width:100%;font-size:11px;padding:6px 10px;font-family:var(--font-mono);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:6px;color:var(--text);outline:none;transition:border-color 0.2s;box-sizing:border-box; }
input.rp-subject-search::placeholder { color:var(--text3); }
input.rp-subject-search:focus { border-color:var(--accent-border); }
.rp-empty-msg { padding:12px 8px;font-size:12px;color:var(--text2); }
.rp-subjects-footer { padding:8px;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:4px; }
.rp-ai-label { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);padding:4px 8px; }
.rp-sp-action-btn { display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;font-family:var(--font-mono);font-size:11px;border:none;background:none;color:var(--text2);cursor:pointer;transition:all 0.15s;width:100%;text-align:left; }
.rp-icon-dim { opacity:0.6; }
.rp-topbar-actions { display:flex;align-items:center;gap:6px; }
.rp-chat-tb-btn { font-family:var(--font-mono);font-size:10px;padding:4px 10px;border-radius:5px;border:1px solid var(--glass-border);background:none;color:var(--text3);cursor:pointer;transition:all 0.15s; }
.rp-pending-banner { padding:8px 16px;background:rgba(245,158,11,0.1);border-bottom:1px solid rgba(245,158,11,0.3);font-size:12px;color:var(--amber);flex-shrink:0;align-items:center;gap:8px; }
.rp-review-btn { font-size:10px;padding:2px 8px;flex-shrink:0; }
.rp-dismiss-btn { background:none;border:none;cursor:pointer;color:var(--text2);font-size:14px;flex-shrink:0;padding:0 2px; }
.rp-qa-bar { padding:6px 16px;display:flex;flex-wrap:wrap;gap:5px;border-bottom:1px solid var(--glass-border);flex-shrink:0; }
.rp-trim-banner { padding:5px 16px;background:rgba(245,158,11,0.08);border-top:1px solid rgba(245,158,11,0.25);font-size:11px;color:var(--amber);flex-shrink:0;align-items:center;gap:6px; }
.rp-trim-suffix { color:var(--text2);margin-left:2px; }
.rp-stop-btn { background:#dc2626; }
.ctx-picker-hdr { padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(79,142,247,0.1);background:rgba(79,142,247,0.03);flex-shrink:0;position:sticky;top:0;z-index:2; }
.ctx-picker-ttl { font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--accent);letter-spacing:0.5px;flex:1; }
.ctx-picker-mode-toggle { display:flex;border:1px solid rgba(79,142,247,0.25);border-radius:10px;overflow:hidden;cursor:pointer;flex-shrink:0; }
.ctx-picker-mode-label { padding:2px 8px;font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:0.3px;transition:all 0.2s; }
.ctx-picker-token-badge { font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--accent);background:rgba(79,142,247,0.1);padding:2px 8px;border-radius:8px; }
.ctx-picker-close { background:none;border:none;color:var(--text2);cursor:pointer;font-size:14px;padding:0 2px; }
.ctx-picker-body { max-height:240px;overflow-y:auto;padding:8px; }
.ctx-picker-empty { text-align:center;padding:20px;color:var(--text2);font-family:var(--font-mono);font-size:11px; }
.ctx-picker-ftr { padding:6px 12px;border-top:1px solid rgba(79,142,247,0.1);display:flex;align-items:center;gap:8px; }
.ctx-picker-bar-track { flex:1;height:4px;border-radius:2px;background:rgba(255,255,255,0.04);overflow:hidden; }
.ctx-picker-bar-fill { height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent));border-radius:2px;transition:width 0.3s; }
.ctx-picker-cost { font-family:var(--font-mono);font-size:9px;color:var(--text3); }
.rp-suggest-btn { font-family:var(--font-mono);font-size:9px;padding:3px 8px;letter-spacing:0.5px; }
.rp-issues-scroll { flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0; }
.rp-suggested-hdr { font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between; }
.rp-clear-btn { font-size:11px;padding:2px 7px; }
.rp-notes-filter { font-size:10px;padding:2px 5px;border-radius:5px;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text);font-family:var(--font-mono); }
.rp-notes-scroll { flex:1;overflow-y:auto;min-height:0; }
.rp-notes-footer-btns { display:flex;gap:6px;margin-bottom:4px; }
.rp-note-title-input { margin-bottom:6px;font-weight:600; }
.rp-note-textarea { margin-bottom:6px;resize:vertical; }
.rp-note-fields { display:flex;gap:6px;margin-bottom:6px; }
.rp-note-link-label { font-size:11px;color:var(--text2);display:flex;align-items:center;gap:6px;margin-bottom:6px; }
.rp-issue-textarea { margin-bottom:6px;resize:vertical; }
.rp-doc-panel-rel { position:relative; }
.rp-drop-overlay { position:absolute;inset:0;z-index:10;background:rgba(10,10,15,0.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px dashed var(--accent);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none; }
.rp-drop-label { color:var(--accent);font-weight:600;font-size:14px;font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase; }
.light-theme .rp-drop-overlay { background:rgba(255,255,255,0.8); }
.rp-pane-full { height:100%; }
.rp-due-flex { flex:1.2; }
.rp-hidden-compat { display:none; }
.rp-suggested-section { border-top:1px solid var(--glass-border);padding:8px; }

/* ── Transcription section ── */
.ts-tab-bar { display:flex;border-bottom:1px solid var(--glass-border);flex-shrink:0;padding:0 8px;gap:4px;align-items:center; }
.ts-tab-active { padding:12px 16px;font-family:var(--font-display);font-size:13px;font-weight:600;border:none;background:none;cursor:pointer;border-bottom:2px solid var(--accent);color:var(--accent);transition:all 0.2s; }
.ts-rec-indicator { width:6px;height:6px;background:#dc2626;border-radius:50%;margin-right:4px;animation:recBlink 1s infinite;display:inline-block; }
.ts-tab-divider { width:1px;height:16px;background:var(--glass-border);margin:0 8px; }
.ts-max-w-800 { max-width:800px; }
.ts-mt-20 { margin-top:20px; }
.ts-flex-wrap-gap-8 { display:flex;flex-wrap:wrap;gap:8px; }
.ts-drop-hint { font-size:9px;color:var(--text3);margin-top:4px;display:inline-block; }
.ts-section-label { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:6px; }
.ts-form-input { width:100%;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:8px 12px;font-family:var(--font-display);font-size:13px;color:var(--text);outline:none;transition:border-color 0.2s;box-sizing:border-box; }
.ts-form-input:focus { border-color:var(--accent-border); }
.ts-checkbox-label { display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;color:var(--text3);cursor:pointer; }
.ts-accent-check { accent-color:var(--accent); }
.ts-wave-wrap { height:60px;background:var(--glass-bg);border-radius:10px;overflow:hidden;position:relative;border:1px solid var(--glass-border); }
.ts-wave-canvas { width:100%;height:100%; }
.ts-wave-label { position:absolute;bottom:3px;right:8px;font-size:8px;font-weight:700;color:rgba(255,255,255,0.2);letter-spacing:1px;text-transform:uppercase; }
.ts-timer { font-size:32px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--accent);margin:8px 0;font-family:var(--font-mono);letter-spacing:4px;opacity:0.5; }
.ts-live-header { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:8px;display:flex;align-items:center;gap:8px; }
.ts-live-dot { width:8px;height:8px;background:#dc2626;border-radius:50%;animation:recBlink 1s infinite; }
.ts-live-text { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;max-height:300px;overflow-y:auto;white-space:pre-wrap;font-size:13px;line-height:1.7;color:var(--text);min-height:60px; }
.ts-mt-32 { margin-top:32px; }
.ts-mt-16 { margin-top:16px; }
.ts-flex-col-gap-6 { display:flex;flex-direction:column;gap:6px; }
.ts-mc-label { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:10px; }
.ts-glass-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:14px; }
.ts-mc-sub-label { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:10px;display:flex;align-items:center;gap:8px; }
.ts-speaker-count { font-size:8px;color:var(--text3); }
.ts-speaker-list { display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px; }

/* Speaker tag chips — 3 states */
.mc-speaker-tag {
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;
  border-radius:var(--radius-sm);
  font-family:var(--font-display);font-size:13px;font-weight:500;
  white-space:nowrap;
  transition:background 0.15s, border-color 0.15s, transform 0.1s;
}
.mc-speaker-tag svg.mc-tag-icon { width:16px;height:16px;flex-shrink:0; }

/* State: Normal (not recording) */
.mc-speaker-tag--normal {
  background:rgba(79,142,247,0.08);
  border:1px solid rgba(79,142,247,0.12);
  color:var(--text);
}

/* State: Untagged (recording, clickable) */
.mc-speaker-tag--untagged {
  background:rgba(79,142,247,0.1);
  border:1px solid rgba(79,142,247,0.25);
  color:var(--text);
  cursor:pointer;
}
.mc-speaker-tag--untagged:hover {
  background:rgba(79,142,247,0.18);
  border-color:rgba(79,142,247,0.4);
  transform:translateY(-1px);
}
.mc-speaker-tag__label {
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  color:var(--accent);letter-spacing:0.5px;
  padding:2px 6px;border-radius:4px;
  background:rgba(79,142,247,0.12);
}

/* State: Tagged (recording, active/green) */
.mc-speaker-tag--tagged {
  background:rgba(34,197,94,0.14);
  border:1px solid rgba(34,197,94,0.3);
  color:var(--emerald);
}
.mc-speaker-tag__time {
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  opacity:0.8;
}

/* Remove / Untag button inside tags */
.mc-speaker-tag__btn {
  background:none;border:none;cursor:pointer;
  padding:2px;margin-left:2px;line-height:1;
  border-radius:50%;transition:background 0.15s, color 0.15s;
  display:inline-flex;align-items:center;justify-content:center;
}
.mc-speaker-tag__btn svg { width:11px;height:11px; }
.mc-speaker-tag--normal .mc-speaker-tag__btn { color:var(--text3); }
.mc-speaker-tag--normal .mc-speaker-tag__btn:hover { color:var(--red);background:rgba(239,68,68,0.1); }
.mc-speaker-tag--tagged .mc-speaker-tag__btn { color:var(--emerald); }
.mc-speaker-tag--tagged .mc-speaker-tag__btn:hover { color:var(--red);background:rgba(239,68,68,0.1); }
.ts-no-speakers { font-family:var(--font-mono);font-size:10px;color:var(--text3);padding:4px 0; }
.ts-mc-input { flex:1;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:6px 10px;font-family:var(--font-display);font-size:12px;color:var(--text);outline:none;box-sizing:border-box;transition:border-color 0.2s; }
.ts-mc-input:focus { border-color:var(--accent-border); }
.ts-notes-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:14px;flex:1;display:flex;flex-direction:column; }
.ts-notes-header { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between; }
.ts-notes-saved { font-size:8px;color:var(--emerald);opacity:0;transition:opacity 0.3s; }
.ts-notes-textarea { width:100%;flex:1;min-height:400px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:12px 14px;font-family:var(--font-display);font-size:13px;color:var(--text);outline:none;resize:vertical;box-sizing:border-box;line-height:1.7;transition:border-color 0.2s; }
.ts-notes-textarea:focus { border-color:var(--accent-border); }
.ts-inline-player { background:#000;text-align:center;margin-bottom:16px;border-radius:var(--radius);overflow:hidden; }
.ts-file-info { margin-bottom:16px;font-family:var(--font-display);font-size:13px;color:var(--text2); }
.ts-progress-card { margin-top:20px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px; }
.ts-progress-label { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:10px; }
.ts-progress-msg { font-family:var(--font-display);font-size:13px;color:var(--text);margin-bottom:8px; }
.ts-pick-section { margin-bottom:12px; }
.ts-no-transcript { text-align:center;padding:60px 20px;color:var(--text3); }
.ts-no-transcript svg { margin-bottom:12px;opacity:0.5; }
.ts-no-transcript-hint { font-family:var(--font-mono);font-size:9px;color:var(--text3);margin-top:4px; }
.ts-transcript-player { text-align:center;margin-bottom:12px; }
.ts-transcript-player video { max-height:40vh;max-width:100%;margin:0 auto;display:block;background:#000;border-radius:var(--radius); }
.ts-transcript-player audio { width:100%;box-sizing:border-box; }
.ts-transcript-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px; }
.ts-transcript-header { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:12px; }
.ts-transcript-title { font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text); }
.ts-transcript-dash { font-family:var(--font-mono);font-size:10px;color:var(--text3); }
.ts-speaker-panel { margin-bottom:14px;padding:12px;background:var(--glass-bg);border-radius:var(--radius-sm);border:1px solid var(--glass-border); }
.ts-apply-names-btn { font-size:10px;padding:5px 12px;margin-top:8px;border-color:rgba(34,197,94,0.3);color:var(--emerald); }
.ts-go-review-btn { font-size:10px;padding:5px 12px;margin-top:6px;border-color:rgba(79,142,247,0.3);color:var(--accent);background:rgba(79,142,247,0.06); }
.ts-go-review-btn:hover { background:rgba(79,142,247,0.12);border-color:rgba(79,142,247,0.5); }

/* Recent transcript cards */
.rec-transcript-card { display:flex;align-items:center;gap:10px; }
.rec-mode-badge { font-family:var(--font-mono);font-size:10px;padding:3px 8px;border-radius:4px;border:1px solid;flex-shrink:0;letter-spacing:0.5px; }
.rec-transcript-name { flex:1;min-width:0;cursor:pointer; }
.rec-transcript-date { font-family:var(--font-mono);font-size:9px;color:var(--text3);flex-shrink:0;white-space:nowrap; }
.rec-transcript-action { background:none;border:none;color:var(--text3);cursor:pointer;padding:4px;flex-shrink:0;transition:color 0.15s; }
.rec-transcript-action:hover { color:var(--accent); }
.rec-transcript-action--danger:hover { color:var(--red); }
.text-truncate { white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }

/* Meeting groups in recent transcripts */
.rec-meeting-group { border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden;margin-bottom:6px; }
.rec-meeting-header { display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(108,99,255,0.04);cursor:pointer;transition:background 0.15s; }
.rec-meeting-header:hover { background:rgba(108,99,255,0.08); }
.rec-meeting-chevron { flex-shrink:0;transition:transform 0.2s;color:var(--text3); }
.rec-meeting-group.collapsed .rec-meeting-chevron { transform:rotate(-90deg); }
.rec-meeting-group.collapsed .rec-meeting-recordings { display:none; }
.rec-meeting-title { font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--text);flex:1; }
.rec-meeting-count { font-family:var(--font-mono);font-size:9px;color:var(--text3);flex-shrink:0; }
.rec-meeting-recordings { border-top:1px solid var(--glass-border); }
.rec-meeting-recordings > .rec-order-num { margin-left:8px; }
.rec-meeting-rec-row { display:flex;align-items:center;gap:0;border-bottom:1px solid rgba(255,255,255,0.03); }
.rec-meeting-rec-row:last-child { border-bottom:none; }
.rec-meeting-rec-row .rec-transcript-card { flex:1;padding:6px 12px; }
.rec-view-stitch-btn { font-family:var(--font-mono);font-size:9px;padding:2px 8px;border-radius:4px;border:1px solid rgba(34,197,94,0.25);background:rgba(34,197,94,0.08);color:var(--emerald);cursor:pointer;flex-shrink:0;transition:background 0.15s; }
.rec-view-stitch-btn:hover { background:rgba(34,197,94,0.16); }
.rec-stitch-btn { font-family:var(--font-mono);font-size:9px;padding:2px 8px;border-radius:4px;border:1px solid rgba(108,99,255,0.25);background:rgba(108,99,255,0.08);color:var(--accent2);cursor:pointer;flex-shrink:0;transition:background 0.15s; }
.rec-stitch-btn:hover { background:rgba(108,99,255,0.16); }
.rec-order-num { font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--accent2);width:16px;text-align:center;flex-shrink:0; }
.rec-reorder-btns { display:flex;flex-direction:column;gap:1px;flex-shrink:0; }

/* Transcript panel — parent/child cards (matches session-card style) */
.trans-panel-group { margin-bottom:4px; }
.trans-panel-parent {
  background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:10px;padding:10px 14px;margin-bottom:4px;
  display:flex;align-items:center;gap:8px;
  cursor:pointer;transition:all 0.15s;
}
.trans-panel-parent:hover { border-color:var(--accent-border);background:var(--glass-hover); }
.light-theme .trans-panel-parent { background:#fff;box-shadow:0 1px 3px rgba(0,0,0,0.04); }
.trans-panel-parent-name { font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.trans-panel-count { font-family:var(--font-mono);font-size:9px;color:var(--text3);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:4px;padding:1px 5px;flex-shrink:0; }
.trans-panel-children { padding-left:12px;margin-left:8px;border-left:2px solid rgba(79,142,247,0.15); }
.trans-panel-child {
  background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:8px;padding:7px 12px;margin-bottom:3px;
  display:flex;align-items:center;gap:6px;
  cursor:pointer;transition:all 0.15s;
}
.trans-panel-child:hover { border-color:var(--accent-border);background:var(--glass-hover); }
.light-theme .trans-panel-child { background:#fff; }
.trans-panel-child-name { font-family:var(--font-display);font-size:11px;color:var(--text2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.trans-panel-child-meta { font-family:var(--font-mono);font-size:8px;color:var(--text3);flex-shrink:0; }

/* Note cards in WF1 */
.cr-notes-empty { font-size:12px;color:var(--text3);padding:16px;text-align:center; }
.cr-note-card {
  background:var(--bg-surface, #1a1a2e);
  border:1px solid var(--glass-border);border-radius:var(--radius);
  padding:12px 14px;margin-bottom:8px;overflow:hidden;
}
.light-theme .cr-note-card { background:rgba(255,255,255,0.7);border-color:rgba(0,0,0,0.08);box-shadow:0 1px 3px rgba(0,0,0,0.04); }
.cr-note-header { display:flex;align-items:center;gap:6px; }
.cr-note-status-dot { width:8px;height:8px;border-radius:50%;flex-shrink:0; }
.cr-note-title { font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.cr-note-actions { display:flex;align-items:center;gap:4px;flex-shrink:0; }
.cr-note-status-select { font-family:var(--font-mono);font-size:9px;padding:2px 4px;border:1px solid var(--glass-border);border-radius:4px;background:var(--bg-surface, #1a1a2e);color:var(--text2);width:auto;max-width:70px; }
.light-theme .cr-note-status-select { background:#fff; }
.cr-note-edit-btn,.cr-note-del-btn { background:none;border:none;color:var(--text3);cursor:pointer;padding:3px;flex-shrink:0;transition:color 0.15s;display:flex;align-items:center; }
.cr-note-edit-btn:hover { color:var(--accent); }
.cr-note-del-btn:hover { color:var(--red); }
.cr-note-textarea {
  width:100%;box-sizing:border-box;margin-top:8px;
  padding:8px 10px;border:1px solid var(--glass-border);border-radius:var(--radius-sm);
  background:var(--bg-surface, #111);color:var(--text);
  font-family:var(--font-display);font-size:12px;line-height:1.5;
  resize:vertical;outline:none;transition:border-color 0.2s;
}
.cr-note-textarea:focus { border-color:var(--accent-border); }
.light-theme .cr-note-textarea { background:#fff;border-color:rgba(0,0,0,0.12); }
.cr-note-due { font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-top:6px; }
.cr-note-due.overdue { color:var(--red); }

/* Meeting picker row */
.mc-meeting-picker-row { display:flex;gap:6px;align-items:center; }
.mc-meeting-picker-row select { flex:1; }

/* Team / Guests two-column speakers */
.mc-speakers-cols { display:flex;gap:12px; }
.mc-speakers-col { flex:1;min-width:0; }

/* Save & End button */
.mc-save-end-btn { font-size:11px;padding:6px 14px;margin-top:8px;border-color:rgba(34,197,94,0.3);color:var(--emerald);background:rgba(34,197,94,0.06);width:100%; }
.mc-save-end-btn:hover { background:rgba(34,197,94,0.14);border-color:rgba(34,197,94,0.5); }

/* Wide dialog variant (for notepad) */
.obl-dialog--wide { width:90vw;max-width:900px;padding:20px 10px 16px;align-items:stretch; }
.obl-dialog--wide .obl-dialog-detail { text-align:left;width:100%; }
.obl-dialog--wide .obl-dialog-btns { justify-content:flex-end; }

/* Notepad modal textarea */
.obl-notepad-textarea {
  width:100%;min-height:400px;max-height:70vh;
  padding:16px 20px;margin-top:8px;box-sizing:border-box;
  border:1px solid var(--glass-border);border-radius:var(--radius);
  background:var(--glass-bg);color:var(--text);
  font-family:var(--font-display);font-size:14px;line-height:1.8;
  resize:vertical;outline:none;transition:border-color 0.2s;
}
.obl-notepad-textarea:focus { border-color:var(--accent-border); }

/* Note icon on transcript cards */
.rec-note-icon { flex-shrink:0;color:var(--amber);cursor:pointer;padding:4px;transition:color 0.15s; }
.rec-note-icon:hover { color:var(--accent); }
.rec-note-icon svg { width:12px;height:12px; }

/* Stitch timeline bar */
.rec-stitch-timeline { display:flex;height:20px;border-radius:4px;overflow:hidden;margin-top:4px;border:1px solid var(--glass-border); }
.rec-stitch-segment { display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.15s;background:rgba(108,99,255,0.08);border-right:1px solid var(--glass-border); }
.rec-stitch-segment:last-child { border-right:none; }
.rec-stitch-segment:hover { background:rgba(108,99,255,0.2); }
.rec-stitch-segment-label { font-family:var(--font-mono);font-size:8px;color:var(--text3); }

/* Stitch recording tabs (above player) */
.stitch-rec-tabs { display:flex;gap:6px;padding:8px 12px;flex-wrap:wrap; }
.stitch-rec-tab {
  font-family:var(--font-display);font-size:11px;font-weight:600;
  padding:5px 14px;border-radius:var(--radius-sm);
  border:1px solid var(--glass-border);background:var(--glass-bg);
  color:var(--text3);cursor:pointer;transition:all 0.2s;
}
.stitch-rec-tab:hover { color:var(--text);border-color:var(--accent-border); }
.stitch-rec-tab.active {
  color:var(--accent);border-color:rgba(79,142,247,0.4);
  background:rgba(79,142,247,0.08);
  box-shadow:0 0 8px rgba(79,142,247,0.15);
}

/* Stitch divider in transcript body */
.stitch-divider {
  display:flex;align-items:center;gap:10px;
  padding:12px 0;margin:8px 0;cursor:pointer;
}
.stitch-divider-line { flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--accent-border),transparent); }
.stitch-divider-label {
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  color:var(--accent);letter-spacing:0.5px;
  padding:3px 10px;border-radius:var(--radius-sm);
  background:rgba(79,142,247,0.06);border:1px solid rgba(79,142,247,0.15);
  white-space:nowrap;
}
.stitch-divider:hover .stitch-divider-label { background:rgba(79,142,247,0.12);border-color:rgba(79,142,247,0.3); }

/* Stitch modal */
.stitch-meeting-name { font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px; }
.stitch-order-label { font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-bottom:8px;letter-spacing:0.5px; }
.stitch-order-list { display:flex;flex-direction:column;gap:4px; }
.stitch-order-item { display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm); }
.stitch-order-num { font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--accent2);width:18px;text-align:center;flex-shrink:0; }
.stitch-order-name { font-family:var(--font-display);font-size:12px;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.stitch-order-mode { font-family:var(--font-mono);font-size:9px;flex-shrink:0; }
.stitch-order-btns { display:flex;gap:2px;flex-shrink:0; }
.stitch-move-btn { background:none;border:1px solid var(--glass-border);border-radius:4px;color:var(--text3);cursor:pointer;padding:3px;display:flex;align-items:center;transition:color 0.15s,border-color 0.15s; }
.stitch-move-btn:hover { color:var(--accent);border-color:var(--accent-border); }
.stitch-move-placeholder { width:20px; }
.stitch-confirm-btn { border-color:rgba(108,99,255,0.3);color:var(--accent2);background:rgba(108,99,255,0.06); }
.stitch-confirm-btn:hover { background:rgba(108,99,255,0.14);border-color:rgba(108,99,255,0.5); }

/* Media tab — file + transcript companion cards */
.media-file-row { display:flex;gap:6px;align-items:stretch;margin-bottom:4px; }
.media-file-card { flex:1;display:flex;align-items:center;gap:10px;cursor:pointer; }
.media-file-info { flex:1;min-width:0; }
.media-file-name { font-family:var(--font-display);font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.media-file-meta { display:flex;gap:8px;align-items:center;margin-top:2px; }
.media-file-size { font-family:var(--font-mono);font-size:9px;color:var(--text3); }
.media-file-ext { font-family:var(--font-mono);font-size:8px;padding:1px 5px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:3px;color:var(--text3); }
.media-transcript-card { width:120px;flex-shrink:0;display:flex;align-items:center;gap:6px;cursor:pointer;background:rgba(34,197,94,0.04);border-color:rgba(34,197,94,0.15); }
.media-transcript-card:hover { background:rgba(34,197,94,0.1);border-color:rgba(34,197,94,0.3); }
.media-transcript-label { font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--emerald); }
.media-no-transcript { width:120px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:1px dashed var(--glass-border);border-radius:var(--radius);padding:8px; }
.media-no-transcript-label { font-family:var(--font-mono);font-size:9px;color:var(--text3); }
.ts-export-label { font-family:var(--font-mono);font-size:10px;letter-spacing:1px;color:var(--text3);margin-bottom:6px; }
.ts-export-textarea { width:100%;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:12px;font-family:var(--font-display);font-size:13px;color:var(--text);outline:none;resize:vertical;box-sizing:border-box;transition:border-color 0.2s; }
.ts-export-textarea:focus { border-color:var(--accent-border); }
.ts-export-filename { width:260px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:8px 12px;font-family:var(--font-display);font-size:13px;color:var(--text);outline:none;transition:border-color 0.2s; }
.ts-export-filename:focus { border-color:var(--accent-border); }
.ts-export-btns { display:flex;gap:8px;margin-bottom:32px; }
.ts-mb-4 { margin-bottom:4px; }
.ts-btn-sm-pad { padding:5px 12px; }
.ts-btn-pad { padding:8px 20px; }

/* ── DD Report section ── */
.dd-page-header { padding:20px 24px 16px;border-bottom:1px solid var(--glass-border);flex-shrink:0; }
.dd-page-title { font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold); }
.dd-page-desc { font-family:var(--font-mono);font-size:11px;color:var(--text3);margin-top:4px;letter-spacing:0.5px; }
.dd-layout { display:flex;flex:1;overflow:hidden;gap:0; }
.dd-left { flex:1;min-width:0;border-right:1px solid var(--glass-border);display:flex;flex-direction:column;overflow:hidden; }
.dd-left-header { flex-shrink:0;padding:18px 20px 12px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:8px; }
.dd-left-body { flex:1;overflow-y:auto;padding:16px 20px; }
.dd-right { flex:1;display:flex;flex-direction:column;overflow:hidden; }
.dd-context { flex:1;overflow-y:auto;padding:18px 24px;border-bottom:1px solid var(--glass-border); }
.dd-section-label { font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text3); }
.dd-context-hint { font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-bottom:8px;margin-top:6px; }
.dd-context-textarea { width:100%;resize:vertical;font-size:13px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:12px;font-family:var(--font-body);color:var(--text);outline:none;min-height:120px;line-height:1.6;transition:border-color 0.2s;box-sizing:border-box; }
.dd-context-textarea:focus { border-color:var(--accent-border); }
.dd-template { flex-shrink:0;padding:16px 24px;border-bottom:1px solid var(--glass-border); }
.dd-drop-zone { margin-bottom:8px;padding:18px;font-family:var(--font-mono);font-size:11px; }
.dd-drop-zone:hover { border-color:rgba(212,168,71,0.3);color:var(--gold);background:rgba(212,168,71,0.03); }
.dd-template-textarea { font-size:11px;width:100%;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:6px;padding:10px;font-family:var(--font-mono);color:var(--text2);outline:none;line-height:1.5;box-sizing:border-box; }
.dd-generate { flex-shrink:0;padding:16px 24px;display:flex;flex-direction:column;gap:10px; }
.dd-gen-row { display:flex;align-items:center;gap:12px; }
.dd-gen-status { font-family:var(--font-mono);font-size:10px;color:var(--text3); }
.dd-feedback-btn { font-size:10px;background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.3);color:#f59e0b; }
.dd-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:12px;margin-bottom:8px;transition:border-color 0.15s; }
.dd-card:hover { border-color:rgba(212,168,71,0.2); }
.dd-card-header { display:flex;gap:6px;align-items:center;margin-bottom:8px; }
input.dd-card-title { flex:1;font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--text2);background:transparent;border:1px solid transparent;border-radius:6px;padding:4px 8px;outline:none;transition:border-color 0.2s; }
input.dd-card-title:focus { border-color:var(--accent-border);background:var(--glass-bg); }
.dd-card-move { width:24px;height:24px;border-radius:6px;border:1px solid var(--glass-border);background:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0; }
.dd-card-move:hover { background:var(--glass-bg);color:var(--text);border-color:var(--accent-border); }
.dd-card-move:disabled { opacity:0.3;cursor:default; }
.dd-card-del { width:24px;height:24px;border-radius:6px;border:1px solid rgba(239,68,68,0.15);background:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0; }
.dd-card-del:hover { background:rgba(239,68,68,0.1);color:var(--red);border-color:rgba(239,68,68,0.3); }
.dd-card-textarea { width:100%;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:6px;padding:8px 10px;font-family:var(--font-body);font-size:12px;color:var(--text);outline:none;resize:vertical;line-height:1.6;transition:border-color 0.2s;box-sizing:border-box; }
.dd-card-textarea:focus { border-color:var(--accent-border); }
.dd-report-output { max-height:260px;overflow-y:auto;padding:14px 16px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;font-size:12px;line-height:1.7;white-space:pre-wrap;color:var(--text); }

/* ── Sessions section ── */
.ss-checkbox-label { display:flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10px;color:var(--text3);cursor:pointer;flex-shrink:0; }

/* ── Compare / Pages section classes ── */
.cmp-body { max-width:900px;margin:0 auto; }
.cmp-grid { display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px; }
.cmp-icon-dim { opacity:0.4; }
.cmp-run-btn { padding:12px 32px; }
.cmp-status { margin-top:16px;font-family:var(--font-mono);font-size:11px;color:var(--text3);text-align:center; }
.prec-empty-msg { font-family:var(--font-mono);font-size:11px;color:var(--text3);line-height:1.7; }
.prec-empty-icon { opacity:0.15; }
.prec-tree-empty { padding:24px 14px;font-family:var(--font-mono);font-size:11px;color:var(--text3);text-align:center;line-height:1.7; }
.prec-content-title-style { font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:1px;color:var(--text); }
.prec-content-sub-style { font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-top:4px;letter-spacing:0.5px; }
.prec-add-sector-btn { width:auto;padding:4px 10px; }
.pg-folder-modal { position:fixed;inset:0;z-index:9998;background:var(--bg-mid);flex-direction:column; }
.pg-folder-header { display:flex;align-items:center;padding:14px 24px;border-bottom:1px solid var(--glass-border);background:var(--bg-mid);flex-shrink:0; }
.pg-folder-title { font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:1px;color:var(--text); }
.pg-folder-subtitle { font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-top:3px;letter-spacing:0.5px; }
.pg-folder-controls { display:flex;gap:6px;align-items:center;margin-right:12px; }
.pg-folder-edit-btn { padding:5px 12px; }
.pg-folder-save-btn { font-size:10px;padding:5px 12px;border-color:rgba(34,197,94,0.3);color:var(--emerald); }
.pg-folder-legend { display:flex;gap:14px;align-items:center;margin-right:20px;font-family:var(--font-mono);font-size:9px; }
.pg-legend-item { display:flex;align-items:center;gap:5px;color:var(--text3); }
.pg-legend-folder { display:inline-block;width:12px;height:12px;border-radius:3px;border:1px solid var(--glass-border);background:var(--glass-bg); }
.pg-legend-badge-amber { background:var(--amber);color:#fff;font-size:7px;font-weight:700;padding:1px 5px;border-radius:6px; }
.pg-legend-badge-green { background:var(--emerald);color:#fff;font-size:7px;font-weight:700;padding:1px 5px;border-radius:6px; }
.pg-folder-diagram { flex:1;overflow:auto;padding:28px 32px; }
#panel-playbook.active { display:flex;flex-direction:column;height:100%;overflow:hidden; }
.pg-playbook-header { display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--glass-border);flex-shrink:0; }
.pg-playbook-title { font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text); }
.pg-playbook-desc { font-family:var(--font-mono);font-size:11px;color:var(--text3);margin-top:4px;letter-spacing:0.5px; }
#playbookGrid { flex:1;overflow-y:auto;padding:20px 24px; }
#panel-quick-notes.active { display:flex;flex-direction:column;height:100%;overflow:hidden; }
#panel-deal-docs.active { display:flex;flex-direction:column;height:100%;overflow:hidden; }
#panel-deal-docs #ddDetail { display:flex;flex-direction:column;overflow:hidden;flex:1;padding:0; }
#panel-deal-docs .prec-v2-layout { display:flex;flex-direction:column;height:100%;min-height:0;flex:1; }
.pb-empty { text-align:center;padding:60px 20px;color:var(--text2); }
.pb-empty-title { font-family:var(--font-display);font-size:16px;font-weight:600;margin-bottom:6px; }
.pb-empty-desc { font-family:var(--font-mono);font-size:11px;color:var(--text3); }
.pb-group { margin-bottom:24px; }
.pb-group-label { font-family:var(--font-mono);font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px;padding-left:4px; }
.pb-grid { display:flex;flex-direction:column;gap:12px; }
.pb-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:18px;transition:border-color 0.15s;overflow:hidden; }
.pb-card:hover { border-color:var(--accent-border); }
.pb-card-header { display:flex;align-items:center;gap:10px;margin-bottom:14px; }
.pb-card-title { font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text); }
.pb-badge-active { font-family:var(--font-mono);font-size:8px;padding:2px 8px;border-radius:4px;background:rgba(52,211,153,0.1);color:var(--emerald);border:1px solid rgba(52,211,153,0.2); }
.pb-columns { display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;min-width:0; }
.pb-columns > div { min-width:0;overflow-wrap:break-word;word-break:break-word; }
.pb-notes { margin-top:12px; }
.pb-card-actions { display:flex;gap:4px;flex-shrink:0; }
.pb-card-btn { width:24px;height:24px;border-radius:6px;border:1px solid var(--glass-border);background:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s; }
.pb-card-btn:hover { background:var(--glass-bg);color:var(--text);border-color:var(--accent-border); }
.pb-card-btn-del:hover { background:rgba(239,68,68,0.1);color:var(--red);border-color:rgba(239,68,68,0.3); }
.pb-label { font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px; }
.pb-label-std { color:var(--text3); }
.pb-label-fall { color:var(--text3); }
.pb-label-red { color:var(--red); }
.pb-label-notes { color:var(--text3); }
.pb-text { font-size:12px;color:var(--text2);line-height:1.6;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word; }
.pb-text-muted { font-size:11px;color:var(--text3);line-height:1.4; }

/* Quick Notes */
.qn-list { display:flex;flex-direction:column;gap:10px;padding:16px 24px; }
.qn-card { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:14px 18px;transition:border-color 0.15s; }
.qn-card:hover { border-color:var(--accent-border); }
.qn-card-header { display:flex;align-items:center;justify-content:space-between;margin-bottom:8px; }
.qn-card-meta { display:flex;align-items:center;gap:10px; }
.qn-date { font-family:var(--font-mono);font-size:10px;color:var(--text3);letter-spacing:0.5px; }
.qn-project { font-family:var(--font-mono);font-size:10px;color:var(--accent);background:var(--accent-soft);padding:2px 8px;border-radius:4px; }
.qn-text { font-size:13px;color:var(--text);line-height:1.5;white-space:pre-wrap; }

.pg-modal-w640 { width:640px;max-width:96vw; }
.pg-form-2col { display:grid;grid-template-columns:1fr 1fr;gap:12px; }
.pg-modal-actions { display:flex;gap:8px;justify-content:flex-end;margin-top:16px; }
.pg-modal-w620 { width:620px; }
.pg-context-desc { font-size:12px;color:var(--text2);margin-bottom:12px; }
.pg-ai-settings-row { display:flex;gap:16px;margin-bottom:16px;padding:14px 16px;background:rgba(79,142,247,0.06);border:1px solid rgba(79,142,247,0.15);border-radius:10px; }
.pg-juris-other { width:100%;padding:6px 10px;font-size:12px;border-radius:6px;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text);margin-top:4px; }
.pg-persona-indicator { display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;padding:8px 12px;background:rgba(0,0,0,0.2);border-radius:8px;min-height:28px;align-items:center; }
.pg-persona-label { font-size:9px;font-weight:700;color:rgba(255,255,255,0.3);letter-spacing:0.5px;margin-right:4px; }
.pg-modal-w560 { width:560px; }
.pg-doc-label-select { width:180px; }
.pg-doc-counter { display:flex;justify-content:space-between;margin-top:5px;font-size:11px;color:var(--text2); }
.pg-brief-modal { width:800px;max-width:96vw;height:80vh;max-height:88vh; }
.pg-brief-subtitle-row { display:flex;align-items:center;gap:8px;margin-top:2px; }
.pg-stale-tag { font-family:var(--font-mono);font-size:8px;font-weight:700;padding:2px 6px;border-radius:4px;background:rgba(245,158,11,0.1);color:var(--amber);border:1px solid rgba(245,158,11,0.2); }
.pg-improve-btn { border-color:rgba(245,158,11,0.3);color:var(--amber); }
.pg-settings-modal { width:520px;height:620px;display:flex;flex-direction:column;overflow:hidden; }
.pg-settings-tabs { display:flex;gap:0;border-bottom:1px solid var(--glass-border);flex-shrink:0;margin:-4px -4px 16px; }
.pg-wiz-quick-start { display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(79,142,247,0.07);border:1px solid rgba(79,142,247,0.2);border-radius:8px;margin-bottom:14px; }
.pg-wiz-checkbox { width:16px;height:16px;cursor:pointer;accent-color:var(--accent); }
.pg-wiz-qs-title { font-size:13px;font-weight:600;color:var(--accent); }
.pg-wiz-representing { margin:0;grid-column:1/-1; }
.pg-wiz-rep-list { display:flex;flex-direction:column;gap:6px;margin-top:4px; }
.pg-wiz-required { color:var(--red); }
.pg-wiz-name-hint { font-size:10px;color:var(--text2);margin-top:3px;font-style:italic; }
.pg-wiz-persona-desc { font-size:11px;color:var(--text2);margin-bottom:8px; }
.pg-wiz-juris-other { margin-top:4px;width:100%;padding:5px 8px;font-size:12px;border-radius:6px;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text); }
.pg-wiz-persona-preview { display:flex;gap:4px;flex-wrap:wrap;margin-top:8px;margin-bottom:18px; }
.pg-wiz-auto-note { font-size:12px;color:var(--accent);padding:10px 12px;background:rgba(79,142,247,0.08);border-radius:8px;border:1px solid rgba(79,142,247,0.2); }
.pg-wiz-step3-desc { font-size:12px;color:var(--text2);margin-bottom:14px; }
.pg-wiz-custom-subject { margin-top:10px; }
.pg-wiz-ready-center { text-align:center;padding:20px 0; }
.pg-wiz-check-icon { font-size:40px;margin-bottom:12px; }
.pg-wiz-ready-title { font-size:16px;font-weight:600;margin-bottom:8px; }
.pg-wiz-summary { font-size:13px;color:var(--text2);line-height:1.7; }
.pg-wiz-context-box { background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:14px;margin-top:14px; }
.pg-wiz-context-label { font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px; }
.pg-wiz-context-preview { font-size:12px;color:var(--text);line-height:1.7;white-space:pre-wrap; }
.pg-wiz-back-hidden { visibility:hidden; }
.pg-wiz-archive-section { margin-top:16px;padding:14px 16px;border:1px solid rgba(239,68,68,0.2);border-radius:10px;background:rgba(239,68,68,0.04); }
.pg-wiz-archive-title { font-size:12px;font-weight:600;color:var(--red); }
.pg-wiz-archive-btn { color:var(--red);border-color:rgba(239,68,68,0.3);flex-shrink:0; }

/* ── Post-AI section classes ── */

/* Modal panel size variants */
.modal-panel-720 { width:720px;max-width:95vw; }
.modal-panel-820 { width:820px;max-width:95vw;max-height:90vh; }
.modal-panel-1200 { width:1200px;max-width:97vw;height:96vh; }
.modal-panel-420 { width:420px;max-height:75vh;box-shadow:0 20px 40px rgba(0,0,0,0.4); }
.modal-panel-580 { width:580px;max-width:95vw;max-height:88vh; }
.modal-box-680 { width:680px;max-width:96vw;height:80vh;max-height:88vh; }
.modal-box-glass { background:var(--bg-mid);border:1px solid var(--glass-border);border-radius:12px;box-shadow:0 20px 40px rgba(0,0,0,0.5);backdrop-filter:blur(20px); }
.modal-box-glass-560 { width:560px;max-height:85vh;overflow-y:auto; }
.modal-box-glass-450 { width:450px;max-height:70vh;overflow:hidden;display:flex;flex-direction:column; }
.modal-box-glass-600 { width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column; }
.modal-box-glass-700 { width:700px;max-height:70vh;overflow:hidden;display:flex;flex-direction:column; }
.modal-box-glass-wide { width:90vw;max-width:1100px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column; }

/* Text truncation */
.text-truncate { white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }

/* Outlook modal */
.set-outlook-modal { width:720px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden; }
.set-outlook-hdr { display:flex;align-items:center;justify-content:space-between;flex-shrink:0;padding-bottom:14px;border-bottom:1px solid var(--glass-border); }
.set-outlook-icon { font-size:18px; }
.set-outlook-mode-label { font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600; }
.set-outlook-tabs { display:none;padding:8px 0 4px;flex-shrink:0;border-bottom:1px solid var(--glass-border);margin-bottom:4px; }
.set-outlook-tab-btn { padding:4px 12px; }
.set-outlook-note { font-size:10px;color:var(--text2);margin-top:6px;line-height:1.4;padding:4px 0; }
.set-outlook-controls { display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:12px 0;flex-shrink:0; }
.set-outlook-select { font-size:12px;padding:5px 8px;min-width:140px;flex-shrink:0; }
.set-outlook-select-sm { font-size:12px;padding:5px 8px;flex-shrink:0; }
.set-outlook-search { font-size:12px;padding:5px 8px;flex:1;min-width:140px; }
.set-outlook-selectall { display:flex;align-items:center;gap:8px;padding-bottom:8px;flex-shrink:0; }
.set-outlook-selectall-label { font-size:12px;color:var(--text2);cursor:pointer;display:flex;align-items:center;gap:4px; }
.set-outlook-list { flex:1;overflow-y:auto;border:1px solid var(--glass-border);border-radius:8px;background:var(--glass-bg);min-height:200px; }
.set-outlook-placeholder { padding:40px 20px;text-align:center;font-size:13px;color:var(--text2); }
.set-outlook-footer { padding-top:12px;border-top:1px solid var(--glass-border);margin-top:12px;flex-shrink:0;display:flex;flex-direction:column;gap:10px; }
.set-outlook-checkbox-label { font-size:12px;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:6px; }
.set-outlook-status { flex:1;font-size:12px;color:var(--text2); }
.set-outlook-upload-pane { display:none;flex:1;flex-direction:column;gap:8px;padding-top:8px; }
.set-outlook-dropzone { flex:1;min-height:200px;border:2px dashed rgba(79,142,247,0.3);border-radius:10px;background:rgba(79,142,247,0.03);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:border-color 0.2s,background 0.2s; }
.set-outlook-drop-icon { font-size:36px;opacity:0.5; }
.set-outlook-drop-title { font-size:14px;font-weight:600;color:var(--text); }
.set-outlook-upload-list { max-height:140px;overflow-y:auto;border:1px solid var(--glass-border);border-radius:8px;background:var(--glass-bg);display:none; }
.set-outlook-upload-footer { display:flex;align-items:center;gap:10px;padding-top:8px;border-top:1px solid var(--glass-border); }

/* EML modal */
.eml-grid-meta { display:grid;gap:4px; }
.eml-attach-wrap { flex-wrap:wrap;gap:6px; }
.eml-uppercase-input { text-transform:uppercase; }
.eml-max-subject { max-width:400px; }

/* Import preview */
.set-import-list-pad { padding:12px 20px; }
.set-import-status { margin-right:auto; }
.imp-item {
  display:flex !important; flex-direction:row !important; align-items:center; gap:10px;
  padding:10px 12px; border-radius:10px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--glass-border);
  margin-bottom:6px; transition:background 0.15s;
}
.imp-item:hover { background:rgba(255,255,255,0.07); }
.imp-icon {
  width:28px; height:28px; border-radius:6px;
  background:rgba(79,142,247,0.1); border:1px solid rgba(79,142,247,0.2);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:var(--accent);
}
.imp-info { flex:1 1 0% !important; min-width:0; overflow:hidden; }
.imp-name {
  font-family:var(--font-display); font-size:13px; font-weight:600;
  color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.imp-meta {
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.5px;
  color:var(--text2); margin-top:2px;
}
.imp-badge {
  font-family:var(--font-mono); font-size:9px; font-weight:700;
  letter-spacing:0.5px; padding:3px 10px; border-radius:6px; flex-shrink:0;
}
.imp-badge-email {
  background:rgba(79,142,247,0.12); border:1px solid rgba(79,142,247,0.25);
  color:var(--accent);
}
.imp-label-select {
  font-family:var(--font-mono); font-size:9px; font-weight:600;
  letter-spacing:0.5px; padding:4px 8px; border-radius:6px;
  background:rgba(255,255,255,0.04); border:1px solid var(--glass-border);
  color:var(--text); cursor:pointer; flex-shrink:0;
  width:auto; max-width:110px;
}
.imp-role {
  font-family:var(--font-mono); font-size:9px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; padding:0 0 4px 42px;
}
.imp-swap-btn {
  font-family:var(--font-mono); font-size:9px; letter-spacing:0.5px;
  padding:3px 12px; border-radius:6px; cursor:pointer;
  background:none; border:1px solid var(--glass-border); color:var(--text2);
  display:inline-flex; align-items:center; gap:4px; transition:all 0.15s;
}
.imp-swap-btn:hover { border-color:var(--accent); color:var(--accent); }
/* Light theme */
.light-theme .imp-item { background:rgba(255,255,255,0.6); border-color:rgba(0,0,0,0.08); }
.light-theme .imp-item:hover { background:rgba(255,255,255,0.8); }
.light-theme .imp-icon { background:rgba(79,142,247,0.08); border-color:rgba(79,142,247,0.15); }
.light-theme .imp-label-select { background:#fff !important; border-color:rgba(0,0,0,0.12) !important; color:var(--text) !important; }
.light-theme .imp-label-select option { background:#fff !important; color:var(--text) !important; }
.light-theme .imp-swap-btn { border-color:rgba(0,0,0,0.12); }
.light-theme .modal-panel select,
.light-theme .modal-panel select option { background:#fff; color:var(--text); }

/* Doc viewer note due */
.set-note-due { flex:1.2; }

/* Case Brief modal */
.set-cb-meta { font-family:var(--font-mono);font-size:9px;color:var(--text3);margin-top:2px; }
.set-cb-content { font-size:13px;line-height:1.8;color:var(--text); }
.set-cb-content h1,.set-cb-content h2,.set-cb-content h3 { color:var(--text);font-family:var(--font-ui);font-weight:600;margin:16px 0 6px; }
.set-cb-content h1 { font-size:15px; }
.set-cb-content h2 { font-size:14px;border-bottom:1px solid var(--glass-border);padding-bottom:4px; }
.set-cb-content h3 { font-size:13px;color:var(--text2); }
.set-cb-content ul,.set-cb-content ol { padding-left:20px;margin:6px 0; }
.set-cb-content li { margin:3px 0; }
.set-cb-content strong { color:var(--text);font-weight:600; }
.set-cb-content p { margin:6px 0; }
.set-cb-content hr { border:none;border-top:1px solid var(--glass-border);margin:12px 0; }
.set-cb-improve-btn { border-color:rgba(245,158,11,0.3);color:var(--amber); }

/* Help guide inline styles */
.hg-info-box { background:var(--glass-bg);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text2);line-height:1.7;margin-bottom:12px; }
.hg-info-box-mt { background:var(--glass-bg);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text2);line-height:1.7;margin-top:8px; }
.hg-callout-precedent { background:linear-gradient(135deg,rgba(167,139,250,0.08),rgba(79,142,247,0.06));border:1px solid rgba(167,139,250,0.25);border-radius:10px;padding:14px 18px;margin-bottom:20px;font-size:12px;color:var(--text2);line-height:1.7; }
.hg-callout-tools { background:linear-gradient(135deg,rgba(56,178,172,0.08),rgba(49,130,206,0.06));border:1px solid rgba(56,178,172,0.25);border-radius:10px;padding:14px 18px;margin-bottom:20px;font-size:12px;color:var(--text2);line-height:1.7; }
.hg-title-blue { color:#3182ce; }
.hg-title-green { color:#38a169; }
.hg-title-purple { color:#805ad5; }
.hg-card-span-2 { grid-column:span 2; }
.hg-tip-teal { margin-top:4px;padding:12px 16px;background:rgba(56,178,172,0.07);border:1px solid rgba(56,178,172,0.2);border-radius:8px;font-size:12px;color:var(--text2);line-height:1.7; }
.hg-tip-glass { margin-top:4px;padding:12px 16px;background:var(--glass-bg);border-radius:8px;font-size:12px;color:var(--text2);line-height:1.7; }

/* Playbook modal */
.set-pb-body { padding:20px;display:flex;flex-direction:column;gap:14px; }
.set-pb-input { width:100%;padding:8px 10px;border:1px solid var(--glass-border);border-radius:6px;background:var(--glass-bg);color:var(--text);font-family:var(--font-body);font-size:13px;box-sizing:border-box;outline:none;transition:border-color 0.2s; }
.set-pb-input:focus { border-color:var(--accent-border); }
.set-pb-select { width:100%;padding:8px 10px;border:1px solid var(--glass-border);border-radius:6px;background:var(--glass-bg);color:var(--text);font-size:13px;outline:none;transition:border-color 0.2s; }
.set-pb-select:focus { border-color:var(--accent-border); }
.set-pb-label-teal { font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;display:block;margin-bottom:4px;color:var(--emerald); }
.set-pb-label-gold { font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;display:block;margin-bottom:4px;color:var(--amber); }
.set-pb-label-red { font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;display:block;margin-bottom:4px;color:var(--red); }
.set-pb-save-btn { padding:10px;font-size:13px;font-weight:600; }

/* Obligation modal body */
.obl-body { flex:1;overflow:auto;padding:0; }

/* Section padding utility */
.pad-body { padding:12px 16px; }

/* Global Search modal */
.set-search-modal { display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:9999;justify-content:center;align-items:flex-start;padding-top:80px; }

/* Status bar */
.sb-truncate { max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }

/* General text color utilities */
.text-purple { color:var(--accent); }
.text-blue { color:#60a5fa; }
.text-red { color:#f87171; }
.text-green { color:#34d399; }
.text-orange { color:#f97316; }
.text-amber { color:#f59e0b; }
.text-teal { color:#38b2ac; }
.text-color { color:var(--text); }

/* Form elements */
.form-input {
  width:100%; padding:8px 12px; border-radius:8px;
  background:var(--glass-bg); border:1px solid var(--glass-border);
  color:var(--text); font-family:var(--font-body); font-size:13px; outline:none;
  transition:border-color 0.2s; box-sizing:border-box;
}
input.form-input { font-family:var(--font-body); }
.form-input:focus { border-color:var(--accent-border); }
.form-select {
  padding:4px 8px; border-radius:4px;
  background:var(--glass-bg); border:1px solid var(--glass-border);
  color:var(--text2); font-size:10px; outline:none;
}
.form-textarea {
  width:100%; padding:8px 10px; border-radius:8px;
  background:var(--glass-bg); border:1px solid var(--glass-border);
  color:var(--text); font-family:var(--font-body); font-size:12px; resize:vertical;
  line-height:1.5; outline:none; box-sizing:border-box; transition:border-color 0.2s;
}
.form-textarea:focus { border-color:var(--accent-border); }
.form-label {
  font-family:var(--font-mono); font-size:10px; font-weight:700;
  color:var(--text3); letter-spacing:0.5px; margin-bottom:4px; display:block;
}

/* Separator */
.separator { height:1px; background:var(--glass-border); }

/* ═══════════════════════════════════════════════════════════════════
   AI SUITE CLASSES (from FIX_PROMPT_11)
   ═══════════════════════════════════════════════════════════════════ */

/* Header */
.as-page-header { display:flex;align-items:flex-start;justify-content:space-between;padding:10px 24px 10px;border-bottom:1px solid var(--glass-border);flex-shrink:0; }
.as-page-title { font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent); }
.as-page-desc { font-family:var(--font-mono);font-size:12px;color:var(--text3);margin-top:4px;letter-spacing:0.5px; }

/* Tab bar */
.as-tab-bar { display:flex;border-bottom:1px solid var(--glass-border);padding:0 20px;flex-shrink:0; }
.as-tab { padding:10px 18px;font-family:var(--font-mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--text3);cursor:pointer;border:none;background:none;position:relative;transition:color 0.2s; }
.as-tab:hover { color:var(--text2); }
.as-tab.active { color:var(--accent); }
.as-tab.active::after { content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--accent); }

/* Prompt Sidebar */
.as-prompt-sidebar { width:240px; flex-shrink:0; border-right:1px solid var(--glass-border); display:flex; flex-direction:column; overflow-y:auto; }
.as-prompt-sidebar-hdr { padding:12px; font-family:var(--font-mono); font-size:10px; color:var(--text3); letter-spacing:2px; text-transform:uppercase; border-bottom:1px solid var(--glass-border); }
.as-prompt-item { padding:10px 14px; cursor:pointer; border-left:3px solid transparent; transition:background 0.12s; }
.as-prompt-item:hover { background:var(--glass-bg); }
.as-prompt-item.active { border-left-color:var(--accent); background:rgba(79,142,247,0.04); }
.as-prompt-name { font-size:12px; font-weight:600; color:var(--text); }
.as-prompt-meta { font-family:var(--font-mono); font-size:10px; color:var(--text3); margin-top:2px; }

/* Editor Pane */
.as-editor { flex:1; display:flex; flex-direction:column; min-height:0; border-right:1px solid var(--glass-border); }
.as-editor-empty { flex:1; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:12px; color:var(--text3); }
.as-editor-bar { padding:14px 20px; border-bottom:1px solid var(--glass-border); display:flex; align-items:center; gap:10px; flex-shrink:0; }
.as-sub-tab { padding:9px 14px; font-family:var(--font-display); font-size:12px; font-weight:600; border:none; background:none; cursor:pointer; border-bottom:2px solid transparent; color:var(--text3); }
.as-sub-tab.active { border-bottom-color:var(--accent); color:var(--accent); }
.as-version-badge { font-family:var(--font-mono); font-size:10px; padding:2px 8px; border-radius:4px; background:rgba(79,142,247,0.1); color:var(--accent); }
.as-custom-badge { font-family:var(--font-mono); font-size:9px; padding:2px 8px; border-radius:4px; background:rgba(52,211,153,0.1); color:var(--emerald); }
.as-save-btn { font-size:12px; padding:3px 10px; border-radius:6px; border:1px solid rgba(34,197,94,0.3); background:rgba(34,197,94,0.1); color:var(--emerald); cursor:pointer; }
.as-btn-sm { font-size:12px; padding:3px 8px; border-radius:6px; border:1px solid var(--glass-border); background:none; color:var(--text3); cursor:pointer; }
.as-btn-sm:hover { color:var(--text2); border-color:var(--accent-border); }
.as-btn-danger { font-size:12px; padding:3px 8px; border-radius:6px; border:1px solid rgba(239,68,68,0.25); background:none; color:var(--red); cursor:pointer; }
.as-textarea { flex:1; width:100%; box-sizing:border-box; resize:none; padding:20px; border:none; background:transparent; color:var(--text); font-family:var(--font-mono); font-size:12px; line-height:1.8; outline:none; }

/* Chat Panel */
.as-chat-pane { width:420px; flex-shrink:0; display:flex; flex-direction:column; overflow:hidden; }
.as-chat-header { padding:10px 14px; border-bottom:1px solid var(--glass-border); flex-shrink:0; display:flex; align-items:center; justify-content:space-between; background:rgba(10,10,15,0.3); }
.as-chat-title { font-family:var(--font-display); font-size:12px; font-weight:700; color:var(--accent); }
.as-chat-sub { font-family:var(--font-mono); font-size:11px; color:var(--text3); }
.as-chat-messages { flex:1; overflow-y:auto; padding:12px; display:flex; flex-direction:column; gap:8px; min-height:0; }
.as-chat-input-wrap { padding:8px 12px; flex-shrink:0; background:rgba(10,10,15,0.3); }
.as-chat-send { padding:0 12px; border-radius:8px; border:none; background:var(--accent); color:#fff; cursor:pointer; font-size:14px; }

/* AI Map Nodes */
.as-node { padding:14px; border-radius:10px; text-align:center; cursor:pointer; width:100%; transition:transform 0.2s; }
.as-node:hover { transform:translateY(-2px); }
.as-node-title { font-family:var(--font-display); font-size:12px; font-weight:700; color:var(--text); }
.as-node-desc { font-family:var(--font-mono); font-size:10px; color:var(--text2); margin-top:3px; }
/* node-persona/chat/redline defined earlier — no duplicates */
.as-node-risk { background:rgba(239,68,68,0.06); border:1px solid rgba(239,68,68,0.2); }
.as-node-context { background:rgba(34,197,94,0.06); border:1px solid rgba(34,197,94,0.2); }
.as-model-badge { font-family:var(--font-mono); font-size:10px; margin-top:6px; padding:2px 8px; border-radius:8px; display:inline-block; }
.as-connector-v { width:2px; margin:0 auto; }
.as-connector-h { height:2px; }

/* Connection Map */
.as-conn-desc { font-family:var(--font-body); font-size:13px; color:var(--text2); margin-bottom:28px; line-height:1.6; }
.as-conn-headers { display:grid; grid-template-columns:190px 24px 210px 24px 190px 24px 210px; align-items:center; padding:0 0 14px; font-family:var(--font-mono); font-size:10px; font-weight:700; color:var(--text2); letter-spacing:0.9px; }
.as-flow-row { display:grid; grid-template-columns:190px 24px 210px 24px 190px 24px 210px; align-items:center; padding:5px 0; }
.as-flow-card { padding:10px 13px; border-radius:8px; font-size:12px; color:var(--text2); }
.as-flow-card-label { font-family:var(--font-mono); font-size:10px; font-weight:700; margin-bottom:4px; }
.as-flow-card-route { font-family:var(--font-mono); font-size:11px; color:var(--accent); }
.as-flow-card-route-sub { margin-top:4px; font-family:var(--font-body); font-size:9px; color:var(--text2); }
.as-flow-arrow { text-align:center; color:rgba(79,142,247,0.6); font-size:18px; }
.as-flow-model { padding:10px 13px; border-radius:8px; background:var(--glass-bg); border:1px solid var(--glass-border); font-size:12px; color:var(--text2); text-align:center; }
.as-flow-sep { height:1px; background:var(--glass-border); margin:3px 0; }
.as-conn-legend { margin-top:28px; padding:14px 18px; border:1px solid var(--glass-border); border-radius:10px; background:var(--glass-bg); }
.as-conn-legend-title { font-family:var(--font-mono); font-size:11px; font-weight:700; color:var(--text2); margin-bottom:10px; letter-spacing:0.6px; }

/* AI Improvements */
.as-fb-sidebar { width:380px; flex-shrink:0; border-right:1px solid var(--glass-border); display:flex; flex-direction:column; background:var(--glass-bg); }
.as-fb-header { padding:11px 14px; display:flex; align-items:center; gap:8px; border-bottom:1px solid var(--glass-border); }
.as-fb-label { font-family:var(--font-mono); font-size:10px; font-weight:700; color:var(--text2); letter-spacing:0.8px; flex:1; }
.as-fb-workshop { flex:1; display:flex; flex-direction:column; min-height:0; }
.as-fb-workshop-header { padding:12px 16px; border-bottom:1px solid var(--glass-border); flex-shrink:0; }

/* Context Map */
.as-ctx-topbar { padding:12px 20px; border-bottom:1px solid var(--glass-border); flex-shrink:0; display:flex; align-items:center; gap:16px; background:var(--glass-bg); }
.as-ctx-section-hdr { display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.as-ctx-bar { width:3px; height:16px; border-radius:2px; }
.as-ctx-section-label { font-family:var(--font-mono); font-size:11px; font-weight:700; letter-spacing:0.8px; }
.as-ctx-section-line { flex:1; height:1px; }
.as-ctx-stats-panel { width:300px; flex-shrink:0; border-left:1px solid var(--glass-border); background:var(--glass-bg); display:flex; flex-direction:column; overflow-y:auto; }
.as-ctx-stat-section { padding:16px 20px; border-bottom:1px solid var(--glass-border); }
.as-ctx-stat-title { font-family:var(--font-mono); font-size:10px; font-weight:700; color:var(--text2); letter-spacing:0.8px; margin-bottom:10px; }
.as-ctx-stat-card { flex:1; background:var(--glass-bg); border-radius:8px; padding:10px; text-align:center; }
.as-preset-btn { width:100%; padding:8px 12px; border-radius:6px; border:1px solid var(--glass-border); background:var(--glass-bg); color:var(--text); font-size:12px; font-weight:600; cursor:pointer; text-align:left; display:flex; align-items:center; gap:8px; }
.as-preset-btn:hover { border-color:var(--accent-border); }

/* Transparency Table */
.as-transparency-title { font-family:var(--font-display); font-size:18px; font-weight:700; color:var(--text); margin-bottom:6px; }
.as-transparency-desc { font-family:var(--font-body); font-size:12px; color:var(--text2); margin-bottom:24px; }
.as-transparency-policy { margin-top:24px; padding:14px; border-radius:10px; background:rgba(34,197,94,0.04); border:1px solid rgba(34,197,94,0.15); }

/* ── AI Suite — extracted from inline styles ───────────────────── */
/* AI Studio panel */
.as-panel { flex-direction:column;font-family:inherit; }
.as-panel.active { display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden; }

/* AI Studio full-page mode */
.as-panel.as-fullpage {
  display:flex !important; position:fixed !important; top:0; left:0; right:0; bottom:0; z-index:9000;
  background: linear-gradient(135deg, #0a0a0f 0%, #0d1117 30%, #0a0f1a 60%, #0a0a0f 100%) !important;
  color:#e6edf3;
  --text: #e6edf3; --text2: #8b949e; --text3: #484f58;
  --glass-bg: rgba(22,27,34,0.8); --glass-border: rgba(255,255,255,0.06);
  --accent: #4f8ef7; --accent2: #6c63ff;
}
.as-panel.as-fullpage::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(79,142,247,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,142,247,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}

/* Header bar — supplemental rules */
.as-logo-icon { font-size:16px; }
.as-tab-active { border-bottom-color:var(--accent);color:var(--accent); }
.as-tab-relative { position:relative; }
.as-tab-badge { position:absolute;top:4px;right:8px;background:var(--amber);color:#000;font-size:9px;font-weight:800;border-radius:50%;width:16px;height:16px;line-height:16px;text-align:center; }
.as-tab svg { vertical-align:-1px;margin-right:3px; }
.as-header-controls { display:flex;align-items:center;gap:12px;padding:0 20px; }
.as-close-btn { background:none;border:1px solid var(--glass-border);color:var(--text3);border-radius:6px;padding:4px 10px;cursor:pointer;font-size:13px; }
.as-close-btn:hover { color:var(--text); }

/* Tab body */
.as-tab-body { flex:1;min-height:0;overflow:hidden; }


/* Prompt sidebar — supplemental */
.as-prompt-list { flex:1;overflow-y:auto;padding:4px; }

/* Editor — supplemental */
.as-editor-empty-icon { font-size:36px; }
.as-editor-empty-title { font-size:14px;font-weight:600;color:var(--accent); }
.as-editor-empty-desc { font-size:12px;color:var(--text3);text-align:center;max-width:300px; }
.as-editor-pane { flex:1;flex-direction:column;min-height:0; }
.as-editor-bar-controls { display:flex;align-items:center;gap:6px;padding:5px 0; }
.as-sub-tab-active { border-bottom-color:var(--accent);color:var(--accent); }
.as-history-bar { padding:8px 16px;border-bottom:1px solid var(--glass-border);background:rgba(10,10,15,0.3);max-height:160px;overflow-y:auto;flex-shrink:0; }
.as-section-label { font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--text3);margin-bottom:6px;letter-spacing:0.5px; }
.as-save-note-bar { padding:6px 16px;border-bottom:1px solid var(--glass-border);flex-shrink:0; }
input.as-save-note-input { width:100%;padding:5px 8px;border:1px solid var(--glass-border);border-radius:6px;background:var(--glass-bg);color:var(--text);font-family:var(--font-mono);font-size:11px;box-sizing:border-box;outline:none; }
input.as-save-note-input:focus { border-color:var(--accent-border); }
.as-sub-edit { flex:1;display:flex;flex-direction:column;min-height:0;padding:12px 16px; }
.as-persona-sections { flex:1;overflow-y:auto;flex-direction:column;gap:2px; }
.as-sub-examples { flex:1;overflow-y:auto;padding:16px 20px; }
.as-sub-impact { flex:1;overflow-y:auto;padding:16px 20px; }

/* Chat resizer */
.as-chat-resizer { width:5px;flex-shrink:0;cursor:col-resize;background:rgba(79,142,247,0.15);transition:background 0.15s; }
.as-chat-resizer:hover { background:rgba(79,142,247,0.4); }
.as-chat-input-resizer { height:5px;flex-shrink:0;cursor:ns-resize;background:rgba(79,142,247,0.12);transition:background 0.15s; }
.as-chat-input-resizer:hover { background:rgba(79,142,247,0.3); }

/* Chat pane — supplemental */
.as-chat-controls { display:flex;align-items:center;gap:6px; }
.as-font-btn { padding:2px 6px;font-size:11px;font-weight:700;border:1px solid var(--glass-border);border-radius:5px;color:var(--text3);cursor:pointer;line-height:1.4;user-select:none; }
.as-font-btn:hover { color:var(--text2); }
.as-chat-welcome { text-align:center;padding:20px 10px; }
.as-chat-welcome-icon { font-size:28px;margin-bottom:8px; }
.as-chat-welcome-title { font-size:12px;font-weight:600;color:var(--accent);margin-bottom:6px; }
.as-chat-welcome-desc { font-size:11px;color:var(--text3);line-height:1.5; }
.as-chat-starters { margin-top:12px;display:flex;flex-direction:column;gap:6px; }
.as-chat-input-row { display:flex;gap:6px; }
.as-chat-input { flex:1;resize:none;padding:7px 9px;border:1px solid var(--glass-border);border-radius:8px;background:var(--glass-bg);color:var(--text);font-family:var(--font-body);font-size:13px;line-height:1.4;height:54px;min-height:36px;overflow-y:auto;outline:none; }
.as-chat-input:focus { border-color:var(--accent-border); }
.as-chat-hint { font-family:var(--font-mono);font-size:9px;color:var(--text3);margin-top:4px;text-align:right; }

/* AI Map (Tab 2) */
.as-map-body { flex:1;overflow-y:auto;padding:40px; }
.as-map-container { max-width:860px;margin:0 auto; }
.as-map-intro { font-size:13px;color:var(--text2);margin-bottom:32px;line-height:1.7; }
.as-map-accent { color:var(--accent); }
.as-map-node-center { display:flex;justify-content:center;margin-bottom:8px; }
.as-node-icon-lg { font-size:22px;margin-bottom:5px; }
.as-node-icon-md { font-size:14px;margin-bottom:4px; }
.as-node-title { font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--text); }
.as-node-title-sm { font-family:var(--font-display);font-weight:700;font-size:11px;color:var(--text); }
.as-node-desc { font-family:var(--font-mono);font-size:10px;color:var(--text2);margin-top:3px; }
.as-node-desc-dim { font-family:var(--font-mono);font-size:9px;color:var(--text2);margin-top:3px; }
.as-node-link { font-family:var(--font-mono);font-size:9px;margin-top:7px;color:var(--accent);font-weight:600; }
.as-connector-v { width:2px;height:36px;background:linear-gradient(to bottom,rgba(79,142,247,0.7),rgba(79,142,247,0.1)); }
.as-connector-v-sm { width:2px;height:24px; }
.as-connector-v-sm-tail { width:2px;height:20px; }
.as-map-grid-4 { display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative; }
.as-map-grid-line { position:absolute;top:0;left:12.5%;right:12.5%;height:2px;background:linear-gradient(to right,transparent,rgba(79,142,247,0.5),rgba(79,142,247,0.5),rgba(79,142,247,0.5),transparent); }
.as-map-col { display:flex;flex-direction:column;align-items:center; }
.as-map-impact { margin-top:48px;border:1px solid rgba(79,142,247,0.2);border-radius:12px;overflow:hidden; }
.as-map-impact-hdr { padding:12px 16px;background:rgba(79,142,247,0.08);border-bottom:1px solid rgba(79,142,247,0.2);font-size:12px;font-weight:700;color:var(--accent); }
.as-map-table { width:100%;border-collapse:collapse;font-size:12px; }
.as-map-table thead tr { background:rgba(0,0,0,0.2); }
.as-map-table th { padding:9px 14px;text-align:left;color:var(--text2);font-weight:600;border-bottom:1px solid rgba(79,142,247,0.15); }
.as-map-table tr.as-map-row { border-bottom:1px solid rgba(79,142,247,0.1); }
.as-map-table td { padding:10px 14px; }
.as-map-table td:first-child { font-weight:600; }
.as-map-table td:nth-child(2) { color:var(--text3); }
.as-map-table td:nth-child(3) { color:var(--accent); }

/* AI Wiring Map (Tab 3) */
.as-wiring-body { flex:1;flex-direction:column;min-height:0; }
.as-wiring-legend { display:flex;align-items:center;gap:16px;padding:8px 24px;border-bottom:1px solid rgba(79,142,247,0.15);flex-shrink:0;background:var(--glass-bg);font-size:11px; }
.as-wiring-legend-item { display:flex;align-items:center;gap:5px;color:var(--text3); }
.as-wiring-badge-auto { background:#10b981;color:#fff;font-size:8px;font-weight:700;padding:1px 5px;border-radius:6px; }
.as-wiring-badge-input { background:#f59e0b;color:#fff;font-size:8px;font-weight:700;padding:1px 5px;border-radius:6px; }
.as-wiring-diagram { flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:30px 20px; }

/* Connection Map (Tab 4) */
.as-conn-body { flex:1;overflow-y:auto;padding:36px; }
.as-conn-container { max-width:1020px;margin:0 auto; }
.as-conn-intro { font-family:var(--font-body);font-size:13px;color:var(--text3);margin-bottom:28px;line-height:1.6; }
.as-conn-flow { display:flex;flex-direction:column;gap:2px; }
.as-conn-headers { display:grid;grid-template-columns:190px 24px 210px 24px 190px 24px 210px;align-items:center;padding:0 0 14px;font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--text3);letter-spacing:0.9px; }
.as-conn-headers > div { text-align:center; }
.as-flow-row { display:grid;grid-template-columns:190px 24px 210px 24px 190px 24px 210px;align-items:center;padding:5px 0; }
.as-flow-sep { height:1px;background:rgba(79,142,247,0.08);margin:3px 0; }
.as-flow-arrow { text-align:center;color:rgba(79,142,247,0.45);font-size:18px; }
.as-flow-card { padding:10px 13px;border-radius:8px;font-size:12px;color:var(--text2); }
.as-flow-card-label { font-family:var(--font-mono);font-size:10px;font-weight:700;margin-bottom:4px; }
.as-flow-card-route { padding:10px 13px;border-radius:8px;background:rgba(79,142,247,0.06);border:1px solid rgba(79,142,247,0.18);font-size:11px;color:var(--accent);font-family:var(--font-mono); }
.as-flow-card-route-sub { margin-top:4px;font-size:9px;color:var(--text3);font-family:var(--font-mono); }
.as-flow-model { padding:10px 13px;border-radius:8px;background:rgba(10,10,15,0.3);border:1px solid rgba(79,142,247,0.18);font-size:12px;color:var(--text2);text-align:center; }
.as-flow-model-icon { font-size:15px;margin-bottom:3px; }
.as-flow-model-name { font-family:var(--font-display);font-size:10px;font-weight:700; }
.as-flow-model-note { font-family:var(--font-mono);font-size:9px;color:var(--text3);margin-top:2px; }

/* Flow card color variants */
.as-flow-card-blue { background:rgba(79,142,247,0.07);border:1px solid rgba(79,142,247,0.2); }
.as-flow-card-blue .as-flow-card-label { color:#60a5fa; }
.as-flow-card-red { background:rgba(239,68,68,0.05);border:1px solid rgba(239,68,68,0.18); }
.as-flow-card-red .as-flow-card-label { color:#f87171; }
.as-flow-card-green { background:rgba(16,185,129,0.05);border:1px solid rgba(16,185,129,0.18); }
.as-flow-card-green .as-flow-card-label { color:#34d399; }
.as-flow-card-purple { background:rgba(79,142,247,0.07);border:1px solid rgba(79,142,247,0.2); }
.as-flow-card-purple .as-flow-card-label { color:var(--accent); }
.as-flow-card-orange { background:rgba(234,88,12,0.05);border:1px solid rgba(234,88,12,0.18); }
.as-flow-card-orange .as-flow-card-label { color:#f97316; }
.as-flow-card-blue-lt { background:rgba(79,142,247,0.05);border:1px solid rgba(79,142,247,0.15); }
.as-flow-card-blue-lt .as-flow-card-label { color:#60a5fa; }

/* Flow model name color variants */
.as-flow-model-name.text-blue { color:#60a5fa; }
.as-flow-model-name.text-red { color:#f87171; }
.as-flow-model-name.text-green { color:#34d399; }
.as-flow-model-name.text-purple { color:var(--accent); }
.as-flow-model-name.text-orange { color:#f97316; }
.as-flow-model-name.text-amber { color:#f59e0b; }
.as-flow-model-name.text-teal { color:#38b2ac; }

/* Connector color variants */
.as-connector-v-sm.conn-blue { background:rgba(79,142,247,0.6); }
.as-connector-v-sm-tail.conn-blue { background:rgba(79,142,247,0.3); }
.as-connector-v-sm.conn-purple { background:rgba(79,142,247,0.6); }
.as-connector-v-sm-tail.conn-purple { background:rgba(79,142,247,0.3); }
.as-connector-v-sm.conn-red { background:rgba(239,68,68,0.6); }
.as-connector-v-sm-tail.conn-red { background:rgba(239,68,68,0.3); }
.as-connector-v-sm.conn-green { background:rgba(16,185,129,0.6); }
.as-connector-v-sm-tail.conn-green { background:rgba(16,185,129,0.3); }

/* Connection legend */
.as-conn-legend { margin-top:28px;padding:14px 18px;border:1px solid var(--glass-border);border-radius:10px;background:rgba(10,10,15,0.3); }
.as-conn-legend-title { font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text3);margin-bottom:10px;letter-spacing:0.6px; }
.as-conn-legend-items { display:flex;gap:24px;flex-wrap:wrap; }
.as-conn-legend-item { display:flex;align-items:center;gap:6px; }
.as-conn-legend-dot { width:8px;height:8px;border-radius:50%;display:inline-block; }
.as-conn-legend-text { font-size:11px;color:var(--text2); }

/* AI Improvements (Tab 5) */
.as-fb-body { flex:1;min-height:0;overflow:hidden; }
.as-fb-sidebar { width:380px;flex-shrink:0;border-right:1px solid rgba(245,158,11,0.2);display:flex;flex-direction:column;background:rgba(0,0,0,0.2); }
.as-fb-header { padding:11px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(245,158,11,0.15); }
.as-fb-label { font-size:10px;font-weight:700;color:var(--text2);letter-spacing:0.8px;flex:1; }
.as-fb-filter { font-size:10px;padding:2px 6px;border-radius:4px;background:var(--bg);border:1px solid var(--glass-border);color:var(--text2); }
.as-fb-list { flex:1;overflow-y:auto;padding:6px; }
.as-fb-workshop { flex:1;display:flex;flex-direction:column;min-height:0; }
.as-fb-workshop-header { padding:12px 16px;border-bottom:1px solid rgba(245,158,11,0.15);flex-shrink:0; }
.as-fb-workshop-title { font-size:13px;font-weight:700;color:var(--text); }
.as-fb-workshop-sub { font-size:11px;color:var(--text2);margin-top:2px; }
.as-fb-chat-history { flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px; }
.as-fb-chat-empty { text-align:center;padding:40px 20px;color:var(--text2);font-size:12px; }
.as-fb-chat-bar { padding:10px 16px;border-top:1px solid rgba(245,158,11,0.15);flex-shrink:0;display:flex;gap:8px; }
.as-fb-chat-input { flex:1;padding:8px 12px;font-size:12px;border-radius:8px;background:var(--bg);border:1px solid var(--glass-border);color:var(--text); }
.as-fb-send-btn { background:rgba(245,158,11,0.2);border-color:rgba(245,158,11,0.4);color:#f59e0b; }

/* Context Map (Tab 6) */
.as-ctx-body { flex:1;min-height:0;overflow:hidden;flex-direction:column; }
.as-ctx-topbar { padding:12px 20px;border-bottom:1px solid rgba(79,142,247,0.15);flex-shrink:0;display:flex;align-items:center;gap:16px;background:var(--glass-bg); }
.as-ctx-project-wrap { display:flex;align-items:center;gap:8px; }
.as-ctx-project-label { font-size:10px;font-weight:700;color:var(--accent);letter-spacing:0.8px; }
.as-ctx-project-select { font-size:12px;padding:4px 10px;border-radius:6px;background:var(--bg);border:1px solid rgba(79,142,247,0.25);color:var(--text);min-width:200px; }
.as-ctx-stats-group { display:flex;align-items:center;gap:16px; }
.as-ctx-stat-block { text-align:right; }
.as-ctx-stat-label { font-size:10px;color:var(--text2);letter-spacing:0.5px; }
.as-ctx-stat-value-lg { font-size:16px;font-weight:800;color:var(--accent); }
.as-ctx-stat-value-sm { font-size:11px;color:var(--text2); }
.as-ctx-main { flex:1;display:flex;min-height:0;overflow:hidden; }
.as-ctx-picker { flex:1;overflow-y:auto;padding:16px 20px 100px; }
.as-ctx-section { margin-bottom:20px; }
.as-ctx-section-hdr { display:flex;align-items:center;gap:8px;margin-bottom:10px; }
.as-ctx-section-bar { width:3px;height:16px;border-radius:2px; }
.as-ctx-section-label { font-size:11px;font-weight:700;letter-spacing:0.8px; }
.as-ctx-section-count { font-size:9px;color:var(--text2);background:var(--glass-bg);padding:1px 6px;border-radius:8px; }
.as-ctx-section-line { flex:1;height:1px; }
.as-ctx-section-items { display:flex;flex-direction:column;gap:4px; }
.as-ctx-btn-on { font-size:9px;padding:2px 8px;border-radius:4px;cursor:pointer; }
.as-ctx-btn-off { font-size:9px;padding:2px 8px;border-radius:4px;border:1px solid rgba(255,255,255,0.1);background:none;color:var(--text2);cursor:pointer; }
.as-ctx-btn-purple { border:1px solid rgba(79,142,247,0.3);background:rgba(79,142,247,0.1);color:var(--accent); }
.as-ctx-btn-blue { border:1px solid rgba(79,142,247,0.3);background:rgba(79,142,247,0.1);color:#4f8ef7; }
.as-ctx-btn-amber { border:1px solid rgba(245,158,11,0.3);background:rgba(245,158,11,0.1);color:#f59e0b; }
.as-ctx-btn-green { border:1px solid rgba(34,197,94,0.3);background:rgba(34,197,94,0.1);color:#22c55e; }

/* Stats panel */
.as-ctx-stats-panel { width:300px;flex-shrink:0;border-left:1px solid rgba(79,142,247,0.15);background:rgba(0,0,0,0.2);display:flex;flex-direction:column;overflow-y:auto; }
.as-ctx-stat-section { padding:20px;border-bottom:1px solid rgba(79,142,247,0.1); }
.as-ctx-stat-section-sm { padding:16px 20px;border-bottom:1px solid rgba(79,142,247,0.1); }
.as-ctx-stat-title { font-size:10px;font-weight:700;color:var(--text2);letter-spacing:0.8px;margin-bottom:12px; }
.as-ctx-stat-title-sm { font-size:10px;font-weight:700;color:var(--text2);letter-spacing:0.8px;margin-bottom:10px; }
.as-ctx-progress-bar { height:24px;border-radius:12px;background:var(--glass-bg);overflow:hidden;position:relative;margin-bottom:8px; }
.as-ctx-progress-fill { height:100%;border-radius:12px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width 0.4s ease;width:0%; }
.as-ctx-progress-label { position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,0.5); }
.as-ctx-progress-footer { display:flex;justify-content:space-between;font-size:10px;color:var(--text2); }
.as-ctx-time-grid { display:flex;gap:12px; }
.as-ctx-stat-card { flex:1;background:var(--glass-bg);border-radius:8px;padding:10px;text-align:center; }
.as-ctx-stat-card-label { font-size:9px;color:var(--text2);margin-bottom:4px; }
.as-ctx-stat-card-value { font-size:18px;font-weight:800; }
.as-ctx-stat-card-sub { font-size:9px;margin-top:2px; }

/* Context map section color variants */
.ctx-purple .as-ctx-section-bar { background:var(--accent); }
.ctx-purple .as-ctx-section-label { color:var(--accent); }
.ctx-purple .as-ctx-section-line { background:rgba(79,142,247,0.15); }
.ctx-blue .as-ctx-section-bar { background:#4f8ef7; }
.ctx-blue .as-ctx-section-label { color:#4f8ef7; }
.ctx-blue .as-ctx-section-line { background:rgba(79,142,247,0.15); }
.ctx-amber .as-ctx-section-bar { background:#f59e0b; }
.ctx-amber .as-ctx-section-label { color:#f59e0b; }
.ctx-amber .as-ctx-section-line { background:rgba(245,158,11,0.15); }
.ctx-green .as-ctx-section-bar { background:#22c55e; }
.ctx-green .as-ctx-section-label { color:#22c55e; }
.ctx-green .as-ctx-section-line { background:rgba(34,197,94,0.15); }

/* Context map stat value color variants */
.as-ctx-stat-card-value.text-blue { color:var(--accent); }
.as-ctx-stat-card-value.text-purple { color:var(--accent); }
.as-ctx-stat-card-value.text-amber { color:#f59e0b; }
.as-ctx-stat-card-sub.text-blue-dim { color:rgba(79,142,247,0.5); }
.as-ctx-stat-card-sub.text-purple-dim { color:rgba(167,139,250,0.6); }
.as-ctx-stat-card-sub.text-amber-dim { color:rgba(245,158,11,0.6); }

/* Connection legend dot variants */
.as-conn-legend-dot.dot-purple { background:var(--accent); }
.as-conn-legend-dot.dot-blue { background:#60a5fa; }
.as-conn-legend-dot.dot-green { background:#10b981; }

.as-ctx-breakdown { display:flex;flex-direction:column;gap:6px; }
.as-ctx-presets { padding:16px 20px; }

/* Preset buttons */
.as-preset-btn { width:100%;padding:8px 12px;border-radius:6px;border:1px solid rgba(79,142,247,0.2);background:rgba(79,142,247,0.05);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;text-align:left;display:flex;align-items:center;gap:8px; }
.as-preset-icon { font-size:14px; }
.as-preset-sub { font-size:9px;color:var(--text2);font-weight:400; }

/* AI Transparency (Tab 7) */
.as-transparency-body { flex:1;overflow-y:auto;padding:36px; }
.as-transparency-container { max-width:1000px;margin:0 auto; }
.as-transparency-title { font-size:18px;font-weight:700;color:var(--text);margin-bottom:6px; }
.as-transparency-desc { font-size:12px;color:var(--text2);margin-bottom:24px; }
.as-transparency-table { width:100%;border-collapse:collapse;font-size:11px; }
.as-transparency-table thead tr { border-bottom:2px solid var(--glass-border); }
.as-transparency-table th { text-align:left;padding:10px 12px;color:var(--text);font-weight:700;white-space:nowrap; }
.as-transparency-policy { margin-top:24px;padding:14px;background:rgba(52,211,153,0.06);border:1px solid rgba(52,211,153,0.2);border-radius:10px; }
.as-transparency-policy-title { font-size:11px;font-weight:700;color:#34d399;margin-bottom:6px; }
.as-transparency-policy-text { font-size:11px;color:var(--text2);line-height:1.6; }

/* AI Feedback Modal */
.as-feedback-modal-content { background:var(--bg-mid, #1a1a2e);border:1px solid rgba(245,158,11,0.3);border-radius:14px;width:520px;max-width:95vw;padding:24px;box-shadow:0 16px 48px rgba(0,0,0,0.3); }
.light-theme .as-feedback-modal-content { background:#fff;box-shadow:0 8px 32px rgba(0,0,0,0.1); }
.as-feedback-hdr { display:flex;align-items:center;gap:10px;margin-bottom:16px; }
.as-feedback-icon { font-size:20px; }
.as-feedback-title { font-size:14px;font-weight:700;color:var(--text); }
.as-feedback-sub { font-size:11px;color:var(--text2); }
.as-feedback-context { margin-bottom:10px;padding:8px 10px;border-radius:6px;background:rgba(79,142,247,0.06);border:1px solid rgba(79,142,247,0.15);font-size:11px;color:var(--text2); }
.as-feedback-field-label { font-size:10px;font-weight:700;color:var(--text2);letter-spacing:0.5px;margin-bottom:4px;display:block; }
.as-feedback-textarea { width:100%;padding:10px 12px;font-size:12px;border-radius:8px;background:var(--bg-surface, #111);border:1px solid var(--glass-border);color:var(--text);resize:vertical;box-sizing:border-box;outline:none;transition:border-color 0.2s; }
.as-feedback-textarea:focus { border-color:var(--accent-border); }
.light-theme .as-feedback-textarea { background:#fff; }
.as-feedback-footer { display:flex;align-items:center;gap:8px; }
.as-feedback-note { flex:1;font-size:10px;color:var(--text2); }

/* Utility classes */
.flex { display:flex; }
.flex-col { display:flex;flex-direction:column; }
.flex-center { display:flex;align-items:center;justify-content:center; }
.flex-between { display:flex;align-items:center;justify-content:space-between; }
.items-center { align-items:center; }
.gap-4 { gap:4px; }
.gap-6 { gap:6px; }
.gap-8 { gap:8px; }
.gap-10 { gap:10px; }
.gap-12 { gap:12px; }
.gap-16 { gap:16px; }
.shrink-0 { flex-shrink:0; }
.min-h-0 { min-height:0; }
.overflow-hidden { overflow:hidden; }
.overflow-auto { overflow:auto; }
.hidden { display:none; }
.text-center { text-align:center; }
.w-full { width:100%; }
.cursor-pointer { cursor:pointer; }
.mt-4 { margin-top:4px; }
.mt-8 { margin-top:8px; }
.mt-12 { margin-top:12px; }
.mt-16 { margin-top:16px; }
.mb-4 { margin-bottom:4px; }
.mb-8 { margin-bottom:8px; }
.mb-12 { margin-bottom:12px; }
.mb-16 { margin-bottom:16px; }
.p-8 { padding:8px; }
.p-12 { padding:12px; }
.p-16 { padding:16px; }

/* AI Suite — model badge color variants */
.as-model-badge-blue { background:rgba(79,142,247,0.2);color:#60a5fa; }
.as-model-badge-purple { background:rgba(79,142,247,0.2);color:var(--accent); }
.as-model-badge-red { background:rgba(239,68,68,0.15);color:#f87171; }
.as-model-badge-green { background:rgba(16,185,129,0.15);color:#34d399; }

/* AI Suite — output node color variants */
.as-output-node-blue { background:rgba(79,142,247,0.08);border-color:rgba(79,142,247,0.2);color:var(--accent); }
.as-output-node-purple { background:rgba(79,142,247,0.08);border-color:rgba(79,142,247,0.2);color:var(--accent); }
.as-output-node-red { background:rgba(239,68,68,0.06);border-color:rgba(239,68,68,0.2);color:#f87171; }
.as-output-node-green { background:rgba(16,185,129,0.06);border-color:rgba(16,185,129,0.2);color:#34d399; }

/* AI Suite — map table variants */
.as-map-table-head { background:rgba(0,0,0,0.2); }
.as-map-th { padding:9px 14px;text-align:left;color:var(--text2);font-weight:600;border-bottom:1px solid rgba(79,142,247,0.15); }
.as-map-td { padding:10px 14px; }
.as-map-td-dim { color:var(--text2); }
.as-map-td-accent { color:var(--accent); }
.as-map-td-purple { font-weight:600;color:var(--accent); }
.as-map-td-blue { font-weight:600;color:#60a5fa; }
.as-map-td-red { font-weight:600;color:#f87171; }
.as-map-td-green { font-weight:600;color:#34d399; }

/* AI Suite — transparency table */
.as-transparency-thead-row { border-bottom:2px solid var(--glass-border); }
.as-transparency-th { text-align:left;padding:10px 12px;color:var(--text);font-weight:700;white-space:nowrap; }

/* ═══════════════════════════════════════════════════════════════
   EMAIL WORKSHOP LIGHT THEME — Frosted glass architecture
   Mirrors WF1 redline modal pattern exactly:
   Layer 1: Per-theme gradient + 60px grid on .edm-modal
   Layer 2: Frosted glass bars (header, controls, section bars)
   Layer 3: Frosted pills (approach/tone buttons)
   Layer 4: Solid white inputs — no distraction when typing
   ═══════════════════════════════════════════════════════════════ */

/* ── Layer 1 — Modal background: gradient + grid ── */
/* Hide the dark-theme ::before grid so it doesn't double up */
.light-theme .edm-modal::before {
  display: none !important;
}
/* Base light-theme fallback (Ivory) */
.light-theme .edm-modal {
  background:
    linear-gradient(rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(160deg, #d0cac0 0%, #c4bcb0 25%, #b8b0a4 50%, #c4bcb0 75%, #d0cac0 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-ivory .edm-modal {
  background:
    linear-gradient(rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,184,0.12) 1px, transparent 1px),
    linear-gradient(160deg, #d0cac0 0%, #c4bcb0 25%, #b8b0a4 50%, #c4bcb0 75%, #d0cac0 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-snow .edm-modal {
  background:
    linear-gradient(rgba(37,99,235,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #e0e0e8 0%, #d8d8e2 25%, #d0d0dc 50%, #d8d8e2 75%, #e0e0e8 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-pearl .edm-modal {
  background:
    linear-gradient(rgba(59,130,246,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(59,130,246,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #d5d9df 0%, #cdd1d8 25%, #c5c9d1 50%, #cdd1d8 75%, #d5d9df 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-linen .edm-modal {
  background:
    linear-gradient(rgba(184,134,11,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(184,134,11,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #dfd6c9 0%, #d8cfc1 25%, #d0c6b8 50%, #d8cfc1 75%, #dfd6c9 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}
body.theme-frost .edm-modal {
  background:
    linear-gradient(rgba(2,132,199,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(2,132,199,0.10) 1px, transparent 1px),
    linear-gradient(160deg, #d0d8e2 0%, #c8d0dc 25%, #c0c8d4 50%, #c8d0dc 75%, #d0d8e2 100%) !important;
  background-size: 60px 60px, 60px 60px, 100% 100% !important;
}

/* ── Layer 2 — Frosted glass bars ── */
/* Header bar — frosted glass over grid */
.light-theme .edm-header {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255,255,255,0.4) !important;
  box-shadow: 0 1px 8px rgba(0,0,0,0.04) !important;
}

/* Controls bar — frosted glass */
.light-theme .edm-controls-bar {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 2px solid rgba(255,255,255,0.3) !important;
}

/* Section bars (left panel header, right panel header) — frosted glass */
.light-theme .edm-section-bar,
.light-theme .edm-section-bar-plain,
.light-theme .edm-right-header {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
}

/* Footer bars — frosted glass, vertically aligned */
.light-theme .edm-footer-bar,
.light-theme .edm-output-footer {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255,255,255,0.3) !important;
  padding: 7px 14px !important;
  display: flex !important;
  align-items: center !important;
}
/* Output footer buttons — match btn-sm exactly (5px 10px, 12px font) */
.light-theme .edm-output-footer .btn {
  font-size: 12px !important;
  padding: 5px 10px !important;
}

/* Refine bar — frosted glass */
.light-theme .edm-refine-bar {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255,255,255,0.3) !important;
}
.light-theme .edm-refine-input {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.12) !important;
  color: var(--text) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}
.light-theme .edm-refine-send {
  box-shadow: 0 1px 6px rgba(79,142,247,0.25) !important;
}

/* User draft bar — frosted with subtle accent tint */
.light-theme .edm-user-draft-bar {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
}

/* Claude label bar — frosted with subtle accent tint */
.light-theme .edm-claude-label {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
}

/* Header card (email metadata) — frosted */
.light-theme .edm-header-card {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
}

/* ── Layer 2b — Panels transparent so grid shows through ── */
.light-theme .edm-left-panel {
  border-right: 1px solid rgba(0,0,0,0.08) !important;
}
.light-theme .edm-scroll-area,
.light-theme .edm-output-scroll,
.light-theme .edm-left-new,
.light-theme .edm-refine-body {
  background: transparent !important;
}

/* ── Layer 2c — Tab group — frosted pill container ── */
.light-theme .edm-tab-group {
  background: rgba(255,255,255,0.35) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-color: rgba(0,0,0,0.08) !important;
}
.light-theme .edm-tab {
  color: var(--text2) !important;
}
.light-theme .edm-tab.active {
  background: rgba(255,255,255,0.75) !important;
  color: var(--text) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
}

/* ── Layer 3 — Approach & tone buttons as rounded rectangles ── */
.light-theme .email-approach-btn {
  background: rgba(255,255,255,0.75) !important;
  border-color: rgba(0,0,0,0.08) !important;
  color: var(--text2) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05) !important;
  border-radius: 7px !important;
}
.light-theme .email-approach-btn:hover {
  background: #fff !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  box-shadow: 0 1px 6px rgba(79,142,247,0.15) !important;
}
.light-theme .email-approach-btn.active {
  background: #fff !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  box-shadow: 0 1px 6px rgba(79,142,247,0.15) !important;
  font-weight: 700 !important;
}

.light-theme .email-tone-btn {
  background: rgba(255,255,255,0.75) !important;
  border-color: rgba(0,0,0,0.08) !important;
  color: var(--text2) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05) !important;
  border-radius: 7px !important;
}
.light-theme .email-tone-btn:hover {
  background: #fff !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  box-shadow: 0 1px 6px rgba(79,142,247,0.15) !important;
}
.light-theme .email-tone-btn.active {
  background: #fff !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  box-shadow: 0 1px 6px rgba(79,142,247,0.15) !important;
  font-weight: 600 !important;
}

/* ── Layer 3b — Divider ── */
.light-theme .edm-divider-v {
  background: rgba(0,0,0,0.08) !important;
}

/* ── Layer 3c — Labels ── */
.light-theme .edm-approach-label {
  color: var(--text2) !important;
}
.light-theme .edm-section-label {
  color: var(--text2) !important;
}
.light-theme .edm-user-draft-label {
  color: var(--accent) !important;
}

/* ── Layer 4 — Solid white inputs ── */
.light-theme .edm-instructions-input,
.light-theme .edm-select {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.12) !important;
  color: var(--text) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}
.light-theme .edm-source-textarea,
.light-theme .edm-keypoints-textarea,
.light-theme .edm-refine-textarea,
.light-theme .edm-user-draft-textarea {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-radius: 8px !important;
  color: var(--text) !important;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.04) !important;
  margin: 8px !important;
  padding: 12px 14px !important;
}

/* Generate button — keep accent solid */
.light-theme .edm-gen-btn {
  background: var(--accent) !important;
  color: #fff !important;
  box-shadow: 0 1px 6px rgba(79,142,247,0.25) !important;
}
.light-theme .edm-gen-btn:hover {
  box-shadow: 0 2px 10px rgba(79,142,247,0.35) !important;
}


/* Placeholder text */
.light-theme .edm-placeholder {
  color: var(--text2) !important;
}
.light-theme .edm-placeholder-icon {
  opacity: 0.08 !important;
}

/* Panel border refinement */
.light-theme .edm-user-draft-pane {
  border-bottom-color: rgba(0,0,0,0.08) !important;
}

/* ── Layer 5 — White bubble cards for content areas ── */
/* Email source text — white card bubble in the scroll area */
.light-theme .edm-scroll-area {
  padding: 14px 18px !important;
}
.light-theme .edm-body-pre {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
}

/* Email header card (Subject/From/To/Date) — frosted bar, full width */
.light-theme .edm-header-card {
  background: rgba(255,255,255,0.60) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
  margin: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Claude output — white card bubble */
.light-theme .edm-output-scroll {
  padding: 14px 18px !important;
}
.light-theme .edm-output-pre {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
}

/* User draft textarea — white card bubble */
.light-theme .edm-user-draft-pane {
  background: transparent !important;
}
.light-theme .edm-user-draft-textarea {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
  border-radius: 14px !important;
  margin: 12px 18px !important;
  padding: 14px 18px !important;
}

/* ═══════════════════════════════════════════════════════════════
   HELP SYSTEM — Light theme overrides
   ═══════════════════════════════════════════════════════════════ */

/* AI badge — subtle blue on white */
.light-theme .help-ai-badge {
  background: rgba(79,142,247,0.10) !important;
  border: 1px solid rgba(79,142,247,0.15);
}

/* Tip callout — soft blue tint */
.light-theme .help-tip {
  background: rgba(79,142,247,0.06) !important;
  border-color: rgba(79,142,247,0.15) !important;
}

/* Callout boxes — softer tints for light backgrounds */
.light-theme .help-callout-blue {
  background: rgba(79,142,247,0.05) !important;
  border-color: rgba(79,142,247,0.15) !important;
}
.light-theme .help-callout-green {
  background: linear-gradient(135deg, rgba(56,161,105,0.06), rgba(229,62,62,0.04)) !important;
  border-color: rgba(56,161,105,0.15) !important;
}
.light-theme .help-callout-purple {
  background: rgba(167,139,250,0.06) !important;
  border-color: rgba(167,139,250,0.15) !important;
}

/* Summary box */
.light-theme .help-summary-box {
  background: rgba(0,0,0,0.03) !important;
}

/* Card spans — softer tints */
.light-theme .help-card-span-blue {
  background: rgba(79,142,247,0.04) !important;
  border-color: rgba(79,142,247,0.15) !important;
}
.light-theme .help-card-span-purple {
  background: rgba(79,142,247,0.04) !important;
  border-color: rgba(79,142,247,0.15) !important;
}
.light-theme .help-card-span-teal {
  background: rgba(56,178,172,0.04) !important;
  border-color: rgba(56,178,172,0.15) !important;
}

/* Help cards — white with subtle border */
.light-theme .help-card {
  background: #fff !important;
  border-color: rgba(0,0,0,0.08) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}

/* Help features — white */
.light-theme .help-feature {
  background: #fff !important;
  border-color: rgba(0,0,0,0.08) !important;
}

/* Help popover — white card, softer shadow */
.light-theme #helpPopover {
  background: #fff !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.12) !important;
  border-color: var(--warning) !important;
}

/* Info boxes */
.light-theme .hg-info-box,
.light-theme .hg-info-box-mt {
  background: rgba(0,0,0,0.03) !important;
}

/* ═══════════════════════════════════════════════════════════════
   AI STUDIO — Complete Light Theme Overrides
   Frosted glass architecture matching WF1 design language
   ═══════════════════════════════════════════════════════════════ */

/* ── Text — all faint/dim text readable on light ── */
.light-theme .as-map-intro,
.light-theme .as-fb-label,
.light-theme .as-ctx-stat-title,
.light-theme .as-ctx-stat-title-sm,
.light-theme .as-feedback-field-label,
.light-theme .as-map-td-dim,
.light-theme .as-map-th,
.light-theme .as-section-label,
.light-theme .as-conn-desc,
.light-theme .as-conn-headers,
.light-theme .as-conn-legend-title,
.light-theme .as-flow-card-route-sub,
.light-theme .as-page-desc,
.light-theme .as-node-desc,
.light-theme .as-node-desc-dim,
.light-theme .as-node-desc-dim,
.light-theme .as-chat-hint,
.light-theme .as-chat-welcome-desc,
.light-theme .as-editor-empty-desc,
.light-theme .as-chat-sub,
.light-theme .as-prompt-meta,
.light-theme .as-prompt-sidebar-hdr,
.light-theme .as-wiring-legend-item,
.light-theme .as-flow-model-note {
  color: var(--text2) !important;
}

/* ── Tab bar ── */
.light-theme .as-tab {
  color: var(--text2) !important;
}
.light-theme .as-tab:hover {
  color: var(--text) !important;
}
.light-theme .as-tab.active {
  color: var(--accent) !important;
}
.light-theme .as-tab-bar {
  border-bottom-color: rgba(0,0,0,0.08) !important;
}

/* ── Sub-tabs ── */
.light-theme .as-sub-tab {
  color: var(--text2) !important;
}
.light-theme .as-sub-tab:hover {
  color: var(--text) !important;
}
.light-theme .as-sub-edit-active,
.light-theme .as-sub-tab-active {
  color: var(--accent) !important;
  border-bottom-color: var(--accent) !important;
}

/* ── Map table ── */
.light-theme .as-map-table-head,
.light-theme .as-map-table thead tr {
  background: rgba(0,0,0,0.03) !important;
}
.light-theme .as-map-th {
  border-bottom-color: rgba(79,142,247,0.12) !important;
}

/* ── Progress bar ── */
.light-theme .as-ctx-progress-bar {
  background: rgba(0,0,0,0.06) !important;
}
.light-theme .as-ctx-progress-label {
  color: #fff !important;
  text-shadow: 0 1px 3px rgba(0,0,0,0.3) !important;
}

/* ── Output nodes — accent-colored text ── */
.light-theme .as-output-node {
  background: #fff !important;
  border-color: rgba(0,0,0,0.08) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}
.light-theme .as-output-node-blue { background: rgba(79,142,247,0.08) !important; border-color: rgba(79,142,247,0.2) !important; color: var(--accent) !important; }
.light-theme .as-output-node-purple { background: rgba(79,142,247,0.08) !important; border-color: rgba(79,142,247,0.2) !important; color: var(--accent) !important; }
.light-theme .as-output-node-red { background: rgba(239,68,68,0.06) !important; border-color: rgba(239,68,68,0.2) !important; color: #ef4444 !important; }
.light-theme .as-output-node-green { background: rgba(16,185,129,0.06) !important; border-color: rgba(16,185,129,0.2) !important; color: #10b981 !important; }

/* ── Frosted glass bars ── */
.light-theme .as-chat-header {
  background: rgba(255,255,255,0.60) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  border-bottom: 1px solid rgba(255,255,255,0.3) !important;
}
.light-theme .as-chat-input-wrap {
  background: rgba(255,255,255,0.55) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}
.light-theme .as-history-bar {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-bottom-color: rgba(0,0,0,0.06) !important;
}
.light-theme .as-save-note-bar {
  background: rgba(255,255,255,0.45) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
.light-theme .as-ctx-topbar {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  border-bottom: 1px solid rgba(0,0,0,0.06) !important;
}

/* ── Dark background panels → light frosted ── */
.light-theme .as-fb-sidebar {
  background: rgba(245,158,11,0.03) !important;
  border-right: 1px solid rgba(245,158,11,0.10) !important;
}
.light-theme .as-ctx-stats-panel {
  background: rgba(79,142,247,0.03) !important;
  border-left: 1px solid rgba(79,142,247,0.10) !important;
}

/* ── Connection map ── */
.light-theme .as-flow-model {
  background: rgba(79,142,247,0.05) !important;
  border-color: rgba(79,142,247,0.15) !important;
}
.light-theme .as-conn-legend {
  background: rgba(79,142,247,0.03) !important;
  border-color: rgba(0,0,0,0.06) !important;
}
.light-theme .as-flow-arrow {
  color: rgba(79,142,247,0.5) !important;
}
.light-theme .as-flow-sep {
  background: rgba(79,142,247,0.12) !important;
}

/* ── White inputs ── */
.light-theme .as-chat-input,
.light-theme .as-fb-chat-input,
.light-theme .as-ctx-project-select,
.light-theme .as-feedback-textarea,
.light-theme input.as-save-note-input {
  background: #fff !important;
  border-color: rgba(0,0,0,0.12) !important;
  color: var(--text) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}

/* ── Buttons ── */
.light-theme .as-btn-sm {
  border-color: rgba(0,0,0,0.12) !important;
  color: var(--text2) !important;
}
.light-theme .as-btn-sm:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}
.light-theme .as-font-btn {
  color: var(--text2) !important;
  border-color: rgba(0,0,0,0.08) !important;
}
.light-theme .as-font-btn:hover {
  color: var(--text) !important;
}
.light-theme .as-ctx-btn-off {
  border-color: rgba(0,0,0,0.10) !important;
  color: var(--text2) !important;
}
.light-theme .as-preset-btn {
  background: rgba(79,142,247,0.06) !important;
  border-color: rgba(79,142,247,0.15) !important;
}
.light-theme .as-preset-btn:hover {
  border-color: var(--accent) !important;
}
.light-theme .as-save-btn {
  background: rgba(34,197,94,0.08) !important;
  border-color: rgba(34,197,94,0.20) !important;
}

/* ── Badges ── */
.light-theme .as-version-badge {
  background: rgba(79,142,247,0.10) !important;
}
.light-theme .as-custom-badge {
  background: rgba(52,211,153,0.10) !important;
}

/* ── AI Map nodes — visible on light ── */
.light-theme .as-node-persona {
  background: linear-gradient(135deg, rgba(79,142,247,0.10), rgba(79,142,247,0.06)) !important;
  border-color: rgba(79,142,247,0.30) !important;
}
.light-theme .as-node-chat {
  background: rgba(79,142,247,0.07) !important;
  border-color: rgba(79,142,247,0.25) !important;
}
.light-theme .as-node-redline {
  background: rgba(79,142,247,0.07) !important;
  border-color: rgba(79,142,247,0.20) !important;
}
.light-theme .as-node-risk {
  background: rgba(239,68,68,0.06) !important;
  border-color: rgba(239,68,68,0.20) !important;
}
.light-theme .as-node-context {
  background: rgba(16,185,129,0.06) !important;
  border-color: rgba(16,185,129,0.20) !important;
}

/* ── Examples (Edit tab) ── */
.light-theme .as-ex-block {
  background: rgba(255,255,255,0.60) !important;
  border-color: rgba(0,0,0,0.06) !important;
}
.light-theme .as-ex-good {
  background: rgba(16,185,129,0.06) !important;
  border-color: rgba(16,185,129,0.18) !important;
}
.light-theme .as-ex-bad {
  background: rgba(239,68,68,0.06) !important;
  border-color: rgba(239,68,68,0.18) !important;
}

/* ── Transparency ── */
.light-theme .as-transparency-policy {
  background: rgba(52,211,153,0.05) !important;
  border-color: rgba(52,211,153,0.15) !important;
}
.light-theme .as-transparency-policy-title {
  color: #10b981 !important;
}
.light-theme .as-transparency-table {
  border-color: rgba(0,0,0,0.06) !important;
}

/* ── Feedback / Improvements ── */
.light-theme .as-fb-header {
  border-bottom-color: rgba(245,158,11,0.12) !important;
}
.light-theme .as-fb-workshop-header {
  border-bottom-color: rgba(245,158,11,0.10) !important;
}
.light-theme .as-fb-chat-bar {
  border-top-color: rgba(245,158,11,0.10) !important;
}
.light-theme .as-fb-send-btn {
  background: rgba(245,158,11,0.12) !important;
  border-color: rgba(245,158,11,0.25) !important;
}
.light-theme .as-feedback-context {
  background: rgba(79,142,247,0.05) !important;
  border-color: rgba(79,142,247,0.12) !important;
}

/* ── Persona sections ── */
.light-theme .as-persona-sections {
  background: transparent !important;
}

/* ── Chat resizers ── */
.light-theme .as-chat-resizer {
  background: rgba(79,142,247,0.08) !important;
}
.light-theme .as-chat-resizer:hover {
  background: rgba(79,142,247,0.20) !important;
}
.light-theme .as-chat-input-resizer {
  background: rgba(79,142,247,0.06) !important;
}
.light-theme .as-chat-input-resizer:hover {
  background: rgba(79,142,247,0.18) !important;
}

/* ── Connectors & wiring ── */
.light-theme .as-connector-v {
  background: linear-gradient(to bottom, rgba(79,142,247,0.4), rgba(79,142,247,0.08)) !important;
}
.light-theme .as-wiring-legend {
  background: rgba(255,255,255,0.50) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

/* ═══ LDDR Builder ═══════════════════════════════════════════════════════════ */

/* ═══ Email Archive ═══════════════════════════════════════════════════════════ */

.ea-layout { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.ea-header { display:flex; align-items:center; justify-content:space-between; padding:16px 20px 12px; border-bottom:1px solid var(--glass-border); flex-shrink:0; }
.ea-title { font-family:var(--font-display); font-size:16px; font-weight:700; color:var(--text-primary); }
.ea-subtitle { font-size:11px; color:var(--text-dim); margin-top:2px; }
.ea-body { flex:1; overflow-y:auto; padding:16px 20px; }
.ea-search { background:var(--glass-bg); border:1px solid var(--glass-border); color:var(--text-primary); padding:6px 12px; border-radius:6px; font-size:12px; width:240px; }
.ea-search:focus { outline:none; border-color:var(--cyan); }

/* Empty state */
.ea-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:60px 20px; text-align:center; }
.ea-empty-icon { opacity:0.4; }
.ea-empty-title { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--text-primary); }
.ea-empty-desc { font-size:12px; color:var(--text-muted); max-width:360px; line-height:1.6; }

/* Import cards grid */
.ea-imports-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:12px; }
.ea-import-card { background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:10px; padding:16px; transition:border-color .15s, transform .1s; }
.ea-card-done { cursor:pointer; }
.ea-card-done:hover { border-color:var(--cyan); transform:translateY(-1px); }
.ea-card-top { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:10px; }
.ea-card-icon { opacity:0.7; }
.ea-card-del { background:none; border:none; color:var(--text-dim); cursor:pointer; font-size:16px; padding:0 4px; }
.ea-card-del:hover { color:#ef4444; }
.ea-card-name { font-weight:600; font-size:13px; color:var(--text-primary); margin-bottom:4px; }
.ea-card-meta { font-size:11px; color:var(--text-muted); }
.ea-card-stats { font-family:var(--font-mono); font-size:12px; color:var(--cyan); margin-top:8px; font-weight:600; }
.ea-card-status { margin-top:8px; }
.ea-parsing-indicator { display:flex; align-items:center; gap:8px; font-size:11px; color:var(--text-muted); }
.ea-spinner { width:14px; height:14px; border:2px solid var(--glass-border); border-top-color:var(--cyan); border-radius:50%; animation:ea-spin 0.8s linear infinite; }
@keyframes ea-spin { to { transform:rotate(360deg); } }

/* Browse layout — folder sidebar + email list */
.ea-browse-layout { display:flex; flex:1; overflow:hidden; }
.ea-folder-sidebar { width:220px; flex-shrink:0; border-right:1px solid var(--glass-border); overflow-y:auto; padding:12px 0; }
.ea-folder-title { font-family:var(--font-mono); font-size:9px; font-weight:600; color:var(--text-dim); text-transform:uppercase; letter-spacing:1px; padding:4px 14px; margin-top:4px; }
.ea-folder-item { display:flex; align-items:center; justify-content:space-between; padding:5px 14px; font-size:11px; color:var(--text-muted); cursor:pointer; transition:background .1s; }
.ea-folder-item:hover { background:var(--glass-bg); }
.ea-folder-item.active { color:var(--text-primary); background:var(--glass-bg); font-weight:600; }
.ea-folder-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; }
.ea-folder-count { font-family:var(--font-mono); font-size:10px; color:var(--text-dim); flex-shrink:0; margin-left:6px; }
.ea-stat-item { font-size:10px; color:var(--text-dim); padding:2px 14px; }
.ea-sender-item { display:flex; align-items:center; justify-content:space-between; padding:3px 14px; font-size:10px; color:var(--text-muted); cursor:pointer; }
.ea-sender-item:hover { color:var(--cyan); }
.ea-sender-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; }

/* Email list */
.ea-email-list { flex:1; overflow-y:auto; }
.ea-email-row { display:flex; align-items:center; padding:8px 16px; border-bottom:1px solid var(--glass-border); cursor:pointer; transition:background .1s; gap:12px; }
.ea-email-row:hover { background:var(--glass-bg); }
.ea-row-sender { font-size:12px; font-weight:600; color:var(--text-primary); width:160px; flex-shrink:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ea-row-content { flex:1; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.ea-row-subject { font-size:12px; color:var(--text-primary); }
.ea-row-preview { font-size:11px; color:var(--text-dim); }
.ea-row-meta { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.ea-row-date { font-size:10px; font-family:var(--font-mono); color:var(--text-dim); white-space:nowrap; }
.ea-row-tag { font-size:8px; font-weight:700; padding:1px 6px; border-radius:3px; text-transform:uppercase; letter-spacing:0.3px; }
.ea-tag-project { background:rgba(79,142,247,0.15); color:var(--cyan); }
.ea-tag-client { background:rgba(168,85,247,0.15); color:#a855f7; }
.ea-tag-reference { background:rgba(34,197,94,0.15); color:#22c55e; }
.ea-tag-admin { background:rgba(249,115,22,0.15); color:#f97316; }
.ea-tag-skip { background:rgba(107,114,128,0.15); color:#6b7280; }
.ea-no-results { padding:40px; text-align:center; font-size:12px; color:var(--text-dim); }

/* Pagination */
.ea-pagination { display:flex; align-items:center; justify-content:center; gap:12px; padding:12px; border-top:1px solid var(--glass-border); }
.ea-page-info { font-size:11px; font-family:var(--font-mono); color:var(--text-dim); }

/* Email detail */
.ea-email-detail { flex:1; overflow-y:auto; padding:16px 20px; }
.ea-detail-meta { background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:8px; padding:12px 16px; margin-bottom:16px; }
.ea-meta-row { display:flex; gap:12px; padding:3px 0; font-size:12px; }
.ea-meta-label { color:var(--text-dim); width:50px; flex-shrink:0; font-weight:600; font-size:10px; text-transform:uppercase; }
.ea-meta-value { color:var(--text-primary); flex:1; word-break:break-all; }
.ea-tag-select { background:var(--glass-bg); border:1px solid var(--glass-border); color:var(--text-primary); padding:4px 8px; border-radius:4px; font-size:11px; }
.ea-tag-select:focus { outline:none; border-color:var(--cyan); }

/* Attachments */
.ea-attachments { margin-bottom:16px; }
.ea-att-title { font-family:var(--font-mono); font-size:10px; font-weight:600; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:8px; }
.ea-att-list { display:flex; flex-wrap:wrap; gap:6px; }
.ea-att-item { display:flex; align-items:center; gap:6px; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:6px; padding:6px 10px; font-size:11px; }
.ea-att-name { color:var(--text-primary); }
.ea-att-size { color:var(--text-dim); font-family:var(--font-mono); font-size:10px; }

/* Email body iframe */
.ea-body-frame { flex:1; min-height:300px; }
.ea-body-iframe { width:100%; height:100%; min-height:400px; border:1px solid var(--glass-border); border-radius:6px; background:#fff; }

/* ═══ Precedent Library v2 ════════════════════════════════════════════════════ */

.prec-v2-layout { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.prec-v2-header { display:flex; align-items:center; justify-content:space-between; padding:16px 20px 12px; border-bottom:1px solid var(--glass-border); flex-shrink:0; }
.prec-v2-title { font-family:var(--font-display); font-size:16px; font-weight:700; color:var(--text-primary); }
.prec-v2-subtitle { font-size:11px; color:var(--text-dim); margin-top:2px; }
.prec-v2-search { background:var(--glass-bg); border:1px solid var(--glass-border); color:var(--text-primary); padding:6px 12px; border-radius:6px; font-size:12px; width:220px; }
.prec-v2-search:focus { outline:none; border-color:var(--cyan); }

.prec-v2-body { flex:1; overflow-y:auto; padding:16px 20px; }
.prec-v2-loading { font-size:12px; color:var(--text-dim); padding:40px; text-align:center; }

/* Deal cards */
.prec-v2-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:12px; }
.prec-v2-card { background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:10px; padding:14px 16px; cursor:pointer; transition:border-color .15s, transform .1s; }
.prec-v2-card:hover { border-color:var(--cyan); transform:translateY(-1px); }
.prec-v2-card-name { font-weight:600; font-size:13px; color:var(--text-primary); margin-bottom:4px; }
.prec-v2-card-meta { font-size:11px; color:var(--text-muted); line-height:1.5; }
.prec-v2-card-tags { display:flex; flex-wrap:wrap; gap:4px; margin-top:8px; }
.prec-v2-card-tag { font-size:9px; font-weight:600; padding:2px 8px; border-radius:4px; background:rgba(79,142,247,0.1); color:var(--cyan); text-transform:uppercase; letter-spacing:0.3px; }
.prec-v2-card-docs { font-family:var(--font-mono); font-size:10px; color:var(--text-dim); margin-top:6px; }

.prec-v2-grid-dragover { outline:2px dashed var(--cyan); outline-offset:-4px; border-radius:10px; background:rgba(79,142,247,0.04); }

.prec-v2-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:60px 20px; text-align:center; }
.prec-v2-empty-title { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--text-primary); }
.prec-v2-empty-desc { font-size:12px; color:var(--text-muted); max-width:320px; }

/* Deal detail view */
.prec-v2-detail { flex:1; overflow-y:auto; padding:16px 20px; }
.prec-v2-detail-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.prec-v2-detail-title { font-family:var(--font-display); font-size:18px; font-weight:700; color:var(--text-primary); }
.prec-v2-detail-meta { display:grid; grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:8px; margin-bottom:20px; }
.prec-v2-meta-item { background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:6px; padding:8px 12px; }
.prec-v2-meta-label { font-size:9px; font-weight:600; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.5px; }
.prec-v2-meta-value { font-size:12px; color:var(--text-primary); margin-top:2px; }

/* Document upload area */
.prec-v2-docs-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.prec-v2-docs-title { font-family:var(--font-mono); font-size:11px; color:var(--text-dim); text-transform:uppercase; letter-spacing:1px; }
.prec-v2-doc-list { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.prec-v2-doc-item { display:flex; align-items:center; gap:10px; padding:6px 12px; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:6px; min-height:36px; }
.prec-v2-doc-name { font-size:11px; color:var(--text-primary); flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.prec-v2-doc-icon { color:var(--cyan); flex-shrink:0; }
.prec-v2-doc-slot { font-family:var(--font-mono); font-size:10px; color:var(--text-dim); }
.prec-v2-doc-type { background:var(--glass-bg, rgba(255,255,255,0.03)); border:1px solid var(--glass-border, rgba(255,255,255,0.06)); border-radius:4px; padding:4px 6px; font-size:10px; font-weight:600; cursor:pointer; flex-shrink:0; width:140px; max-width:140px; color:var(--cyan, #4f8ef7); -webkit-appearance:menulist; appearance:menulist; }
.prec-v2-doc-type:focus { outline:none; border-color:var(--cyan); }
.prec-v2-doc-type option { background:#1a1a2e; color:#e0e0e0; }
.prec-v2-doc-del { background:none; border:none; color:var(--text-dim); cursor:pointer; padding:4px; flex-shrink:0; }
.prec-v2-doc-del:hover { color:#ef4444; }

/* Folder Scanner */
.scan-row { transition:background 0.12s; border-radius:4px; }
.scan-row:hover { background:rgba(79,142,247,0.08) !important; }
.scan-row.scan-focused { background:rgba(79,142,247,0.15) !important; outline:1px solid rgba(79,142,247,0.3); }
@keyframes scan-spin { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }
.sr-matrix-row:hover { background:rgba(79,142,247,0.08); }
.sr-matrix-row:hover td { background:transparent; }

.prec-v2-drop { border:2px dashed var(--glass-border); border-radius:10px; padding:24px; text-align:center; cursor:pointer; transition:border-color .15s; }
.prec-v2-drop:hover, .prec-v2-drop.dragover { border-color:var(--cyan); background:rgba(79,142,247,0.04); }
.prec-v2-drop-text { font-size:12px; color:var(--text-muted); }

/* Panel layout */
#panel-lddr { overflow:hidden; }
#panel-lddr .lddr-workspace { height:100%; }
#panel-lddr .lddr-columns { flex:1; min-height:0; }

.lddr-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:40px 20px; text-align:center; }
.lddr-empty-icon { color:var(--text-dim, #64748b); opacity:0.5; }
.lddr-empty-title { font-family:var(--font-display, 'Rajdhani', sans-serif); font-size:16px; font-weight:600; color:var(--text-primary, #e6edf3); }
.lddr-empty-desc { font-size:12px; color:var(--text-muted, #475569); max-width:280px; }

.lddr-report-list { padding:8px; }
.lddr-list-header { display:flex; align-items:center; justify-content:space-between; padding:4px 8px 12px; font-family:var(--font-mono, monospace); font-size:11px; color:var(--text-dim); letter-spacing:1px; text-transform:uppercase; }
.lddr-report-card { padding:12px; margin-bottom:8px; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:8px; cursor:pointer; transition:border-color .15s; }
.lddr-report-card:hover { border-color:var(--cyan, #4f8ef7); }
.lddr-report-title { font-weight:600; font-size:13px; color:var(--text-primary); }
.lddr-report-meta { font-size:11px; color:var(--text-muted); margin-top:4px; }

/* Workspace layout */
.lddr-workspace { display:flex; flex-direction:column; height:100%; min-height:0; }
.lddr-topbar { display:flex; align-items:center; justify-content:space-between; padding:8px 12px; border-bottom:1px solid var(--glass-border); flex-shrink:0; }
.lddr-topbar-left { display:flex; align-items:center; gap:8px; }
.lddr-topbar-right { display:flex; align-items:center; gap:8px; }
.lddr-back-btn { background:none; border:none; color:var(--text-muted); cursor:pointer; padding:4px; border-radius:4px; }
.lddr-back-btn:hover { background:var(--glass-bg); color:var(--text-primary); }
.lddr-title { font-family:var(--font-display); font-weight:600; font-size:14px; color:var(--text-primary); }
.lddr-version { font-family:var(--font-mono); font-size:10px; color:var(--text-dim); padding:2px 6px; background:var(--glass-bg); border-radius:4px; }
.lddr-status { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:0.5px; padding:2px 8px; border-radius:4px; }
.lddr-status-draft { color:#fbbf24; background:rgba(251,191,36,0.1); }
.lddr-status-review { color:#4f8ef7; background:rgba(79,142,247,0.1); }
.lddr-status-final { color:#22c55e; background:rgba(34,197,94,0.1); }

.lddr-risk-summary { display:flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:11px; color:var(--text-muted); }
.lddr-risk-dot { width:8px; height:8px; border-radius:50%; display:inline-block; margin-left:4px; }
.lddr-risk-high { background:#ef4444; }
.lddr-risk-medium { background:#f59e0b; }
.lddr-risk-low { background:#22c55e; }

/* Three columns */
.lddr-columns { display:flex; flex:1; min-height:0; overflow:hidden; }
.lddr-col-tree { width:220px; min-width:180px; border-right:1px solid var(--glass-border); overflow-y:auto; flex-shrink:0; }
.lddr-col-editor { flex:1; min-width:280px; overflow-y:auto; padding:12px; }
.lddr-col-ref { width:300px; min-width:200px; border-left:1px solid var(--glass-border); overflow-y:auto; flex-shrink:0; }

/* Contract tree */
.lddr-tree-header { display:flex; align-items:center; justify-content:space-between; padding:8px 10px; font-family:var(--font-mono); font-size:10px; color:var(--text-dim); letter-spacing:1px; text-transform:uppercase; }
.lddr-tree-add { background:none; border:1px solid var(--glass-border); color:var(--cyan); width:20px; height:20px; border-radius:4px; cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; }
.lddr-tree-add:hover { background:var(--glass-bg); }

.lddr-tree-contract { padding:6px 10px; cursor:pointer; border-left:3px solid transparent; transition:all .1s; }
.lddr-tree-contract:hover { background:var(--glass-bg); }
.lddr-tree-contract.active { background:var(--glass-bg); border-left-color:var(--cyan); }
.lddr-tree-contract-row { display:flex; align-items:center; justify-content:space-between; }
.lddr-tree-contract-name { font-size:12px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.lddr-tree-badges { display:flex; gap:4px; flex-shrink:0; }
.lddr-badge-high { font-size:9px; font-weight:700; color:#ef4444; background:rgba(239,68,68,0.12); padding:1px 5px; border-radius:3px; }
.lddr-badge-med { font-size:9px; font-weight:700; color:#f59e0b; background:rgba(245,158,11,0.12); padding:1px 5px; border-radius:3px; }
.lddr-badge-low { font-size:9px; font-weight:700; color:#22c55e; background:rgba(34,197,94,0.12); padding:1px 5px; border-radius:3px; }

.lddr-tree-issue { display:flex; align-items:center; gap:6px; padding:4px 10px 4px 18px; cursor:pointer; border-radius:4px; margin:1px 4px; }
.lddr-tree-issue:hover { background:rgba(79,142,247,0.08); }
.lddr-tree-issue.active { background:rgba(79,142,247,0.15); }
.lddr-tree-issue-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.lddr-tree-issue-ref { font-family:var(--font-mono); font-size:10px; color:var(--text-dim); flex-shrink:0; }
.lddr-tree-issue-topic { font-size:11px; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.lddr-tree-add-issue { font-size:11px; color:var(--cyan); padding:4px 18px; cursor:pointer; opacity:0.6; }
.lddr-tree-add-issue:hover { opacity:1; }

/* Editor */
.lddr-editor-empty, .lddr-ref-empty, .lddr-ref-loading { display:flex; align-items:center; justify-content:center; height:100%; font-size:12px; color:var(--text-dim); padding:20px; text-align:center; }
.lddr-editor-section { display:flex; flex-direction:column; gap:12px; }
.lddr-editor-header { display:flex; align-items:center; justify-content:space-between; }
.lddr-editor-label { font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--text-primary); }
.lddr-editor-actions { display:flex; gap:6px; }

.lddr-field { display:flex; flex-direction:column; gap:4px; }
.lddr-field-row { display:flex; gap:10px; }
.lddr-field-label { font-size:10px; font-weight:600; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.5px; }
.lddr-input { background:var(--glass-bg); border:1px solid var(--glass-border); color:var(--text-primary); padding:6px 10px; border-radius:6px; font-size:12px; font-family:inherit; }
.lddr-input:focus { outline:none; border-color:var(--cyan); }
.lddr-textarea { background:var(--glass-bg); border:1px solid var(--glass-border); color:var(--text-primary); padding:8px 10px; border-radius:6px; font-size:12px; font-family:inherit; resize:vertical; line-height:1.5; }
.lddr-textarea:focus { outline:none; border-color:var(--cyan); }

.lddr-risk-select.lddr-risk-high { color:#ef4444; border-color:rgba(239,68,68,0.3); }
.lddr-risk-select.lddr-risk-medium { color:#f59e0b; border-color:rgba(245,158,11,0.3); }
.lddr-risk-select.lddr-risk-low { color:#22c55e; border-color:rgba(34,197,94,0.3); }

.lddr-btn-del { color:#ef4444 !important; border-color:rgba(239,68,68,0.2) !important; }
.lddr-btn-del:hover { background:rgba(239,68,68,0.1) !important; }

.lddr-issue-summary { font-size:11px; color:var(--text-dim); padding-top:8px; border-top:1px solid var(--glass-border); }
.lddr-linked-doc { font-family:var(--font-mono); font-size:10px; color:var(--text-dim); margin-left:8px; }

/* Cross-references */
.lddr-cross-refs { padding-top:8px; border-top:1px solid var(--glass-border); }
.lddr-cross-ref-item { display:flex; align-items:center; gap:8px; padding:4px 0; }
.lddr-cross-ref-link { font-size:11px; color:var(--cyan); cursor:pointer; text-decoration:underline; }
.lddr-cross-ref-type { font-size:10px; color:var(--text-dim); }

/* Document picker */
.lddr-doc-picker { display:flex; flex-direction:column; gap:4px; }
.lddr-doc-pick-item { padding:8px 12px; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:6px; cursor:pointer; font-size:12px; color:var(--text-primary); transition:border-color .15s; }
.lddr-doc-pick-item:hover { border-color:var(--cyan); }
.lddr-doc-pick-cancel { color:var(--text-dim); text-align:center; }

/* Reference panel */
.lddr-ref-content { padding:12px; height:100%; overflow:auto; }
.lddr-ref-text { font-family:var(--font-mono); font-size:11px; line-height:1.6; color:var(--text-muted); white-space:pre-wrap; word-break:break-word; }

/* AI progress */
.lddr-ai-progress { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; height:100%; text-align:center; font-size:12px; color:var(--text-muted); padding:20px; }
.lddr-spinner { width:32px; height:32px; border:3px solid var(--glass-border); border-top-color:var(--cyan); border-radius:50%; animation:spin 0.8s linear infinite; }

/* ── PDF.js Viewer ─────────────────────────────────────────────── */

/* Toolbar */
.pdf-toolbar {
  display:flex; align-items:center; gap:4px;
  padding:4px 8px;
  background:rgba(30,30,30,0.95);
  border-bottom:1px solid rgba(255,255,255,0.06);
  flex-shrink:0; flex-wrap:wrap;
}
.pdf-toolbar-group { display:flex; align-items:center; gap:3px; }
.pdf-toolbar-sep { width:1px; height:20px; background:rgba(255,255,255,0.1); margin:0 4px; flex-shrink:0; }
.pdf-toolbar-spacer { flex:1; }
.pdf-tool {
  display:flex; align-items:center; justify-content:center;
  min-width:28px; height:26px;
  border-radius:5px; border:none;
  background:rgba(255,255,255,0.06);
  color:rgba(255,255,255,0.6);
  font-family:var(--font-mono); font-size:11px;
  cursor:pointer; flex-shrink:0;
  padding:0 6px; gap:4px;
  transition:all 0.15s;
}
.pdf-tool:hover { background:rgba(255,255,255,0.14); color:rgba(255,255,255,0.9); }
.pdf-tool:active { background:rgba(255,255,255,0.2); }
.pdf-tool.active { background:rgba(79,142,247,0.25); color:#4f8ef7; }
.pdf-tool svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:2; }

/* Zoom level display */
.pdf-zoom-level {
  font-family:var(--font-mono);
  font-size:10px; color:rgba(255,255,255,0.5);
  min-width:36px; text-align:center;
  cursor:pointer; padding:2px 4px;
  border-radius:4px; transition:all 0.15s;
}
.pdf-zoom-level:hover { background:rgba(255,255,255,0.08); color:rgba(255,255,255,0.8); }

/* Page navigation */
.pdf-page-nav { display:flex; align-items:center; gap:4px; }
.pdf-page-input {
  width:40px; height:22px; padding:0 4px;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:4px;
  background:rgba(255,255,255,0.06);
  color:#fff; font-family:var(--font-mono);
  font-size:11px; text-align:center;
  outline:none; -moz-appearance:textfield;
}
.pdf-page-input::-webkit-inner-spin-button,
.pdf-page-input::-webkit-outer-spin-button { -webkit-appearance:none; margin:0; }
.pdf-page-input:focus { border-color:var(--gold, #d4a847); background:rgba(255,255,255,0.1); }
.pdf-page-total {
  font-family:var(--font-mono);
  font-size:11px; color:rgba(255,255,255,0.4);
  white-space:nowrap;
}

/* Search bar */
.pdf-search-bar {
  display:none; align-items:center; gap:6px;
  padding:4px 8px;
  background:rgba(30,30,30,0.95);
  border-bottom:1px solid rgba(255,255,255,0.06);
  flex-shrink:0;
}
.pdf-search-bar.show { display:flex; }
.pdf-search-input {
  flex:1; height:26px; padding:0 10px;
  border-radius:5px; border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  color:#fff; font-size:12px;
  outline:none;
}
.pdf-search-input::placeholder { color:rgba(255,255,255,0.3); }
.pdf-search-input:focus { border-color:var(--gold, #d4a847); }
.pdf-search-nav { display:flex; gap:2px; }
.pdf-search-count {
  font-family:var(--font-mono);
  font-size:10px; color:rgba(255,255,255,0.4);
  white-space:nowrap;
}
.pdf-search-close { margin-left:auto; }

/* Body: thumbs + pages side by side */
.pdf-body {
  flex:1; display:flex; min-height:0; position:relative;
}

/* Thumbnail sidebar */
.pdf-thumbs {
  width:0; overflow-y:auto; overflow-x:hidden;
  background:rgba(20,20,20,0.95);
  border-right:1px solid rgba(255,255,255,0.06);
  transition:width 0.2s ease;
  flex-shrink:0; display:flex;
  flex-direction:column; align-items:center;
  gap:8px; padding:0;
}
.pdf-thumbs.open {
  width:120px; padding:10px 8px;
}
.pdf-thumb {
  cursor:pointer; text-align:center;
  border-radius:4px; padding:4px;
  border:2px solid transparent;
  transition:border-color 0.15s;
  flex-shrink:0;
}
.pdf-thumb:hover { border-color:rgba(255,255,255,0.2); }
.pdf-thumb.active { border-color:var(--gold, #d4a847); }
.pdf-thumb canvas {
  width:100%; height:auto;
  border-radius:2px;
  box-shadow:0 1px 4px rgba(0,0,0,0.4);
}
.pdf-thumb span {
  display:block;
  font-family:var(--font-mono);
  font-size:9px; color:rgba(255,255,255,0.4);
  margin-top:3px;
}
.pdf-thumb.active span { color:var(--gold, #d4a847); }

/* Scrollbar styling */
.pdf-thumbs::-webkit-scrollbar,
.pdf-pages::-webkit-scrollbar { width:10px; height:10px; }
.pdf-thumbs::-webkit-scrollbar-track,
.pdf-pages::-webkit-scrollbar-track { background:rgba(0,0,0,0.3); }
.pdf-thumbs::-webkit-scrollbar-thumb,
.pdf-pages::-webkit-scrollbar-thumb {
  background:rgba(255,255,255,0.35);
  border-radius:5px;
  border:2px solid transparent;
  background-clip:padding-box;
}
.pdf-thumbs::-webkit-scrollbar-thumb:hover,
.pdf-pages::-webkit-scrollbar-thumb:hover { background:rgba(255,255,255,0.55); background-clip:padding-box; }

/* Main pages area */
.pdf-pages {
  flex:1; overflow:auto;
  padding:8px 0 20px;
  background:#525252;
  position:relative;
  scroll-behavior:auto;
}

/* Page wraps */
.pdf-page-wrap {
  position:relative;
  background:#fff;
  box-shadow:0 1px 8px rgba(0,0,0,0.3);
  margin:8px auto;
}
.pdf-page-wrap canvas { display:block; }

/* Dual page layout */
.pdf-dual-row {
  display:flex; justify-content:center;
  gap:8px; margin:8px auto;
}
.pdf-dual-row .pdf-page-wrap { margin:0; }

/* Text layer for selection */
.pdf-text-layer {
  position:absolute; inset:0;
  overflow:hidden; opacity:0.3; line-height:1;
}
.pdf-text-layer span {
  position:absolute; white-space:pre;
  color:transparent; cursor:text;
  user-select:text;
}
.pdf-text-layer ::selection { background:rgba(212,168,71,0.4); }

/* Floating page indicator */
.pdf-page-num {
  position:absolute;
  bottom:12px; left:50%;
  transform:translateX(-50%);
  padding:4px 14px; border-radius:12px;
  background:rgba(0,0,0,0.65);
  backdrop-filter:blur(8px);
  color:#fff;
  font-family:var(--font-mono);
  font-size:11px; letter-spacing:0.5px;
  pointer-events:none; z-index:10;
}

/* Loading overlay */
.pdf-loading-overlay {
  position:absolute; inset:0;
  background:#525252;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:20px; z-index:10;
  transition:opacity 0.4s;
}
.pdf-loading-overlay.done { opacity:0; pointer-events:none; }
.pdf-loading-logo {
  font-family:var(--font-display);
  font-size:28px; font-weight:700;
  color:var(--gold, #d4a847);
  letter-spacing:2px; text-transform:uppercase;
  opacity:0.9;
}
.pdf-loading-track {
  width:180px; height:3px;
  background:rgba(255,255,255,0.1);
  border-radius:2px; overflow:hidden;
}
.pdf-loading-fill {
  height:100%; width:0%;
  background:var(--gold, #d4a847);
  border-radius:2px;
  transition:width 0.2s ease;
}
.pdf-loading-text {
  font-family:var(--font-mono);
  font-size:11px; color:rgba(255,255,255,0.4);
  letter-spacing:0.5px;
}

/* Search highlights */
.pdf-search-highlight {
  position:absolute;
  background:rgba(212,168,71,0.35);
  border-radius:2px;
  pointer-events:none;
  mix-blend-mode:multiply;
}
.pdf-search-highlight.active {
  background:rgba(212,168,71,0.6);
  outline:2px solid #d4a847;
}

