/* Clara v2 — additive styles on top of styles.css */

/* ====== FIX: CSS transitions occasionally hang at currentTime 0 in heavy
   mounts (especially under DOM-rendered screenshot tools). Strip them on
   layout-affecting props; keep them on the dot/halo/banner where motion is
   the point. */
.reveal {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}
.reveal .rose-underline::after { transform: scaleX(1) !important; transition: none !important; }
.spine-node .pin,
.spine-card,
.spine-card::after,
.spine-card::before,
.spine-line .fill,
.how-v2 .step .num,
.agent-node .avatar,
.src-card-v2,
.src-card-v2::before,
.src-card-v2 .bar span {
  transition: none !important;
}

/* ====== Section backgrounds — dark spine (01-06) + cream zone (07-10) ====== */
/* The JS-driven #bg-flow gradient lingers in mid-tones around 50% scroll, which
   makes the light-themed sections (Dashboard, Agentes, Casos, CTA) hard to read.
   We set explicit per-section backgrounds so the contrast is always right. */

section[data-screen-label="01 Hero"]            { background: transparent; }
section[data-screen-label="02 Caos"]            { background: transparent; }
section[data-screen-label="03 Aparece Clara"]   { background: transparent; }
section[data-screen-label="04 Cómo funciona"]   { background: transparent; }
section[data-screen-label="05 Asistente"]       { background: transparent; }
section[data-screen-label="06 Fuentes"]         { background: transparent; }

section[data-screen-label="07 Dashboard"],
section[data-screen-label="08 Agentes"],
section[data-screen-label="09 Casos de uso"],
section[data-screen-label="10 Decisión"] {
  background: #F5F0E8;
  color: var(--text-light-primary);
  position: relative;
  z-index: 2;
}

/* Bridges 7–9: solid cream (already inside the light zone) */
.page-root > .bridge:nth-of-type(7),
.page-root > .bridge:nth-of-type(8),
.page-root > .bridge:nth-of-type(9) {
  background: #F5F0E8;
  color: var(--text-light-primary);
  position: relative;
  z-index: 2;
}

/* ── Gradiente de página completa — non-linear warm masking ────────────────
   .page-root (z-index 1) cubre al #bg-flow (z-index 0).
   Las secciones 01–06 son transparent → muestran este gradiente.
   Las secciones 07–10 tienen background: #F5F0E8 → lo tapan cuando ya es cream.

   Técnica: el oscuro se mantiene sólido hasta el 57% y luego salta por tonos
   cálidos (marrones, no grises neutros) para evitar la "zona muerta de grises".
   Bridge 6 aplica un overlay de cream encima para sellar la transición.

     0–10 %  → Hero, negro puro
    10–57 %  → Actos 02–06, oscuro cálido progresivo (casi sin cambio visible)
    57–65 %  → Bridge 6 empieza: marrón oscuro cálido (#4a4844 — anti-gris)
    65–73 %  → Transición rápida a marrón claro cálido (#a3a098)
    73–88 %  → Llegando a cream cálido
    88–100%  → Cream sólido (coincide exacto con bg de secciones 07–10)
   ──────────────────────────────────────────────────────────────────────────── */
.page-root {
  background: linear-gradient(
    to bottom,
    #0D0D0D   0%,
    #0D0D0D  10%,
    #111110  28%,
    #161412  46%,
    #1c1916  57%,
    #4a4844  65%,
    #a3a098  73%,
    #d8d2cc  81%,
    #F5F0E8  88%,
    #F5F0E8 100%
  );
}

/* ── Bridge 6 (Y TODO ESO…): cierre fino sobre el gradiente de page-root ──
   page-root ya hace el trabajo pesado (dark → warm gray → cream).
   Este overlay cream 18→100 % sella la transición justo antes de section 07. */

/* El pie de la sección 06 anticipa el viraje hacia el cream */
section[data-screen-label="06 Fuentes"]::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 300px;
  background: linear-gradient(
    to bottom,
    rgba(245, 240, 232, 0)    0%,
    rgba(245, 240, 232, 0.25) 100%
  );
  pointer-events: none;
  z-index: -1;
}

/* Paso 2: el bridge continúa hasta cream sólido con un arranque más alto
   para sellar el marrón cálido del gradiente subyacente más rápido */
.page-root > .bridge:nth-of-type(6) {
  background: linear-gradient(
    to bottom,
    rgba(245, 240, 232, 0.30)  0%,
    rgba(245, 240, 232, 0.60) 30%,
    rgba(245, 240, 232, 0.85) 60%,
    rgba(245, 240, 232, 0.97) 85%,
    rgba(245, 240, 232, 1.00) 100%
  );
  color: var(--text-light-primary);
  position: relative;
  z-index: 2;
  padding-top: 110px;
  padding-bottom: 110px;
}

/* Bridges in the dark zone still need a faint background so the bg-flow gradient
   doesn't bleed through with the wrong tone */
.page-root > .bridge:nth-of-type(1),
.page-root > .bridge:nth-of-type(2),
.page-root > .bridge:nth-of-type(3),
.page-root > .bridge:nth-of-type(4),
.page-root > .bridge:nth-of-type(5) {
  background: transparent;
  color: var(--text-dark-secondary);
}

