/* ─────────────────────────────────────────────────────────
   DOTGAINEN · EXPERIENCE
   Single-page narrative · spectacular motion
   ───────────────────────────────────────────────────────── */
:root{
  --ink:#070b14;
  --ink-2:#0c121f;
  --panel:#111a2b;
  --panel-2:#172238;
  --line:#1d2a40;
  --line-soft:rgba(29,42,64,.55);
  --fog:#8fa3c0;
  --fog-dim:#6c7e98;
  --text:#e8eef7;
  --signal:#5ff2b0;
  --signal-dim:#2fae7e;
  --signal-glow:rgba(95,242,176,.18);
  --alert:#ff7a59;
  --display:"Schibsted Grotesk",sans-serif;
  --body:"IBM Plex Sans",sans-serif;
  --mono:"IBM Plex Mono",monospace;
  --maxw:1320px;
  --pad:clamp(20px, 4vw, 56px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}  /* Lenis handles smooth scroll */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:clip}

body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--body);
  line-height:1.55;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  cursor:none;  /* custom cursor on hover-capable */
}
@media(hover:none){body{cursor:auto}}
::selection{background:var(--signal);color:var(--ink)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:none;border:0;background:none;color:inherit}
@media(hover:none){button{cursor:pointer}}

/* ─────────── Custom cursor ─────────── */
.cursor,.cursor-dot{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  border-radius:50%;
  mix-blend-mode:screen;
  will-change:transform;
}
.cursor{
  width:32px;height:32px;
  border:1px solid var(--signal);
  margin-left:-16px;margin-top:-16px;
  transition:width .25s, height .25s, background .25s, border-color .25s;
}
.cursor-dot{
  width:5px;height:5px;
  background:var(--signal);
  margin-left:-2.5px;margin-top:-2.5px;
  box-shadow:0 0 12px var(--signal);
}
.cursor.hovering{
  width:54px;height:54px;
  margin-left:-27px;margin-top:-27px;
  background:rgba(95,242,176,.08);
}
@media(hover:none){.cursor,.cursor-dot{display:none}}

/* ─────────── Loader ─────────── */
.loader{
  position:fixed;inset:0;z-index:10000;
  background:var(--ink);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  gap:18px;
  transition:opacity .6s ease, visibility .6s;
}
.loader.gone{opacity:0;visibility:hidden;pointer-events:none}
.loader .lg{
  font-family:var(--mono);font-size:.78rem;color:var(--fog);
  letter-spacing:.2em;text-transform:uppercase;
}
.loader .bar{width:160px;height:1px;background:var(--line);overflow:hidden}
.loader .bar i{
  display:block;height:100%;width:0%;background:var(--signal);
  transition:width .3s linear;
  box-shadow:0 0 6px var(--signal);
}

/* ─────────── Header ─────────── */
header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(7,11,20,.55);
  border-bottom:1px solid transparent;
  transition:background .3s, border-color .3s;
}
header.solid{background:rgba(7,11,20,.85);border-bottom-color:var(--line)}
.bar{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  height:76px;gap:24px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:56px;width:auto;display:block}
footer .brand img{height:56px}
.brand .pulse{
  width:9px;height:9px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 12px var(--signal);
  animation:pulse 2.4s ease-in-out infinite;flex-shrink:0;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.32}}

nav.primary ul{display:flex;gap:30px;list-style:none}
nav.primary a{color:var(--fog);font-size:.9rem;font-weight:500;transition:color .2s}
nav.primary a:hover{color:var(--text)}
.right{display:flex;align-items:center;gap:18px}
.lang{font-family:var(--mono);font-size:.78rem;color:var(--fog);letter-spacing:.04em}
.lang b{color:var(--text)}
.lang a{color:var(--fog);text-decoration:none;transition:color .2s;font-weight:500}
.lang a:hover{color:var(--text)}
.lang a.active{color:var(--text);font-weight:600}

/* ──────────────────────────────────────────────────────────
   Legal pages (aviso-legal.html, privacidad.html)
   ────────────────────────────────────────────────────────── */
.legal-page{background:var(--ink);overflow-x:hidden}
.legal-page header + .legal-main{padding-top:120px}
.legal-main{padding-bottom:clamp(60px,8vw,120px)}
.legal-article{
  max-width:760px;margin:0 auto;padding:0 var(--pad);
  position:relative;z-index:2;
}
.legal-header{
  margin-bottom:clamp(40px,5vw,60px);
  padding-bottom:clamp(24px,3vw,36px);
  border-bottom:1px solid var(--line);
}
.legal-header h1{
  font-family:var(--display);font-weight:800;
  font-size:clamp(2.4rem,5.5vw,3.6rem);
  letter-spacing:-.03em;line-height:1.05;
  color:var(--text);margin-top:14px;
}
.legal-meta{
  font-family:var(--mono);font-size:.78rem;color:var(--fog);
  letter-spacing:.06em;margin-top:18px;
}
.legal-article h2{
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.3rem,2vw,1.6rem);
  letter-spacing:-.015em;color:var(--text);
  margin:48px 0 18px;
}
.legal-article h3{
  font-family:var(--display);font-weight:600;
  font-size:1.1rem;color:var(--text);margin:32px 0 12px;
}
.legal-article p,
.legal-article li{
  color:var(--fog);font-size:1rem;line-height:1.72;
}
.legal-article p{margin-bottom:18px}
.legal-article ul{
  padding-left:22px;margin-bottom:22px;
  list-style:none;
}
.legal-article li{
  position:relative;padding-left:18px;margin-bottom:10px;
}
.legal-article li::before{
  content:"·";position:absolute;left:0;color:var(--signal);
  font-weight:700;
}
.legal-article a{color:var(--signal);text-decoration:underline;text-underline-offset:3px}
.legal-article a:hover{color:var(--text)}
.legal-article strong{color:var(--text);font-weight:600}
.legal-back{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:56px;padding:14px 22px;
  font-family:var(--mono);font-size:.85rem;letter-spacing:.06em;
  color:var(--signal);text-decoration:none;
  border:1px solid var(--signal-dim);border-radius:99px;
  transition:.3s;
}
.legal-back:hover{background:var(--signal);color:var(--ink);border-color:var(--signal)}

.btn{
  background:var(--signal);color:var(--ink);
  font-weight:600;font-family:var(--body);font-size:.92rem;
  padding:12px 22px;border-radius:8px;
  border:1px solid var(--signal);
  display:inline-flex;align-items:center;gap:8px;
  transition:.2s;
}
.btn:hover{background:transparent;color:var(--signal)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--signal);color:var(--signal);background:transparent}
.btn-lg{padding:15px 26px;font-size:1rem}

.menu-btn{
  display:none;
  width:42px;height:42px;border:1px solid var(--line);border-radius:8px;
  align-items:center;justify-content:center;background:var(--ink-2);
}
.menu-btn svg{width:18px;height:18px;color:var(--text)}
@media(max-width:980px){
  nav.primary{display:none}
  .menu-btn{display:flex}
  .lang{display:none}
}
.drawer{
  position:fixed;inset:76px 0 0 0;z-index:48;
  background:rgba(7,11,20,.96);backdrop-filter:blur(14px);
  display:none;flex-direction:column;padding:40px var(--pad);
}
.drawer.open{display:flex}
.drawer a{
  font-family:var(--display);font-weight:700;font-size:1.7rem;
  letter-spacing:-.02em;color:var(--text);
  padding:18px 0;border-bottom:1px solid var(--line);
}
.drawer a:last-child{border-bottom:0}

/* ─────────── Hero scene ─────────── */
.hero{
  position:relative;
  height:100vh;min-height:720px;
  width:100%;overflow:hidden;
  isolation:isolate;
}
#scene{
  position:absolute;inset:0;
  width:100%;height:100%;
  z-index:0;
}
/* Legacy `.hero::after` heavy vignette removed: it painted above the
   `.hero-act` content (`.hero-pin` is a sticky stacking context, so
   `.hero::after` z-index 1 rendered above the act z-index 2) and was
   darkening the hero headline. The subtle bottom fade now lives only
   on `.hero-pin::after` further down in this file. */
/* `.hero-overlay` legacy block removed — only `Dotgainen Home.html`
   (the orphan home prototype) referenced it; the live `index.html`
   uses `.hero-act` + `.hero-stage` instead. */
