/* ISpyMyAI Live-home stylesheet — ISPY-LIVE-01d.1.
 * Extracted from docs/a1-v3-mockups/14-home-live-ispy-v5.html (v5 design lock).
 * Every top-level selector is prefixed `.live-home` for scope hygiene (so the
 * persistent dashboard shell — header / tabs / banner — is never restyled, and a
 * grep for `.tri-tile` in dashboard.html that comes up empty points the reader here).
 * Tokens (:root) are NOT duplicated — they live in dashboard.html. The Coordinator
 * FAB (.assistant-*) is omitted (hidden in P1 per Calibrating Spec §3; re-add with
 * AGENTMAPS-LIVE-01). @keyframes kept verbatim; @media inner selectors prefixed.
 * Sub-element treatments per Calibrating Spec §3. Wired in 01d.3-5. */

.live-home * { box-sizing: border-box; }
.live-home button { font: inherit; cursor: pointer; }
.live-home header.app-hdr {
  background: var(--eu-bg);
  border-bottom: 1px solid var(--eu-border);
  padding: 12px 24px;
  display: flex; align-items: center;
  flex-wrap: wrap; gap: 10px 14px;
}
.live-home .brand { display: flex; align-items: center; gap: 10px; flex: 0 0 auto; }
.live-home .brand h1 { font-size: 18px; font-weight: 600; letter-spacing: -0.02em; margin: 0; }
.live-home .brand-mark { width: 28px; height: 28px; display: block; flex-shrink: 0; }
/* LIVE-UX-POLISH-01 (Change 1) — the control row flows from the left after the brand (Live · band ·
   filters) and grows to fill the bar (flex:1, min-width:0 so it can SHRINK and wrap instead of
   overflowing — the band selector + filter cluster made the old max-content right-jam push Assistant
   off the right edge). Assistant is pushed to the right by its own margin-left:auto. */
.live-home .hdr-right { display: flex; align-items: center; gap: 8px 10px; flex-wrap: wrap; flex: 1 1 auto; min-width: 0; }
.live-home .hdr-right .hdr-cta { margin-left: auto; }
.live-home .hdr-icon {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 10px;
  border-radius: 7px;
  font-size: 12px; font-weight: 500;
  border: 1px solid var(--eu-border);
  background: var(--eu-panel-2);
  color: var(--eu-text);
  transition: background 120ms;
}
.live-home .hdr-icon:hover { background: var(--eu-panel-3); }
.live-home .hdr-icon svg { display: block; }
/* ISPY-LIVE-HELPER-HEALTH-01 — native-helper liveness pill (set by renderHelperHealthIndicator). */
.live-home .helper-health-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 8px; border-radius: 999px;
  border: 1px solid transparent; background: transparent;
  color: var(--eu-muted); font-size: 11.5px; cursor: default;
}
.live-home .helper-health-pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--eu-muted); }
.live-home .helper-health-pill.healthy { color: var(--eu-good); }
.live-home .helper-health-pill.healthy .dot { background: var(--eu-good); }
.live-home .helper-health-pill.stale { color: var(--eu-warn); border-color: var(--eu-warn); }
.live-home .helper-health-pill.stale .dot { background: var(--eu-warn); }
.live-home .helper-health-pill.dead { color: var(--eu-bad); border-color: var(--eu-bad); cursor: pointer; }
.live-home .helper-health-pill.dead .dot { background: var(--eu-bad); }
.live-home .toggle, .live-home .theme-toggle, .live-home .timerange {
  display: inline-flex;
  border: 1px solid var(--eu-border-strong);
  border-radius: 7px;
  overflow: hidden;
  background: var(--eu-panel);
}
.live-home .toggle button, .live-home .theme-toggle button, .live-home .timerange button {
  border: 0; border-radius: 0;
  background: transparent;
  padding: 6px 11px;
  color: var(--eu-muted);
  font-weight: 500;
  font-size: 12px;
}
.live-home .toggle button + button, .live-home .theme-toggle button + button, .live-home .timerange button + button {
  border-left: 1px solid var(--eu-border-strong);
}
.live-home .toggle button:hover, .live-home .theme-toggle button:hover, .live-home .timerange button:hover {
  color: var(--eu-text);
  background: var(--eu-panel-2);
}
.live-home .toggle button.on, .live-home .theme-toggle button.is-active, .live-home .timerange button.on {
  background: var(--eu-accent);
  color: #fff;
  font-weight: 600;
}
.live-home .page-dd {
  position: relative;
  display: inline-block;
}
.live-home .page-dd-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 11px;
  border-radius: 7px;
  font-size: 12.5px; font-weight: 600;
  border: 1px solid var(--eu-border-strong);
  background: var(--eu-panel);
  color: var(--eu-text);
  min-width: 130px;
  transition: background 120ms, border-color 120ms;
}
.live-home .page-dd-btn:hover { background: var(--eu-panel-2); border-color: var(--eu-accent-soft-2); }
.live-home .page-dd-btn.open { background: var(--eu-panel-2); border-color: var(--eu-accent); }
.live-home .page-dd-btn .live-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--eu-bad);
  box-shadow: 0 0 0 0 rgba(196,48,48,0.6);
  animation: pulse 1.6s ease-out infinite;
  flex-shrink: 0;
}
.live-home .page-dd-btn .label { flex: 1; text-align: left; }
.live-home .page-dd-btn .chev { color: var(--eu-muted); transition: transform 120ms; }
.live-home .page-dd-btn.open .chev { transform: rotate(180deg); }
@keyframes pulse{
  0%   { box-shadow: 0 0 0 0 rgba(196,48,48,0.55); }
  70%  { box-shadow: 0 0 0 6px rgba(196,48,48,0); }
  100% { box-shadow: 0 0 0 0 rgba(196,48,48,0); }
}
.live-home .page-dd-panel {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 360px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border-strong);
  border-radius: 9px;
  box-shadow: var(--eu-shadow-pop);
  padding: 6px;
  z-index: 50;
  display: none;
}
.live-home .page-dd-pref {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px;
}
.live-home .page-dd-pref .pref-label {
  font-size: 12px;
  color: var(--eu-muted);
  flex: 1;
  display: inline-flex; align-items: center; gap: 8px;
}
.live-home .page-dd-pref .pref-label .icon {
  width: 13px; height: 13px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--eu-muted-2);
}
.live-home .page-dd-panel .theme-toggle button, .live-home .page-dd-panel .toggle button {
  padding: 4px 9px;
  font-size: 11px;
}
.live-home .page-dd-footer {
  display: flex; align-items: center; gap: 10px;
  padding: 10px;
  margin-top: 4px;
  border-top: 1px solid var(--eu-border);
}
.live-home .page-dd-footer .brand-logo {
  width: 36px; height: 36px;
  flex-shrink: 0;
  display: block;
}
.live-home .page-dd-footer .brand-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
  line-height: 1.35;
}
.live-home .page-dd-footer .brand-text .name {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--eu-text);
}
.live-home .page-dd-footer .brand-text .copy {
  font-size: 9.5px;
  color: var(--eu-muted-2);
}
.live-home .page-dd-panel.open { display: block; }
.live-home .page-dd-option {
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  padding: 8px 10px;
  border-radius: 6px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 13px;
  color: var(--eu-text);
  text-align: left;
  cursor: pointer;
}
.live-home .page-dd-option:hover { background: var(--eu-panel-2); }
.live-home .page-dd-option.active {
  background: var(--eu-accent-soft);
  color: var(--eu-accent);
  font-weight: 600;
}
.live-home .page-dd-option .icon {
  width: 14px; height: 14px;
  color: var(--eu-muted);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.live-home .page-dd-option.active .icon { color: var(--eu-accent); }
.live-home .page-dd-option .name { flex: 1; }
.live-home .page-dd-option .live-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 1px 7px;
  border-radius: 999px;
  background: rgba(196,48,48,0.10);
  border: 1px solid rgba(196,48,48,0.28);
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--eu-bad);
  text-transform: uppercase;
}
.live-home .page-dd-option .live-pill .dot {
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--eu-bad);
  animation: pulse 1.6s ease-out infinite;
}
.live-home .page-dd-option .check {
  color: var(--eu-accent);
  font-size: 12px;
  flex-shrink: 0;
}
.live-home .page-dd-section {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  padding: 6px 10px 4px;
}
.live-home .ms-dd { position: relative; display: inline-block; }
.live-home .ms-dd-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 10px;
  border-radius: 7px;
  font-size: 12px; font-weight: 500;
  border: 1px solid var(--eu-border);
  background: var(--eu-panel-2);
  color: var(--eu-text);
  transition: background 120ms, border-color 120ms;
}
.live-home .ms-dd-btn:hover { background: var(--eu-panel-3); }
.live-home .ms-dd-btn.open { background: var(--eu-panel-3); border-color: var(--eu-accent); }
.live-home .ms-dd-btn.has-selection {
  background: var(--eu-accent-soft);
  border-color: var(--eu-accent-soft-2);
  color: var(--eu-accent);
}
.live-home .ms-dd-btn .chev { transition: transform 120ms; opacity: 0.6; }
.live-home .ms-dd-btn.open .chev { transform: rotate(180deg); }
.live-home .ms-dd-btn .pill-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 17px; height: 16px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--eu-accent);
  color: #fff;
  font-size: 10px; font-weight: 700;
  margin-left: 1px;
}
/* LIVE-UX-POLISH-01 (Change 1) — the count chip is HIDDEN when empty. Before, the min-width pill
   rendered as a persistent blue dot that read as a notification badge even with no filter active. */
.live-home .ms-dd-btn .pill-count:empty { display: none; }

/* LIVE-UX-POLISH-01 (Change 1) — Filter cluster: the four dropdowns grouped under one labeled group
   with a Clear-all, so filters read as filters (distinct from nav / time-band / Assistant). */
.live-home .filter-cluster {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 5px;
  border: 1px solid var(--eu-border);
  border-radius: 9px;
  background: var(--eu-panel);
}
.live-home .filter-cluster .fc-label {
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--eu-muted-2);
  padding: 0 2px 0 5px;
}
.live-home .filter-cluster .fc-clear {
  display: none;   /* shown only when .filter-cluster.has-active (≥1 filter selected) */
  align-items: center; gap: 4px;
  padding: 5px 9px;
  border: 1px dashed var(--eu-border-strong);
  border-radius: 7px;
  background: transparent;
  color: var(--eu-muted);
  font-size: 11.5px; font-weight: 600;
  cursor: pointer;
}
.live-home .filter-cluster.has-active .fc-clear { display: inline-flex; }
.live-home .filter-cluster .fc-clear:hover { color: var(--eu-bad); border-color: var(--eu-bad); }
.live-home .filter-cluster .fc-clear svg { display: block; }

/* LIVE-UX-POLISH-01 (Change 1) — Assistant gets action styling (filled accent CTA); it opens a
   panel, it doesn't filter, so it shouldn't share the neutral filter/nav treatment. */
.live-home .hdr-icon.hdr-cta {
  background: var(--eu-accent);
  border-color: var(--eu-accent);
  color: #fff;
  font-weight: 600;
}
.live-home .hdr-icon.hdr-cta:hover { background: var(--eu-accent); filter: brightness(1.07); }
.live-home .hdr-icon.hdr-cta svg { color: #fff; }
.live-home .ms-dd-panel {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border-strong);
  border-radius: 9px;
  box-shadow: var(--eu-shadow-pop);
  padding: 5px;
  z-index: 50;
  display: none;
  max-height: 380px;
  overflow-y: auto;
}
.live-home .ms-dd-panel.open { display: block; }
.live-home .ms-dd-panel .ms-dd-head {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  padding: 6px 8px 4px;
  display: flex; justify-content: space-between; align-items: center;
}
.live-home .ms-dd-panel .ms-dd-head .clear {
  background: transparent; border: 0;
  color: var(--eu-accent);
  font-size: 10px; font-weight: 600;
  text-transform: none; letter-spacing: 0;
  cursor: pointer;
}
.live-home .ms-dd-panel .ms-dd-head .clear:hover { text-decoration: underline; }
.live-home .ms-dd-option {
  display: flex; align-items: center; gap: 9px;
  width: 100%;
  padding: 6px 8px;
  border-radius: 5px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 12.5px;
  color: var(--eu-text);
  text-align: left;
  cursor: pointer;
}
.live-home .ms-dd-option:hover { background: var(--eu-panel-2); }
.live-home .ms-dd-option .check {
  width: 14px; height: 14px;
  border: 1.5px solid var(--eu-border-strong);
  border-radius: 3px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  background: var(--eu-bg);
  color: transparent;
  transition: background 120ms, border-color 120ms;
}
.live-home .ms-dd-option.on .check {
  background: var(--eu-accent);
  border-color: var(--eu-accent);
  color: #fff;
}
.live-home .ms-dd-option.on .check svg { display: block; }
.live-home .ms-dd-option .check svg { display: none; }
.live-home .ms-dd-option .name { flex: 1; }
.live-home .ms-dd-option .ws-sw {
  width: 9px; height: 9px;
  border-radius: 2px;
  flex-shrink: 0;
}
.live-home .ms-dd-option .n {
  color: var(--eu-muted-2);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}
