/* iKomek Dashboard — global theme (Phase 0a extract).
 *
 * Loaded BEFORE inline <style> in dashboard-v100.html so per-screen rules
 * in inline <style> can override theme defaults via cascade order.
 *
 * Contents: CSS variables (:root, [data-theme=dark]), base reset/body,
 * layout (.app, .sidebar, .topbar), generic components (.kpi-*, .card,
 * .team-*, .att-*, .btn-*, .chip, .nav-item, .modal, .toast), and
 * @keyframes shared across screens.
 *
 * Per-screen selectors (.exp-*, .qf-*, .q1-*, .an-*, .kb-*, .start-*,
 * .dept-*, .calib-*, .weights-*, .audit-*, .tile-*) are deliberately
 * NOT here — they live in inline <style> (Phase 0a) and will move to
 * screens/<name>/screen.css in Phase 1+.
 */

:root{
  --bg:#F5F7FA;
  --surface:#FFFFFF;
  --surface-2:#F9FAFB;
  --surface-3:#F3F4F6;
  --text:#0F172A;
  --text-2:#334155;
  --muted:#64748B;
  --mutex:#94A3B8;
  --border:#E5E7EB;
  --border-2:#EEF0F4;
  --accent:#2B4EFF;
  --accent-soft:rgba(43,78,255,.08);
  --accent-soft-2:rgba(43,78,255,.14);
  --success:#10B981;
  --success-soft:rgba(16,185,129,.1);
  --danger:#F43F5E;
  --danger-soft:rgba(244,63,94,.08);
  --danger-soft-2:rgba(244,63,94,.16);
  --warn:#F59E0B;
  --warn-soft:rgba(245,158,11,.1);
  --purple:#8B5CF6;
  --purple-soft:rgba(139,92,246,.1);
  --shadow-sm:0 1px 2px rgba(15,23,42,.04);
  --shadow:0 4px 20px rgba(15,23,42,.06);
  --shadow-lg:0 12px 40px rgba(15,23,42,.08);
  --mix-tint:#FFFFFF;
  --bar-muted:#E5E7EB;
  --r:20px;
  --r-sm:12px;
}
[data-theme="dark"]{
  --bg:#15171C;
  --surface:#1C1F25;
  --surface-2:#22262D;
  --surface-3:#2A2F37;
  --text:#E8EAED;
  --text-2:#B8BDC7;
  --muted:#7F8594;
  --mutex:#5E6472;
  --border:#2F343D;
  --border-2:#272B32;
  --accent:#7C8CFF;
  --accent-soft:rgba(124,140,255,.10);
  --accent-soft-2:rgba(124,140,255,.18);
  --success:#4ADE80;
  --success-soft:rgba(74,222,128,.10);
  --danger:#F87171;
  --danger-soft:rgba(248,113,113,.10);
  --danger-soft-2:rgba(248,113,113,.18);
  --warn:#FBBF24;
  --warn-soft:rgba(251,191,36,.10);
  --purple:#B4A0FF;
  --purple-soft:rgba(180,160,255,.12);
  --shadow-sm:0 1px 2px rgba(0,0,0,.25);
  --shadow:0 4px 18px rgba(0,0,0,.32);
  --shadow-lg:0 12px 36px rgba(0,0,0,.42);
  --mix-tint:#22262D;
  --bar-muted:#374151;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
html{transition:background-color .35s ease}
body{transition:background-color .35s ease, color .35s ease}
.sidebar,.topbar,.kpi-card,.block-card,.att-item,.lead-row,.team-card{transition:background-color .35s ease, border-color .35s ease, color .35s ease, box-shadow .35s ease}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Manrope',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-weight:500;
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.01em;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
svg{display:block}

/* Layout */
.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{
  background:var(--surface);
  border-right:1px solid var(--border);
  padding:24px 16px;
  display:flex;
  flex-direction:column;
  gap:8px;
  position:sticky;
  top:0;
  height:100vh;
  overflow-y:auto;
}
.logo{
  display:flex;align-items:center;gap:10px;
  padding:4px 8px 20px;
  font-weight:800;font-size:18px;letter-spacing:-.02em;
}
.logo-mark{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),#6366F1);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px;
}
.sb-group-label{
  font-size:11.5px;color:var(--muted);font-weight:600;
  padding:14px 12px 6px;text-transform:none;letter-spacing:.02em;
}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:12px;
  color:var(--text-2);font-weight:600;font-size:13.5px;
  cursor:pointer;transition:all .15s;
}
.nav-item:hover{background:var(--surface-3);color:var(--text)}
.nav-item.active{
  background:var(--accent);
  color:#fff;
  box-shadow:0 4px 12px rgba(43,78,255,.25);
}
.nav-item .ic{
  width:20px;height:20px;flex-shrink:0;
  display:grid;place-items:center;
  color:currentColor;
}
.sb-bottom{margin-top:auto;display:flex;flex-direction:column;gap:10px}
.theme-toggle{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;
  background:var(--surface-3);border-radius:12px;
  font-size:12.5px;font-weight:600;color:var(--text-2);
}
.theme-sw{
  position:relative;width:36px;height:20px;border-radius:20px;
  background:var(--border);transition:.2s;
}
.theme-sw::after{
  content:'';position:absolute;top:2px;left:2px;
  width:16px;height:16px;border-radius:50%;
  background:#fff;transition:.2s;
  box-shadow:0 1px 3px rgba(0,0,0,.15);
}
[data-theme="dark"] .theme-sw{background:var(--accent)}
[data-theme="dark"] .theme-sw::after{transform:translateX(16px)}
.sb-profile{
  display:flex;align-items:center;gap:10px;
  padding:10px;border-radius:12px;
  background:var(--surface-3);
}
.sb-profile-av{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,#F59E0B,#F43F5E);
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:12.5px;
  flex-shrink:0;
}
.sb-profile-name{font-size:12.5px;font-weight:700;color:var(--text)}
.sb-profile-role{font-size:11.5px;color:var(--muted)}