.tag-live{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:.78rem;color:var(--signal);
  letter-spacing:.08em;text-transform:uppercase;
  border:1px solid var(--line);background:rgba(12,18,31,.75);
  padding:8px 14px;border-radius:99px;
  width:max-content;
  backdrop-filter:blur(4px);
}
.tag-live .dot{
  width:7px;height:7px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 8px var(--signal);
  animation:pulse 2.4s ease-in-out infinite;
}

.hero h1.kinetic{
  font-family:var(--display);font-weight:800;
  letter-spacing:-.035em;line-height:1.06;
  font-size:clamp(2.2rem, 5.4vw, 5.25rem);
  margin:clamp(20px,2.4vw,28px) 0 clamp(18px,2vw,24px);
  max-width:20ch;
  padding-bottom:0.12em;
}
.hero h1 .word{display:inline-block;overflow:clip;overflow-clip-margin:0.25em;vertical-align:top}
.hero h1.done .word{overflow:visible}
.hero h1 .word .ch{display:inline-block;transform:translateY(110%);opacity:0;will-change:transform,opacity}
.hero h1 .word .ch.in{transform:translateY(0);opacity:1;transition:transform .9s cubic-bezier(.2,.7,.2,1), opacity .9s}
.hero h1 .hl{color:var(--signal)}
.hero h1 br{display:block;line-height:0}

.hero .lead{
  font-size:clamp(1rem, 1.3vw, 1.2rem);
  color:var(--fog);max-width:56ch;line-height:1.55;
  margin-bottom:clamp(24px,2.6vw,34px);
  opacity:0;transform:translateY(20px);transition:opacity .9s .9s, transform .9s .9s;
}
.hero .lead.in{opacity:1;transform:none}
.hero .lead b{color:var(--text);font-weight:600}
.hero .cta-row{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;transform:translateY(20px);transition:opacity .9s 1.15s, transform .9s 1.15s;
}
.hero .cta-row.in{opacity:1;transform:none}

/* ─── Hero risk-reversal microcopy + guarantees row (act 1) ─── */
.hero-microcopy{
  font-size:.95rem;color:var(--fog);
  margin:18px 0 12px;max-width:52ch;line-height:1.55;
}
.hero-microcopy b{color:var(--text);font-weight:600}
.hero-guarantees{
  font-family:var(--mono);font-size:.74rem;
  color:var(--fog-dim);letter-spacing:.08em;
  margin:0;
}

/* hero trust line + ledger */
.hero-trust{
  font-family:var(--mono);font-size:.78rem;
  color:var(--fog);letter-spacing:.1em;text-transform:uppercase;
  margin-top:clamp(22px,2.4vw,30px);
  display:inline-block;
  padding:6px 0;
  border-top:1px solid var(--line);
  opacity:0;transform:translateY(16px);transition:opacity .9s 1.35s, transform .9s 1.35s;
}
.hero-trust.in{opacity:1;transform:none}

.hero-ledger{
  margin-top:clamp(22px,2.4vw,30px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);
  border:1px solid var(--line);border-radius:11px;overflow:hidden;
  max-width:720px;
  opacity:0;transform:translateY(20px);transition:opacity .9s 1.55s, transform .9s 1.55s;
  backdrop-filter:blur(6px);
}
.hero-ledger.in{opacity:1;transform:none}
.hl-cell{
  background:rgba(7,11,20,.68);
  padding:14px 18px;
}
.hl-cell .n{
  font-family:var(--display);font-weight:800;
  font-size:clamp(1.3rem,2.4vw,1.85rem);
  letter-spacing:-.025em;line-height:1;
  font-variant-numeric:tabular-nums;
}
.hl-cell .n .s{
  color:var(--signal);font-size:.52em;font-weight:700;margin-left:4px;
}
.hl-cell .l{
  font-family:var(--mono);font-size:.62rem;
  color:var(--fog);letter-spacing:.1em;
  text-transform:uppercase;margin-top:6px;line-height:1.4;
}
@media(max-width:780px){
  .hero-ledger{grid-template-columns:repeat(2,1fr);max-width:none}
  .hero-trust{font-size:.7rem}
}
@media(max-width:420px){
  .hero-ledger{grid-template-columns:1fr}
}

.scroll-hint{
  position:absolute;
  bottom:24px;right:var(--pad);
  font-family:var(--mono);font-size:.66rem;color:var(--fog);
  letter-spacing:.18em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;
  z-index:3;
  opacity:0;animation:hintIn 1s 1.7s forwards;
  pointer-events:none;
}
.scroll-hint::after{
  content:"↓";font-size:1rem;color:var(--signal);line-height:1;
  animation:hintArrow 2.4s ease-in-out infinite;
}
@keyframes hintIn{to{opacity:.7}}
@keyframes hintArrow{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(6px);opacity:.4}}
@media(max-height:840px){.scroll-hint{display:none}}
@media(max-width:520px){.scroll-hint{display:none}}

/* hero entry animations — act-1 elements appear quickly with the page; no opacity delays that risk looking dim */
.hero-act-1 .tag-live{opacity:1;transform:none;transition:none;animation:none}
.hero-act-1 .lead{opacity:1;transform:none;transition:none}
.hero-act-1 .cta-row{opacity:1;transform:none;transition:none}

/* ─────────── Generic section layout ─────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative;z-index:2}
section{position:relative;z-index:2}
.eyebrow{
  font-family:var(--mono);font-size:.74rem;color:var(--signal);
  text-transform:uppercase;letter-spacing:.16em;
}
h2{
  font-family:var(--display);font-weight:800;letter-spacing:-.03em;
  font-size:clamp(2rem,5.4vw,4.2rem);line-height:1.02;
  margin:14px 0 18px;max-width:18ch;
}
h2 .hl{color:var(--signal)}
.sub{color:var(--fog);max-width:64ch;font-size:clamp(1rem,1.3vw,1.18rem);line-height:1.6}

/* reveal helper */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.15s}.d3{transition-delay:.28s}.d4{transition-delay:.4s}.d5{transition-delay:.52s}

/* ─────────── Promise · giant counters ─────────── */
.promise{
  min-height:100vh;padding:140px 0 100px;
  display:flex;flex-direction:column;justify-content:center;
}
.promise h2{max-width:18ch;font-size:clamp(2.4rem,6.5vw,5.2rem)}
.counters{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;
  margin-top:clamp(40px,5vw,64px);
}
.ctr{background:var(--ink-2);padding:clamp(28px,3vw,40px) clamp(22px,2.4vw,32px)}
.ctr .n{
  font-family:var(--display);font-weight:800;letter-spacing:-.025em;line-height:1;
  font-size:clamp(2.4rem,6vw,4.4rem);
}
.ctr .n .s{color:var(--signal);font-size:.45em;font-weight:700;margin-left:.1em}
.ctr .l{
  font-family:var(--mono);font-size:.72rem;color:var(--fog);
  text-transform:uppercase;letter-spacing:.12em;margin-top:14px;line-height:1.5;
}
@media(max-width:860px){.counters{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.counters{grid-template-columns:1fr}}

/* ─────────── Partners strip (Cisco-only, rich) ─────────── */
.partners-rich{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(28px,4vw,44px) 0;
  display:grid;grid-template-columns:1.1fr 1px 2.2fr;gap:clamp(28px,4vw,48px);
  align-items:stretch;position:relative;
}
.partners-rich::before{
  /* subtle signal glow on the cisco side */
  content:"";position:absolute;left:0;top:0;bottom:0;width:38%;
  background:radial-gradient(circle at 30% 50%, var(--signal-glow), transparent 70%);
  pointer-events:none;opacity:.5;
}
.pr-left{
  display:flex;flex-direction:column;justify-content:center;gap:14px;
  position:relative;z-index:1;
}
.pr-label{
  font-family:var(--mono);font-size:.7rem;
  text-transform:uppercase;letter-spacing:.16em;color:var(--fog);
  line-height:1.5;
}
.pr-cisco{display:flex;align-items:center;gap:14px;margin-top:8px}
.pr-cisco-logo{
  height:clamp(56px,7vw,84px);width:auto;display:block;
  /* SVG ships with fill="#ffffff", so the asset stays white over the dark site */
}
.pr-tag{
  font-family:var(--mono);font-size:.72rem;
  color:var(--signal);letter-spacing:.14em;text-transform:uppercase;
}
.pr-divider{background:var(--line);position:relative;z-index:1}
.pr-badges{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  align-items:stretch;position:relative;z-index:1;
}
.pr-badge{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:12px;padding:22px 20px;
  display:flex;flex-direction:column;gap:6px;
  transition:.3s;position:relative;overflow:hidden;
}
.pr-badge::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:2px;
  background:var(--signal);transform:scaleX(0);transform-origin:left;
  transition:transform .4s;
}
.pr-badge:hover{border-color:var(--signal-dim);transform:translateY(-2px)}
.pr-badge:hover::before{transform:scaleX(1)}
.pr-badge-head{
  font-family:var(--display);font-weight:700;
  font-size:1rem;letter-spacing:-.01em;color:var(--text);line-height:1.25;
}
.pr-badge-year{
  font-family:var(--mono);font-size:.74rem;
  color:var(--signal);letter-spacing:.1em;
}
.pr-badge-sub{
  font-size:.8rem;color:var(--fog);line-height:1.45;margin-top:4px;
}
@media(max-width:980px){
  .partners-rich{grid-template-columns:1fr;gap:28px}
  .pr-divider{display:none}
  .partners-rich::before{width:100%;opacity:.25}
}
@media(max-width:640px){.pr-badges{grid-template-columns:1fr}}

