/* Knowi GTM Agent — design system, themed to match Knowi Agentic BI.
   Tokens as CSS vars (primitive -> semantic), light + dark themes, responsive.
   Untitled-UI gray scale + Knowi orange primary (#f28c37) + purple AI accent (#7f56d9).
   Type: DM Sans (body/UI) + Inter (fallback) + a mono for numbers/code.
   NOTE: var NAMES are preserved for backward compat with views/components/chart.js.
   The "blue/orange/green/.../slate" primitive names keep their semantic role but
   their VALUES are remapped to the Knowi palette. */

/* ---------- tokens: primitives ---------- */
:root {
  /* ORANGE = Knowi brand primary. The legacy "blue-*" ramp is retargeted to orange
     so every place that referenced --primary/--blue reads as Knowi orange. */
  --blue-50:rgba(242,140,55,.08); --blue-100:rgba(242,140,55,.14); --blue-200:#fcd9b6; --blue-400:#f9a866;
  --blue-500:#f28c37; --blue-600:#f28c37; --blue-700:#c2410c; --blue-900:#7c2d12;
  --orange-500:#f28c37; --orange-600:#fb6514;
  /* AI / agentic accent = purple */
  --violet-500:#7f56d9; --violet-400:#9e77ed; --violet-600:#6941c6;
  --green-500:#12b76a; --green-600:#047857; --green-bg:#ecfdf5;
  --amber-500:#f79009; --amber-600:#b54708; --amber-bg:#fef3c7;
  --red-500:#f04438; --red-600:#d92d20; --red-bg:#fef3f2;
  /* Untitled-UI neutral ramp (kept under the "slate-*" names) */
  --slate-50:#f9fafb; --slate-100:#f2f4f7; --slate-200:#e4e7ec; --slate-300:#d0d5dd;
  --slate-400:#98a2b3; --slate-500:#667085; --slate-600:#475467; --slate-700:#344054;
  --slate-800:#1d2939; --slate-900:#101828; --slate-950:#0c111d;

  --radius:8px; --radius-sm:6px; --radius-lg:12px;
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:20px;
  --space-6:24px; --space-8:32px;
  --font-sans:'DM Sans','Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-mono:'DM Mono',ui-monospace,'SF Mono',Menlo,monospace;
  /* soft Untitled-UI shadows */
  --shadow-sm:0 1px 2px rgba(16,24,40,.05);
  --shadow:0 1px 3px rgba(16,24,40,.10),0 1px 2px rgba(16,24,40,.06);
  --shadow-lg:0 12px 16px -4px rgba(16,24,40,.10),0 4px 6px -2px rgba(16,24,40,.05);
  --tx:160ms cubic-bezier(.4,0,.2,1);
  /* Knowi signature AI gradient (used sparingly for AI/brand flourishes) */
  --brand-gradient:linear-gradient(90deg,#7f56d9 0%,#9e77ed 50%,#7f56d9 100%);
  --brand-gradient-135:linear-gradient(135deg,#7f56d9 0%,#9e77ed 100%);
}

/* ---------- semantic: light (default) ---------- */
:root {
  --bg:var(--slate-50); --surface:#ffffff; --surface-2:var(--slate-50);
  --surface-3:var(--slate-100); --border:var(--slate-200); --border-strong:var(--slate-300);
  --text:var(--slate-900); --text-2:var(--slate-600); --text-3:var(--slate-400);
  /* primary = orange brand. --primary is the AA-safe deep orange used for TEXT,
     links, borders and active states; --primary-bright is the vivid Knowi orange
     reserved for fills / accent rails / soft tints. */
  --primary:#c2410c; --primary-strong:#9a3412; --primary-soft:rgba(242,140,55,.08);
  --primary-bright:var(--orange-500); --on-primary:#ffffff;
  /* CTA stays orange (single brand action color) */
  --cta:var(--orange-500); --cta-strong:var(--orange-600);
  /* AI accent (purple) — semantic alias for agentic flourishes */
  --accent-ai:var(--violet-500); --accent-ai-strong:var(--violet-600); --accent-ai-soft:#f4ebff;
  --focus:var(--orange-500); --sidebar:#ffffff; --sidebar-text:var(--slate-600);
  --scrim:rgba(16,24,40,.50);
}
/* ---------- semantic: dark (Knowi orange/purple on dark slate) ---------- */
:root[data-theme="dark"] {
  --bg:#0c111d; --surface:#151b27; --surface-2:#101622; --surface-3:#1d2535;
  --border:#26303f; --border-strong:#384354;
  --text:#f5f7fa; --text-2:#aeb9cc; --text-3:#6c7689;
  /* primary stays the Knowi orange, slightly lifted for contrast on dark */
  --primary:#f7a766; --primary-strong:#f28c37; --primary-soft:rgba(242,140,55,.16);
  --primary-bright:#f28c37; --on-primary:#1a1206;
  --cta:#f7a766; --cta-strong:#f28c37;
  --accent-ai:#9e77ed; --accent-ai-strong:#b692f6; --accent-ai-soft:#241b3a;
  --focus:#f7a766; --sidebar:#101622; --sidebar-text:#aeb9cc;
  --scrim:rgba(8,11,18,.66);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4); --shadow:0 1px 3px rgba(0,0,0,.5);
  --shadow-lg:0 16px 40px rgba(0,0,0,.6);
}

/* ---------- reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
/* Default size for inline SVG icons used inside text/links/chips/cells. Components
   that need a specific size (nav, kpi, btn, state) override below. Without this,
   raw <svg> with no width/height balloons to its viewBox default. */
svg{width:16px;height:16px;flex:none;vertical-align:-3px}
a svg,.chip svg,.sc-rec svg,td svg,dd svg,.help svg,.mb svg,.evi a svg,.tl-purpose svg{width:14px;height:14px}
.mode-badge svg,.badge svg{width:13px;height:13px}
body{
  margin:0;font-family:var(--font-sans);font-size:14px;line-height:1.55;
  color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{margin:0;font-weight:600;line-height:1.25}
h1{font-size:20px} h2{font-size:16px} h3{font-size:14px}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit}
code,kbd,.mono,.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:4px}
::selection{background:rgba(242,140,55,.22);color:var(--slate-900)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:8px;top:-48px;background:var(--primary);color:#fff;padding:8px 14px;border-radius:6px;z-index:200;transition:top var(--tx)}
.skip-link:focus{top:8px}

/* ---------- app shell ---------- */
#app{min-height:100dvh}
.layout{display:grid;grid-template-columns:236px 1fr;grid-template-rows:56px 1fr;
  grid-template-areas:"sidebar topbar" "sidebar main";min-height:100dvh}

/* top bar */
.topbar{grid-area:topbar;display:flex;align-items:center;gap:var(--space-4);
  padding:0 var(--space-5);background:var(--surface);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:30}
.topbar .crumb{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}
.topbar .crumb .sub{color:var(--text-3);font-weight:400}
.topbar .spacer{flex:1}
.topbar .who{display:flex;align-items:center;gap:8px;color:var(--text-2);font-size:13px}
.topbar .avatar{width:28px;height:28px;border-radius:50%;background:var(--brand-gradient-135);color:#fff;
  display:grid;place-items:center;font-weight:600;font-size:12px}

/* mode badge — prominent proof that nothing real is sent */
.mode-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);
  font-size:11.5px;font-weight:600;letter-spacing:.02em;padding:5px 11px;border-radius:999px;
  border:1px solid transparent;white-space:nowrap}
