:root{
  --bg:#FAFAF7; --bg-soft:#F4F4EE;
  --ink:#0B0B0F; --ink-2:#1A1A22;
  --muted:#5C5C66; --muted-2:#8A8A93;
  --line:#E6E6DE; --line-2:#EFEFE7;
  --blue:#3B82F6; --blue-2:#2563EB;
  --blue-soft:#E8F1FF; --blue-tint:#F2F7FF;
  --mint:#D7F5E3; --mint-2:#16A34A; --mint-tint:#ECFDF5;
  --alert:#B45309; --alert-soft:#FEF3E2;
  --serif:"Instrument Serif",serif;
  --sans:"Inter",sans-serif;
  --mono:"JetBrains Mono",monospace;
  --r-md:14px; --r-lg:18px; --r-xl:22px;
  --shadow-sm:0 1px 2px rgba(11,11,15,.04);
  --shadow-md:0 6px 24px -10px rgba(11,11,15,.10), 0 1px 2px rgba(11,11,15,.04);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);font-family:var(--sans);color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased}
em{font-family:var(--serif);font-style:italic;font-weight:400}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}

body{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);display:inline-block;margin-bottom:6px}
.dot{display:inline-block;width:6px;height:6px;border-radius:999px;background:var(--muted-2);margin-right:6px;vertical-align:middle}
.dot--mint{background:var(--mint-2)}
.status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:500}
.status--mint{background:var(--mint);color:#0F5132}
.muted-meta{font-size:11.5px;color:var(--muted-2);font-family:var(--mono);letter-spacing:.04em}

/* ============ SIDEBAR ============ */
.sidebar{
  background:#fff;
  border-right:1px solid var(--line);
  padding:22px 16px;
  display:flex;flex-direction:column;gap:24px;
  position:sticky;top:0;height:100vh;
}
.sidebar__brand{display:flex;align-items:center;gap:10px;padding:0 6px 16px;border-bottom:1px solid var(--line)}
.sidebar__mark{
  width:36px;height:36px;border-radius:10px;background:var(--ink);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.sidebar__mark svg{width:22px;height:22px}
.sidebar__name{font-size:15px;font-weight:600;letter-spacing:-.01em}
.sidebar__name em{font-size:16px;margin-left:2px}
.sidebar__sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--muted-2);margin-top:1px}

.sidebar__group{display:flex;flex-direction:column;gap:2px}
.sidebar__heading{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted-2);
  padding:0 12px;margin-bottom:6px;
}
.sidebar__link{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:10px;
  font-size:13.5px;color:var(--ink-2);font-weight:450;
  transition:background .15s, color .15s;
}
.sidebar__link svg{width:17px;height:17px;color:var(--muted)}
.sidebar__link:hover{background:var(--bg-soft)}
.sidebar__link--active{background:var(--blue-tint);color:var(--blue-2);font-weight:500}
.sidebar__link--active svg{color:var(--blue-2)}
.sidebar__badge{
  margin-left:auto;
  font-family:var(--mono);font-size:10.5px;
  background:var(--blue);color:#fff;
  padding:1px 7px;border-radius:999px;font-weight:500;
}
.sidebar__user{
  margin-top:auto;
  display:flex;align-items:center;gap:10px;
  padding:12px;border-radius:12px;background:var(--bg-soft);border:1px solid var(--line);
}
.sidebar__avatar{
  width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  color:#fff;display:inline-flex;align-items:center;justify-content:center;
  font-weight:600;font-size:12px;letter-spacing:.02em;
}
.sidebar__user-name{font-size:13px;font-weight:600;letter-spacing:-.005em}
.sidebar__user-role{font-size:11px;color:var(--muted)}