/* ─────────── Cisco stack · categorized chip grid ─────────── */
.stack-cats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,32px);
}
.stack-cat-head{
  display:block;
  font-family:var(--mono);font-size:.72rem;color:var(--signal);
  text-transform:uppercase;letter-spacing:.16em;
  margin-bottom:16px;padding-bottom:12px;
  border-bottom:1px solid var(--line);
}
.stack-cat .stack-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:0}
@media(max-width:860px){.stack-cats{grid-template-columns:1fr;gap:24px}}

/* ─────────── Triada — pinned stacked cards ─────────── */
.triada-section{
  padding:clamp(80px,12vw,160px) 0;
}
.triada-header{margin-bottom:clamp(40px,5vw,60px)}
/* `.triada-stack` legacy grid removed — superseded by `.triada-content`
   (the diagram + detail-rows layout introduced in the spectacular UX
   pass). No HTML or JS still references this class. */
.tcard{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;padding:36px 32px;position:relative;
  min-height:340px;
  display:flex;flex-direction:column;
  transition:transform .3s, border-color .3s;
  overflow:hidden;
}
.tcard::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:2px;
  background:var(--signal);transform:scaleX(0);transform-origin:left;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.tcard.active::before,.tcard:hover::before{transform:scaleX(1)}
.tcard.active{border-color:var(--signal-dim)}
.tcard .step{
  font-family:var(--mono);font-size:.74rem;color:var(--signal);
  letter-spacing:.16em;
}
.tcard h3{
  font-family:var(--display);font-weight:700;font-size:1.5rem;
  letter-spacing:-.02em;margin:14px 0 14px;line-height:1.18;
}
.tcard p{color:var(--fog);font-size:.96rem;line-height:1.55;flex:1}
.tcard .badge{
  position:absolute;top:24px;right:24px;
  font-family:var(--mono);font-size:.62rem;
  color:var(--signal);letter-spacing:.12em;
  border:1px solid var(--signal-dim);padding:4px 8px;border-radius:5px;
  background:rgba(7,11,20,.6);
}
.tcard .glyph{
  width:54px;height:54px;border:1px solid var(--line);border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
  background:var(--ink);
}
.tcard.active .glyph{border-color:var(--signal-dim)}
.tcard .glyph svg{width:24px;height:24px;color:var(--signal)}
@media(max-width:920px){.triada-stack{grid-template-columns:1fr}.tcard{min-height:0}}

/* ─────────── SOC console — pinned with incident ─────────── */
.soc-section{
  padding:clamp(80px,10vw,140px) 0 clamp(100px,12vw,180px);
}
.soc-section h2{margin-bottom:clamp(24px,3vw,40px)}
.console{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:18px;overflow:hidden;position:relative;
  box-shadow:0 40px 100px -50px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.03);
}
.console.alert{box-shadow:0 40px 100px -50px rgba(255,122,89,.4), 0 0 0 1px var(--alert), inset 0 1px 0 rgba(255,255,255,.03)}
.console.contained{box-shadow:0 40px 100px -50px rgba(95,242,176,.4), 0 0 0 1px var(--signal-dim), inset 0 1px 0 rgba(255,255,255,.03)}
.console-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 22px;border-bottom:1px solid var(--line);
  background:var(--panel);gap:16px;flex-wrap:wrap;
}
.console-head .left{
  display:flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:.72rem;color:var(--fog);letter-spacing:.12em;
}
.console-head .left .stat{
  display:inline-flex;align-items:center;gap:9px;
}
.console-head .clock{font-family:var(--mono);font-size:.72rem;color:var(--text);letter-spacing:.04em}
.console-head .state-pill{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;
  padding:5px 10px;border-radius:5px;color:var(--signal);
  border:1px solid var(--signal-dim);
  transition:.4s;
}
.console.alert .state-pill{color:var(--alert);border-color:var(--alert)}
.console.contained .state-pill{color:var(--signal);border-color:var(--signal)}

.kpi-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-bottom:1px solid var(--line);
}
.kpi{padding:22px 22px;border-right:1px solid var(--line)}
.kpi:last-child{border-right:0}
.kpi .n{font-family:var(--display);font-weight:800;font-size:clamp(1.5rem,2.6vw,2rem);letter-spacing:-.02em;line-height:1;color:var(--text)}
.kpi .n .s{color:var(--signal);font-size:.55em;font-weight:700;margin-left:4px}
.kpi.alert .n .num{color:var(--alert);transition:color .3s}
.kpi .l{font-family:var(--mono);font-size:.66rem;color:var(--signal);letter-spacing:.14em;margin-top:10px}
.kpi .sub{font-size:.78rem;color:var(--fog);margin-top:4px;line-height:1.4;max-width:none}
@media(max-width:860px){.kpi-row{grid-template-columns:repeat(2,1fr)}.kpi:nth-child(2){border-right:0}.kpi:nth-child(1),.kpi:nth-child(2){border-bottom:1px solid var(--line)}}
@media(max-width:460px){.kpi-row{grid-template-columns:1fr}.kpi{border-right:0;border-bottom:1px solid var(--line)}}

.console-body{display:grid;grid-template-columns:1fr 1fr}
.chart-pane,.stream-pane{padding:22px}
.chart-pane{border-right:1px solid var(--line)}
@media(max-width:860px){.console-body{grid-template-columns:1fr}.chart-pane{border-right:0;border-bottom:1px solid var(--line)}}
.pane-head{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;
  font-family:var(--mono);font-size:.66rem;color:var(--fog);letter-spacing:.14em;
}
.pane-head .right{color:var(--signal)}
.bars{display:flex;gap:3px;align-items:flex-end;height:108px;margin-bottom:14px}
.bars div{flex:1;border-radius:1px;background:rgba(143,163,192,.22);transition:height .3s, background .3s}
.bars div.peak{background:var(--signal-dim)}
.bars div.now{background:var(--signal);box-shadow:0 0 6px var(--signal)}
.bars div.spike{background:var(--alert);box-shadow:0 0 10px var(--alert)}

.legend{display:flex;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:.66rem;color:var(--fog)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:8px;height:2px;display:inline-block;background:var(--fog-dim)}

.events{display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:.78rem;min-height:260px}
.evt{
  display:grid;grid-template-columns:62px 50px 1fr 92px;gap:10px;
  align-items:center;padding:8px 0;border-bottom:1px solid var(--line-soft);
  opacity:0;transform:translateY(-6px);animation:evtIn .4s forwards;
}
.evt.alert .src{color:var(--alert);border-color:var(--alert)}
.evt.alert .state{color:var(--alert)}
.evt.success .state{color:var(--signal)}
@keyframes evtIn{to{opacity:1;transform:none}}
.evt:last-child{border-bottom:0}
.evt .t{color:var(--fog);font-size:.72rem}
.evt .src{color:var(--signal);text-align:center;font-size:.62rem;letter-spacing:.1em;border:1px solid var(--line);padding:2px 4px;border-radius:4px}
.evt .desc{color:var(--text);font-family:var(--body);font-size:.85rem;line-height:1.35}
.evt .state{color:var(--signal);text-transform:uppercase;font-size:.62rem;letter-spacing:.12em;text-align:right}
.evt .state::before{content:"· "}
@media(max-width:520px){
  .evt{grid-template-columns:54px 1fr;row-gap:4px;column-gap:10px}
  .evt .src{display:none}
  .evt .state{grid-column:2;text-align:left;margin-top:2px}
  .evt .state::before{content:""}
}