.mode-badge .dot{width:8px;height:8px;border-radius:50%;background:currentColor;
  box-shadow:0 0 0 3px color-mix(in srgb,currentColor 22%,transparent)}
.mode-badge.mock{color:var(--green-600);background:var(--green-bg);border-color:color-mix(in srgb,var(--green-500) 35%,transparent)}
:root[data-theme="dark"] .mode-badge.mock{background:#0e2a1c;color:#4ade80}
.mode-badge.live{color:var(--red-600);background:var(--red-bg);border-color:color-mix(in srgb,var(--red-500) 35%,transparent)}

/* sidebar */
.sidebar{grid-area:sidebar;background:var(--sidebar);border-right:1px solid var(--border);
  display:flex;flex-direction:column;position:sticky;top:0;height:100dvh;overflow-y:auto}
.brand{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--border)}
.brand .logo{width:30px;height:30px;border-radius:8px;background:var(--brand-gradient-135);
  display:grid;place-items:center;color:#fff;font-weight:700;font-family:var(--font-sans);font-size:15px;flex:none;
  box-shadow:0 1px 2px rgba(16,24,40,.12)}
.brand .name{font-weight:700;font-size:14px;letter-spacing:-.01em;line-height:1.1}
.brand .name small{display:block;font-weight:400;font-size:11px;color:var(--text-3)}
.nav{padding:10px 10px;display:flex;flex-direction:column;gap:2px}
.nav .section{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);
  font-weight:600;padding:14px 10px 6px}
