/* ═══════════════════════════════════════════════════════════════
   BARDLOG – Unified Stylesheet
   Consolidated from inline <style> + external app.css – Phase 3.1
   ═══════════════════════════════════════════════════════════════ */

/* ── Root Variables & Reset ───────────────────────────────── */
:root{
  --bg:#0f1220; --panel:#171a2b; --panel-2:#1f2340; --text:#e6e8f3; --muted:#9aa1c6;
  --accent:#6ea8fe; --accent-2:#9b6eff; --danger:#ff6b6b; --ok:#29d398; --border:#2a2e55;
  --chip:#262a4d; --active-bg:#21264b; --hl:#2b6cfb33; --hl-border:#2b6cfb;
  /* Highlight colors (overridden by user preset via JS) */
  --block-hl-bg:#21264b; --block-hl-border:rgba(110,168,254,.18);
  --phrase-hl-bg:#21264b; --phrase-hl-border:rgba(110,168,254,.22);
  /* Semantic colors (referenced by JS instead of hardcoded hex) */
  --color-recording:#ef4444; --color-dm:#ef4444; --color-player:#fbbf24;
  --color-success:#6ee7b7; --color-success-bg:#203a33;
  --color-error:#e55; --color-error-light:#f87171;
  --color-info:#93c5fd; --color-warning:#ffa726; --color-summary:#b388ff;
  --color-queued-bg:#262a4d;
  /* Duration for Prev/Next jump highlight flash */
  --jump-flash-ms: 900ms;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font:14px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji";overflow:hidden;overflow-x:hidden}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Skip-to-content Link ─────────────────────────────────── */
.skip-link{position:absolute;top:-100%;left:16px;z-index:99999;padding:8px 16px;background:var(--accent);color:#fff;border-radius:0 0 8px 8px;font-weight:600;font-size:14px;text-decoration:none;transition:top .15s ease}
.skip-link:focus{top:0}

/* ── App Modal (replaces browser alert/confirm/prompt) ────── */
.app-modal{position:fixed;inset:0;z-index:11000;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .15s ease}
.app-modal.hidden{display:none}
.app-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.app-modal-box{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px 24px;min-width:320px;max-width:520px;width:90%;box-shadow:0 12px 48px rgba(0,0,0,.5);animation:modalSlide .18s ease}
@keyframes modalSlide{from{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.app-modal-title{font-size:15px;font-weight:700;margin-bottom:12px;color:var(--text)}
.app-modal-body{font-size:13px;color:var(--muted);line-height:1.55;white-space:pre-wrap;word-break:break-word;max-height:50vh;overflow-y:auto}
.modal-info-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:13px}
.modal-info-grid .label{color:var(--muted);font-weight:600}
.modal-info-grid .value{color:var(--text)}
.app-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}
.app-modal-actions .btn{padding:6px 18px;border-radius:6px;font-size:13px;cursor:pointer;border:none;font-weight:600;transition:background .12s}
.app-modal-actions .btn.dismiss,.app-modal-actions .btn.cancel{background:var(--chip);color:var(--muted)}
.app-modal-actions .btn.dismiss:hover,.app-modal-actions .btn.cancel:hover{background:var(--panel-2);color:var(--text)}
.app-modal-actions .btn.ok{background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#fff;box-shadow:0 2px 10px rgba(110,168,254,.2)}
.app-modal-actions .btn.ok:hover{filter:brightness(1.1);box-shadow:0 4px 16px rgba(110,168,254,.3),0 0 20px rgba(155,110,255,.15)}
.app-modal-actions .btn.danger{background:var(--danger);color:#fff}
.app-modal-actions .btn.danger:hover{background:#ff8a8a}
.app-modal-body .modal-select-list{list-style:none;padding:0;margin:8px 0 0}
.app-modal-body .modal-select-list li{padding:8px 12px;border-radius:6px;cursor:pointer;transition:background .12s;color:var(--text);display:flex;align-items:center;gap:8px}
.app-modal-body .modal-select-list li:hover{background:var(--active-bg)}
.app-modal-body .modal-select-list li .idx{color:var(--muted);font-size:12px;min-width:18px}

/* ── Receipt Modal ────────────────────────────────────────── */
.receipt-modal{white-space:normal}
.receipt-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:14px 18px}
.receipt-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0}
.receipt-row .receipt-label{color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.receipt-row .receipt-value{color:var(--text);font-size:14px;text-align:right}
.receipt-row.receipt-total{border-top:1px solid var(--border);margin-top:4px;padding-top:8px}
.receipt-row.receipt-total .receipt-label,.receipt-row.receipt-total .receipt-value{font-size:15px;font-weight:700}

/* ── Welcome Modal ────────────────────────────────────────── */
.welcome-modal{text-align:center;white-space:normal}
.welcome-hero{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0 16px;border-bottom:1px solid var(--border);margin-bottom:18px}
.welcome-lyre{width:56px;height:56px;filter:drop-shadow(0 0 12px rgba(110,168,254,.35))}
.welcome-subtitle{font-size:14px;color:var(--accent);margin:0;font-weight:500}
.welcome-steps{display:flex;flex-direction:column;gap:10px;text-align:left}
.welcome-step{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;border-radius:10px;background:var(--panel-2);border:1px solid var(--border);transition:border-color .15s,background .15s}
.welcome-step:hover{border-color:var(--accent);background:var(--active-bg)}
.welcome-step-num{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#6ea8fe,#9b6eff);color:#0f1220;font-weight:700;font-size:13px;margin-top:1px}
.welcome-step strong{color:var(--text);font-size:13.5px}
.welcome-step .muted-text{color:var(--muted);font-size:12.5px;line-height:1.45}

/* ── Session Loading Overlay ──────────────────────────────── */
.session-loader{position:absolute;inset:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--bg);transition:opacity .2s ease}
.session-loader.hidden{display:none}
.session-loader .loader-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.session-loader .loader-text{font-size:13px;color:var(--muted);font-weight:500}

/* ── Layout (Grid + Sidebar) ──────────────────────────────── */
.layout{display:grid;grid-template-columns:280px 1fr;grid-template-rows:auto 1fr;grid-template-areas:"header header" "sidebar main";height:100%;transition:grid-template-columns .18s ease}
.layout .sidebar{transition:opacity .18s ease, visibility .18s ease}
.layout #diarizerBanner{grid-column:1 / -1; width:100%; box-sizing:border-box}
@media (min-width:901px){
  .layout.sidebar-collapsed{grid-template-columns:0 1fr}
  .layout.sidebar-collapsed .sidebar{border-right:none;overflow:hidden;opacity:0;visibility:hidden;pointer-events:none;max-width:0;padding-left:0;padding-right:0}
}
header{grid-area:header;padding:8px 12px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--panel),var(--panel-2));display:flex;flex-direction:column;position:relative;z-index:1005}
.header-logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none !important;line-height:0;position:relative;overflow:visible}
.header-logo img{display:block;height:30px;width:auto;filter:drop-shadow(0 0 8px rgba(110,168,254,.3))}
.env-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-35deg);font-size:14px;font-weight:900;letter-spacing:3px;opacity:.9;pointer-events:none;white-space:nowrap;z-index:10;user-select:none;text-transform:uppercase}
.env-dev{color:#ffaa33;text-shadow:0 0 6px rgba(255,170,51,.7),0 0 12px rgba(255,170,51,.35)}
.env-sandbox{color:#ff3333;text-shadow:0 0 6px rgba(255,0,0,.7),0 0 12px rgba(255,0,0,.35)}
.sidebar{grid-area:sidebar;border-right:1px solid var(--border);background:var(--panel);padding:0;overflow:hidden;display:flex;flex-direction:column;position:relative;z-index:4}
.sidebar .userbar{display:flex;align-items:center;gap:8px;padding:10px 10px 0 10px;position:sticky;top:0;background:linear-gradient(180deg,var(--panel),rgba(0,0,0,0));z-index:6}
.sidebar .userbar .spacer{flex:1}
#partyListView{display:flex;flex-direction:column;flex:1;min-height:0;padding:12px 0 0}
#partyListView #parties{flex:1;overflow-y:auto;min-height:0;padding:2px 12px 4px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
#partySessionsView{padding:12px 0 0;display:flex;flex-direction:column;flex:1;min-height:0}
#partySessionsView #sessions{flex:1;overflow-y:auto;min-height:0;padding:2px 12px 4px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
/* ── Themed scrollbar (desktop) ───────────────────────────── */
@media(hover:hover){
  #partySessionsView #sessions,#partyListView #parties,
  .split-layout > .scroll,.summary-scroll,#chatHistory,.landing-morph .morph-card{scrollbar-width:thin;scrollbar-color:var(--border) transparent}
  #partySessionsView #sessions::-webkit-scrollbar,#partyListView #parties::-webkit-scrollbar,
  .split-layout > .scroll::-webkit-scrollbar,.summary-scroll::-webkit-scrollbar,#chatHistory::-webkit-scrollbar,.landing-morph .morph-card::-webkit-scrollbar{width:6px}
  #partySessionsView #sessions::-webkit-scrollbar-track,#partyListView #parties::-webkit-scrollbar-track,
  .split-layout > .scroll::-webkit-scrollbar-track,.summary-scroll::-webkit-scrollbar-track,#chatHistory::-webkit-scrollbar-track,.landing-morph .morph-card::-webkit-scrollbar-track{background:transparent}
  #partySessionsView #sessions::-webkit-scrollbar-thumb,#partyListView #parties::-webkit-scrollbar-thumb,
  .split-layout > .scroll::-webkit-scrollbar-thumb,.summary-scroll::-webkit-scrollbar-thumb,#chatHistory::-webkit-scrollbar-thumb,.landing-morph .morph-card::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
  #partySessionsView #sessions::-webkit-scrollbar-thumb:hover,#partyListView #parties::-webkit-scrollbar-thumb:hover,
  .split-layout > .scroll::-webkit-scrollbar-thumb:hover,.summary-scroll::-webkit-scrollbar-thumb:hover,#chatHistory::-webkit-scrollbar-thumb:hover,.landing-morph .morph-card::-webkit-scrollbar-thumb:hover{background:var(--muted)}
}
.sidebarFooter{flex-shrink:0;background:var(--panel);padding:12px 12px 14px;border-top:1px solid var(--border)}
main{grid-area:main;overflow:hidden;display:grid;grid-template-rows:auto auto auto 1fr;background:radial-gradient(1200px 600px at 80% -200px,rgba(110,168,254,.12),transparent 60%),var(--bg);position:relative;z-index:1}
main > .split-layout{grid-row:4;min-height:0}
main > .scroll{min-height:0}

/* ── Toolbar ──────────────────────────────────────────────── */
.toolbar{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;width:100%;min-height:38px}
.toolbar .group{display:flex;align-items:center;gap:6px;flex-shrink:0}
.toolbar .group.transport .btn.round{width:34px;height:34px;display:inline-grid;place-items:center;padding:0;font-size:16px}
.toolbar .group.meta .btn.ghost{padding:6px 8px}
.toolbar .group.account{flex-shrink:0;margin-left:auto}
.toolbar-spacer{flex:1;min-width:0}
.toolbar .sep{width:1px;height:24px;background:var(--border);margin:0 2px;flex-shrink:0}
.toolbar .btn,.toolbar .select,.toolbar .dd-button{height:34px;display:inline-flex;align-items:center;box-sizing:border-box;font-size:13px}
.toolbar .btn.icon{width:34px;height:34px;font-size:18px;display:inline-grid;place-items:center;padding:0}
.toolbar .pill{font-size:11px;padding:4px 8px}
.toolbar label{font-size:13px;white-space:nowrap}
.toolbar input[type="range"]{height:20px}
.toolbar input[type="checkbox"]{margin:0;accent-color:var(--accent-2)}
/* ── Filter group (Speakers + Rate): match pill aesthetic ── */
.toolbar .group.filter .dd-button{background:var(--chip);border-radius:999px;padding:3px 4px 3px 10px;font-size:12px;height:auto;color:var(--muted);gap:5px}
.toolbar .group.filter .dd-button .pill{padding:2px 7px;font-size:10px;border:none;background:rgba(110,168,254,.12);color:var(--accent)}

/* ── Desktop feature pills ─────────────────────────────────── */
.dfb-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:14px;border:1px solid var(--border);background:var(--panel-2);color:var(--muted);font-size:12px;white-space:nowrap;cursor:pointer;transition:all .15s;box-sizing:border-box;height:30px;line-height:1}
.dfb-pill:hover{border-color:rgba(110,168,254,.5);color:var(--text)}
.dfb-pill.disabled{opacity:.35;pointer-events:none;cursor:default}
.dfb-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.dfb-pill.dfb-clip.active,.dfb-pill.dfb-clip.clip-active{background:rgba(41,211,152,.15);color:var(--ok);border-color:var(--ok)}
.dfb-pill svg{flex-shrink:0}
.dfb-sep{width:1px;align-self:stretch;margin:2px 2px;background:var(--border);flex-shrink:0}
.toolbar .group.features{gap:4px}

/* ── Controls & Widgets ───────────────────────────────────── */
.controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.controls .btn,.controls .select,.controls .dd-button{height:34px;display:inline-flex;align-items:center;box-sizing:border-box}
.btn{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:8px 12px;border-radius:10px;cursor:pointer;transition:transform .05s ease,background .15s ease,border-color .15s ease,box-shadow .18s ease;user-select:none}
.btn:hover{transform:translateY(-1px);border-color:rgba(110,168,254,.5);box-shadow:0 0 12px rgba(110,168,254,.15)}
.btn:active{transform:translateY(0);box-shadow:none}
.btn.active{border-color:var(--accent-2);background:rgba(155,110,255,.12);color:var(--accent)}
.btn.round{border-radius:999px}
.btn.round:hover{border-color:rgba(155,110,255,.5);background:linear-gradient(135deg,rgba(155,110,255,.12),rgba(110,168,254,.12))}
.btn.primary{background:linear-gradient(135deg,var(--accent-2),var(--accent));border-color:rgba(155,110,255,.4);color:#fff;box-shadow:0 2px 10px rgba(110,168,254,.2),0 0 20px rgba(155,110,255,.1)}
.btn.primary:hover{border-color:rgba(155,110,255,.6);box-shadow:0 4px 16px rgba(110,168,254,.3),0 0 24px rgba(155,110,255,.2);filter:brightness(1.1)}
.btn.danger{background:linear-gradient(180deg,#b73a3a,#8b2c2c);border-color:#b73a3a;color:#fff}
.btn.dismiss{background:var(--chip);border-color:var(--border);color:var(--muted);font-weight:600}
.btn.dismiss:hover{background:var(--panel-2);border-color:rgba(110,168,254,.3);color:var(--text)}
.btn.ghost{background:transparent}
.btn.icon{width:36px;height:36px;display:inline-grid;place-items:center;padding:0;font-size:20px;line-height:1}
.btn.icon:hover{border-color:rgba(155,110,255,.5);background:rgba(155,110,255,.08)}
.btn.icon.sm{width:30px;height:30px;font-size:16px}
.btn svg,.kebabBtn svg{display:block}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;filter:none}
input[type="checkbox"]{accent-color:var(--accent-2)}
input[type="range"]{accent-color:var(--accent-2)}
.select,.input{background:var(--panel-2);color:var(--text);border:1px solid var(--border);padding:8px 10px;border-radius:10px}
/* Prevent iOS auto-zoom on input focus (triggers when font-size < 16px) */
@media screen and (max-width:900px){input:not([type=checkbox]):not([type=radio]):not([type=range]),textarea,select,.input,.select{font-size:16px !important}}
.pill{background:var(--chip);border:1px solid var(--border);border-radius:999px;padding:6px 10px;color:var(--muted);font-size:12px}
.pill.warning{background:rgba(234,179,8,.1);border-color:rgba(234,179,8,.3);color:#eab308}
/* Progress view pills: force white text for readability over status backgrounds */
#progressView .pill{color:#fff !important}
.sep{width:1px;height:28px;background:var(--border);margin:0 8px}
.row{display:flex;align-items:center;gap:8px}
.badge{padding:2px 8px;border-radius:999px;font-size:11px;background:#27305a;color:#bcd0ff;border:1px solid var(--border);margin-right:8px}
.badge.ok{background:#203a33;color:#92f0cf}
.badge.proc{background:#20243b;color:#bcd0ff}
.badge.err{background:#3b2224;color:#ffb0b0;border-color:#7a3a3a}
.badge.dm{background:#3a1520;color:#ef4444}
.badge.player{background:#203a60;color:#b0d0ff}
.badge.guest{background:#3a3020;color:#ffd0a0}
.label{display:block;font-size:12px;color:var(--muted);font-weight:600}

/* ── Session List & Kebab Menu ────────────────────────────── */
.session{padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--panel-2);margin-bottom:8px;cursor:pointer;position:relative;z-index:0;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .12s ease}
.session:hover{border-color:rgba(110,168,254,.4);background:linear-gradient(135deg,rgba(110,168,254,.06),rgba(155,110,255,.04));transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.session.active{border-color:var(--accent);background:linear-gradient(135deg,rgba(110,168,254,.1),rgba(155,110,255,.06));box-shadow:0 0 0 1px var(--accent),0 2px 12px rgba(110,168,254,.15)}
.session.active::before{content:'';position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,var(--accent-2),var(--accent))}
.session.open{z-index:20}
.session .session-title{font-weight:600;font-size:13.5px;line-height:1.35;padding-right:36px}
.session .session-date{font-size:12px;color:var(--muted);margin-top:6px;display:flex;align-items:center;gap:6px}
.session .session-date svg{opacity:.5;flex-shrink:0}
.session.status-processing{border-left:3px solid var(--accent)}
.session.status-processing .session-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--accent);font-weight:500}
.session.status-recording{border-left:3px solid #ef4444}
.session.status-recording .session-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#ef4444;font-weight:500}
@keyframes recording-pulse{0%,100%{opacity:1}50%{opacity:.4}}
.session.status-recording .rec-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#ef4444;animation:recording-pulse 1.5s ease-in-out infinite}
.session.status-error{border-left:3px solid var(--danger)}
.session.status-error .session-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--danger);font-weight:500}
.session.status-done .session-status{display:none}
.session.status-done{border-color:rgba(41,211,152,0.5)}
.session.status-done:hover{border-color:var(--ok)}
.session-progress-bar{height:3px;background:var(--border);border-radius:1.5px;margin-top:6px;overflow:hidden}
.session-progress-fill{height:100%;background:var(--accent);border-radius:1.5px;transition:width .3s ease}
.session-progress-fill.completed{background:var(--ok)}
.no-sessions{padding:20px 16px;text-align:center;color:var(--muted);font-size:13px}
/* Onboarding guide for empty parties */
.onboarding-guide{padding:24px 20px;text-align:center;color:var(--fg)}
.onboarding-guide .onboarding-icon{font-size:36px;margin-bottom:8px}
.onboarding-guide h3{margin:0 0 6px;font-size:16px;font-weight:600;color:var(--fg)}
.onboarding-guide>p{margin:0 0 16px;font-size:13px;color:var(--muted);line-height:1.5}
.onboarding-steps{list-style:none;padding:0;margin:0 0 12px;text-align:left}
.onboarding-step{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:8px;transition:background .15s}
.onboarding-step:hover{background:rgba(255,255,255,.04)}
.onboarding-step .step-num{width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--bg);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.onboarding-step .onboard-link{color:var(--accent);font-size:13px;font-weight:500;text-decoration:none;cursor:pointer}
.onboarding-step .onboard-link:hover{text-decoration:underline}
.onboarding-step .step-desc{display:block;font-size:12px;color:var(--muted);margin-top:2px;line-height:1.4}
.onboarding-guide .cmd{background:rgba(155,110,255,.15);padding:1px 5px;border-radius:4px;font-size:.85em;color:#b8a0ff;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;white-space:nowrap}
.onboarding-tips,.onboarding-player-tips{margin:12px 0 8px;padding:10px 14px;background:rgba(255,255,255,.03);border-radius:8px;border:1px solid var(--border);text-align:left}
.onboarding-tip{margin:0;padding:3px 0;font-size:12px;color:var(--muted);line-height:1.5}
.onboarding-tip+.onboarding-tip{margin-top:4px}
.onboarding-tip strong{color:var(--fg);font-weight:500}
.onboarding-hint{font-size:12px;color:var(--muted);margin:0;opacity:.7}
.onboarding-beta{font-size:12px;color:var(--muted);margin:8px 0 0;opacity:.8}
.onboarding-beta .onboard-link{font-size:12px}
.kebab{position:absolute;top:10px;right:10px}
.kebabBtn{all:unset;cursor:pointer;padding:4px 6px;border-radius:8px;line-height:0;border:1px solid var(--border);background:var(--panel);display:grid;place-items:center}
.kebabBtn:hover{border-color:var(--accent)}
.kebabBtn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.menu{position:absolute;top:32px;right:8px;background:var(--panel);border:1px solid var(--border);border-radius:10px;min-width:200px;box-shadow:0 12px 50px rgba(0,0,0,.5);z-index:10000}
.menu.hidden{display:none}
.menu .item{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border)}
.menu .item:last-child{border-bottom:none}
.menu .item:hover{background:rgba(255,255,255,.04)}
.menu .item.danger{color:var(--danger)}

/* ── Party Cards ──────────────────────────────────────────── */
.party-card{padding:14px 14px 12px;border:1px solid var(--border);border-radius:12px;background:var(--panel-2);margin-bottom:8px;cursor:pointer;position:relative;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .12s ease}
.party-card:hover{border-color:rgba(110,168,254,.4);background:linear-gradient(135deg,rgba(110,168,254,.06),rgba(155,110,255,.04));transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.party-card.selected{border-color:var(--accent);background:linear-gradient(135deg,rgba(110,168,254,.1),rgba(155,110,255,.06));box-shadow:0 0 0 1px var(--accent),0 2px 12px rgba(110,168,254,.15)}
.party-card.selected::before{content:'';position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,var(--accent-2),var(--accent))}
.party-card .party-name{font-weight:600;font-size:13.5px;margin-bottom:6px;padding-right:36px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.party-card .party-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}
.party-card .party-card-kebab{position:absolute;top:10px;right:10px}

/* ── Onboarding & Hints ───────────────────────────────────── */
#onboardingHint{padding:0 12px}
.onboarding-card{padding:20px 16px;border:1px dashed var(--accent);border-radius:12px;background:var(--panel-2);text-align:center;margin-bottom:12px}
.onboarding-card .onboarding-icon{font-size:2rem;margin-bottom:8px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 0 10px rgba(110,168,254,.35))}
.onboarding-card h3,.onboarding-card h4{margin:0 0 6px;font-size:1rem;color:var(--text)}
.onboarding-card p{margin:0;font-size:0.85rem;color:var(--muted);line-height:1.5}
.main-content-hint{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--muted);gap:8px;min-height:200px;overflow:visible}
.main-content-hint .hint-icon{font-size:2.5rem;opacity:1;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 0 12px rgba(110,168,254,.35));padding:16px}
.main-content-hint .hint-icon svg{width:48px;height:48px}
.main-content-hint p{margin:0;font-size:0.95rem;max-width:360px;line-height:1.6}
.main-content-hint kbd{display:inline-block;padding:1px 6px;font-size:0.8em;font-family:inherit;background:rgba(255,255,255,.08);border:1px solid var(--border);border-radius:4px;box-shadow:0 1px 0 rgba(0,0,0,.25);color:var(--text);vertical-align:baseline}
.main-content-hint .hint-dismiss{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.1rem;padding:4px 8px;line-height:1;border-radius:4px;opacity:.5;transition:opacity .15s}
.main-content-hint .hint-dismiss:hover{opacity:1;color:var(--text)}
.main-content-hint{position:relative}

/* ── Feature Explainer (empty states) ─────────────────────── */
.feature-explainer{display:flex;flex-direction:column;align-items:center;padding:32px 20px;gap:4px;text-align:center}
.feature-explainer-header{display:flex;flex-direction:column;align-items:center;gap:8px}
.feature-explainer-header h3{margin:0;font-size:1.1rem;color:var(--text);font-weight:600}
.feature-explainer-header svg{opacity:.4}
.feature-explainer-subtitle{margin:0 0 12px;font-size:.9rem;color:var(--muted)}
.feature-explainer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-width:520px;width:100%;text-align:left}
.feature-explainer-card{display:flex;flex-direction:column;gap:3px;padding:12px 14px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;transition:border-color .15s}
.feature-explainer-card:hover{border-color:var(--accent)}
.feature-explainer-card .feature-explainer-icon{font-size:1.2rem;line-height:1}
.feature-explainer-card strong{font-size:.85rem;color:var(--text)}
.feature-explainer-card span:last-child{font-size:.78rem;color:var(--muted);line-height:1.45}
@media(max-width:600px){.feature-explainer-grid{grid-template-columns:1fr}}

/* ── Party Member Cards ───────────────────────────────────── */
.member-section-header{display:flex;align-items:center;gap:10px;margin:12px 0 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.member-section-header:first-child{margin-top:0}
.member-section-header::after{content:'';flex:1;height:1px;background:var(--border)}
.member-card{padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--panel);margin-bottom:8px;position:relative;transition:border-color .15s}
.member-card.managed{border-left:3px solid var(--accent-2)}
.member-card.managed .avatar{background:linear-gradient(135deg,rgba(155,110,255,.25),rgba(110,168,254,.2));color:var(--accent)}
.member-card.is-dm{border-left:3px solid #ef4444}
.member-card.is-dm .avatar{background:linear-gradient(135deg,rgba(239,68,68,.25),rgba(255,80,80,.2));color:#ef4444}
.member-card.unmanaged{border-left:3px solid var(--border);opacity:.85}
.member-card.unmanaged .avatar{background:var(--chip);color:var(--muted)}
.merge-unmanaged-section{padding:4px 0 8px 52px}
.merge-unmanaged-section .btn-merge-unmanaged{font-size:12px;opacity:.7;transition:opacity .15s}
.merge-unmanaged-section .btn-merge-unmanaged:hover{opacity:1}
.merge-select-wrapper{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.merge-select-wrapper .merge-unmanaged-select{flex:1;min-width:140px;font-size:13px}
.member-card .member-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.member-card .avatar{width:40px;height:40px;border-radius:50%;background:var(--chip);display:grid;place-items:center;font-size:18px;flex-shrink:0;overflow:hidden;position:relative}
.member-card .avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.member-card .avatar-wrapper{position:relative;cursor:pointer}
.member-card .avatar-wrapper .avatar-overlay{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.55);display:none;place-items:center;font-size:14px;color:#fff}
.member-card .avatar-wrapper:hover .avatar-overlay{display:grid}
.member-card .member-name{font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.member-card .member-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.member-card .member-fields label{font-size:11px;color:var(--muted);display:block;margin-bottom:2px}
.member-card .member-fields input{width:100%;box-sizing:border-box}
.member-card .member-fields .full-width{grid-column:1/-1}
.member-card .member-actions{display:flex;gap:6px;margin-top:8px;justify-content:flex-end}
.member-card .btn-save-member{font-size:12px;padding:4px 10px}
.member-card .btn-remove{all:unset;cursor:pointer;font-size:20px;line-height:1;color:var(--muted);padding:2px 6px;border-radius:6px;transition:color .15s,background .15s}
.member-card .btn-remove:hover{color:var(--danger);background:rgba(255,107,107,.12)}
.discord-linked-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;background:rgba(88,101,242,.12);border:1px solid rgba(88,101,242,.25);font-size:13px;color:#7289da;cursor:default}
.discord-linked-icon{color:#57f287;font-weight:700;font-size:14px}
.discord-linked-name{font-weight:500}
.form-hint-sm{font-size:11px;color:var(--muted);margin-top:3px}
.form-hint-sm code{background:var(--chip);padding:1px 4px;border-radius:3px;font-size:10px}

/* ── DDB Character Links ──────────────────────────────────── */
.ddb-section{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.ddb-section .ddb-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.ddb-section .ddb-header span{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.ddb-char{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;background:var(--panel-2);transition:border-color .15s}
.ddb-char:hover{border-color:rgba(110,168,254,.3)}
.ddb-char .ddb-avatar{width:32px;height:32px;border-radius:50%;background:var(--chip);flex-shrink:0;overflow:hidden}
.ddb-char .ddb-avatar img{width:100%;height:100%;object-fit:cover}
.ddb-char .ddb-info{flex:1;min-width:0;display:flex;flex-direction:column}
.ddb-char .ddb-name{font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--accent);text-decoration:none}
.ddb-char .ddb-name:hover{text-decoration:underline}
.ddb-char .ddb-meta{font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ddb-char .ddb-actions{display:flex;gap:4px;flex-shrink:0}
.ddb-char .ddb-actions button{all:unset;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;color:var(--muted);transition:color .15s}
.ddb-char .ddb-actions button:hover{color:var(--accent)}
.ddb-char .ddb-actions button.danger:hover{color:var(--danger)}
.ddb-char.is-primary{border-color:rgba(141,101,56,.35);background:rgba(141,101,56,.06)}
.ddb-primary-toggle{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;color:#c9943e;cursor:pointer;user-select:none;margin-left:6px;vertical-align:middle}
.ddb-primary-cb{accent-color:#c9943e;width:13px;height:13px;cursor:pointer;margin:0}
.ddb-primary-cb:disabled{cursor:default;opacity:.55}
.ddb-link-label{display:inline-block;font-size:9px;color:var(--muted);background:var(--chip);border-radius:3px;padding:0 4px;margin-left:4px;vertical-align:middle}
.ddb-link-form{margin-top:6px}
.ddb-link-form input{flex:1;font-size:12px;padding:5px 8px}
.ddb-link-form button{font-size:12px;padding:5px 10px;white-space:nowrap}
.ddb-preview{padding:8px;border:1px dashed var(--border);border-radius:8px;margin-top:6px;font-size:12px}
.ddb-preview .ddb-char{margin:0}
.ddb-badge{display:inline-block;font-size:10px;padding:1px 6px;border-radius:4px;background:rgba(110,168,254,.15);color:var(--accent);margin-left:4px}
.ddb-overrides{padding:6px 8px 2px;margin-top:6px;border-top:1px solid var(--border)}
.ddb-override-label{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);cursor:pointer;padding:2px 0;user-select:none}
.ddb-override-label:hover{color:var(--accent)}
.ddb-override-cb{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}

/* ── Invite Cards ─────────────────────────────────────────── */
.invite-card{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel);margin-bottom:8px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}
.invite-card .invite-code{font-family:monospace;font-size:13px;color:var(--text)}
.invite-card .invite-meta{font-size:12px;color:var(--muted)}
.invite-card .invite-actions{display:flex;gap:6px}

/* ── Party Tabs ───────────────────────────────────────────── */
.party-tab.hidden{display:none}

/* ── Session Details Modal ────────────────────────────────── */
.sd-tab-content.hidden{display:none}
.sd-loading{color:var(--muted);font-size:13px;text-align:center;padding:24px 0}
.sd-section{margin-bottom:14px}
.sd-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border)}
.sd-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;font-size:13px}
.sd-grid .sd-label{color:var(--muted);font-weight:600;white-space:nowrap}
.sd-grid .sd-value{color:var(--text);word-break:break-word}
.sd-status{display:inline-flex;align-items:center;gap:5px;font-size:13px}
.sd-status .sd-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.sd-status .sd-dot.done{background:#22c55e}
.sd-status .sd-dot.processing{background:#3b82f6}
.sd-status .sd-dot.recording{background:#ef4444;animation:pulse-rec 1.2s infinite}
.sd-status .sd-dot.error{background:#ef4444}
.sd-status .sd-dot.queued{background:#eab308}
.sd-speakers{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.sd-speakers .sd-speaker{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;background:var(--panel);border:1px solid var(--border);font-size:12px;color:var(--text)}
.sd-dl-section{border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px}
.sd-dl-section h4{margin:0 0 8px;font-size:13px;color:var(--fg)}
.sd-dl-row{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px}
.sd-dl-row .sd-dl-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.sd-dl-row .sd-dl-size{color:var(--muted);font-size:12px;white-space:nowrap}
.sd-dl-row .btn{flex-shrink:0}
.sd-share-card{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:12px;background:rgba(255,255,255,.01);margin-bottom:6px}
.sd-share-card.expired{opacity:.55}
.sd-share-url{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--accent);cursor:pointer}
.sd-share-url.expired{color:var(--muted);text-decoration:line-through}
.sd-share-meta{display:flex;align-items:center;gap:8px;color:var(--muted)}
.sd-empty{color:var(--muted);font-size:13px;text-align:center;padding:16px 0}
.sd-field{margin-bottom:14px}
.sd-field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px}
.sd-field .input{width:100%;box-sizing:border-box}
.sd-lang-hint{display:block;margin-top:4px;font-size:11px;color:var(--muted)}
.sd-danger-zone{border:1px solid #ef4444;border-radius:10px;padding:14px;margin-top:16px}
.sd-danger-zone h4{margin:0 0 8px;font-size:13px;color:#ef4444}

/* ── Tabs ─────────────────────────────────────────────────── */
.tabs{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;min-height:42px;height:42px}
.tabs button.btn.tab{background:var(--panel-2);padding:6px 10px !important;line-height:1;display:inline-flex;align-items:center;height:28px}
.tabs .btn.tab.active{border-color:var(--accent)}

/* ── Player & Seek Bar ────────────────────────────────────── */
.player{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--border);background:var(--panel)}
.time{font-variant-numeric:tabular-nums;color:var(--muted);min-width:50px;text-align:center;font-size:13px}
.bar{height:8px;border-radius:999px;background:#1b1e36;position:relative;cursor:pointer;border:1px solid var(--border);flex:1;overflow:visible}
.prog{position:absolute;left:0;top:0;bottom:0;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:999px;z-index:2}
.vad-span{position:absolute;top:0;bottom:0;background:#22c55e;opacity:.35;border-radius:1px;z-index:1;pointer-events:none}
.bar:hover .vad-span{opacity:.55}
.marker{position:absolute;top:-4px;width:2px;height:16px;background:rgba(255,255,255,.5)}
.seek-tooltip{position:absolute;top:calc(100% + 22px);transform:translateX(-50%);background:var(--panel-2);color:var(--text);font-size:11px;font-variant-numeric:tabular-nums;padding:3px 8px;border-radius:6px;border:1px solid var(--border);box-shadow:0 4px 12px rgba(0,0,0,.5);pointer-events:none;opacity:0;transition:opacity .12s;white-space:nowrap;z-index:10000}
.seek-tooltip::after{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:4px solid transparent;border-bottom-color:var(--border)}
.bar:hover .seek-tooltip{opacity:1}
.seek-hover-line{position:absolute;top:-2px;width:1px;height:12px;background:rgba(255,255,255,.6);pointer-events:none;opacity:0;transition:opacity .12s;z-index:15}
.bar:hover .seek-hover-line{opacity:1}

/* ── Progress Views ───────────────────────────────────────── */
/* Dual-phase progress bar */
#pOverallBar.dualbar{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;align-items:end}
#pOverallBar .phase{display:grid;grid-template-rows:auto;gap:6px}
#pOverallBar .bar{height:14px;position:relative}
#pOverallBar .phaseText{position:absolute;left:8px;right:8px;top:50%;transform:translateY(-50%);font-size:11px;color:#fff;text-shadow:0 1px 0 rgba(0,0,0,.6);pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Per-file progress list */
#pFiles{display:grid;gap:10px;margin-top:8px}
#pFiles .fileRow{border:1px solid var(--border);border-radius:10px;padding:8px 10px;background:linear-gradient(180deg,var(--panel-2),rgba(23,26,43,.88))}
#pFiles .fileRow .bar{height:8px;margin-top:4px}
#pFiles .fileRow .vadWrap{margin-top:6px}
.vadBar{position:relative;height:6px;background:#1b1e36;border:1px solid var(--border);border-radius:6px;overflow:hidden}
.vadBar.empty{opacity:.6}
.vadBar .vadSpan{position:absolute;top:0;bottom:0;background:linear-gradient(90deg,#2fbf71,#1d8f5a);opacity:.9}
/* Phase progress cards */
.phase-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:12px 0 16px}
.phase-card{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel)}
.phase-card.active{border-color:var(--accent);box-shadow:0 0 0 1px rgba(110,168,254,.15)}
.phase-card.done{border-color:var(--ok)}
.phase-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.phase-label{font-size:12px;font-weight:600;color:var(--muted)}
.phase-card.active .phase-label{color:var(--accent)}
.phase-card.done .phase-label{color:var(--ok)}
.phase-pct{font-size:12px;font-variant-numeric:tabular-nums;color:var(--muted);margin-left:auto}
.phase-card.active .phase-pct{color:var(--text)}
.phase-card.done .phase-pct{color:var(--ok)}
.phase-bar{height:4px;border-radius:999px;background:#1b1e36;position:relative}
.phase-fill{position:absolute;left:0;top:0;bottom:0;width:0%;border-radius:999px;transition:width .3s ease}
.phase-fill.vad{background:linear-gradient(90deg,#9b6eff,#c084fc)}
.phase-fill.transcription{background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.phase-fill.encoding{background:linear-gradient(90deg,#29d398,#6ee7b7)}
.phase-fill.mixing{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
/* Progress view (file pills) */
.filePill{background:var(--chip);border:1px solid var(--border);border-radius:999px;padding:6px 10px;color:var(--muted);font-size:12px;display:inline-flex;align-items:center;gap:6px}

/* ── Transcript & Segments ────────────────────────────────── */
.scroll{overflow:auto;padding:14px 16px;position:relative;z-index:1}
#tsScroll{padding:0 16px 14px}
.transcript{max-width:1200px;margin:0 auto;display:grid;gap:2px}
.seg{padding:8px 10px;border-radius:10px;display:grid;grid-template-columns:86px 1fr;gap:10px;align-items:baseline;border:1px solid transparent;transition:opacity .18s ease, background .18s ease, border-color .18s ease}
.seg:hover{background:rgba(255,255,255,.02);border-color:var(--border)}
.seg.active{background:var(--block-hl-bg);border-color:var(--block-hl-border)}
.seg.dim{opacity:.35}
.seg .ts{
  color:var(--muted);
  font-variant-numeric:tabular-nums;
  font-size:12px;
  cursor:pointer;
  padding:4px 8px;
  border-radius:6px;
  background:rgba(255,255,255,0.03);
  border:1px solid transparent;
  transition:all .1s ease;
  user-select:none;
  text-align:center;
  min-width:60px;
  display:inline-block;
  width:fit-content;
}
.seg .ts:hover{
  background:rgba(255,255,255,0.08);
  border-color:var(--border);
  color:var(--text);
  transform:translateY(-1px);
}
.seg .ts:active, .seg .ts.clicked{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  transform:translateY(0) scale(0.96);
}
.seg .ts .tslink{color:var(--muted);text-decoration:none;display:inline-block;padding:2px 4px;border-radius:6px;transition:background .12s ease,color .12s ease}
.seg .ts .tslink:hover{background:rgba(255,255,255,.06);color:var(--accent);text-decoration:none}
.seg .seg-content.has-avatar{position:relative;padding-left:25px}
.seg .speaker-wrap{position:relative}
.seg.continuation{padding-top:0}
.seg.continuation .ts{visibility:hidden}
.seg.continuation .speaker-wrap,.seg.continuation .speaker-avatar{display:none}
.seg .speaker-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.12);position:absolute;left:0;top:1px}
.seg .speaker{color:#959bb4;font-weight:600;margin-right:6px;cursor:pointer}
.seg .speaker[data-char-idx]{margin-right:0}
.seg .speaker[data-char-idx]:last-of-type{margin-right:6px}
.seg .speaker.has-character{color:#fbbf24;border-bottom:1px dotted rgba(251,191,36,.4);position:relative}
.seg .speaker.is-dm{color:#ef4444;border-bottom:1px dotted rgba(239,68,68,.4);position:relative}
.seg .speaker.unmapped{position:relative;border-bottom:1px dotted rgba(138,138,154,.3)}
.seg .speaker-sep{color:#959bb4;font-weight:600;cursor:default;opacity:.5}
.seg .text{white-space:pre-wrap;word-break:break-word}
/* Per-phrase highlighting (replaces per-block .seg.active) */
.phrase{border-radius:4px;padding:1px 3px;transition:background .15s ease,color .1s ease;-webkit-box-decoration-break:clone;box-decoration-break:clone}
.phrase.active{background:linear-gradient(var(--phrase-hl-bg) calc(100% - 2px),color-mix(in srgb,var(--phrase-hl-bg) 40%,#fff) calc(100% - 2px)) no-repeat;color:#fff}
/* Inline silence indicators between merged phrases */
.inline-silence{display:inline-block;font-size:10px;color:var(--muted);opacity:.55;margin:0 4px;vertical-align:baseline;font-variant-numeric:tabular-nums;transition:opacity .15s}
.inline-silence.hidden{display:none}
.silence-gap{padding:2px 12px;margin:2px 0;display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center;transition:opacity .15s}
/* Jump flash animation */
.seg.jumped{background:var(--active-bg);border-color:var(--accent);box-shadow:0 0 0 2px rgba(110,168,254,.25) inset}
@keyframes jumpFlash{
  0%{box-shadow:0 0 0 0 rgba(110,168,254,.45)}
  50%{box-shadow:0 0 0 8px rgba(110,168,254,.18)}
  100%{box-shadow:0 0 0 0 rgba(110,168,254,0)}
}
.seg.jump-flash{animation:jumpFlash var(--jump-flash-ms) ease;background:var(--active-bg);border-color:var(--accent)}
/* Session notes — inline in transcript */
.session-note{padding:6px 10px;margin:2px 0;border-radius:8px;display:grid;grid-template-columns:86px 1fr;gap:10px;align-items:baseline;background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.18);cursor:pointer;transition:background .15s,border-color .15s}
.session-note:hover{background:rgba(251,191,36,.10);border-color:rgba(251,191,36,.30)}
.session-note.private{background:rgba(139,92,246,.06);border:1px solid rgba(139,92,246,.18)}
.session-note.private:hover{background:rgba(139,92,246,.10);border-color:rgba(139,92,246,.30)}
.session-note .note-ts{font-size:12px;color:var(--muted);white-space:nowrap}
.session-note .note-body{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.session-note .note-author{color:#fbbf24;font-weight:600;font-size:13px}
.session-note.private .note-author{color:#a78bfa}
.session-note .note-text{white-space:pre-wrap;word-break:break-word;font-size:14px;color:var(--fg)}
.session-note .note-actions{display:inline-flex;gap:2px;margin-left:auto}
.session-note .note-actions button{background:none;border:none;cursor:pointer;font-size:13px;padding:2px 4px;border-radius:4px;opacity:.5;transition:opacity .15s}
.session-note .note-actions button:hover{opacity:1;background:rgba(255,255,255,.08)}
.session-note .note-edit-input{flex:1;min-width:120px;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:4px 8px;color:var(--fg);font-size:14px}
.session-note .note-save-btn,.session-note .note-cancel-btn{background:none;border:1px solid var(--border);cursor:pointer;padding:2px 8px;border-radius:6px;font-size:14px;color:var(--fg)}
.session-note .note-save-btn:hover{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.4)}
.session-note .note-cancel-btn:hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.4)}
/* Modal select list (speaker map) */
.modal-select-list{list-style:none;padding:0;margin:0}
.modal-select-list .map-option{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .15s}
.modal-select-list .map-option:hover{background:rgba(255,255,255,.06)}
.modal-select-list .map-option.current{background:rgba(251,191,36,.12);color:#fbbf24}
.modal-select-list .map-option .idx{width:16px;text-align:center;font-size:13px;color:#fbbf24}

/* ── Speaker Popup ────────────────────────────────────────── */
@keyframes ttFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.speaker-popup{position:fixed;z-index:10000;background:linear-gradient(135deg,#1e1b2e 0%,#2a2545 100%);border:1px solid rgba(251,191,36,.35);border-radius:10px;padding:10px 14px;white-space:nowrap;font-size:12px;font-weight:500;color:#e2dff0;line-height:1.5;box-shadow:0 4px 20px rgba(0,0,0,.45),0 0 15px rgba(251,191,36,.08);animation:ttFadeIn .15s ease;cursor:default;min-width:180px}
.speaker-popup.dm-popup{border-color:rgba(239,68,68,.45);box-shadow:0 4px 20px rgba(0,0,0,.45),0 0 15px rgba(239,68,68,.12)}
.speaker-popup.dm-popup .sp-character{color:#ef4444}
.speaker-popup.dm-popup .sp-avatar{border-color:rgba(239,68,68,.4)}
.speaker-popup.dm-popup .sp-avatar-initial{background:linear-gradient(135deg,rgba(239,68,68,.3),rgba(200,50,50,.25));color:#ef4444;border-color:rgba(239,68,68,.3)}
.speaker-popup.dm-popup .sp-arrow{color:rgba(239,68,68,.5)}
.speaker-popup.unmapped{border-color:rgba(138,138,154,.35);box-shadow:0 4px 20px rgba(0,0,0,.45),0 0 15px rgba(138,138,154,.08)}
.speaker-popup .sp-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.speaker-popup .sp-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid rgba(251,191,36,.3);flex-shrink:0;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}
@media(hover:hover){.speaker-popup .sp-avatar:hover{transform:scale(2.5);z-index:10;box-shadow:0 4px 20px rgba(0,0,0,.6);border-color:rgba(251,191,36,.6)}}
.speaker-popup .sp-avatar.zoomed{transform:scale(2.5);z-index:10;box-shadow:0 4px 20px rgba(0,0,0,.6);border-color:rgba(251,191,36,.6)}
.speaker-popup .sp-avatar-initial{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-size:18px;font-weight:700;flex-shrink:0;background:linear-gradient(135deg,rgba(155,110,255,.3),rgba(110,168,254,.25));color:var(--accent);border:2px solid rgba(183,175,255,.2)}
.speaker-popup.unmapped .sp-avatar-initial{background:var(--chip);color:var(--muted);border-color:rgba(138,138,154,.15)}
.speaker-popup .sp-details{display:flex;flex-direction:column;gap:1px}
.speaker-popup .sp-character{font-size:14px;font-weight:700;color:#fbbf24}
.speaker-popup.unmapped .sp-character{color:#8a8a9a}
.speaker-popup .sp-player{font-size:11px;color:var(--muted)}
.speaker-popup .sp-role{font-size:10px;color:var(--muted);opacity:.7;text-transform:uppercase;letter-spacing:.04em}
.speaker-popup .sp-divider{height:1px;background:rgba(255,255,255,.06);margin:4px 0}
.speaker-popup .sp-mapping{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.speaker-popup .sp-mapping .sp-arrow{color:rgba(251,191,36,.5)}
.speaker-popup .sp-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:6px}
.speaker-popup .sp-actions .btn{font-size:11px;padding:2px 10px;border-radius:6px;min-width:0}
.speaker-popup .sp-actions .btn.map-btn{background:var(--accent);color:#fff}
.speaker-popup .sp-actions .btn.map-btn:hover{filter:brightness(1.15)}
/* Refresh button in standard (non-DDB) popup */
.speaker-popup .sp-ddb-refresh{padding:4px 12px 6px;text-align:center}
.speaker-popup .sp-ddb-refresh .btn-refresh-ddb{font-size:11px;padding:3px 10px;border:1px solid rgba(251,191,36,.35);background:rgba(251,191,36,.08);color:var(--accent);border-radius:4px;cursor:pointer;transition:all .15s;width:100%}
.speaker-popup .sp-ddb-refresh .btn-refresh-ddb:hover{background:rgba(251,191,36,.18);color:#fde68a}

/* ── Character Sheet Popup (DDB-enhanced) ─────────────────── */
.speaker-popup.ddb-sheet{padding:0;border:none;border-radius:12px;min-width:280px;max-width:340px;white-space:normal;background:#1a1525;box-shadow:0 8px 32px rgba(0,0,0,.6),0 0 0 1px rgba(141,101,56,.35),0 0 20px rgba(141,101,56,.08);overflow:visible}
.speaker-popup.ddb-sheet .cs-banner{position:relative;display:flex;align-items:flex-end;gap:12px;padding:14px 16px 12px;background:linear-gradient(135deg,#2a1f1a 0%,#1e1520 50%,#1a1525 100%);border-bottom:2px solid #8d6538;border-radius:12px 12px 0 0}
.speaker-popup.ddb-sheet .cs-banner::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h1v1H0z' fill='%23fff' fill-opacity='.012'/%3E%3C/svg%3E");opacity:.5;pointer-events:none;border-radius:12px 12px 0 0}
.speaker-popup.ddb-sheet .cs-avatar-frame{position:relative;flex-shrink:0;z-index:2}
.speaker-popup.ddb-sheet .sp-avatar{width:56px;height:56px;border:2px solid #8d6538;box-shadow:0 2px 8px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,255,255,.06);border-radius:8px}
@media(hover:hover){.speaker-popup.ddb-sheet .sp-avatar:hover{transform:scale(2.8);z-index:99999;box-shadow:0 8px 32px rgba(0,0,0,.8);border-color:#c9943e;border-radius:6px}}
.speaker-popup.ddb-sheet .sp-avatar.zoomed{transform:scale(2.8);z-index:99999;box-shadow:0 8px 32px rgba(0,0,0,.8);border-color:#c9943e;border-radius:6px}
.speaker-popup.ddb-sheet .sp-avatar-initial{width:56px;height:56px;border-radius:8px;border:2px solid #8d6538;background:linear-gradient(135deg,#2a2040,#1e1530);font-size:22px}
.speaker-popup.ddb-sheet .cs-lvl{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;background:linear-gradient(135deg,#8d6538,#c9943e);color:#1a1525;font-size:10px;font-weight:800;border-radius:50%;line-height:1;margin-left:6px;vertical-align:middle;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.speaker-popup.ddb-sheet .cs-name-block{flex:1;min-width:0;position:relative;z-index:1}
.speaker-popup.ddb-sheet .cs-char-name{font-size:16px;font-weight:800;color:#e8d5a3;letter-spacing:.02em;line-height:1.2;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.speaker-popup.ddb-sheet .cs-race-class{font-size:11px;color:#b8a080;margin-top:2px;line-height:1.3}
/* Ability score row */
.speaker-popup.ddb-sheet .cs-abilities{display:grid;grid-template-columns:repeat(6,1fr);gap:2px;padding:8px 12px 6px;background:rgba(0,0,0,.15)}
.speaker-popup.ddb-sheet .cs-ability{display:flex;flex-direction:column;align-items:center;gap:0}
.speaker-popup.ddb-sheet .cs-ability-label{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:#8d6538;font-weight:800;line-height:1}
.speaker-popup.ddb-sheet .cs-ability-mod{font-size:16px;font-weight:700;color:#e8d5a3;line-height:1.3}
.speaker-popup.ddb-sheet .cs-ability-score{font-size:9px;color:#7a6f5a;font-weight:600;line-height:1}
/* Combat stats row */
.speaker-popup.ddb-sheet .cs-combat{display:flex;justify-content:space-around;padding:6px 12px;gap:4px}
.speaker-popup.ddb-sheet .cs-combat-stat{display:flex;flex-direction:column;align-items:center;flex:1}
.speaker-popup.ddb-sheet .cs-combat-label{font-size:8px;text-transform:uppercase;letter-spacing:.1em;color:#8d6538;font-weight:700;line-height:1.4}
.speaker-popup.ddb-sheet .cs-combat-value{font-size:15px;font-weight:700;color:#d4c4a0;line-height:1.3}
.speaker-popup.ddb-sheet .cs-combat-unit{font-size:8px;color:#7a6f5a;font-weight:500}
.speaker-popup.ddb-sheet .cs-rule{height:1px;background:linear-gradient(90deg,transparent,#8d6538 20%,#8d6538 80%,transparent);margin:0;border:none;opacity:.35}
.speaker-popup.ddb-sheet .cs-body{padding:8px 16px 4px}
.speaker-popup.ddb-sheet .cs-stats{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px}
.speaker-popup.ddb-sheet .cs-stat{display:flex;flex-direction:column}
.speaker-popup.ddb-sheet .cs-stat-label{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:#8d6538;font-weight:700}
.speaker-popup.ddb-sheet .cs-stat-value{font-size:12px;color:#d4c4a0;font-weight:500}
.speaker-popup.ddb-sheet .cs-footer{display:flex;align-items:center;justify-content:space-between;padding:6px 16px 10px;margin-top:4px;border-top:1px solid rgba(141,101,56,.2)}
.speaker-popup.ddb-sheet .cs-player-tag{font-size:10px;color:#7a6f5a;display:flex;align-items:center;gap:4px}
.speaker-popup.ddb-sheet .cs-player-tag .cs-dot{width:4px;height:4px;border-radius:50%;background:#8d6538;opacity:.6}
.speaker-popup.ddb-sheet .cs-ddb-link{font-size:10px;color:#8d6538;text-decoration:none;display:flex;align-items:center;gap:3px;transition:color .15s}
.speaker-popup.ddb-sheet .cs-ddb-link:hover{color:#c9943e}
.speaker-popup.ddb-sheet .cs-mapping{font-size:10px;color:#7a6f5a;padding:0 16px 4px;display:flex;align-items:center;gap:4px}
.speaker-popup.ddb-sheet .cs-mapping .sp-arrow{color:#8d6538}
.speaker-popup.ddb-sheet .cs-snapshot{font-size:9px;color:#5a5040;padding:0 16px;opacity:.8;font-style:italic}
/* Defense/sense tags */
.speaker-popup.ddb-sheet .cs-tags{display:flex;flex-wrap:wrap;gap:3px;padding:4px 12px 2px}
.speaker-popup.ddb-sheet .cs-tag{font-size:9px;padding:1px 6px;border-radius:3px;font-weight:600;line-height:1.6}
.speaker-popup.ddb-sheet .cs-tag-res{background:rgba(60,120,60,.25);color:#6dbf6d}
.speaker-popup.ddb-sheet .cs-tag-imm{background:rgba(70,70,160,.25);color:#9090e0}
.speaker-popup.ddb-sheet .cs-tag-sense{background:rgba(100,80,40,.25);color:#b0a070}
.speaker-popup.ddb-sheet .cs-xp-bar-wrap{padding:4px 16px 2px}
.speaker-popup.ddb-sheet .cs-xp-bar{height:6px;background:rgba(0,0,0,.3);border-radius:3px;overflow:hidden;border:1px solid rgba(141,101,56,.25)}
.speaker-popup.ddb-sheet .cs-xp-fill{height:100%;background:linear-gradient(90deg,#8d6538,#c9943e);border-radius:3px;transition:width .3s}
.speaker-popup.ddb-sheet .cs-xp-label{font-size:9px;color:#7a6f5a;font-weight:600;text-align:center;margin-top:2px}
.speaker-popup.ddb-sheet .btn-refresh-ddb{font-size:9px;padding:1px 6px;margin-left:6px;border:1px solid rgba(141,101,56,.4);background:rgba(141,101,56,.15);color:#c9943e;border-radius:3px;cursor:pointer;transition:all .15s}
.speaker-popup.ddb-sheet .btn-refresh-ddb:hover{background:rgba(141,101,56,.3);color:#e8d5a3}
.speaker-popup.ddb-sheet .sp-actions{padding:0 16px 10px;margin-top:2px}
.speaker-popup.ddb-sheet .sp-actions .btn.map-btn{background:linear-gradient(135deg,#8d6538,#c9943e);color:#1a1525;font-weight:700;border:none}
/* Primary badge */
.speaker-popup.ddb-sheet .cs-primary-badge{display:inline-block;font-size:9px;font-weight:700;color:#c9943e;background:rgba(141,101,56,.2);border:1px solid rgba(141,101,56,.35);border-radius:3px;padding:1px 6px;margin-top:2px;letter-spacing:.03em;text-transform:uppercase}
/* Secondary character cards */
.speaker-popup.ddb-sheet .cs-secondary-char{display:flex;align-items:center;gap:10px;padding:8px 16px;background:rgba(0,0,0,.15);border-radius:6px;margin:4px 12px}
.speaker-popup.ddb-sheet .cs-sec-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1.5px solid rgba(141,101,56,.4);flex-shrink:0}
.speaker-popup.ddb-sheet .cs-sec-initial{display:flex;align-items:center;justify-content:center;background:rgba(141,101,56,.2);color:#c9943e;font-weight:700;font-size:13px}
.speaker-popup.ddb-sheet .cs-sec-info{flex:1;min-width:0}
.speaker-popup.ddb-sheet .cs-sec-name{font-size:12px;font-weight:700;color:#e8d5a3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.speaker-popup.ddb-sheet .cs-sec-label{font-size:9px;font-weight:600;color:#7a6f5a;background:rgba(141,101,56,.15);border-radius:2px;padding:0 4px;vertical-align:middle}
.speaker-popup.ddb-sheet .cs-sec-meta{font-size:10px;color:#7a6f5a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.speaker-popup.ddb-sheet .cs-sec-link{color:#8d6538;text-decoration:none;font-size:14px;flex-shrink:0;transition:color .15s}
.speaker-popup.ddb-sheet .cs-sec-link:hover{color:#c9943e}
/* Radio card for settings */
.radio-card{transition:border-color .15s,background .15s}
.radio-card:has(input:checked){border-color:var(--accent) !important;background:rgba(251,191,36,.06)}
.radio-card:has(input:disabled){opacity:.6;cursor:default !important}

/* ── Clip Mode ────────────────────────────────────────────── */
.clip-mode .seg{cursor:crosshair}
.seg.clip-start{border-left:3px solid var(--ok);border-top-left-radius:3px;border-bottom-left-radius:3px}
.seg.clip-end{border-right:3px solid var(--ok);border-top-right-radius:3px;border-bottom-right-radius:3px}
.seg.clip-range{background:rgba(41,211,152,.08)}
.seg.clip-range:hover{background:rgba(41,211,152,.14)}
.btn.clip-active,.dfb-pill.clip-active{color:var(--ok);border-color:var(--ok);background:rgba(41,211,152,.1)}
.clip-badge{position:fixed;bottom:80px;right:20px;background:var(--panel);border:1px solid var(--ok);border-radius:20px;padding:6px 14px;font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(0,0,0,.4);z-index:900;animation:ttFadeIn .18s ease;user-select:none}
.clip-badge .clip-badge-time{color:var(--ok);font-weight:600;font-variant-numeric:tabular-nums}
.clip-badge .clip-badge-dur{color:var(--muted);font-size:11px}
.clip-badge .clip-badge-clear{cursor:pointer;color:var(--muted);margin-left:4px;font-size:16px;line-height:1;padding:0 2px}
.clip-badge .clip-badge-clear:hover{color:var(--danger)}

/* ── Clip Export Panel ────────────────────────────────────── */
.clip-export-panel{position:fixed;bottom:80px;right:20px;width:320px;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:950;animation:ttFadeIn .18s ease}
.clip-export-panel .cep-title{font-size:15px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.clip-export-panel .cep-title .cep-dur{font-size:12px;color:var(--ok);font-weight:400}
.clip-export-panel .cep-close{cursor:pointer;color:var(--muted);font-size:18px;line-height:1;padding:2px 4px}
.clip-export-panel .cep-close:hover{color:var(--danger)}
.clip-export-panel .cep-row{display:flex;gap:8px;margin-bottom:10px}
.clip-export-panel .cep-row.cep-buttons{margin-bottom:14px}
.clip-export-panel .cep-btn{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;text-align:center;font-size:13px;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .15s ease}
.clip-export-panel .cep-btn:hover{border-color:var(--accent);background:rgba(110,168,254,.08)}
.clip-export-panel .cep-btn.active{border-color:var(--accent);background:rgba(110,168,254,.12);box-shadow:0 0 0 1px var(--accent) inset}
.clip-export-panel .cep-btn.active svg{opacity:1}
.clip-export-panel .cep-btn svg{opacity:.7}
.clip-export-panel .cep-option{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);margin-bottom:6px;cursor:pointer}
.clip-export-panel .cep-option input[type="checkbox"]{margin:0}
.clip-export-panel .cep-radio-group{display:flex;gap:12px;margin-bottom:10px}
.clip-export-panel .cep-radio{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text);cursor:pointer}
.clip-export-panel .cep-radio input{margin:0}
.clip-export-panel .cep-select{width:100%;padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-size:13px;margin-bottom:10px}
.clip-export-panel .cep-section{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:10px 0 6px;font-weight:600}
.clip-export-panel .cep-actions{display:flex;gap:8px;margin-top:14px}
.clip-export-panel .cep-actions .btn{flex:1}
/* Clip render progress */
.clip-export-panel .cep-progress{margin-top:12px}
.clip-export-panel .cep-progress-bar{height:6px;border-radius:3px;background:var(--border);overflow:hidden}
.clip-export-panel .cep-progress-fill{height:100%;border-radius:3px;background:var(--ok);transition:width .3s ease}
.clip-export-panel .cep-progress-text{font-size:11px;color:var(--muted);margin-top:4px;text-align:center}
.clip-export-panel .cep-done{text-align:center;margin-top:8px}
.clip-export-panel .cep-done .btn{display:inline-flex;align-items:center;gap:6px}

/* ── Note Mode ──────────────────────────────────────────── */
.note-mode .seg{cursor:crosshair}
.seg.note-target{border-left:3px solid #fbbf24;background:rgba(251,191,36,.10);border-top-left-radius:3px;border-bottom-left-radius:3px}
.btn.note-active,.dfb-pill.note-active{color:#fbbf24;border-color:#fbbf24;background:rgba(251,191,36,.1)}
.note-badge{position:fixed;bottom:80px;right:20px;background:var(--panel);border:1px solid #fbbf24;border-radius:20px;padding:6px 14px;font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(0,0,0,.4);z-index:900;animation:ttFadeIn .18s ease;user-select:none}
.note-badge .note-badge-icon{font-size:16px}
.note-badge .note-badge-text{color:var(--muted);font-size:12px}
.note-badge .note-badge-ts{color:#fbbf24;font-weight:600;font-variant-numeric:tabular-nums}
.note-badge .note-badge-clear{cursor:pointer;color:var(--muted);margin-left:4px;font-size:16px;line-height:1;padding:0 2px}
.note-badge .note-badge-clear:hover{color:var(--danger)}
/* Note compose panel (phases 2 & 3) */
.note-panel{position:fixed;bottom:80px;right:20px;width:340px;background:var(--panel);border:1px solid rgba(251,191,36,.25);border-radius:14px;padding:20px;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:950;animation:ttFadeIn .18s ease}
.note-panel .np-title{font-size:15px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.note-panel .np-title .np-ts{font-size:12px;color:#fbbf24;font-weight:400;margin-left:auto}
.note-panel .np-close{cursor:pointer;color:var(--muted);font-size:18px;line-height:1;padding:2px 4px}
.note-panel .np-close:hover{color:var(--danger)}
.note-panel .np-textarea{width:100%;box-sizing:border-box;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--fg);font-size:14px;font-family:inherit;resize:vertical;min-height:80px;line-height:1.5;transition:border-color .15s}
.note-panel .np-textarea:focus{outline:none;border-color:#fbbf24}
.note-panel .np-charcount{font-size:11px;color:var(--muted);text-align:right;margin-top:4px}
.note-panel .np-actions{display:flex;gap:8px;margin-top:14px}
.note-panel .np-actions .btn{flex:1}
/* Preview box */
.note-panel .np-preview-box{padding:10px 12px;border-radius:10px;background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.18);margin-bottom:12px}
.note-panel .np-preview-ts{font-size:12px;color:var(--muted);margin-bottom:4px}
.note-panel .np-preview-text{white-space:pre-wrap;word-break:break-word;font-size:14px;color:var(--fg);line-height:1.5}
/* Visibility radio group */
.note-panel .np-visibility{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.note-panel .np-vis-option{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);cursor:pointer;transition:all .15s}
.note-panel .np-vis-option:hover{border-color:rgba(251,191,36,.3);background:rgba(251,191,36,.04)}
.note-panel .np-vis-option:has(input:checked){border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.note-panel .np-vis-option input[type="radio"]{margin-top:3px}
.note-panel .np-vis-label{font-weight:600;font-size:13px;color:var(--fg)}
.note-panel .np-vis-desc{font-size:11px;color:var(--muted);display:block;margin-top:1px}
/* Note mode toggle bar */
.note-mode-bar{position:fixed;bottom:44px;right:20px;z-index:960;display:flex;gap:0;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--panel);animation:ttFadeIn .18s ease}
.note-mode-btn{padding:6px 14px;font-size:13px;font-weight:500;cursor:pointer;border:none;background:transparent;color:var(--muted);transition:all .15s;white-space:nowrap}
.note-mode-btn:hover{color:var(--fg);background:rgba(251,191,36,.06)}
.note-mode-btn.active{color:#fbbf24;background:rgba(251,191,36,.12);font-weight:600}
/* AI note range highlight */
.ai-note-mode .seg{cursor:crosshair}
.seg.ai-note-start{border-left:3px solid #fbbf24;background:rgba(251,191,36,.10);border-top-left-radius:3px;border-bottom-left-radius:3px}
.seg.ai-note-end{border-right:3px solid #fbbf24;background:rgba(251,191,36,.10);border-top-right-radius:3px;border-bottom-right-radius:3px}
.seg.ai-note-range{background:rgba(251,191,36,.06)}
.seg.ai-note-range:hover{background:rgba(251,191,36,.12)}
/* AI note panel extras */
.ai-note-panel .np-title .np-ts{color:#fbbf24}
.anp-field{margin-bottom:10px}
.anp-label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px}
.anp-label .muted{font-weight:400}
.anp-select{width:100%;box-sizing:border-box;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--fg);font-size:13px;font-family:inherit}
.anp-select:focus{outline:none;border-color:#fbbf24}
.anp-input{width:100%;box-sizing:border-box;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--fg);font-size:13px;font-family:inherit}
.anp-input:focus{outline:none;border-color:#fbbf24}
.anp-cost{font-size:12px;color:var(--muted);margin:8px 0 4px;min-height:18px}
.anp-cost .cost-free{color:#4caf50;font-weight:600}
.anp-cost .cost-paid{color:#e8b630;font-weight:600}
.anp-cost .cost-error{color:var(--danger)}
.anp-generate-btn{display:flex;align-items:center;justify-content:center;gap:8px}
.anp-generate-btn .btn-cost{font-size:11px;opacity:.8;background:rgba(255,255,255,.1);padding:1px 6px;border-radius:6px}
.anp-generate-btn .btn-cost.free{color:#4caf50}
.anp-generating{display:flex;align-items:center;gap:10px;padding:24px 0;justify-content:center;color:var(--muted);font-size:14px}
.anp-spinner{width:20px;height:20px;border:2px solid rgba(251,191,36,.3);border-top-color:#fbbf24;border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.anp-preview-header{font-size:12px;color:#fbbf24;margin-bottom:8px;font-weight:500}
.ai-note-panel{border-color:rgba(251,191,36,.25)}

/* ── Search Strip ─────────────────────────────────────────── */
.search-strip{padding:6px 14px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.search-strip.hidden{display:none !important}
.search-strip #title,#title{margin:0;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}
.searchbar{max-width:1200px;margin:0 auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex:1}
.searchbar .input{width:320px}
.searchbar .btn{padding:6px 10px;height:30px}
.searchbar .pill.small{padding:4px 8px;font-size:11px}
mark.hl{background:var(--hl);color:inherit;border:1px solid var(--hl-border);border-radius:4px;padding:0 2px}
.control-help{position:absolute;right:18px;top:64px;width:320px;background:var(--panel-2);border:1px solid var(--border);padding:10px;border-radius:10px;font-size:13px;color:var(--muted);box-shadow:0 12px 40px rgba(0,0,0,.6);z-index:60}
.control-help p{margin:6px 0}
#status{position:relative;z-index:7}

/* ── Modals & Dialogs ─────────────────────────────────────── */
.modal{position:fixed;inset:0;z-index:10500;overflow-y:auto;display:flex;flex-direction:column;align-items:center}
.modal .backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.modal .dialog{position:relative;width:min(620px,92vw);background:var(--panel-2);border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:0 20px 60px rgba(0,0,0,.6);margin:auto;flex-shrink:0;animation:modalSlide .18s ease;max-height:calc(100vh - 48px);overflow:auto}
.dialog h3{margin:0 0 10px}
.dialog .rowline{display:flex;gap:8px;margin:8px 0;align-items:center}
.dialog .rowline .input{flex:1}
/* ── Highlight preset picker ─────────────────────────────── */
.hl-presets{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 4px}
.hl-preset{width:64px;height:44px;border-radius:8px;border:2px solid var(--border);cursor:pointer;position:relative;overflow:hidden;transition:border-color .15s,box-shadow .15s}
.hl-preset:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.hl-preset.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}
.hl-preset .hl-swatch-block{height:50%;width:100%}
.hl-preset .hl-swatch-phrase{height:50%;width:100%}
.hl-preset-label{font-size:10px;color:var(--muted);text-align:center;margin-top:2px;line-height:1.1}
.hl-custom-row{display:flex;gap:12px;align-items:center;margin-top:8px}
.hl-custom-row label{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px}
.hl-custom-row input[type=color]{width:32px;height:24px;border:1px solid var(--border);border-radius:4px;background:var(--panel);cursor:pointer;padding:0}
.hl-custom-row input[type=color]::-webkit-color-swatch-wrapper{padding:1px}
.hl-custom-row input[type=color]::-webkit-color-swatch{border-radius:2px;border:none}

/* ── Gate (Auth Overlay) ──────────────────────────────────── */
.gate{position:fixed;inset:0;display:grid;place-items:center;background:rgba(8,10,20,.55);backdrop-filter:blur(6px);z-index:9999}
.gate.hidden{display:none}
.gate .card{background:var(--panel-2);border:1px solid var(--border);border-radius:14px;padding:18px;width:min(440px,92vw);box-shadow:0 20px 60px rgba(0,0,0,.7)}
.gate .card h3{margin:0 0 10px}
.gate .rowline{display:flex;gap:8px;margin:8px 0;align-items:center}
.gate .rowline .input{flex:1}
.gate.showing{animation:fadeIn .16s ease}
.gate.showing .card{animation:popIn .18s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ── Wiki Panel (inline in split-layout) ──────────────────── */
#wikiOverlay{display:none;flex-direction:column;overflow:hidden;background:var(--bg);min-height:0;animation:wikiFadeIn .2s ease}
#wikiOverlay.hidden{display:none !important}
.split-layout.wiki-open #wikiOverlay:not(.hidden){display:flex}
.split-layout.wiki-open #tsScroll{display:none}
@keyframes wikiFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.wiki-header{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--panel),var(--panel-2));flex-shrink:0}
.wiki-header h2{margin:0;font-size:18px;font-weight:700;white-space:nowrap}
.wiki-header .wiki-party-name{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wiki-search-bar{flex:1;max-width:420px;position:relative;display:none}
.wiki-search-bar.wiki-search-visible{display:block}
.wiki-search-bar input{width:100%;padding:8px 12px 8px 34px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px}
.wiki-search-bar input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(110,168,254,.15)}
.wiki-search-bar .wiki-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.wiki-type-pills{display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.wiki-type-pill{padding:4px 10px;border-radius:14px;font-size:12px;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--muted);transition:all .15s}
.wiki-type-pill:hover{border-color:var(--accent);color:var(--text)}
.wiki-type-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.wiki-type-pill .wiki-pill-count{opacity:.7;margin-left:3px;font-size:10px}
.wiki-sort-select{margin-left:auto;padding:4px 8px;border-radius:8px;font-size:12px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;outline:none;transition:border-color .15s}
.wiki-sort-select:hover,.wiki-sort-select:focus{border-color:var(--accent)}
.wiki-body{display:grid;grid-template-columns:380px 1fr;grid-template-rows:1fr;flex:1;min-height:0;overflow:hidden}
.wiki-sidebar{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;background:var(--panel)}
.wiki-sidebar-scroll{flex:1;overflow-y:auto;padding:4px 0}
.wiki-entry-row{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;cursor:pointer;border-left:3px solid transparent;transition:background .12s,border-color .12s}
.wiki-entry-row:hover{background:rgba(255,255,255,.04)}
.wiki-entry-row.active{background:var(--active-bg);border-left-color:var(--accent)}
.wiki-entry-row .wiki-entry-icon{font-size:20px;flex-shrink:0;width:28px;text-align:center;padding-top:2px}
.wiki-entry-row .wiki-entry-info{flex:1;min-width:0}
.wiki-entry-row .wiki-entry-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wiki-entry-row .wiki-entry-summary{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.wiki-entry-row .wiki-entry-meta{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:10px;color:var(--muted)}
.wiki-entry-row .wiki-entry-type-label{text-transform:uppercase;letter-spacing:.3px;opacity:.7}
.wiki-entry-row .wiki-entry-mentions{opacity:.7}
.wiki-mobile-back{display:none;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);color:var(--text);font-size:13px;cursor:pointer;margin-bottom:12px;transition:background .15s,border-color .15s}
.wiki-mobile-back:hover{background:var(--active);border-color:var(--accent)}
.wiki-detail{overflow-y:auto;padding:32px 40px;background:var(--bg)}
.wiki-detail-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted);font-size:14px;flex-direction:column;gap:8px}
.wiki-detail-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}
.wiki-detail-header .wiki-detail-icon{font-size:36px}
.wiki-detail-header .wiki-detail-title{font-size:22px;font-weight:700;margin:0}
.wiki-detail-header .wiki-detail-type{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--chip);color:var(--muted);display:inline-block;margin-top:2px}
.wiki-detail-aliases{font-size:12px;color:var(--muted);font-style:italic;margin-bottom:12px}
.wiki-detail-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:16px}
.wiki-detail-tags .badge{font-size:10px}
.wiki-detail-summary{font-size:14px;color:var(--muted);font-style:italic;margin-bottom:16px;line-height:1.5;border-left:3px solid var(--accent);padding-left:12px}
.wiki-detail-body{font-size:14px;line-height:1.7;margin-bottom:24px}
.wiki-detail-body h1,.wiki-detail-body h2,.wiki-detail-body h3{margin:16px 0 8px;font-weight:600;line-height:1.3}
.wiki-detail-body h1{font-size:18px}.wiki-detail-body h2{font-size:16px}.wiki-detail-body h3{font-size:14px;color:var(--accent);text-transform:uppercase;letter-spacing:.3px}
.wiki-detail-body strong{font-weight:600}.wiki-detail-body em{font-style:italic;color:var(--muted)}
.wiki-detail-body code{background:var(--panel-2);padding:1px 5px;border-radius:4px;font-size:12px;font-family:var(--font-mono)}
.wiki-detail-body .list-item{padding:2px 0 2px 8px}
.wiki-detail-body .md-table{border-collapse:collapse;margin:8px 0;font-size:13px;width:100%}
.wiki-detail-body .md-table th,.wiki-detail-body .md-table td{padding:4px 8px;border:1px solid var(--border);text-align:left}
.wiki-detail-body .md-table th{background:var(--panel-2);font-weight:600}
.wiki-link{color:var(--accent);text-decoration:none;border-bottom:1px dashed var(--accent);cursor:pointer;transition:border-color .15s,color .15s}
.wiki-link:hover{color:var(--accent-2);border-bottom-style:solid}
.wiki-link.broken{color:var(--muted);border-bottom-color:var(--muted);cursor:default}
.wiki-detail-section{margin-bottom:24px}
.wiki-detail-section h3{font-size:14px;font-weight:600;margin:0 0 8px;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}
.wiki-section-toggle{cursor:pointer;display:flex;align-items:center;gap:6px;user-select:none;transition:opacity .15s}
.wiki-section-toggle:hover{opacity:.8}
.wiki-section-arrow{display:inline-block;transition:transform .2s;font-size:11px;line-height:1}
.wiki-section-toggle.open .wiki-section-arrow{transform:rotate(90deg)}
.wiki-section-body{overflow:hidden;transition:max-height .25s ease}
.wiki-section-body.collapsed{max-height:0 !important;overflow:hidden}
.wiki-mention-group{margin-bottom:12px}
.wiki-mention-group-header{display:flex;align-items:center;gap:8px;padding:6px 0;margin-bottom:4px;border-bottom:1px solid var(--border)}
.wiki-mention-group-header a,.wiki-mention-group-header span{font-size:13px;font-weight:600;color:var(--text);text-decoration:none}
.wiki-mention-group-header a:hover{color:var(--accent);text-decoration:underline}
.wiki-mention-group-count{font-size:11px;color:var(--muted);font-weight:400}
.wiki-relation-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);font-size:12px;cursor:pointer;transition:border-color .15s,background .15s;margin:0 6px 6px 0}
.wiki-relation-chip:hover{border-color:var(--accent);background:var(--active-bg)}
.wiki-mention-row{display:flex;gap:8px;padding:8px 12px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);margin-bottom:6px;font-size:12px;align-items:flex-start}
.wiki-mention-row .wiki-mention-ts{color:var(--accent);font-weight:600;flex-shrink:0;cursor:pointer;text-decoration:none}
.wiki-mention-row .wiki-mention-ts:hover{text-decoration:underline}
.wiki-mention-row .wiki-mention-session{color:var(--muted);flex-shrink:0;font-style:italic}
.wiki-mention-row .wiki-mention-speaker{color:var(--accent-2);flex-shrink:0}
.wiki-mention-row .wiki-mention-text{color:var(--text);flex:1;min-width:0}
.wiki-detail-actions{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}
.wiki-detail-actions .btn{font-size:12px;padding:6px 14px;display:inline-flex;align-items:center;gap:5px;border-radius:8px;font-weight:600;white-space:nowrap}
.wiki-detail-actions .btn svg{flex-shrink:0}
.wiki-detail-actions .btn.discord-post-btn{background:rgba(88,101,242,.12);border-color:rgba(88,101,242,.35);color:#7c8af2}
.wiki-detail-actions .btn.discord-post-btn:hover{background:rgba(88,101,242,.2);border-color:rgba(88,101,242,.55);color:#95a0ff}
.wiki-edit-form{max-width:640px}
.wiki-edit-form .wiki-field{margin-bottom:12px}
.wiki-edit-form .wiki-field label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.wiki-edit-form .wiki-field input,.wiki-edit-form .wiki-field select,.wiki-edit-form .wiki-field textarea{width:100%}

/* ── Wiki Autocomplete ────────────────────────────────────── */
.wiki-ac-dropdown{position:fixed;z-index:9999;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.35);max-height:240px;overflow-y:auto;min-width:200px;padding:4px 0}
.wiki-ac-item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;font-size:13px;color:var(--text);transition:background .1s}
.wiki-ac-item:hover,.wiki-ac-item.active{background:rgba(var(--accent-rgb,99,102,241),.15)}
.wiki-ac-icon{font-size:14px;width:20px;text-align:center;flex-shrink:0}
.wiki-ac-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wiki-ac-type{font-size:11px;color:var(--muted);text-transform:capitalize;flex-shrink:0}

/* ── Wiki View Tabs ───────────────────────────────────────── */
.wiki-view-tabs{display:flex;gap:4px;padding:0 16px 10px;border-bottom:1px solid var(--border);flex-shrink:0}
.wiki-view-tab{padding:5px 14px;border-radius:6px;font-size:12px;font-weight:600;color:var(--muted);background:transparent;border:1px solid transparent;cursor:pointer;transition:all .15s;letter-spacing:.2px}
.wiki-view-tab:hover{color:var(--text);background:var(--panel-2)}
.wiki-view-tab.active{color:var(--accent);background:rgba(var(--accent-rgb,99,102,241),.1);border-color:rgba(var(--accent-rgb,99,102,241),.25)}

/* ── Wiki Timeline ────────────────────────────────────────── */
.wiki-timeline-container{flex:1;overflow-y:auto;padding:16px 24px;grid-column:1/-1}
.wiki-timeline{position:relative}
.tl-session{position:relative;padding-left:28px;margin-bottom:24px}
.tl-session::before{content:'';position:absolute;left:7px;top:20px;bottom:0;width:2px;background:var(--border);border-radius:1px}
.tl-session:last-child::before{display:none}
.tl-session-header{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:4px 0;margin-left:-28px;padding-left:0;border-radius:8px;transition:background .15s}
.tl-session-header:hover{background:var(--panel-2);padding-left:8px;margin-left:-36px}
.tl-session-dot{width:16px;height:16px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:2px;box-shadow:0 0 0 3px var(--panel),0 0 8px rgba(var(--accent-rgb,99,102,241),.3)}
.tl-session-info{min-width:0}
.tl-session-title{display:block;font-size:14px;font-weight:700;color:var(--text);line-height:1.3}
.tl-session-date{display:block;font-size:11px;color:var(--muted);margin-top:2px}
.tl-session-body{padding:10px 0 0;overflow:hidden;transition:max-height .3s ease,opacity .25s ease;max-height:2000px;opacity:1}
.tl-session.collapsed .tl-session-body{max-height:0;opacity:0;padding:0}
.tl-session-toggle{font-size:10px;color:var(--muted);flex-shrink:0;transition:transform .2s;display:inline-block;margin-top:4px}
.tl-session.collapsed .tl-session-toggle{transform:rotate(-90deg)}
.tl-group{margin-bottom:12px}
.tl-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px;padding-left:2px}
.tl-entry{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s;border:1px solid transparent;margin-bottom:3px}
.tl-entry:hover{background:var(--panel-2);border-color:var(--border)}
.tl-entry-new{align-items:flex-start}
.tl-entry-new .tl-entry-info{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.tl-entry-icon{font-size:16px;flex-shrink:0;line-height:1}
.tl-entry-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-entry-summary{font-size:11px;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tl-entry-date{font-size:11px;color:var(--accent);font-weight:500}
.tl-entry-mc{font-size:11px;color:var(--muted);flex-shrink:0;font-weight:500}
.tl-entry-returning{opacity:.75}
.tl-entry-returning:hover{opacity:1}
.tl-filter-bar{padding:0 0 12px;border-bottom:1px solid var(--border);margin-bottom:16px}
.tl-filter-pills{display:flex;gap:4px;flex-wrap:wrap}
.tl-filter-pill{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;color:var(--muted);background:transparent;border:1px solid transparent;cursor:pointer;transition:all .15s;text-transform:capitalize}
.tl-filter-pill:hover{color:var(--text);background:var(--panel-2)}
.tl-filter-pill.active{color:var(--accent);background:rgba(var(--accent-rgb,99,102,241),.1);border-color:rgba(var(--accent-rgb,99,102,241),.25)}

/* ── Wiki Graph ───────────────────────────────────────────── */
.wiki-graph-container{grid-column:1/-1;overflow:hidden;position:relative;display:flex;flex-direction:column;height:100%}
.graph-controls{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);flex-shrink:0;gap:8px}
.graph-filter-pills{display:flex;gap:4px;flex-wrap:wrap}
.graph-filter-pill{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;color:var(--muted);background:transparent;border:1px solid transparent;cursor:pointer;transition:all .15s}
.graph-filter-pill:hover{color:var(--text);background:var(--panel-2)}
.graph-filter-pill.active{color:var(--accent);background:rgba(var(--accent-rgb,99,102,241),.1);border-color:rgba(var(--accent-rgb,99,102,241),.25)}
.graph-actions{display:flex;gap:4px}
.graph-btn{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;color:var(--muted);background:var(--panel-2);border:1px solid var(--border);cursor:pointer;transition:all .15s}
.graph-btn:hover{color:var(--text);border-color:var(--accent)}
.graph-canvas{flex:1;min-height:0}
.graph-tooltip{position:absolute;transform:translate(-50%,-100%);background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:6px 10px;pointer-events:auto;z-index:100;box-shadow:0 4px 12px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:2px;max-width:280px}
.graph-tooltip strong{font-size:12px;color:var(--text);white-space:nowrap}
.graph-tooltip-type{font-size:10px;color:var(--muted);text-transform:capitalize}
.graph-tooltip-mc{font-size:10px;color:var(--accent)}
.graph-tooltip-relations{margin-top:4px;border-top:1px solid var(--border);padding-top:4px;max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:3px}
.graph-tooltip-rel{display:flex;flex-direction:column;gap:0}
.graph-tooltip-rel-name{font-size:11px;font-weight:600;color:var(--accent);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.graph-tooltip-rel-name:hover{text-decoration:underline}
.graph-tooltip-rel-labels{font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.graph-tooltip-tappable{cursor:pointer}
.graph-tooltip-hint{display:block;margin-top:4px;font-size:10px;color:var(--accent);text-align:center;opacity:.7}
.graph-tooltip-open{margin-top:4px;padding:3px 10px;border:none;border-radius:5px;background:var(--accent);color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:opacity .15s}
.graph-tooltip-open:hover{opacity:.85}
.graph-edge-tooltip{pointer-events:none}
.graph-edge-tooltip-header{font-size:11px;color:var(--accent);white-space:nowrap}
.graph-edge-tooltip-list{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:1px}
.graph-edge-tooltip-list li{font-size:11px;color:var(--text);padding:2px 0;white-space:nowrap}
.graph-edge-tooltip-list li::before{content:'→ ';color:var(--muted)}

/* ── Discord Tab (Party Modal) ────────────────────────────── */
.discord-section{padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);margin-bottom:12px}
.discord-section-title{margin:0 0 10px;font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center}
.discord-status-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:8px;border:1px solid var(--border);background:var(--panel);margin-bottom:10px}
.discord-status-card.connected{border-color:rgba(41,211,152,.35);background:linear-gradient(135deg,rgba(41,211,152,.06),transparent)}
.discord-status-card.disconnected{border-color:rgba(255,107,107,.25);background:linear-gradient(135deg,rgba(255,107,107,.05),transparent)}
.discord-status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.discord-status-dot.connected{background:var(--ok);box-shadow:0 0 6px rgba(41,211,152,.45)}
.discord-status-dot.disconnected{background:var(--danger);box-shadow:0 0 6px rgba(255,107,107,.35)}
.discord-status-info{min-width:0}
.discord-status-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);margin-bottom:2px}
.discord-status-name{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.discord-status-id{font-size:11px;color:var(--muted);margin-top:1px;font-family:monospace}
.discord-hint{font-size:12px;color:var(--muted);line-height:1.5;margin:6px 0 0}
.discord-hint code{background:var(--panel);padding:1px 5px;border-radius:4px;font-size:11px;border:1px solid var(--border)}
.discord-setup-steps{margin-top:10px}
.discord-steps{margin:6px 0 0;padding-left:22px;font-size:12px;color:var(--text);line-height:1.7}
.discord-steps li{margin-bottom:2px}
.discord-link{color:var(--accent);font-weight:600}
.discord-link:hover{text-decoration:underline}
.discord-invite-btn{display:inline-flex;align-items:center;margin-top:10px;background:#5865F2!important;color:#fff!important;border:none;font-weight:600;padding:8px 16px;border-radius:8px;font-size:13px;transition:background .15s,transform .1s;text-decoration:none}
.discord-invite-btn:hover{background:#4752C4!important;transform:translateY(-1px)}
.discord-invite-btn-sm{display:inline-flex;align-items:center;background:transparent;color:#5865F2;border:1px solid rgba(88,101,242,.4);font-weight:600;padding:4px 12px;border-radius:6px;font-size:12px;transition:background .15s,color .15s;text-decoration:none;cursor:pointer}
.discord-invite-btn-sm:hover{background:rgba(88,101,242,.1);color:#4752C4}
.discord-generate-btn{display:inline-flex;align-items:center;margin-top:8px;background:#5865F2;color:#fff;border:none;font-weight:600;padding:10px 20px;border-radius:8px;font-size:13px;transition:background .15s,transform .1s;cursor:pointer}
.discord-generate-btn:hover{background:#4752C4;transform:translateY(-1px)}
.discord-generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.discord-connected-actions{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.discord-channel-input-row{display:flex;align-items:center;gap:10px;margin-top:8px}
.discord-channel-label{font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap;flex-shrink:0}
.discord-channel-input{flex:1;max-width:280px;font-family:monospace;font-size:13px}
.discord-channel-status{display:flex;align-items:center;font-size:12px;color:var(--text);margin-top:10px;line-height:1.5}
.discord-unlink-btn{font-size:12px;background:transparent;border:1px solid var(--danger);color:var(--danger);padding:4px 12px;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}
.discord-unlink-btn:hover{background:var(--danger);color:#fff}
.discord-link-code-card{padding:16px 18px;border:1px solid rgba(88,101,242,.4);border-radius:10px;background:linear-gradient(135deg,rgba(88,101,242,.08),rgba(88,101,242,.02));margin-bottom:8px}
.discord-link-code-label{font-size:13px;color:var(--text);margin-bottom:4px;font-weight:600}
.discord-link-code-expiry{font-weight:400;color:var(--muted);font-size:12px}
.discord-link-code-row{display:flex;align-items:center;gap:10px;margin:8px 0 12px}
.discord-link-code{font-family:monospace;font-size:24px;font-weight:700;color:#5865F2;letter-spacing:3px;user-select:all;line-height:1}
.discord-copy-btn{padding:4px 8px;font-size:14px;background:var(--panel);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s;line-height:1}
.discord-copy-btn:hover{background:var(--active)}
.discord-link-code-instructions{border-top:1px solid rgba(88,101,242,.2);padding-top:10px;margin-top:4px}
.discord-link-code-steps{display:flex;align-items:baseline;gap:8px;font-size:12px;color:var(--text);margin:6px 0;line-height:1.5}
.discord-link-code-steps code{background:var(--panel);padding:2px 6px;border-radius:4px;font-size:11px;border:1px solid var(--border)}
.discord-link-code-steps strong{color:#5865F2;font-family:monospace;letter-spacing:1px}
.discord-step-num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:rgba(88,101,242,.15);color:#5865F2;font-size:11px;font-weight:700;flex-shrink:0}
.discord-link-code-status{font-size:12px;color:var(--muted);margin-top:10px}

/* ── User Dropdown ────────────────────────────────────────── */
.user-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 4px;border-radius:20px;background:var(--panel-2);border:1px solid var(--border);color:var(--text);font-size:13px;cursor:pointer;position:relative;transition:background .15s,border-color .15s}
.user-btn:hover{background:var(--active);border-color:var(--accent)}
.user-avatar-sm{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;display:inline-grid;place-items:center;font-size:12px;font-weight:600;flex-shrink:0}
.user-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:#e04040;color:#fff;font-size:11px;font-weight:700;display:inline-grid;place-items:center;padding:0 5px;border:2px solid var(--panel);pointer-events:none;line-height:1}
.user-badge.hidden{display:none}
.user-chevron{opacity:.5;transition:transform .15s}
.user-btn[aria-expanded="true"] .user-chevron{transform:rotate(180deg)}
.user-btn-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#userDropdown{position:absolute;top:calc(100% + 6px);right:0;width:340px;max-height:480px;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.35);z-index:2000;display:flex;flex-direction:column;overflow:hidden}
#userDropdown.hidden{display:none}
.dropdown-header{padding:14px 16px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.dropdown-header .username{font-weight:600;font-size:14px;color:var(--text)}
.dropdown-header .role-badge{font-size:11px;padding:2px 6px;border-radius:4px;background:var(--accent);color:#fff}
.dropdown-header .role-badge.hidden{display:none}
.notif-section{flex:1;overflow-y:auto;max-height:280px;border-bottom:1px solid var(--border)}
.notif-section-header{padding:10px 16px 6px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:flex;justify-content:space-between;align-items:center}
.notif-item{padding:10px 16px;display:flex;align-items:flex-start;gap:10px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:var(--active)}
.notif-item.unread{background:rgba(110,168,254,.04)}
.notif-item.recording .notif-dot{background:#ef4444;animation:recording-pulse 1.5s ease-in-out infinite}
.notif-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}
.notif-item.unread .notif-dot{background:var(--accent)}
.notif-item:not(.unread) .notif-dot{background:transparent}
.notif-content{flex:1;min-width:0}
.notif-icon{font-size:14px;margin-bottom:2px}
.notif-title{font-size:13px;font-weight:500;color:var(--text);display:block;word-wrap:break-word;overflow-wrap:break-word}
.notif-body{font-size:12px;color:var(--muted);margin-top:2px;display:block;word-wrap:break-word;overflow-wrap:break-word}
.notif-time{font-size:11px;color:var(--muted);opacity:.7;margin-top:3px;display:block}
.notif-empty{padding:24px 16px;text-align:center;font-size:13px;color:var(--muted)}
.notif-action-btn{margin-left:auto;flex-shrink:0;font-size:11px;padding:2px 8px;border-radius:6px;background:var(--panel-2);border:1px solid var(--border);color:var(--text);cursor:pointer}
.notif-action-btn:hover{background:var(--active);border-color:var(--accent)}
.notif-actions{display:flex;gap:4px;align-items:center;margin-left:auto;flex-shrink:0}
.notif-mark-read,.notif-dismiss{background:none;border:1px solid transparent;border-radius:4px;font-size:13px;cursor:pointer;padding:2px 6px;color:var(--muted);transition:background .15s,color .15s,border-color .15s;line-height:1}
.notif-mark-read:hover{background:var(--active);border-color:var(--accent);color:var(--accent)}
.notif-dismiss:hover{background:rgba(224,64,64,.08);border-color:#e04040;color:#e04040}
.notif-progress{height:4px;border-radius:2px;background:var(--border);margin-top:6px;overflow:hidden}
.notif-progress-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .3s ease}
.notif-progress-indeterminate .notif-progress-fill{animation:notif-indeterminate 1.8s ease-in-out infinite;width:40% !important}
@keyframes notif-indeterminate{0%{transform:translateX(-100%)}50%{transform:translateX(150%)}100%{transform:translateX(-100%)}}
.notif-item.active-task{background:rgba(110,168,254,.06)}
.notif-error{color:#e04040 !important}
/* Global notification priority styles */
.notif-item.global-notif{border-left:3px solid var(--muted)}
.notif-item.global-notif.priority-info{border-left-color:var(--accent, #6ea8fe)}
.notif-item.global-notif.priority-warning{border-left-color:var(--color-warning, #ffa726)}
.notif-item.global-notif.priority-critical{border-left-color:#ef4444;background:rgba(239,68,68,.04)}
.notif-item.global-notif.unread.priority-critical{background:rgba(239,68,68,.08)}
.dropdown-actions{padding:6px 8px}
.dropdown-action{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--text);cursor:pointer;transition:background .1s}
.dropdown-action:hover{background:var(--active)}
.dropdown-action.danger{color:#e04040}
.dropdown-action.danger:hover{background:rgba(224,64,64,.08)}
.dropdown-divider{height:1px;background:var(--border);margin:0}

/* ── Masquerade Bar ───────────────────────────────────────── */
#masqueradeBar{display:none;background:linear-gradient(90deg,#b8860b,#d4a017);color:#000;font-size:13px;font-weight:600;align-items:center;gap:10px;border-radius:0;padding:10px 12px;cursor:pointer;transition:background .2s ease,color .2s ease}
#masqueradeBar.active{display:flex}
#masqueradeBar:hover{background:linear-gradient(90deg,#a01010,#c02020);color:#fff}
#masqueradeBar .masq-label{display:inline}
#masqueradeBar .masq-end{display:none;color:#fff}
#masqueradeBar:hover .masq-label{display:none}
#masqueradeBar:hover .masq-end{display:inline}
#masqueradeSelect{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 6px;font-size:12px}

/* ── Split Layout (Transcript + Summary) ──────────────────── */
.split-layout{display:grid;grid-template-columns:1fr;overflow:hidden;height:100%}
.split-layout > .scroll{overflow:auto;height:100%;position:relative}
#summaryView{display:none;scroll-behavior:auto}
.split-layout.summary-open #summaryView{display:flex;flex-direction:column;overflow:hidden}
/* Summary / Recap sub-tab bar */
.sv-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);flex-shrink:0;padding:0 16px;background:var(--panel)}
.sv-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:13px;padding:8px 14px;cursor:pointer;transition:all .15s;font-weight:500}
.sv-tab:hover{color:var(--text)}
.sv-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.sv-pane{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}
.sv-pane.hidden{display:none}
/* Summary full-screen: hide transcript, summary takes full width */
.split-layout.summary-open.summary-full #tsScroll{display:none}
.summary-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px;min-height:0;position:relative}
#chatSection{flex-shrink:0;border-top:1px solid var(--border);padding:12px 16px;max-height:45%;padding-bottom:calc(12px + env(safe-area-inset-bottom, 0px))}
#chatHistory{max-height:200px;overflow-y:auto}

/* ── Summary Toolbar ──────────────────────────────────────── */
.summary-toolbar{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;position:relative;z-index:3}
.summary-toolbar .toolbar-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.summary-toolbar .toolbar-row.end{justify-content:flex-end}
.summary-toolbar .select{font-size:13px;padding:4px 8px;height:30px;min-width:0;flex:1}
.summary-toolbar .refine-input{font-size:13px;padding:4px 8px;height:30px;flex:1;min-width:120px}
.summary-toolbar .sm-btn{font-size:12px;padding:4px 10px;height:30px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}
.token-estimate{font-size:11px;color:var(--muted);white-space:nowrap;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:var(--chip);border:1px solid var(--border)}
.token-estimate.warn{color:#f5a623;border-color:#f5a623}
.token-estimate.danger{color:#e74c3c;border-color:#e74c3c}
/* Button cost labels */
.btn.has-cost{display:inline-flex;flex-direction:column;align-items:center;line-height:1.2;padding:6px 16px}
.btn.has-cost .btn-text{font-weight:600}
.btn-cost-label{display:block;font-size:10px;opacity:.9;font-weight:400;margin-top:1px;letter-spacing:.2px}
.btn-cost-label.free{color:#4caf50}
.btn.ghost.has-cost{padding:4px 10px}
.chat-cost-hint{font-size:11px;color:var(--muted);margin-top:4px;text-align:right;min-height:16px}

/* ── Summary & Markdown Rendering ─────────────────────────── */
.summary{white-space:pre-wrap;line-height:1.6;overflow-wrap:anywhere;word-break:break-word;max-width:100%;position:relative}
.summary pre{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;margin:0;max-width:100%;overflow-x:auto}
.summary.md{white-space:normal}
.summary.md h1,.summary.md h2,.summary.md h3,.summary.md h4,.summary.md h5,.summary.md h6{margin:14px 0 8px;line-height:1.25}
.summary.md h1{font-size:22px;border-bottom:1px solid var(--border);padding-bottom:6px}
.summary.md h2{font-size:18px;margin-top:18px;border-bottom:1px solid var(--border);padding-bottom:4px}
.summary.md h3{font-size:16px}
.summary.md ul{margin:8px 0 12px 20px;padding:0}
.summary.md li{margin:6px 0}
.summary.md p{margin:8px 0}
.summary.md a{color:var(--accent)}
.summary.md code{background:#1b1e36;border:1px solid var(--border);padding:0 4px;border-radius:4px;font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:.95em}
.summary.md pre{background:#111426;border:1px solid var(--border);padding:10px;border-radius:10px;overflow:auto}
.summary.md pre code{border:none;background:transparent;padding:0}
.summary.md hr{border:0;border-top:1px solid var(--border);margin:14px 0}
.summary.md table.md-table{width:100%;border-collapse:collapse;margin:8px 0 14px;background:var(--panel-2);display:block;overflow-x:auto}
.summary.md table.md-table td{border:1px solid var(--border);padding:8px;vertical-align:top;font-family:inherit}
.summary.md table.md-table tr:nth-child(even){background:rgba(255,255,255,0.01)}
.summary.md table.md-table thead th{background:var(--panel);border-bottom:2px solid var(--border);padding:10px;text-align:left}
.summary.md table.md-table thead th:first-child{border-top-left-radius:6px}
.summary.md table.md-table thead th:last-child{border-top-right-radius:6px}
/* Standalone markdown tables */
.md-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:13px}
.md-table th,.md-table td{border:1px solid var(--border);padding:8px 12px;text-align:left}
.md-table th{background:var(--panel-2);font-weight:600;color:var(--text)}
.md-table tr:nth-child(even){background:rgba(255,255,255,0.02)}

/* ── Timestamp Links ──────────────────────────────────────── */
.timestamp-link{color:var(--accent);cursor:pointer;font-family:monospace;background:rgba(110,168,254,0.1);padding:2px 4px;border-radius:4px;text-decoration:none;transition:background .15s ease}
.timestamp-link:hover{background:rgba(110,168,254,0.2);text-decoration:none}

/* ── Chat Bubbles ─────────────────────────────────────────── */
.chat-row{display:flex;margin-bottom:12px}
.chat-row.user{justify-content:flex-end}
.chat-row.assistant{justify-content:flex-start}
.chat-bubble{max-width:80%;padding:10px 14px;border-radius:12px;position:relative;font-size:14px;line-height:1.5}
.chat-bubble.user{background:var(--accent);color:#fff;border-bottom-right-radius:2px}
.chat-bubble.assistant{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:2px}
.chat-bubble .chat-name{font-size:11px;font-weight:700;margin-bottom:4px;opacity:.7;text-transform:uppercase;letter-spacing:.5px}
.chat-bubble.user .chat-name{text-align:right;color:rgba(255,255,255,.9)}
.chat-bubble.assistant .chat-name{text-align:left;color:var(--accent)}
.chat-bubble .chat-content p{margin:0 0 8px}
.chat-bubble .chat-content p:last-child{margin:0}
.chat-bubble .chat-content pre{background:rgba(0,0,0,0.2);padding:8px;border-radius:6px;overflow-x:auto}
/* Streaming chat bubble — blinking cursor */
.chat-bubble.streaming .chat-content::after{content:'';display:inline-block;width:2px;height:1em;vertical-align:text-bottom;margin-left:2px;background:var(--accent);animation:chat-cursor-blink .6s steps(2) infinite}
@keyframes chat-cursor-blink{0%{opacity:1}50%{opacity:0}}

/* ── Admin Dashboard ──────────────────────────────────────── */
#adminDashboard{position:absolute;inset:0;background:var(--bg);z-index:100;overflow-y:auto;padding:24px 32px;display:none}
#adminDashboard.active{display:block}
.admin-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.admin-header h2{margin:0;font-size:20px;font-weight:700}
.admin-header .btn{font-size:13px}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.admin-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px 20px}
.admin-card h3{margin:0 0 12px;font-size:15px;font-weight:600;color:var(--accent)}
.admin-card .stat-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}
.admin-card .stat-key{color:var(--muted)}
.admin-card .stat-val{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--border);color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.admin-table td{padding:6px 10px;border-bottom:1px solid var(--border)}
.admin-table tr:hover td{background:rgba(255,255,255,.02)}
.admin-status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase}
.admin-status.done{background:#1a2e1a;color:#6ee7b7}
.admin-status.processing{background:#1a2042;color:#60a5fa}
.admin-status.queued{background:#2a2218;color:#f59e0b}
.admin-status.error{background:#2e1a1a;color:#f87171}
.admin-status.encoding{background:#1a2e2e;color:#29d398}
.admin-ban-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}
.admin-ban-row:last-child{border-bottom:none}
.admin-ban-ip{font-family:monospace;font-size:13px;color:var(--text);min-width:120px}
.admin-ban-reason{font-size:11px;color:var(--muted);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.admin-ban-until{font-size:12px;color:var(--muted);white-space:nowrap}
.btn-danger{background:#7f1d1d;color:#fca5a5;border-color:#991b1b}
.btn-danger:hover{background:#991b1b}
.admin-card .quick-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
/* ── Admin Tabs ──────────────────────────────────────── */
.admin-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid var(--border)}
.admin-tab{background:none;border:none;padding:10px 20px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.admin-tab:hover{color:var(--text)}
.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.admin-tab-pane{display:none}
.admin-tab-pane.active{display:block}

/* ── Admin Live Sessions ───────────────────────────────── */
.live-stat{display:flex;flex-direction:column;align-items:center;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;padding:8px 14px;min-width:80px}
.live-stat-val{font-size:16px;font-weight:700;color:var(--fg);font-variant-numeric:tabular-nums}
.live-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-top:2px}

/* ── Admin Announcements ───────────────────────────────── */
.ann-subtabs{display:flex;gap:2px;padding:4px 8px 0;background:rgba(0,0,0,.15);border-bottom:1px solid var(--border)}
.ann-subtab{background:none;border:none;color:var(--muted);font-size:12px;padding:6px 12px;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.ann-subtab:hover{color:var(--fg)}
.ann-subtab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}
.ann-time{font-size:11px;color:var(--muted);min-width:56px;text-align:right;flex-shrink:0}
.ann-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px solid var(--border);font-size:13px;cursor:pointer;transition:background .15s}
.ann-row:hover{background:rgba(255,255,255,.04)}
.ann-row.playing{background:rgba(110,231,183,.08);border-left:3px solid var(--accent)}
.ann-row .ann-voice{color:var(--muted);font-size:11px;min-width:90px;flex-shrink:0}
.ann-row .ann-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ann-row .ann-rating{font-size:12px;color:#fbbf24;min-width:48px;text-align:center}
.ann-row .ann-weight{font-size:11px;color:var(--muted);min-width:36px;text-align:center}
.ann-row.inactive{opacity:.4}
.ann-inline-stars{display:inline-flex;gap:1px;min-width:72px;justify-content:center;flex-shrink:0}
.ann-istar{font-size:14px;color:#444;cursor:pointer;transition:color .12s,transform .12s;user-select:none;line-height:1}
.ann-istar.filled{color:#fbbf24}
.ann-istar.hover{color:#fde68a;transform:scale(1.25)}
.ann-istar:hover{color:#fde68a;transform:scale(1.25)}
.ann-star{font-size:18px;color:#555;transition:color .1s;user-select:none}
.ann-star.filled{color:#fbbf24}
.ann-star:hover{color:#fde68a}
.ann-msg-header{font-weight:600;font-size:13px;padding:10px 10px 4px;color:var(--accent);border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}

/* ── Bug Reports ──────────────────────────────────────────── */
.bug-priority-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}
.bug-priority-dot.priority-low{background:#4ade80}
.bug-priority-dot.priority-medium{background:#facc15}
.bug-priority-dot.priority-high{background:#ef4444}
.admin-bug-title{font-weight:600;font-size:13px}
.admin-bug-desc{font-size:11px;color:var(--muted);max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.admin-status.open{color:#bcd0ff}
.admin-status.in_progress{color:#facc15}
.admin-status.resolved{color:#4ade80}
.admin-status.closed{color:var(--muted)}
.bug-manage-section{margin-bottom:12px}
.bug-manage-section h4{font-size:12px;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.bug-manage-field{font-size:13px;line-height:1.5;color:var(--text);white-space:pre-wrap}
.bug-manage-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:13px}
.bug-manage-meta .label{color:var(--muted)}
.admin-pagination{display:flex;gap:6px;justify-content:center;align-items:center}
.admin-pagination .btn{min-width:32px}

/* ── Admin Dashboard Mobile ───────────────────────────────── */
@media (max-width:900px){
  #adminDashboard{padding:12px 10px}
  .admin-header{flex-wrap:wrap;gap:8px}
  .admin-header h2{font-size:17px;width:100%}
  .admin-header .btn{font-size:12px;padding:6px 10px}
  /* Scrollable tab bar with fade hint */
  .admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:0;position:relative;mask-image:linear-gradient(to right,#000 calc(100% - 40px),transparent);-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 40px),transparent)}
  .admin-tabs.scrolled-end{mask-image:linear-gradient(to left,#000 calc(100% - 40px),transparent);-webkit-mask-image:linear-gradient(to left,#000 calc(100% - 40px),transparent)}
  .admin-tabs.scrolled-mid{mask-image:linear-gradient(to right,transparent,#000 40px,#000 calc(100% - 40px),transparent);-webkit-mask-image:linear-gradient(to right,transparent,#000 40px,#000 calc(100% - 40px),transparent)}
  .admin-tabs.scrolled-none{mask-image:none;-webkit-mask-image:none}
  .admin-tabs::-webkit-scrollbar{display:none}
  .admin-tab{white-space:nowrap;padding:8px 12px;font-size:12px;flex-shrink:0}
  /* Cards & grids */
  .admin-grid{grid-template-columns:1fr;gap:12px}
  .admin-card{padding:12px 14px}
  /* Tables — ensure horizontal scroll */
  .admin-table{font-size:12px}
  .admin-table th{padding:6px 8px;font-size:10px}
  .admin-table td{padding:5px 8px}
  /* Ban rows */
  .admin-ban-row{flex-wrap:wrap;gap:4px}
  .admin-ban-ip{min-width:0;font-size:12px}
  .admin-ban-reason{max-width:none}
  /* Bot config grid */
  #botConfigBody > div:first-child{grid-template-columns:1fr !important;max-width:none !important}
  /* Bot config timeout grid */
  #botConfigBody div[style*="grid-template-columns"]{grid-template-columns:1fr !important;max-width:none !important}
  /* Announcement controls */
  #annControlsRow{gap:6px}
  #annControlsRow label{font-size:11px}
  #annControlsRow .select{max-width:120px;font-size:11px}
  .ann-row .ann-voice{min-width:60px;font-size:10px}
  .ann-row .ann-label{font-size:12px}
  .ann-subtabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}
  .ann-subtabs::-webkit-scrollbar{display:none}
  .ann-subtab{flex-shrink:0;white-space:nowrap}
  /* Bug report stats */
  .admin-bug-stats{flex-wrap:wrap}
  .admin-bug-stats .admin-card{flex:1 1 calc(50% - 6px);min-width:0}
  .admin-bug-desc{max-width:180px}
  .bug-manage-meta{grid-template-columns:1fr}
  /* Financial config */
  #adminFinancialConfig{grid-template-columns:1fr !important}
  /* Financial overview — 2-col on tablet */
  #adminFinOverview{grid-template-columns:1fr 1fr !important}
  /* Users table — hide Discord + Staff columns */
  #adminUsersTable th:nth-child(3),
  #adminUsersTable td:nth-child(3),
  #adminUsersTable th:nth-child(4),
  #adminUsersTable td:nth-child(4){display:none}
  /* Live session stats */
  .live-stat{min-width:60px;padding:6px 10px}
  .live-stat-val{font-size:14px}
  .live-stat-label{font-size:9px}
  /* LLM charts — stack vertically */
  #adminTabLLM div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important}
  /* LLM metrics — fit 2 per row */
  #llmMetricsCards{grid-template-columns:1fr 1fr !important;gap:8px}
  #llmMetricsCards .card{padding:10px 12px}
  #llmMetricsCards .card div[style*="font-size:22px"]{font-size:18px !important}
  /* LLM sub-tabs — scrollable */
  .llm-subtabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap}
  .llm-subtabs::-webkit-scrollbar{display:none}
  .llm-subtab{flex-shrink:0;white-space:nowrap}
  /* LLM date range filter — wrap */
  #llmUsage > div:first-child{flex-wrap:wrap}
  /* LLM log filters — wrap nicely */
  #adminTabLLM div[style*="display:flex"][style*="margin-bottom:12px"]{flex-wrap:wrap}
  /* LLM model stats — wrap */
  #llmModels > div:first-child{flex-wrap:wrap;gap:8px}
  /* LLM Request Log — hide Cache R/W + Markup columns on tablet */
  #llmLogBody{font-size:11px}
  /* Email reports — full width */
  #adminTabEmailReports fieldset{padding:10px 12px}
  #adminTabEmailReports .admin-card > div[style*="max-width"]{max-width:none !important}
  /* Global notifications — full width */
  #adminTabGlobalNotifs .admin-card > div[style*="max-width"]{max-width:none !important}
}

@media (max-width:600px){
  #adminDashboard{padding:8px 6px}
  .admin-header h2{font-size:15px}
  .admin-header .btn{font-size:11px;padding:5px 8px}
  /* Shorten "Database Admin" text via clipping */
  .admin-header a[href="/db-auth"]{font-size:10px;padding:4px 6px}
  .admin-tab{padding:7px 10px;font-size:11px}
  .admin-card{padding:10px 10px}
  /* Announcements — stack controls */
  #annControlsRow{flex-direction:column;align-items:stretch}
  #annControlsRow label{width:100%}
  #annControlsRow .select{max-width:none;width:100%}
  #annControlsRow .btn{width:100%;justify-content:center}
  .ann-row{gap:6px;padding:6px 8px}
  .ann-row .ann-voice{display:none}
  .ann-inline-stars{min-width:60px}
  /* Bug stats — stack fully */
  .admin-bug-stats .admin-card{flex:1 1 100%}
  /* Financial overview — 2 col */
  #adminFinOverview{grid-template-columns:1fr 1fr !important}
  /* LLM metrics — stack to 2-col with smaller text */
  #llmMetricsCards{grid-template-columns:1fr 1fr !important;gap:6px}
  #llmMetricsCards .card{padding:8px 10px}
  #llmMetricsCards .card div[style*="font-size:22px"]{font-size:16px !important}
  #llmMetricsCards .card div[style*="font-size:11px"]{font-size:10px !important}
  /* LLM model stats cards — smaller on mobile */
  #llmModels > div:first-child .card{padding:8px 12px}
  #llmModels > div:first-child .card span[style*="font-size:18px"]{font-size:15px !important}
  /* LLM log filter bar — stack */
  #adminTabLLM div[style*="display:flex"][style*="align-items:center"][style*="gap:10px"]{flex-direction:column;align-items:stretch}
  #adminTabLLM div[style*="display:flex"][style*="align-items:center"][style*="gap:10px"] .input{width:100%;max-width:none}
  /* Users table — also hide Key column */
  #adminUsersTable th:nth-child(5),
  #adminUsersTable td:nth-child(5){display:none}
  /* Bug filters — wrap */
  .admin-bug-filters{gap:6px}
  .admin-bug-filters .select{width:100% !important;max-width:none}
  /* Live session cards — tighter spacing */
  .live-stat{min-width:50px;padding:5px 8px}
  .live-stat-val{font-size:13px}
  /* Email reports fieldsets */
  #adminTabEmailReports fieldset{padding:8px 10px}
  #adminTabEmailReports legend{font-size:12px}
  /* Visitor details summaries */
  details > summary{font-size:13px}
}

@media (max-width:420px){
  .admin-tab{padding:6px 8px;font-size:10px}
  /* Financial overview — full stack */
  #adminFinOverview{grid-template-columns:1fr !important}
  /* LLM metrics — single column */
  #llmMetricsCards{grid-template-columns:1fr !important}
  /* Users table — hide even more columns (Joined, Last Login) */
  #adminUsersTable th:nth-child(6),
  #adminUsersTable td:nth-child(6),
  #adminUsersTable th:nth-child(7),
  #adminUsersTable td:nth-child(7){display:none}
  /* Bug reports — hide Reporter + Submitted columns */
  #adminBugsTable th:nth-child(3),
  #adminBugsTable td:nth-child(3),
  #adminBugsTable th:nth-child(6),
  #adminBugsTable td:nth-child(6){display:none}
  /* Admin header — hide DB admin link, keep Back + Refresh */
  .admin-header a[href="/db-auth"]{display:none}
  /* Announcement player — tighter */
  #adminAnnPlayer{padding:8px 10px}
  #adminAnnPlayer audio{height:28px}
}

/* ── Utilities ────────────────────────────────────────────── */
.muted{color:var(--muted)}
.hidden{display:none !important}
#btnLogout{display:inline-grid;place-items:center;border-radius:10px}
#btnLogout svg{display:block}
.meta-spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.12);border-top-color:var(--accent);animation:spin 1s linear infinite;display:inline-block;vertical-align:middle;margin-left:8px}
.btn-spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.12);border-top-color:var(--accent);animation:spin 1s linear infinite;display:inline-block;vertical-align:middle;margin-right:8px}
.summary-body-wrap{min-height:0}
.summary-spinner-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:14px;background:rgba(var(--bg-rgb,14,14,18),.85);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:10px;z-index:2;transition:opacity .4s ease}
.summary-spinner-overlay.fade-out{opacity:0;pointer-events:none}
.summary-spinner-inner{display:flex;flex-direction:column;align-items:center;gap:12px}
.summary-spinner-ring{width:28px;height:28px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:spin .8s linear infinite}
.summary-spinner-label{font-size:13px;color:var(--muted);letter-spacing:.02em}
/* Typewriter reveal animation for summary content */
.typewriter-revealing{position:relative}
.typewriter-revealing::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--accent,#e67e22);opacity:.6;animation:typewriter-cursor-pulse .5s ease-in-out infinite}
@keyframes typewriter-cursor-pulse{0%,100%{opacity:.6}50%{opacity:.2}}
.summary-error-banner{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(255,60,60,.08);border:1px solid rgba(255,60,60,.2);border-radius:8px;margin-bottom:12px;font-size:13px;color:#ff7b7b}
.summary-error-icon{font-size:16px;flex-shrink:0}
.summary-error-text{flex:1;line-height:1.4}
.mix-badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#20243b;color:var(--muted);font-size:12px;margin-left:8px}
.mix-badge.mixed{background:#2a2a34;color:#bcd0ff}
.mix-badge.per{background:#22332a;color:#9ef0c4}
.diag-panel{position:fixed;right:16px;bottom:16px;width:360px;max-height:50vh;overflow:auto;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:10px;box-shadow:0 20px 60px rgba(0,0,0,.6);z-index:20000}
.diag-panel.hidden{display:none}
.diag-panel pre{margin:0;font-size:12px;color:var(--muted);white-space:pre-wrap}
/* Message color utilities (replaces inline .style.color assignments) */
.msg-danger{color:var(--danger) !important}
.msg-success{color:var(--ok) !important}
.msg-muted{color:var(--muted) !important}
.msg-accent{color:var(--accent) !important}
.msg-warning{color:#ffaa00 !important}
/* Discord linked state layout */
#discordLinked{display:flex;align-items:center;gap:12px;padding:8px 0}
/* Layout utilities */
.ml-auto{margin-left:auto}
.input-full{width:100%;box-sizing:border-box}
.flex-fill{flex:1;min-width:0}
/* Form label utilities */
.form-label-sm{font-size:11px;color:var(--muted);display:block;margin-bottom:2px}
.text-muted-sm{color:var(--muted);font-size:11px}
/* Button size variant */
.btn-sm{font-size:11px !important;padding:2px 8px !important}
.admin-viewas-btn{white-space:nowrap;cursor:pointer}
/* DDB avatar fallback */
.ddb-avatar-fallback{display:flex;align-items:center;justify-content:center;font-size:14px;background:var(--panel-2);color:var(--muted);width:100%;height:100%;border-radius:50%}
/* Disable look (opacity + no interaction) */
.disabled-look{opacity:0.5;pointer-events:none}
/* Empty state centered */
.empty-state{padding:32px;text-align:center;color:var(--muted)}
.empty-state-sm{padding:12px;text-align:center;color:var(--muted)}
/* Summary editor */
.summary-editor-textarea{width:100%;min-height:400px;font-family:monospace;line-height:1.4;padding:10px;resize:vertical}
.summary-editor-toolbar{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}
/* Shortcut table */
.shortcut-table{width:100%;border-collapse:collapse;text-align:left}
.shortcut-table td{padding:4px 0}
.shortcut-table td:first-child{padding-right:12px}
.shortcut-table kbd{background:var(--panel-2);padding:2px 8px;border-radius:4px;font-size:.95em}
.shortcut-table .shortcut-desc{color:var(--muted)}
/* Speaker filter label */
.speaker-filter-header{display:flex;align-items:center;gap:6px;padding:4px 6px;font-weight:600;border-bottom:1px solid var(--border);margin-bottom:4px}
.speaker-filter-item{display:flex;align-items:center;gap:6px;padding:4px 6px;cursor:pointer}
/* Speaker map modal */
.map-modal-instructions{font-size:13px;color:var(--muted);margin-bottom:6px}
.map-modal-list{max-height:200px;overflow-y:auto;margin-bottom:12px}
.map-modal-create{border:1px solid var(--border);border-radius:8px;padding:8px 12px}
.map-modal-create .create-toggle{cursor:pointer;color:var(--accent);font-size:13px}
.map-modal-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.map-modal-actions{display:flex;justify-content:flex-end;margin-top:8px}
/* Add member form */
.add-member-form{border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px}
.add-member-form .form-hint{font-size:13px;color:var(--muted);margin-bottom:8px}
.add-member-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.add-member-form .form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
/* Wiki editor */
.wiki-editor-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.wiki-editor-title{margin:0;font-size:18px}
.wiki-editor-actions{display:flex;gap:8px;margin-top:16px}
/* Wiki history */
.wiki-history-list{max-height:400px;overflow-y:auto}
.wiki-history-item{padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px}
.wiki-history-row{display:flex;justify-content:space-between;align-items:center}
.wiki-history-summary{margin-top:4px;font-style:italic;color:var(--muted);font-size:12px}
/* Wiki extraction modal */
.wiki-extract-modal{max-height:60vh;display:flex;flex-direction:column;gap:12px}
.wiki-extract-model{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.wiki-extract-model label{font-size:13px;font-weight:600;white-space:nowrap}
.wiki-extract-model .select{flex:1;min-width:0}
.wiki-extract-sessions{overflow-y:auto;max-height:50vh;display:flex;flex-direction:column;gap:2px}
.wiki-extract-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:8px;background:var(--panel)}
.wiki-extract-row.disabled{opacity:.5}
.wiki-extract-info{display:flex;flex-wrap:wrap;align-items:center;gap:6px;flex:1;min-width:0}
.wiki-extract-title{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}
.wiki-extract-date{font-size:11px;color:var(--muted)}
.wiki-extract-action{flex-shrink:0}
.wiki-extract-row .pill.sm{font-size:11px;padding:2px 8px}
.wiki-extract-row .pill.sm.success{background:rgba(34,197,94,.12);color:#4ade80;border-color:rgba(34,197,94,.2)}
.wiki-extract-row .pill.sm.ready{background:rgba(96,165,250,.12);color:#60a5fa;border-color:rgba(96,165,250,.2)}
.wiki-extract-row .pill.sm.muted{color:var(--muted)}
/* Avatar circle */
.avatar-circle{width:36px;height:36px;border-radius:50%;object-fit:cover}
/* DDB section header */
.ddb-section-top{display:flex;align-items:center;justify-content:space-between;padding:0 4px;margin-top:8px}
/* Silence gap label/line */
.silence-gap-label{color:var(--muted);font-size:11px;text-align:right}
.silence-gap-line{border-top:1px dashed var(--border);align-self:center;opacity:0.5}
/* SVG icon alignment */
.icon-inline{vertical-align:-2px;margin-right:3px}
/* Checkbox margin */
.checkbox-mr{margin-right:6px}
/* Pill flex wrap */
.pill-flex-wrap{display:flex;flex-wrap:wrap;gap:6px}

/* ── Device Badges ────────────────────────────────────────── */
.device-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;cursor:default;position:relative;text-transform:uppercase;letter-spacing:.5px}
.device-badge.gpu{background:#1a2942;color:#60a5fa;border:1px solid #2d4a73}
.device-badge.cpu{background:#2a2218;color:#f59e0b;border:1px solid #5c4a1e}
.device-badge .device-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.device-badge.gpu .device-dot{background:#3b82f6;box-shadow:0 0 4px rgba(59,130,246,.5)}
.device-badge.cpu .device-dot{background:#f59e0b;box-shadow:0 0 4px rgba(245,158,11,.4)}
.device-tooltip{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:#1e2030;border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:11px;white-space:nowrap;z-index:50;color:var(--text);box-shadow:0 4px 12px rgba(0,0,0,.4);pointer-events:none}
.device-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--border)}
.device-badge:hover .device-tooltip{display:block}
.device-tooltip .dt-row{display:flex;justify-content:space-between;gap:12px;line-height:1.6}
.device-tooltip .dt-key{color:var(--muted)}
.device-tooltip .dt-val{color:var(--text);font-weight:500}

/* ── Checkbox Dropdown ────────────────────────────────────── */
.checkbox-dropdown{position:relative;display:inline-block}
.checkbox-dropdown .dd-button{cursor:pointer;padding:6px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);display:inline-flex;align-items:center;gap:8px}
.checkbox-dropdown .dd-panel{position:absolute;top:calc(100% + 8px);left:0;min-width:280px;max-width:420px;max-height:280px;overflow:auto;background:var(--panel-2);border:1px solid var(--border);padding:8px;border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.6);z-index:150}
.checkbox-dropdown .dd-panel.hidden{display:none}

/* ── Skip Silence Control ─────────────────────────────────── */
.skip-ctl{display:inline-flex!important;align-items:center;gap:4px;padding:3px 8px!important;font-size:12px;cursor:pointer;user-select:none}
.skip-ctl input[type=checkbox]{margin:0;width:13px;height:13px;cursor:pointer}
.skip-label{white-space:nowrap}
.skip-dd-zone{display:inline-flex;align-items:center;gap:3px;cursor:pointer;pointer-events:none;opacity:0;max-width:0;overflow:hidden;transition:opacity .2s,max-width .2s}
.skip-dd-zone.active{pointer-events:auto;opacity:1;max-width:80px}
.skip-sep{color:var(--border);font-size:12px;font-weight:300;line-height:1;user-select:none}
.skip-thresh{font-size:10px;color:var(--accent);font-variant-numeric:tabular-nums;white-space:nowrap}
.skip-panel{position:absolute;top:calc(100% + 6px);right:0;z-index:200;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;box-shadow:0 6px 20px rgba(0,0,0,.4);white-space:nowrap}
#secondaryControls .skip-panel{right:auto;left:50%;transform:translateX(-50%)}
.skip-panel.hidden{display:none}
.skip-panel-row{display:flex;align-items:center;gap:8px;font-size:12px}
.skip-panel-label{color:var(--muted);flex-shrink:0}
.skip-panel-row input[type=range]{width:100px;accent-color:var(--accent-2);cursor:pointer}
.skip-panel-val{min-width:28px;text-align:right;font-variant-numeric:tabular-nums;color:var(--text)}
.skip-panel-check{margin-top:4px;cursor:pointer;gap:6px}
.skip-panel-check input[type=checkbox]{accent-color:var(--accent-2);cursor:pointer}

/* ── Rate slider pill ───────────────────────────────────────── */
.rate-pill{cursor:pointer}
.rate-val{font-size:10px;color:var(--accent);font-variant-numeric:tabular-nums;white-space:nowrap;margin-left:2px}
.rate-presets{display:flex;gap:4px;margin-top:6px;justify-content:center}
.rate-preset{background:var(--chip);border:1px solid var(--border);color:var(--muted);font-size:10px;padding:2px 8px;border-radius:999px;cursor:pointer;transition:all .15s;font-variant-numeric:tabular-nums}
.rate-preset:hover{border-color:rgba(110,168,254,.5);color:var(--text)}
.rate-preset.active{background:rgba(110,168,254,.15);border-color:var(--accent);color:var(--accent)}
#secondaryControls .rate-dropdown .skip-panel{right:auto;left:50%;transform:translateX(-50%)}

/* ── Dev Banner ───────────────────────────────────────────── */
.dev-banner{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:linear-gradient(90deg,rgba(155,110,255,.15),rgba(110,168,254,.15));border-bottom:1px solid rgba(155,110,255,.3);color:var(--muted);font-size:.82rem;letter-spacing:.02em;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.dev-banner svg{flex-shrink:0;color:#e8a642;opacity:.9}
.dev-banner.beta-banner{background:linear-gradient(90deg,rgba(110,168,254,.18),rgba(155,110,255,.18));border-bottom-color:rgba(110,168,254,.4)}
.dev-banner.beta-banner svg{color:#9b6eff}
.beta-slot-notice{margin-bottom:12px;padding:8px 12px;border-radius:8px;font-size:.85rem;background:rgba(110,168,254,.12);border:1px solid rgba(110,168,254,.3);color:var(--muted);text-align:center}

/* ── Landing Page ─────────────────────────────────────────── */
.landing{height:100vh;min-height:100vh;display:grid;place-items:center;padding:40px 16px;padding-top:56px;position:relative;overflow:hidden}
.landing::before{content:"";position:absolute;inset:-20% -10% 0 -10%;background:
  radial-gradient(1200px 600px at 85% -200px, rgba(110,168,254,.18), transparent 60%),
  radial-gradient(900px 500px at 10% -150px, rgba(155,110,255,.16), transparent 60%),
  var(--bg);
  filter:blur(0.2px); z-index:0}
.landing-hero{position:relative;z-index:1;max-width:980px;text-align:center;background:linear-gradient(180deg, rgba(23,26,43,.85), rgba(23,26,43,.65));border:1px solid var(--border);border-radius:16px;padding:0;box-shadow:0 20px 80px rgba(0,0,0,.45);display:flex;flex-direction:column}
.morph-brand{padding:20px 20px 0;line-height:0;text-align:center;flex-shrink:0;position:relative;z-index:2}
.landing .landing-logo{height:48px;width:auto;filter:drop-shadow(0 0 12px rgba(110,168,254,.35))}
.morph-panels{position:relative;flex:1;min-height:0}
.landing h1{margin:6px 0 6px;font-size:1.35rem;line-height:1.3;font-weight:700;background:linear-gradient(135deg,#e6e8f3 40%,#9b6eff 80%,#6ea8fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.landing .hero-sub{color:var(--muted);margin:0 0 18px;font-size:.95rem}
.hero-highlights{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px;text-align:left;max-width:620px;margin:0 auto 18px}
.hero-hl{display:flex;align-items:center;gap:10px;font-size:.86rem;color:var(--text);line-height:1.4}
.hero-hl svg{flex-shrink:0;opacity:.85}
.hero-hl span{color:var(--muted)}
.hero-hl-defs{position:absolute;width:0;height:0;overflow:hidden}
.landing .cta-row{display:flex;gap:10px;justify-content:center;margin-top:6px}
/* Landing morph panels */
.landing-morph .morph-card{position:relative;overflow:hidden;padding:0;transition:height .24s ease;max-height:88vh}
.landing-morph.mode-about .morph-card{overflow:auto}
.landing-morph .morph-card .panel{padding:14px 20px 24px}
.landing-morph .panel.hero{opacity:1;transform:translateY(0);transition:transform .24s ease, opacity .24s ease;}
.landing-morph .panel.auth{position:absolute;inset:0 0 0 0;opacity:0;transform:translateY(12px) scale(.98);pointer-events:none;transition:transform .24s ease, opacity .24s ease;}
.landing-morph.mode-login .panel.hero{opacity:0;transform:translateY(-12px) scale(.98)}
.landing-morph.mode-signup .panel.hero{opacity:0;transform:translateY(-12px) scale(.98)}
.landing-morph.mode-login #panelLogin{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.landing-morph.mode-signup #panelSignup{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.landing-morph.mode-verify #panelVerify{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.landing-morph.mode-about .panel.hero{opacity:0;transform:translateY(-12px) scale(.98)}
.landing-morph.mode-about #panelAbout{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.landing-morph.mode-verify .panel.hero{opacity:0;transform:translateY(-12px) scale(.98)}
.landing-morph.mode-forgot .panel.hero{opacity:0;transform:translateY(-12px) scale(.98)}
.landing-morph.mode-forgot #panelForgot{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.landing-morph.mode-reset .panel.hero{opacity:0;transform:translateY(-12px) scale(.98)}
.landing-morph.mode-reset #panelReset{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.landing-morph .panel.auth h3{text-align:left}
.landing-morph .panel.auth form{text-align:left;max-width:560px;margin:0 auto}
.landing-morph .panel.auth .rowline{display:flex;gap:8px;margin:8px 0;align-items:center}
.landing-morph .panel.auth .rowline .input{flex:1;min-width:260px}
.landing-morph .panel.auth .row{gap:8px}
.turnstile-row{position:absolute;overflow:hidden;width:0;height:0;pointer-events:none}
.landing-morph #panelLogin{min-height:260px}
.landing-morph #panelSignup{min-height:300px}
.landing-morph #panelVerify{min-height:220px}
/* About / How it works panel */
.about-heading{text-align:center;font-size:1.2rem;margin:0 0 6px;background:linear-gradient(135deg,#e6e8f3 40%,#9b6eff 80%,#6ea8fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.about-lead{text-align:center;color:var(--muted);font-size:.88rem;margin:0 0 20px;line-height:1.5}
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.about-card{background:rgba(15,18,32,.55);border:1px solid var(--border);border-radius:12px;padding:18px 16px 16px;text-align:center}
.about-card-icon{margin-bottom:10px;line-height:0}
.about-card h4{font-size:.9rem;margin:0 0 8px;color:var(--text);font-weight:600}
.about-card p{font-size:.82rem;color:var(--muted);line-height:1.55;margin:0}
.about-section{margin-bottom:18px;text-align:left}
.about-section h4{font-size:.92rem;margin:0 0 12px;color:var(--text);font-weight:600;text-align:center}
.about-steps{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;max-width:680px;margin:0 auto}
.about-step{display:flex;align-items:baseline;gap:10px;font-size:.83rem;color:var(--muted);line-height:1.5}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#9b6eff,#6ea8fe);color:#fff;font-size:.72rem;font-weight:700;flex-shrink:0;line-height:1}
.about-step code{background:rgba(155,110,255,.15);padding:1px 5px;border-radius:4px;font-size:.8rem;color:#b8a0ff}
.about-section-split{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.about-split-col{background:rgba(15,18,32,.55);border:1px solid var(--border);border-radius:12px;padding:16px}
.about-split-col h4{font-size:.88rem;margin:0 0 8px;color:var(--text);font-weight:600;text-align:left}
.about-split-col p{font-size:.82rem;color:var(--muted);line-height:1.55;margin:0}
.about-defs{position:absolute;width:0;height:0;overflow:hidden}
.about-back-row{display:flex;justify-content:flex-end;margin-top:14px;gap:8px}
/* Landing features section */
.landing-features{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:64px 24px 48px;text-align:center}
.features-logo-row{margin-bottom:20px}
.features-logo{height:56px;width:auto;filter:drop-shadow(0 0 18px rgba(110,168,254,.3))}
.features-defs{position:absolute;width:0;height:0;overflow:hidden}
.landing-features-heading{font-size:1.45rem;font-weight:700;color:var(--text);margin:0 0 10px;line-height:1.35;background:linear-gradient(135deg,#e6e8f3 30%,#9b6eff 70%,#6ea8fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.landing-features-sub{font-size:.9rem;color:var(--muted);margin:0 0 36px;line-height:1.55;max-width:640px;margin-left:auto;margin-right:auto}
.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;text-align:left}
.feature-card{background:linear-gradient(180deg,rgba(23,26,43,.75),rgba(23,26,43,.45));border:1px solid var(--border);border-radius:14px;padding:22px 22px 20px;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease;position:relative;overflow:hidden}
.feature-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#9b6eff,#6ea8fe);opacity:0;transition:opacity .2s ease}
.feature-card:hover{border-color:rgba(110,168,254,.4);transform:translateY(-2px);box-shadow:0 6px 28px rgba(0,0,0,.35)}
.feature-card:hover::before{opacity:1}
.feature-card .feature-icon{margin-bottom:10px;line-height:0}
.feature-card .feature-icon svg{display:inline-block}
.feature-card h3{font-size:.95rem;margin:0 0 8px;color:var(--text);font-weight:600}
.feature-card p{font-size:.85rem;line-height:1.6;color:var(--muted);margin:0}
.feature-card .feature-cta{margin-top:10px;font-size:.82rem;display:inline-block}
/* Landing footer */
.landing-footer{position:relative;z-index:1;max-width:700px;margin:0 auto;padding:32px 24px 40px;text-align:center;color:var(--muted);font-size:.82rem;line-height:1.6}
.landing-footer p{margin:0 0 6px}
.landing-footer-sub{opacity:.5;font-size:.75rem}

/* ── Model Cost Tier Colors ───────────────────────────────── */
option.model-free{color:#4caf50}
option.model-cheap{color:#e8b630}
option.model-expensive{color:#d4830b}
option.model-unavailable{color:#888;text-decoration:line-through}
select.model-tier-free{color:#4caf50}
select.model-tier-cheap{color:#e8b630}
select.model-tier-expensive{color:#d4830b}

/* ── Custom Model Dropdown ────────────────────────────────── */
.model-dropdown{position:relative;width:100%;min-width:0}
.model-dropdown-trigger{display:flex;align-items:center;gap:6px;width:100%;padding:6px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;font-size:13px;min-height:30px;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;text-align:left}
.model-dropdown-trigger:hover{border-color:rgba(110,168,254,.5);box-shadow:0 0 12px rgba(110,168,254,.15)}
.model-dropdown-trigger.mdt-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}
.model-dropdown-trigger.mdt-disabled:hover{border-color:var(--border);box-shadow:none}
.model-dropdown-trigger .mdt-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.model-dropdown-trigger .mdt-chevron{flex-shrink:0;font-size:10px;color:var(--muted);transition:transform .15s}
.model-dropdown.open .mdt-chevron{transform:rotate(180deg)}
.model-dropdown-trigger.tier-free .mdt-label{color:#4caf50}
.model-dropdown-trigger.tier-cheap .mdt-label{color:#e8b630}
.model-dropdown-trigger.tier-expensive .mdt-label{color:#d4830b}
.model-dropdown-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:320px;overflow-y:auto;background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:1100;display:none;overscroll-behavior:contain}
.model-dropdown.open .model-dropdown-panel{display:block}
.model-dropdown-option{display:flex;flex-direction:column;gap:2px;padding:10px 12px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border)}
.model-dropdown-option:last-child{border-bottom:none}
.model-dropdown-option:hover{background:var(--active-bg)}
.model-dropdown-option.selected{background:rgba(110,168,254,.1)}
.model-dropdown-option .mdo-name{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.model-dropdown-option .mdo-name .mdo-lock{font-size:11px}
.model-dropdown-option .mdo-meta{font-size:11px;color:var(--muted);display:flex;flex-wrap:wrap;gap:4px 10px}
.model-dropdown-option .mdo-cost{font-weight:600}
.model-dropdown-option .mdo-cost.cost-free{color:#4caf50}
.model-dropdown-option .mdo-cost.cost-cheap{color:#e8b630}
.model-dropdown-option .mdo-cost.cost-expensive{color:#d4830b}
.model-dropdown-option .mdo-ctx{color:var(--muted)}
.model-dropdown-option.unavailable{opacity:.55}
.model-dropdown-option.unavailable .mdo-name{text-decoration:line-through}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */

/* Defaults (before mobile overrides) */
.only-mobile{display:none !important}
#secondaryControls{display:none}
#sidebarBackdrop{display:none}

/* ── Desktop: Summary side-by-side ── */
@media (min-width:901px){
  .split-layout.summary-open{grid-template-columns:1fr 450px}
  .split-layout.summary-open.summary-full{grid-template-columns:1fr}
  .split-layout.summary-open #summaryView{border-left:1px solid var(--border);background:var(--panel-2)}
  .split-layout.summary-open.summary-full #summaryView{border-left:none}
  /* Shift toasts left of the 450px summary panel */
  body:has(.split-layout.summary-open:not(.summary-full)) .toast-container{right:474px}
}

/* ── Mobile ≤900px ── */
@media (max-width:900px){
  .layout{grid-template-columns:1fr;grid-template-areas:"header" "main";max-width:100vw;overflow-x:hidden}
  .sidebar{position:fixed;top:0;left:0;bottom:0;width:min(92vw,400px);transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:0 0 40px rgba(0,0,0,.6);border-top:none;padding-top:var(--sidebar-top,60px);z-index:1001;overscroll-behavior:contain}
  body.mobile-menu-open .sidebar{transform:translateX(0)}
  #sidebarBackdrop{display:block;position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(2px);z-index:1000;opacity:0;pointer-events:none;transition:opacity 0.25s ease}
  body.mobile-menu-open #sidebarBackdrop{opacity:1;pointer-events:auto}
  header{position:sticky;top:0;z-index:1005;transition:transform .25s ease;padding:6px 10px;overflow-x:clip;max-width:100vw}
  body.header-collapsed header .mobile-feature-bar{max-height:50px}
  .only-desktop{display:none !important}
  .only-mobile{display:inline-flex !important}
  .toolbar{gap:4px;min-height:34px;min-width:0;max-width:100%;flex-wrap:wrap}
  .toolbar .group{gap:4px}
  /* Touch targets: 36px for interactive header elements (compact but tappable) */
  .toolbar .btn.icon{min-width:36px;min-height:36px}
  .toolbar .btn.icon.only-mobile{display:inline-grid !important;place-items:center;padding:0}
  .toolbar .group.transport .btn.round{min-width:36px;min-height:36px}
  .user-btn{min-width:36px;min-height:36px;padding:3px}
  .header-logo img{height:22px}
  #secondaryControls{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0 6px;border-top:1px solid var(--border);margin-top:4px}
  #secondaryControls.mobile-hidden-controls{display:none !important}
  #secondaryControls .control-group{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;width:100%}
  #secondaryControls label{display:flex;align-items:center;gap:6px}
  #secondaryControls .select{max-width:200px}
  #secondaryControls .checkbox-dropdown .dd-panel{left:auto;right:0;min-width:220px;max-width:85vw}
  #secondaryControls .dd-button{background:var(--chip);border-radius:999px;padding:3px 4px 3px 10px;font-size:12px;height:auto;color:var(--muted);gap:5px}
  #secondaryControls .dd-button .pill{padding:2px 7px;font-size:10px;border:none;background:rgba(110,168,254,.12);color:var(--accent)}
  /* Hide redundant search button in secondary controls — feature bar already has Search pill */
  #secondaryControls .btnToggleSearchMobile{display:none}
  .mobile-feature-bar{display:flex !important;gap:6px;padding:4px 10px;border-top:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;white-space:nowrap;flex-shrink:0;min-width:0;max-width:100%;max-height:42px;transition:max-height .25s ease,padding .25s ease,border-top-color .25s ease}
  .mobile-feature-bar::-webkit-scrollbar{display:none}
  .mobile-feature-bar.mfb-fade-right{-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 28px),transparent);mask-image:linear-gradient(to right,#000 calc(100% - 28px),transparent)}
  .mobile-feature-bar.mfb-fade-left{-webkit-mask-image:linear-gradient(to right,transparent,#000 28px);mask-image:linear-gradient(to right,transparent,#000 28px)}
  .mobile-feature-bar.mfb-fade-both{-webkit-mask-image:linear-gradient(to right,transparent,#000 28px,#000 calc(100% - 28px),transparent);mask-image:linear-gradient(to right,transparent,#000 28px,#000 calc(100% - 28px),transparent)}
  .mfb-pill{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:14px;border:1px solid var(--border);background:var(--panel-2);color:var(--muted);font-size:11px;white-space:nowrap;cursor:pointer;flex-shrink:0;transition:all .15s;min-height:0;box-sizing:border-box}
  .mfb-pill:hover,.mfb-pill:active{border-color:var(--accent);color:var(--text)}
  .mfb-pill.disabled{opacity:.35;pointer-events:none;cursor:default}
  .mfb-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
  .mfb-pill.mfb-note.active{background:rgba(251,191,36,.1);color:#fbbf24;border-color:#fbbf24}
  .mfb-pill.mfb-clip.active{background:rgba(41,211,152,.15);color:var(--ok);border-color:var(--ok)}
  .mfb-pill svg{flex-shrink:0}
  .mfb-sep{width:1px;align-self:stretch;margin:4px 2px;background:var(--border);flex-shrink:0}
  .player{padding:6px 10px}
  .time{min-width:auto;font-size:12px}
  .bar{height:10px;position:relative}
  .bar::before{content:'';position:absolute;top:-17px;bottom:-17px;left:0;right:0}
  .search-strip{padding:6px 10px}
  .search-strip #title,#title{max-width:none;white-space:normal;overflow:visible;text-overflow:clip}
  .seg{grid-template-columns:56px 1fr}
  .seg .ts{min-width:0}
  .modal{align-items:start;padding-top:80px}
  .modal .dialog{max-height:calc(100vh - 96px)}
  .dialog .rowline{flex-direction:column;align-items:stretch;gap:4px}
  .dialog .rowline .label{min-width:0 !important;margin-bottom:4px}
  #optCharPreview table{display:block;overflow-x:auto;white-space:nowrap}
  /* User dropdown mobile */
  .user-btn-name,.user-chevron{display:none !important}
  #userDropdown{position:absolute;top:calc(100% + 6px);right:0;left:auto;width:min(340px,calc(100vw - 16px));max-height:min(70vh,480px);border-radius:12px;border:1px solid var(--border);z-index:3000}
  /* Split layout mobile — stacked (transcript top, summary bottom) */
  .split-layout{overflow-x:hidden}
  #tsScroll{overflow-x:hidden}
  .split-layout.summary-open.summary-full #tsScroll{display:none}
  .split-layout.summary-open:not(.summary-full):not(.wiki-open){grid-template-rows:1fr 1fr}
  .split-layout.summary-open:not(.summary-full) #summaryView{border-top:1px solid var(--border)}
  .split-layout.summary-open #summaryView{overflow:hidden;display:flex;flex-direction:column}
  .split-layout.summary-open .sv-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
  .split-layout.summary-open .sv-pane.hidden{display:none}
  .split-layout.summary-open .summary-scroll{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}
  .split-layout.summary-open #chatSection{flex-shrink:0;max-height:40%;border-top:1px solid var(--border);padding-bottom:60px;overflow-y:auto}
  /* Clip badge — ensure it doesn't overlap transcript text */
  .clip-badge{bottom:100px;right:12px;backdrop-filter:blur(8px);background:rgba(23,26,43,.92)}
  .clip-export-panel{bottom:100px;right:12px;width:calc(100vw - 24px);max-width:340px;max-height:calc(100vh - 120px);overflow-y:auto}
  .clip-mode #tsScroll{padding-bottom:80px}
  /* Note mode mobile */
  .note-badge{bottom:100px;right:12px;backdrop-filter:blur(8px);background:rgba(23,26,43,.92)}
  .note-panel{bottom:100px;right:12px;width:calc(100vw - 24px);max-width:340px}
  .note-mode-bar{bottom:64px;right:12px}
  .ai-note-panel{bottom:100px;right:12px;width:calc(100vw - 24px);max-width:340px}
  .note-mode #tsScroll{padding-bottom:80px}
  /* Member card fields */
  .member-card .member-fields{grid-template-columns:1fr}
  .summary-toolbar{justify-content:flex-start;gap:6px}
  .summary-toolbar .select{width:100%;max-width:none;order:1}
  .summary-toolbar .refine-input{width:100%;min-width:100%;order:2}
  .summary-toolbar .sm-btn{flex:1;min-height:44px;order:3}
}

/* ── Landscape: collapse feature bar to save space ── */
@media (max-width:900px) and (max-height:500px) and (orientation:landscape){
  .mobile-feature-bar{display:none !important}
}

/* ── Features grid responsive ── */
@media (max-width:800px){
  .features-grid{grid-template-columns:1fr}
  .phase-grid{grid-template-columns:1fr 1fr;gap:8px}
}

/* ── Small tablets / large phones ── */
@media (max-width:700px){
  html,body{font-size:12px}
  header{padding:6px 8px}
  .player{padding:6px 8px}
  .btn{padding:6px 8px;border-radius:8px}
  .btn.icon{width:30px;height:30px;min-width:30px;min-height:30px;font-size:16px}
  .toolbar .btn.icon{width:30px;height:30px;min-width:30px;min-height:30px;font-size:16px}
  .toolbar .group.transport .btn.round{min-width:30px;min-height:30px}
  .user-btn{min-width:30px;min-height:30px}
  .btn.icon.sm{width:26px;height:26px;font-size:14px}
  .select,.input{padding:6px 8px;border-radius:8px}
  .pill{padding:4px 8px}
  .seg{padding:6px 8px;grid-template-columns:52px 1fr}
  .seg .ts{font-size:11px}
  .tabs button.btn.tab{height:26px}
  .search-strip .btn{height:28px}
  .search-strip .select,.search-strip .input{height:28px}
}

/* ── Landing auth responsive ── */
@media (max-width:600px){
  .landing-morph #panelLogin{min-height:220px}
  .landing-morph #panelSignup{min-height:320px}
  .landing-hero{padding:0}
  .morph-brand{padding:16px 14px 0}
  .hero-highlights{grid-template-columns:1fr;gap:6px;max-width:none}
  .landing h1{font-size:18px}
  .about-grid{grid-template-columns:1fr}
  .about-steps{grid-template-columns:1fr}
  .about-section-split{grid-template-columns:1fr}
  .landing-morph .panel.auth form{max-width:360px;width:100%}
  .landing-morph .panel.auth .rowline{flex-direction:column;align-items:stretch}
  .landing-morph .panel.auth .rowline .label{min-width:0 !important;width:100%}
  .landing-morph .panel.auth .rowline .input{min-width:0;width:100%}
}

/* ── Small features/phase grid ── */
@media (max-width:520px){
  .features-grid{grid-template-columns:1fr}
  .landing-features{padding:40px 16px 32px}
  .landing-features-heading{font-size:1.15rem}
  .features-logo{height:44px}
}

/* ── Phase progress small ── */
@media (max-width:500px){
  .phase-grid{grid-template-columns:1fr;gap:8px}
}

/* ── DDB sheet mobile ── */
@media (max-width:480px){
  .speaker-popup.ddb-sheet{min-width:240px;max-width:calc(100vw - 24px)}
  .speaker-popup.ddb-sheet .cs-abilities{gap:1px;padding:6px 8px 4px}
  .speaker-popup.ddb-sheet .cs-ability-mod{font-size:14px}
  .speaker-popup.ddb-sheet .cs-combat-value{font-size:13px}
}

/* ── Smallest screens ── */
@media (max-width:420px){
  html,body{font-size:11px}
  .seg{grid-template-columns:48px 1fr}
}

/* ── Wiki mobile ── */
@media (max-width:768px){
  .wiki-body{grid-template-columns:1fr}
  .wiki-sidebar{display:none}
  .wiki-body.wiki-show-list .wiki-sidebar{display:flex}
  .wiki-body.wiki-show-list .wiki-detail{display:none}
  .wiki-header{flex-wrap:wrap;padding:10px 12px;gap:8px}
  .wiki-header h2{font-size:16px}
  .wiki-search-bar{max-width:none;order:10;width:100%}
  .wiki-type-pills{order:11;width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .wiki-type-pills::-webkit-scrollbar{display:none}
  .wiki-view-tabs{padding:0 12px 8px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .wiki-view-tabs::-webkit-scrollbar{display:none}
  .wiki-detail{padding:16px 14px}
  .wiki-mobile-back{display:inline-flex}
  /* Detail header — scale down for narrow screens */
  .wiki-detail-header .wiki-detail-icon{font-size:28px}
  .wiki-detail-header .wiki-detail-title{font-size:18px}
  .wiki-detail-summary{font-size:13px}
  .wiki-detail-body{font-size:13px;line-height:1.6}
  /* Tables — horizontally scrollable so they don't blow out viewport */
  .wiki-detail-body .md-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}
  /* Mention rows — stack vertically instead of horizontal flex */
  .wiki-mention-row{flex-direction:column;align-items:flex-start;gap:4px;padding:8px 10px}
  .wiki-mention-row .wiki-mention-ts{font-size:11px}
  .wiki-mention-row .wiki-mention-text{white-space:normal;word-break:break-word}
  /* Relation chips — scroll if too many */
  .wiki-detail-section .wiki-relation-chip{font-size:11px;padding:5px 10px}
  /* Actions — full width buttons on small screens */
  .wiki-detail-actions{flex-direction:column}
  .wiki-detail-actions .btn{width:100%;justify-content:center}
  /* Edit form — respect narrow viewport */
  .wiki-edit-form{max-width:100%}
  /* Timeline */
  .wiki-timeline-container{padding:12px 14px}
  .tl-session{padding-left:20px}
  .tl-session-header{margin-left:-20px}
  .tl-session-header:hover{margin-left:-26px;padding-left:6px}
  .tl-filter-pills{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tl-filter-pills::-webkit-scrollbar{display:none}
  /* Graph */
  .graph-controls{flex-wrap:wrap;padding:6px 10px}
  .graph-filter-pills{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .graph-filter-pills::-webkit-scrollbar{display:none}
  .graph-canvas{min-height:300px}
  /* Extraction modal */
  .wiki-extract-row{flex-direction:column;align-items:flex-start;gap:6px}
  .wiki-extract-title{max-width:none}
  .wiki-extract-info{flex-direction:column;align-items:flex-start;gap:2px}
  .wiki-extract-action{width:100%}
  .wiki-extract-action .btn{width:100%;justify-content:center}
  /* Autocomplete dropdown */
  .wiki-ac-dropdown{max-width:calc(100vw - 24px);min-width:160px}
}

/* ═══════════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════════ */

/* ── Notification entrance/exit ── */
@keyframes notifSlideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes notifFadeOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(40px)}}
.notif-item{animation:notifSlideIn .25s ease both}
.notif-item:nth-child(2){animation-delay:.04s}
.notif-item:nth-child(3){animation-delay:.08s}
.notif-item:nth-child(4){animation-delay:.12s}
.notif-item:nth-child(5){animation-delay:.16s}
.notif-item.notif-removing{animation:notifFadeOut .25s ease both}

/* ── Toast / Snackbar ─────────────────────────────────────── */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:12000;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;max-width:380px;width:100%;transition:right .25s ease}
.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;background:var(--panel-2);border:1px solid var(--border);color:var(--text);font-size:13px;line-height:1.4;box-shadow:0 8px 32px rgba(0,0,0,.45);pointer-events:auto;animation:toastIn .25s ease both;word-break:break-word}
.toast-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.toast-success .toast-icon{background:rgba(41,211,152,.18);color:var(--ok)}
.toast-error .toast-icon{background:rgba(255,107,107,.18);color:var(--danger)}
.toast-warning .toast-icon{background:rgba(255,167,38,.18);color:var(--color-warning)}
.toast-info .toast-icon{background:rgba(110,168,254,.18);color:var(--accent)}
.toast-msg{flex:1;min-width:0}
.toast-action{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;padding:0 4px;font-size:13px;white-space:nowrap}
.toast-action:hover{text-decoration:underline}
.toast-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;padding:0 0 0 6px;flex-shrink:0;opacity:.7;transition:opacity .15s}
.toast-close:hover{opacity:1}
.toast-exit{animation:toastOut .2s ease both}
@keyframes toastIn{from{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes toastOut{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(12px) scale(.96)}}
@media(max-width:500px){.toast-container{right:12px;left:12px;bottom:12px;max-width:none}}

/* ── Share mode: hide write-only elements ── */
body.share-mode .kebab,
body.share-mode .kebabBtn,
body.share-mode .session-kebab,
body.share-mode .kebab-menu,
body.share-mode #btnNew,
body.share-mode #btnNewParty,
body.share-mode #uploadModal,
body.share-mode #chatInputRow,
body.share-mode #summaryGenRow,
body.share-mode #cepActions,
body.share-mode #wikiExtractBtn,
body.share-mode .sidebar-footer,
body.share-mode #masqueradeSection,
body.share-mode #masqueradeBar,
body.share-mode #adminDashboard,
body.share-mode #btnUnassigned,

body.share-mode #btnWikiAdd,
body.share-mode #btnNukeWiki,
body.share-mode [data-wiki-action="edit"],
body.share-mode [data-wiki-action="delete"],
body.share-mode [data-wiki-action="post-discord"],
body.share-mode #wikiEditPanel,
body.share-mode #btnDiscordSync { display: none !important; }

/* ── Sub-Session Overlay ──────────────────────────────────── */
#overlayView{display:none;position:absolute;inset:0;z-index:50;background:var(--bg);overflow-y:auto;padding:0}
#overlayView.active{display:block}
.overlay-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--panel);position:sticky;top:0;z-index:2}
.overlay-header .overlay-close{background:none;border:1px solid var(--border);color:var(--muted);cursor:pointer;padding:6px 12px;border-radius:8px;font-size:13px;display:flex;align-items:center;gap:4px;transition:all .15s ease}
.overlay-header .overlay-close:hover{color:var(--text);border-color:var(--accent);background:rgba(110,168,254,.08)}
.overlay-header .overlay-title{font-size:15px;font-weight:600;color:var(--text)}
.overlay-header .overlay-subtitle{font-size:13px;color:var(--muted);margin-left:auto}
.overlay-body{padding:20px;max-width:900px;margin:0 auto}

/* ── Character Sheet ──────────────────────────────────────── */
.char-sheet-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px;padding:16px;background:var(--panel);border-radius:12px;border:1px solid var(--border)}
.char-sheet-header .cs-avatar{width:80px;height:80px;border-radius:12px;object-fit:cover;border:2px solid var(--border)}
.char-sheet-header .cs-info{flex:1}
.char-sheet-header .cs-name{font-size:20px;font-weight:700;color:var(--text);margin-bottom:4px}
.char-sheet-header .cs-meta{font-size:13px;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px}
.char-sheet-header .cs-meta span{background:var(--chip);padding:2px 8px;border-radius:6px}

.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:640px){.cs-grid{grid-template-columns:1fr}}
.cs-section{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.cs-section-title{font-size:12px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.cs-section-title svg{width:14px;height:14px;opacity:.5}

.cs-abilities{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.cs-ability{text-align:center;background:var(--panel-2);border-radius:8px;padding:10px 6px;border:1px solid var(--border)}
.cs-ability .ability-label{font-size:10px;text-transform:uppercase;color:var(--muted);letter-spacing:.5px}
.cs-ability .ability-score{font-size:22px;font-weight:700;color:var(--text)}
.cs-ability .ability-mod{font-size:13px;color:var(--accent);font-weight:600}

.cs-stat-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;border-bottom:1px solid rgba(42,46,85,.4)}
.cs-stat-row:last-child{border-bottom:none}
.cs-stat-label{color:var(--muted)}
.cs-stat-value{color:var(--text);font-weight:600}
.cs-stat-value.prof{color:var(--accent)}

.cs-tags{display:flex;flex-wrap:wrap;gap:6px}
.cs-tag{background:var(--chip);color:var(--text);padding:4px 10px;border-radius:6px;font-size:12px}
.cs-tag.attuned{border:1px solid var(--accent-2);color:var(--accent-2)}

.cs-spell-slots{display:flex;flex-wrap:wrap;gap:8px}
.cs-spell-slot{text-align:center;background:var(--panel-2);border-radius:8px;padding:8px 12px;border:1px solid var(--border)}
.cs-spell-slot .slot-level{font-size:10px;color:var(--muted);text-transform:uppercase}
.cs-spell-slot .slot-count{font-size:16px;font-weight:700;color:var(--accent-2)}

.cs-currency{display:flex;gap:12px;flex-wrap:wrap}
.cs-currency-item{display:flex;align-items:center;gap:4px;font-size:13px}
.cs-currency-item .coin{font-size:15px}

.cs-empty-state{text-align:center;padding:40px 20px;color:var(--muted)}
.cs-empty-state svg{width:48px;height:48px;opacity:.3;margin-bottom:12px}
.cs-empty-state .cs-empty-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:8px}
.cs-empty-state .cs-empty-desc{font-size:13px;max-width:400px;margin:0 auto}

.cs-snapshot-meta{text-align:center;padding:12px;font-size:12px;color:var(--muted);border-top:1px solid var(--border);margin-top:16px}
.cs-snapshot-meta a{color:var(--accent);text-decoration:none}
.cs-snapshot-meta a:hover{text-decoration:underline}
.cs-live-warning{background:rgba(255,180,0,.1);border:1px solid rgba(255,180,0,.3);border-radius:8px;padding:8px 14px;font-size:12px;color:#fdb44b;margin-bottom:16px;text-align:center}

/* ── Player Notes ─────────────────────────────────────────── */
.notes-view{max-width:800px;margin:0 auto}
.notes-generate{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px}
.notes-generate-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px}
.notes-generate .gen-types{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.notes-generate .gen-type{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}
.notes-generate .gen-type input{accent-color:var(--accent)}
.notes-generate .gen-actions{display:flex;align-items:center;gap:12px}
.notes-content{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px}
.notes-content .notes-toolbar{display:flex;gap:8px;margin-bottom:12px}
.notes-rendered{color:var(--text);font-size:14px;line-height:1.65}
.notes-rendered h2{font-size:17px;font-weight:700;margin:20px 0 8px;padding-top:12px;border-top:1px solid var(--border);color:var(--text)}
.notes-rendered h2:first-child{border-top:none;margin-top:0;padding-top:0}
.notes-rendered h3{font-size:14px;font-weight:600;color:var(--accent);margin:12px 0 6px}
.notes-rendered ul,.notes-rendered ol{margin:4px 0 8px 18px}
.notes-rendered li{margin:2px 0}
.notes-rendered hr{border:none;border-top:1px solid var(--border);margin:16px 0}
.notes-rendered em{color:var(--accent-2)}
.notes-rendered strong{color:var(--text);font-weight:700}
.notes-edit-area{width:100%;min-height:400px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:monospace;font-size:13px;padding:12px;resize:vertical;line-height:1.6}
.notes-edit-area:focus{outline:none;border-color:var(--accent)}
.notes-empty{text-align:center;padding:32px;color:var(--muted);font-size:14px}

/* ── Sidebar Character Expansion ──────────────────────────── */
.session-characters{padding:8px 0 4px;display:none}
.session.active .session-characters{display:block}
.char-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .12s ease;font-size:12px}
.char-row:hover{background:rgba(110,168,254,.08)}
.char-row.active{background:rgba(110,168,254,.12);border-left:2px solid var(--accent)}
.char-row .cr-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid var(--border);flex-shrink:0}
.char-row .cr-name{flex:1;color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.char-row .cr-role{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.char-row .cr-btns{display:flex;gap:2px;flex-shrink:0;opacity:.5;transition:opacity .12s}
.char-row:hover .cr-btns{opacity:1}
.char-row .cr-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px 4px;font-size:13px;border-radius:4px;transition:color .12s,background .12s}
.char-row .cr-btn:hover{color:var(--accent);background:rgba(110,168,254,.12)}

/* ── Sheet Visibility Config (Party Modal Tab) ────────────── */
.vis-section-toggle{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px;color:var(--text)}
.vis-section-toggle input{accent-color:var(--accent)}
.vis-section-toggle.always-on{opacity:.6}
.vis-section-toggle.always-on input{pointer-events:none}
.vis-preview{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:14px;margin-top:12px;font-size:12px;color:var(--muted)}
.vis-preview-title{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:8px;font-weight:600}

/* ── AI Note Generation ────────────── */
.notes-generate{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:14px}
.notes-generate-title{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:10px}
.gen-types{display:flex;flex-wrap:wrap;gap:8px 16px;margin-bottom:10px}
.gen-type{font-size:12px;color:var(--text);display:flex;align-items:center;gap:5px;cursor:pointer}
.gen-type input{accent-color:var(--accent)}
.gen-actions{display:flex;align-items:center;gap:10px}