/* incident timeline */
.incident-timeline{
  margin-top:clamp(24px,3vw,40px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  position:relative;
}
.incident-timeline::before{
  content:"";position:absolute;top:24px;left:6%;right:6%;height:1px;
  background:linear-gradient(90deg,var(--line) 0,var(--line) 100%);
}
.it-step{
  background:rgba(7,11,20,.7);
  padding-top:8px;display:flex;flex-direction:column;align-items:flex-start;position:relative;
}
.it-step .dot{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--line);background:var(--ink-2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:.7rem;color:var(--fog);
  margin-bottom:14px;position:relative;z-index:1;
  transition:.3s;
}
.it-step.active .dot{border-color:var(--signal);color:var(--signal);background:var(--signal-glow);box-shadow:0 0 14px var(--signal-glow)}
.it-step.done .dot{border-color:var(--signal-dim);color:var(--signal);background:var(--ink-2)}
.it-step .it-label{font-family:var(--mono);font-size:.66rem;color:var(--signal);letter-spacing:.14em}
.it-step .it-title{font-family:var(--display);font-weight:600;font-size:1rem;margin-top:6px;letter-spacing:-.01em}
.it-step .it-sub{font-size:.84rem;color:var(--fog);margin-top:6px;line-height:1.45}
@media(max-width:760px){.incident-timeline{grid-template-columns:1fr}.incident-timeline::before{display:none}}

/* ─────────── Cisco ─────────── */
.cisco-section{padding:clamp(80px,10vw,140px) 0}
.cisco-stack-block{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;padding:clamp(28px,3vw,40px);margin-top:24px;
}
.stack-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.chip{
  font-family:var(--mono);font-size:.7rem;color:var(--text);
  background:var(--panel);border:1px solid var(--line);
  padding:6px 10px;border-radius:6px;letter-spacing:.04em;
}
.stack-chips .chip{font-size:.78rem;padding:7px 12px}
.cisco-creds{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;margin-top:clamp(40px,5vw,60px);
}
.cisco-creds .ctr{padding:clamp(24px,2.5vw,32px) clamp(20px,2.2vw,28px)}
.cisco-creds .ctr .n{font-size:clamp(1.5rem,2.6vw,2.2rem)}
@media(max-width:480px){.cisco-creds{grid-template-columns:1fr}}

/* ─────────── Ecosistema ─────────── */
.eco-section{padding:clamp(80px,10vw,140px) 0}
.products{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
  margin-top:clamp(40px,5vw,56px);
}
.pcard{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;padding:36px 32px;position:relative;overflow:hidden;
  transition:.3s;
}
.pcard::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:2px;
  background:var(--signal);transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.pcard:hover{border-color:var(--signal-dim);transform:translateY(-4px)}
.pcard:hover::before{transform:scaleX(1)}
.pcard .code{font-family:var(--mono);font-size:.74rem;color:var(--fog);letter-spacing:.08em}
.pcard .code .pilot{color:var(--alert)}
.pcard h3{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em;margin:10px 0 12px}
.pcard p{color:var(--fog);font-size:.96rem;line-height:1.55}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.pc-result{
  margin-top:20px;padding-top:16px;
  border-top:1px solid var(--line);
  font-family:var(--display);font-weight:700;color:var(--signal);
  font-size:1.02rem;line-height:1.4;letter-spacing:-.01em;
}
@media(max-width:780px){.products{grid-template-columns:1fr}}

/* ─── Collapsible tech detail (pcards + Cisco catalog) ──────────
   Business benefit lives in the flow; the acronym wall lives behind
   a "Ver tecnología" / "Ver catálogo completo" toggle so CEO/CFO
   readers aren't ambushed by XDR/ETD/ISE/etc. */
.pc-tech,
.cisco-catalog{
  margin-top:18px;padding-top:14px;
  border-top:1px solid var(--line);
}
.pc-tech > summary,
.cisco-catalog > summary{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--fog);cursor:pointer;
  list-style:none;display:inline-flex;align-items:center;gap:10px;
  padding:4px 0;transition:color .2s;outline-offset:4px;
}
.pc-tech > summary::-webkit-details-marker,
.cisco-catalog > summary::-webkit-details-marker{display:none}
.pc-tech > summary::before,
.cisco-catalog > summary::before{
  content:"+";color:var(--signal);font-weight:700;
  font-size:1.15em;line-height:1;width:14px;text-align:center;
  transition:transform .3s;
}
.pc-tech[open] > summary::before,
.cisco-catalog[open] > summary::before{content:"−"}
.pc-tech > summary:hover,
.cisco-catalog > summary:hover,
.pc-tech > summary:focus-visible,
.cisco-catalog > summary:focus-visible{color:var(--signal)}
.pc-tech .chips{margin-top:14px}
.cisco-catalog .stack-cats{margin-top:18px}
.cisco-stack-lead{
  color:var(--fog);font-size:clamp(1rem,1.3vw,1.18rem);
  line-height:1.6;max-width:64ch;margin:0 0 22px;
}
.cisco-stack-lead b{color:var(--text);font-weight:600}
@media(prefers-reduced-motion:reduce){
  .pc-tech > summary::before,
  .cisco-catalog > summary::before{transition:none}
}

/* ─────────── Triada · live tape ─────────── */
.triada-tape{
  margin-top:clamp(28px,3vw,40px);
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;
  box-shadow:0 20px 50px -30px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.03);
}
.tt-head{
  padding:13px 20px;border-bottom:1px solid var(--line);
  background:var(--panel);
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  font-family:var(--mono);font-size:.68rem;color:var(--fog);letter-spacing:.16em;
}
.tt-dot{
  width:7px;height:7px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 8px var(--signal);
  animation:pulse 2.4s ease-in-out infinite;
}
.tt-clock{margin-left:auto;color:var(--text);letter-spacing:.04em}
.tt-log{
  padding:6px 20px 14px;
  /* Fixed height + overflow:hidden so the page below doesn't jump while
     the tape briefly holds 6 rows (newest inserted before the oldest
     finishes its fade-out). 5 rows × ~37px (.tt-line padding+border)
     + container padding = ~215px; 220 gives a small buffer. */
  height:220px;box-sizing:border-box;overflow:hidden;
  font-family:var(--mono);font-size:.82rem;
}
.tt-line{
  display:grid;grid-template-columns:1fr auto;gap:16px;
  padding:9px 0;border-bottom:1px solid var(--line-soft);
  opacity:0;transform:translateY(-6px);
  animation:ttIn .45s cubic-bezier(.2,.7,.2,1) forwards;
}
.tt-line:last-child{border-bottom:0}
.tt-line .l{color:var(--text)}
.tt-line .l .src{color:var(--fog);margin-right:4px}
.tt-line .r{color:var(--signal);text-transform:lowercase;letter-spacing:.02em}
@keyframes ttIn{to{opacity:1;transform:none}}

/* ─────────── In-house systems block ─────────── */
.inhouse-block{
  margin-top:clamp(40px,5vw,56px);
  padding:clamp(28px,3.4vw,40px);
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;position:relative;overflow:hidden;
}
.inhouse-block::before{
  content:"";position:absolute;top:0;right:0;width:50%;height:100%;pointer-events:none;
  background:radial-gradient(ellipse at 80% 20%, var(--signal-glow), transparent 70%);
  opacity:.45;
}
.inhouse-block > *{position:relative;z-index:1}
.inhouse-block .ih-head{
  font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.4vw,1.8rem);
  letter-spacing:-.02em;line-height:1.18;
  margin:12px 0 10px;max-width:24ch;
}
.inhouse-block .ih-sub{
  color:var(--fog);font-size:1rem;line-height:1.55;max-width:60ch;
  margin-bottom:26px;
}
.inhouse-list{
  display:flex;flex-direction:column;gap:0;
  border-top:1px solid var(--line);
}
.ih-item{
  display:grid;grid-template-columns:200px 1fr;gap:24px;
  padding:18px 0;border-bottom:1px solid var(--line-soft);
  align-items:start;
}
.ih-item:last-child{border-bottom:0}
.ih-item .ih-name{
  font-family:var(--display);font-weight:700;font-size:1.18rem;
  letter-spacing:-.01em;color:var(--text);line-height:1.2;
  display:flex;flex-direction:column;gap:6px;align-items:flex-start;
}
.ih-pilot{
  font-family:var(--mono);font-size:.6rem;color:var(--signal);
  letter-spacing:.14em;border:1px solid var(--signal-dim);
  padding:3px 7px;border-radius:4px;font-weight:500;
}
.ih-item .ih-desc{color:var(--fog);font-size:.94rem;line-height:1.55}
.ih-featured .ih-name > span:first-child{color:var(--signal)}
@media(max-width:760px){
  .ih-item{grid-template-columns:1fr;gap:10px}
}