.live-home .ms-dd-option.is-all {
  font-weight: 600;
  border-bottom: 1px dashed var(--eu-border);
  margin-bottom: 3px;
  padding-bottom: 8px;
  border-radius: 5px 5px 0 0;
}
.live-home .ms-dd-empty {
  padding: 14px 12px;
  font-size: 12px;
  color: var(--eu-muted);
  line-height: 1.5;
  text-align: left;
}
.live-home .ms-dd-empty .empty-title {
  font-size: 12.5px;
  color: var(--eu-text);
  font-weight: 600;
  margin-bottom: 4px;
}
.live-home .ms-dd-empty .empty-sub {
  font-size: 11.5px;
  color: var(--eu-muted-2);
}
.live-home .ms-dd-foot {
  margin-top: 4px;
  padding: 8px 6px 4px;
  border-top: 1px dashed var(--eu-border);
}
.live-home .ms-dd-foot .foot-link {
  display: flex; align-items: center; gap: 7px;
  width: 100%;
  padding: 8px 10px;
  border-radius: 6px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 12.5px;
  color: var(--eu-accent);
  font-weight: 600;
  text-align: left;
  cursor: pointer;
}
.live-home .ms-dd-foot .foot-link:hover {
  background: var(--eu-accent-soft);
}
.live-home .ms-dd-foot .foot-link .icon {
  width: 13px; height: 13px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.live-home .shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 14px 24px 96px;
}
.live-home .ticker {
  background: var(--eu-panel);
  border: 1px solid var(--eu-border);
  border-radius: 10px;
  padding: 7px 14px;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 14px;
  font-family: 'SF Mono', 'JetBrains Mono', Menlo, monospace;
  font-size: 11.5px;
  color: var(--eu-muted);
  overflow: hidden;
}
.live-home .ticker .label {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
}
.live-home .ticker .label .dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--eu-good);
  animation: pulse-g 2s ease-out infinite;
}
.live-home .ticker-context {
  background: transparent;
  border: 0;
  padding: 2px 6px 2px 0;
  margin-right: 4px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 4px;
  cursor: pointer;
  transition: background 120ms;
}
.live-home .ticker-context:hover { background: var(--eu-panel-2); }
.live-home .ticker-context .ctx-name {
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: var(--eu-text);
  text-transform: none;
}
.live-home .ticker-context .ctx-chev { color: var(--eu-muted-2); opacity: 0.6; }
@keyframes pulse-g{
  0%   { box-shadow: 0 0 0 0 rgba(12,148,102,0.55); }
  70%  { box-shadow: 0 0 0 6px rgba(12,148,102,0); }
  100% { box-shadow: 0 0 0 0 rgba(12,148,102,0); }
}
.live-home .ticker .stream {
  flex: 1; min-width: 0;
  display: flex; align-items: center;
  white-space: nowrap; overflow: hidden;
  mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 60px), transparent);
}
/* ISPY-LIVE-01d-ticker-scroll — marquee on the inner track (renderTicker duplicates the ticks so
   translateX(-50%) = exactly one copy → seamless loop). .stream stays the fixed overflow+mask
   viewport above; animating the clip container itself would just slide the whole box (no scroll).
   Per design call 2026-05-28 — deviation from the v5 mockup (silent on motion), documented in the PR. */