/* ── Narrative bridge colours per zone ─────────────────────────────────────
   Bridges 1-5 live over the dark gradient → white text.
   Bridge 6 is the cream-transition bridge → still handled by its own rule above.
   Bridges 7-9 live over cream → dark text.
   Bridge 7 is the .nb-accent block → its own dark panel, ignores zone colour.
   ────────────────────────────────────────────────────────────────────────── */

/* Dark zone bridges 1-5: force bright white so narratives read clearly */
.page-root > .bridge:nth-of-type(1) .nb-text,
.page-root > .bridge:nth-of-type(2) .nb-text,
.page-root > .bridge:nth-of-type(3) .nb-text,
.page-root > .bridge:nth-of-type(4) .nb-text,
.page-root > .bridge:nth-of-type(5) .nb-text {
  color: var(--text-dark-primary);
}

/* Bridge 6 transition (dark→cream): use the already-established light primary */
.page-root > .bridge:nth-of-type(6) .nb-text {
  color: var(--text-light-primary);
}

/* Light zone bridges 8-9 (cream background) */
.page-root > .bridge:nth-of-type(8) .nb-text,
.page-root > .bridge:nth-of-type(9) .nb-text {
  color: var(--text-light-primary);
}

/* The accent bridge (bridge 7) manages its own colours via .nb-accent */

/* How-step v2: num badge smaller/secondary, title is the headline */
.how-v2 .step .num {
  width: 40px;
  height: 40px;
  font-size: 13px;
  border-color: var(--text-dark-line);
  color: var(--text-dark-tertiary);
}
.how-v2 .step .step-title {
  font-size: clamp(19px, 2vw, 24px);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.18;
  color: var(--text-dark-primary);
  margin: 18px 0 10px;
}

/* In v2 we also want the light-zone topnav switch to happen sooner */

/* ====== HERO BANNER ====== */

.hero-banner {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding-top: 80px;
}
.hero-banner .stage-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 50% at 52% 45%, rgba(232,0,111,0.10), transparent 60%),
    radial-gradient(40% 35% at 18% 16%, rgba(245,240,232,0.04), transparent 70%);
  pointer-events: none;
}
.hero-banner .rule {
  position: absolute;
  left: 8%; right: 8%;
  height: 1px;
  background: var(--text-dark-line);
  pointer-events: none;
}
.hero-banner .rule.top { top: 116px; }
.hero-banner .rule.bot { bottom: 96px; }

.hero-banner .role-strip {
  position: absolute;
  left: 8%;
  top: 96px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-dark-secondary);
}
.hero-banner .role-strip .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 12px rgba(232,0,111,0.55);
}

.hero-banner .slide-frame {
  position: relative;
  width: min(88%, 1280px);
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 200px;
  align-items: center;
  gap: 32px;
  z-index: 2;
}
@media (max-width: 900px) {
  .hero-banner .slide-frame {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

.hero-banner .area-tag {
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-dark-tertiary);
}
.hero-banner .question {
  max-width: 980px;
  font-size: clamp(2rem, 4.4vw, 4.6rem);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.045em;
  color: var(--text-dark-primary);
}
.hero-banner .clara-knows {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  justify-content: flex-end;
  color: var(--accent);
  font-size: 14px;
  letter-spacing: -0.01em;
  font-weight: 500;
}
.hero-banner .clara-knows .ko-dot {
  width: 7px; height: 7px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 14px rgba(232,0,111,0.55);
  animation: pulse-soft 2.4s ease-in-out infinite;
}
.hero-banner .clara-knows .arr {
  display: inline-block;
  transition: transform 0.3s var(--decel);
}

.hero-banner .word {
  display: inline-block;
  white-space: pre;
  opacity: 0;
  transform: translateY(22px);
  filter: blur(8px);
  transition: opacity 0.55s var(--decel), transform 0.55s var(--decel), filter 0.55s var(--decel);
}
.hero-banner .word.in {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.hero-banner .progress-bar {
  position: absolute;
  left: 0; bottom: 0;
  height: 2px;
  width: 100%;
  background: transparent;
}
.hero-banner .progress-bar .fill {
  height: 100%;
  background: var(--accent);
  transform-origin: left;
  transform: scaleX(0);
  will-change: transform;
}

.hero-banner .progress-dots {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
}
.hero-banner .progress-dots .pd {
  width: 8px; height: 6px;
  border-radius: 999px;
  background: rgba(245,240,232,0.18);
  transition: width 0.35s var(--decel), background-color 0.35s var(--decel);
}
.hero-banner .progress-dots .pd.active {
  width: 34px;
  background: var(--accent);
}

.hero-banner .replay-btn {
  position: absolute;
  right: 32px; bottom: 90px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-dark-tertiary);
  border: 1px solid var(--text-dark-line-strong);
  background: transparent;
  padding: 8px 14px;
  border-radius: 999px;
  cursor: pointer;
  transition: color 0.2s var(--decel), border-color 0.2s var(--decel), background-color 0.2s var(--decel);
}
.hero-banner .replay-btn:hover {
  color: var(--text-dark-primary);
  border-color: var(--text-dark-primary);
  background: rgba(245,240,232,0.04);
}

/* CLARA logo final state */
.hero-banner .final-stage {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 24px;
}
.hero-banner .clara-logo {
  font-size: clamp(4.5rem, 11vw, 11rem);
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 0.95;
  color: var(--text-dark-primary);
  font-family: 'DM Sans', sans-serif;
}
.hero-banner .clara-logo .live {
  display: inline-block;
  width: 0.18em;
  height: 0.18em;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 28px rgba(232,0,111,0.55);
  vertical-align: 0.06em;
  margin-left: 0.08em;
}
.hero-banner .final-stage .tag {
  font-size: 12px;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--text-dark-tertiary);
}
.hero-banner .final-stage .lede {
  max-width: 760px;
  font-size: clamp(1.5rem, 2.6vw, 2.4rem);
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--text-dark-secondary);
}
.hero-banner .final-stage .ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 12px;
}
.hero-banner .final-stage .integrations-strip {
  margin-top: 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.hero-banner .final-stage .integrations-strip .lbl {
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 10px;
  color: var(--text-dark-tertiary);
}
.hero-banner .final-stage .integrations-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px 20px;
}
.hero-banner .final-stage .int-icon {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  color: rgba(245, 240, 232, 0.28);
  transition: color 0.25s ease, transform 0.25s ease;
  cursor: default;
}
.hero-banner .final-stage .int-icon:hover {
  color: rgba(245, 240, 232, 0.55);
  transform: translateY(-3px);
}
.hero-banner .final-stage .int-icon svg {
  width: 32px;
  height: 32px;
  display: block;
}
.hero-banner .final-stage .int-icon span {
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: inherit;
  white-space: nowrap;
}
.hero-banner .final-stage .int-more {
  color: rgba(245, 240, 232, 0.18);
}