/* ─────────── Contraste section ─────────── */
.contraste-section{padding:clamp(80px,10vw,140px) 0}
.compare{
  margin-top:clamp(40px,5vw,60px);
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;
  box-shadow:0 20px 50px -30px rgba(0,0,0,.4);
}
.compare-row{
  display:grid;grid-template-columns:200px 1fr 1.2fr;gap:32px;
  padding:22px 32px;border-bottom:1px solid var(--line);
  align-items:center;
}
.compare-row:last-child{border-bottom:0}
.compare-header{
  background:var(--panel);
  padding-top:18px;padding-bottom:18px;
}
.compare-header .cr-typical,.compare-header .cr-us{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;padding-left:0;border-left:0;margin-left:0;
}
.compare-header .cr-us{color:var(--signal)}
.compare-header .cr-typical{color:var(--fog)}
.cr-label{
  font-family:var(--mono);font-size:.72rem;color:var(--fog);
  letter-spacing:.14em;text-transform:uppercase;
}
.cr-typical{color:var(--fog-dim);font-size:1rem;line-height:1.4}
.cr-us{
  color:var(--text);font-size:1.05rem;font-weight:500;line-height:1.4;
  border-left:2px solid var(--signal);padding-left:16px;margin-left:-18px;
}
@media(max-width:780px){
  .compare-row{grid-template-columns:1fr;gap:6px;padding:20px 22px}
  .cr-us{margin-left:0;padding-left:14px}
  .compare-header{display:grid;grid-template-columns:1fr 1fr;padding:14px 22px}
  .compare-header .cr-label{display:none}
}

/* ─────────── Final · offer pill ─────────── */
.final-offer{
  margin:24px auto 32px;max-width:62ch;
  padding:12px 20px;
  border:1px solid var(--signal-dim);
  border-radius:99px;
  background:rgba(95,242,176,.06);
  display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;
  justify-content:center;
}
.final-offer .fo-pill{
  font-family:var(--mono);font-size:.74rem;
  color:var(--signal);letter-spacing:.16em;font-weight:600;
  border-right:1px solid var(--signal-dim);padding-right:14px;
}
.final-offer .fo-text{color:var(--fog);font-size:.92rem;line-height:1.4}
@media(max-width:520px){
  .final-offer .fo-pill{border-right:0;padding-right:0;padding-bottom:4px}
}

/* ─────────── Cursor radial glow on dark cards (premium micro-interaction) ─────────── */
.tcard,.pcard,.scol,.scard,.pr-badge,.ih-item.ih-featured{
  --mx:50%;--my:50%;
}
.tcard::after,.pcard::after,.scol::after,.scard::after,.pr-badge::after,.ih-item.ih-featured::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  border-radius:inherit;
  background:radial-gradient(280px circle at var(--mx) var(--my), rgba(95,242,176,0.12), transparent 55%);
  opacity:0;transition:opacity .35s ease;
  z-index:0;
}
.tcard:hover::after,.pcard:hover::after,.scol:hover::after,.scard:hover::after,.pr-badge:hover::after,.ih-item.ih-featured:hover::after{opacity:1}
.tcard > *,.pcard > *,.scol > *,.scard > *,.pr-badge > *,.ih-item.ih-featured > *{position:relative;z-index:1}
.ih-item.ih-featured{position:relative;border-radius:12px;padding-left:16px;padding-right:16px;margin:0 -16px;background:rgba(95,242,176,0.04)}
@media(max-width:780px){.products{grid-template-columns:1fr}}

/* ─────────── Sectors · horizontal scroll ─────────── */
.sectors-section{
  padding:clamp(80px,10vw,140px) 0 clamp(40px,6vw,80px);
  overflow:hidden;
}
.sectors-header{padding:0 var(--pad);max-width:var(--maxw);margin:0 auto}
.sectors-track-outer{margin-top:clamp(40px,5vw,60px);overflow:hidden}
.sectors-track{
  display:flex;gap:18px;
  padding:0 var(--pad);
  will-change:transform;
}
.scard{
  flex-shrink:0;width:clamp(260px,28vw,360px);min-height:280px;
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;padding:32px 28px;
  display:flex;flex-direction:column;justify-content:space-between;
  transition:.3s;position:relative;overflow:hidden;
}
.scard::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:2px;
  background:var(--signal);transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.scard:hover{border-color:var(--signal-dim)}
.scard:hover::before{transform:scaleX(1)}
.scard .idx{font-family:var(--mono);font-size:.7rem;color:var(--signal);letter-spacing:.16em}
.scard h4{font-family:var(--display);font-weight:700;font-size:1.7rem;letter-spacing:-.02em;line-height:1.1;margin-top:14px}
.scard .keywords{font-family:var(--mono);font-size:.74rem;color:var(--fog);letter-spacing:.04em;margin-top:18px;line-height:1.6}
.sectors-hint{
  margin:24px var(--pad) 0;
  font-family:var(--mono);font-size:.72rem;color:var(--fog);
  letter-spacing:.16em;text-transform:uppercase;
  display:flex;align-items:center;gap:14px;
}
.sectors-hint::after{
  content:"";flex:1;height:1px;background:var(--line);
}
@media(max-width:760px){
  .sectors-track-outer{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .sectors-track-outer::-webkit-scrollbar{display:none}
}

/* ─────────── Modelo + Por qué (combined grid) ─────────── */
.split-section{padding:clamp(80px,10vw,140px) 0}
.split-3{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin-top:clamp(40px,5vw,56px);
}
@media(max-width:920px){.split-3{grid-template-columns:1fr}}

/* ─────────── Talento ─────────── */
.talento-section{padding:clamp(80px,10vw,140px) 0}
.split-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:clamp(40px,5vw,56px)}
.scol{background:var(--ink-2);border:1px solid var(--line);border-radius:16px;padding:clamp(28px,3vw,40px)}
.scol h3{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em;margin-bottom:12px}
.scol p{color:var(--fog);font-size:.97rem;margin-bottom:24px;line-height:1.55}
@media(max-width:780px){.split-2{grid-template-columns:1fr}}

/* ─────────── Final CTA ─────────── */
.final-section{padding:clamp(80px,10vw,140px) 0 clamp(60px,8vw,100px)}
.final{
  background:linear-gradient(135deg,var(--panel),var(--ink-2));
  border:1px solid var(--line);border-radius:20px;
  padding:clamp(48px,7vw,88px) clamp(28px,5vw,72px);
  text-align:center;position:relative;overflow:hidden;
}
.final::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 0%, var(--signal-glow), transparent 55%);
}
.final > *{position:relative;z-index:1}
.final h2{margin:14px auto 14px;max-width:18ch}
.final .sub{margin:0 auto 32px}
.final .cta-row{justify-content:center;display:flex;gap:14px;flex-wrap:wrap}

/* ─────────── Footer ─────────── */
footer{border-top:1px solid var(--line);padding:clamp(48px,6vw,72px) 0 36px;position:relative;z-index:2}
.fgrid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:36px}
footer .brand img{height:38px}
.fcol h5{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--fog);margin-bottom:16px;font-weight:500}
.fcol a{color:var(--text);font-size:.92rem;display:block;margin-bottom:10px;opacity:.85;transition:.2s}
.fcol a:hover{color:var(--signal);opacity:1}
.foot-desc{color:var(--fog);font-size:.9rem;max-width:340px;margin-top:18px;line-height:1.55}
.fbot{margin-top:44px;padding-top:22px;border-top:1px solid var(--line);font-family:var(--mono);font-size:.76rem;color:var(--fog);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;letter-spacing:.04em}
@media(max-width:860px){.fgrid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:520px){.fgrid{grid-template-columns:1fr}}

/* ─────────── Reduced motion ─────────── */
@media(prefers-reduced-motion:reduce){
  .hero h1 .ch,.hero .lead,.hero .cta-row,.tag-live,.reveal{opacity:1 !important;transform:none !important;transition:none !important}
  .scroll-hint,.brand .pulse,.tag-live .dot{animation:none !important}
  .noc-ticker .nt-track,.story-rail-line,.act-1 h1,.cmdk-bg,.cisco-award-modal::backdrop{animation:none !important}
  .triada-diagram .axis-pulse{animation:none !important}
}