@keyframes ticker-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.live-home .ticker .stream-track {
  display: flex; align-items: center; gap: 22px;
  width: max-content; flex-shrink: 0;
  animation: ticker-marquee 60s linear infinite;
}
.live-home .ticker .stream:hover .stream-track { animation-play-state: paused; }
@media (prefers-reduced-motion: reduce) {
  .live-home .ticker .stream-track { animation: none; }
}
.live-home .ticker .tick { display: inline-flex; align-items: center; gap: 7px; flex-shrink: 0; }
.live-home .ticker .t-time { color: var(--eu-muted-2); font-size: 10.5px; }
.live-home .ticker .t-source {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 1px 6px; border-radius: 4px;
  background: var(--eu-panel-2);
  border: 1px solid var(--eu-border);
  color: var(--eu-text);
  font-size: 10.5px;
}
.live-home .ticker em { color: var(--eu-accent); font-style: normal; font-weight: 600; }
/* ACTIVITY-ROW-REFINE-01 — ticker surface dot + headline (replaces SP initials + the dead `· —`). */
.live-home .ticker .tick .bd { flex-shrink: 0; }
.live-home .ticker .t-head { color: var(--eu-muted); font-size: 10.5px; white-space: nowrap; }
.live-home .chipstrip {
  background: var(--eu-panel);
  border: 1px solid var(--eu-border);
  border-radius: 10px;
  padding: 6px 12px;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
}
.live-home .cs-label {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  flex-shrink: 0;
}
.live-home .cs-tabs {
  display: inline-flex;
  background: var(--eu-panel-2);
  border: 1px solid var(--eu-border);
  border-radius: 7px;
  padding: 2px;
  gap: 2px;
}
.live-home .cs-tabs button {
  border: 0;
  background: transparent;
  padding: 4px 11px;
  border-radius: 5px;
  font-size: 11.5px;
  color: var(--eu-muted);
}
.live-home .cs-tabs button:hover { color: var(--eu-text); }
.live-home .cs-tabs button.on {
  background: var(--eu-bg);
  color: var(--eu-text);
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(15,23,42,.06);
}
.live-home .cs-chips {
  display: flex; gap: 5px;
  flex: 1; min-width: 0;
  flex-wrap: nowrap; overflow-x: auto;
  scrollbar-width: thin;
}
.live-home .cs-chips .ch {
  flex-shrink: 0;
  padding: 4px 11px;
  border-radius: 999px;
  font-size: 11.5px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--eu-muted);
  display: inline-flex; align-items: center; gap: 5px;
}
.live-home .cs-chips .ch:hover { color: var(--eu-text); background: var(--eu-panel-2); }
.live-home .cs-chips .ch.on {
  background: var(--eu-accent-soft);
  border-color: var(--eu-accent-soft-2);
  color: var(--eu-accent);
  font-weight: 600;
}
.live-home .cs-chips .ch .n { color: var(--eu-muted-2); font-size: 10.5px; }
.live-home .cs-chips .ch.on .n { color: var(--eu-accent); opacity: 0.85; }
.live-home .cs-filters-btn {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11.5px; font-weight: 500;
  border: 1px solid var(--eu-border);
  background: var(--eu-bg);
  color: var(--eu-muted);
}
.live-home .cs-filters-btn:hover { color: var(--eu-accent); border-color: var(--eu-accent-soft-2); background: var(--eu-accent-soft); }
.live-home .cs-filters-btn.has-active {
  border-color: var(--eu-accent-soft-2);
  background: var(--eu-accent-soft);
  color: var(--eu-accent);
  font-weight: 600;
}
.live-home .cs-filters-btn .badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 16px; height: 16px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--eu-accent);
  color: #fff;
  font-size: 10px; font-weight: 700;
}
.live-home .active-lens-bar {
  display: none;
  margin-bottom: 8px;
}
.live-home .active-lens-bar.show { display: block; }
.live-home .cs-active-lens {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center; gap: 6px;
  padding: 4px 11px;
  border-radius: 6px;
  font-size: 11.5px; font-weight: 600;
  border: 1px solid;
}
.live-home .cs-active-lens .clear {
  margin-left: 4px;
  font-size: 14px; line-height: 1;
  color: inherit;
  opacity: 0.6;
}
.live-home .cs-active-lens .clear:hover { opacity: 1; }
.live-home .cs-active-lens[data-lens="auto"] { background: rgba(91,33,182,0.08);  color: var(--st-auto);     border-color: rgba(91,33,182,0.24); }
.live-home .cs-active-lens[data-lens="assisted"] { background: rgba(38,96,214,0.08);  color: var(--st-assisted); border-color: rgba(38,96,214,0.24); }
.live-home .cs-active-lens[data-lens="manual"] { background: rgba(124,138,163,0.12); color: var(--st-manual);  border-color: rgba(124,138,163,0.30); }
.live-home .cs-signals {
  display: none;
  flex-basis: 100%;
  padding-top: 6px; margin-top: 4px;
  border-top: 1px dashed var(--eu-border);
  gap: 6px; flex-wrap: wrap;
}
.live-home .cs-signals.show { display: flex; }
.live-home .sig-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px; font-weight: 500;
  border: 1px solid var(--eu-border);
  background: var(--eu-panel-2);
  color: var(--eu-muted);
}
.live-home .sig-chip:hover { color: var(--eu-text); }
.live-home .sig-chip.on {
  background: var(--eu-accent-soft);
  border-color: var(--eu-accent-soft-2);
  color: var(--eu-accent);
  font-weight: 600;
}
.live-home .sig-chip .x { opacity: 0.6; font-size: 10px; }
.live-home .cloud {
  background: var(--eu-panel);
  border: 1px solid var(--eu-border);
  border-radius: 10px;
  padding: 6px 12px;
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 10px;
  overflow-x: auto;
  scrollbar-width: thin;
}
.live-home .cloud .label {
  flex-shrink: 0;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
}
.live-home .cloud .terms { display: flex; gap: 5px; flex-wrap: nowrap; }
.live-home .cloud .term {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 9px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--eu-text);
  font-size: 12px;
  flex-shrink: 0;
}
.live-home .cloud .term:hover { background: var(--eu-panel-2); }
.live-home .cloud .term.on {
  background: var(--eu-accent-soft);
  border-color: var(--eu-accent-soft-2);
  color: var(--eu-accent);
  font-weight: 600;
}
.live-home .cloud .term b { color: var(--eu-accent); font-weight: 600; }
.live-home .live-grid {
  display: grid;
  grid-template-columns: 280px 1fr 1fr 1fr;
  gap: 10px;
  align-items: stretch; /* all 4 columns share the same height — fits 13" MacBook one-page view */
  /* Height budgeted for 13" MacBook (≈800px viewport minus 170px page chrome) */
  height: calc(100vh - 175px);
  min-height: 540px;
  max-height: 760px;
}
.live-home .panel-card {
  background: var(--eu-panel);
  border: 1px solid var(--eu-border);
  border-radius: 10px;
  box-shadow: var(--eu-shadow-pop);
  overflow: hidden;
  display: flex; flex-direction: column;
  position: relative;
  /* Fill the grid cell so all 4 columns are the same height */
  height: 100%;
  max-height: 100%;
}
.live-home .live-grid > aside.panel-card {
  overflow-y: auto;
}
.live-home .sb-section {
  padding: 8px 14px;
  border-top: 1px solid var(--eu-border);
}
.live-home .sb-section:first-child { border-top: none; padding-top: 10px; }
.live-home .sb-section .head {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  margin-bottom: 6px;
}
/* LEFT-RAIL-SCORECARD-01 — band header (single window label at the top of the rail). */
.live-home .sb-bandhead { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.live-home .sb-bandhead .bh-window { font-size: 12px; font-weight: 600; color: var(--eu-text); text-transform: capitalize; }
.live-home .sb-bandhead .bh-n { font-size: 11px; color: var(--eu-muted-2); font-variant-numeric: tabular-nums; }
/* LEFT-RAIL-SCORECARD-01 — Tokenomics tile (I/O + cache totals, no $; links to the full page). */
.live-home .sb-tokenomics .tok-row { display: flex; gap: 18px; margin: 6px 0 5px; }
.live-home .sb-tokenomics .tok-stat { display: flex; flex-direction: column; gap: 1px; }
.live-home .sb-tokenomics .tok-stat .big { font-size: 17px; font-weight: 600; color: var(--eu-text); font-variant-numeric: tabular-nums; line-height: 1.1; }
.live-home .sb-tokenomics .tok-stat .lbl { font-size: 10px; color: var(--eu-muted-2); }
/* tokdelta — band-over-band I/O delta line; empty (zero-height) until the prior-band fetch lands */
.live-home .sb-tokenomics .tok-delta { font-size: 10.5px; color: var(--eu-muted-2); font-variant-numeric: tabular-nums; margin: 0 0 4px; min-height: 0; }
.live-home .sb-tokenomics .tok-delta:empty { display: none; }
.live-home .sb-tokenomics .tok-link { background: none; border: none; padding: 0; cursor: pointer; font-size: 11px; color: var(--eu-accent); font-weight: 500; }
.live-home .sb-tokenomics .tok-link:hover { text-decoration: underline; }
.live-home .sb-headstrip { padding: 10px 14px 8px; }
.live-home .sb-headstrip .hs-row {
  display: flex; align-items: center; gap: 11px;
}
.live-home .sb-headstrip .sb-glyph { width: 30px; height: 30px; }
.live-home .sb-headstrip .sb-glyph .core { width: 6px; height: 6px; }
.live-home .sb-headstrip .hs-text { flex: 1; min-width: 0; }
.live-home .sb-headstrip .hs-mode {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
}
.live-home .sb-headstrip .hs-stat {
  display: flex; align-items: baseline; gap: 7px;
  margin-top: 1px;
}
.live-home .sb-headstrip .hs-stat .big {
  font-size: 22px; font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--eu-text);
  line-height: 1;
}
.live-home .sb-headstrip .hs-stat .lbl {
  font-size: 11px;
  color: var(--eu-muted);
}
.live-home .sb-headstrip .hs-stat .trend {
  font-size: 10.5px;
  color: var(--eu-good);
  font-weight: 500;
  margin-left: auto;
}
.live-home .sb-headstrip .anchor-spark { height: 10px; margin-top: 4px; gap: 1px; }
.live-home .sb-inline { padding-top: 9px; padding-bottom: 9px; }
.live-home .sb-inline .il-row {
  display: flex; align-items: baseline; gap: 8px;
  padding: 5px 0;
  font-size: 11.5px;
}
.live-home .sb-inline .il-row + .il-row { border-top: 1px dashed var(--eu-border); }
.live-home .sb-inline .il-label {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  width: 72px;
  flex-shrink: 0;
}
.live-home .sb-inline .il-big {
  font-size: 14px; font-weight: 600;
  color: var(--eu-text);
  white-space: nowrap;
}
.live-home .sb-inline .il-sub {
  flex: 1; min-width: 0;
  color: var(--eu-muted);
  font-size: 10.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: right;
}
.live-home .sb-state-row { display: flex; align-items: center; gap: 10px; }
.live-home .sb-glyph {
  width: 36px; height: 36px; border-radius: 50%;
  background: radial-gradient(circle at center, var(--eu-accent-soft) 0%, transparent 70%);
  position: relative;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.live-home .sb-glyph::before, .live-home .sb-glyph::after {
  content: ''; position: absolute;
  border-radius: 50%;
  border: 1px solid var(--eu-accent);
  width: 100%; height: 100%;
  opacity: 0.45;
}
.live-home .sb-glyph::before { animation: ring 3s ease-out infinite; }
.live-home .sb-glyph::after { animation: ring 3s ease-out infinite; animation-delay: 1.5s; }
.live-home .sb-glyph .core {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--eu-accent);
  box-shadow: 0 0 8px var(--eu-accent);
}
@keyframes ring{
  0%   { transform: scale(0.4); opacity: 0.7; }
  100% { transform: scale(1.2); opacity: 0; }
}
.live-home .sb-state .l1 {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
}
.live-home .sb-state .l2 { font-size: 14px; font-weight: 600; color: var(--eu-text); }
.live-home .anchor-row { display: flex; align-items: baseline; gap: 8px; }
.live-home .anchor-big { font-size: 28px; font-weight: 600; letter-spacing: -0.02em; line-height: 1; }
.live-home .anchor-trend { font-size: 11.5px; color: var(--eu-good); font-weight: 500; }
.live-home .anchor-spark {
  display: flex; align-items: flex-end; gap: 2px;
  height: 16px; margin-top: 8px;
}
.live-home .anchor-spark span {
  flex: 1; background: var(--eu-accent);
  border-radius: 2px; opacity: 0.45;
}
.live-home .anchor-spark span:last-child { opacity: 1; }
.live-home .anchor-sub {
  font-size: 10.5px;
  color: var(--eu-muted-2);
  margin-top: 5px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
}
.live-home .sb-tristate {
  position: relative;
}
.live-home .sb-tristate.is-filtering::before {
  content: 'Filter active';
  position: absolute;
  top: 12px; right: 14px;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--eu-accent);
  text-transform: uppercase;
}
.live-home .sb-tristate .head-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.live-home .sb-tristate .head {
  margin: 0;
}
.live-home .sb-tristate .lens-hint {
  font-size: 10px;
  color: var(--eu-muted-2);
  font-style: italic;
}
.live-home .tri {
  display: flex; height: 8px;
  border-radius: 999px; overflow: hidden;
  background: var(--eu-panel-2);
  margin-bottom: 8px;
}
.live-home .tri span { display: block; height: 100%; }
.live-home .tri .tri-auto { background: var(--st-auto); }
.live-home .tri .tri-assisted { background: var(--st-assisted); }
.live-home .tri .tri-manual { background: var(--st-manual); }
/* CONNECTIONS-UI-01h — all-calibrating state (nothing actor-classified in window): muted grey bar. */
.live-home .tri .tri-cal { background: rgba(124,138,163,0.28); }
.live-home .tri-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 4px;
}
.live-home .tri-tile {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 3px;
  padding: 7px 4px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  border-radius: 6px;
  cursor: pointer;
  font: inherit;
  transition: background 120ms, border-color 120ms;
}
.live-home .tri-tile:hover { background: var(--eu-panel-2); }
.live-home .tri-tile.on[data-lens="auto"] { background: rgba(91,33,182,0.10);  border-color: rgba(91,33,182,0.32); }
.live-home .tri-tile.on[data-lens="assisted"] { background: rgba(38,96,214,0.10);  border-color: rgba(38,96,214,0.32); }
.live-home .tri-tile.on[data-lens="manual"] { background: rgba(124,138,163,0.16); border-color: rgba(124,138,163,0.36); }
.live-home .tri-tile .val {
  font-size: 14px; font-weight: 600;
  color: var(--eu-text);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.live-home .tri-tile .lbl {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 9.5px;
  color: var(--eu-muted);
  font-weight: 500;
  letter-spacing: 0.02em;
}
.live-home .tri-tile .sw { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.live-home .tri-tile .sw.auto { background: var(--st-auto); }
.live-home .tri-tile .sw.assisted { background: var(--st-assisted); }
.live-home .tri-tile .sw.manual { background: var(--st-manual); }
/* CONNECTIONS-UI-01h — empty lane (no events of this actor_class in the window): greyed, no lens. */
.live-home .tri-tile.disabled { opacity: 0.42; cursor: default; }
.live-home .tri-tile.disabled:hover { background: none; }
/* Calibrating sub-note: events without an actor_class yet (ispy, pre ISPY-ACTOR-CLASS-01). */
.live-home .sb-tristate .tri-calibrating {
  margin-top: 6px; font-size: 9px; color: var(--eu-muted-2);
  text-align: center; letter-spacing: 0.02em;
}
.live-home .tri-legend { display: flex; flex-direction: column; gap: 2px; }
.live-home .tri-legend .row {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11.5px;
  padding: 3px 7px;
  border-radius: 5px;
  cursor: pointer;
  transition: background 120ms;
  border: 1px solid transparent;
}
.live-home .tri-legend .row:hover { background: var(--eu-panel-2); }
.live-home .tri-legend .row.on {
  background: var(--eu-accent-soft);
  border-color: var(--eu-accent-soft-2);
}
.live-home .tri-legend .row.on[data-lens="auto"] { background: rgba(91,33,182,0.10);  border-color: rgba(91,33,182,0.24); }
.live-home .tri-legend .row.on[data-lens="assisted"] { background: rgba(38,96,214,0.10);  border-color: rgba(38,96,214,0.24); }
.live-home .tri-legend .row.on[data-lens="manual"] { background: rgba(124,138,163,0.14); border-color: rgba(124,138,163,0.30); }
.live-home .tri-legend .name { display: inline-flex; align-items: center; gap: 7px; color: var(--eu-muted); }
.live-home .tri-legend .row.on .name { color: var(--eu-text); font-weight: 600; }
.live-home .tri-legend .swatch { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.live-home .tri-legend .swatch.auto { background: var(--st-auto); }
.live-home .tri-legend .swatch.assisted { background: var(--st-assisted); }
.live-home .tri-legend .swatch.manual { background: var(--st-manual); }
.live-home .tri-legend .val { color: var(--eu-text); font-weight: 600; font-size: 11.5px; }
.live-home .kv {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 4px 0;
  font-size: 12px;
}
.live-home .kv .k { color: var(--eu-muted); }
.live-home .kv .v { color: var(--eu-text); font-weight: 600; }
.live-home .kv + .kv { border-top: 1px dashed var(--eu-border); }
.live-home .wfc-list { display: flex; flex-direction: column; gap: 5px; }
.live-home .wfc-list .wfc-row { display: flex; align-items: center; gap: 8px; font-size: 11.5px; }
.live-home .wfc-list .wfc-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.live-home .wfc-list .wfc-name { flex: 1; color: var(--eu-text); }
.live-home .wfc-list .wfc-n { color: var(--eu-muted); font-variant-numeric: tabular-nums; }
.live-home .sb-worktime .total {
  display: flex; align-items: baseline; gap: 8px;
  margin-bottom: 5px;
}
.live-home .sb-worktime .total .big {
  font-size: 17px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--eu-text);
  line-height: 1;
}
.live-home .sb-worktime .total .wait {
  font-size: 10.5px;
  color: var(--eu-muted-2);
}
.live-home .sb-worktime .total .wait b { color: var(--eu-accent); font-weight: 600; }
.live-home .ws-stack {
  display: flex; height: 8px;
  border-radius: 999px; overflow: hidden;
  background: var(--eu-panel-2);
  margin-bottom: 8px;
}
.live-home .ws-stack span { display: block; height: 100%; }
.live-home .ws-stack .think { background: var(--ws-think); }
.live-home .ws-stack .search { background: var(--ws-search); }
.live-home .ws-stack .read { background: var(--ws-read); }
.live-home .ws-stack .write { background: var(--ws-write); }
.live-home .ws-stack .tool { background: var(--ws-tool); }
.live-home .ws-stack .gen { background: var(--ws-gen); }
.live-home .ws-legend {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1px 8px;
  font-size: 9.5px;
}
.live-home .ws-legend .row { display: flex; align-items: center; gap: 5px; }
.live-home .ws-legend .sw { width: 7px; height: 7px; border-radius: 2px; flex-shrink: 0; }
.live-home .ws-legend .nm { color: var(--eu-muted); flex: 1; min-width: 0; }
.live-home .ws-legend .pc { color: var(--eu-text); font-weight: 600; font-variant-numeric: tabular-nums; }
.live-home .ws-legend .sw.think { background: var(--ws-think); }
.live-home .ws-legend .sw.search { background: var(--ws-search); }
.live-home .ws-legend .sw.read { background: var(--ws-read); }
.live-home .ws-legend .sw.write { background: var(--ws-write); }
.live-home .ws-legend .sw.tool { background: var(--ws-tool); }
.live-home .ws-legend .sw.gen { background: var(--ws-gen); }
/* LLM-STATE-01 c9 (§9.4): Tier-1 Work Shape legend — one shape per line, clickable into the
   §9.5 cognitive drill-down. Swatch colors are inlined from WS_SHAPE_META (not the cognitive vars). */
.live-home .sb-worktime .ws-legend.ws-shapes { grid-template-columns: 1fr; gap: 2px 0; }
.live-home .ws-legend.ws-shapes .row {
  padding: 2px 5px; border-radius: 5px; cursor: pointer;
}
.live-home .ws-legend.ws-shapes .row:hover { background: var(--eu-panel-2); }
.live-home .ws-legend.ws-shapes .row.zero { opacity: 0.5; }
.live-home .ws-legend.ws-shapes .row.zero:hover { opacity: 0.7; }
.live-home .ws-legend.ws-shapes .ct {
  color: var(--eu-muted-2); font-variant-numeric: tabular-nums; min-width: 36px; text-align: right;
}
.live-home .sb-worktime .ws-cta {
  margin-top: 8px; width: 100%; text-align: left;
  font-size: 9.5px; color: var(--eu-accent);
  background: none; border: 1px solid var(--eu-border); border-radius: 6px;
  padding: 4px 8px; cursor: pointer;
}
.live-home .sb-worktime .ws-cta:hover { background: var(--eu-panel-2); }

/* §9.5 cognitive drill-down modal (rendered at <body>, outside .live-home) */
.cog-modal .cog-card { max-width: 460px; width: 92%; padding: 0; }
.cog-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; border-bottom: 1px solid var(--eu-border);
}
.cog-title { font-weight: 600; font-size: 13px; color: var(--eu-text); }
.cog-close { background: none; border: none; font-size: 19px; line-height: 1; cursor: pointer; color: var(--eu-muted); }
.cog-body { padding: 12px 14px; }
.cog-row { display: flex; align-items: center; gap: 8px; font-size: 11px; margin-bottom: 7px; }
.cog-row .sw { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.cog-row .nm { width: 66px; color: var(--eu-text); flex-shrink: 0; }
.cog-row .bar { flex: 1; height: 7px; background: var(--eu-panel-2); border-radius: 999px; overflow: hidden; }
.cog-row .bar span { display: block; height: 100%; }
.cog-row .pc { width: 34px; text-align: right; font-weight: 600; font-variant-numeric: tabular-nums; color: var(--eu-text); }
.cog-row .ct { width: 70px; text-align: right; color: var(--eu-muted-2); font-variant-numeric: tabular-nums; }
.cog-note { font-size: 11.5px; color: var(--eu-muted); line-height: 1.5; }
.cog-foot { font-size: 10px; color: var(--eu-muted-2); margin-top: 10px; border-top: 1px solid var(--eu-border); padding-top: 8px; line-height: 1.4; }
.live-home .now-row {
  margin-top: 6px;
  padding: 5px 9px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  border-radius: 6px;
  font-size: 10px;
  color: var(--eu-muted);
  display: flex; align-items: center; gap: 6px;
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
  width: 100%;
}
.live-home .now-row:hover { border-color: var(--eu-accent); background: var(--eu-accent-soft); }
.live-home .now-row .live-tick {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--eu-accent);
  box-shadow: 0 0 6px var(--eu-accent);
  animation: pulse-b 2s ease-out infinite;
  flex-shrink: 0;
}
.live-home .now-row b { color: var(--eu-text); font-variant-numeric: tabular-nums; }
.live-home .now-row em { color: var(--eu-accent); font-style: normal; }
.live-home .now-row .arrow {
  margin-left: auto;
  color: var(--eu-accent);
  font-size: 13px;
  opacity: 0.6;
}
.live-home .now-row:hover .arrow { opacity: 1; }
.live-home .fp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.live-home .fp-tile {
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  border-radius: 8px;
  padding: 8px 10px;
  text-align: center;
}
.live-home .fp-tile.privacy { border-left: 2px solid var(--eu-accent); }
.live-home .fp-tile.noise { border-left: 2px solid var(--eu-accent-2); }
/* LIVE-FILTER-PULSE-PCT-DROP — renamed .pct → .count (same prominence; headline is the raw count, not a %). */
.live-home .fp-tile .count { font-size: 18px; font-weight: 600; line-height: 1.1; }
.live-home .fp-tile.privacy .count { color: var(--eu-accent); }
.live-home .fp-tile.noise   .count { color: var(--eu-accent-2); }
.live-home .fp-tile .lbl {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  margin-top: 3px;
}
.live-home .fp-tile .sub { font-size: 10px; color: var(--eu-muted-2); margin-top: 1px; }
.live-home .sb-head-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
  gap: 6px;
}
.live-home .sb-head-toggle {
  display: inline-flex; align-items: center; gap: 4px;
  background: transparent;
  border: 0;
  padding: 0;
  font: inherit;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  cursor: pointer;
}
.live-home .sb-head-toggle:hover { color: var(--eu-text); }
.live-home .sb-head-toggle .chev { opacity: 0.55; }
.live-home .sb-head-actions {
  display: inline-flex; align-items: center; gap: 6px;
}
.live-home .sb-head-filter {
  width: 18px; height: 18px;
  border-radius: 4px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  color: var(--eu-muted-2);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  padding: 0;
}
.live-home .sb-head-filter svg { display: block; }
.live-home .sb-head-filter:hover { color: var(--eu-accent); border-color: var(--eu-accent); }
.live-home .sb-head-filter.has-active {
  background: var(--eu-accent-soft);
  border-color: var(--eu-accent-soft-2);
  color: var(--eu-accent);
}
.live-home .sb-head-pagination {
  display: inline-flex; align-items: center; gap: 3px;
  font-family: 'SF Mono', Menlo, monospace;
  font-size: 9px;
  color: var(--eu-muted);
}
.live-home .sb-head-pagination button {
  width: 16px; height: 16px;
  border-radius: 3px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  color: var(--eu-muted);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  padding: 0;
}
.live-home .sb-head-pagination button svg { display: block; }
.live-home .sb-head-pagination button:hover:not(:disabled) { color: var(--eu-accent); border-color: var(--eu-accent); }
.live-home .sb-head-pagination button:disabled { opacity: 0.35; cursor: not-allowed; }
.live-home .sb-head-pagination .info { padding: 0 2px; }
.live-home .users { display: flex; flex-direction: column; gap: 2px; }
.live-home .user-row {
  display: flex; align-items: center; gap: 7px;
  padding: 3px 7px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  border-radius: 5px;
}
.live-home .user-row .avatar {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--eu-accent-soft);
  border: 1px solid var(--eu-accent-soft-2);
  color: var(--eu-accent);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 8.5px; font-weight: 700;
  flex-shrink: 0;
}
.live-home .user-row .meta { flex: 1; min-width: 0; display: flex; flex-direction: column; line-height: 1.2; }
.live-home .user-row .name { font-size: 11px; color: var(--eu-text); font-weight: 500; }
.live-home .user-row .sub { font-size: 9.5px; color: var(--eu-muted-2); }
.live-home .user-row .count { font-size: 11.5px; font-weight: 600; color: var(--eu-text); white-space: nowrap; }
.live-home .col { /* min-height removed — height now driven by grid cell */ }
.live-home .col-head {
  padding: 9px 14px;
  border-bottom: 1px solid var(--eu-border);
  display: flex; align-items: baseline; justify-content: space-between;
  flex-shrink: 0;
  /* Single row, always: title left, controls/echo right (pre-polish layout, restored per Shane
     2026-06-11 — the Activity head no longer carries a count, so nothing needs to wrap). */
}
.live-home .col-head .title { font-size: 13px; font-weight: 600; color: var(--eu-text); }
.live-home .col-head .now {
  font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
}
.live-home .col-body {
  flex: 1; min-height: 0;
  display: flex; flex-direction: column;
  /* Columns scroll WITHIN their fixed height so all loaded rows are accessible.
     Pagination in col-foot loads the next batch from backend when scrolled to bottom. */
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--eu-border-strong) transparent;
}
.live-home .col-body::-webkit-scrollbar { width: 6px; }
.live-home .col-body::-webkit-scrollbar-track { background: transparent; }
.live-home .col-body::-webkit-scrollbar-thumb { background: var(--eu-border-strong); border-radius: 3px; }
.live-home .col-body::-webkit-scrollbar-thumb:hover { background: var(--eu-muted-2); }
.live-home .col-foot {
  padding: 6px 12px;
  border-top: 1px solid var(--eu-border);
  background: var(--eu-accent-soft);
  color: var(--eu-accent);
  font-size: 11px; font-weight: 500;
  display: flex; justify-content: space-between; align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.live-home .col-foot .plus { font-weight: 700; }
.live-home .col-foot .upd { font-size: 10px; color: var(--eu-muted-2); font-family: 'SF Mono', Menlo, monospace; }
.live-home .col-foot .arrow { opacity: 0.7; }
.live-home .col-foot .count-text { font-size: 11px; color: var(--eu-accent); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.live-home .pagination {
  display: inline-flex; align-items: center; gap: 5px;
  flex-shrink: 0;
}
/* LIVE-UX-POLISH-01 (Change 6) — the ‹ › pager glyphs are text, so `font-size: 0` (the old value)
   rendered them as bare invisible squares. Give them a visible size at AA contrast, ≥24px targets,
   and a dimmed-but-still-visible disabled state (was opacity 0.35 over an invisible glyph). */
.live-home .pagination button {
  width: 24px; height: 24px;
  border-radius: 5px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  color: var(--eu-text);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: 15px; line-height: 1; font-weight: 600;
  padding: 0;
}
.live-home .pagination button svg { display: block; }
.live-home .pagination button:hover:not(:disabled) {
  color: var(--eu-accent);
  border-color: var(--eu-accent);
}
.live-home .pagination button:disabled { opacity: 0.4; color: var(--eu-muted-2); cursor: not-allowed; }
.live-home .pagination .page-info {
  font-family: 'SF Mono', Menlo, monospace;
  font-size: 10px;
  color: var(--eu-muted);
  min-width: 38px;
  text-align: center;
}
.live-home .row-item {
  padding: 10px 14px;
  border-bottom: 1px solid var(--eu-border);
  display: flex; flex-direction: column; gap: 5px;
  transition: background 120ms, border-left-color 120ms;
  border-left: 2px solid transparent;
}
.live-home .row-item:hover { background: var(--eu-bg); }
.live-home .row-item.highlight {
  background: var(--eu-accent-soft);
  border-left-color: var(--eu-accent);
}
.live-home .row-item .r-top {
  display: flex; align-items: center; gap: 6px;
  font-size: 10.5px; color: var(--eu-muted-2);
}
.live-home .r-livedot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--eu-accent);
  box-shadow: 0 0 6px var(--eu-accent);
  animation: pulse-b 2s ease-out infinite;
  flex-shrink: 0;
}
@keyframes pulse-b{
  0%   { box-shadow: 0 0 0 0 rgba(38,96,214,0.55); }
  70%  { box-shadow: 0 0 0 5px rgba(38,96,214,0); }
  100% { box-shadow: 0 0 0 0 rgba(38,96,214,0); }
}
.live-home .r-surface {
  color: var(--eu-text); font-size: 10.5px; font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; flex: 0 1 auto;
}
/* ACTIVITY-ROW-LAYOUT-01 — Line 1 fits at 280px: the surface truncates; everything to its right
   (via-Cowork, the I/O/cost corner, time, count, source badge) stays one line and never shrinks. */