/* fade primitives */
.fx-fade { opacity: 0; transition: opacity 0.7s var(--decel); }
.fx-fade.in { opacity: 1; }
.fx-rise { opacity: 0; transform: translateY(28px); transition: opacity 0.7s var(--decel), transform 0.7s var(--decel); }
.fx-rise.in { opacity: 1; transform: translateY(0); }

/* ====== DYNAMIC GUIDE ====== */

/* Hide the v1 guide chrome when v2 is loaded */
body.v2 .guide-trail,
body.v2 .guide-dot,
body.v2 .guide-label { display: none !important; }

.v2-guide {
  position: fixed;
  inset: 0;
  z-index: 45;
  pointer-events: none;
}
.v2-guide svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.v2-dot {
  position: fixed;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 30px rgba(232,0,111,0.55);
  z-index: 70;
  pointer-events: none;
  transform: translate(-50%, -50%);
  will-change: transform, opacity, width, height;
}
.v2-dot .halo {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid var(--accent);
  opacity: 0;
}
.v2-dot.halo-fire .halo {
  animation: v2-halo 1.2s var(--decel) forwards;
}
@keyframes v2-halo {
  0% { transform: scale(1); opacity: 0.6; }
  100% { transform: scale(8); opacity: 0; }
}

.v2-label {
  display: none !important;
}

.v2-particle {
  position: fixed;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  z-index: 46;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%);
}
.v2-particle.fire {
  animation: v2-particle-fly 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes v2-particle-fly {
  0%   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  60%  { opacity: 1; }
  100% { opacity: 0; transform: translate(calc(-50% + var(--dx, 0px)), calc(-50% + var(--dy, 0px))) scale(0.4); }
}

/* ====== ENHANCED SOURCES (Act 06) ====== */

.sources-grid-v2 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 1000px) { .sources-grid-v2 { grid-template-columns: repeat(2, 1fr); } }

.src-card-v2 {
  position: relative;
  border: 1px solid rgba(245,240,232,0.16);
  border-radius: 14px;
  padding: 22px 22px 18px;
  background: linear-gradient(180deg, rgba(245,240,232,0.08), rgba(245,240,232,0.025));
  transition: transform 320ms var(--decel), border-color 320ms var(--decel), background 320ms var(--decel);
  overflow: hidden;
}
.src-card-v2::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(120% 60% at 100% 0%, rgba(232,0,111,0.10), transparent 55%);
  opacity: 0;
  transition: opacity 320ms var(--decel);
  pointer-events: none;
}
.src-card-v2:hover {
  transform: translateY(-3px);
  border-color: rgba(245,240,232,0.32);
}
.src-card-v2:hover::before { opacity: 1; }
.src-card-v2 .logo {
  width: 42px; height: 42px;
  border-radius: 10px;
  background: rgba(245,240,232,0.10);
  border: 1px solid rgba(245,240,232,0.20);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.10em;
  color: var(--text-dark-primary);
}
.src-card-v2 .name {
  margin-top: 18px;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text-dark-primary);
}
.src-card-v2 .row {
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 12px;
}
.src-card-v2 .row .meta {
  color: var(--text-dark-secondary);
}
.src-card-v2 .row .live {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}
.src-card-v2 .row .live .pip {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(232,0,111,0.55);
  animation: pulse-soft 2.4s ease-in-out infinite;
}
.src-card-v2 .bar {
  margin-top: 14px;
  height: 3px;
  border-radius: 2px;
  background: rgba(245,240,232,0.10);
  overflow: hidden;
  position: relative;
}
.src-card-v2 .bar span {
  position: absolute;
  inset: 0;
  width: var(--w, 60%);
  background: linear-gradient(90deg, var(--accent), rgba(232,0,111,0.4));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 1.2s var(--decel);
}
.src-card-v2.reveal.in .bar span { transform: scaleX(1); }