/* ═══════════════════════════════════════════════════════════════
   ROUND 2 — SPECTACULAR UI/UX UPGRADES
   1 · Hero 3-act scrubbed   3 · Tríada SVG diagram
   4 · Hero h1 SVG displacement
   5 · Magnetic CTAs + proximity glow (JS)
   6 · NOC ticker     7 · Vertical timeline rail
   8 · Section sweeps  9 · Cmd+K palette
   10 · Cisco awards modal   11 · Mesh formation intro
   ═══════════════════════════════════════════════════════════════ */

/* ─── 1 · Hero 3-act scrubbed ─── */
.hero{
  /* extended scroll length for 3 acts */
  height:300vh;min-height:auto;
  position:relative;
  overflow:visible;
  isolation:isolate;
}
.hero-pin{
  position:sticky;top:0;
  height:100vh;min-height:680px;
  width:100%;overflow:hidden;
  isolation:isolate;
}
.hero-pin > #scene{position:absolute;inset:0;z-index:0}
.hero-pin::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:
    linear-gradient(180deg, transparent 0%, transparent 70%, rgba(7,11,20,.85) 100%);
}
.hero-stage{
  position:absolute;inset:0;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:80px var(--pad) 100px;
}
.hero-act{
  position:absolute;
  left:var(--pad);right:var(--pad);top:0;bottom:0;
  max-width:var(--maxw);
  margin:0 auto;
  display:flex;flex-direction:column;justify-content:center;
  padding:130px 0 100px;
  pointer-events:none;
  z-index:2;
  will-change:opacity,transform;
}
.hero-act.active{pointer-events:auto}
.hero-act-2,.hero-act-3{opacity:0}
.hero-act h1,
.hero-act h2{
  font-family:var(--display);font-weight:800;
  letter-spacing:-.035em;line-height:1.06;
  font-size:clamp(2.2rem,5.4vw,5.25rem);
  margin:clamp(20px,2.4vw,28px) 0 clamp(18px,2vw,24px);
  max-width:20ch;
  padding-bottom:0.12em;
  color:var(--text);
}
.hero-act h1 .hl,
.hero-act h2 .hl{color:var(--signal)}

/* keep the kinetic animation only inside act 1 */
.hero-act-1 h1.kinetic .word{display:inline-block;overflow:visible;vertical-align:top}
.hero-act-1 h1.kinetic.done .word{overflow:visible}
.hero-act-1 h1.kinetic .ch{display:inline-block;opacity:1}

/* act 2 specific (giant figures cascade) */
.act-figures{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(28px,4vw,56px);
  margin-top:clamp(16px,2vw,24px);max-width:1080px;
}
.act-fig{
  border-top:1px solid var(--line);padding-top:18px;
}
.act-fig .n{
  font-family:var(--display);font-weight:800;
  font-size:clamp(2.6rem,5.4vw,4.6rem);
  letter-spacing:-.035em;line-height:1;
  color:var(--text);
}
.act-fig .n .s{color:var(--signal);font-size:.45em;font-weight:700;margin-left:6px}
.act-fig .l{
  font-family:var(--mono);font-size:.74rem;
  color:var(--fog);letter-spacing:.14em;text-transform:uppercase;
  margin-top:14px;line-height:1.5;
}
@media(max-width:780px){.act-figures{grid-template-columns:1fr;gap:18px}}

/* act 3 specific (selectividad) */
.act-scarcity{
  display:inline-flex;align-items:center;gap:0;border-radius:99px;overflow:hidden;
  border:1px solid var(--line);background:var(--ink-2);
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;
  margin-bottom:24px;
}
.act-scarcity .s-1{padding:9px 16px;color:var(--fog);
  display:inline-flex;align-items:center;gap:10px;}
.act-scarcity .s-1::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 8px var(--signal);
  animation:pulse 2.4s ease-in-out infinite;
}
.act-scarcity .s-2{
  padding:9px 16px;color:var(--signal);font-weight:500;
  background:rgba(95,242,176,.06);
  border-left:1px solid var(--line);
}

/* progress indicator (mini dots) */
.hero-progress{
  position:absolute;left:50%;transform:translateX(-50%);
  bottom:34px;z-index:5;
  display:flex;gap:10px;align-items:center;
  font-family:var(--mono);font-size:.66rem;color:var(--fog);letter-spacing:.16em;
}
.hero-progress .dot{
  width:24px;height:1px;background:var(--line);
  transition:.3s;
}
.hero-progress .dot.active{background:var(--signal);box-shadow:0 0 6px var(--signal)}
@media(max-width:520px){.hero-progress{font-size:0;gap:8px}}

/* ─── 3 · Tríada SVG diagram ─── */
.triada-content{
  display:grid;grid-template-columns:0.95fr 1.05fr;gap:clamp(32px,5vw,64px);
  margin-top:clamp(40px,5vw,56px);align-items:start;
}
.triada-diagram{
  position:sticky;top:120px;
  width:100%;
}
.triada-diagram svg{width:100%;height:auto;display:block}
/* Concentric-circle diagram — purely geometric, no duplicated text;
   the right-hand `.triada-row` cards carry all the prose. */
.triada-diagram .ring-outer{fill:none;stroke:rgba(95,242,176,0.12);stroke-width:1;transition:.4s}
.triada-diagram .ring-mid{fill:none;stroke:rgba(95,242,176,0.22);stroke-width:1;transition:.4s}
.triada-diagram .ring-inner{fill:rgba(95,242,176,0.06);stroke:rgba(95,242,176,0.45);stroke-width:1;transition:.4s}
.triada-diagram .ring-feat{fill:rgba(95,242,176,0.14);stroke:rgba(95,242,176,0.65);stroke-width:1.5}
.triada-diagram .layer-active .ring-outer{stroke:rgba(95,242,176,0.4)}
.triada-diagram .layer-active .ring-mid{stroke:rgba(95,242,176,0.62)}
.triada-diagram .layer-active .ring-inner{fill:rgba(95,242,176,0.2);stroke:rgba(95,242,176,0.85)}
.triada-diagram .layer-num{font-family:var(--display);font-weight:800;font-size:22px;fill:var(--text);letter-spacing:-0.02em;transition:.4s}
.triada-diagram .layer-num-feat{font-size:26px;fill:var(--signal)}
.triada-diagram .layer-active .layer-num{fill:var(--signal)}
.triada-diagram .diagram-crown-label{font-family:var(--mono);font-size:10px;fill:var(--fog);letter-spacing:1.5px}
.triada-diagram .axis{
  stroke:var(--line);stroke-width:1;
}
.triada-diagram .axis-pulse{
  stroke:var(--signal);stroke-width:2;stroke-linecap:round;
  filter:drop-shadow(0 0 4px var(--signal));
  animation:axisPulse 4.5s ease-in-out infinite;
}
@keyframes axisPulse{
  0%{stroke-dasharray:0 60 0 999;opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  100%{stroke-dasharray:0 999 60 0;opacity:0}
}
.triada-detail{display:flex;flex-direction:column;gap:8px}
.triada-row{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:12px;padding:22px 24px;
  transition:.4s;cursor:default;position:relative;overflow:hidden;
  --mx:50%;--my:50%;
}
.triada-row::before{
  content:"";position:absolute;top:0;left:0;width:2px;height:100%;
  background:var(--signal);transform:scaleY(0);transform-origin:top;
  transition:transform .5s;
}
.triada-row.active{border-color:var(--signal-dim)}
.triada-row.active::before,.triada-row:hover::before{transform:scaleY(1)}
.triada-row::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  border-radius:inherit;
  background:radial-gradient(220px circle at var(--mx) var(--my), rgba(95,242,176,0.10), transparent 55%);
  opacity:0;transition:opacity .35s;
}
.triada-row:hover::after{opacity:1}
.triada-row > *{position:relative;z-index:1}
.triada-row .step{
  font-family:var(--mono);font-size:.7rem;color:var(--signal);letter-spacing:.16em;
}
.triada-row h3{
  font-family:var(--display);font-weight:700;font-size:1.2rem;
  letter-spacing:-.015em;margin:8px 0 8px;line-height:1.2;
}
.triada-row .badge{
  display:inline-block;
  font-family:var(--mono);font-size:.6rem;
  color:var(--signal);letter-spacing:.12em;
  border:1px solid var(--signal-dim);padding:3px 7px;border-radius:5px;
  margin-left:10px;vertical-align:middle;
}
.triada-row p{color:var(--fog);font-size:.92rem;line-height:1.55}
.triada-fact{
  margin-top:14px;padding-top:14px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.72rem;color:var(--signal);
  letter-spacing:.14em;text-transform:uppercase;line-height:1.55;
}
.triada-row.active .triada-fact{border-top-color:var(--signal-dim)}
@media(max-width:920px){
  .triada-content{grid-template-columns:1fr;gap:32px}
  .triada-diagram{position:static}
}