/* Demo toggle — inline in sidebar user card */
.sidebar__demo-inline{
  display:flex;flex-direction:column;align-items:center;gap:3px;margin-left:auto;flex-shrink:0;
}
.sidebar__demo-label{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.demo-pill{
  width:34px;height:18px;border-radius:999px;background:var(--line);
  position:relative;transition:background .2s;flex-shrink:0;
}
.demo-pill__knob{
  position:absolute;top:3px;left:3px;
  width:12px;height:12px;border-radius:999px;background:#fff;
  box-shadow:0 1px 3px rgba(11,11,15,.2);
  transition:transform .2s;
}
.demo-pill--on{background:var(--blue);}
.demo-pill--on .demo-pill__knob{transform:translateX(16px);}

/* Demo badge in orb panel */
.orb-demo-badge{
  display:none;margin-left:auto;
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  background:var(--alert-soft);color:var(--alert);
  padding:2px 8px;border-radius:999px;border:1px solid rgba(180,83,9,.2);font-weight:500;
}
.is-demo-mode .orb-demo-badge{display:inline-block;}
.is-demo-mode .orb-status{color:var(--alert);}

/* ============ MAIN ============ */
.main{padding:0 32px 56px;min-width:0}

/* TOPBAR */
.topbar{
  position:sticky;top:0;z-index:20;
  display:flex;align-items:center;gap:16px;
  padding:14px 0;
  background:rgba(250,250,247,.85);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
  margin-bottom:24px;
}
.topbar__search{
  flex:1;max-width:480px;
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;
  background:#fff;
  border:1px solid var(--line);border-radius:10px;
}
.topbar__search svg{color:var(--muted-2);flex-shrink:0}
.topbar__search input{flex:1;border:none;outline:none;background:none;font-size:13.5px;color:var(--ink);font-family:inherit}
.topbar__search input::placeholder{color:var(--muted-2)}
.topbar__kbd{
  font-family:var(--mono);font-size:10.5px;color:var(--muted);
  padding:2px 6px;background:var(--bg-soft);border-radius:5px;border:1px solid var(--line);
}
.topbar__actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.icon-btn{
  position:relative;
  width:36px;height:36px;border-radius:10px;
  border:1px solid var(--line);background:#fff;
  display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2);
  transition:background .15s,border-color .15s;
}
.icon-btn svg{width:16px;height:16px}
.icon-btn:hover{background:var(--bg-soft)}
.icon-btn__pip{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:999px;background:var(--alert);border:1.5px solid #fff}

.ai-badge{
  display:inline-flex;align-items:center;gap:7px;
  padding:6px 12px;border-radius:999px;
  background:var(--blue-tint);border:1px solid var(--blue-soft);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--blue-2);font-weight:500;
}
.ai-badge__dot{
  width:6px;height:6px;border-radius:999px;background:var(--blue);
  box-shadow:0 0 0 3px rgba(59,130,246,.18);
}
.primary-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;border-radius:10px;
  background:var(--ink);color:#fff;font-size:13px;font-weight:500;
}
.primary-btn:hover{background:#222}

/* PAGE HEADER */
.pageheader{
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  margin-bottom:24px;flex-wrap:wrap;
}
.crumb{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted-2);margin-bottom:8px;
}
.crumb__sep{margin:0 8px;color:var(--line)}
.pageheader__title{
  font-size:42px;font-weight:600;letter-spacing:-.025em;line-height:1;margin-bottom:6px;
}
.pageheader__title em{color:var(--blue-2)}
.pageheader__sub{font-size:14px;color:var(--muted)}
.pageheader__meta{display:flex;gap:10px;flex-wrap:wrap}
.meta-tile{
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 14px;
  display:flex;flex-direction:column;gap:2px;min-width:140px;
}
.meta-tile__l{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.meta-tile__v{font-size:13.5px;font-weight:500}
.meta-tile--mint{background:var(--mint-tint);border-color:var(--mint)}

/* KPIs */
.kpis{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:28px;
}
.kpi{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:18px 18px 14px;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:8px;
  transition:transform .15s, box-shadow .15s;
}
.kpi:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.kpi--alert{background:linear-gradient(180deg,#FEF8F0 0%,#fff 70%);border-color:#F1D9B8}
.kpi__alert{
  position:absolute;top:14px;right:14px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;
  background:var(--alert);color:#fff;padding:3px 7px;border-radius:5px;font-weight:500;
}
.kpi__head{display:flex;align-items:center;justify-content:space-between}
.kpi__label{font-size:12.5px;color:var(--muted);font-weight:500}
.kpi__icon{
  width:30px;height:30px;border-radius:9px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--blue-soft);color:var(--blue-2);
}
.kpi__icon svg{width:15px;height:15px}
.kpi__icon--mint{background:var(--mint);color:#0F5132}
.kpi__icon--alert{background:#FEEFD8;color:var(--alert)}
.kpi__value{
  font-size:34px;font-weight:600;letter-spacing:-.03em;line-height:1;color:var(--ink);
}
.kpi__value em{color:var(--blue-2);font-size:18px;margin-left:4px;letter-spacing:0}
.kpi--alert .kpi__value em{color:var(--alert)}
.kpi__delta{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12px;font-weight:500;
}
.kpi__delta span{color:var(--muted);font-weight:400;margin-left:2px}
.kpi__delta--up{color:var(--mint-2)}
.kpi__delta--down{color:var(--alert)}
.kpi__delta--neutral{color:var(--muted)}
.kpi__spark{height:34px;margin-top:auto;margin-left:-6px;margin-right:-6px}
.kpi__spark canvas{width:100%!important;height:100%!important}

/* TABS */
.tabs{
  display:flex;gap:4px;
  border-bottom:1px solid var(--line);margin-bottom:24px;
}
.tab{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;
  font-size:14px;color:var(--muted);font-weight:500;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:color .15s, border-color .15s;
}
.tab__num{
  font-family:var(--mono);font-size:10.5px;color:var(--muted-2);letter-spacing:.08em;
}
.tab:hover{color:var(--ink)}
.tab--active{color:var(--ink);border-bottom-color:var(--blue)}
.tab--active .tab__num{color:var(--blue-2)}
.tab__pip{
  font-family:var(--mono);font-size:10px;background:var(--blue);color:#fff;
  padding:1px 6px;border-radius:999px;font-weight:500;
}

/* TAB PANELS */
.tabpanel{display:none}
.tabpanel--active{display:block;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* SCENARIO BAR */
.scenario-bar{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  margin-bottom:18px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:16px 20px;
}
.scenario-bar__l{font-size:13px;color:var(--muted)}
.scenario-toggles{display:flex;gap:8px;flex-wrap:wrap}
.scn{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 12px 8px 10px;border-radius:10px;
  background:var(--bg-soft);border:1px solid var(--line);
  font-size:13px;font-weight:500;color:var(--muted);
  transition:all .15s;
}
.scn__sw{
  width:28px;height:16px;border-radius:999px;
  background:#D6D6CC;position:relative;flex-shrink:0;
  transition:background .2s;
}
.scn__dot{
  position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:999px;background:#fff;
  transition:transform .2s;
  box-shadow:0 1px 2px rgba(0,0,0,.2);
}
.scn__chip{
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;
  background:#fff;border:1px solid var(--line);padding:2px 7px;border-radius:5px;
  color:var(--muted-2);
}
.scn--on{color:var(--ink);background:#fff}
.scn--on .scn__dot{transform:translateX(12px)}
.scn--base.scn--on .scn__sw{background:var(--blue)}
.scn--up.scn--on .scn__sw{background:var(--mint-2)}
.scn--dn.scn--on .scn__sw{background:var(--alert)}
.scn--base.scn--on{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.08)}
.scn--up.scn--on{border-color:var(--mint-2);box-shadow:0 0 0 3px rgba(22,163,74,.08)}
.scn--dn.scn--on{border-color:var(--alert);box-shadow:0 0 0 3px rgba(180,83,9,.08)}

/* GRID + CARDS */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card--span4{grid-column:span 4}
.card--span6{grid-column:span 6}
.card--span8{grid-column:span 8}
.card--span12{grid-column:span 12}
@media(max-width:1100px){
  .card--span4,.card--span6,.card--span8{grid-column:span 12}
  .kpis{grid-template-columns:repeat(2,1fr)}
  body{grid-template-columns:1fr}
  .sidebar{display:none}
}

.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:20px;
  display:flex;flex-direction:column;
}
.card__head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;
  margin-bottom:14px;
}
.card__title{font-size:17px;font-weight:600;letter-spacing:-.015em;line-height:1.2}
.card__title--lg{font-size:24px;letter-spacing:-.02em}
.card__title em{color:var(--blue-2)}
.card__sub{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.5;max-width:60ch}

.legend{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--muted)}
.legend__item{display:inline-flex;align-items:center;gap:6px}
.legend__item i{width:9px;height:9px;border-radius:2px;display:inline-block}
.legend__item--dash i{height:0;border-top:2px dashed currentColor;background:transparent!important;width:14px}
.legend__item--dash i[style*="background"]{border-top-color:inherit}
.legend__item--off{opacity:.4;text-decoration:line-through}

.chart{position:relative;width:100%}
.chart--md{height:220px}
.chart--lg{height:280px}
.chart canvas{width:100%!important;height:100%!important}

.card__strip{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  background:var(--bg-soft);
  margin-top:14px;
}
.card__strip strong{font-size:18px;font-weight:600;letter-spacing:-.01em}
.card__strip > div{display:flex;flex-direction:column;gap:2px}
.card__arrow{font-size:18px;color:var(--muted-2);font-weight:300}
.card__delta{
  margin-left:auto;
  font-family:var(--mono);font-size:12px;font-weight:500;
  background:var(--mint);color:#0F5132;padding:4px 10px;border-radius:6px;
}

/* TABLE */
.ftable{width:100%;border-collapse:collapse;font-size:13.5px}
.ftable th, .ftable td{padding:11px 12px;text-align:right;border-bottom:1px dashed var(--line-2)}
.ftable th{
  font-family:var(--mono);font-weight:500;font-size:10.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted-2);text-align:right;
  border-bottom:1px solid var(--line);
}
.ftable th:first-child, .ftable td:first-child{text-align:left;color:var(--muted);font-weight:500}
.ftable td{color:var(--ink);font-variant-numeric:tabular-nums}
.ftable tr:last-child td{border-bottom:0}
.ftable__delta td{font-weight:600}
.ftable .up{color:var(--mint-2)}
.ftable .dn{color:var(--alert)}
.ftable [data-col].is-hidden{opacity:.25}
.ftable--compact th, .ftable--compact td{padding:7px 10px;font-size:12.5px}
.ftable__foot{
  margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);
  font-size:13px;color:var(--muted);line-height:1.5;
}
.ftable__foot strong{color:var(--ink);font-weight:600}