.nav a{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);
  color:var(--sidebar-text);font-size:13.5px;font-weight:500;transition:background var(--tx),color var(--tx);
  text-decoration:none;position:relative}
.nav a:hover{background:var(--surface-3);color:var(--text)}
.nav a.active{background:var(--primary-soft);color:var(--primary-strong);font-weight:600}
.nav a.active::before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;
  border-radius:0 3px 3px 0;background:var(--primary-bright)}
.nav a svg{width:17px;height:17px;flex:none;stroke-width:1.9}
.nav .count{margin-left:auto;font-family:var(--font-mono);font-size:11px;background:#c2410c;
  color:#fff;border-radius:999px;padding:1px 7px;font-weight:600}
:root[data-theme="dark"] .nav .count{background:var(--orange-600)}
.sidebar .foot{margin-top:auto;padding:14px 16px;border-top:1px solid var(--border);font-size:11.5px;color:var(--text-3)}

/* main */
.main{grid-area:main;padding:var(--space-6);max-width:1500px;width:100%;overflow-x:hidden}
.view-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:var(--space-5);flex-wrap:wrap}
.view-head .titles h1{margin-bottom:3px}
.view-head .titles p{margin:0;color:var(--text-2);font-size:13px}
.view-head .actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;
  font-size:13px;font-weight:600;line-height:1;padding:9px 14px;border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);background:var(--surface);color:var(--text);
  transition:background var(--tx),border-color var(--tx),transform var(--tx),box-shadow var(--tx);
  min-height:36px;white-space:nowrap}
.btn:hover{background:var(--surface-3);border-color:var(--text-3)}
.btn:active{transform:translateY(1px)}
.btn svg{width:16px;height:16px;flex:none}
/* Orange fills with white labels: use the deep Knowi orange (#c2410c) so small
   button text clears WCAG AA (4.5:1). Bright #f28c37 is reserved for accents/tints. */