/* ─── 6 · NOC ticker ─── */
.noc-ticker{
  position:fixed;top:76px;left:0;right:0;z-index:48;
  height:32px;
  background:rgba(7,11,20,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;
  overflow:hidden;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.04em;
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.noc-ticker.in{transform:translateY(0)}
.nt-label{
  flex-shrink:0;
  padding:0 14px;height:100%;
  background:var(--panel);
  border-right:1px solid var(--line);
  display:inline-flex;align-items:center;gap:9px;
  color:var(--signal);letter-spacing:.18em;font-size:.62rem;
}
.nt-label::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 8px var(--signal);
  animation:pulse 2.4s ease-in-out infinite;
}
.nt-track{
  flex:1;height:100%;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 40px,#000 calc(100% - 60px),transparent);
          mask-image:linear-gradient(90deg,transparent,#000 40px,#000 calc(100% - 60px),transparent);
}
.nt-row{
  display:flex;gap:34px;align-items:center;
  height:100%;width:max-content;
  animation:nocSlide 96s linear infinite;
  white-space:nowrap;
}
@keyframes nocSlide{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.nt-item{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--fog);
}
.nt-item .t{color:var(--text);font-size:.66rem}
.nt-item .src{
  color:var(--signal);font-size:.6rem;letter-spacing:.1em;
  border:1px solid var(--line);padding:1px 6px;border-radius:3px;
}
.nt-item .state{color:var(--signal);font-size:.66rem;text-transform:uppercase;letter-spacing:.1em}
.nt-item .div{color:var(--line)}
@media(max-width:640px){.noc-ticker{display:none}}

/* push everything down a bit when ticker is visible */
body.has-ticker header + .noc-ticker + *,body.has-ticker .hero{margin-top:0}
@media(min-width:641px){
  body.has-ticker .hero-pin{height:calc(100vh - 32px)}
}

/* ─── 7 · Vertical timeline rail ─── */
.story-rail{
  position:fixed;right:18px;top:50%;transform:translateY(-50%);
  z-index:46;pointer-events:none;
  display:flex;flex-direction:column;gap:14px;align-items:flex-end;
  opacity:0;transition:opacity .5s;
}
.story-rail.in{opacity:1}
.sr-item{
  pointer-events:auto;
  display:flex;align-items:center;gap:10px;
  cursor:pointer;
  font-family:var(--mono);font-size:.62rem;
  color:var(--fog);letter-spacing:.14em;text-transform:uppercase;
}
.sr-item .sr-line{
  width:22px;height:1px;background:var(--line);
  transition:.3s;
}
.sr-item .sr-label{
  opacity:0;transform:translateX(8px);transition:.3s;
}
.sr-item:hover .sr-label,.sr-item.active .sr-label{opacity:1;transform:none}
.sr-item:hover .sr-line,.sr-item.active .sr-line{
  width:38px;background:var(--signal);box-shadow:0 0 6px var(--signal);
}
.sr-item.active{color:var(--text)}
@media(max-width:980px){.story-rail{display:none}}

/* ─── 8 · Section sweeps ─── */
.sweep-on-enter{position:relative;overflow:hidden}
.sweep-on-enter > .section-sweep{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--signal),transparent);
  opacity:0;
  pointer-events:none;
  z-index:5;
}
.sweep-on-enter.swept > .section-sweep{
  animation:sectionSweep 1.4s cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes sectionSweep{
  0%{opacity:0;transform:translateX(-30%) scaleX(.3)}
  20%{opacity:1}
  100%{opacity:0;transform:translateX(0) scaleX(1)}
}

/* H2 letter sweep — subtle */
.h2-sweep h2{position:relative;display:inline-block}
.h2-sweep h2::after{
  content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;
  background:linear-gradient(90deg,var(--signal),transparent);
  transition:width 1s cubic-bezier(.2,.7,.2,1) .2s;
}
.h2-sweep.swept h2::after{width:100%}

/* ─── 9 · Cmd+K palette ─── */
.cmdk{
  position:fixed;inset:0;z-index:100;
  display:none;align-items:flex-start;justify-content:center;
  padding-top:14vh;
  background:rgba(7,11,20,.72);backdrop-filter:blur(10px);
  animation:cmdkBgIn .25s ease-out;
}
.cmdk.open{display:flex}
@keyframes cmdkBgIn{from{opacity:0}to{opacity:1}}
.cmdk-panel{
  width:min(560px, calc(100vw - 40px));
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.7);
  animation:cmdkIn .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes cmdkIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
.cmdk-search{
  display:flex;align-items:center;gap:12px;
  padding:18px 22px;
  border-bottom:1px solid var(--line);
}
.cmdk-search svg{width:18px;height:18px;color:var(--fog);flex-shrink:0}
.cmdk-search input{
  flex:1;background:none;border:0;outline:0;color:var(--text);
  font-family:var(--body);font-size:1rem;
}
.cmdk-search input::placeholder{color:var(--fog-dim)}
.cmdk-search .kbd{
  font-family:var(--mono);font-size:.66rem;color:var(--fog);
  border:1px solid var(--line);padding:3px 6px;border-radius:4px;
}
.cmdk-list{list-style:none;max-height:50vh;overflow-y:auto;padding:8px}
.cmdk-list li{
  display:flex;align-items:center;gap:14px;
  padding:11px 14px;border-radius:8px;cursor:pointer;
  font-size:.92rem;color:var(--text);
}
.cmdk-list li.active{background:var(--panel);color:var(--signal)}
.cmdk-list li .ck-num{
  font-family:var(--mono);font-size:.66rem;color:var(--fog);letter-spacing:.1em;
  min-width:32px;
}
.cmdk-list li.active .ck-num{color:var(--signal)}
.cmdk-list li .ck-arrow{margin-left:auto;color:var(--fog);font-family:var(--mono);font-size:.8rem}
.cmdk-list li.active .ck-arrow{color:var(--signal)}
.cmdk-foot{
  padding:10px 22px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.66rem;color:var(--fog);
  display:flex;justify-content:space-between;letter-spacing:.06em;
}
.cmdk-foot .kbd{
  font-family:var(--mono);font-size:.62rem;color:var(--text);
  border:1px solid var(--line);padding:2px 5px;border-radius:3px;margin:0 3px;
}

/* ─── 10 · Cisco awards modal ─── */
.pr-badge{cursor:pointer}
.pr-badge[data-award]:hover .pr-badge-head{color:var(--signal)}
.cisco-award-modal{
  position:fixed;inset:0;z-index:100;
  display:none;align-items:center;justify-content:center;
  padding:24px;
  background:rgba(7,11,20,.78);backdrop-filter:blur(10px);
  animation:cmdkBgIn .25s ease-out;
}
.cisco-award-modal.open{display:flex}
.cam-panel{
  width:min(620px, 100%);
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;position:relative;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8);
  animation:cmdkIn .4s cubic-bezier(.2,.7,.2,1);
}
.cam-banner{
  height:140px;
  background:
    radial-gradient(circle at 30% 100%, var(--signal-glow), transparent 60%),
    linear-gradient(135deg, var(--panel), var(--ink-2));
  border-bottom:1px solid var(--line);
  position:relative;display:flex;align-items:center;justify-content:center;
}
.cam-banner .star{
  font-size:64px;color:var(--signal);
  text-shadow:0 0 30px var(--signal);
  animation:pulse 2.4s ease-in-out infinite;
}
.cam-body{padding:30px 36px}
.cam-eyebrow{
  font-family:var(--mono);font-size:.68rem;color:var(--signal);
  letter-spacing:.16em;text-transform:uppercase;
}
.cam-title{
  font-family:var(--display);font-weight:700;font-size:1.6rem;
  letter-spacing:-.02em;margin:10px 0 10px;
}
.cam-year{
  font-family:var(--mono);font-size:.9rem;color:var(--text);letter-spacing:.06em;
  margin-bottom:18px;
}
.cam-desc{color:var(--fog);font-size:.96rem;line-height:1.6;margin-bottom:24px}
.cam-quote{
  border-left:2px solid var(--signal);padding-left:16px;
  color:var(--text);font-style:italic;font-size:.96rem;line-height:1.5;
}
.cam-close{
  position:absolute;top:14px;right:14px;
  width:34px;height:34px;border-radius:50%;
  background:rgba(7,11,20,.5);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--text);cursor:pointer;transition:.2s;
}
.cam-close:hover{border-color:var(--signal);color:var(--signal)}
.cam-close svg{width:14px;height:14px}