/* INSIGHTS */
.insights-head{margin-bottom:18px}
.insight{
  display:grid;grid-template-columns:64px 1fr;gap:0;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);
  margin-bottom:14px;overflow:hidden;
}
.insight__rail{
  background:var(--bg-soft);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:24px 0;
}
.insight__num{
  font-family:var(--serif);font-style:italic;font-size:32px;color:var(--muted-2);line-height:1;
}
.insight__sev{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 8px;border-radius:5px;font-weight:500;
  writing-mode:vertical-rl;text-orientation:mixed;margin-top:auto;
}
.insight__sev--high{background:#FEE2E2;color:#991B1B}
.insight__sev--med{background:var(--alert-soft);color:var(--alert)}
.insight__body{padding:24px 28px}
.insight__title{font-size:22px;font-weight:600;letter-spacing:-.02em;line-height:1.2;margin-bottom:10px;text-wrap:balance}
.insight__title em{color:var(--blue-2)}
.insight__finding{font-size:14.5px;color:var(--ink-2);line-height:1.55;margin-bottom:18px;max-width:80ch}
.insight__finding strong{color:var(--ink);font-weight:600}

.evidence{
  display:grid;grid-template-columns:repeat(7,1fr);gap:8px;
  margin-bottom:18px;
}
@media(max-width:1100px){.evidence{grid-template-columns:repeat(3,1fr)}}
.ev{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;
  padding:10px 12px;display:flex;flex-direction:column;gap:4px;
}
.ev__l{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2)}
.ev strong{font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--ink);font-variant-numeric:tabular-nums}
.ev--down{color:var(--alert)}