/* ====== AGENTS ORBIT (Act 08) ====== */

.agents-stage {
  position: relative;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
  min-height: 580px;
}
@media (max-width: 900px) {
  .agents-stage {
    aspect-ratio: auto;
    min-height: 0;
    height: auto;
  }
}
.agents-stage .orbit-svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}
.agent-core {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 168px; height: 168px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff, var(--bg-cream) 70%);
  border: 1px solid rgba(28,28,28,0.18);
  display: flex; flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--text-light-primary);
  font-weight: 700;
  letter-spacing: 0.06em;
  box-shadow:
    0 30px 80px rgba(28,28,28,0.18),
    0 0 0 8px rgba(245,240,232,0.5),
    0 0 0 16px rgba(245,240,232,0.25);
  z-index: 4;
}
.agent-core .logo {
  font-size: 22px;
  letter-spacing: 0.16em;
}
.agent-core .logo .live {
  display: inline-block;
  width: 0.32em; height: 0.32em;
  background: var(--accent);
  border-radius: 50%;
  margin-left: 0.18em;
  vertical-align: 0.16em;
  box-shadow: 0 0 14px rgba(232,0,111,0.65);
  animation: pulse-soft 2.4s ease-in-out infinite;
}
.agent-core .label {
  margin-top: 6px;
  font-size: 9px;
  letter-spacing: 0.32em;
  font-weight: 500;
  color: var(--text-light-tertiary);
  text-transform: uppercase;
}

.agent-node {
  position: absolute;
  width: 132px;
  text-align: center;
  z-index: 3;
  transform: translate(-50%, -50%);
}
.agent-node .avatar {
  width: 92px; height: 92px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid rgba(28,28,28,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  color: var(--text-light-primary);
  box-shadow:
    0 16px 40px rgba(28,28,28,0.12),
    inset 0 0 0 1px rgba(28,28,28,0.04);
  transition: transform 320ms var(--decel), box-shadow 320ms var(--decel), border-color 320ms var(--decel);
  cursor: pointer;
}
.agent-node:hover .avatar {
  transform: translateY(-4px) scale(1.04);
  border-color: var(--accent);
  box-shadow:
    0 20px 50px rgba(232,0,111,0.18),
    0 0 0 4px rgba(232,0,111,0.08);
}
.agent-node:hover .avatar svg { color: var(--accent); }
.agent-node .role {
  margin-top: 12px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-light-primary);
}
.agent-node .desc {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-light-secondary);
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 0.4s var(--decel), max-height 0.5s var(--decel);
}
.agent-node:hover .desc,
.agent-node.lit .desc {
  opacity: 1;
  max-height: 140px;
}

.agents-stage.lit .agent-node .avatar {
  border-color: var(--accent);
  box-shadow:
    0 16px 40px rgba(232,0,111,0.16),
    0 0 0 3px rgba(232,0,111,0.10);
}
.agents-stage.lit .agent-node .avatar svg { color: var(--accent); }

.agent-node .label-tip {
  position: absolute;
  left: 50%; top: -36px;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-light-tertiary);
  background: #fff;
  border: 1px solid var(--text-light-line);
  border-radius: 999px;
  padding: 4px 10px;
  opacity: 0;
  transition: opacity 0.3s var(--decel);
  white-space: nowrap;
}
.agent-node:hover .label-tip { opacity: 1; }
.agent-node .label-tip .pip {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--accent);
}

@media (max-width: 900px) {
  .agents-stage { display: none; }
}
.agents-grid-mobile {
  display: none;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (max-width: 900px) { .agents-grid-mobile { display: grid; } }
.agents-grid-mobile .ag-row {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 14px;
  align-items: start;
  padding: 16px;
  border: 1px solid var(--text-light-line);
  border-radius: 14px;
  background: #fff;
}
.agents-grid-mobile .ag-row .avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  border: 1px solid var(--text-light-line);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-light-primary);
}
.agents-grid-mobile .ag-row .role {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-light-primary);
}
.agents-grid-mobile .ag-row .desc {
  margin-top: 6px;
  font-size: 13px;
  color: var(--text-light-secondary);
  line-height: 1.55;
}

/* ====== USE CASES SPINE (Act 09) ====== */

.usecases-spine-wrap {
  position: relative;
  max-width: 1080px;
  margin: 0 auto;
  padding: 40px 0 80px;
}
.spine-line {
  position: absolute;
  left: 50%;
  top: 40px; bottom: 40px;
  width: 2px;
  background: rgba(28,28,28,0.10);
  transform: translateX(-50%);
  border-radius: 2px;
  overflow: hidden;
}
.spine-line .fill {
  position: absolute;
  left: 0; right: 0; top: 0;
  height: var(--h, 0%);
  background: linear-gradient(180deg, rgba(232,0,111,0.0) 0%, var(--accent) 18%, var(--accent) 100%);
  box-shadow: 0 0 16px rgba(232,0,111,0.45);
  transition: height 0.1s linear;
}
@media (max-width: 800px) {
  .spine-line { left: 24px; }
}