.btn-primary{background:#c2410c;border-color:#c2410c;color:#fff;box-shadow:0 1px 2px rgba(16,24,40,.08)}
.btn-primary:hover{background:#9a3412;border-color:#9a3412}
.btn-cta{background:#c2410c;border-color:#c2410c;color:#fff;box-shadow:0 1px 2px rgba(16,24,40,.08)}
.btn-cta:hover{background:#9a3412;border-color:#9a3412}
:root[data-theme="dark"] .btn-primary,:root[data-theme="dark"] .btn-cta{background:#f28c37;border-color:#f28c37;color:#1a1206}
:root[data-theme="dark"] .btn-primary:hover,:root[data-theme="dark"] .btn-cta:hover{background:#f7a766;border-color:#f7a766}
.btn-success{background:var(--green-600);border-color:var(--green-600);color:#fff}
.btn-success:hover{filter:brightness(1.05)}
.btn-danger{background:var(--surface);color:var(--red-600);border-color:color-mix(in srgb,var(--red-500) 45%,var(--border))}
.btn-danger:hover{background:var(--red-bg)}
:root[data-theme="dark"] .btn-danger:hover{background:#2a1416}
.btn-ghost{background:transparent;border-color:transparent}
.btn-ghost:hover{background:var(--surface-3)}
.btn-sm{padding:6px 10px;min-height:30px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}
.btn-icon{padding:8px;min-height:36px;min-width:36px}

/* ---------- cards ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm)}
.card-pad{padding:var(--space-5)}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--border)}
.card-head h2{font-size:14px} .card-head .hint{color:var(--text-3);font-size:12px;font-weight:400}
.card-body{padding:18px}

/* KPI cards */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:16px;display:flex;flex-direction:column;gap:6px;transition:border-color var(--tx),box-shadow var(--tx)}
.kpi:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}
.kpi .label{font-size:11.5px;color:var(--text-2);font-weight:500;text-transform:uppercase;letter-spacing:.03em;
  display:flex;align-items:center;gap:6px}
.kpi .label svg{width:14px;height:14px;color:var(--text-3)}
.kpi .value{font-family:var(--font-mono);font-size:26px;font-weight:600;line-height:1;letter-spacing:-.02em}
.kpi .sub{font-size:11.5px;color:var(--text-3)}
.kpi.accent .value{color:#c2410c}
.kpi.cta .value{color:#c2410c}
:root[data-theme="dark"] .kpi.accent .value,:root[data-theme="dark"] .kpi.cta .value{color:#f7a766}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.stack{display:flex;flex-direction:column;gap:16px}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ---------- tables ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg)}
table.data{width:100%;border-collapse:collapse;font-size:13px}
table.data th{text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--text-2);padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface-2);
  position:sticky;top:0;white-space:nowrap}
table.data td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
table.data tr:last-child td{border-bottom:none}
table.data tbody tr{transition:background var(--tx)}
table.data tbody tr.clickable{cursor:pointer}
table.data tbody tr.clickable:hover{background:var(--surface-3)}
table.data td .num,table.data th.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
td.right,th.right{text-align:right}
.cell-strong{font-weight:600}
.cell-muted{color:var(--text-3)}
.cell-domain{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}

/* ---------- badges ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;
  padding:3px 9px;border-radius:999px;line-height:1.4;white-space:nowrap;
  border:1px solid transparent;font-family:var(--font-sans)}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.gray{color:var(--slate-600);background:var(--slate-100);border-color:var(--slate-200)}
:root[data-theme="dark"] .badge.gray{color:var(--slate-300);background:#1c2533;border-color:#2a3545}
/* blue stays a true info-blue so it reads distinct from the orange brand */
.badge.blue{color:#175cd3;background:#eff8ff;border-color:#b2ddff}
:root[data-theme="dark"] .badge.blue{color:#84caff;background:#102a43;border-color:#1d4574}
.badge.green{color:var(--green-600);background:var(--green-bg);border-color:#a6f4c5}
:root[data-theme="dark"] .badge.green{color:#3ccb7f;background:#0c2a1c;border-color:#15452f}
.badge.amber{color:var(--amber-600);background:var(--amber-bg);border-color:#fec84b}
:root[data-theme="dark"] .badge.amber{color:#fdb022;background:#2c2410;border-color:#4a3d18}
.badge.red{color:var(--red-600);background:var(--red-bg);border-color:#fecdca}
:root[data-theme="dark"] .badge.red{color:#f97066;background:#2a1414;border-color:#4a1f1d}
/* orange tone for brand-tinted pills (optional) */
.badge.orange{color:var(--orange-600);background:rgba(242,140,55,.10);border-color:rgba(242,140,55,.30)}
:root[data-theme="dark"] .badge.orange{color:#f7a766;background:rgba(242,140,55,.14);border-color:rgba(242,140,55,.32)}
.badge.violet{color:var(--violet-600);background:#f4ebff;border-color:#e9d7fe}
:root[data-theme="dark"] .badge.violet{color:#b692f6;background:#1f1733;border-color:#352a55}

/* ---------- score bars ---------- */
.score-bars{display:flex;flex-direction:column;gap:9px}
.score-row{display:grid;grid-template-columns:160px 1fr 30px;gap:12px;align-items:center;font-size:12.5px}
.score-row .crit{color:var(--text-2);font-weight:500}
.score-track{height:8px;border-radius:999px;background:var(--surface-3);overflow:hidden;position:relative}
.score-fill{display:block;height:100%;border-radius:999px;transition:width 420ms cubic-bezier(.4,0,.2,1)}
.score-fill.s0{background:var(--red-500);width:8%}
.score-fill.s1{background:var(--amber-500);width:50%}
.score-fill.s2{background:var(--green-500);width:100%}
.score-row .pts{font-family:var(--font-mono);font-weight:600;text-align:right;font-size:12px}
.score-total{display:flex;align-items:baseline;gap:8px;margin-bottom:14px}
.score-total .big{font-family:var(--font-mono);font-size:34px;font-weight:700;line-height:1}
.score-total .of{color:var(--text-3);font-family:var(--font-mono);font-size:16px}

/* funnel / mini-bars */
.funnel{display:flex;flex-direction:column;gap:8px}
.funnel-row{display:grid;grid-template-columns:120px 1fr 44px;gap:10px;align-items:center;font-size:12.5px}
.funnel-row .lbl{color:var(--text-2);text-transform:capitalize}
.funnel-bar{height:22px;border-radius:6px;background:var(--surface-3);overflow:hidden}
.funnel-bar > span{display:block;height:100%;background:linear-gradient(90deg,#f7a766,#f28c37);
  border-radius:6px;min-width:2px;transition:width 420ms cubic-bezier(.4,0,.2,1)}
.funnel-row .n{font-family:var(--font-mono);text-align:right;font-weight:600}

/* ---------- slack-style approval card ---------- */
.slack-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--tx),border-color var(--tx);display:flex;flex-direction:column}
.slack-card:hover{box-shadow:var(--shadow)}
.slack-card .sc-rail{border-left:4px solid var(--primary-bright)}
.slack-card.kind-account .sc-rail{border-left-color:#2e90fa}
.slack-card.kind-message .sc-rail{border-left-color:var(--accent-ai)}
.slack-card.kind-reply .sc-rail{border-left-color:var(--green-500)}
.sc-rail{padding:16px 18px;flex:1}
.sc-top{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.sc-channel{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3)}
.sc-title{font-weight:700;font-size:15px;margin-bottom:6px}
.sc-meta{display:flex;flex-direction:column;gap:4px;font-size:12.5px;color:var(--text-2);margin-bottom:10px}
.sc-meta b{color:var(--text);font-weight:600}
.sc-summary{font-size:13px;color:var(--text);background:var(--surface-2);border:1px solid var(--border);
  border-radius:8px;padding:10px 12px;margin-bottom:12px;white-space:pre-wrap}
.sc-rec{font-size:12.5px;color:var(--text-2);margin-bottom:12px}
.sc-actions{display:flex;gap:8px;flex-wrap:wrap;padding:12px 18px;border-top:1px solid var(--border);background:var(--surface-2)}

/* ---------- markdown rendering ---------- */
.md{font-size:13.5px;line-height:1.65;color:var(--text)}
.md h1{font-size:18px;margin:4px 0 12px} .md h2{font-size:15px;margin:20px 0 8px;
  padding-bottom:5px;border-bottom:1px solid var(--border)}
.md h3{font-size:13.5px;margin:14px 0 6px;color:var(--text-2)}
.md p{margin:0 0 10px} .md ul,.md ol{margin:0 0 12px;padding-left:22px}
.md li{margin:3px 0} .md strong{font-weight:600;color:var(--text)}
.md a{word-break:break-word} .md code{background:var(--surface-3);padding:1px 5px;border-radius:4px;font-size:12px}
.md hr{border:none;border-top:1px solid var(--border);margin:16px 0}
.md table{border-collapse:collapse;width:100%;margin:0 0 12px;font-size:12.5px}
.md th,.md td{border:1px solid var(--border);padding:6px 10px;text-align:left}

/* ---------- detail layout ---------- */
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:16px;overflow-x:auto}
.tab{padding:9px 14px;font-size:13px;font-weight:600;color:var(--text-2);cursor:pointer;
  border:none;background:none;border-bottom:2px solid transparent;transition:color var(--tx),border-color var(--tx);white-space:nowrap}
.tab:hover{color:var(--text)}
.tab.active{color:var(--primary);border-bottom-color:var(--primary-bright);border-bottom-width:2.5px}
.kv{display:grid;grid-template-columns:max-content 1fr;gap:6px 16px;font-size:13px}
.kv dt{color:var(--text-2);font-weight:500} .kv dd{margin:0;color:var(--text)}

/* evidence / message items */
.evi{border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:10px;background:var(--surface-2)}
.evi-head{display:flex;align-items:center;gap:8px;margin-bottom:5px;flex-wrap:wrap}
.evi-head .lbl{font-weight:600;font-size:13px}
.evi p{margin:4px 0 0;font-size:12.5px;color:var(--text-2)}
.evi a{font-size:12px;font-family:var(--font-mono);word-break:break-all}
.msg-item{border:1px solid var(--border);border-radius:8px;margin-bottom:10px;overflow:hidden}
.msg-item .mh{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface-2);
  border-bottom:1px solid var(--border);flex-wrap:wrap}
.msg-item .mh .subj{font-weight:600;font-size:13px}
.msg-item .mb{padding:12px 14px;white-space:pre-wrap;font-size:12.5px;color:var(--text-2);line-height:1.6}

/* timeline (cadence) */
.timeline{position:relative;padding-left:26px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--border)}
.tl-item{position:relative;padding:0 0 16px}
.tl-item::before{content:"";position:absolute;left:-21px;top:3px;width:12px;height:12px;border-radius:50%;
  background:var(--surface);border:2px solid var(--border-strong)}
.tl-item.done::before{background:var(--green-500);border-color:var(--green-500)}
.tl-item.replied::before{background:#2e90fa;border-color:#2e90fa}
.tl-head{display:flex;align-items:center;gap:8px;font-size:12.5px;margin-bottom:2px;flex-wrap:wrap}
.tl-head .day{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}
.tl-head .step{font-weight:600;text-transform:capitalize}
.tl-purpose{font-size:12px;color:var(--text-2)}

/* ---------- forms ---------- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:12.5px;font-weight:600;color:var(--text)}
.field label.check{display:flex;align-items:center;gap:8px;font-weight:500;cursor:pointer;margin-top:24px}
.field label.check input{width:auto;margin:0}
.field .help{font-size:11.5px;color:var(--text-3)}
.field .err{font-size:12px;color:var(--red-600);display:flex;align-items:center;gap:5px}
input[type=text],input[type=email],input[type=password],input[type=search],textarea,select{
  width:100%;font-family:inherit;font-size:13.5px;color:var(--text);background:var(--surface);
  border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:9px 11px;
  transition:border-color var(--tx),box-shadow var(--tx);min-height:38px}
textarea{min-height:90px;resize:vertical;line-height:1.6}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--focus);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--focus) 20%,transparent)}
input::placeholder,textarea::placeholder{color:var(--text-3)}
select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
.filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.filters select,.filters input{min-height:36px;width:auto;min-width:150px}
.filters .grow{flex:1;min-width:200px}

/* ---------- states ---------- */
.state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  padding:48px 24px;text-align:center;color:var(--text-2)}
.state svg{width:40px;height:40px;color:var(--text-3)}
.state h3{font-size:15px;color:var(--text)}
.state p{margin:0;font-size:13px;max-width:380px}
.state.error{color:var(--red-600)} .state.error svg{color:var(--red-500)}
.spinner{width:22px;height:22px;border:2.5px solid var(--border-strong);border-top-color:var(--primary);
  border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{background:linear-gradient(90deg,var(--surface-3) 25%,var(--surface-2) 50%,var(--surface-3) 75%);
  background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:6px}
@keyframes shimmer{to{background-position:-200% 0}}
.sk-row{height:44px;margin-bottom:8px}
.inline-spin{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;
  border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px}

/* ---------- toast ---------- */
.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:120;max-width:360px}
.toast{display:flex;gap:10px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);
  border-left:3px solid var(--primary);border-radius:8px;padding:12px 14px;box-shadow:var(--shadow-lg);
  font-size:13px;animation:toastIn .22s ease-out}
.toast.success{border-left-color:var(--green-500)} .toast.error{border-left-color:var(--red-500)}
.toast svg{width:18px;height:18px;flex:none;margin-top:1px}
.toast.success svg{color:var(--green-500)} .toast.error svg{color:var(--red-500)} .toast.info svg{color:var(--primary)}
.toast .tx-body{flex:1} .toast .tx-body b{display:block;margin-bottom:1px}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}

/* ---------- modal ---------- */
.modal-scrim{position:fixed;inset:0;background:var(--scrim);z-index:100;display:grid;place-items:center;
  padding:20px;animation:fade .15s ease-out}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:88dvh;overflow:auto;animation:pop .18s cubic-bezier(.34,1.4,.64,1)}
.modal.lg{max-width:680px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface)}
.modal-head h2{font-size:15px}
.modal-body{padding:20px} .modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}

/* ---------- login ---------- */
.auth-wrap{min-height:100dvh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1100px 500px at 50% -10%,color-mix(in srgb,var(--primary) 14%,var(--bg)),var(--bg))}
.auth-card{width:100%;max-width:400px}
.auth-brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:24px;text-align:center}
.auth-brand .logo{width:52px;height:52px;border-radius:14px;background:var(--brand-gradient-135);
  display:grid;place-items:center;color:#fff;font-weight:700;font-family:var(--font-sans);font-size:24px;
  box-shadow:0 6px 16px rgba(127,86,217,.30)}
.auth-brand h1{font-size:19px} .auth-brand p{margin:0;color:var(--text-2);font-size:13px}
.auth-tabs{display:flex;gap:4px;background:var(--surface-3);padding:4px;border-radius:9px;margin-bottom:20px}
.auth-tabs button{flex:1;padding:8px;border:none;background:none;border-radius:6px;cursor:pointer;
  font-size:13px;font-weight:600;color:var(--text-2);transition:background var(--tx),color var(--tx)}
.auth-tabs button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}
.auth-hint{font-size:11.5px;color:var(--text-3);text-align:center;margin-top:16px;line-height:1.6}

/* chips / pills */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-family:var(--font-mono);
  background:var(--surface-3);border:1px solid var(--border);border-radius:6px;padding:3px 8px;color:var(--text-2)}
.pill-list{display:flex;gap:6px;flex-wrap:wrap}
.theme-toggle{background:none;border:1px solid var(--border);border-radius:8px;padding:7px;cursor:pointer;
  color:var(--text-2);display:grid;place-items:center;min-width:36px;min-height:36px;transition:background var(--tx)}
.theme-toggle:hover{background:var(--surface-3);color:var(--text)}

/* hamburger (mobile) */
.menu-btn{display:none}

/* ---------- responsive ---------- */
@media (max-width:1080px){.detail-grid{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr 1fr}}
@media (max-width:880px){
  .layout{grid-template-columns:1fr;grid-template-areas:"topbar" "main"}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;z-index:60;transform:translateX(-100%);
    transition:transform var(--tx);box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:none}
  .menu-btn{display:grid;place-items:center;background:none;border:1px solid var(--border);border-radius:8px;
    width:36px;height:36px;cursor:pointer;color:var(--text-2)}
  .nav-scrim{position:fixed;inset:0;background:var(--scrim);z-index:55}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .main{padding:var(--space-4)}
  .who .who-name{display:none}
}
@media (max-width:520px){
  .topbar .crumb .sub{display:none}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .score-row{grid-template-columns:110px 1fr 28px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