.implication{
  background:var(--blue-tint);border:1px solid var(--blue-soft);border-radius:12px;
  padding:14px 16px;
}
.implication p{font-size:13.5px;color:var(--ink-2);line-height:1.55;margin-top:4px}
.implication strong{color:var(--ink);font-weight:600}

.conc-bar{margin-bottom:16px}
.conc-bar__l{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);display:block;margin-bottom:8px}
.conc-bar__track{height:14px;display:flex;border-radius:999px;overflow:hidden;border:1px solid var(--line)}
.seg{display:block;height:100%}
.conc-bar__legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px;font-size:11.5px;color:var(--muted)}
.conc-bar__legend i{width:9px;height:9px;border-radius:2px;display:inline-block;margin-right:6px}

.dso{margin-bottom:16px;display:flex;flex-direction:column;gap:8px}
.dso__row{display:grid;grid-template-columns:80px 1fr 50px;gap:12px;align-items:center;font-size:13px}
.dso__l{color:var(--muted)}
.dso__bar{height:10px;background:var(--bg-soft);border-radius:999px;overflow:hidden;position:relative}
.dso__bar i{position:absolute;inset:0;border-radius:999px;display:block}
.dso__row strong{font-weight:600;font-variant-numeric:tabular-nums;text-align:right}