.spine-row {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 80px 1fr;
  gap: 0;
  margin: 0 0 12px;
  min-height: 240px;
  align-items: center;
}
.spine-row + .spine-row { margin-top: -36px; }
@media (max-width: 800px) {
  .spine-row {
    grid-template-columns: 56px 1fr;
    gap: 16px;
    min-height: 0;
    margin: 0 0 24px;
    align-items: start;
  }
  .spine-row + .spine-row { margin-top: 0; }
}

.spine-node {
  position: relative;
  width: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.spine-node .pin {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--bg-cream);
  border: 2px solid rgba(28,28,28,0.18);
  position: relative;
  z-index: 2;
  transition: background 0.4s var(--decel), border-color 0.4s var(--decel), box-shadow 0.4s var(--decel);
}
.spine-row.lit .spine-node .pin {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 0 6px rgba(232,0,111,0.12), 0 0 18px rgba(232,0,111,0.6);
}
@media (max-width: 800px) {
  .spine-node {
    grid-column: 1;
    width: 56px;
    justify-content: flex-start;
    padding-left: 16px;
  }
}

.spine-card {
  position: relative;
  background: #fff;
  border: 1px solid var(--text-light-line);
  border-radius: 16px;
  padding: 28px 28px 26px;
  transition: border-color 0.4s var(--decel), background 0.4s var(--decel), transform 0.4s var(--decel);
  overflow: hidden;
}
.spine-card::before {
  /* pink fill overlay (gradient that grows from edge toward center) */
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(var(--fill-from, 90deg), rgba(232,0,111,0.18) 0%, rgba(232,0,111,0.04) 60%, transparent 90%);
  opacity: 0;
  transition: opacity 0.6s var(--decel);
  pointer-events: none;
}
.spine-card::after {
  /* connector stub */
  content: "";
  position: absolute;
  top: 50%;
  width: 24px; height: 2px;
  background: var(--text-light-line);
  transform: translateY(-50%);
  transition: background-color 0.4s var(--decel);
}
.spine-row.left .spine-card { grid-column: 1; margin-right: 12px; }
.spine-row.right .spine-card { grid-column: 3; margin-left: 12px; }
.spine-row.left .spine-card::after { right: -24px; }
.spine-row.right .spine-card::after { left: -24px; }
.spine-row.left .spine-card  { --fill-from: 270deg; }   /* fills from right (toward spine) */
.spine-row.right .spine-card { --fill-from: 90deg; }    /* fills from left  (toward spine) */
.spine-row.lit .spine-card {
  border-color: rgba(232,0,111,0.55);
  transform: translateY(-2px);
}
.spine-row.lit .spine-card::before { opacity: 1; }
.spine-row.lit .spine-card::after { background-color: var(--accent); }

@media (max-width: 800px) {
  .spine-row.left .spine-card,
  .spine-row.right .spine-card {
    grid-column: 2;
    margin: 0;
  }
  .spine-row .spine-card::after { display: none; }
  .spine-row.right .spine-card  { --fill-from: 90deg; }
  .spine-row.left .spine-card   { --fill-from: 90deg; }
}

.spine-card .n {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--accent);
}
.spine-card .title {
  margin-top: 8px;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text-light-primary);
}
.spine-card .desc {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-light-secondary);
}
.spine-card .insight {
  margin-top: 18px;
  background: #1c1c1c;
  border-radius: 10px;
  padding: 16px 16px;
  color: #f5f0e8;
  font-size: 13px;
  line-height: 1.5;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
}
.spine-card .insight .who {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.45);
  margin-bottom: 4px;
}
.spine-card .insight .pip {
  width: 7px; height: 7px;
  background: var(--accent);
  border-radius: 50%;
  margin-top: 6px;
  box-shadow: 0 0 10px rgba(232,0,111,0.55);
}

/* Override assistant-grid to give chat more breathing room */
.assistant-grid { grid-template-columns: 34fr 66fr; gap: 48px; }
@media (max-width: 900px) { .assistant-grid { grid-template-columns: 1fr; gap: 36px; } }

/* ====== ENHANCED CHAT MOCKUP ====== */

.chat-v2 {
  background: #161513;
  border: 1px solid rgba(245,240,232,0.10);
  border-radius: 16px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 56px 1fr;
  min-height: 540px;
  box-shadow: 0 30px 90px rgba(0,0,0,0.4);
}
@media (min-width: 1100px) {
  .chat-v2 { grid-template-columns: 56px 1fr 230px; }
}
.chat-v2 .side { display: none; }
@media (min-width: 1100px) { .chat-v2 .side { display: block; } }
.chat-v2 .titlebar {
  grid-column: 1 / -1;
  display: flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  background: #121110;
  border-bottom: 1px solid rgba(245,240,232,0.08);
}
.chat-v2 .titlebar .tlights {
  display: flex; gap: 6px;
}
.chat-v2 .titlebar .tlights span {
  width: 11px; height: 11px;
  border-radius: 50%;
  background: #2a2724;
}
.chat-v2 .titlebar .crumbs {
  margin-left: 14px;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.42);
  display: flex; align-items: center; gap: 8px;
}
.chat-v2 .titlebar .crumbs .pip {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(232,0,111,0.5);
}
.chat-v2 .titlebar .right {
  margin-left: auto;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.42);
}

.chat-v2 .rail {
  background: #121110;
  border-right: 1px solid rgba(245,240,232,0.08);
  padding: 16px 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}