.live-home .r-top .invoked-from,
.live-home .r-top .tok-corner,
.live-home .r-top .r-time,
.live-home .r-top .r-count,
.live-home .r-top .obs-badge,
.live-home .r-top .r-chain,
.live-home .r-top .bd { flex-shrink: 0; }
/* WORK-ITEM-COLLAPSE-01 — cross-surface work-item chain indicator (Cowork → Claude Code) on Line 1. */
.live-home .r-top .r-chain { display: inline-flex; align-items: center; gap: 3px; font-size: 10px; color: var(--eu-muted-2); white-space: nowrap; }
.live-home .r-top .r-chain .ch-arrow { color: var(--eu-muted-2); font-weight: 600; }
.live-home .r-time {
  margin-left: auto;
  color: var(--eu-muted-2);
  font-size: 10.5px;
  font-variant-numeric: tabular-nums;
  font-family: 'SF Mono', Menlo, monospace;
}
/* USAGE-TOKENS-01 — Tokenomics view (toggle + per-turn token corner + breakdown row). */
.live-home .col-head .tok-toggle {
  display: inline-flex; align-self: center; flex: none;
  border: 1px solid var(--eu-border); border-radius: 999px; overflow: hidden;
}
.live-home .col-head .tok-toggle .tok-seg {
  padding: 4px 11px; border: none; background: transparent; cursor: pointer;
  color: var(--eu-muted); line-height: 1; white-space: nowrap;
  display: inline-flex; align-items: center; justify-content: center;
}
.live-home .col-head .tok-toggle .tok-seg svg { width: 14px; height: 14px; display: block; pointer-events: none; }
/* Fixed brand colors: Activity = blue-grey, Tokenomics = green (same green as the row coins chip).
   Selected segment gets a soft tint of its own colour rather than a heavy fill, so the coloured
   icons stay legible in both states (and in light + dark). */
.live-home .col-head .tok-toggle .tok-seg[data-tok="0"] svg { color: var(--st-manual); }
.live-home .col-head .tok-toggle .tok-seg[data-tok="1"] svg { color: var(--eu-good); }
.live-home .col-head .tok-toggle .tok-seg.on { background: var(--eu-panel-2); }
.live-home .col-head .tok-toggle .tok-seg[data-tok="0"].on { background: rgba(100,113,134,0.16); }
.live-home .col-head .tok-toggle .tok-seg[data-tok="1"].on { background: rgba(15,138,108,0.14); }
/* SESSION-MODEL-UI-01 — group-by control + rollup header. Two controls share the right edge. */
.live-home .col-head .ch-controls { display: inline-flex; align-items: center; gap: 8px; }
/* LIVE-UX-POLISH-01 (Change 3) — Group MENU (replaces the cycling group-cyc button). A labeled chip
   "[icon] Group: <Active> ▾" opening Stream/Solution/Project/Task; the active choice is always visible. */
.live-home .col-head .grp-menu { position: relative; display: inline-flex; align-self: center; flex: none; }
/* Icon-only chip when CLOSED (the column is ~300px — labels don't fit; that's why the controls were
   icons-only). The active mode is the icon + tooltip, accent when a grouping is on. The OPEN menu
   carries the full labels + descriptions, so grouping stays discoverable. */