/* ============ AGENT HIGHLIGHT ============ */
.agent-highlight{
  animation:agentGlow 2.5s ease-out forwards;
}
@keyframes agentGlow{
  0%  {box-shadow:0 0 0 0 rgba(59,130,246,0),var(--shadow-sm)}
  15% {box-shadow:0 0 0 3px rgba(59,130,246,0.7),0 0 24px rgba(59,130,246,0.25)}
  70% {box-shadow:0 0 0 3px rgba(59,130,246,0.4),0 0 16px rgba(59,130,246,0.15)}
  100%{box-shadow:0 0 0 0 rgba(59,130,246,0),var(--shadow-sm)}
}

/* ============ ORB WIDGET ============ */
.orb-widget{
  position:fixed;bottom:24px;right:24px;z-index:1000;
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;
}
.orb-toggle{
  width:52px;height:52px;border-radius:50%;
  background:var(--ink);color:#fff;
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(11,11,15,.35);
  transition:transform .2s,box-shadow .2s;
  flex-shrink:0;align-self:flex-start;
}
.orb-toggle:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(11,11,15,.45)}
.orb-toggle svg{width:22px;height:22px}

.orb-panel{
  width:370px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:0 16px 60px -10px rgba(11,11,15,.18),0 2px 8px rgba(11,11,15,.06);
  display:flex;flex-direction:column;
  overflow:hidden;
  transform-origin:bottom right;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),opacity .2s;
}
.orb-panel.is-hidden{
  transform:scale(0.92) translateY(12px);
  opacity:0;
  pointer-events:none;
}

.orb-panel__header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px 12px;
  border-bottom:1px solid var(--line);
}
.orb-panel__title{font-size:13px;font-weight:600;letter-spacing:-.01em}
.orb-panel__sub{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-top:1px}
.orb-panel__close{
  width:28px;height:28px;border-radius:8px;border:1px solid var(--line);
  background:var(--bg-soft);display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--muted);font-size:16px;line-height:1;
  transition:background .15s;
}
.orb-panel__close:hover{background:var(--line)}