.chat-v2 .rail .ico {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(245,240,232,0.55);
  transition: background 0.2s var(--decel), color 0.2s var(--decel);
}
.chat-v2 .rail .ico:hover { background: rgba(245,240,232,0.06); color: var(--text-dark-primary); }
.chat-v2 .rail .ico.active {
  background: rgba(232,0,111,0.12);
  color: var(--accent);
}
.chat-v2 .rail .gap { flex: 1; }

.chat-v2 .main {
  padding: 20px 22px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
  min-width: 0;
}
.chat-v2 .convo-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(245,240,232,0.08);
  font-size: 12px;
  color: rgba(245,240,232,0.5);
}
.chat-v2 .convo-head .h {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.chat-v2 .convo-head .h .pin {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(232,0,111,0.55);
}
.chat-v2 .convo-head .meta {
  display: inline-flex; gap: 8px;
}
.chat-v2 .convo-head .meta .tag {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.55);
  border: 1px solid rgba(245,240,232,0.10);
  padding: 3px 8px;
  border-radius: 999px;
}

.chat-v2 .msg {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 12px;
  align-items: start;
}
.chat-v2 .msg .av {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: rgba(245,240,232,0.08);
  border: 1px solid rgba(245,240,232,0.14);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 500;
  color: rgba(245,240,232,0.7);
}
.chat-v2 .msg.clara .av {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.chat-v2 .msg .who {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.45);
  margin-bottom: 4px;
}
.chat-v2 .msg.clara .who { color: var(--accent); }
.chat-v2 .msg .body { color: var(--text-dark-primary); font-size: 14px; line-height: 1.6; }
.chat-v2 .msg .ts {
  font-size: 10px;
  color: rgba(245,240,232,0.35);
  margin-left: 6px;
}

.chat-v2 .kpiblock {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
@media (max-width: 600px) { .chat-v2 .kpiblock { grid-template-columns: repeat(2, 1fr); } }
.chat-v2 .kpiblock .k {
  background: rgba(245,240,232,0.04);
  border: 1px solid rgba(245,240,232,0.10);
  border-radius: 10px;
  padding: 10px 12px;
}
.chat-v2 .kpiblock .k.accent {
  background: rgba(232,0,111,0.08);
  border-color: rgba(232,0,111,0.42);
}
.chat-v2 .kpiblock .k .lbl {
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(245,240,232,0.45);
}
.chat-v2 .kpiblock .k .val {
  font-size: 18px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text-dark-primary);
  margin-top: 2px;
}
.chat-v2 .kpiblock .k.accent .val { color: var(--accent); }

.chat-v2 .sources-inline {
  margin-top: 12px;
  display: flex; gap: 6px; flex-wrap: wrap;
}
.chat-v2 .sources-inline .src {
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.55);
  border: 1px solid rgba(245,240,232,0.14);
  border-radius: 6px;
  padding: 3px 8px;
  display: inline-flex;
  gap: 6px;
  align-items: center;
}
.chat-v2 .sources-inline .src .ix {
  font-size: 9px;
  font-weight: 600;
  color: var(--accent);
}

.chat-v2 .composer {
  margin-top: auto;
  border-top: 1px solid rgba(245,240,232,0.08);
  padding-top: 12px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
}
.chat-v2 .composer .input {
  display: flex; align-items: center; gap: 10px;
  background: rgba(245,240,232,0.04);
  border: 1px solid rgba(245,240,232,0.10);
  border-radius: 999px;
  padding: 10px 16px;
  color: rgba(245,240,232,0.6);
  font-size: 13px;
}
.chat-v2 .composer .input .caret {
  display: inline-block;
  width: 2px; height: 14px;
  background: var(--accent);
  animation: caret-blink 0.9s steps(2) infinite;
}
.chat-v2 .composer .send {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  font-size: 16px;
}

.chat-v2 .side {
  background: #121110;
  border-left: 1px solid rgba(245,240,232,0.08);
  padding: 18px 18px;
  font-size: 12px;
  color: rgba(245,240,232,0.65);
}
.chat-v2 .side h5 {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.4);
  margin: 0 0 12px;
  font-weight: 500;
}
.chat-v2 .side ul {
  list-style: none; padding: 0; margin: 0 0 22px;
  display: flex; flex-direction: column; gap: 8px;
}
.chat-v2 .side li {
  display: grid; grid-template-columns: 1fr auto;
  gap: 8px;
  font-size: 12px;
}
.chat-v2 .side li .lbl { color: rgba(245,240,232,0.78); }
.chat-v2 .side li .meta { color: rgba(245,240,232,0.35); }
.chat-v2 .side .insight-box {
  background: rgba(232,0,111,0.06);
  border: 1px solid rgba(232,0,111,0.28);
  border-radius: 10px;
  padding: 12px;
  font-size: 12px;
  line-height: 1.5;
}
.chat-v2 .side .insight-box .head {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
}
.chat-v2 .side .insight-box .head .p {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(232,0,111,0.55);
  animation: pulse-soft 2.4s ease-in-out infinite;
}

