/* ═══════════════════════════════════════════════════════
   ForesightAI · Intelligence Console (rose / teal theme)
   ═══════════════════════════════════════════════════════ */
:root {
  --bg:      #0c0a10;
  --surface: #12101a;
  --card:    rgba(18, 16, 28, 0.9);
  --cb:      rgba(255,255,255,0.065);
  --hover:   rgba(255,255,255,0.045);

  /* Primary chrome = rose; secondary = teal (keeps --blue/--cyan names for fewer edits) */
  --blue:   #ec4899; --blue-b: #f9a8d4; --blue-d: rgba(236,72,153,.14);
  --cyan:   #14b8a6; --cyan-d:  rgba(20,184,166,.14);
  --green:  #10B981; --green-d: rgba(16,185,129,.12);
  --amber:  #F59E0B; --amber-d: rgba(245,158,11,.12);
  --red:    #EF4444; --red-d:   rgba(239,68,68,.12);
  --purple: #a78bfa;

  --t1: #f4f1f8; --t2: #9b93ad; --t3: #5c5468;

  --bord:   rgba(255,255,255,.065);
  --bord-hi:rgba(236,72,153,.42);
  --sh:     0 1px 2px rgba(0,0,0,.45), 0 12px 32px rgba(0,0,0,.35);
  --sh-lg:  0 4px 8px rgba(0,0,0,.4), 0 20px 48px rgba(0,0,0,.38);
  --sh-xl:  0 24px 64px rgba(0,0,0,.55);

  --font: 'Sora', system-ui, sans-serif;
  --mono: 'IBM Plex Mono', 'Consolas', monospace;

  --r1: 8px; --r2: 12px; --r3: 16px; --r4: 20px;
  --sw: 228px;
  --th: 60px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--t1);
  min-height: 100vh;
  display: flex;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  line-height: 1.5;
}

/* Ambient radial glow */
body::before, body::after {
  content: ''; position: fixed; border-radius: 50%; pointer-events: none; z-index: 0;
}
body::before { width:780px;height:780px;top:-220px;left:-120px;background:radial-gradient(circle,rgba(236,72,153,.06) 0%,transparent 68%); }
body::after  { width:640px;height:640px;bottom:-180px;right:5%;background:radial-gradient(circle,rgba(20,184,166,.045) 0%,transparent 70%); }

/* Fine dot grid */
.bg-grid {
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(236,72,153,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 85% 70% at 50% 20%,#000 20%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 85% 70% at 50% 20%,#000 20%,transparent 75%);
}

/* Scrollbar */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--t3);border-radius:2px}

/* ═══ GLASS CARD ════════════════════════════════════════ */
.card {
  background: var(--card);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--cb);
  border-radius: var(--r4);
  box-shadow: var(--sh);
  position: relative; overflow: hidden;
  transition: border-color .2s, box-shadow .2s, transform .2s;
}
.card::after {
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent);
  pointer-events:none;
}
.card:hover { border-color: rgba(255,255,255,.11); }

/* ═══ SIDEBAR ════════════════════════════════════════════ */
#sidebar {
  width:var(--sw);min-width:var(--sw);height:100vh;
  position:fixed;top:0;left:0;
  background:linear-gradient(180deg,rgba(14,12,20,.99) 0%,rgba(10,8,16,.98) 100%);
  border-right:1px solid var(--bord);
  box-shadow:inset -1px 0 0 rgba(236,72,153,.06);
  display:flex;flex-direction:column;
  z-index:100;
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}

.logo-area {
  padding:24px 18px 20px;
  display:flex;align-items:center;gap:11px;
  border-bottom:1px solid rgba(255,255,255,.045);
}
.logo-icon {
  width:38px;height:38px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(145deg,#ec4899,#14b8a6);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 1px rgba(236,72,153,.35),0 0 28px rgba(236,72,153,.2);
}
.logo-name { font-size:14px;font-weight:800;letter-spacing:-.025em; }
.logo-sub  { font-size:9px;font-family:var(--mono);color:var(--cyan);letter-spacing:.09em;text-transform:uppercase;margin-top:1px; }

.nav-group-label {
  font-size:9px;font-family:var(--mono);color:var(--t3);
  letter-spacing:.12em;text-transform:uppercase;padding:18px 20px 6px;
}
nav { display:flex;flex-direction:column;gap:2px;padding:0 10px;flex:1; }

.nav-link {
  display:flex;align-items:center;gap:9px;
  padding:9px 12px;border-radius:var(--r2);
  cursor:pointer;font-size:13px;font-weight:500;
  color:var(--t2);background:transparent;
  border:1px solid transparent;font-family:var(--font);
  transition:all .16s;text-align:left;width:100%;position:relative;
}
.nav-link:hover { background:var(--hover);color:var(--t1); }
.nav-link.active { background:var(--blue-d);border-color:rgba(236,72,153,.3);color:var(--blue-b); }
.ni  { width:15px;height:15px;flex-shrink:0;opacity:.8;transition:opacity .16s; }
.nav-link.active .ni { opacity:1; }
.nav-pip {
  width:5px;height:5px;border-radius:50%;
  background:var(--blue);margin-left:auto;
  box-shadow:0 0 8px var(--blue);
  opacity:0;transition:opacity .16s;
}
.nav-link.active .nav-pip { opacity:1; }

.sidebar-foot {
  margin-top:auto;padding:14px 16px 20px;
  border-top:1px solid rgba(255,255,255,.04);
}
.health-row { display:flex;align-items:center;gap:7px;margin-bottom:6px; }
.pulse-dot {
  width:7px;height:7px;border-radius:50%;
  background:var(--green);box-shadow:0 0 8px var(--green);
  animation:pulse 2.2s ease-in-out infinite;flex-shrink:0;display:inline-block;
}
.pulse-dot.sm { width:5px;height:5px; }
.pulse-dot.off{ background:var(--red);box-shadow:0 0 8px var(--red);animation:none; }
.health-lbl { font-size:11px;font-weight:500;color:var(--green); }
.health-lbl.off { color:var(--red); }

.ai-badge {
  display:inline-block;font-size:10px;font-family:var(--mono);
  padding:3px 9px;border-radius:20px;margin-bottom:6px;
  border:1px solid;transition:all .2s;
}
.ai-on  { background:var(--green-d);border-color:rgba(16,185,129,.25);color:var(--green); }
.ai-off { background:var(--amber-d);border-color:rgba(245,158,11,.25);color:var(--amber); }
.sb-time { font-size:10px;font-family:var(--mono);color:var(--t3); }

/* ═══ MAIN ═══════════════════════════════════════════════ */
#main {
  margin-left:var(--sw);flex:1;min-height:100vh;
  display:flex;flex-direction:column;
  position:relative;z-index:1;
  max-width:calc(100vw - var(--sw));
}