/* ORB SPHERE */
.orb-stage{
  display:flex;flex-direction:column;align-items:center;
  padding:24px 18px 16px;gap:10px;
}
.orb-sphere-wrap{
  position:relative;width:96px;height:96px;
  display:flex;align-items:center;justify-content:center;
}
.orb-sphere{
  width:80px;height:80px;border-radius:50%;
  background:
    radial-gradient(circle at 34% 34%, rgba(255,255,255,.35) 0%, transparent 55%),
    radial-gradient(circle, #60a5fa 0%, #2563eb 55%, #1e3a8a 100%);
  box-shadow:0 8px 32px rgba(37,99,235,.45),0 2px 8px rgba(37,99,235,.2);
  transition:transform .1s;
  cursor:pointer;
}
.orb-sphere--idle{animation:orbBreathe 3.2s ease-in-out infinite}
@keyframes orbBreathe{
  0%,100%{transform:scale(1);box-shadow:0 8px 32px rgba(37,99,235,.35)}
  50%{transform:scale(1.06);box-shadow:0 12px 48px rgba(37,99,235,.55)}
}
.orb-sphere--processing{animation:orbSpin 1.2s linear infinite}
@keyframes orbSpin{
  0%{filter:hue-rotate(0deg)}100%{filter:hue-rotate(30deg)}
}
.orb-sphere--speaking{animation:orbSpeak .9s ease-in-out infinite}
@keyframes orbSpeak{
  0%,100%{transform:scale(1)}
  40%{transform:scale(1.04)}
  70%{transform:scale(0.97)}
}

/* ripple rings */
.orb-ripple{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(59,130,246,.45);
  animation:rippleOut 1.8s ease-out infinite;
  pointer-events:none;
}
.orb-ripple:nth-child(2){animation-delay:.6s}
.orb-ripple:nth-child(3){animation-delay:1.2s}
@keyframes rippleOut{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(2.2);opacity:0}
}

/* processing ring */
.orb-processing-ring{
  position:absolute;inset:-8px;border-radius:50%;
  border:2px solid transparent;
  border-top-color:var(--blue);
  animation:spin 1s linear infinite;
  pointer-events:none;display:none;
}
.orb-sphere--processing ~ .orb-processing-ring{display:block}
@keyframes spin{to{transform:rotate(360deg)}}

.orb-status{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted-2);
  transition:color .2s;
}
.orb-status--listening{color:var(--blue-2)}
.orb-status--processing{color:var(--muted)}
.orb-status--speaking{color:var(--mint-2)}

/* LIVE TRANSCRIPT */
.orb-live{
  margin:0 18px;
  font-size:13px;color:var(--muted);font-style:italic;
  min-height:18px;line-height:1.4;
  transition:opacity .2s;
}

/* RESPONSE CARD */
.orb-response{
  margin:0 14px 4px;
  background:var(--blue-tint);border:1px solid var(--blue-soft);
  border-radius:12px;padding:12px 14px;
  animation:fadeIn .3s ease;
}
.orb-response__headline{
  font-size:12px;font-weight:600;color:var(--blue-2);
  letter-spacing:-.005em;margin-bottom:4px;
}
.orb-response__spoken{
  font-size:13px;color:var(--ink-2);line-height:1.55;
}
.orb-response__dp{
  font-family:var(--mono);font-size:11px;color:var(--muted-2);
  margin-top:6px;letter-spacing:.04em;
}

/* HISTORY */
.orb-history{
  margin:0 14px;
  display:flex;flex-direction:column;gap:6px;
  max-height:120px;overflow-y:auto;
}
.orb-history__item{font-size:12.5px;line-height:1.4}
.orb-history__q{color:var(--muted);margin-bottom:2px}
.orb-history__q span{color:var(--ink);font-weight:500}

/* CONTROLS */
.orb-controls{
  display:flex;align-items:center;justify-content:center;
  padding:14px 18px 0;
}
.orb-mic{
  width:48px;height:48px;border-radius:50%;
  background:var(--ink);color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(11,11,15,.25);
  transition:background .15s,transform .15s;
}
.orb-mic:hover{background:#333;transform:scale(1.05)}
.orb-mic--listening{background:var(--blue);animation:micPulse 1s ease-in-out infinite}
.orb-mic--listening:hover{background:var(--blue-2)}
@keyframes micPulse{
  0%,100%{box-shadow:0 4px 16px rgba(59,130,246,.4)}
  50%{box-shadow:0 4px 32px rgba(59,130,246,.7)}
}
.orb-mic svg{width:20px;height:20px}

/* SUGGESTIONS */
.orb-suggestions{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:10px 14px 16px;
}
.orb-suggestion{
  font-size:11.5px;color:var(--muted);
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:999px;padding:5px 12px;cursor:pointer;
  transition:background .15s,color .15s,border-color .15s;
  text-align:left;
}
.orb-suggestion:hover{
  background:var(--blue-tint);color:var(--blue-2);border-color:var(--blue-soft);
}