/* ====== ENHANCED DASHBOARD ====== */
.dash-v2 {
  background: #fdfaf3;
  border: 1px solid var(--text-light-line);
  border-radius: 18px;
  overflow: hidden;
  color: var(--text-light-primary);
  box-shadow: 0 30px 90px rgba(28,28,28,0.10);
}
.dash-v2 .topbar {
  display: grid;
  grid-template-columns: 220px 1fr auto;
  align-items: center;
  border-bottom: 1px solid var(--text-light-line);
}
.dash-v2 .topbar .brand {
  padding: 14px 20px;
  font-size: 12px;
  letter-spacing: 0.16em;
  font-weight: 600;
  border-right: 1px solid var(--text-light-line);
  display: flex; align-items: center; gap: 8px;
}
.dash-v2 .topbar .brand .pip {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(232,0,111,0.55);
}
.dash-v2 .topbar .tabs {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 10px 16px;
}
.dash-v2 .topbar .tabs .t {
  font-size: 12px;
  padding: 6px 12px;
  border-radius: 6px;
  color: var(--text-light-tertiary);
}
.dash-v2 .topbar .tabs .t.active {
  background: rgba(28,28,28,0.04);
  color: var(--text-light-primary);
}
.dash-v2 .topbar .right {
  padding: 0 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text-light-tertiary);
}
.dash-v2 .topbar .right .badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(232,0,111,0.08);
  color: var(--accent);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
}
.dash-v2 .topbar .right .badge .p {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(232,0,111,0.55);
  animation: pulse-soft 2.4s ease-in-out infinite;
}

.dash-v2 .layout {
  display: grid;
  grid-template-columns: 220px 1fr;
}
@media (max-width: 900px) { .dash-v2 .layout { grid-template-columns: 1fr; } .dash-v2 .layout .sidebar { display: none; } }
.dash-v2 .layout .sidebar {
  padding: 18px 16px;
  border-right: 1px solid var(--text-light-line);
  font-size: 13px;
}
.dash-v2 .layout .sidebar h6 {
  font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-light-tertiary);
  margin: 0 0 10px;
  font-weight: 500;
}
.dash-v2 .layout .sidebar ul {
  list-style: none; padding: 0; margin: 0 0 18px;
  display: flex; flex-direction: column; gap: 2px;
}
.dash-v2 .layout .sidebar li {
  padding: 8px 10px;
  border-radius: 8px;
  color: var(--text-light-secondary);
  display: flex; align-items: center; gap: 10px;
}
.dash-v2 .layout .sidebar li.active {
  background: rgba(28,28,28,0.05);
  color: var(--text-light-primary);
  font-weight: 500;
}
.dash-v2 .layout .sidebar li .ico {
  width: 14px; height: 14px;
  border-radius: 4px;
  background: rgba(28,28,28,0.10);
}
.dash-v2 .layout .sidebar li.active .ico {
  background: var(--accent);
}