/* Main */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:16px 32px;
  display:flex;align-items:center;gap:16px;
  position:sticky;top:0;z-index:5;
}
.topbar-title{
  min-width:0;
  display:flex;flex-direction:column;gap:2px;
}
.topbar-title h1{
  font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--text);
}
.topbar-title p{font-size:12.5px;color:var(--muted);font-weight:500}
.topbar-search{
  flex:0 1 320px;
  display:flex;align-items:center;gap:8px;
  padding:9px 14px;
  background:var(--surface-3);border-radius:12px;
  font-size:13px;color:var(--muted);
}
.topbar-search input{
  background:none;border:none;outline:none;
  color:var(--text);font-family:inherit;font-size:13px;font-weight:500;
  width:100%;
}
.icon-btn{
  width:40px;height:40px;border-radius:12px;
  background:var(--surface-3);
  display:grid;place-items:center;
  color:var(--text-2);transition:.15s;
}
.icon-btn:hover{background:var(--border)}
.icon-btn .dot{
  position:absolute;top:9px;right:9px;
  width:7px;height:7px;border-radius:50%;
  background:var(--danger);border:2px solid var(--surface);
}
.icon-btn{position:relative}

/* Screen */
.screen-wrap{padding:36px 40px 48px}
.screen{display:none;flex-direction:column;gap:32px}
.screen.active{display:flex}

.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:16px;margin-bottom:24px;
}
.section-head h2{
  font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--text);
}
.section-head .fresh{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;color:var(--muted);font-weight:500;
}
.section-head .fresh::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--success);
  box-shadow:0 0 0 3px var(--success-soft);
}
.section-head.section-head--stacked{
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
  margin-bottom:28px;
}
.section-desc{
  font-size:15px;
  color:var(--muted);
  font-weight:600;
  letter-spacing:-.005em;
}

/* KPI */
.kpi-grid{display:grid;gap:20px}
.funnel-grid{grid-template-columns:1.6fr repeat(5,1fr)}

.kpi-card{
  background:var(--surface);
  border-radius:var(--r);
  padding:26px;
  box-shadow:var(--shadow);
  border:1px solid var(--border-2);
  display:flex;flex-direction:column;gap:14px;justify-content:flex-start;
  min-width:0;
  transition:.2s;
}
.kpi-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.kpi-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:40px;
}
.kpi-ic{
  width:40px;height:40px;border-radius:12px;
  display:grid;place-items:center;
  color:var(--accent);
  background:linear-gradient(135deg,var(--accent-soft),color-mix(in srgb,var(--accent-soft) 60%,var(--mix-tint)));
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 12%,transparent), 0 1px 2px color-mix(in srgb,var(--accent) 8%,transparent);
  flex-shrink:0;transition:.2s;
}
.kpi-card:hover .kpi-ic{transform:scale(1.04)}
.kpi-ic.--danger{color:var(--danger);background:linear-gradient(135deg,var(--danger-soft),color-mix(in srgb,var(--danger-soft) 60%,var(--mix-tint)));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--danger) 12%,transparent)}
.kpi-ic.--warn{color:var(--warn);background:linear-gradient(135deg,var(--warn-soft),color-mix(in srgb,var(--warn-soft) 60%,var(--mix-tint)));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--warn) 12%,transparent)}
.kpi-ic.--purple{color:var(--purple);background:linear-gradient(135deg,var(--purple-soft),color-mix(in srgb,var(--purple-soft) 60%,var(--mix-tint)));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--purple) 12%,transparent)}
.kpi-ic.--muted{color:var(--muted);background:linear-gradient(135deg,var(--surface-3),color-mix(in srgb,var(--surface-3) 50%,var(--mix-tint)));box-shadow:inset 0 0 0 1px var(--border-2)}
.kpi-ic.--success{color:var(--success);background:linear-gradient(135deg,var(--success-soft),color-mix(in srgb,var(--success-soft) 60%,var(--mix-tint)));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--success) 12%,transparent)}
.kpi-badge{
  font-size:11.5px;font-weight:700;color:var(--muted);
  padding:3px 9px;background:var(--surface-3);border-radius:20px;
}
.kpi-label{
  font-size:12.5px;
  color:var(--muted);
  font-weight:600;
  min-height:32px;           /* место под 2 строки лейбла */
  display:flex;
  align-items:flex-start;
  line-height:1.3;
}
.kpi-value{
  font-size:32px;font-weight:800;letter-spacing:-.03em;color:var(--text);line-height:1.05;
}
.kpi-hint{
  font-size:12px;
  color:var(--mutex);
  font-weight:500;
  min-height:30px;           /* место под 2 строки */
  line-height:1.4;
}