.live-home .col-head .grp-chip {
  display: inline-flex; align-items: center; gap: 3px; cursor: pointer; white-space: nowrap;
  padding: 4px 7px; border: 1px solid var(--eu-border); border-radius: 999px;
  background: transparent; color: var(--eu-muted); line-height: 1;
}
.live-home .col-head .grp-chip .grp-chip-ico { display: inline-flex; }
.live-home .col-head .grp-chip svg { width: 14px; height: 14px; display: block; pointer-events: none; }
.live-home .col-head .grp-chip .grp-chev { width: 9px; height: 9px; opacity: 0.55; transition: transform 120ms; }
.live-home .col-head .grp-chip.on { background: var(--eu-accent-soft); border-color: var(--eu-accent); color: var(--eu-accent); }
.live-home .col-head .grp-menu.open .grp-chip { background: var(--eu-panel-2); border-color: var(--eu-accent); color: var(--eu-text); }
.live-home .col-head .grp-menu.open .grp-chip .grp-chev { transform: rotate(180deg); }
/* Menu (mockup .gmenu / .gopt) — text-only options, bold label + description line, ✓ on selected. */
.live-home .col-head .grp-panel-head {
  padding: 4px 10px 6px; font-size: 10px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--eu-muted-2);
}
.live-home .col-head .grp-panel {
  /* position:fixed (placed by JS from the chip rect) so the scrolling Activity card can't clip it. */
  display: none; position: fixed; z-index: 60;
  width: 250px; padding: 4px;
  background: var(--eu-bg); border: 1px solid var(--eu-border); border-radius: 9px;
  box-shadow: var(--eu-shadow-pop, 0 8px 24px -6px rgba(15,23,42,0.18));
}
.live-home .col-head .grp-menu.open .grp-panel { display: block; }
.live-home .col-head .grp-opt {
  display: block; width: 100%;
  padding: 7px 10px; border: none; border-radius: 6px; background: transparent; cursor: pointer;
  text-align: left; color: var(--eu-text);
}
.live-home .col-head .grp-opt:hover { background: var(--eu-panel-2); }
.live-home .col-head .grp-opt.sel { background: var(--eu-accent-soft); color: var(--eu-accent); }
.live-home .col-head .grp-opt .gname { font-size: 12.5px; font-weight: 600; }
.live-home .col-head .grp-opt.sel .gname::before { content: "✓ "; font-weight: 700; }
.live-home .col-head .grp-opt em {
  display: block; margin-top: 2px; font-style: normal; font-weight: 400; font-size: 11px; color: var(--eu-muted-2);
}
.live-home .col-head .grp-opt.sel em { color: var(--eu-accent); opacity: 0.85; }
/* LIVE-UX-POLISH-01 (Change 3) — Solution rollup header dot (reuses the row surface .bd palette). */
.live-home .r-group .rg-dot { width: 8px; height: 8px; border-radius: 50%; flex: none; align-self: center; }
.live-home .r-group {
  display: flex; align-items: baseline; gap: 7px; cursor: pointer;
  padding: 7px 14px; background: var(--eu-surface-2, rgba(127,127,127,0.05));
  border-bottom: 1px solid var(--eu-border); font-size: 11.5px;
}
.live-home .r-group:hover { background: var(--eu-surface-3, rgba(127,127,127,0.09)); }
.live-home .r-group .rg-tw { color: var(--eu-muted-2); font-size: 10px; flex: none; }
.live-home .r-group .rg-label { font-weight: 600; color: var(--eu-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.live-home .r-group .rg-label .rg-glyph { margin-right: 2px; }
.live-home .r-group .rg-label .rg-cont { color: var(--eu-muted); font-weight: 500; }
.live-home .r-group .rg-stat { color: var(--eu-muted-2); font-size: 10.5px; white-space: nowrap; }
.live-home .r-group .rg-tok {
  margin-left: auto; color: var(--eu-text); font-size: 10.5px; white-space: nowrap;
  font-variant-numeric: tabular-nums; font-family: 'SF Mono', Menlo, monospace;
}
.live-home .r-group.ungrouped { opacity: 0.7; }
.live-home .r-group.ungrouped .rg-label { font-weight: 500; color: var(--eu-muted); }
.live-home .tok-corner {            /* legacy text corner — retained for any non-row callers */
  margin-left: auto; font-size: 10.5px; color: var(--eu-text); white-space: nowrap;
  font-variant-numeric: tabular-nums; font-family: 'SF Mono', Menlo, monospace;
}
.live-home .tok-corner.muted { color: var(--eu-muted-2); }
/* ACTIVITY-ROW-DECLUTTER-01 — Line-1 token total as a coins chip (I/O only; cache excluded). */
.live-home .r-top .tok-coins {
  margin-left: auto; flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 7px 1px 5px; border-radius: 999px;
  background: rgba(15,138,108,0.12); color: var(--eu-good);
  font-size: 10.5px; font-weight: 600; white-space: nowrap;
  font-variant-numeric: tabular-nums; font-family: 'SF Mono', Menlo, monospace;
}
.live-home .r-top .tok-coins { cursor: default; }
.live-home .r-top .tok-coins svg { width: 12px; height: 12px; flex-shrink: 0; pointer-events: none; }
.live-home .r-top .tok-coins .tc-cost { color: var(--eu-text); }
.live-home .r-top .tok-coins .tc-lim { color: var(--eu-muted); font-weight: 500; }
/* Literal in/out/cache proportion bar (cache usually dominates — that's the honest picture). */
.live-home .row-item .r-tokbar {
  display: flex; height: 5px; border-radius: 3px; overflow: hidden;
  margin: 6px 0 5px; background: var(--eu-panel-2);
}
.live-home .row-item .r-tokbar .tb-in { background: var(--eu-accent); }
.live-home .row-item .r-tokbar .tb-out { background: var(--eu-good); }
/* fixed cache marker — divider + lighter fill flags that it is NOT to scale (cache dwarfs I/O). */
.live-home .row-item .r-tokbar .tb-cache {
  background: var(--eu-border-strong); opacity: 0.65;
  box-shadow: inset 2px 0 0 var(--eu-bg);
}
.live-home .row-item .r-tokrow {
  display: flex; align-items: center; gap: 7px; flex-wrap: nowrap;
  margin-top: 4px; font-size: 10.5px; color: var(--eu-muted);
  font-variant-numeric: tabular-nums; white-space: nowrap; overflow: hidden;
}
.live-home .row-item .r-tokrow b { color: var(--eu-text); font-weight: 600; }
.live-home .row-item .r-tokrow .tk-seg { flex-shrink: 0; }
.live-home .row-item .r-tokrow .tk-cache { color: var(--eu-muted-2); }
.live-home .row-item .r-tokrow .tk-model {
  color: var(--eu-muted-2); background: var(--eu-panel-2);
  border-radius: 5px; padding: 0 5px; flex-shrink: 0;
}
.live-home .row-item .r-tokrow .tk-cost b { color: var(--eu-good); }
.live-home .row-item .r-tokrow .tk-lev { color: var(--eu-muted-2); font-style: italic; }
.live-home .row-item .r-tokrow.muted { color: var(--eu-muted-2); font-style: italic; }
/* Line-3 icon chips — state / shape / engagement / cross-surface are icon-only (label on hover);
   the workflow code keeps its label but gains a leading category glyph. */
.live-home .row-item .r-meta .wf-tag { display: inline-flex; align-items: center; gap: 3px; flex-shrink: 0; }
.live-home .row-item .r-meta .wf-tag svg { width: 11px; height: 11px; }
.live-home .row-item .r-meta .ws-ico,
.live-home .row-item .r-meta .eng-ico,
.live-home .row-item .r-meta .x-ico {
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; cursor: default;
}
.live-home .row-item .r-meta .ws-ico svg,
.live-home .row-item .r-meta .eng-ico svg,
.live-home .row-item .r-meta .x-ico svg { width: 13px; height: 13px; }
/* Make the title-bearing chip the hover target (the inner SVG has no title) so the native tooltip
   fires consistently on every line-3 icon instead of only when the cursor misses the glyph. */
.live-home .row-item .r-meta svg { pointer-events: none; }
.live-home .row-item .r-meta .ws-ico.think  { color: var(--ws-think); }
.live-home .row-item .r-meta .ws-ico.search { color: var(--ws-search); }
.live-home .row-item .r-meta .ws-ico.read   { color: var(--ws-read); }
.live-home .row-item .r-meta .ws-ico.write  { color: var(--ws-write); }
.live-home .row-item .r-meta .ws-ico.tool   { color: var(--ws-tool); }
.live-home .row-item .r-meta .ws-ico.gen    { color: var(--ws-gen); }
.live-home .row-item .r-meta .ws-ico.shape-agentic        { color: #6d54c8; }
.live-home .row-item .r-meta .ws-ico.shape-conversational { color: #0891b2; }
.live-home .row-item .r-meta .ws-ico.shape-embedded       { color: #db2777; }
.live-home .row-item .r-meta .ws-ico.shape-automated      { color: var(--eu-muted); }
.live-home .row-item .r-meta .eng-ico.manual { color: var(--st-manual); }
.live-home .row-item .r-meta .x-ico.cross    { color: var(--eu-accent); }
.live-home .row-item .r-meta .x-ico .n { font-size: 8px; font-weight: 700; margin-left: 1px; }
.live-home .row-item .r-meta .r-session svg { width: 11px; height: 11px; flex-shrink: 0; vertical-align: -1px; margin-right: 2px; }
/* SESSION-MODEL-01 — light session (Task) anchor, bottom-right of Line 3. */
.live-home .row-item .r-meta .r-session {
  margin-left: auto; color: var(--eu-muted-2); font-size: 10px; flex-shrink: 0;
  font-variant-numeric: tabular-nums; white-space: nowrap; font-family: 'SF Mono', Menlo, monospace;
}
/* ISPY-LIVE-01d-parity-col1-dedup — ×N badge on collapsed adjacent-duplicate rows. Sits to the
   right of .r-time (which already carries margin-left:auto); the .r-top flex gap spaces them. */
.live-home .r-count {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 8px;
  background: var(--eu-panel-2);
  border: 1px solid var(--eu-border-strong);
  color: var(--eu-muted);
  font-size: 11px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.live-home .row-item .r-title {
  font-size: 13px; color: var(--eu-text);
  font-weight: 500; line-height: 1.35;
  /* ACTIVITY-ROW-DECLUTTER-01 — the headline is the row's anchor: slightly larger + vertical rhythm
     so it reads clearly above the muted surface line and the icon meta line (don't-blend pass). */
  margin: 3px 0 5px;
  /* one-line truncate per density pass — full prompt shown in expand view */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.live-home .row-item .r-meta {
  display: flex; flex-wrap: nowrap; align-items: center; gap: 6px;
  font-size: 10.5px; color: var(--eu-muted-2);
  overflow: hidden;
}
.live-home .row-item .state-pill {
  font-size: 0;
  padding: 0;
  width: 9px; height: 9px;
  border-radius: 50%;
  border: 0;
  flex-shrink: 0;
  position: relative;
  overflow: visible;
}
.live-home .row-item .state-pill .dot { display: none; }
.live-home .row-item .state-pill.auto { background: var(--st-auto); }
.live-home .row-item .state-pill.assisted { background: var(--st-assisted); }
.live-home .row-item .state-pill.manual { background: var(--st-manual); }
.live-home .row-item .wf-tag {
  font-size: 9px;
  padding: 1px 5px;
  letter-spacing: 0.06em;
}
.live-home .row-item .t-chip {
  font-size: 0;
  padding: 0;
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.live-home .row-item .t-chip.t3 { background: var(--eu-good); }
.live-home .row-item .t-chip.t2 { background: var(--eu-warn); }
.live-home .row-item .t-chip.t1 { background: var(--eu-bad); }
.live-home .row-item .r-meta .r-sub {
  font-size: 10px;
  color: var(--eu-muted-2);
  margin-left: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  flex: 1;
}
.live-home .f-ico {
  display: inline-flex; align-items: center; justify-content: center;
  width: 14px; height: 14px;
  border-radius: 4px;
  font-size: 9.5px;
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', sans-serif;
  flex-shrink: 0;
  cursor: help;
}
.live-home .f-ico.priv { background: rgba(38,96,214,0.10); color: var(--eu-accent); }
.live-home .f-ico.noise { background: rgba(15,138,108,0.10); color: var(--eu-accent-2); }
.live-home .f-ico.cross { background: rgba(177,106,12,0.10); color: var(--eu-warn); }
.live-home .f-ico.stall { background: rgba(196,48,48,0.10); color: var(--eu-bad); }
.live-home .f-ico.new { background: rgba(91,33,182,0.10); color: var(--st-auto); }
.live-home .f-ico.long { background: rgba(177,106,12,0.10); color: var(--eu-warn); }
.live-home .f-ico .n { font-size: 8px; font-weight: 700; margin-left: 1px; }
.live-home .r-expand {
  /* ACTIVITY-ITEM-DRILLDOWN-01 — the whole row is the click target now; this is just a subtle chevron
     HINT (no box/border/bg — that rendered as an ugly empty rectangle). Sits after the ↳project anchor. */
  margin-left: 4px;
  width: 16px; height: 16px;
  border: 0; background: transparent; padding: 0;
  color: var(--eu-muted);
  display: inline-flex; align-items: center; justify-content: center;
  opacity: 0.5; flex-shrink: 0; cursor: pointer;
  transition: opacity 120ms, color 120ms, transform 120ms;
}
/* the row itself is clickable to expand its artifact chain (Activity column only). */
.live-home .col[data-section="col.activity"] .row-item { cursor: pointer; }
.live-home .col[data-section="col.activity"] .row-item:hover { background: var(--eu-bg); }
.live-home .col[data-section="col.activity"] .row-item:hover .r-expand { opacity: 1; color: var(--eu-accent); }
/* ACTIVITY-ITEM-DRILLDOWN-01 — expand chevron + the inline artifact-chain accordion under a row. */
.live-home .r-expand svg { width: 14px; height: 14px; pointer-events: none; transition: transform 120ms; }
.live-home .r-expand.open { opacity: 1; color: var(--eu-accent); }
.live-home .r-expand.open svg { transform: rotate(180deg); }
.live-home .r-drilldown {
  padding: 9px 12px 11px; background: var(--eu-bg);
  border-bottom: 1px solid var(--eu-border); border-left: 2px solid var(--eu-accent);
}
.live-home .r-drilldown .dd-prompt { font-size: 12px; color: var(--eu-text); line-height: 1.4; margin-bottom: 6px; }
.live-home .r-drilldown .dd-tools { font-size: 10.5px; color: var(--eu-muted); margin-bottom: 4px; font-variant-numeric: tabular-nums; }
.live-home .r-drilldown .dd-chain .row-item { padding: 5px 0; border-bottom: 0; }
/* LIVE-UX-POLISH-01 (Change 3) — inside an expansion, child artifact rows drop the repeated source
   line (surface dot + label) and the workflow chip: the parent row already established both, so the
   children read as a clean artifact chain (the drilldown rail carries the lineage). The per-step time
   stays. */
.live-home .r-drilldown .dd-chain .row-item .r-top .bd,
.live-home .r-drilldown .dd-chain .row-item .r-top .r-surface,
.live-home .r-drilldown .dd-chain .row-item .r-meta .wf-tag { display: none; }
.live-home .r-drilldown .dd-empty { font-size: 11px; color: var(--eu-muted-2); font-style: italic; }
.live-home .r-drilldown .dd-states { font-size: 10px; color: var(--eu-muted-2); margin-top: 6px; font-family: 'SF Mono', Menlo, monospace; line-height: 1.5; }
.live-home .row-item { padding: 8px 12px; }
.live-home .row-item .r-top { gap: 5px; }
.live-home .row-item .ws-chip { font-size: 9.5px; padding: 0px 6px; }
.live-home .bd {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0; display: inline-block;
}
.live-home .bd.claude { background: var(--badge-claude); }
.live-home .bd.openai { background: var(--badge-openai); }
.live-home .bd.gemini { background: var(--badge-gemini); }
.live-home .bd.perplexity { background: var(--badge-perplexity); }
.live-home .bd.cursor { background: var(--wf-dev); }
.live-home .bd.breeze { background: var(--badge-breeze); }
.live-home .amini {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--eu-panel-2);
  border: 1px solid var(--eu-border);
  color: var(--eu-text);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700;
  flex-shrink: 0;
}
.live-home .amini.accent { background: var(--eu-accent-soft); border-color: var(--eu-accent-soft-2); color: var(--eu-accent); }
.live-home .row-item .r-meta .amini { display: none; }
/* PROFILES-01 — avatar on Line 1: self-ring (your own rows) + custom-image variant. */
.live-home .amini.self { box-shadow: 0 0 0 1.5px var(--eu-panel), 0 0 0 3px var(--eu-accent); }
.live-home .amini.img { padding: 0; overflow: hidden; border: none; }
.live-home .amini.img img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; display: block; }
.live-home .wf-row .wf-foot .avatars { display: none; }
.live-home .row-item .r-meta .state-pill { display: none; }
.live-home .row-item .r-meta .t-chip.t3, .live-home .row-item .r-meta .t-chip.t2 { display: none; }
.live-home .row-item .r-meta .f-ico { display: none; }
/* ISPY-FLOWS-CLIENT-01 (C7) — the cross-surface connector glyph is the only f-ico that
   renders inline in Phase 1: it activates when a flow has linked_flow_ids[] from Stage 2
   handoff detection. priv/long/noise/stall/new stay hidden until their respective tickets
   (CONN-04/CONN-06/01d.3-followup) light them up. */
.live-home .row-item .r-meta .f-ico.cross.active {
  display: inline-flex;
  background: rgba(38,96,214,0.14);    /* accent-tinted, distinct from the muted .cross */
  color: var(--eu-accent);
  border: 1px solid rgba(38,96,214,0.24);
  padding: 0 3px;
  width: auto;
  min-width: 14px;
  font-weight: 600;
  font-size: 9px;
}
.live-home .row-item .r-meta .r-sub { display: none; }
.live-home .row-item .r-meta .state-pill.manual {
  display: inline-flex;
  font-size: 9.5px;
  padding: 1px 7px;
  width: auto; height: auto;
  border-radius: 999px;
  background: rgba(124,138,163,0.14);
  color: var(--st-manual);
  border: 1px solid rgba(124,138,163,0.34);
}
.live-home .row-item .r-meta .state-pill.manual .dot {
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--st-manual);
}
.live-home .row-item .r-meta .t-chip.t1 {
  font-size: 9px;
  padding: 1px 6px;
  width: auto; height: auto;
  border-radius: 4px;
  color: var(--eu-bad);
  background: rgba(196,48,48,0.12);
  font-weight: 700;
  letter-spacing: 0.06em;
}
.live-home .row-item .r-meta .t-chip.t1::before {
  content: 'T1 · ';
  opacity: 0.85;
}
.live-home .state-pill {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 7px; border-radius: 999px;
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid var(--eu-border);
}
.live-home .state-pill.auto { background: rgba(91,33,182,0.10);  color: var(--st-auto);     border-color: rgba(91,33,182,0.28); }
.live-home .state-pill.assisted { background: rgba(38,96,214,0.10);  color: var(--st-assisted); border-color: rgba(38,96,214,0.28); }
.live-home .state-pill.manual { background: rgba(124,138,163,0.14); color: var(--st-manual);  border-color: rgba(124,138,163,0.34); }
.live-home .state-pill .dot { width: 5px; height: 5px; border-radius: 50%; }
.live-home .state-pill.auto     .dot { background: var(--st-auto); }
.live-home .state-pill.assisted .dot { background: var(--st-assisted); }
.live-home .state-pill.manual   .dot { background: var(--st-manual); }
/* CONN-INGEST-01f — subtle marker on connector (observability_events) rows so users see why a row
   is thinner (no prompt/trace). Sits next to the surface label in Col 1. */
.live-home .row-item .obs-badge {
  font-size: 8px; font-weight: 700; letter-spacing: 0.06em;
  padding: 1px 4px; border-radius: 3px; flex-shrink: 0;
  color: var(--eu-muted-2); background: var(--eu-panel-2);
  border: 1px solid var(--eu-border);
}
/* BADGE-FIX — AGENT (AgentMaps-hosted agent) distinct from CONN: subdued grey-blue, same weight. */
.live-home .row-item .obs-badge.agent {
  color: #5a6b8c; background: rgba(90,107,140,0.10); border-color: rgba(90,107,140,0.28);
}
/* LIVE-DELEGATED-FIX — data-driven Invoked-From badge (replaces the retired hardcoded DELEGATED
   placeholder). Accent-tinted so a real spawned-by relationship reads as signal, not chrome. */
.live-home .row-item .invoked-from {
  /* ACTIVITY-ROW-REFINE-01 — quiet sentence-case pill ("via Cowork"), was loud "VIA COWORK". */
  font-size: 9px; font-weight: 500; letter-spacing: 0;
  padding: 1px 5px; border-radius: 3px; flex-shrink: 0;
  color: var(--eu-accent); background: rgba(38,96,214,0.10);
  border: 1px solid rgba(38,96,214,0.24);
}
.live-home .ws-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 1px 7px;
  border-radius: 4px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid var(--eu-border);
  background: var(--eu-bg);
  font-family: 'SF Mono', Menlo, monospace;
}
.live-home .ws-chip .ws-dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
.live-home .ws-chip.think { color: var(--eu-sand-shadow); border-color: rgba(160,137,96,0.40); }
.live-home .ws-chip.think  .ws-dot { background: var(--ws-think); }
.live-home .ws-chip.search { color: var(--ws-search); border-color: rgba(38,96,214,0.32); }
.live-home .ws-chip.search .ws-dot { background: var(--ws-search); }
.live-home .ws-chip.read { color: var(--ws-read); border-color: var(--eu-border-strong); }
.live-home .ws-chip.read   .ws-dot { background: var(--ws-read); }
.live-home .ws-chip.write { color: var(--ws-write); border-color: rgba(177,106,12,0.32); }
.live-home .ws-chip.write  .ws-dot { background: var(--ws-write); }
.live-home .ws-chip.tool { color: var(--ws-tool); border-color: rgba(15,138,108,0.32); }
.live-home .ws-chip.tool   .ws-dot { background: var(--ws-tool); }
.live-home .ws-chip.gen { color: var(--ws-gen); border-color: rgba(194,65,12,0.32); }
.live-home .ws-chip.gen    .ws-dot { background: var(--ws-gen); }
.live-home .ws-chip.blocked { color: var(--ws-blocked); border-color: rgba(196,48,48,0.32); }
.live-home .ws-chip.blocked .ws-dot { background: var(--ws-blocked); }
.live-home .ws-chip.done { color: var(--ws-done); border-color: rgba(12,148,102,0.30); }
.live-home .ws-chip.done   .ws-dot { background: var(--ws-done); }
.live-home .dur { font-variant-numeric: tabular-nums; font-family: 'SF Mono', Menlo, monospace; font-size: 10.5px; color: var(--eu-text); }
.live-home .dur.live { color: var(--eu-accent); font-weight: 600; }
.live-home .dur.long { color: var(--eu-warn); font-weight: 700; }
.live-home .dur.took { color: var(--eu-muted); }
.live-home .delegated {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 1px 6px; border-radius: 4px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.06em;
  background: rgba(91,33,182,0.08);
  color: var(--st-auto);
  border: 1px solid rgba(91,33,182,0.24);
  font-family: 'SF Mono', Menlo, monospace;
}
.live-home .wf-tag {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 6px; border-radius: 4px;
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid var(--eu-border);
  background: var(--eu-panel-2);
  color: var(--eu-muted);
}
.live-home .wf-tag.q2c { color: var(--wf-q2c); border-color: rgba(38,96,214,0.30);  background: rgba(38,96,214,0.08); }
.live-home .wf-tag.c2r { color: var(--wf-c2r); border-color: rgba(15,138,108,0.30); background: rgba(15,138,108,0.08); }
.live-home .wf-tag.h2r { color: var(--wf-h2r); border-color: rgba(177,106,12,0.30); background: rgba(177,106,12,0.08); }
.live-home .wf-tag.p2p { color: var(--wf-p2p); border-color: rgba(14,124,140,0.30); background: rgba(14,124,140,0.08); }
.live-home .wf-tag.cs { color: var(--wf-cs);  border-color: rgba(162,28,175,0.30); background: rgba(162,28,175,0.08); }
.live-home .wf-tag.r2r { color: var(--wf-r2r); border-color: rgba(91,33,182,0.30);  background: rgba(91,33,182,0.08); }
.live-home .wf-tag.dev { color: var(--wf-dev); border-color: rgba(79,70,229,0.30);  background: rgba(79,70,229,0.08); }
.live-home .wf-tag.pm { color: var(--wf-pm);  border-color: rgba(225,29,107,0.30); background: rgba(225,29,107,0.08); }
.live-home .wf-tag.gen { color: var(--wf-gen); border-color: rgba(124,138,163,0.30); background: rgba(124,138,163,0.08); }
.live-home .t-chip {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 6px; border-radius: 4px;
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.04em;
}
.live-home .t-chip.t3 { background: rgba(12,148,102,0.12); color: var(--eu-good); }
.live-home .t-chip.t2 { background: rgba(177,106,12,0.12); color: var(--eu-warn); }
.live-home .t-chip.t1 { background: rgba(196,48,48,0.12);  color: var(--eu-bad);  }
.live-home .f-chip {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 6px; border-radius: 4px;
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.04em;
}
.live-home .f-chip.priv { background: rgba(38,96,214,0.10); color: var(--eu-accent); }
.live-home .f-chip.noise { background: rgba(15,138,108,0.10); color: var(--eu-accent-2); }
.live-home .f-chip.cross { background: rgba(177,106,12,0.10); color: var(--eu-warn); }
.live-home .f-chip.stall { background: rgba(196,48,48,0.10); color: var(--eu-bad); }
.live-home .f-chip.new { background: rgba(91,33,182,0.10); color: var(--st-auto); }
.live-home .f-chip.longt { background: rgba(177,106,12,0.10); color: var(--eu-warn); }
.live-home .c-icon {
  width: 22px; height: 22px; border-radius: 5px;
  background: var(--eu-panel-2);
  border: 1px solid var(--eu-border);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--eu-muted);
  flex-shrink: 0;
}
.live-home .c-icon svg { display: block; }
.live-home .c-icon.doc { color: var(--eu-accent); }
.live-home .c-icon.sheet { color: var(--eu-accent-2); }
.live-home .c-icon.code { color: var(--wf-dev); }
.live-home .c-icon.msg { color: var(--eu-warn); }
.live-home .c-icon.deck { color: var(--badge-claude); }
.live-home .verb {
  display: inline-flex;
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  color: var(--eu-muted);
}
.live-home .verb.created { color: var(--eu-good); border-color: rgba(12,148,102,0.30); }
.live-home .verb.edited { color: var(--eu-accent); border-color: rgba(38,96,214,0.30); }
.live-home .verb.updated { color: var(--eu-accent-2); border-color: rgba(15,138,108,0.30); }
.live-home .verb.uploaded { color: var(--eu-warn); border-color: rgba(177,106,12,0.30); }
.live-home .verb.summarized { color: var(--wf-cs); border-color: rgba(162,28,175,0.30); }

/* CONTENT-DATA-REDESIGN-01 — L2 verb action-glyph (leads the bold target; color encodes the verb
   class), and L3 touch-count / session-span chips + the Project anchor (un-hides what .r-sub hid). */
.live-home .r-title .vg { display: inline-flex; vertical-align: -2px; margin-right: 5px; flex-shrink: 0; }
.live-home .r-title .vg svg { display: block; pointer-events: none; }
.live-home .vg.created  { color: var(--eu-good); }
.live-home .vg.edited   { color: var(--eu-accent); }
.live-home .vg.viewed   { color: var(--eu-muted); }
.live-home .vg.ran      { color: var(--wf-dev); }
.live-home .vg.searched { color: var(--wf-q2c); }
.live-home .vg.browsed  { color: var(--badge-perplexity); }
.live-home .row-item .r-meta .r-count { font-size: 10px; color: var(--eu-muted); flex-shrink: 0; }
.live-home .row-item .r-meta .r-span  { font-size: 10px; color: var(--eu-muted-2); flex-shrink: 0; }
.live-home .row-item .r-meta .r-anchor {
  margin-left: auto; display: inline-flex; align-items: center; gap: 3px;
  font-size: 10px; color: var(--eu-muted-2); min-width: 0; flex: 0 1 auto;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.live-home .row-item .r-meta .r-anchor svg { flex-shrink: 0; pointer-events: none; }

.live-home .wf-row {
  padding: 6px 12px;
  border-bottom: 1px solid var(--eu-border);
  display: flex; flex-direction: column; gap: 3px;
}
.live-home .wf-row:hover { background: var(--eu-bg); }
.live-home .wf-row .wf-top {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 8px;
}
.live-home .wf-row .wf-name {
  display: inline-flex; align-items: baseline; gap: 8px;
  font-size: 13px; font-weight: 600;
  color: var(--eu-text);
}
.live-home .wf-row .wf-name .ispy-sub {
  font-size: 10.5px; font-weight: 500;
  color: var(--eu-muted-2);
}
.live-home .wf-row .wf-vol {
  font-size: 16px; font-weight: 600;     /* WORKFLOWS-REDESIGN-01 — volume is the row's headline metric */
  color: var(--eu-text);
  font-variant-numeric: tabular-nums;
}
.live-home .wf-row .wf-mix {
  display: flex; align-items: center; gap: 8px;
  font-size: 10.5px;
}
.live-home .wf-row .wf-mix .tri { flex: 1; margin: 0; height: 6px; }   /* WORKFLOWS-REDESIGN-01 — tri-bar now full-width on its own line */
/* LIVE-UX-POLISH-01 (Change 4) — labeled lane micro-chips (swatch + count + lane name) replace the
   bare color-coded "9 253 0" vals triplet. Each chip self-legends, so the header .wf-legend is gone.
   Colors come from the shipped tristate palette (assisted = --eu-accent, matching the tri-bar). The
   foot is allowed to wrap so the labels never truncate on a narrow column. */
.live-home .wf-row .wf-foot .lanestats {
  display: inline-flex; align-items: center; gap: 4px 8px; flex-wrap: wrap;
  font-variant-numeric: tabular-nums;
}
.live-home .wf-row .wf-foot .lstat {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 9.5px; font-weight: 600; color: var(--eu-muted);
  white-space: nowrap;
}
.live-home .wf-row .wf-foot .lstat .sw { width: 7px; height: 7px; border-radius: 2px; flex-shrink: 0; }
.live-home .wf-row .wf-foot .lstat.auto .sw { background: var(--st-auto); }
.live-home .wf-row .wf-foot .lstat.assisted .sw { background: var(--eu-accent); }
.live-home .wf-row .wf-foot .lstat.manual .sw { background: var(--st-manual); }
.live-home .wf-row .wf-foot .lstat.zero { opacity: 0.4; }
.live-home .wf-row .wf-foot {
  display: flex; align-items: center; gap: 7px;
  font-size: 9.5px; color: var(--eu-muted-2);
  flex-wrap: wrap;
}
.live-home .wf-row .wf-foot .trust {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 9.5px;
  color: var(--eu-good);
  font-weight: 600;
  flex-shrink: 0;
  white-space: nowrap;
}
.live-home .wf-row .wf-foot .trust::before {
  content: '';
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.live-home .wf-row .wf-foot .trust.med { color: var(--eu-warn); }
.live-home .wf-row .wf-foot .trust.bad { color: var(--eu-bad); }
.live-home .wf-row .wf-foot .time {
  font-family: 'SF Mono', Menlo, monospace;
  color: var(--eu-muted);
  font-size: 9.5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.live-home .wf-row .wf-foot .time b { color: var(--eu-text); font-weight: 600; }
.live-home .wf-row .wf-foot .time .longest { color: var(--eu-warn); }
.live-home .wf-row .wf-foot .spark {
  margin-left: auto;
  display: inline-flex; align-items: flex-end; gap: 1px;
  height: 12px; flex: 0 0 40px;
}
.live-home .wf-row .wf-name { font-size: 12px; gap: 7px; }
/* WORKFLOWS-REDESIGN-01 — the column's identity chip carries the WF_ICON category glyph (it's built
   directly, not via maybeWfTag, so it needs its own inline-flex + svg sizing). */
.live-home .wf-row .wf-name .wf-tag { font-size: 9.5px; padding: 1px 6px; display: inline-flex; align-items: center; gap: 3px; flex-shrink: 0; }
.live-home .wf-row .wf-name .wf-tag svg { width: 11px; height: 11px; flex-shrink: 0; pointer-events: none; }
/* LIVE-UX-POLISH-01 (Change 4) — the one-time .wf-legend and the .wf-mix .vals rules were removed:
   per-row lane micro-chips (.wf-foot .lstat, above) now self-legend. */
.live-home .wf-row .wf-name .ispy-sub { font-size: 10px; }
.live-home .wf-row .wf-vol { font-size: 12px; }
.live-home .wf-row .wf-mix .tri { height: 5px; }
.live-home .wf-row.manual-only .try-ai { font-size: 9.5px; }
.live-home .wf-row .wf-foot .spark span {
  flex: 1; background: var(--eu-accent);
  border-radius: 1px; opacity: 0.6;
}
.live-home .wf-row .wf-foot .spark span:last-child { opacity: 1; }
.live-home .wf-row.manual-only {
  background: rgba(124,138,163,0.07);
  border-left: 3px solid var(--st-manual);
}
.live-home .wf-row.manual-only .wf-name { color: var(--eu-muted); }
.live-home .wf-row.manual-only .ispy-sub { font-style: italic; color: var(--eu-muted-2); }
.live-home .wf-row.manual-only .manual-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(124,138,163,0.22);
  color: var(--eu-text);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.live-home .wf-row.manual-only .manual-badge::before {
  content: '';
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--st-manual);
}
.live-home .wf-row.manual-only .try-ai {
  margin-left: auto;
  padding: 3px 9px;
  border-radius: 5px;
  background: var(--eu-accent-soft);
  border: 1px solid var(--eu-accent-soft-2);
  color: var(--eu-accent);
  font-size: 10px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}
.live-home .wf-row.manual-only .try-ai:hover {
  background: var(--eu-accent);
  border-color: var(--eu-accent);
  color: #fff;
}
.live-home .ao-head {
  padding: 14px 16px;
  border-bottom: 1px solid var(--eu-border);
  display: flex; align-items: center; gap: 10px;
}
.live-home .ao-head .pin {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--eu-accent-soft);
  border: 1px solid var(--eu-accent-soft-2);
  color: var(--eu-accent);
  display: inline-flex; align-items: center; justify-content: center;
}
.live-home .ao-head .n { font-size: 13px; font-weight: 600; color: var(--eu-text); }
.live-home .ao-head .r {
  font-size: 10.5px; color: var(--eu-muted-2);
  letter-spacing: 0.06em; text-transform: uppercase;
  font-weight: 600;
}
.live-home .ao-head .close {
  margin-left: auto;
  background: transparent;
  border: 1px solid var(--eu-border);
  color: var(--eu-muted);
  width: 26px; height: 26px;
  border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
}
.live-home .ao-head .close:hover { color: var(--eu-text); background: var(--eu-panel-2); }
.live-home .ao-intro {
  padding: 12px 16px;
  font-size: 12px; color: var(--eu-muted);
  line-height: 1.5;
  border-bottom: 1px solid var(--eu-border);
}
.live-home .ao-questions {
  flex: 1; overflow-y: auto;
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 8px;
}
.live-home .qhead {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.live-home .qsubhead {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--eu-muted-2);
  text-transform: uppercase;
  margin: 8px 0 2px;
}
.live-home .qbtn {
  text-align: left;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--eu-border);
  background: var(--eu-panel-2);
  font-size: 12px; color: var(--eu-text);
  display: flex; align-items: flex-start; gap: 8px;
  line-height: 1.45;
}
.live-home .qbtn:hover { background: var(--eu-panel-3); border-color: var(--eu-border-strong); }
.live-home .qbtn .qarrow { color: var(--eu-accent); flex-shrink: 0; margin-top: 2px; }
.live-home .ao-input {
  padding: 12px 14px;
  border-top: 1px solid var(--eu-border);
}
.live-home .ao-input .inp {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  background: var(--eu-bg);
  border: 1px solid var(--eu-border);
  border-radius: 10px;
  font-size: 12px; color: var(--eu-muted-2);
}
.live-home .ao-input .send {
  margin-left: auto;
  width: 24px; height: 24px; border-radius: 6px;
  background: var(--eu-accent); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}
.live-home .scrim {
  position: fixed; inset: 0;
  background: rgba(15,23,42,0.20);
  z-index: 35;
  opacity: 0;
  pointer-events: none;
  transition: opacity 240ms;
}
.live-home .scrim.open { opacity: 1; pointer-events: auto; }
@media (max-width: 1100px){

  .live-home .live-grid { grid-template-columns: 240px 1fr 1fr; }
  .live-home .live-grid .col:nth-child(4) { grid-column: 2 / 4; min-height: 280px; }
}
@media (max-width: 800px){

  .live-home .live-grid { grid-template-columns: 1fr; }
  .live-home .live-grid .col:nth-child(4) { grid-column: auto; }
  .live-home .hdr-right { gap: 6px; }
  .live-home .hdr-right .timerange button { padding: 6px 8px; }
}

/* ───── ISPY-LIVE-01d.1 — Phase 1 verb chip palette extension (Calibrating Spec §3 Col 2) ─────
   The mockup ships .verb.created/.edited/.updated/.uploaded/.summarized. The P1 verb set is
   CREATED · EDITED · VIEWED · RAN · SEARCHED · BROWSED; the four below had no mockup CSS yet.
   01d.4 (Col 2 wiring) consumes these without touching CSS. UPDATED/UPLOADED/SUMMARIZED stay
   in the mockup palette and light up when ISPY-CONN-03 connectors land. */
.live-home .verb.viewed    { color: var(--eu-muted);  border-color: rgba(124,138,163,0.30); }
.live-home .verb.ran       { color: var(--wf-dev);    border-color: rgba(79,70,229,0.30); }
.live-home .verb.searched  { color: var(--wf-q2c);    border-color: rgba(38,96,214,0.30); }
.live-home .verb.browsed   { color: var(--badge-perplexity); border-color: rgba(14,124,140,0.30); }

/* ───── ISPY-LIVE-01d.1.5 — Pathways page placeholder (page-dropdown nav) ───── */
.live-home .page-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; min-height: 360px; gap: 8px; color: var(--eu-muted); }
.live-home .page-placeholder h2 { margin: 0; font-size: 20px; font-weight: 600; color: var(--eu-text); }
.live-home .page-placeholder p { margin: 0; font-size: 14px; }

/* ───── ISPY-LIVE-01d.3 — Col 1 row bd stripes (surfaces the mockup CSS didn't cover) ───── */
.live-home .bd.claude_code { background: var(--wf-dev); }
.live-home .bd.cowork      { background: var(--eu-accent); }
.live-home .bd.chatgpt     { background: var(--badge-openai); }
.live-home .bd.grok        { background: var(--eu-muted); }
.live-home .bd.google      { background: var(--wf-c2r); }
.live-home .bd.unknown     { background: var(--eu-muted-2); }

/* ───── ISPY-LIVE-01d.3 — column empty state (filters → zero rows) ───── */
.live-home .col-empty { padding: 32px 16px; text-align: center; color: var(--eu-muted); }
.live-home .col-empty-title { font-size: 13px; font-weight: 600; color: var(--eu-text); }
.live-home .col-empty-sub { font-size: 12px; margin-top: 4px; }

/* ───── ISPY-LIVE-01d.4 — Col 2 c-icon kinds the mockup didn't cover (cmd / search / browse) ───── */
.live-home .c-icon.cmd    { color: var(--wf-dev); }
.live-home .c-icon.search { color: var(--wf-q2c); }
.live-home .c-icon.browse { color: var(--badge-perplexity); }

/* ───── ISPY-LIVE-01d-parity §3.2 — calibrated (greyed/disabled/placeholder) modifiers ─────
   Per feedback_follow_mockup_religiously: mockup elements blocked by missing data render greyed,
   not removed. Applies to Col 1 row sub-elements + the restored scoreboard sections. */
.live-home .delegated.disabled,
.live-home .ws-chip.placeholder,
.live-home .f-ico.disabled,
.live-home .t-chip.t3,
.live-home .sb-headstrip.disabled,
.live-home .sb-worktime.disabled,
.live-home .il-row.disabled,
.live-home .user-row .count.disabled,
.live-home .sb-head-toggle:disabled,
.live-home .sb-head-filter:disabled,
.live-home .sb-head-pagination button:disabled {
  opacity: 0.42;
  cursor: default;
}
.live-home .delegated.disabled:hover,
.live-home .ws-chip.placeholder:hover,
.live-home .f-ico.disabled:hover {
  opacity: 0.55;   /* small lift so the tooltip-readable cue stays alive on hover */
}

/* ───── ISPY-LIVE-01d-parity §4 — Coordinator FAB + overlay (chrome ships; content calibrated).
   .assistant-* rules were dropped in 01d.1's extraction (FAB was hidden then); restored here.
   Visibility is driven by the native [hidden] attribute (JS toggles overlay.hidden), so the base
   overlay rule is NOT off-screen-translated. AGENTMAPS-LIVE-01 wires the real Coordinator chat. */
.live-home .assistant-fab {
  position: fixed; right: 24px; bottom: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  border-radius: 999px; border: none;
  background: var(--eu-accent); color: #fff;
  box-shadow: 0 8px 24px -6px rgba(38,96,214,0.40), 0 2px 6px -2px rgba(15,23,42,0.10);
  cursor: pointer; z-index: 30;
  transition: transform 120ms, filter 120ms;
}
.live-home .assistant-fab:hover { transform: translateY(-2px); filter: brightness(1.05); }
.live-home .assistant-fab svg { display: block; }
.live-home .assistant-overlay[hidden] { display: none; }
.live-home .assistant-overlay {
  position: fixed; right: 0; top: 0; bottom: 0; width: 360px; max-width: calc(100vw - 40px);
  background: var(--eu-panel); border-left: 1px solid var(--eu-border);
  box-shadow: -12px 0 32px -8px rgba(15,23,42,0.12);
  z-index: 40; display: flex; flex-direction: column; overflow: hidden;
}
.live-home .assistant-panel { display: flex; flex-direction: column; height: 100%; }
.live-home .assistant-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--eu-border);
}
.live-home .assistant-head .title { font-size: 14px; font-weight: 600; }
.live-home .assistant-head .close {
  border: none; background: none; color: var(--eu-muted); font-size: 20px; line-height: 1;
  cursor: pointer; padding: 0 4px;
}
.live-home .assistant-head .close:hover { color: var(--eu-text); }
.live-home .assistant-body { padding: 18px; overflow-y: auto; }
.live-home .assistant-body .calibrating-note {
  font-size: 13px; line-height: 1.5; color: var(--eu-muted);
  background: var(--eu-panel-2); border: 1px solid var(--eu-border); border-radius: 8px; padding: 12px 14px;
}