#topbar {
  position:sticky;top:0;z-index:50;height:var(--th);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px 0 32px;
  background:rgba(12,10,16,.88);
  border-bottom:1px solid rgba(255,255,255,.05);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}
.tb-crumb { font-size:10px;font-family:var(--mono);color:var(--t3);letter-spacing:.08em; }
.tb-title { font-size:15px;font-weight:700;letter-spacing:-.02em; }
.tb-right { display:flex;align-items:center;gap:8px; }
.tb-chip {
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:20px;
  font-size:10.5px;font-weight:500;font-family:var(--mono);border:1px solid;
  background:rgba(255,255,255,.03);border-color:var(--bord);color:var(--t3);
}
.live-chip { background:var(--green-d);border-color:rgba(16,185,129,.22);color:var(--green); }

.icon-btn {
  display:flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:var(--r2);
  background:rgba(255,255,255,.04);border:1px solid var(--bord);
  color:var(--t2);font-size:12px;font-weight:500;font-family:var(--font);
  cursor:pointer;transition:all .16s;
}
.icon-btn:hover { background:rgba(255,255,255,.07);color:var(--t1); }
.icon-btn.spin svg { animation:spin 1s linear infinite; }

/* ═══ PAGES ═══════════════════════════════════════════════ */
.content { padding:26px 30px 52px;flex:1; }
.page { display:none; }
.page.active { display:block;animation:pageIn .28s ease; }

/* ═══ HERO ════════════════════════════════════════════════ */
.hero {
  padding:36px 40px;margin-bottom:24px;
  display:flex;align-items:center;justify-content:space-between;gap:28px;
  background:linear-gradient(145deg,rgba(22,18,32,.96) 0%,rgba(12,10,18,.88) 55%,rgba(18,14,24,.92) 100%);
  overflow:hidden;
}
.hero::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--blue) 20%,var(--cyan) 50%,var(--blue) 80%,transparent);
  opacity:.85;
}
.hero-left { flex:1; }
.hero-eyebrow {
  display:flex;align-items:center;gap:8px;
  font-size:10.5px;font-family:var(--mono);color:var(--cyan);
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;
}
.hero-h { font-size:29px;font-weight:800;letter-spacing:-.04em;line-height:1.1;margin-bottom:10px; }
.hero-h em { font-style:normal;color:var(--blue-b); }
.hero-p { font-size:13.5px;color:var(--t2);max-width:500px;line-height:1.65;margin-bottom:26px; }
.hero-stats { display:flex;align-items:stretch;flex-wrap:wrap; }
.hs { padding:0 24px; }
.hs:first-child { padding-left:0; }
.hs-val { font-size:22px;font-weight:800;font-family:var(--mono);letter-spacing:-.02em; }
.hs-lbl { font-size:9.5px;font-family:var(--mono);color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin-top:2px; }
.hs-sep { width:1px;background:var(--bord);align-self:stretch;margin:4px 0; }