/* Hero KPI (danger critical) */
.kpi-hero{
  grid-column:span 1;
  background:linear-gradient(135deg,#F43F5E,#E11D48);
  color:#fff;position:relative;overflow:hidden;
  border:none;
}
.kpi-hero::before{
  content:'';position:absolute;inset:-40%;
  background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.18),transparent 45%);
}
.kpi-hero>*{position:relative;z-index:1}
.kpi-hero .kpi-ic{background:rgba(255,255,255,.18);color:#fff}
.kpi-hero .kpi-label,.kpi-hero .kpi-hint{color:rgba(255,255,255,.85)}
.kpi-hero .kpi-badge{background:rgba(255,255,255,.2);color:#fff}
.kpi-hero .kpi-value{color:#fff;font-size:32px}
.kpi-hero .btn-action{
  background:#fff;color:#E11D48;box-shadow:0 2px 10px rgba(0,0,0,.12);
  padding:8px 14px;border-radius:10px;
  font-size:12.5px;font-weight:700;
  display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  margin-top:auto;
  transition:.15s;
}
.kpi-hero .btn-action:hover{background:#FFF;box-shadow:0 4px 16px rgba(0,0,0,.2);transform:translateY(-1px)}
.kpi-hero{transition:.2s}
.kpi-hero:hover{transform:translateY(-1px);box-shadow:0 14px 36px rgba(244,63,94,.35), inset 0 0 0 2px rgba(255,255,255,.55)}

/* ── Expenses screen (Phase 4) ── */










@keyframes shimmer{to{background-position:-400% 0}}



/* Topup modal */












/* Card (generic) */
.card{
  background:var(--surface);
  border-radius:var(--r);
  padding:24px;
  box-shadow:var(--shadow);
  border:1px solid var(--border-2);
}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}
.card-head h3{font-size:16px;font-weight:700;letter-spacing:-.01em;color:var(--text)}
.card-head .fresh{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-weight:500}
.card-head .fresh::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 0 3px var(--success-soft)}

/* Team */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.team-card.is-hidden{display:none}
.expand-actions{
  margin:16px auto 0;
  display:flex;justify-content:center;align-items:center;gap:8px;
  flex-wrap:wrap;
}
.expand-btn,.collapse-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  color:var(--text-2);
  font-size:13px;font-weight:600;
  cursor:pointer;
  transition:all .15s ease;
}
.expand-btn:hover,.collapse-btn:hover{
  background:var(--surface-2);
  border-color:var(--accent);
  color:var(--accent);
}
.collapse-btn{
  background:transparent;
  color:var(--muted);
  border-color:var(--border-2,var(--border));
  opacity:.85;
}
.collapse-btn:hover{
  opacity:1;
  color:var(--text-2);
  border-color:var(--text-2);
  background:var(--surface);
}
.expand-btn-ic,.collapse-btn-ic{transition:transform .2s ease}
.expand-btn[hidden],.collapse-btn[hidden]{display:none}
.team-card{
  background:var(--surface);
  border-radius:var(--r);
  padding:22px;
  box-shadow:var(--shadow);
  border:1px solid var(--border-2);
  display:flex;flex-direction:column;gap:18px;
}
.team-top{display:flex;align-items:center;gap:14px}
.team-av{
  position:relative;width:52px;height:52px;border-radius:50%;
  display:grid;place-items:center;
  font-weight:800;font-size:16px;color:#fff;
  background:linear-gradient(135deg,var(--accent),#8B5CF6);
  flex-shrink:0;
}
.team-av.--warm{background:linear-gradient(135deg,#F59E0B,#F43F5E)}
.team-av-dot{
  position:absolute;bottom:2px;right:2px;
  width:12px;height:12px;border-radius:50%;
  background:var(--success);border:2.5px solid var(--surface);
}
.team-info{min-width:0;flex:1}
.team-name{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.team-meta{font-size:12px;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}
.team-meta .sep{color:var(--mutex)}
.team-metrics{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px 6px;
}
.team-metric{display:flex;flex-direction:column;gap:2px;padding:4px 0}
.team-metric-val{font-size:17px;font-weight:800;color:var(--text);letter-spacing:-.02em;line-height:1}
.team-metric-val.--accent{color:var(--accent)}
.team-metric-val.--success{color:var(--success)}
.team-metric-val.--warn{color:var(--warn)}
.team-metric-val.--danger{color:var(--danger)}
.team-metric-val.--purple{color:var(--purple)}
.team-metric-val.--muted{color:var(--muted)}
.team-metric-lbl{font-size:11.5px;color:var(--muted);font-weight:500}

/* Attention group */
.att-group{
  background:var(--surface);
  border-radius:var(--r);
  padding:22px;
  box-shadow:var(--shadow);
  border:1px solid var(--border-2);
  display:flex;flex-direction:column;gap:14px;
}
.att-group-head{display:flex;align-items:center;gap:10px;justify-content:space-between}
.att-group-title{
  display:flex;align-items:center;gap:10px;
  font-size:13.5px;font-weight:700;color:var(--text);letter-spacing:-.01em;
}
.att-group-title .g-chip{
  font-size:11.5px;font-weight:700;
  padding:3px 9px;border-radius:8px;
  background:var(--accent-soft);color:var(--accent);letter-spacing:.02em;
}
.att-group-title .g-chip.--danger{background:var(--danger-soft);color:var(--danger)}
.att-group-title .g-chip.--warn{background:var(--warn-soft);color:var(--warn)}
.att-group-title .g-chip.--money{background:var(--success-soft);color:var(--success)}

.att-item{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  background:var(--surface-2);
  border:1px solid var(--border-2);
  border-radius:14px;
}
.att-item.--danger{background:var(--danger-soft);border-color:var(--danger-soft-2)}
.att-item.--warn{background:var(--warn-soft);border-color:rgba(245,158,11,.22)}
.att-item.--purple{background:var(--purple-soft);border-color:rgba(139,92,246,.22)}
.att-code{
  font-size:11.5px;font-weight:800;letter-spacing:.04em;
  padding:3px 9px;border-radius:8px;
  background:var(--surface);color:var(--muted);flex-shrink:0;
  border:1px solid var(--border-2);
}
.att-item.--danger .att-code{background:rgba(244,63,94,.14);color:var(--danger);border-color:transparent}
.att-item.--warn .att-code{background:rgba(245,158,11,.18);color:var(--warn);border-color:transparent}
.att-item.--purple .att-code{background:rgba(139,92,246,.18);color:var(--purple);border-color:transparent}
.att-val{
  font-size:22px;
  font-weight:800;
  color:var(--text);
  flex-shrink:0;
  min-width:36px;
}
.att-item.--danger .att-val{color:var(--danger)}
.att-item.--warn .att-val{color:var(--warn)}
.att-item.--purple .att-val{color:var(--purple)}
.att-text{
  flex:1;
  font-size:13.5px;
  line-height:1.5;
  color:var(--text-2);
}
.att-text b{color:var(--text);font-weight:700}
.att-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
}
.btn-s{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;
  font-size:12.5px;font-weight:600;
  border-radius:10px;
  background:var(--surface);color:var(--text-2);
  border:1px solid var(--border);
  transition:.15s;
}
.btn-s:hover{background:var(--surface-3)}
.btn-ai{
  background:linear-gradient(120deg, var(--accent) 0%, var(--purple) 40%, #EC4899 60%, var(--accent) 100%);
  background-size:300% 100%;
  color:#fff;
  padding:8px 14px;
  border-radius:10px;
  font-size:12.5px;font-weight:700;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 2px 10px rgba(43,78,255,.18);
  transition:box-shadow .15s ease, transform .15s ease;
  animation:btnAiFlow 6s ease infinite;
  position:relative;
  overflow:hidden;
  border:none;
  cursor:pointer;
  font-family:inherit;
}
.btn-ai::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.25) 50%, transparent 100%);
  transform:translateX(-100%);
  transition:transform .8s ease;
  pointer-events:none;
}
.btn-ai:hover{
  box-shadow:0 4px 20px rgba(43,78,255,.35), 0 0 24px rgba(139,92,246,.4);
  transform:translateY(-1px);
  animation-duration:3s;
}
.btn-ai:hover::before{
  transform:translateX(100%);
}
@keyframes btnAiFlow{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

/* Attention · row layout (A + B) */
.att-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
@media (max-width:960px){
  .att-row{grid-template-columns:1fr}
}
.att-list{display:flex;flex-direction:column;gap:10px}
.att-item.is-hidden{display:none}
.lead-row.is-hidden{display:none}

/* Attention · C · Hot leads — 2-col grid */
#hot-leads-list{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
}
/* 2-col mode requires ~1280px viewport to fit phone+time+buttons without wrapping. */
@media (max-width:1280px){
  #hot-leads-list{grid-template-columns:1fr}
}

/* List (C) — flex rows */
.lead-list{display:flex;flex-direction:column;gap:8px}
.lead-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;
  background:var(--surface-2);
  border:1px solid var(--border-2);
  border-radius:14px;
  transition:.15s;
  min-width:0;
}
.lead-row .btn-s,.lead-row .btn-ai{flex-shrink:0;white-space:nowrap}
/* Блок C · «Быстрые деньги в воронке» — табличное выравнивание карточек.
   Фиксированные grid-треки, одинаковые во всех карточках: аватар / телефон+имя /
   время в воронке / кнопка CRM / кнопка Дожать. Колонки выровнены друг под другом. */
#hot-leads-list .lead-row{
  display:grid;
  grid-template-columns:36px minmax(0,1fr) 150px 92px 108px;
  align-items:center;
  gap:14px;
}
#hot-leads-list .lead-row .lead-id{flex:unset;min-width:0}
#hot-leads-list .lead-row .lead-when{
  flex:unset;margin-left:0;min-width:0;
  justify-self:start;text-align:left;
}
#hot-leads-list .lead-row .btn-s,
#hot-leads-list .lead-row .btn-ai{
  width:100%;justify-content:center;padding-left:0;padding-right:0;
}
/* Узкий viewport — прячем колонку времени и сжимаем layout. */
@media (max-width:720px){
  #hot-leads-list .lead-row{
    grid-template-columns:36px minmax(0,1fr) 80px 92px;
  }
  #hot-leads-list .lead-row .lead-when{display:none}
}
.hl-fire{display:inline-block;font-size:13px;line-height:1;margin-left:4px;vertical-align:middle;}
.lead-row:hover{background:var(--surface-3);border-color:var(--border)}
.lead-mgr-av{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#8B5CF6);
  display:grid;place-items:center;
  color:#fff;font-size:12px;font-weight:700;
  flex-shrink:0;
}
.lead-mgr-av.--warm{background:linear-gradient(135deg,#F59E0B,#F43F5E)}
.lead-id{
  min-width:0;display:flex;flex-direction:column;gap:3px;
  flex:0 0 200px;
}
.lead-phone{
  font-size:14px;font-weight:700;color:var(--text);
  font-family:'JetBrains Mono',monospace;letter-spacing:.01em;
  cursor:pointer;transition:.15s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.lead-phone:hover{color:var(--accent)}
.lead-mgr-name{font-size:12px;color:var(--muted);font-weight:500}
.lead-why{
  flex:1;min-width:0;
  font-size:12.5px;color:var(--text-2);line-height:1.4;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.lead-when{
  flex:0 0 auto;margin-left:auto;text-align:right;
  display:flex;flex-direction:column;gap:2px;
}
.lead-age{font-size:12.5px;color:var(--text-2);font-weight:600}
.lead-time{font-size:11.5px;color:var(--muted)}

/* Panels (generic section-like container) */
.panel{
  background:var(--surface);
  border-radius:var(--r);
  padding:28px;
  box-shadow:var(--shadow);
  border:1px solid var(--border-2);
  display:flex;flex-direction:column;gap:14px;
}
.panel-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;
}
.panel-head .pt{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.panel-head .pd{font-size:12px;color:var(--muted);font-weight:500;margin-top:3px}
.panel-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11.5px;font-weight:700;letter-spacing:.02em;
  padding:3px 9px;border-radius:8px;
  background:var(--accent-soft);color:var(--accent);
}
.chip.--muted{background:var(--surface-3);color:var(--muted)}
.chip.--success{background:var(--success-soft);color:var(--success)}
.chip.--warn{background:var(--warn-soft);color:var(--warn)}
.chip.--danger{background:var(--danger-soft);color:var(--danger)}
.chip.--purple{background:var(--purple-soft);color:var(--purple)}
.chip.--tag{background:var(--surface-3);color:var(--text-2);font-weight:600}
/* ── Единый стиль переключателя периода (эталон) ── */
/* неактивный — светло-серый фон, серый текст, без рамки */
/* активный — белый фон + синяя рамка + синий текст (outline) */
.chip.--period{
  cursor:pointer;transition:.15s;user-select:none;
  background:var(--surface-3);color:var(--muted);
  padding:6px 14px;border-radius:999px;
  border:1px solid transparent;
  font-weight:600;
}
.chip.--period:hover{color:var(--text-2);background:var(--surface-2)}
.chip.--period.is-active{
  background:var(--surface);
  color:var(--accent);
  border:1px solid var(--accent);
  box-shadow:none;
}
.panel-chips{gap:8px}

/* Tasks view switcher */
.tasks-view{
  display:flex;gap:6px;background:var(--surface-2);border:1px solid var(--border-2);
  border-radius:14px;padding:6px;margin-bottom:4px;flex-wrap:wrap;
}
.tasks-view-btn{
  flex:1;min-width:140px;
  padding:9px 14px;font-size:12.5px;font-weight:600;
  color:var(--muted);border-radius:10px;transition:.15s;
  background:transparent;
}
.tasks-view-btn:hover{color:var(--text-2);background:var(--surface-3)}
.tasks-view-btn.is-active{
  background:var(--accent-soft);color:var(--accent);
  box-shadow:inset 0 0 0 1px var(--accent);
}

/* Task source chip — clickable */
.chip.--src{cursor:pointer;transition:.15s}
.chip.--src:hover{box-shadow:inset 0 0 0 1px var(--accent);background:var(--accent-soft);color:var(--accent)}
.help-q{
  width:20px;height:20px;border-radius:50%;
  background:var(--surface-3);border:1px solid var(--border-2);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11.5px;color:var(--muted);cursor:help;
}

/* Block-card — сегменты внутри panel */
.block-card{
  background:var(--surface-2);
  border:1px solid var(--border-2);
  border-radius:14px;
  padding:14px 16px;
  display:flex;flex-direction:column;gap:10px;
}
.block-card.--danger{background:var(--danger-soft);border-color:var(--danger-soft-2)}
.block-card.--warn{background:var(--warn-soft);border-color:rgba(245,158,11,.22)}
.block-card.--accent{background:var(--accent-soft);border-color:rgba(43,78,255,.22)}
.block-card.--success{background:var(--success-soft);border-color:rgba(16,185,129,.22)}
.block-card.--purple{background:var(--purple-soft);border-color:rgba(139,92,246,.22)}
.block-card.--orange{background:rgba(245,158,11,.06);border-color:rgba(245,158,11,.18)}


.section-grid{display:grid;gap:14px}
.sg-1{grid-template-columns:1fr}
.sg-3{grid-template-columns:repeat(3,1fr)}
.sg-5{grid-template-columns:repeat(5,1fr)}












/* Onboarding / Start screen */





.btn-primary{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;font-size:13px;font-weight:700;
  background:var(--accent);color:#fff;border-radius:10px;
  transition:.15s;
  box-shadow:0 2px 8px rgba(43,78,255,.25);
}
.btn-primary:hover{background:#1E3FE0;transform:translateY(-1px);box-shadow:0 4px 12px rgba(43,78,255,.3)}

.mini-card{
  background:var(--surface-2);
  border:1px solid var(--border-2);
  border-radius:14px;
  padding:16px;
  display:flex;flex-direction:column;gap:8px;
  text-align:center;
}
.mini-card .mi{font-size:26px}
.mini-card .mt{font-size:13px;font-weight:700;color:var(--accent)}
.mini-card .md{font-size:12px;color:var(--muted);line-height:1.55}
.mini-card.--success .mt{color:var(--success)}
.mini-card.--purple .mt{color:var(--purple)}

.src-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:var(--surface-2);
  border:1px solid var(--success-soft);
  border-radius:12px;
  font-size:12px;font-weight:600;color:var(--text);
}
.src-pill .ok{color:var(--success);font-weight:800}

.agent-card{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px 16px;
  background:var(--surface-2);
  border:1px solid var(--border-2);
  border-left:3px solid var(--accent);
  border-radius:14px;
}
.agent-card.--green{border-left-color:var(--success)}
.agent-card.--cyan{border-left-color:#38d9c0}
.agent-card.--blue{border-left-color:#5aaeff}
.agent-card.--yellow{border-left-color:#ffdd55}
.agent-card.--gray{border-left-color:var(--muted)}
.agent-ic{font-size:22px;flex-shrink:0;padding-top:2px}
.agent-body{flex:1;min-width:0}
.agent-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.agent-code{font-size:11.5px;font-weight:800;letter-spacing:.05em;color:var(--accent);font-family:'JetBrains Mono',monospace}
.agent-name{font-size:14px;font-weight:700;color:var(--text)}
.agent-desc{font-size:12px;color:var(--muted);line-height:1.55}

/* ════════════════════════════════════════════════════
   Start screen v2 — единый стиль с дашбордом v100
   Темная и светлая темы — через CSS-переменные
   ════════════════════════════════════════════════════ */

.sg-2{grid-template-columns:repeat(2,1fr)}








































































































@media (max-width:900px){
  .sg-2{grid-template-columns:1fr}
}


/* Analytics */
.plan-bar-track{height:8px;background:var(--surface-3);border-radius:20px;overflow:hidden;margin-top:6px}
.plan-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#6366F1);border-radius:20px}

.bar-chart{display:flex;align-items:flex-end;gap:6px;height:80px}
.bar-chart .bar{flex:1;background:var(--bar-muted);border-radius:4px 4px 0 0;cursor:help;transition:.15s}
.bar-chart .bar:hover{filter:brightness(1.1)}
.bar-chart .bar.--accent{background:var(--accent);opacity:.7}
.bar-chart .bar.--accent2{background:var(--accent);opacity:.85}
.bar-chart .bar.--success{background:var(--success)}

.metric-box{
  background:var(--surface-3);
  border-radius:10px;
  padding:14px 16px;
  min-height:92px;
  display:flex;flex-direction:column;justify-content:center;
}
.metric-box .mv{font-size:24px;font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--text)}
.metric-box .mv.--accent{color:var(--accent)}
.metric-box .mv.--success{color:var(--success)}
.metric-box .mv.--warn{color:var(--warn)}
.metric-box .mv.--danger{color:var(--danger)}
.metric-box .ml{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:6px;font-weight:700}
.metric-box .mh{font-size:11.5px;color:var(--muted);margin-top:4px}

/* Leader badge — корректный контраст в обеих темах */
.leader-badge{
  position:absolute;top:10px;right:12px;
  font-size:11.5px;padding:3px 8px;border-radius:10px;
  font-weight:800;letter-spacing:.04em;
  background:var(--warn);color:#1F2937;
}
[data-theme="dark"] .leader-badge{background:var(--warn);color:#15171C}

.nav-arrow{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:14px 18px;
  background:var(--surface-2);
  border:1px solid var(--border-2);
  border-left:3px solid var(--accent);
  border-radius:14px;
  cursor:pointer;
  transition:.15s;
}
.nav-arrow:hover{background:var(--surface-3)}
.nav-arrow .na-title{font-size:14px;font-weight:700;color:var(--text)}
.nav-arrow .na-arrow{font-size:12px;color:var(--muted)}

/* Quality */
.qa-op{
  background:var(--surface-2);
  border:1px solid var(--border-2);
  border-radius:14px;
  padding:14px 16px;
  display:flex;flex-direction:column;gap:10px;
}
.qa-op-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.qa-av{
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px;
  flex-shrink:0;
}
.qa-av.--gj{background:linear-gradient(135deg,var(--success),#38d9c0)}
.qa-av.--ga{background:linear-gradient(135deg,var(--warn),#F59E0B)}
.qa-av.--gd{background:linear-gradient(135deg,#5aaeff,var(--purple))}
.qa-score{font-size:26px;font-weight:900;letter-spacing:-.03em;line-height:1}
.qa-score.--success{color:var(--success)}
.qa-score.--warn{color:var(--warn)}
.qa-score.--blue{color:#5aaeff}
.qa-zones{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.qa-zone{
  padding:10px 12px;border-radius:10px;
  font-size:12px;color:var(--text-2);line-height:1.55;
}
.qa-zone.--good{background:var(--success-soft);border:1px solid rgba(16,185,129,.18)}
.qa-zone.--bad{background:var(--danger-soft);border:1px solid var(--danger-soft-2)}
.qa-zone-lbl{display:block;font-size:11.5px;font-weight:800;margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}
.qa-zone.--good .qa-zone-lbl{color:var(--success)}
.qa-zone.--bad .qa-zone-lbl{color:var(--danger)}
.qa-obj{
  font-size:12px;color:var(--text-2);background:var(--surface-3);
  border-radius:8px;padding:10px 12px;line-height:1.5;
}
.qa-obj b{color:var(--warn);font-weight:700}
.qa-obj.--danger b{color:var(--danger)}

/* Tasks */
.task-section{
  background:var(--surface);
  border:1px solid var(--border-2);
  border-radius:var(--r);
  padding:18px 20px;
  box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:14px;
}
.task-section.--urgent{border-color:var(--danger-soft-2)}
.task-section.--clients{border-color:rgba(245,158,11,.25)}
.task-section.--process{border-color:rgba(90,174,255,.25)}
.task-section.--loss{border-color:rgba(245,140,80,.25)}
.task-sh{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.task-st{font-size:14px;font-weight:700;color:var(--text)}
.task-st.--danger{color:var(--danger)}
.task-tag{font-size:11.5px;font-weight:700;letter-spacing:.04em;padding:3px 10px;border-radius:20px;text-transform:uppercase}
.task-tag.--danger{background:var(--danger-soft);color:var(--danger)}
.task-tag.--warn{background:var(--warn-soft);color:var(--warn)}
.task-tag.--blue{background:var(--accent-soft);color:var(--accent)}
.task-tag.--orange{background:var(--warn-soft);color:var(--warn)}
.task-tag.--muted{background:var(--surface-3);color:var(--muted)}
.task-item{display:flex;gap:12px;align-items:flex-start}
.task-item + .task-item{border-top:1px solid var(--border-2);padding-top:14px}
.task-num{font-size:14px;font-weight:800;flex-shrink:0;padding-top:2px;min-width:24px}
.task-num.--danger{color:var(--danger)}
.task-num.--warn{color:var(--warn)}
.task-num.--blue{color:#5aaeff}
.task-num.--orange{color:#f58c50}
.task-num.--muted{color:var(--muted)}
.task-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}
.task-title{font-size:13px;font-weight:600;color:var(--text)}
.task-tags{display:flex;gap:6px;flex-wrap:wrap}
.task-desc{font-size:12.5px;color:var(--muted);line-height:1.6}

/* Details marker — rotating arrow */
/* v28-modal (adapted to v29) */
#modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:8888;align-items:center;justify-content:center;backdrop-filter:blur(4px);padding:16px}
#modal-overlay.open{display:flex}
#modal-box{background:var(--surface);border:1px solid var(--border);border-radius:18px;width:min(680px,95vw);max-height:82vh;overflow-y:auto;box-shadow:var(--shadow-lg);font-family:inherit}
#modal-box .modal-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
#modal-box .modal-head #modal-title{font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.01em}
#modal-close{background:var(--surface-3);border:1px solid var(--border);color:var(--text-2);font-size:14px;cursor:pointer;line-height:1;width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center}
#modal-close:hover{color:var(--text);background:var(--surface-2)}
#modal-box .modal-body{padding:14px 22px 22px}
#modal-box .mhead,#modal-box .mrow{display:grid;grid-template-columns:1.3fr 1fr 60px;gap:12px;align-items:center}
#modal-box .mhead{font-size:11.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:8px 4px;border-bottom:1px solid var(--border)}
#modal-box .mrow{padding:12px 4px;border-bottom:1px solid var(--border-2);font-size:13px;color:var(--text)}
#modal-box .mrow:last-child{border-bottom:none}
#modal-box .mrow-phone{color:var(--accent);font-weight:700}
#modal-box .mrow-wait{font-weight:700}
#modal-box .mrow-mgr{color:var(--muted)}
#modal-box .mrow-pot{font-weight:700}
#modal-box .mrow-crm{font-size:12px;color:var(--accent);font-weight:700}
@media (max-width:640px){
  #modal-box .mhead{display:none}
  #modal-box .mrow{grid-template-columns:1fr 1fr;gap:6px 12px;padding:12px 4px}
  #modal-box .mrow-crm{grid-column:1/-1;text-align:right}
}

details.panel>summary{list-style:none}
details.panel>summary::-webkit-details-marker{display:none}
details.panel>summary .det-arrow{
  display:inline-block;transition:transform .2s ease;font-size:11.5px;margin-left:auto;
}
details.panel[open]>summary .det-arrow{transform:rotate(90deg)}

/* Tamagochi */
.tama-stage{
  background:#08080e;
  border-radius:var(--r);
  min-height:360px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:32px 20px;gap:16px;
  position:relative;overflow:hidden;
  background-image:radial-gradient(circle at 20% 30%,rgba(124,140,255,.18),transparent 45%),
                   radial-gradient(circle at 80% 70%,rgba(180,160,255,.12),transparent 45%),
                   #08080e;
}
.tama-hp{width:200px;height:8px;background:rgba(255,255,255,.1);border-radius:20px;overflow:hidden}
.tama-hp-fill{height:100%;width:78%;background:linear-gradient(90deg,var(--success),#38d9c0);border-radius:20px}
.tama-name{font-size:13px;font-weight:700;color:#fff;letter-spacing:.4px}
.tama-mood{font-size:12px;color:rgba(255,255,255,.6);text-align:center;max-width:280px;line-height:1.6}
.tama-pet{font-size:84px;line-height:1;filter:drop-shadow(0 6px 30px rgba(124,140,255,.5))}
.tama-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border-2)}
.tama-stat{background:var(--surface-2);padding:14px;text-align:center}
.tama-stat-v{font-size:22px;font-weight:800;letter-spacing:-.02em;font-family:'JetBrains Mono',monospace}
.tama-stat-v.--accent{color:var(--accent)}
.tama-stat-v.--success{color:var(--success)}
.tama-stat-v.--purple{color:var(--purple)}
.tama-stat-v.--cyan{color:#38d9c0}
.tama-stat-l{font-size:11.5px;color:var(--muted);margin-top:3px;font-weight:500}
.tama-history{display:flex;gap:4px;flex-wrap:wrap;padding:4px 0}
.tama-dot{width:12px;height:12px;border-radius:3px;background:var(--surface-3)}
.tama-dot.--ok{background:var(--success)}
.tama-dot.--warn{background:var(--warn)}
.tama-dot.--off{background:var(--danger-soft-2)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;
  background:rgba(255,255,255,.08);color:#fff;
  border:1px solid rgba(255,255,255,.14);
  border-radius:10px;
  font-size:12.5px;font-weight:600;
  transition:.15s;
}
.btn-ghost:hover{background:rgba(255,255,255,.14)}

/* Responsive */
@media (max-width:1200px){
  .funnel-grid{grid-template-columns:repeat(3,1fr)}
  .kpi-hero{grid-column:span 3;order:-1}
  .team-metrics{grid-template-columns:repeat(4,1fr)}
  #analytics-kpi{grid-template-columns:repeat(3,1fr)!important}
}
@media (max-width:1200px){
  .sg-5{grid-template-columns:repeat(3,1fr)}
  .tama-stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .app{grid-template-columns:1fr}
  .sg-3,.sg-5{grid-template-columns:1fr}
  .qa-zones{grid-template-columns:1fr}
  .sidebar{position:fixed;transform:translateX(-100%);z-index:20;width:260px;transition:.25s}
  .sidebar.open{transform:translateX(0)}
  .topbar{padding:14px 16px}
  .topbar-search{display:none}
  .screen-wrap{padding:20px 16px 32px}
  .funnel-grid{grid-template-columns:repeat(2,1fr)}
  .kpi-hero{grid-column:span 2}
  .team-grid{grid-template-columns:1fr}
  .team-metrics{grid-template-columns:repeat(4,1fr)}
  #analytics-kpi{grid-template-columns:repeat(2,1fr)!important}
  .lead-row,.lead-head{grid-template-columns:1fr}
  #hot-leads-list .lead-row{grid-template-columns:1fr}
  .lead-head{display:none}
  .lead-row{padding:16px}
  .att-item{flex-wrap:wrap}
  .att-actions{width:100%}
  .burger{display:grid !important}
}
.burger{
  display:none;width:40px;height:40px;border-radius:12px;
  background:var(--surface-3);place-items:center;color:var(--text);
}
@media (max-width:600px){
  .funnel-grid{grid-template-columns:1fr}
  .kpi-hero{grid-column:span 1}
  .team-metrics{grid-template-columns:repeat(2,1fr)}
}

/* v29 · оживление (toast, hover, transitions) */
.toast-stack{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{
  min-width:260px;max-width:460px;
  background:var(--surface);color:var(--text);
  border:1px solid var(--border);border-radius:14px;
  box-shadow:var(--shadow-lg);
  padding:12px 16px;font-size:13px;font-weight:600;line-height:1.45;
  opacity:0;transform:translateY(12px);
  transition:opacity .2s ease, transform .2s ease;
  pointer-events:auto;
  display:flex;align-items:flex-start;gap:10px;
}
.toast.is-show{opacity:1;transform:translateY(0)}
.toast.--success{border-color:var(--success);box-shadow:0 8px 24px rgba(16,185,129,.18)}
.toast.--warn{border-color:var(--warn);box-shadow:0 8px 24px rgba(245,158,11,.18)}
.toast.--danger{border-color:var(--danger);box-shadow:0 8px 24px rgba(244,63,94,.18)}
.toast.--info{border-color:var(--accent)}
.toast-ic{flex-shrink:0;font-size:15px;line-height:1.1;margin-top:1px}
.toast-body{flex:1;min-width:0;white-space:pre-wrap;word-break:break-word}

/* hover на кликабельных блоках */
.kpi-card[onclick]{transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
.kpi-card[onclick]:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--accent)}
.team-card[onclick]{transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
.team-card[onclick]:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--accent-soft-2)}
.team-card--finished { opacity: .55; }
.team-card-finished { font-size: 11px; color: var(--muted); margin-top: 4px; }
.att-item[onclick]{transition:transform .12s ease, box-shadow .12s ease}
.att-item[onclick]:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.task-item[onclick]{cursor:pointer;transition:background-color .12s ease, box-shadow .12s ease}
.task-item[onclick]:hover{background:var(--surface-2);box-shadow:var(--shadow-sm)}
.lead-row[onclick]{cursor:pointer;transition:background-color .12s ease}
.lead-row[onclick]:hover{background:var(--surface-2)}
.team-metric[title]{cursor:help}
.metric-box[onclick]{cursor:pointer;transition:transform .12s ease}
.metric-box[onclick]:hover{transform:translateY(-1px)}
.chip[onclick]{cursor:pointer}
.lead-phone{cursor:pointer;transition:color .12s ease}
.lead-phone:hover{color:var(--accent)}

/* Theme toggle (в сайдбаре) */
.theme-toggle{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;margin:0 0 8px;
  border:1px solid var(--border);border-radius:12px;
  background:var(--surface-2);cursor:pointer;
  transition:background-color .15s ease, border-color .15s ease;
}
.theme-toggle:hover{background:var(--surface-3)}
.theme-toggle-ic{font-size:14px;line-height:1}
.theme-toggle-label{font-size:13px;font-weight:600;color:var(--text-2);flex:1}
.theme-toggle-track{
  position:relative;width:32px;height:18px;border-radius:999px;
  background:var(--border);
  transition:background-color .2s ease;
  flex-shrink:0;
}
.theme-toggle-thumb{
  position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;
  background:#fff;box-shadow:0 1px 3px rgba(15,23,42,.2);
  transition:transform .2s ease;
}
[data-theme="dark"] .theme-toggle-track{background:var(--accent)}
[data-theme="dark"] .theme-toggle-thumb{transform:translateX(14px)}

.live-chip{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:2px 8px;
  background:rgba(34, 197, 94, .18);
  color:#22C55E;
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  border-radius:999px;
  line-height:1;
}
.live-dot{
  width:7px;height:7px;
  border-radius:50%;
  background:#22C55E;
  box-shadow:0 0 0 3px rgba(34, 197, 94, .25), 0 0 10px rgba(34, 197, 94, .6);
  animation:pulse 1.6s infinite;
}
.nav-item.active .live-chip{
  background:rgba(255,255,255,.22);
  color:#fff;
}
.nav-item.active .live-dot{
  background:#fff;
  box-shadow:0 0 0 3px rgba(255,255,255,.35), 0 0 10px rgba(255,255,255,.7);
}

/* === Onboarding overlay === */
.onb-overlay{position:fixed;inset:0;background:transparent;z-index:9998;display:none}
.onb-overlay.active{display:block}
.onb-spotlight{position:fixed;border:2px solid var(--accent,#7C8CFF);border-radius:14px;box-shadow:0 0 0 9999px rgba(0,0,0,.35),0 0 0 4px rgba(124,140,255,.25);z-index:9999;pointer-events:none;transition:all .35s cubic-bezier(.2,.8,.2,1)}
.onb-tip{position:fixed;z-index:10000;background:var(--bg,#15171C);color:var(--text,#E8EAED);border:1px solid var(--border,#2F343D);border-radius:12px;padding:14px 18px;max-width:420px;box-shadow:0 16px 48px rgba(0,0,0,.5)}
.onb-tip-title{font-size:13px;font-weight:700;margin-bottom:6px;color:var(--text)}
.onb-tip-text{font-size:12.5px;color:var(--muted);line-height:1.5;margin-bottom:12px}
.onb-tip-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}
.onb-tip .btn-s,.onb-tip .btn-primary{font-size:12px;padding:6px 14px}
.onb-counter{font-size:11px;color:var(--muted);margin-right:auto}

/* Chat modal — restored from v29: opens /chat in iframe overlay */
#chat-modal{display:none;position:fixed;inset:0;background:rgba(15,23,42,.65);z-index:9999;align-items:center;justify-content:center;backdrop-filter:blur(8px);padding:12px}
#chat-modal.open{display:flex}
#chat-modal-box{width:min(980px,96vw);height:min(680px,92vh);border-radius:18px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.55);background:#1e293b}
#chat-modal-box iframe{width:100%;height:100%;border:none}

/* Phase 3 — block placeholders */
[data-block][data-state="loading"] .block-skeleton{
  display:inline-block;padding:12px 16px;color:var(--muted);font-size:13px;
  opacity:.7;animation:ikm-pulse 1.4s ease-in-out infinite;
}
[data-block][data-state="empty"] .block-empty{
  padding:12px 16px;color:var(--muted);font-size:13px;
}
[data-block][data-state="error"] .block-error{
  padding:12px 16px;color:var(--danger);font-size:13px;
}
[data-block][data-state="error"] .block-error button{
  margin-left:8px;padding:4px 10px;border:1px solid var(--danger);
  background:transparent;color:var(--danger);border-radius:6px;cursor:pointer;
  font:inherit;
}
@keyframes ikm-pulse{0%,100%{opacity:.5}50%{opacity:1}}
/* Phase 3 — score sparkline */
.score-spark{display:flex;gap:3px;align-items:flex-end;height:40px}
.spark-bar{flex:1;background:var(--accent);border-radius:2px;min-height:2px}
/* ───────── KB · База знаний (screen-knowledge) ───────── */













































/* ───── KB Quiz modal ───── */