/* ─── 4 · Hero h1 SVG displacement filter is consumed via CSS filter url ─── */
.hero-act-1 h1.kinetic{filter:none}

/* ─── 5 · Magnetic CTAs ─── */
.magnetic{
  will-change:transform;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.magnetic:hover{transition:transform .15s ease-out}

/* ──────────────────────────────────────────────────────────
   Hero CTA-alt (Task 3 — links to #diagnostico)
   ────────────────────────────────────────────────────────── */
.hero-cta-alt{margin-top:14px;font-size:.92rem;color:var(--fog)}
.hero-cta-alt a{
  color:var(--signal);text-decoration:none;
  border-bottom:1px solid var(--signal-dim);
  transition:color .2s,border-color .2s;padding-bottom:2px;
}
.hero-cta-alt a:hover,
.hero-cta-alt a:focus-visible{color:var(--text);border-bottom-color:var(--text);outline:none}

/* ──────────────────────────────────────────────────────────
   Diagnóstico exprés (Task 3)
   ────────────────────────────────────────────────────────── */
.diag-section{padding:clamp(80px,10vw,140px) 0}
.diag-app{
  margin-top:clamp(32px,4vw,48px);
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;padding:clamp(28px,4vw,48px);
  position:relative;overflow:hidden;
}
.diag-intro{display:flex;justify-content:center;padding:clamp(20px,3vw,36px) 0}

/* Question card */
.diag-card{display:flex;flex-direction:column;gap:clamp(20px,2vw,28px)}
.diag-progress{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.diag-progress-label{
  font-family:var(--mono);font-size:.72rem;color:var(--signal);
  letter-spacing:.14em;text-transform:uppercase;
}
.diag-dots{display:flex;gap:6px}
.diag-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--line);transition:background .3s;
}
.diag-dot.done{background:var(--signal-dim)}
.diag-dot.active{background:var(--signal);box-shadow:0 0 8px var(--signal)}
.diag-q-text{
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.3rem,2.4vw,1.8rem);letter-spacing:-.02em;
  color:var(--text);line-height:1.3;margin:0;max-width:32ch;
}
.diag-options{display:flex;flex-direction:column;gap:10px}
.diag-option{
  font-family:var(--body);font-size:.98rem;text-align:left;
  background:var(--ink);color:var(--text);
  border:1px solid var(--line);border-radius:10px;
  padding:16px 20px;cursor:pointer;
  transition:border-color .2s,background .2s,transform .15s;
}
.diag-option:hover,.diag-option:focus-visible{
  border-color:var(--signal);background:rgba(95,242,176,0.06);outline:none;
}
.diag-option:active{transform:scale(.985)}
.diag-back{
  align-self:flex-start;font-family:var(--mono);font-size:.8rem;
  background:transparent;border:none;color:var(--fog);cursor:pointer;
  padding:6px 0;letter-spacing:.06em;
}
.diag-back:hover{color:var(--text)}

/* Results */
.diag-results{display:flex;flex-direction:column;gap:clamp(24px,3vw,36px)}
.diag-result-h{
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.5rem,2.6vw,2rem);letter-spacing:-.02em;
  color:var(--text);margin:8px 0 0;
}
.diag-score{
  display:flex;align-items:baseline;gap:6px;
  font-family:var(--display);font-weight:800;letter-spacing:-.04em;line-height:1;
}
.diag-score-n{font-size:clamp(4rem,9vw,6.5rem);color:var(--signal)}
.diag-score.diag-yellow .diag-score-n{color:#f5c451}
.diag-score.diag-red .diag-score-n{color:var(--alert)}
.diag-score-max{font-size:clamp(1.4rem,2.5vw,2rem);color:var(--fog);font-weight:600}

/* Pillars */
.diag-pillars-label,
.diag-recs-label{
  font-family:var(--mono);font-size:.72rem;color:var(--signal);
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:14px;
}
.diag-pillars-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;
}
.diag-pillar{
  background:var(--ink);border:1px solid var(--line);border-radius:10px;
  padding:16px 18px;display:flex;flex-direction:column;gap:10px;
}
.diag-pillar-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.diag-pillar-name{
  font-family:var(--display);font-weight:600;font-size:1rem;
  color:var(--text);letter-spacing:-.01em;
}
.diag-pillar-score{
  font-family:var(--display);font-weight:800;font-size:1.4rem;
  color:var(--signal);letter-spacing:-.02em;
}
.diag-pillar-max{font-size:.8rem;color:var(--fog);font-weight:600;margin-left:2px}
.diag-pillar-bar{
  height:4px;border-radius:99px;
  background:rgba(143,163,192,0.18);overflow:hidden;
}
.diag-pillar-bar i{
  display:block;height:100%;background:var(--signal);border-radius:inherit;
  transition:width .8s cubic-bezier(.2,.7,.2,1);
}
.diag-pillar.diag-yellow .diag-pillar-score,
.diag-pillar.diag-yellow .diag-pillar-bar i{color:#f5c451;background:#f5c451}
.diag-pillar.diag-yellow .diag-pillar-score{background:transparent}
.diag-pillar.diag-red .diag-pillar-score,
.diag-pillar.diag-red .diag-pillar-bar i{color:var(--alert);background:var(--alert)}
.diag-pillar.diag-red .diag-pillar-score{background:transparent}
.diag-pillar-legend{
  font-family:var(--mono);font-size:.7rem;color:var(--fog);
  letter-spacing:.12em;text-transform:uppercase;
}

/* Recommendations */
.diag-recs-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.diag-rec{
  background:var(--ink);border:1px solid var(--line);
  border-left:3px solid var(--signal);border-radius:8px;padding:14px 18px;
}
.diag-rec.diag-yellow{border-left-color:#f5c451}
.diag-rec.diag-red{border-left-color:var(--alert)}
.diag-rec-pillar{
  display:inline-block;font-family:var(--mono);font-size:.68rem;
  color:var(--fog);letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;
}
.diag-rec p{color:var(--text);font-size:.98rem;line-height:1.55;margin:0}

/* CTA chain */
.diag-cta{
  background:var(--ink);border:1px solid var(--signal-dim);
  border-radius:12px;padding:clamp(20px,3vw,28px);
}
.diag-cta h4{
  font-family:var(--display);font-weight:700;font-size:1.15rem;
  letter-spacing:-.01em;color:var(--text);margin:0 0 8px;
}
.diag-cta p{
  color:var(--fog);font-size:.95rem;line-height:1.55;
  margin:0 0 16px;max-width:56ch;
}

/* Email opt-in */
.diag-email{display:flex;flex-direction:column;gap:8px}
.diag-email-label{
  font-family:var(--mono);font-size:.72rem;color:var(--fog);
  letter-spacing:.12em;text-transform:uppercase;
}
.diag-email-row{display:flex;gap:10px;flex-wrap:wrap}
.diag-email input[type="email"]{
  flex:1 1 240px;min-width:0;background:var(--ink);
  border:1px solid var(--line);border-radius:8px;
  padding:12px 16px;color:var(--text);font:inherit;outline-offset:2px;
}
.diag-email input[type="email"]:focus-visible{border-color:var(--signal);outline:none}
.diag-email input[type="email"][disabled]{opacity:.6;cursor:not-allowed}
.diag-email-status{
  font-family:var(--mono);font-size:.78rem;color:var(--fog);
  letter-spacing:.04em;min-height:1.5em;
}
.diag-email-status.ok{color:var(--signal)}
.diag-email-status.err{color:var(--alert)}
.diag-restart{
  align-self:flex-start;font-family:var(--mono);font-size:.78rem;
  background:transparent;border:none;color:var(--fog);cursor:pointer;
  padding:8px 0;letter-spacing:.06em;
}
.diag-restart:hover{color:var(--text)}

@media(prefers-reduced-motion:reduce){
  .diag-pillar-bar i,
  .diag-dot,
  .diag-option{transition:none}
}