.dash-v2 .layout .content { padding: 20px 24px 24px; }
.dash-v2 .content .crumb {
  font-size: 12px;
  color: var(--text-light-tertiary);
  margin-bottom: 10px;
}
.dash-v2 .content .crumb b { color: var(--text-light-primary); font-weight: 500; }
.dash-v2 .content .pagehead {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 18px;
}
.dash-v2 .content .pagehead .h1 {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.dash-v2 .content .pagehead .filters {
  display: flex; gap: 6px;
}
.dash-v2 .content .pagehead .filters .chip {
  font-size: 11px;
  padding: 6px 10px;
  border: 1px solid var(--text-light-line);
  border-radius: 999px;
  color: var(--text-light-secondary);
}
.dash-v2 .content .pagehead .filters .chip.active {
  background: var(--text-light-primary);
  color: #fff;
  border-color: var(--text-light-primary);
}

.dash-v2 .kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}
@media (max-width: 720px) { .dash-v2 .kpis { grid-template-columns: repeat(2, 1fr); } }
.dash-v2 .kpis .k {
  background: #fff;
  border: 1px solid var(--text-light-line);
  border-radius: 12px;
  padding: 16px 16px 14px;
}
.dash-v2 .kpis .k .lbl {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-light-tertiary);
}
.dash-v2 .kpis .k .row {
  margin-top: 8px;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.dash-v2 .kpis .k .val {
  font-size: 26px; font-weight: 700; letter-spacing: -0.025em;
}
.dash-v2 .kpis .k .delta {
  font-size: 12px;
}
.dash-v2 .kpis .k .delta.neg { color: var(--accent); }
.dash-v2 .kpis .k .delta.flat { color: var(--text-light-tertiary); }
.dash-v2 .kpis .k .delta.pos { color: #1a8a4a; }
.dash-v2 .kpis .k .spark {
  margin-top: 8px;
  display: flex; align-items: end;
  gap: 2px;
  height: 24px;
}
.dash-v2 .kpis .k .spark .s {
  width: 6px;
  background: rgba(28,28,28,0.18);
  border-radius: 2px 2px 0 0;
}
.dash-v2 .kpis .k .spark .s.hot { background: var(--accent); }

.dash-v2 .panels {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 14px;
}
@media (max-width: 900px) { .dash-v2 .panels { grid-template-columns: 1fr; } }
.dash-v2 .panel {
  background: #fff;
  border: 1px solid var(--text-light-line);
  border-radius: 12px;
  padding: 18px 18px;
}
.dash-v2 .panel .ph {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 16px;
}
.dash-v2 .panel .ph .t {
  font-size: 13px;
  font-weight: 500;
}
.dash-v2 .panel .ph .leg {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-light-tertiary);
  display: inline-flex; gap: 14px;
}
.dash-v2 .panel .ph .leg .it { display: inline-flex; align-items: center; gap: 6px; }
.dash-v2 .panel .ph .leg .it .d { width: 8px; height: 8px; border-radius: 2px; }
.dash-v2 .panel .ph .leg .it .d.real { background: var(--text-light-primary); }
.dash-v2 .panel .ph .leg .it .d.reported { background: rgba(28,28,28,0.20); }
.dash-v2 .panel .ph .leg .it .d.alert { background: var(--accent); }

.dash-v2 .chart {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 8px;
  height: 200px;
}
.dash-v2 .chart .yax {
  display: flex; flex-direction: column;
  justify-content: space-between;
  font-size: 9px;
  color: var(--text-light-tertiary);
  text-align: right;
}
.dash-v2 .chart .bars {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 6px;
  align-items: end;
  position: relative;
  border-bottom: 1px solid var(--text-light-line);
}
.dash-v2 .chart .bars .grid-h {
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: rgba(28,28,28,0.05);
}
.dash-v2 .chart .bars .col {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  height: 100%;
  align-items: end;
}
.dash-v2 .chart .bars .col .b {
  background: rgba(28,28,28,0.18);
  border-radius: 3px 3px 0 0;
  transition: height 1.0s var(--decel);
}
.dash-v2 .chart .bars .col .b.real { background: var(--text-light-primary); }
.dash-v2 .chart .bars .col.hot .b.real { background: var(--accent); }
.dash-v2 .chart .bars .col .lbl {
  position: absolute;
  bottom: -18px; left: 0; right: 0;
  text-align: center;
  font-size: 9px;
  color: var(--text-light-tertiary);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.dash-v2 .table {
  display: flex; flex-direction: column;
}
.dash-v2 .table .thead, .dash-v2 .table .trow {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.8fr 64px;
  gap: 10px;
  align-items: center;
  padding: 10px 0;
}
.dash-v2 .table .thead {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-light-tertiary);
  border-bottom: 1px solid var(--text-light-line);
}
.dash-v2 .table .trow {
  border-bottom: 1px solid var(--text-light-line);
  font-size: 13px;
}
.dash-v2 .table .trow:last-child { border-bottom: none; }
.dash-v2 .table .trow .name { font-weight: 500; }
.dash-v2 .table .trow .meter {
  height: 6px; border-radius: 3px;
  background: rgba(28,28,28,0.08);
  position: relative;
  overflow: hidden;
}
.dash-v2 .table .trow .meter span {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: var(--w, 50%);
  border-radius: 3px;
  background: var(--text-light-primary);
}
.dash-v2 .table .trow.alert .meter span { background: var(--accent); }
.dash-v2 .table .trow .val { text-align: right; color: var(--text-light-secondary); }
.dash-v2 .table .trow .pct { text-align: right; }
.dash-v2 .table .trow .pct.neg { color: var(--accent); }

.dash-v2 .insightbar {
  margin-top: 16px;
  background: #1c1c1c;
  color: #f5f0e8;
  border-radius: 12px;
  padding: 14px 16px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  font-size: 13px;
}
.dash-v2 .insightbar .head {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex; align-items: center; gap: 6px;
}
.dash-v2 .insightbar .head .p {
  width: 7px; height: 7px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 8px rgba(232,0,111,0.55);
}
.dash-v2 .insightbar .body { font-size: 13px; line-height: 1.5; }
.dash-v2 .insightbar .cta {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #f5f0e8;
  border: 1px solid rgba(245,240,232,0.25);
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 150ms, border-color 150ms;
  white-space: nowrap;
}
.dash-v2 .insightbar .cta:hover { background: rgba(245,240,232,0.1); border-color: rgba(245,240,232,0.5); }

/* ── interactive states ── */
.dash-v2 .layout .sidebar li:hover:not(.active) {
  background: rgba(28,28,28,0.04);
  color: var(--text-light-primary);
}
.dash-v2 .content .pagehead .filters .chip {
  cursor: pointer;
}
.dash-v2 .content .pagehead .filters .chip:hover:not(.active) {
  background: rgba(28,28,28,0.06);
}
.dash-v2 .kpis .k:hover {
  border-color: rgba(28,28,28,0.26) !important;
  box-shadow: 0 2px 8px rgba(28,28,28,0.06);
}
.dash-v2 .table .trow:hover {
  background: rgba(28,28,28,0.03);
}
.dash-v2 .table .trow.trow-sel .meter span {
  background: var(--accent) !important;
}
.dash-v2 .insightbar { cursor: pointer; }
.dash-v2 .insightbar:hover { opacity: 0.95; }
.dash-v2 .chart .bars .col:hover .b { filter: brightness(1.15); }

/* ====== ACT 04 — TRES MOVIMIENTOS — visible numbered guidance ====== */
.how-v2 .step .num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px; height: 56px;
  border-radius: 50%;
  border: 1px solid var(--text-dark-line-strong);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text-dark-secondary);
  transition: background 0.3s var(--decel), color 0.3s var(--decel), border-color 0.3s var(--decel), transform 0.3s var(--decel);
}
.how-v2 .step.lit .num {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  transform: scale(1.08);
  box-shadow: 0 0 0 6px rgba(232,0,111,0.14);
}

/* ====== TOPNAV V2 ====== */