/* ───── TOKENOMICS-PAGE-01 — AI FinOps page ───── */
.tokenomics-page { padding: 16px 20px 40px; max-width: 1080px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.tk-hero { display: flex; gap: 20px; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; }
.tk-hero-l { min-width: 0; flex: 1 1 420px; }
.tk-eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--eu-accent); margin-bottom: 6px; }
.tk-hero h1 { font-size: 26px; font-weight: 600; color: var(--eu-text); margin: 0 0 6px; }
.tk-gap { font-size: 13px; line-height: 1.5; color: var(--eu-muted); margin: 0; max-width: 640px; }
.tk-gap strong { color: var(--eu-text); font-weight: 600; }
.tk-aside { color: var(--eu-muted-2); font-size: 12px; }
.tk-hero-stats { display: flex; gap: 22px; flex-wrap: wrap; }
.tk-stat { display: flex; flex-direction: column; gap: 1px; }
.tk-stat .v { font-size: 20px; font-weight: 700; color: var(--eu-text); font-variant-numeric: tabular-nums; }
.tk-stat .l { font-size: 10.5px; color: var(--eu-muted-2); }
.tk-stat.good .v { color: var(--eu-good); }
.tk-card { background: var(--eu-panel); border: 0.5px solid var(--eu-border); border-radius: 12px; padding: 14px 16px; }
.tk-hero-card { border-color: var(--eu-accent); box-shadow: 0 0 0 1px rgba(38,96,214,0.12); }
.tk-card-h { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.tk-card-h h2 { font-size: 14px; font-weight: 600; color: var(--eu-text); margin: 0; }
.tk-card-sub { font-size: 11px; color: var(--eu-muted-2); }
.tk-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.tk-row { display: flex; align-items: center; gap: 10px; padding: 4px 0; }
.tk-rl { width: 150px; flex-shrink: 0; display: flex; flex-direction: column; min-width: 0; }
.tk-rl-name { font-size: 12px; font-weight: 500; color: var(--eu-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tk-rl-sub { font-size: 10px; color: var(--eu-muted-2); }
.tk-rbar { flex: 1; height: 8px; background: var(--eu-bg); border-radius: 4px; overflow: hidden; min-width: 40px; }
.tk-rbar span { display: block; height: 100%; border-radius: 4px; }
.tk-rv { width: 56px; text-align: right; font-size: 12px; font-weight: 600; color: var(--eu-text); font-variant-numeric: tabular-nums; flex-shrink: 0; }
.tk-irow { display: flex; align-items: center; gap: 8px; padding: 5px 0; font-size: 12px; }
.tk-isw { width: 9px; height: 9px; border-radius: 2px; flex-shrink: 0; }
.tk-in { color: var(--eu-text); flex: 1; }
.tk-iv { color: var(--eu-text); font-variant-numeric: tabular-nums; }
.tk-iv b { font-weight: 700; }
.tk-isub { color: var(--eu-muted-2); font-size: 10.5px; width: 64px; text-align: right; }
.tk-land { display: grid; grid-template-columns: 1fr 1.4fr; gap: 18px; }
.tk-land-h { font-size: 12px; font-weight: 600; color: var(--eu-text); margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }
.tk-land-row { font-size: 12px; color: var(--eu-text); padding: 3px 0; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.tk-land-row.muted { color: var(--eu-muted-2); }
.tk-land-tag { font-size: 9px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; padding: 1px 5px; border-radius: 3px; }
.tk-land-tag.tracked { background: rgba(12,148,102,0.12); color: var(--eu-good); }
.tk-land-tag.observed { background: rgba(38,96,214,0.10); color: var(--eu-accent); }
.tk-land-tag.known { background: var(--eu-bg); color: var(--eu-muted-2); border: 0.5px solid var(--eu-border); }
.tk-maturity { font-size: 12px; color: var(--eu-muted); margin-bottom: 8px; }
.tk-maturity b { color: var(--eu-text); }
.tk-covrow { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--eu-muted); padding: 3px 0; }
.tk-covrow span:first-child { width: 96px; flex-shrink: 0; }
.tk-covbar { flex: 1; height: 6px; background: var(--eu-bg); border-radius: 3px; overflow: hidden; }
.tk-covbar span { display: block; height: 100%; background: var(--eu-accent); }
.tk-covrow b { width: 36px; text-align: right; color: var(--eu-text); font-variant-numeric: tabular-nums; }
.tk-calib .tk-calib-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.tk-calib-list li { font-size: 12px; color: var(--eu-muted); display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.tk-calib-list b { color: var(--eu-text); font-weight: 500; }
.tk-cal { font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: var(--eu-muted-2); border: 0.5px dashed var(--eu-border); border-radius: 3px; padding: 1px 5px; flex-shrink: 0; }
.tk-empty { font-size: 12px; color: var(--eu-muted-2); font-style: italic; padding: 4px 0; }
@media (max-width: 720px) { .tk-grid2, .tk-land { grid-template-columns: 1fr; } }

/* ───── POOLS-MAP-01 — "light up the pool" drill ───── */
.pools-map-page { padding: 16px 20px 40px; max-width: 1080px; margin: 0 auto; display: flex; flex-direction: column; gap: 18px; }
.pm-hero h1 { font-size: 26px; font-weight: 600; color: var(--eu-text); margin: 0 0 6px; }
.pm-gap { font-size: 13px; line-height: 1.5; color: var(--eu-muted); max-width: 760px; margin: 0; }
.pm-gap strong { color: var(--eu-text); font-weight: 600; }
.pm-src { display: inline-block; margin-left: 6px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: var(--eu-muted-2); border: 0.5px solid var(--eu-border); border-radius: 3px; padding: 1px 6px; }
.pm-src-calib { color: var(--eu-warn, #b8860b); border-color: var(--eu-warn, #b8860b); text-transform: none; letter-spacing: 0; }
.pm-dept { display: flex; flex-direction: column; gap: 10px; }
.pm-dept-h { display: flex; align-items: baseline; gap: 10px; border-bottom: 1px solid var(--eu-border); padding-bottom: 4px; }
.pm-dept-h h2 { font-size: 16px; font-weight: 600; color: var(--eu-text); margin: 0; }
.pm-dept-sub { font-size: 11.5px; color: var(--eu-muted-2); }
.pm-pool { background: var(--eu-panel); border: 0.5px solid var(--eu-border); border-radius: 12px; padding: 12px 14px; display: flex; flex-direction: column; gap: 8px; }
.pm-pool-h { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.pm-prov { font-size: 10px; font-weight: 700; color: #fff; background: var(--pm-c, var(--eu-accent)); border-radius: 4px; padding: 2px 7px; letter-spacing: 0.02em; }
.pm-pool-name { font-size: 14px; font-weight: 600; color: var(--eu-text); }
.pm-pool-kind { font-size: 10.5px; color: var(--eu-muted-2); border: 0.5px solid var(--eu-border); border-radius: 3px; padding: 1px 5px; }
.pm-pool-tot { font-size: 11.5px; color: var(--eu-muted); margin-left: auto; }
.pm-cov { font-size: 10.5px; font-weight: 600; color: var(--eu-accent); background: color-mix(in srgb, var(--eu-accent) 12%, transparent); border-radius: 4px; padding: 2px 7px; }
.pm-cov-calib { color: var(--eu-muted-2); background: none; border: 0.5px dashed var(--eu-border); }
.pm-mems { display: flex; flex-direction: column; gap: 2px; }
.pm-mem { display: grid; grid-template-columns: minmax(150px, 1.5fr) 1.1fr auto minmax(150px, 1.3fr); align-items: center; gap: 12px; padding: 4px 0; }
.pm-mem-tool { opacity: 0.82; }
.pm-mem-l { min-width: 0; display: flex; flex-direction: column; }
.pm-mem-name { font-size: 12.5px; font-weight: 500; color: var(--eu-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pm-mem-role { font-size: 10.5px; color: var(--eu-muted-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pm-aitag { font-size: 9px; font-weight: 700; text-transform: uppercase; color: var(--eu-muted-2); border: 0.5px solid var(--eu-border); border-radius: 3px; padding: 0 4px; vertical-align: middle; }
.pm-bar { height: 7px; background: var(--eu-panel-2, rgba(128,128,128,0.12)); border-radius: 4px; overflow: hidden; }
.pm-bar > span { display: block; height: 100%; background: var(--eu-accent); border-radius: 4px; }
.pm-bar-calib { display: block; font-size: 9.5px; color: var(--eu-muted-2); font-style: italic; line-height: 7px; }
.pm-tokens { font-size: 12px; font-variant-numeric: tabular-nums; color: var(--eu-text); text-align: right; min-width: 56px; }
.pm-wfchips { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.pm-wfchip { display: inline-flex; align-items: center; gap: 4px; font-size: 10.5px; color: var(--eu-muted); white-space: nowrap; }
.pm-wfdot { width: 7px; height: 7px; border-radius: 2px; flex-shrink: 0; }
.pm-pool-wf { display: flex; align-items: center; gap: 10px; padding-top: 4px; border-top: 0.5px solid var(--eu-border); }
.pm-pool-wf-l { font-size: 10.5px; color: var(--eu-muted-2); white-space: nowrap; }
.pm-wfbar { flex: 1; display: flex; height: 9px; border-radius: 4px; overflow: hidden; background: var(--eu-panel-2, rgba(128,128,128,0.12)); }
.pm-wfseg { display: block; height: 100%; }
.pm-foot { font-size: 11px; line-height: 1.5; color: var(--eu-muted-2); border-top: 0.5px solid var(--eu-border); padding-top: 10px; margin: 4px 0 0; }
.pm-foot strong { color: var(--eu-muted); }
@media (max-width: 720px) { .pm-mem { grid-template-columns: 1fr auto; } .pm-mem .pm-bar, .pm-mem .pm-wfchips { display: none; } }