.hero-orb { width:150px;height:150px;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center; }
.orb-ring { position:absolute;border-radius:50%;border:1px solid;animation:spin 20s linear infinite; }
.r1 { width:100%;height:100%;border-color:rgba(236,72,153,.22); }
.r2 { width:74%;height:74%;animation-duration:14s;animation-direction:reverse;border-color:rgba(20,184,166,.2); }
.r3 { width:49%;height:49%;animation-duration:9s;border-color:rgba(167,139,250,.22); }
.orb-glyph { font-size:20px;font-weight:800;font-family:var(--mono);background:linear-gradient(135deg,var(--blue-b),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;z-index:1; }

/* ═══ OVERVIEW LAYOUT ════════════════════════════════════ */
.ov-layout { display:grid;grid-template-columns:1fr 268px;gap:16px;margin-bottom:16px; }
.sec-label { font-size:10px;font-family:var(--mono);color:var(--t3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:11px; }

.mod-grid { display:grid;grid-template-columns:1fr 1fr;gap:11px; }
.mod-card {
  padding:20px 22px;cursor:pointer;
  transition:all .22s cubic-bezier(.4,0,.2,1);
}
.mod-card:hover { transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(236,72,153,.32); }
.mod-head { display:flex;align-items:center;justify-content:space-between;margin-bottom:12px; }
.mod-icon {
  width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:16px;
}
.mod-tag {
  font-size:9px;font-family:var(--mono);letter-spacing:.1em;
  padding:3px 8px;border-radius:20px;text-transform:uppercase;border:1px solid;
}
.c-blue  .mod-tag, .mod-tag.c-blue  { background:var(--blue-d);color:var(--blue-b);border-color:rgba(236,72,153,.28); }
.c-amber .mod-tag, .mod-tag.c-amber { background:var(--amber-d);color:var(--amber);border-color:rgba(245,158,11,.22); }
.c-red   .mod-tag, .mod-tag.c-red   { background:var(--red-d);color:var(--red);border-color:rgba(239,68,68,.22); }
.c-cyan  .mod-tag, .mod-tag.c-cyan  { background:var(--cyan-d);color:var(--cyan);border-color:rgba(20,184,166,.28); }
.c-blue  .mod-icon { background:var(--blue-d);border:1px solid rgba(236,72,153,.25); }
.c-amber .mod-icon { background:var(--amber-d);border:1px solid rgba(245,158,11,.2); }
.c-red   .mod-icon { background:var(--red-d);border:1px solid rgba(239,68,68,.2); }
.c-cyan  .mod-icon { background:var(--cyan-d);border:1px solid rgba(20,184,166,.25); }
.mod-name { font-size:14px;font-weight:700;letter-spacing:-.01em;margin-bottom:5px; }
.mod-desc { font-size:12px;color:var(--t2);line-height:1.55; }
.mod-cta  { margin-top:13px;font-size:12px;font-weight:700; }
.mod-cta.c-blue { color:var(--blue-b); }
.mod-cta.c-amber { color:var(--amber); }
.mod-cta.c-red   { color:var(--red); }
.mod-cta.c-cyan  { color:var(--cyan); }

/* Perf card */
.perf-card { padding:20px; }
.perf-rows { margin-top:10px; }
.pr { display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px;color:var(--t2); }
.pr:last-child { border-bottom:none; }
.pbar { flex:1;height:3px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden; }
.pfill { height:100%;background:var(--blue);border-radius:2px; }
.pv { font-family:var(--mono);font-size:11px;color:var(--blue-b);font-weight:500;min-width:38px;text-align:right; }

.stack-card { padding:20px 22px; }
.chip-row { display:flex;flex-wrap:wrap;gap:6px; }
.tech-chip {
  padding:4px 11px;border-radius:20px;font-size:11px;font-family:var(--mono);
  background:rgba(255,255,255,.03);border:1px solid var(--bord);color:var(--t2);
  transition:all .16s;cursor:default;
}
.tech-chip:hover { border-color:rgba(236,72,153,.4);color:var(--t1); }

/* ═══ PAGE HEADERS ═══════════════════════════════════════ */
.pg-head { margin-bottom:22px; }
.pg-title { font-size:22px;font-weight:800;letter-spacing:-.03em;margin-bottom:4px; }
.pg-sub   { font-size:13px;color:var(--t2); }

/* ═══ KPI ROW ════════════════════════════════════════════ */
.kpi-row { display:grid;gap:12px;margin-bottom:18px; }
.kpi-4 { grid-template-columns:repeat(4,1fr); }
.kpi {
  padding:18px 20px 16px;
  transition:transform .18s,border-color .18s;
}
.kpi:hover { transform:translateY(-2px);border-color:rgba(255,255,255,.12); }
.kpi-bar { position:absolute;top:0;left:0;right:0;height:2px;opacity:.45;border-radius:var(--r4) var(--r4) 0 0; }
.kpi-lbl { font-size:10px;font-weight:500;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:11px; }
.kpi-val { font-size:26px;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:10px;font-feature-settings:'tnum'; }
.kpi-ft  { display:flex;align-items:center;justify-content:space-between; }
.kpi-sub { font-size:11px;color:var(--t2); }

/* Color aliases */
.c-blue  { color:var(--blue-b); }
.c-cyan  { color:var(--cyan); }
.c-green { color:var(--green); }
.c-amber { color:var(--amber); }
.c-red   { color:var(--red); }

/* ═══ BADGES ═════════════════════════════════════════════ */
.badge {
  font-size:11px;font-weight:600;font-family:var(--mono);
  display:inline-flex;align-items:center;gap:2px;
  padding:2px 7px;border-radius:20px;
}
.badge-up   { background:var(--green-d);color:var(--green); }
.badge-down { background:var(--red-d);color:var(--red); }
.badge-warn { background:var(--amber-d);color:var(--amber); }
.badge-info { background:var(--blue-d);color:var(--blue-b); }

/* ═══ CHART CARDS ════════════════════════════════════════ */
.chart-card { padding:20px 22px;margin-bottom:14px; }
.chart-card.mb0 { margin-bottom:0; }
.chart-hd {
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:18px;gap:12px;flex-wrap:wrap;
}
.chart-title { font-size:13px;font-weight:700;letter-spacing:-.01em;margin-bottom:2px; }
.chart-sub   { font-size:11px;color:var(--t3); }
.cw { position:relative; }
.cw canvas { width:100% !important; }
.h300{height:300px}.h270{height:270px}.h200{height:200px}.h180{height:180px}.h140{height:140px}

/* Legend */
.lgd { display:flex;gap:14px;align-items:center;flex-wrap:wrap; }
.lgd-item { display:flex;align-items:center;gap:6px;font-size:11px;color:var(--t2); }
.lgd-line { width:18px;height:2px;border-radius:1px;flex-shrink:0; }
.lgd-line.blue  { background:var(--blue); }
.lgd-line.cyan  { background:var(--cyan); }
.lgd-line.green { background:var(--green); }
.lgd-line.red   { background:var(--red); }
.lgd-line.dash  { background:none;border-top:2px dashed currentColor; }
.lgd-line.dot   { background:none;border-top:2px dotted currentColor; }
.lgd-line.cyan.dash  { border-color:var(--cyan); }
.lgd-line.blue.dash  { border-color:var(--blue); }
.lgd-line.red.dot    { border-color:var(--red); }
.lgd-band { width:18px;height:8px;border-radius:2px;background:rgba(20,184,166,.14);flex-shrink:0; }

/* ═══ GRIDS ══════════════════════════════════════════════ */
.two-col   { display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px; }
.three-col { display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:14px; }
.col2 { grid-column:span 2; }

/* ═══ TABLE ══════════════════════════════════════════════ */
.tbl-ctrl { display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-left:auto; }
.tbl-wrap { overflow-x:auto; }
.dtable   { width:100%;border-collapse:separate;border-spacing:0 2px;font-size:12.5px; }
.dtable thead th {
  text-align:left;padding:8px 14px;
  font-size:9.5px;font-weight:500;font-family:var(--mono);
  color:var(--t3);letter-spacing:.1em;text-transform:uppercase;
}
.dtable tbody tr { background:rgba(255,255,255,.018);transition:background .13s; }
.dtable tbody tr:hover { background:var(--hover); }
.dtable td {
  padding:11px 14px;vertical-align:middle;
  border-top:1px solid rgba(255,255,255,.028);
  border-bottom:1px solid rgba(255,255,255,.028);
}
.dtable td:first-child { border-left:1px solid rgba(255,255,255,.028);border-radius:var(--r1) 0 0 var(--r1); }
.dtable td:last-child  { border-right:1px solid rgba(255,255,255,.028);border-radius:0 var(--r1) var(--r1) 0; }
.tbl-ld { text-align:center;color:var(--t3);padding:24px !important;font-family:var(--mono);font-size:12px; }

.status-pill { display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid; }
.risk-bar { display:flex;align-items:center;gap:8px; }
.rtrack   { height:4px;border-radius:2px;background:rgba(255,255,255,.06);width:60px;flex-shrink:0;overflow:hidden; }
.rfill    { height:100%;border-radius:2px; }
.rval     { font-size:11.5px;font-family:var(--mono);font-weight:500; }

/* ═══ SEARCH & TABS ══════════════════════════════════════ */
.srch-wrap { position:relative;display:flex;align-items:center; }
.srch-ico  { position:absolute;left:9px;color:var(--t3);pointer-events:none; }
.srch-inp  {
  background:rgba(255,255,255,.04);border:1px solid var(--bord);
  border-radius:var(--r2);padding:7px 11px 7px 28px;
  color:var(--t1);font-size:12px;font-family:var(--font);
  width:168px;transition:all .18s;outline:none;
}
.srch-inp:focus { border-color:var(--bord-hi);background:rgba(255,255,255,.06); }
.srch-inp::placeholder { color:var(--t3); }
.tabs { display:flex;gap:3px;flex-wrap:wrap; }
.tab {
  padding:5px 12px;border-radius:var(--r1);
  font-size:12px;font-weight:500;cursor:pointer;
  background:transparent;border:1px solid transparent;
  color:var(--t2);font-family:var(--font);transition:all .14s;
}
.tab:hover { background:var(--hover);color:var(--t1); }
.tab.active { background:var(--blue-d);border-color:rgba(236,72,153,.35);color:var(--blue-b); }

/* ═══ DOUGHNUT LEGEND ════════════════════════════════════ */
.donut-lgd { display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-top:10px; }
.dl { display:flex;align-items:center;gap:5px;font-size:11px; }
.dl-dot { width:8px;height:8px;border-radius:2px;flex-shrink:0; }
.dl-k { color:var(--t2);flex:1; }
.dl-v { font-family:var(--mono);font-weight:600; }

/* ═══ SCENARIO ═══════════════════════════════════════════ */
.sc-layout { display:grid;grid-template-columns:288px 1fr;gap:18px;align-items:start; }
.sc-right  { display:flex;flex-direction:column;gap:14px; }
.sc-ctrl   { padding:22px; }
.sc-hd     { display:flex;align-items:center;gap:9px;margin-bottom:22px;font-size:14px;font-weight:700;letter-spacing:-.01em; }
.sc-hd-icon {
  width:28px;height:28px;border-radius:var(--r2);
  background:var(--blue-d);border:1px solid rgba(236,72,153,.28);
  display:flex;align-items:center;justify-content:center;font-size:13px;
}

.sl-grp { margin-bottom:20px; }
.sl-head { display:flex;justify-content:space-between;align-items:center;margin-bottom:9px; }
.sl-lbl  { font-size:12.5px;color:var(--t2);font-weight:500; }
.sl-val  { font-size:12.5px;font-weight:700;font-family:var(--mono); }

.sl-track { position:relative;height:6px;background:rgba(255,255,255,.06);border-radius:3px; }
.sl-fill  { position:absolute;top:0;left:0;height:100%;border-radius:3px;pointer-events:none; }
.sl-fill.blue  { background:linear-gradient(90deg,var(--blue),var(--blue-b)); }
.sl-fill.green { background:linear-gradient(90deg,var(--green),#34D399); }
.sl-fill.amber { background:linear-gradient(90deg,var(--amber),#FCD34D); }
.sl-fill.red   { background:linear-gradient(90deg,var(--red),#F87171); }

.sl-thumb { position:absolute;top:50%;width:14px;height:14px;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;border:2px solid var(--bg); }
.sl-thumb.blue  { background:var(--blue); box-shadow:0 0 0 1px var(--blue), 0 0 12px rgba(236,72,153,.35); }
.sl-thumb.green { background:var(--green);box-shadow:0 0 0 1px var(--green),0 0 10px rgba(16,185,129,.3); }
.sl-thumb.amber { background:var(--amber);box-shadow:0 0 0 1px var(--amber),0 0 10px rgba(245,158,11,.3); }
.sl-thumb.red   { background:var(--red);  box-shadow:0 0 0 1px var(--red),  0 0 10px rgba(239,68,68,.3); }

.sl-rng { display:flex;justify-content:space-between;margin-top:4px;font-size:9px;font-family:var(--mono);color:var(--t3); }
input[type="range"] { position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;-webkit-appearance:none;margin:0; }

.sc-btns { display:flex;gap:8px;margin-top:4px; }
.run-btn {
  flex:1;padding:11px;border-radius:var(--r2);
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  color:#fff;font-size:13px;font-weight:700;font-family:var(--font);
  border:none;cursor:pointer;
  box-shadow:0 4px 24px rgba(236,72,153,.3);
  transition:all .2s;display:flex;align-items:center;justify-content:center;gap:7px;
}
.run-btn:hover { box-shadow:0 8px 32px rgba(236,72,153,.45);transform:translateY(-2px); }
.run-btn:disabled { opacity:.5;cursor:not-allowed;transform:none; }
.reset-btn {
  padding:10px 13px;border-radius:var(--r2);
  background:var(--hover);border:1px solid var(--bord);
  color:var(--t2);cursor:pointer;font-size:15px;transition:all .15s;
}
.reset-btn:hover { border-color:var(--bord-hi);color:var(--t1); }

.param-box {
  margin-top:18px;padding:13px 14px;
  background:rgba(255,255,255,.02);border-radius:var(--r2);
  border:1px solid rgba(255,255,255,.04);
}
.pb-row { display:flex;justify-content:space-between;font-size:12px;padding:3px 0; }
.pb-k { color:var(--t2); }
.pb-v { font-family:var(--mono);font-weight:500; }

.sc-empty { display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:12px;color:var(--t3); }
.sc-empty-ico   { font-size:40px;opacity:.35; }
.sc-empty-title { font-size:15px;font-weight:600;color:var(--t2); }
.sc-empty-body  { font-size:12px;text-align:center;max-width:240px;line-height:1.55; }

.sc-cards { display:grid;grid-template-columns:repeat(3,1fr);gap:12px; }
.sc-res   { padding:18px 20px; }
.scr-lbl  { font-size:10px;font-family:var(--mono);color:var(--t3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px; }
.scr-val  { font-size:22px;font-weight:800;letter-spacing:-.03em;margin-bottom:3px; }
.scr-sub  { font-size:11px;color:var(--t2);margin-bottom:7px; }
.scr-chg  { font-size:12px;font-weight:700; }

/* ═══ AI PANEL ════════════════════════════════════════════ */
.ai-panel {
  border-radius:var(--r4);
  background:linear-gradient(145deg,rgba(20,16,30,.95),rgba(14,12,22,.82));
  border:1px solid rgba(236,72,153,.22);
  overflow:hidden;position:relative;
}
.ai-panel::before {
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(236,72,153,.55) 35%,rgba(20,184,166,.45) 65%,transparent);
}
.ai-hd {
  display:flex;align-items:center;justify-content:space-between;
  padding:17px 20px 12px;
}
.ai-brand { display:flex;align-items:center;gap:10px; }
.ai-orb {
  width:30px;height:30px;border-radius:var(--r2);
  background:linear-gradient(145deg,#ec4899,#14b8a6);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;box-shadow:0 0 18px rgba(236,72,153,.28);flex-shrink:0;
}
.ai-name { font-size:13px;font-weight:600;margin-bottom:1px; }
.ai-pow  { font-size:10px;font-family:var(--mono);color:var(--t3); }
.ai-btn {
  display:flex;align-items:center;gap:7px;
  padding:8px 15px;border-radius:var(--r2);
  background:linear-gradient(135deg,rgba(236,72,153,.16),rgba(20,184,166,.1));
  border:1px solid rgba(236,72,153,.35);color:#fbcfe8;
  font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s;
}
.ai-btn:hover { background:linear-gradient(135deg,rgba(236,72,153,.26),rgba(20,184,166,.16));box-shadow:0 4px 18px rgba(236,72,153,.2); }
.ai-btn:disabled { opacity:.45;cursor:not-allowed; }
.ai-bd  { padding:0 20px 17px; }
.ai-ph  { font-size:12px;color:var(--t3);text-align:center;padding:12px 0;font-style:italic; }
.ai-shim { height:11px;border-radius:5px;background:rgba(236,72,153,.1);margin-bottom:7px;animation:shimmer 1.5s ease-in-out infinite; }
.ai-line { font-size:13px;color:var(--t2);line-height:1.72;margin-bottom:4px; }
.ai-act  {
  margin-top:10px;padding:10px 14px;border-radius:var(--r2);
  background:rgba(245,158,11,.07);border-left:2px solid var(--amber);
  font-size:12.5px;color:#FCD34D;line-height:1.65;
}

/* ═══ TOAST ═══════════════════════════════════════════════ */
.toast {
  position:fixed;bottom:22px;right:22px;z-index:999;
  padding:12px 18px;border-radius:var(--r3);
  background:rgba(16,14,22,.97);border:1px solid var(--bord);
  font-size:13px;font-weight:500;color:var(--t1);
  box-shadow:var(--sh-xl);backdrop-filter:blur(20px);
  transform:translateY(10px);opacity:0;transition:all .26s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.toast.show { transform:translateY(0);opacity:1;pointer-events:auto; }
.toast.ok  { border-color:rgba(16,185,129,.3); }
.toast.err { border-color:rgba(239,68,68,.3); }

/* ═══ ANIMATIONS ══════════════════════════════════════════ */
@keyframes pageIn  { from{opacity:0;transform:translateY(7px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulse   { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.85)} }
@keyframes shimmer { 0%,100%{opacity:.25} 50%{opacity:.65} }
@keyframes spin    { to{transform:rotate(360deg)} }

/* ═══ RESPONSIVE ══════════════════════════════════════════ */
@media(max-width:1300px) {
  .kpi-4{grid-template-columns:repeat(2,1fr)}
  .ov-layout{grid-template-columns:1fr}
  .sc-layout{grid-template-columns:1fr}
  .sc-cards{grid-template-columns:1fr}
}
@media(max-width:920px) {
  .two-col,.three-col{grid-template-columns:1fr}
  .col2{grid-column:span 1}
  #sidebar{width:60px;min-width:60px}
  #main{margin-left:60px;max-width:calc(100vw - 60px)}
  .logo-text-wrap,.nav-group-label,.nav-link span,.nav-pip,
  .health-lbl,.sb-time,.ai-badge{display:none}
  .logo-area{justify-content:center}
  .nav-link{justify-content:center;padding:10px}
  .sidebar-foot{padding:12px 10px;display:flex;flex-direction:column;align-items:center}
  .health-row{justify-content:center}
  .content{padding:18px 14px 44px}
}

/* ═══ Enterprise dark (black background) ═════════════════ */
body.theme-enterprise {
  --bg: #000000;
  --surface: #0a0a0a;
  --card: #0f0f10;
  --cb: rgba(255, 255, 255, 0.06);
  --hover: rgba(255, 255, 255, 0.05);
  --blue: #3b82f6;
  --blue-b: #60a5fa;
  --blue-d: rgba(59, 130, 246, 0.12);
  --cyan: #14b8a6;
  --cyan-d: rgba(20, 184, 166, 0.12);
  --green: #10b981;
  --green-d: rgba(16, 185, 129, 0.12);
  --amber: #f59e0b;
  --amber-d: rgba(245, 158, 11, 0.12);
  --red: #ef4444;
  --red-d: rgba(239, 68, 68, 0.12);
  --purple: #a78bfa;
  --t1: #f1f5f9;
  --t2: #94a3b8;
  --t3: #64748b;
  --bord: rgba(255, 255, 255, 0.08);
  --bord-hi: rgba(59, 130, 246, 0.4);
  --sh: 0 1px 0 rgba(255, 255, 255, 0.04) inset, 0 8px 32px rgba(0, 0, 0, 0.55);
  --sh-lg: 0 12px 40px rgba(0, 0, 0, 0.6);
  --sh-xl: 0 20px 50px rgba(0, 0, 0, 0.65);
  --font: 'Source Sans 3', system-ui, sans-serif;
  --mono: 'IBM Plex Mono', Consolas, monospace;
}

body.theme-enterprise {
  background: var(--bg);
  color: var(--t1);
}
body.theme-enterprise::before,
body.theme-enterprise::after { display: none; }

body.theme-enterprise .bg-grid {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 0%, transparent 75%);
  opacity: 0.9;
}

body.theme-enterprise #sidebar {
  background: #050505;
  border-right: 1px solid var(--bord);
  box-shadow: none;
}
body.theme-enterprise .logo-area {
  border-bottom-color: var(--bord);
}
body.theme-enterprise .logo-icon {
  background: linear-gradient(145deg, #1e40af, #0d9488);
  box-shadow: 0 0 20px rgba(59, 130, 246, 0.2);
}
body.theme-enterprise .logo-sub { color: var(--cyan); }

body.theme-enterprise a.nav-link,
body.theme-enterprise a.logo-link,
body.theme-enterprise a.mod-card-link {
  text-decoration: none;
  color: inherit;
}
body.theme-enterprise a.logo-link { display: flex; align-items: center; gap: 11px; }

body.theme-enterprise .nav-link:hover {
  background: var(--hover);
  color: var(--t1);
}
body.theme-enterprise .nav-link.active {
  background: var(--blue-d);
  border-color: rgba(59, 130, 246, 0.28);
  color: var(--blue-b);
}
body.theme-enterprise .nav-pip {
  background: var(--blue);
  box-shadow: 0 0 10px rgba(59, 130, 246, 0.45);
}

body.theme-enterprise #topbar {
  background: rgba(5, 5, 5, 0.92);
  border-bottom: 1px solid var(--bord);
  backdrop-filter: blur(12px);
}
body.theme-enterprise .tb-chip {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--bord);
  color: var(--t2);
}
body.theme-enterprise .icon-btn {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--bord);
  color: var(--t2);
}
body.theme-enterprise .icon-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

body.theme-enterprise .card {
  background: var(--card);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--bord);
  box-shadow: var(--sh);
}
body.theme-enterprise .card::after {
  display: block;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.04), transparent);
}
body.theme-enterprise .card:hover { border-color: rgba(255, 255, 255, 0.12); }

body.theme-enterprise .hero {
  background: linear-gradient(165deg, #0c0c0e 0%, #050505 55%, #0a0a0c 100%);
  border: 1px solid var(--bord);
}
body.theme-enterprise .hero::before {
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--blue) 25%, var(--cyan) 50%, var(--blue) 75%, transparent);
  opacity: 0.85;
}
body.theme-enterprise .hero-h em { color: var(--blue-b); }

body.theme-enterprise .r1 { border-color: rgba(59, 130, 246, 0.22); }
body.theme-enterprise .r2 { border-color: rgba(20, 184, 166, 0.2); }
body.theme-enterprise .r3 { border-color: rgba(167, 139, 250, 0.22); }

body.theme-enterprise .param-box {
  background: rgba(255, 255, 255, 0.03);
  border-color: var(--bord);
}
body.theme-enterprise .sc-empty {
  color: var(--t3);
}
body.theme-enterprise .sc-empty-title { color: var(--t2); }

body.theme-enterprise .dtable tbody tr {
  background: rgba(255, 255, 255, 0.02);
}
body.theme-enterprise .dtable tbody tr:hover {
  background: rgba(255, 255, 255, 0.04);
}
body.theme-enterprise .dtable td,
body.theme-enterprise .dtable thead th {
  border-color: rgba(255, 255, 255, 0.06);
}

body.theme-enterprise .ai-panel {
  background: linear-gradient(145deg, #0d0d10 0%, #080809 100%);
  border: 1px solid rgba(59, 130, 246, 0.2);
}
body.theme-enterprise .ai-panel::before { opacity: 0.7; }
body.theme-enterprise .ai-orb {
  background: linear-gradient(145deg, #3b82f6, #14b8a6);
  box-shadow: 0 0 20px rgba(59, 130, 246, 0.25);
}
body.theme-enterprise .ai-btn {
  background: rgba(59, 130, 246, 0.12);
  border: 1px solid rgba(59, 130, 246, 0.35);
  color: #93c5fd;
}
body.theme-enterprise .ai-btn:hover {
  background: rgba(59, 130, 246, 0.2);
  box-shadow: 0 4px 20px rgba(59, 130, 246, 0.15);
}
body.theme-enterprise .ai-act {
  background: rgba(245, 158, 11, 0.08);
  color: #fcd34d;
  border-left-color: var(--amber);
}

body.theme-enterprise .toast {
  background: #111113;
  color: var(--t1);
  border: 1px solid var(--bord);
}

body.theme-enterprise .sl-thumb {
  border-color: var(--bg);
}

body.theme-enterprise .mod-card-link { display: block; }

body.theme-enterprise .sidebar-foot {
  border-top-color: var(--bord);
}

body.theme-enterprise .srch-inp {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--bord);
  color: var(--t1);
}
body.theme-enterprise .srch-inp:focus {
  border-color: var(--bord-hi);
  background: rgba(255, 255, 255, 0.06);
}

body.theme-enterprise .tab.active {
  background: var(--blue-d);
  border-color: rgba(59, 130, 246, 0.35);
  color: var(--blue-b);
}

body.theme-enterprise .tech-chip {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--bord);
  color: var(--t2);
}

/* Datasets page */
.ds-form { padding: 4px 0 8px; }
.ds-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 12px 0 6px;
}
body.theme-enterprise .ds-input {
  width: 100%;
  max-width: 420px;
  padding: 9px 12px;
  border: 1px solid var(--bord);
  border-radius: var(--r2);
  font-family: var(--font);
  font-size: 14px;
  background: #0a0a0a;
  color: var(--t1);
}
.ds-file {
  display: block;
  margin-bottom: 14px;
  font-size: 13px;
  color: var(--t2);
}
.ds-submit { max-width: 200px; margin-top: 8px; }
body.theme-enterprise .ds-sample {
  font-family: var(--mono);
  font-size: 12px;
  background: #0a0a0a;
  border: 1px solid var(--bord);
  border-radius: var(--r2);
  padding: 14px;
  overflow-x: auto;
  margin-bottom: 10px;
  color: var(--t1);
}
.ds-hint { font-size: 13px; color: var(--t2); line-height: 1.5; }
body.theme-enterprise .inline-code {
  font-family: var(--mono);
  font-size: 0.9em;
  background: rgba(255, 255, 255, 0.06);
  padding: 1px 6px;
  border-radius: 4px;
  border: 1px solid var(--bord);
  color: var(--t1);
}
.pg-sub a { color: var(--blue-b); text-decoration: none; font-weight: 600; }
.pg-sub a:hover { text-decoration: underline; }

/* ═══ Light Theme ════════════════════════════════════════ */
body.theme-light {
  --bg: #f8fafc;
  --surface: #ffffff;
  --card: #ffffff;
  --cb: rgba(0, 0, 0, 0.08);
  --hover: rgba(0, 0, 0, 0.04);
  
  --blue: #2563eb;
  --blue-b: #3b82f6;
  --blue-d: rgba(37, 99, 235, 0.12);
  --cyan: #0d9488;
  --cyan-d: rgba(13, 148, 136, 0.12);
  --green: #059669;
  --green-d: rgba(5, 150, 105, 0.12);
  --amber: #d97706;
  --amber-d: rgba(217, 119, 6, 0.12);
  --red: #dc2626;
  --red-d: rgba(220, 38, 38, 0.12);
  --purple: #7c3aed;
  
  --t1: #0f172a;
  --t2: #475569;
  --t3: #64748b;
  
  --bord: rgba(0, 0, 0, 0.08);
  --bord-hi: rgba(37, 99, 235, 0.4);
  
  --sh: 0 4px 12px rgba(0, 0, 0, 0.05);
  --sh-lg: 0 10px 24px rgba(0, 0, 0, 0.08);
  --sh-xl: 0 20px 48px rgba(0, 0, 0, 0.1);
  background: var(--bg);
  color: var(--t1);
}

body.theme-light::before,
body.theme-light::after { display: none; }

body.theme-light .bg-grid {
  background-image:
    linear-gradient(rgba(0, 0, 0, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 0, 0, 0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 0%, transparent 75%);
  opacity: 1;
}

body.theme-light #sidebar { background: #ffffff; border-right: 1px solid var(--bord); box-shadow: none; }
body.theme-light .logo-area { border-bottom-color: var(--bord); }
body.theme-light .logo-icon { background: linear-gradient(145deg, #3b82f6, #0d9488); box-shadow: 0 0 15px rgba(37, 99, 235, 0.2); }
body.theme-light .logo-icon svg { color: white; }
body.theme-light .logo-sub { color: var(--cyan); }
body.theme-light a { color: var(--t1); text-decoration: none; }
body.theme-light .nav-link { color: var(--t2); }
body.theme-light .nav-link:hover { background: var(--hover); color: var(--t1); }
body.theme-light .nav-link.active { background: var(--blue-d); border-color: rgba(37, 99, 235, 0.25); color: var(--blue); }
body.theme-light .nav-pip { background: var(--blue); box-shadow: 0 0 8px rgba(37, 99, 235, 0.4); }

body.theme-light #topbar { background: rgba(255, 255, 255, 0.95); border-bottom: 1px solid var(--bord); backdrop-filter: blur(12px); }
body.theme-light .tb-chip { background: var(--surface); border-color: var(--bord); color: var(--t2); }
body.theme-light .icon-btn { background: var(--surface); border-color: var(--bord); color: var(--t2); }
body.theme-light .icon-btn:hover { background: var(--hover); color: var(--t1); }

body.theme-light .card { background: var(--card); border: 1px solid var(--bord); box-shadow: var(--sh); }
body.theme-light .card::after { display: none; }
body.theme-light .card:hover { border-color: rgba(0, 0, 0, 0.15); box-shadow: var(--sh-lg); }

body.theme-light .hero { background: linear-gradient(165deg, #ffffff 0%, #f8fafc 55%, #f1f5f9 100%); border: 1px solid var(--bord); }
body.theme-light .hero::before { height: 3px; background: linear-gradient(90deg, transparent, var(--blue) 25%, var(--cyan) 50%, var(--blue) 75%, transparent); opacity: 0.85; }
body.theme-light .hero-h em { color: var(--blue); }

body.theme-light .r1 { border-color: rgba(37, 99, 235, 0.22); }
body.theme-light .r2 { border-color: rgba(13, 148, 136, 0.2); }
body.theme-light .r3 { border-color: rgba(124, 58, 237, 0.22); }

body.theme-light .param-box { background: rgba(0, 0, 0, 0.02); border-color: var(--bord); }
body.theme-light .sc-empty { color: var(--t3); }
body.theme-light .sc-empty-title { color: var(--t2); }

body.theme-light .dtable tbody tr { background: transparent; }
body.theme-light .dtable tbody tr:hover { background: rgba(0, 0, 0, 0.02); }
body.theme-light .dtable td,
body.theme-light .dtable thead th { border-color: rgba(0, 0, 0, 0.05); }

body.theme-light .ai-panel { background: linear-gradient(145deg, #ffffff 0%, #f8fafc 100%); border: 1px solid rgba(37, 99, 235, 0.2); }
body.theme-light .ai-orb { background: linear-gradient(145deg, #3b82f6, #0d9488); box-shadow: 0 0 15px rgba(37, 99, 235, 0.2); color: white; }
body.theme-light .ai-btn { background: rgba(37, 99, 235, 0.08); border: 1px solid rgba(37, 99, 235, 0.2); color: var(--blue); }
body.theme-light .ai-btn:hover { background: rgba(37, 99, 235, 0.12); box-shadow: 0 4px 15px rgba(37, 99, 235, 0.1); }
body.theme-light .ai-act { background: rgba(217, 119, 6, 0.08); color: var(--amber); border-left-color: var(--amber); }

body.theme-light .toast { background: #ffffff; color: var(--t1); border: 1px solid var(--bord); }
body.theme-light .sl-thumb { border-color: var(--bg); }
body.theme-light .mod-card-link { display: block; }
body.theme-light .sidebar-foot { border-top-color: var(--bord); }
body.theme-light .srch-inp { background: var(--surface); border-color: var(--bord); color: var(--t1); }
body.theme-light .srch-inp:focus { border-color: var(--bord-hi); background: var(--surface); }
body.theme-light .tab.active { background: var(--blue-d); border-color: rgba(37, 99, 235, 0.3); color: var(--blue); }
body.theme-light .tech-chip { background: var(--surface); border-color: var(--bord); color: var(--t2); }
body.theme-light .sl-track, body.theme-light .pbar, body.theme-light .rtrack { background: rgba(0, 0, 0, 0.06); }
body.theme-light .inline-code { background: rgba(0,0,0,0.06); border-color: var(--bord); color: var(--t1); }
body.theme-light .ds-sample { background: var(--surface); border-color: var(--bord); color: var(--t1); }
