/* ================================================================
   NeuronUs · Landing · styles.css
   Brand v2.0 — Neuronal AI Group
   ================================================================ */

:root {
  /* Core brand */
  --bg:         #080F22;
  --bg2:        #0D1B3E;
  --bg3:        #1A2D5A;
  --blue:       #1A6BFF;
  --blue2:      #0A3FCC;
  --cyan:       #4D8DFF;
  --accent:     #F5A623;
  --accent2:    #C47D0A;
  --amber-light:#FDE8B8;
  --white:      #FFFFFF;
  --gray:       #8A92A6;
  --muted:      rgba(255,255,255,.42);
  --success:    #34C778;
  --error:      #FF4D4D;
  --purple:     #9B6DFF;
  --card:       rgba(13,27,62,0.45);

  /* Borders */
  --border:      rgba(26,107,255,.14);
  --border-soft: rgba(26,107,255,.08);
  --border2:     rgba(26,107,255,.22);
  --border3:     rgba(26,107,255,.38);

  /* Typography */
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: 'JetBrains Mono', 'Fira Code', monospace;

  --ease-out: cubic-bezier(0.0, 0.0, 0.2, 1);
  --pad:  clamp(80px, 9vw, 128px);
  --max-w: 1280px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--bg);
  color: var(--white);
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
img { max-width: 100%; display: block; }

/* ── Progress bar ─────────────────────────────────────────── */
.pb{position:fixed;top:0;left:0;right:0;height:2px;z-index:200;background:rgba(255,255,255,.02)}
.pf{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan),var(--accent));width:0%;transition:width .08s}

/* ── Logo text (CSS wordmark, works on any bg) ────────────── */
.logo-text {
  font-family: var(--font);
  font-weight: 800;
  font-size: 22px;
  line-height: 1;
  letter-spacing: -0.02em;
  display: inline-flex; align-items: baseline;
}
.logo-neuron { color: #fff; }
.logo-us     { color: var(--blue); }
.logo-dot    { color: var(--accent); }
.logo-text-lg { font-size: 28px; }
.logo-inline { font-size:inherit; line-height:1; letter-spacing:inherit; vertical-align:baseline; }

/* ── Image logo variants ─────────────────────────────────── */
.logo-img {
  display: inline-block;
  height: 22px !important;
  width: auto !important;
  max-width: none;
  object-fit: contain;
  vertical-align: middle;
}
.logo-img-lg {
  height: 28px !important;
}
.logo-img-inline {
  height: 0.92em !important;
  width: auto !important;
  vertical-align: -0.12em;
  position: relative;
  margin: 0 0.22em;
  display: inline-block;
}
.logo-img-inline:first-child { margin-left: 0; }
.logo-img-inline:last-child  { margin-right: 0; }
.logo-img-text {
  height: 1em !important;
  width: auto !important;
  vertical-align: middle;
  position: relative;
  top: -0.08em;
}
.text-gradient { background:linear-gradient(120deg,var(--blue) 10%,var(--blue2) 90%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; font-weight:700; }

/* ── Container ────────────────────────────────────────────── */
.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 60px);
  width: 100%;
  box-sizing: border-box;
}

/* ── Reveal animations ────────────────────────────────────── */
/* New sections use .reveal + .in */
.reveal {
  opacity: 0; transform: translateY(28px);
  transition: opacity 0.65s var(--ease-out), transform 0.65s var(--ease-out);
  transition-delay: calc(var(--i, 0) * 90ms);
}
.reveal.in { opacity: 1; transform: none; }
/* v13 sections use .r/.r2 + .v */
.r  { opacity:0; transform:translateY(32px); transition:opacity .7s ease,transform .7s ease; }
.r.v { opacity:1; transform:translateY(0); }
.r2 { opacity:0; transform:translateY(20px); transition:opacity .7s .15s ease,transform .7s .15s ease; }
.r2.v { opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .reveal, .r, .r2 { opacity: 1; transform: none; transition: none; }
}

/* ── Divider ──────────────────────────────────────────────── */
.div { height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); }

/* ── Section utilities (v13 pattern) ─────────────────────── */
.sec-inner { max-width:1280px; margin:0 auto; padding:0 clamp(20px,5vw,60px); width:100%; box-sizing:border-box; }
.ey {
  font-family: var(--mono); font-size:10px; color:var(--blue);
  letter-spacing:3px; text-transform:uppercase;
  margin-bottom:14px; display:inline-flex; align-items:center; gap:10px;
}
.st {
  font-family: var(--font); font-size:clamp(32px,3.2vw,52px);
  font-weight:700; line-height:1.08; letter-spacing:-0.02em; margin-bottom:18px;
}
.st em { font-style:normal; color:var(--blue); }
.sd {
  font-family: var(--font); font-size:16px; font-weight:300;
  line-height:1.85; color:rgba(255,255,255,.66);
  max-width:620px; margin-bottom:56px;
}
.sec-head { margin-bottom:56px; max-width:720px; }
.sec-head.center { margin-left:auto; margin-right:auto; text-align:center; }

/* ── Section tag (new sections) ──────────────────────────── */
.section-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10.5px; font-weight: 600;
  letter-spacing: 2.2px; text-transform: uppercase; color: var(--cyan);
  margin-bottom: 20px;
}
.tag-dot {
  width: 5px; height: 5px; background: var(--cyan); border-radius: 50%;
  animation: blink 2.4s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.35} }

/* ── Buttons ──────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--blue); color: var(--white);
  font-family: var(--font); font-size: 15px; font-weight: 600;
  padding: 13px 26px; border-radius: 7px;
  transition: background .2s, transform .15s, box-shadow .2s;
}
.btn-primary:hover {
  background: #2A7BFF; transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(26,107,255,.35);
}
.btn-ghost {
  display: inline-flex; align-items: center; gap: 6px;
  background: transparent; color: var(--white);
  font-family: var(--font); font-size: 15px; font-weight: 600;
  padding: 12px 26px; border-radius: 7px; border: 1px solid var(--border2);
  transition: border-color .2s, color .2s, transform .15s;
}
.btn-ghost:hover { border-color: var(--cyan); color: var(--cyan); transform: translateY(-2px); }
.btn-large { font-size: 17px; padding: 17px 36px; border-radius: 9px; }

/* ── Navbar ───────────────────────────────────────────────── */
.navbar { position:fixed; top:2px; left:0; right:0; z-index:100; background:rgba(5,16,31,.82); backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px); border-bottom:1px solid var(--border); transition:background .3s; }
.nav-inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 60px);
  height: 64px; display: flex; align-items: center; gap: 40px;
  width: 100%; box-sizing: border-box;
}
.nav-logo { display: flex; align-items: center; }
.nav-links { display: flex; gap: 28px; margin-left: auto; }
.nav-links a { font-size: 14px; font-weight: 500; color: rgba(255,255,255,.6); transition: color .2s; }
.nav-links a:hover { color: var(--white); }
.nav-cta { background:linear-gradient(135deg,var(--blue),var(--blue2)); color:#fff; padding:8px 18px; border-radius:50px; font-size:12px; font-weight:700; box-shadow:0 4px 14px rgba(26,107,255,.25); transition:all .25s; white-space:nowrap; }
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 8px 22px rgba(26,107,255,.4); }
.nav-toggle {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px; margin-left: auto;
}
.nav-toggle span {
  display: block; width: 22px; height: 2px;
  background: var(--white); border-radius: 2px;
  transition: transform .25s, opacity .25s;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-mobile {
  display: none; flex-direction: column; gap: 0;
  padding: 12px clamp(20px,5vw,60px) 20px;
  border-top: 1px solid var(--border);
  background: rgba(8,15,34,.97);
}
.nav-mobile.open { display: flex; }
.nav-mobile a {
  font-size: 15px; font-weight: 500; color: rgba(255,255,255,.7);
  padding: 12px 0; border-bottom: 1px solid var(--border);
  transition: color .2s;
}
.nav-mobile a:hover { color: var(--white); }
.nav-mobile a:last-child { border-bottom: none; }

/* ── Icons ────────────────────────────────────────────────── */
.ico{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:rgba(26,107,255,.08);border:1px solid rgba(26,107,255,.18);flex-shrink:0}
.ico svg{width:20px;height:20px;stroke:var(--blue);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ico.g{background:rgba(245,166,35,.08);border-color:rgba(245,166,35,.2)}
.ico.g svg{stroke:var(--accent)}
.ico.c{background:rgba(77,141,255,.08);border-color:rgba(77,141,255,.2)}
.ico.c svg{stroke:var(--cyan)}
.ico.o{background:rgba(245,166,35,.08);border-color:rgba(245,166,35,.2)}
.ico.o svg{stroke:var(--accent)}
.ico-lg{width:52px;height:52px;border-radius:14px}
.ico-lg svg{width:24px;height:24px}

/* ══════════════════════════════════════════════════════════
   HERO v13 — full port
   ══════════════════════════════════════════════════════════ */
.hero2 {
  position: relative;
  background: var(--bg);
  padding: 80px 80px 0;
  min-height: calc(100vh - 64px);
  margin-top: 64px;
  overflow: hidden;
  isolation: isolate;
}
.hero2-glow1,.hero2-glow2 {
  position:absolute; border-radius:50%; filter:blur(140px);
  pointer-events:none; z-index:0; opacity:.35;
}
.hero2-glow1 {
  top:-200px; left:-200px; width:700px; height:700px;
  background:radial-gradient(circle,rgba(44,82,204,.6) 0%,transparent 70%);
}
.hero2-glow2 {
  bottom:-200px; right:-200px; width:600px; height:600px;
  background:radial-gradient(circle,rgba(26,107,255,.4) 0%,transparent 70%);
}
.hero2-particles { position:absolute; inset:0; pointer-events:none; z-index:1; }
.hero2-breath {
  position:absolute; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(26,107,255,.16) 0%,transparent 65%);
  pointer-events:none; z-index:1;
  transform:translate(-50%,-50%); transition:opacity .4s ease;
  opacity:0; filter:blur(20px); mix-blend-mode:screen;
}
.hero2-rail-l,.hero2-rail-r {
  position:absolute; z-index:6;
  font-family:var(--mono); font-size:10px; color:rgba(255,255,255,.34);
  letter-spacing:.18em; text-transform:uppercase;
  writing-mode:vertical-rl; pointer-events:none;
}
.hero2-rail-l { left:18px; top:50%; transform:translateY(-50%) rotate(180deg); }
.hero2-rail-r { right:18px; top:50%; transform:translateY(-50%); }
.hero2-inner {
  position:relative; z-index:5;
  max-width:1280px; margin:0 auto;
  padding:48px 0 56px;
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:64px; align-items:stretch;
}
.hero2-copy { display:flex; flex-direction:column; justify-content:space-between; padding-top:24px; }
.hero2-eyebrow {
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:rgba(255,255,255,.34);
  display:flex; align-items:center; gap:12px; margin-bottom:48px;
}
.hero2-eyebrow::before { content:""; width:24px; height:1px; background:currentColor; }
.hero2-eyebrow-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 8px var(--accent);
  animation:hero2pulse 2.4s ease-in-out infinite; flex-shrink:0;
}
@keyframes hero2pulse { 0%,100%{opacity:.4} 50%{opacity:1} }
.hero2-headline {
  font-family:var(--font); font-weight:300;
  font-size:clamp(44px,5vw,82px); line-height:1.04;
  letter-spacing:-.035em; color:var(--white);
  margin:0 0 32px; max-width:18ch;
}
.hero2-headline strong { font-weight:700; color:var(--white); }
.hero2-headline em { font-style:normal; font-weight:300; color:rgba(255,255,255,.62); }
.hero2-accent { color:var(--blue); font-weight:500; font-style:normal; }
.hero2-lede {
  font-family:var(--font); font-size:17px; line-height:1.55;
  color:rgba(255,255,255,.72); font-weight:300;
  max-width:52ch; margin:0 0 44px;
}
.hero2-lede strong { font-weight:600; color:var(--white); }
.hero2-ctas { display:flex; gap:14px; align-items:center; margin-bottom:56px; flex-wrap:wrap; }
.hero2-btn {
  font-family:var(--font); font-size:13.5px; font-weight:500; letter-spacing:.01em;
  padding:14px 22px; border-radius:6px; text-decoration:none;
  display:inline-flex; align-items:center; gap:10px;
  transition:all .25s ease; border:1px solid transparent; cursor:pointer;
}
.hero2-btn-primary {
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue2) 100%);
  color:#fff; border-color:var(--blue);
  box-shadow:0 0 0 0 rgba(26,107,255,0);
}
.hero2-btn-primary:hover { box-shadow:0 0 30px rgba(26,107,255,.4); transform:translateY(-1px); }
.hero2-btn-ghost { background:transparent; color:var(--white); border-color:rgba(255,255,255,.18); }
.hero2-btn-ghost:hover { border-color:var(--blue); background:rgba(26,107,255,.06); }
.hero2-arrow { width:14px; height:14px; transition:transform .25s ease; }
.hero2-btn:hover .hero2-arrow { transform:translateX(3px); }
.hero2-proof {
  border-top:1px solid var(--border); padding-top:28px;
  display:grid; grid-template-columns:repeat(4,1fr); align-items:start; gap:20px;
}
.hero2-proof-it {
  display:flex; flex-direction:column; gap:6px;
  position:relative;
  padding-left:14px;
}
.hero2-proof-it::before {
  content:'';
  position:absolute;
  left:0; top:6px; bottom:6px;
  width:2px;
  background:linear-gradient(180deg, var(--cyan), transparent);
  border-radius:2px;
}
.hero2-proof-num {
  font-family:var(--mono);
  font-size:9.5px;
  font-weight:600;
  letter-spacing:1.8px;
  color:var(--cyan);
  line-height:1;
  margin-bottom:2px;
}
.hero2-proof-it strong {
  font-family:var(--font); font-size:26px; font-weight:700;
  line-height:1; letter-spacing:-.02em; color:var(--white);
}
.hero2-proof-it span:not(.hero2-proof-num) {
  font-family:var(--mono); font-size:10px; text-transform:uppercase;
  letter-spacing:.14em; color:var(--gray); white-space:nowrap;
}
.hero2-stage {
  position:relative; border-left:1px solid var(--border);
  padding-left:56px; display:flex; flex-direction:column; justify-content:space-between;
}
.hero2-atom-card {
  position:relative; flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; min-height:540px;
}
.hero2-corners { position:absolute; inset:0; pointer-events:none; }
.hero2-corners > span {
  position:absolute; width:14px; height:14px; border:0 solid rgba(255,255,255,.34);
}
.hero2-corners .tl { top:0; left:0; border-top-width:1px; border-left-width:1px; }
.hero2-corners .tr { top:0; right:0; border-top-width:1px; border-right-width:1px; }
.hero2-corners .bl { bottom:0; left:0; border-bottom-width:1px; border-left-width:1px; }
.hero2-corners .br { bottom:0; right:0; border-bottom-width:1px; border-right-width:1px; }
.hero2-meta-top {
  position:absolute; top:16px; left:24px; right:24px;
  display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:11px; color:rgba(255,255,255,.34); letter-spacing:.06em;
}
.hero2-atom-num { color:var(--blue); font-size:18px; font-weight:500; }
.hero2-meta-bot {
  position:absolute; bottom:16px; left:24px; right:24px;
  display:flex; justify-content:space-between; align-items:flex-end;
  font-family:var(--mono); font-size:11px; color:rgba(255,255,255,.34); letter-spacing:.04em;
}
.hero2-atom-name { font-family:var(--font); font-size:13px; color:rgba(255,255,255,.62); letter-spacing:.01em; }
.hero2-atom-mass { text-align:right; color:rgba(255,255,255,.62); }
.hero2-atom-mass .v { color:var(--white); }
.hero2-compounds {
  border-top:1px solid var(--border); padding-top:24px; margin-top:32px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border);
}
.hero2-comp {
  background:var(--bg); padding:18px 16px 20px;
  display:flex; flex-direction:column; gap:6px;
  cursor:default; transition:background .25s ease;
}
.hero2-comp:hover { background:rgba(26,107,255,.06); }
.hero2-comp-f { font-family:var(--font); font-weight:500; font-size:22px; letter-spacing:-.01em; color:var(--white); line-height:1; }
.hero2-comp-f sub { font-size:.65em; color:rgba(255,255,255,.62); font-weight:300; }
.hero2-comp-l { font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.12em; color:var(--blue); }
.hero2-comp-d { font-family:var(--font); font-size:12px; color:rgba(255,255,255,.62); line-height:1.4; font-weight:300; }
.hero2-manifesto {
  position:relative; z-index:5;
  border-top:1px solid var(--border); margin:0 -80px; padding:32px 80px;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font); font-weight:300; font-size:16px; color:rgba(255,255,255,.72);
  gap:32px; letter-spacing:-.005em; background:rgba(11,14,27,.6);
}
.hero2-manifesto em { font-style:normal; font-weight:600; color:var(--white); }
.hero2-manifesto-tag {
  font-family:var(--mono); font-style:normal; font-size:10px;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.34); flex-shrink:0;
}

/* Three.js hero mesh */
#hero2Mesh {
  position:absolute; top:0; left:0; right:0; bottom:56px; z-index:0; overflow:hidden;
}
#hero2Mesh canvas { display:block; width:100%!important; height:100%!important; }
.hero2-corners,.hero2-meta-top { z-index:2; position:absolute; }
.hero2-meta-bot { z-index:2; }

/* ══════════════════════════════════════════════════════════
   CASO DE ÉXITO — v13 port
   ══════════════════════════════════════════════════════════ */
.case-sec {
  background: var(--bg2);
  padding: 110px 0;
}
.case-sec .sec-inner { max-width:var(--max-w); padding:0 clamp(20px,5vw,60px); }
.case-wrap { display:grid; grid-template-columns:1fr 1.4fr; gap:48px; align-items:start; }
.case-side {
  background:linear-gradient(160deg,rgba(26,107,255,.06),rgba(245,166,35,.03));
  border:1px solid rgba(26,107,255,.2); border-radius:20px; padding:32px; position:sticky; top:90px;
}
.case-tag {
  font-family:var(--mono); font-size:10px; color:var(--blue);
  background:rgba(26,107,255,.1); border:1px solid rgba(26,107,255,.2);
  border-radius:4px; padding:4px 10px; display:inline-block; letter-spacing:1px; margin-bottom:14px;
}
.case-title { font-family:var(--font); font-size:28px; font-weight:800; letter-spacing:-.8px; margin-bottom:12px; }
.case-desc { font-family:var(--font); font-size:13px; font-weight:300; color:rgba(255,255,255,.62); line-height:1.75; margin-bottom:24px; }
.case-stats { display:grid; grid-template-columns:1fr; gap:10px; }
.case-stat { display:flex; align-items:baseline; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--border-soft); }
.case-stat:last-child { border-bottom:none; }
.case-stat-val { font-family:var(--font); font-size:26px; font-weight:800; letter-spacing:-.5px; }
.case-stat-lbl { font-family:var(--mono); font-size:10px; color:var(--gray); letter-spacing:.5px; text-transform:uppercase; }
.case-client-logo { height:40px; width:auto; object-fit:contain; margin-bottom:14px; }
.case-testimonial { margin-top:26px; padding:20px 22px; background:rgba(26,107,255,.05); border:1px solid rgba(26,107,255,.14); border-radius:14px; }
.case-testimonial-quote { font-family:var(--font); font-size:13px; font-weight:300; color:rgba(255,255,255,.72); line-height:1.75; margin-bottom:16px; font-style:italic; }
.case-testimonial-author { display:flex; align-items:center; gap:12px; }
.case-testimonial-avatar-logo { width:36px; height:36px; border-radius:50%; object-fit:contain; background:#fff; padding:5px; flex-shrink:0; }
.case-testimonial-name { font-family:var(--font); font-size:14px; font-weight:700; }
.case-testimonial-role { font-family:var(--mono); font-size:10px; color:var(--muted); letter-spacing:.5px; margin-top:3px; }
.case-blocks { display:flex; flex-direction:column; gap:18px; }
.case-block {
  position:relative;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:28px 30px;
  overflow:hidden;
  transition:transform .35s ease, border-color .35s ease, background .35s ease;
}
.case-block::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg,var(--blue),var(--cyan));
  opacity:.65;
  transition:opacity .35s ease;
}
.case-block[data-step="03"]::before {
  background:linear-gradient(90deg,var(--accent),var(--accent2));
}
.case-block:hover {
  transform:translateY(-3px);
  border-color:rgba(26,107,255,.32);
  background:rgba(13,27,62,.6);
}
.case-block:hover::before { opacity:1; }

.case-block-head {
  display:flex; align-items:flex-start; gap:16px; margin-bottom:14px;
}
.case-block-ico {
  width:42px; height:42px;
  border-radius:11px;
  background:rgba(26,107,255,.1);
  border:1px solid rgba(26,107,255,.22);
  display:flex; align-items:center; justify-content:center;
  color:var(--cyan);
  flex-shrink:0;
}
.case-block-ico svg { width:20px; height:20px; }
.case-block[data-step="03"] .case-block-ico {
  background:rgba(245,166,35,.1);
  border-color:rgba(245,166,35,.28);
  color:var(--accent);
}
.case-block-meta { flex:1; min-width:0; padding-top:2px; }
.case-block-num {
  font-family:var(--mono);
  font-size:10.5px;
  font-weight:600;
  letter-spacing:2px;
  color:var(--cyan);
  display:block;
  margin-bottom:8px;
}
.case-block[data-step="03"] .case-block-num { color:var(--accent); }
.case-block h3 {
  font-family:var(--font);
  font-size:19px;
  font-weight:700;
  margin:0;
  letter-spacing:-.02em;
  line-height:1.25;
  color:#fff;
  overflow-wrap:break-word;
}
.case-block p {
  font-family:var(--font);
  font-size:14px;
  font-weight:300;
  color:rgba(255,255,255,.62);
  line-height:1.7;
  margin:0;
  overflow-wrap:break-word;
}

.case-res-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:20px;
  padding-top:20px;
  border-top:1px solid var(--border-soft);
}
.case-res-item {
  background:rgba(245,166,35,.05);
  border:1px solid rgba(245,166,35,.18);
  border-radius:10px;
  padding:14px;
  text-align:center;
}
.case-res-val {
  font-family:var(--font);
  font-size:26px;
  font-weight:800;
  letter-spacing:-.5px;
  margin-bottom:4px;
  color:var(--accent);
  line-height:1;
}
.case-res-lbl {
  font-family:var(--mono);
  font-size:9px;
  color:var(--gray);
  letter-spacing:1px;
  text-transform:uppercase;
}

@media (max-width: 720px) {
  .case-block { padding:24px 22px; }
  .case-block-head { gap:12px; }
  .case-block-ico { width:38px; height:38px; }
  .case-res-grid { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════════════════════════
   NEW SECTIONS (quiénes somos → modelos de colaboración)
   ══════════════════════════════════════════════════════════ */
.section { padding: var(--pad) 0; }
.section-surface { background: var(--bg2); }
.section-header { margin-bottom: clamp(48px,6vw,72px); }
.section-title {
  font-size: clamp(32px,4.8vw,54px); font-weight: 800;
  line-height: 1.1; letter-spacing: -1.4px; max-width: 18em;
}
.section-sub { font-size: clamp(15px,1.3vw,17px); color: rgba(255,255,255,.68); line-height: 1.7; max-width: 580px; margin-top: 18px; }

/* About */
.about-body { display:grid; grid-template-columns:1.2fr 1fr; gap:64px; align-items:start; }
.about-text { position:sticky; top:90px; align-self:start; }
.about-text p { font-size:16px; line-height:1.8; color:rgba(255,255,255,.65); margin-bottom:18px; }
.about-text strong { color:var(--white); font-weight:600; }
.facts { display:flex; flex-direction:column; border:1px solid var(--border); border-radius:10px; overflow:hidden; }
.fact { padding:20px 24px; border-bottom:1px solid var(--border); }
.fact:last-child { border-bottom:none; }
.fact-label { font-family:var(--mono); font-size:9.5px; font-weight:600; letter-spacing:1.8px; text-transform:uppercase; color:var(--gray); margin-bottom:6px; }
.fact-val { font-size:14px; font-weight:600; color:var(--white); }

/* Origin pillars */
.origin-pillars{display:flex;flex-direction:column;gap:16px}
.origin-pillar{display:flex;gap:18px;align-items:flex-start;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:26px 28px;position:relative;overflow:hidden;transition:border-color .3s,background .3s,transform .3s}
.origin-pillar::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--cyan));opacity:.55;transition:opacity .3s}
.origin-pillar:hover{border-color:rgba(26,107,255,.32);background:rgba(13,27,62,.6);transform:translateY(-2px)}
.origin-pillar:hover::before{opacity:1}
.origin-pillar-num{position:absolute;top:20px;right:24px;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--cyan);letter-spacing:2px;background:rgba(26,107,255,.08);border:1px solid var(--border);border-radius:999px;padding:4px 10px;line-height:1}
.origin-pillar .ico{flex-shrink:0;margin-top:2px;width:36px;height:36px;border-radius:10px;background:rgba(26,107,255,.1);border:1px solid rgba(26,107,255,.22);display:flex;align-items:center;justify-content:center;color:var(--cyan)}
.origin-pillar .ico svg{width:18px;height:18px}
.origin-pillar-body{flex:1;min-width:0;padding-right:60px}
.origin-pillar-body h4{font-family:var(--font);font-size:17px;font-weight:700;margin:0 0 8px;letter-spacing:-.3px;color:#fff}
.origin-pillar-body p{font-family:var(--font);font-size:14px;font-weight:300;color:rgba(255,255,255,.62);line-height:1.7;margin:0}

/* Value pillars */
.pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.pillar {
  background:var(--bg); border:1px solid var(--border); border-radius:12px;
  padding:32px 28px; position:relative; overflow:hidden;
  transition:border-color .25s, transform .25s;
}
.pillar:hover { border-color:var(--border3); transform:translateY(-4px); }
.pillar-bar { position:absolute; top:0; left:0; right:0; height:2px; }
.pillar-bar-blue  { background:var(--blue); }
.pillar-bar-cyan  { background:var(--cyan); }
.pillar-bar-amber { background:var(--accent); }
.pillar h3 { font-size:17px; font-weight:700; margin-bottom:6px; margin-top:10px; }
.pillar-claim { font-size:13px; font-weight:600; color:var(--cyan); margin-bottom:14px; }
.pillar p { font-size:14px; color:rgba(255,255,255,.55); line-height:1.7; }

/* ── Value proposition v2 (3 pilares + workflow) ─────────── */
#valor .ey::before { content:''; width:24px; height:1px; background:var(--blue); display:inline-block; }
#valor .st em { background:linear-gradient(120deg,var(--blue) 10%,var(--blue2) 90%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ===== Value pillars (responsive-safe) ===== */
.val-pillars {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
  margin-bottom:96px;
}
.val-pill {
  position:relative;
  padding:clamp(24px,2.4vw,36px) clamp(20px,2vw,32px) clamp(22px,2.2vw,32px);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  min-width:0;
  display:flex;
  flex-direction:column;
  transition:transform .4s ease,border-color .4s ease;
}
.val-pill::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:var(--pill-grad,var(--blue));
}
.val-pill[data-pillar="01"]{ --pill-grad: linear-gradient(90deg,var(--blue),var(--cyan)); }
.val-pill[data-pillar="02"]{ --pill-grad: linear-gradient(90deg,var(--cyan),var(--blue)); }
.val-pill[data-pillar="03"]{ --pill-grad: linear-gradient(90deg,var(--accent),var(--accent2)); }
.val-pill:hover { transform:translateY(-4px); border-color:rgba(26,107,255,.32); }

.val-pill-num {
  font-family:var(--mono);
  font-size:clamp(10px,0.9vw,11px);
  color:var(--cyan);
  letter-spacing:1.6px;
  font-weight:600;
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
  word-break:break-word;
}
.val-pill[data-pillar="03"] .val-pill-num { color:var(--accent); }
.val-pill-dot {
  width:6px; height:6px;
  border-radius:50%;
  background:currentColor;
  box-shadow:0 0 8px currentColor;
  flex-shrink:0;
  animation:pillPulse 2.4s ease-in-out infinite;
}
@keyframes pillPulse {
  0%,100%{ opacity:.5; transform:scale(1); }
  50%{ opacity:1; transform:scale(1.3); }
}

.val-pill h3 {
  font-size:clamp(19px,1.7vw,22px);
  font-weight:700;
  line-height:1.25;
  letter-spacing:-0.02em;
  margin:0 0 10px;
  color:#fff;
  overflow-wrap:break-word;
  hyphens:auto;
}
.val-pill-claim {
  font-size:clamp(13px,1.1vw,14px);
  font-weight:500;
  color:var(--cyan);
  font-style:italic;
  margin:0 0 18px;
  line-height:1.5;
  overflow-wrap:break-word;
}
.val-pill[data-pillar="03"] .val-pill-claim { color:var(--accent); }
.val-pill-body {
  font-size:clamp(14px,1.15vw,15px);
  font-weight:300;
  line-height:1.7;
  color:rgba(255,255,255,.62);
  margin:0 0 24px;
  overflow-wrap:break-word;
  flex:1;
}
.val-pill-body strong { color:#fff; font-weight:600; }
.val-pill-foot {
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--border-soft);
  display:flex;
  align-items:flex-start;
  flex-wrap:nowrap;
  gap:10px;
  font-family:var(--mono);
  font-size:clamp(9.5px,0.8vw,10.5px);
  line-height:1.5;
  color:rgba(255,255,255,.62);
  letter-spacing:1px;
  text-transform:uppercase;
  overflow-wrap:break-word;
  word-break:break-word;
}
.val-pill-foot svg {
  width:14px; height:14px;
  color:var(--blue);
  flex-shrink:0;
  margin-top:1px;
}
.val-pill[data-pillar="03"] .val-pill-foot svg { color:var(--accent); }

/* Workflow */
.wf-wrap { padding:48px 36px 56px; background:linear-gradient(180deg,rgba(13,27,62,.55),rgba(13,27,62,.25)); border:1px solid var(--border); border-radius:24px; position:relative; overflow:hidden; opacity:0; transform:translateY(16px); transition:opacity .8s ease,transform .8s ease; }
.wf-wrap.in { opacity:1; transform:none; }
.wf-wrap::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 20% 30%,rgba(26,107,255,.08) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(77,141,255,.06) 0%,transparent 40%); pointer-events:none; }
.wf-head { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:24px; margin-bottom:48px; position:relative; z-index:1; }
.wf-head-left { flex:1; min-width:280px; }
.wf-head-title { font-size:clamp(22px,2.2vw,30px); font-weight:700; color:#fff; margin:8px 0 6px; letter-spacing:-0.02em; line-height:1.2; }
.wf-head-title em { font-style:normal; background:linear-gradient(120deg,var(--blue),var(--cyan)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.wf-head-sub { font-size:14px; color:rgba(255,255,255,.66); font-weight:300; line-height:1.6; margin:0; max-width:520px; }
.wf-head-status { display:flex; align-items:center; gap:10px; padding:8px 14px; background:rgba(52,199,120,.08); border:1px solid rgba(52,199,120,.2); border-radius:999px; font-family:var(--mono); font-size:10px; color:var(--success); letter-spacing:1.6px; text-transform:uppercase; font-weight:600; }
.wf-head-status-dot { width:6px; height:6px; border-radius:50%; background:var(--success); box-shadow:0 0 8px var(--success); animation:wfStatusPulse 1.6s ease-in-out infinite; }
@keyframes wfStatusPulse { 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.55; transform:scale(1.2); } }
.wf-pipeline { position:relative; margin-bottom:40px; padding:0 12px; }
.wf-track { position:absolute; top:32px; left:60px; right:60px; height:2px; background:rgba(26,107,255,.18); border-radius:2px; z-index:1; }
.wf-track-glow { position:absolute; top:0; left:0; height:100%; width:0; background:linear-gradient(90deg,var(--blue),var(--cyan),var(--blue)); background-size:200% 100%; border-radius:2px; box-shadow:0 0 14px rgba(26,107,255,.6); transition:width 2.4s cubic-bezier(.4,0,.2,1); animation:wfFlow 3s linear infinite; }
@keyframes wfFlow { 0%{ background-position:0% 50%; } 100%{ background-position:200% 50%; } }
.wf-particle { position:absolute; top:26px; left:60px; width:14px; height:14px; background:#fff; border-radius:50%; box-shadow:0 0 16px var(--cyan),0 0 32px rgba(26,107,255,.5); z-index:3; opacity:0; pointer-events:none; }
.wf-wrap.in .wf-particle { opacity:1; animation:wfParticle 5s cubic-bezier(.4,0,.2,1) infinite; }
@keyframes wfParticle { 0%{ left:60px; opacity:0; transform:scale(.5); } 8%{ opacity:1; transform:scale(1); } 92%{ opacity:1; transform:scale(1); } 100%{ left:calc(100% - 74px); opacity:0; transform:scale(.5); } }
.wf-nodes { display:grid; grid-template-columns:repeat(7,1fr); gap:0; position:relative; z-index:2; }
.wf-node { display:flex; flex-direction:column; align-items:center; text-align:center; padding:0 6px; }
.wf-node-marker { width:64px; height:64px; border-radius:50%; background:var(--bg); border:2px solid rgba(26,107,255,.2); display:flex; align-items:center; justify-content:center; margin-bottom:14px; position:relative; transition:all .5s cubic-bezier(.4,0,.2,1); }
.wf-node-marker svg { width:24px; height:24px; color:rgba(255,255,255,.45); transition:color .4s ease; }
.wf-node-marker::before { content:''; position:absolute; inset:-4px; border-radius:50%; background:radial-gradient(circle,var(--blue) 0%,transparent 70%); opacity:0; transition:opacity .5s ease; z-index:-1; }
.wf-node.active .wf-node-marker { border-color:var(--blue); background:var(--bg2); transform:scale(1.08); }
.wf-node.active .wf-node-marker svg { color:var(--cyan); }
.wf-node.active .wf-node-marker::before { opacity:.5; }
.wf-node-num { font-family:var(--mono); font-size:9px; color:var(--cyan); letter-spacing:1.8px; font-weight:600; margin-bottom:6px; }
.wf-node-label { font-size:13px; font-weight:600; color:#fff; line-height:1.3; margin-bottom:4px; letter-spacing:-0.005em; }
.wf-node-module { font-family:var(--mono); font-size:9.5px; color:rgba(255,255,255,.62); letter-spacing:1.2px; text-transform:uppercase; font-weight:500; }
.wf-node.active .wf-node-module { color:var(--cyan); }
.wf-node-kpi { margin-top:10px; padding:6px 10px; background:rgba(13,27,62,.6); border:1px solid var(--border-soft); border-radius:8px; font-family:var(--mono); font-size:11px; color:var(--accent); font-weight:700; letter-spacing:0.5px; min-width:64px; transition:all .4s ease; }
.wf-node.active .wf-node-kpi { border-color:rgba(245,166,35,.4); background:rgba(245,166,35,.05); transform:scale(1.04); }
.wf-lanes { margin-top:48px; padding-top:32px; border-top:1px solid var(--border-soft); position:relative; z-index:1; }
.wf-lanes-title { font-family:var(--mono); font-size:10px; color:rgba(255,255,255,.4); letter-spacing:2.4px; text-transform:uppercase; margin-bottom:18px; text-align:center; }
.wf-lane { display:grid; grid-template-columns:140px 1fr; align-items:center; gap:20px; margin-bottom:14px; padding:0 12px; }
.wf-lane:last-child { margin-bottom:0; }
.wf-lane-label { display:flex; align-items:center; gap:10px; font-size:13px; font-weight:600; color:#fff; letter-spacing:-0.005em; }
.wf-lane-icon { width:24px; height:24px; border-radius:6px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.wf-lane[data-lane="01"] .wf-lane-icon { background:rgba(26,107,255,.15); color:var(--cyan); }
.wf-lane[data-lane="02"] .wf-lane-icon { background:rgba(77,141,255,.15); color:var(--cyan); }
.wf-lane[data-lane="03"] .wf-lane-icon { background:rgba(245,166,35,.15); color:var(--accent); }
.wf-lane-icon svg { width:13px; height:13px; }
.wf-lane-track { position:relative; height:8px; background:rgba(26,107,255,.06); border-radius:4px; overflow:hidden; }
.wf-lane-fill { position:absolute; top:0; height:100%; border-radius:4px; width:0; transition:width 1.4s cubic-bezier(.4,0,.2,1); }
.wf-lane[data-lane="01"] .wf-lane-fill { left:0; background:linear-gradient(90deg,var(--blue),var(--cyan)); }
.wf-lane[data-lane="02"] .wf-lane-fill { background:linear-gradient(90deg,var(--cyan),var(--blue)); }
.wf-lane[data-lane="03"] .wf-lane-fill { background:linear-gradient(90deg,var(--accent),var(--accent2)); }
.wf-wrap.in .wf-lane[data-lane="01"] .wf-lane-fill { width:100%; left:0; }
.wf-wrap.in .wf-lane[data-lane="02"] .wf-lane-fill { width:50%; left:33%; }
.wf-wrap.in .wf-lane[data-lane="03"] .wf-lane-fill { width:50%; left:50%; }
.wf-lane-fill::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent); background-size:200% 100%; animation:wfShimmer 2.4s linear infinite; }
@keyframes wfShimmer { 0%{ background-position:-100% 0; } 100%{ background-position:200% 0; } }

@media (max-width:980px) {
  .val-pillars { gap:18px; margin-bottom:72px; }
  .wf-pipeline { overflow-x:auto; padding-bottom:8px; }
  .wf-nodes { min-width:910px; }
  .wf-track { min-width:790px; }
  .wf-lane { grid-template-columns:1fr; gap:8px; }
}
@media (max-width:720px) {
  .val-pillars { gap:14px; margin-bottom:56px; }
}
@media (max-width:640px) {
  .wf-wrap { padding:32px 20px 40px; }
  .wf-head { margin-bottom:32px; }
}

/* Modules */
.modules { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.module {
  background:var(--bg); border:1px solid var(--border); border-radius:10px;
  padding:26px 24px; transition:border-color .2s, background .2s, transform .2s;
}
.module:hover { border-color:var(--border2); background:rgba(17,31,74,.5); transform:translateY(-2px); }
.module-id {
  font-family:var(--mono); font-size:9.5px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; color:var(--cyan);
  padding:3px 9px; border-radius:4px; background:rgba(77,141,255,.10);
  display:inline-block; margin-bottom:12px;
}
.module h3 { font-size:15px; font-weight:700; margin-bottom:10px; }
.module p { font-size:13.5px; color:rgba(255,255,255,.55); line-height:1.65; }

/* Pipeline */
.pipeline {
  display:grid; grid-template-columns:repeat(6,1fr);
  background:var(--border); gap:1px;
  border:1px solid var(--border2); border-radius:12px; overflow:hidden;
}
.pipe-step { background:var(--bg2); padding:24px 20px; transition:background .2s; }
.pipe-step:hover { background:var(--bg3); }
.pipe-num { font-family:var(--mono); font-size:9px; font-weight:700; letter-spacing:2px; color:var(--gray); text-transform:uppercase; margin-bottom:6px; }
.pipe-mod { font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:1.5px; color:var(--cyan); text-transform:uppercase; padding:2px 7px; background:rgba(77,141,255,.10); border-radius:3px; display:inline-block; margin-bottom:10px; }
.pipe-phase { font-size:14px; font-weight:700; color:var(--white); margin-bottom:8px; }
.pipe-step > p { font-size:12px; color:rgba(255,255,255,.55); line-height:1.6; }

/* Milestones */
.milestones { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.milestone { background:var(--bg); border:1px solid var(--border); border-radius:12px; padding:28px 24px; transition:border-color .2s, transform .2s; }
.milestone:hover { border-color:var(--border2); transform:translateY(-3px); }
.milestone-id { font-family:var(--mono); font-size:9.5px; font-weight:600; letter-spacing:1.8px; text-transform:uppercase; color:var(--accent); margin-bottom:20px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.m-kpis { display:flex; gap:0; margin-bottom:20px; }
.m-kpi { flex:1; padding-right:16px; margin-right:16px; border-right:1px solid var(--border); }
.m-kpi:last-child { border-right:none; padding-right:0; margin-right:0; }
.m-val { font-family:var(--mono); font-size:clamp(18px,2vw,26px); font-weight:800; letter-spacing:-.5px; color:var(--white); line-height:1; margin-bottom:5px; }
.m-key { font-family:var(--mono); font-size:9px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--gray); }
.milestone > p { font-size:13px; color:rgba(255,255,255,.55); line-height:1.65; }

/* Collaboration */
.collab { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.collab-card { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:36px 32px; position:relative; overflow:hidden; transition:border-color .25s; }
.collab-card:hover { border-color:var(--border3); }
.collab-stripe { position:absolute; top:0; left:0; right:0; height:2px; }
.collab-stripe-cyan { background:linear-gradient(90deg,var(--cyan),var(--blue)); }
.collab-stripe-blue { background:var(--blue); }
.collab-num { font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:2px; color:var(--cyan); text-transform:uppercase; margin-bottom:12px; margin-top:6px; }
.collab-card h3 { font-size:20px; font-weight:800; margin-bottom:16px; }
.collab-for { font-size:13.5px; color:rgba(255,255,255,.6); line-height:1.6; margin-bottom:16px; padding:12px 14px; background:rgba(77,141,255,.05); border-radius:6px; border-left:2px solid var(--border2); }
.collab-card > p { font-size:14.5px; color:rgba(255,255,255,.6); line-height:1.7; margin-bottom:20px; }
.collab-card strong { color:var(--white); }
.collab-list { margin-bottom:24px; }
.collab-list li { font-size:14px; color:rgba(255,255,255,.6); padding:8px 0; padding-left:20px; position:relative; border-bottom:1px solid var(--border); }
.collab-list li:last-child { border-bottom:none; }
.collab-list li::before { content:'↳'; position:absolute; left:0; color:var(--cyan); font-size:12px; top:9px; }
.collab-quote { font-size:15px; font-weight:600; font-style:italic; color:var(--white); padding:14px 18px; border-left:3px solid var(--cyan); background:rgba(77,141,255,.05); border-radius:0 6px 6px 0; margin:0; }

/* ── Resultados medibles ─────────────────────────────────── */
.met-sec{background:var(--bg);padding:100px 0}
.met-sec .sec-inner{max-width:var(--max-w);padding:0 clamp(20px,5vw,60px)}
.met-top{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.met-card{background:linear-gradient(160deg,rgba(13,27,62,.6),rgba(8,15,34,.4));border:1px solid var(--border);border-radius:18px;padding:28px;position:relative;overflow:hidden}
.met-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}
.met-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px}
.met-title{font-family:var(--font);font-size:14px;font-weight:700;color:rgba(255,255,255,.85);letter-spacing:-.2px;margin-bottom:4px}
.met-sub{font-family:var(--mono);font-size:10px;color:var(--gray);letter-spacing:.3px}
.met-pill{font-family:var(--mono);font-size:10px;color:var(--blue);background:rgba(26,107,255,.08);border:1px solid rgba(26,107,255,.22);border-radius:4px;padding:3px 8px;letter-spacing:.5px}
.barchart{display:flex;flex-direction:column;gap:14px}
.bar-row{display:flex;align-items:center;gap:14px}
.bar-label{font-family:var(--mono);font-size:10px;color:var(--gray);letter-spacing:.3px;width:90px;flex-shrink:0;text-transform:uppercase}
.bar-track{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;display:flex;align-items:center;padding-left:12px;width:0;transition:width 1.4s cubic-bezier(.17,.67,.3,.98);position:relative}
.bar-fill::after{content:'';position:absolute;right:0;top:0;bottom:0;width:2px;background:rgba(255,255,255,.62);box-shadow:0 0 10px currentColor}
.bar-fill.b1{background:linear-gradient(90deg,rgba(245,166,35,.95),rgba(245,166,35,.45));color:var(--accent)}
.bar-fill.b2{background:linear-gradient(90deg,rgba(245,166,35,.75),rgba(245,166,35,.35));color:var(--accent)}
.bar-fill.b3{background:linear-gradient(90deg,rgba(44,82,204,.85),rgba(44,82,204,.45));color:var(--blue2)}
.bar-fill.b4{background:linear-gradient(90deg,rgba(26,107,255,.75),rgba(26,107,255,.35));color:var(--blue)}
.bar-fill.b5{background:linear-gradient(90deg,rgba(44,82,204,.75),rgba(44,82,204,.35));color:var(--blue2)}
.bar-num{font-family:var(--mono);font-size:12px;font-weight:600;width:44px;text-align:right;flex-shrink:0}
.bar-val{font-size:9px;color:rgba(255,255,255,.6)}
.line-card{grid-column:span 1}
.line-wrap{position:relative}
.line-svg{width:100%;height:220px;display:block}
.line-path{stroke-dasharray:1000;stroke-dashoffset:1000;transition:stroke-dashoffset 2s ease}
.line-path.drawn{stroke-dashoffset:0}
.line-x{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--gray);letter-spacing:.3px;margin-top:8px}
.met-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}
.met-kpi{background:linear-gradient(160deg,rgba(13,27,62,.8),rgba(8,15,34,.5));border:1px solid var(--border);border-radius:14px;padding:24px;position:relative;overflow:hidden;transition:all .3s}
.met-kpi:hover{border-color:rgba(26,107,255,.3);transform:translateY(-3px)}
.met-kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.met-kpi.m1::before,.met-kpi.m2::before,.met-kpi.m3::before,.met-kpi.m4::before{background:var(--accent)}
.met-kpi-val{font-family:var(--font);font-size:42px;font-weight:800;line-height:1;letter-spacing:-1.5px;margin-bottom:8px;color:var(--accent)}
.met-kpi-lbl{font-family:var(--font);font-size:12px;font-weight:300;color:rgba(255,255,255,.48);line-height:1.5;margin-bottom:14px}
.met-kpi-spark{height:30px;opacity:.7}

/* Donut chart */
.donut-wrap{display:flex;align-items:center;gap:28px}
.donut{position:relative;width:180px;height:180px;flex-shrink:0}
.donut svg{width:100%;height:100%;transform:rotate(-90deg)}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.donut-center-val{font-family:var(--font);font-size:34px;font-weight:800;line-height:1;letter-spacing:-1px;color:var(--accent)}
.donut-center-lbl{font-family:var(--mono);font-size:9px;color:var(--gray);letter-spacing:1px;text-transform:uppercase;margin-top:4px}
.donut-legend{flex:1;display:flex;flex-direction:column;gap:12px}
.donut-leg-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-soft)}
.donut-leg-row:last-child{border-bottom:none}
.donut-leg-l{display:flex;align-items:center;gap:10px}
.donut-leg-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.donut-leg-lbl{font-family:var(--font);font-size:12px;font-weight:600;color:rgba(255,255,255,.75)}
.donut-leg-val{font-family:var(--mono);font-size:11px;color:#fff;font-weight:500}
.donut-seg{transition:stroke-dasharray .8s ease,stroke-dashoffset .8s ease}

/* ── NeuronUs platform inline styles (nus-*) ─────────────── */
.nus-sec{
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg3) 50%,var(--bg) 100%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;
  isolation:isolate;
  padding-top:60px;
}
.nus-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.nus-grid{
  position:absolute;inset:-2px;
  background-image:
    linear-gradient(rgba(26,107,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(26,107,255,.05) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,#000 30%,transparent 75%);
}
.nus-glow1,.nus-glow2{position:absolute;border-radius:50%;filter:blur(120px);opacity:.32;pointer-events:none}
.nus-glow1{top:-160px;left:8%;width:520px;height:520px;background:radial-gradient(circle,var(--blue) 0%,transparent 70%)}
.nus-glow2{top:35%;right:5%;width:480px;height:480px;background:radial-gradient(circle,var(--cyan) 0%,transparent 70%);opacity:.18}
.nus-glow3{position:absolute;bottom:-100px;left:30%;width:560px;height:560px;border-radius:50%;filter:blur(140px);background:radial-gradient(circle,var(--accent) 0%,transparent 70%);opacity:.08;pointer-events:none}
.nus-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--blue);
  padding:8px 14px;border:1px solid var(--border);border-radius:999px;
  background:rgba(26,107,255,.06);margin-bottom:28px;
}
.nus-eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);box-shadow:0 0 8px var(--blue);animation:blink 2s infinite}
.nus-logo-row{display:flex;align-items:flex-end;gap:18px;margin-bottom:36px;flex-wrap:wrap}
.nus-logo-svg{
  font-family:var(--font);font-weight:800;
  font-size:54px;line-height:1;letter-spacing:-.04em;
  display:inline-flex;align-items:baseline;
}
.nus-logo-w{color:var(--white)}
.nus-logo-b{color:var(--blue)}
.nus-logo-r{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gray);padding-bottom:8px;letter-spacing:.1em}
.nus-h1{
  font-family:var(--font);font-weight:700;
  font-size:clamp(38px,5vw,64px);line-height:1.04;letter-spacing:-.015em;
  color:var(--white);margin:0 0 32px;
}
.nus-h1 em{
  font-style:normal;
  background:linear-gradient(120deg,var(--blue) 10%,var(--blue2) 90%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.nus-lead{font-family:var(--font);font-size:17px;line-height:1.7;color:rgba(255,255,255,.62);font-weight:300;margin:0 0 36px;max-width:560px}
.nus-lead strong{color:var(--white);font-weight:500}
.nus-quote{
  position:relative;padding:22px 26px 22px 30px;margin:0;
  border-left:2px solid var(--accent);
  background:linear-gradient(90deg,rgba(0,212,170,.07) 0%,rgba(0,212,170,0) 100%);
  border-radius:0 8px 8px 0;
}
.nus-quote-t{font-family:var(--font);font-size:18px;line-height:1.45;color:var(--white);font-weight:500;font-style:italic;margin:0 0 10px}
.nus-quote-s{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);letter-spacing:.12em;text-transform:uppercase}
.nus-hero-r{position:relative;display:flex;align-items:center;justify-content:center;min-height:520px}
.nus-atom{position:relative;width:100%;max-width:520px;aspect-ratio:1}
.nus-atom svg{width:100%;height:100%;display:block;overflow:visible}
@keyframes nusOrb1{from{transform:rotateZ(0deg)}to{transform:rotateZ(360deg)}}
@keyframes nusOrb2{from{transform:rotateZ(0deg)}to{transform:rotateZ(-360deg)}}
@keyframes nusPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}
.nus-atom-orb1{transform-origin:50% 50%;animation:nusOrb1 28s linear infinite}
.nus-atom-orb2{transform-origin:50% 50%;animation:nusOrb2 22s linear infinite}
.nus-atom-orb3{transform-origin:50% 50%;animation:nusOrb1 36s linear infinite}
.nus-atom-core{transform-origin:50% 50%;animation:nusPulse 3s ease-in-out infinite}
.nus-atom-label{
  position:absolute;font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);
  padding:6px 10px;background:rgba(5,16,31,.7);
  border:1px solid var(--border);border-radius:4px;
  backdrop-filter:blur(8px);
}
.nus-atom-l1{top:8%;left:0;color:var(--blue)}
.nus-atom-l2{top:42%;right:-4px;color:var(--accent)}
.nus-atom-l3{bottom:8%;left:6%;color:var(--cyan)}
.nus-atom-l4{bottom:24%;right:8%;color:var(--accent)}
.nus-atom-N{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:104px;height:104px;
  display:flex;align-items:center;justify-content:center;
  filter:drop-shadow(0 0 60px rgba(26,107,255,.6));
  pointer-events:none;
}
.nus-atom-N svg{width:100%;height:100%;display:block}
.nus-atom-N-sub{
  position:absolute;top:calc(50% + 130px);left:50%;transform:translateX(-50%);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--blue);white-space:nowrap;
}
.nus-pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:120px}
.nus-pillar{
  position:relative;padding:32px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.025) 0%,rgba(255,255,255,.005) 100%);
  border:1px solid var(--border);border-radius:16px;
  transition:all .3s ease;overflow:hidden;
}
.nus-pillar::before{
  content:"";position:absolute;top:0;left:0;width:3px;height:48px;
  background:linear-gradient(180deg,var(--blue),transparent);
  transition:height .3s ease;
}
.nus-pillar:hover{border-color:rgba(26,107,255,.32);transform:translateY(-4px);background:linear-gradient(180deg,rgba(26,107,255,.06) 0%,rgba(26,107,255,.01) 100%)}
.nus-pillar:hover::before{height:100%}
.nus-pillar-n{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--blue);letter-spacing:.16em;margin-bottom:18px;display:block}
.nus-pillar-h{font-family:var(--font);font-size:22px;font-weight:700;color:var(--white);line-height:1.15;margin:0 0 12px;letter-spacing:-.01em}
.nus-pillar-p{font-family:var(--font);font-size:13.5px;line-height:1.65;color:rgba(255,255,255,.55);font-weight:300;margin:0}
.nus-block{margin-bottom:120px}
.nus-block:last-of-type{margin-bottom:0}
.nus-head{margin-bottom:64px;max-width:760px}
.nus-head .ey{margin-bottom:14px}
.nus-head .st{margin-bottom:18px}
.nus-head .sd{margin-bottom:0}
.nus-caps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);
  border-radius:16px;overflow:hidden;
}
.nus-cap{
  position:relative;padding:36px 32px;background:var(--card);
  transition:background .3s ease;
}
.nus-cap:hover{background:#0D1B3E}
.nus-cap-ico{
  width:44px;height:44px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(26,107,255,.1);border:1px solid rgba(26,107,255,.2);
  margin-bottom:22px;
}
.nus-cap-ico svg{width:22px;height:22px;stroke:var(--blue);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nus-cap:nth-child(2) .nus-cap-ico{background:rgba(0,207,255,.1);border-color:rgba(0,207,255,.22)}
.nus-cap:nth-child(2) .nus-cap-ico svg{stroke:var(--cyan)}
.nus-cap:nth-child(2) .nus-cap-tag{color:var(--cyan)}
.nus-cap:nth-child(3) .nus-cap-ico{background:rgba(255,104,53,.1);border-color:rgba(255,104,53,.22)}
.nus-cap:nth-child(3) .nus-cap-ico svg{stroke:var(--accent2)}
.nus-cap:nth-child(3) .nus-cap-tag{color:var(--accent2)}
.nus-cap:nth-child(4) .nus-cap-ico{background:rgba(0,212,170,.1);border-color:rgba(0,212,170,.22)}
.nus-cap:nth-child(4) .nus-cap-ico svg{stroke:var(--accent)}
.nus-cap:nth-child(4) .nus-cap-tag{color:var(--accent)}
.nus-cap:nth-child(5) .nus-cap-ico{background:rgba(155,109,255,.1);border-color:rgba(155,109,255,.22)}
.nus-cap:nth-child(5) .nus-cap-ico svg{stroke:var(--purple)}
.nus-cap:nth-child(5) .nus-cap-tag{color:var(--purple)}
.nus-cap:nth-child(6) .nus-cap-ico{background:rgba(0,207,255,.1);border-color:rgba(0,207,255,.22)}
.nus-cap:nth-child(6) .nus-cap-ico svg{stroke:var(--cyan)}
.nus-cap:nth-child(6) .nus-cap-tag{color:var(--cyan)}
.nus-cap-tag{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--blue);letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px;display:block}
.nus-cap-h{font-family:var(--font);font-size:20px;font-weight:700;color:var(--white);line-height:1.2;margin:0 0 10px;letter-spacing:-.005em}
.nus-cap-p{font-family:var(--font);font-size:13.5px;line-height:1.65;color:rgba(255,255,255,.55);font-weight:300;margin:0 0 18px}
.nus-cap-meta{display:flex;flex-wrap:wrap;gap:6px}
.nus-cap-meta span{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--gray);letter-spacing:.06em;padding:4px 9px;background:rgba(26,107,255,.05);border:1px solid var(--border-soft);border-radius:4px}
.nus-builton{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;margin-bottom:36px;
}
.nus-builton-it{
  padding:18px 16px;background:var(--card);text-align:center;
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gray);
  transition:background .25s,color .25s;
}
.nus-builton-it:hover{background:#1A2D5A;color:var(--white)}
.nus-builton-it svg{width:14px;height:14px;flex-shrink:0;stroke:var(--blue);fill:none;stroke-width:1.6}
.nus-layers{display:flex;flex-direction:column;gap:12px;position:relative}
.nus-layers::before{display:none}
.nus-layer{
  position:relative;z-index:1;
  display:grid;grid-template-columns:84px 1fr;gap:0;
  background:linear-gradient(180deg,var(--card) 0%,var(--bg2) 100%);
  border:1px solid var(--border);border-radius:14px;overflow:hidden;
  transition:border-color .25s ease,transform .25s ease;
}
.nus-layer:hover{border-color:rgba(26,107,255,.35);transform:translateX(2px)}
.nus-layer-n{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px 12px;border-right:1px solid var(--border);
  background:rgba(26,107,255,.04);position:relative;
}
.nus-layer-n-num{font-family:'JetBrains Mono',monospace;font-size:24px;font-weight:500;color:var(--blue);line-height:1;letter-spacing:-.02em}
.nus-layer-n-dot{width:8px;height:8px;border-radius:50%;margin-top:10px;background:var(--blue);box-shadow:0 0 12px currentColor}
.nus-layer.l-blue .nus-layer-n-num{color:var(--blue)}
.nus-layer.l-blue .nus-layer-n-dot{background:var(--blue);color:var(--blue)}
.nus-layer.l-red .nus-layer-n-num{color:var(--accent2)}
.nus-layer.l-red .nus-layer-n-dot{background:var(--accent2);color:var(--accent2)}
.nus-layer.l-red:hover{border-color:rgba(255,104,53,.35)}
.nus-layer.l-orange .nus-layer-n-num{color:#F5A623}
.nus-layer.l-orange .nus-layer-n-dot{background:#F5A623;color:#F5A623}
.nus-layer.l-cyan .nus-layer-n-num{color:var(--cyan)}
.nus-layer.l-cyan .nus-layer-n-dot{background:var(--cyan);color:var(--cyan)}
.nus-layer.l-cyan:hover{border-color:rgba(0,207,255,.35)}
.nus-layer.l-mint .nus-layer-n-num{color:var(--accent)}
.nus-layer.l-mint .nus-layer-n-dot{background:var(--accent);color:var(--accent)}
.nus-layer.l-mint:hover{border-color:rgba(0,212,170,.35)}
.nus-layer-body{padding:22px 28px;display:grid;grid-template-columns:240px 1fr 180px;gap:24px;align-items:center}
.nus-layer-title{font-family:var(--font);font-size:17px;font-weight:700;color:var(--white);line-height:1.2;letter-spacing:-.01em;margin:0 0 6px}
.nus-layer-sub{font-family:var(--font);font-size:13px;color:rgba(255,255,255,.55);font-weight:300;line-height:1.4;margin:0}
.nus-layer-comps{display:flex;flex-wrap:wrap;gap:6px}
.nus-layer-comps span{font-family:'JetBrains Mono',monospace;font-size:10px;padding:4px 10px;border-radius:4px;background:rgba(26,107,255,.06);border:1px solid var(--border);color:rgba(255,255,255,.7);letter-spacing:.04em}
.nus-layer-tech{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--gray);text-align:right;letter-spacing:.06em;border-left:1px solid var(--border);padding-left:20px;display:flex;flex-direction:column;gap:4px}
.nus-layer-tech strong{color:var(--white);font-weight:500}
.nus-arch-toggle{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin:32px auto 0;padding:14px 22px;
  background:transparent;border:1px solid var(--border);border-radius:8px;
  color:rgba(255,255,255,.7);font-family:var(--font);font-size:13px;font-weight:500;
  cursor:pointer;transition:all .25s ease;
}
.nus-arch-toggle:hover{border-color:var(--blue);color:var(--white);background:rgba(26,107,255,.06)}
.nus-arch-toggle svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8;transition:transform .3s ease}
.nus-arch-toggle.open svg{transform:rotate(180deg)}
.nus-arch-img{max-height:0;overflow:hidden;transition:max-height .5s ease,margin-top .5s ease;margin-top:0}
.nus-arch-img.open{max-height:2400px;margin-top:24px}
.nus-arch-img-wrap{position:relative;border-radius:14px;overflow:hidden;background:#000;border:1px solid var(--border)}
.nus-arch-img-wrap img{width:100%;height:auto;display:block}
.nus-techstack-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:40px}
.nus-techstack-head .ey{margin-bottom:14px}
.nus-techstack-head .st{font-size:clamp(26px,3vw,38px);margin-bottom:0}
.nus-agnostic{font-family:var(--font);font-size:14px;line-height:1.65;color:rgba(255,255,255,.65);font-weight:300;padding-left:24px;border-left:2px solid var(--blue)}
.nus-agnostic strong{color:var(--white);font-weight:500}
.nus-tech-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.nus-tech-cat{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:18px;transition:border-color .25s ease}
.nus-tech-cat:hover{border-color:rgba(26,107,255,.3)}
.nus-tech-cat-h{display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);padding-bottom:14px;border-bottom:1px solid var(--border-soft)}
.nus-tech-cat-dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}
.nus-tech-cat.c-cyan .nus-tech-cat-h{color:var(--cyan)}
.nus-tech-cat.c-mint .nus-tech-cat-h{color:var(--accent)}
.nus-tech-cat.c-orange .nus-tech-cat-h{color:var(--accent2)}
.nus-tech-cat.c-purple .nus-tech-cat-h{color:var(--purple)}
.nus-tech-items{display:flex;flex-direction:column;gap:10px}
.nus-tech-item{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:6px;transition:background .2s ease}
.nus-tech-item:hover{background:rgba(26,107,255,.05)}
.nus-tech-item-logo{width:30px;height:30px;flex-shrink:0;border-radius:6px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;border:1px solid var(--border-soft);font-family:var(--font);font-weight:700;font-size:11px;color:var(--blue);letter-spacing:-.02em}
.nus-tech-item-logo svg{width:18px;height:18px}
.nus-tech-item-logo.mono{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:.02em}
.nus-tech-item-logo.mono-sm{font-size:9px;letter-spacing:.04em}
.nus-tech-item-logo.mono-xs{font-size:8px;letter-spacing:.04em}
.nus-tech-item-name{font-family:var(--font);font-size:13.5px;color:var(--white);font-weight:500;letter-spacing:-.005em}
.nus-tech-item-role{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--gray);margin-left:auto;letter-spacing:.04em}
.nus-agnostic-block{
  margin-top:32px;padding:32px;
  background:radial-gradient(ellipse at right,rgba(26,107,255,.08) 0%,transparent 60%),linear-gradient(180deg,var(--bg3) 0%,var(--bg2) 100%);
  border:1px solid var(--border);border-radius:16px;
  display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:center;
}
.nus-agnostic-block-l h4{font-family:var(--font);font-size:22px;font-weight:700;color:var(--white);margin:0 0 12px;letter-spacing:-.01em;line-height:1.2}
.nus-agnostic-block-l h4 em{font-style:normal;background:linear-gradient(120deg,var(--blue) 10%,var(--blue2) 90%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nus-agnostic-block-l p{font-family:var(--font);font-size:14px;line-height:1.65;color:rgba(255,255,255,.6);font-weight:300;margin:0;max-width:560px}
.nus-agnostic-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.nus-agnostic-pills span{font-family:'JetBrains Mono',monospace;font-size:10px;padding:5px 11px;border-radius:999px;background:rgba(26,107,255,.08);border:1px solid rgba(26,107,255,.22);color:var(--blue);letter-spacing:.06em}
.nus-agnostic-block-r{display:flex;align-items:center;justify-content:center}
.nus-connector{position:relative;width:100%;aspect-ratio:1;max-width:300px}
.nus-connector svg{width:100%;height:100%;display:block}
.nus-vs{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.nus-vs-card{
  position:relative;padding:36px 32px;border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.025) 0%,rgba(255,255,255,.005) 100%);
  border:1px solid var(--border);
  transition:all .3s ease;
}
.nus-vs-card:hover{border-color:rgba(26,107,255,.3);transform:translateY(-3px)}
.nus-vs-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent2);margin-bottom:16px;display:block}
.nus-vs-card.b .nus-vs-tag{color:var(--purple)}
.nus-vs-card.c .nus-vs-tag{color:var(--gray)}
.nus-vs-h{font-family:var(--font);font-size:20px;font-weight:700;color:var(--white);line-height:1.2;margin:0 0 14px}
.nus-vs-p{font-family:var(--font);font-size:13.5px;line-height:1.7;color:rgba(255,255,255,.55);font-weight:300;margin:0 0 22px}
.nus-vs-list{list-style:none;padding:0;margin:0}
.nus-vs-list li{
  font-family:var(--font);font-size:13px;color:rgba(255,255,255,.7);
  padding:10px 0 10px 20px;position:relative;line-height:1.45;font-weight:400;
  border-top:1px solid var(--border-soft);
}
.nus-vs-list li:first-child{border-top:none}
.nus-vs-list li::before{
  content:"";position:absolute;left:0;top:18px;
  width:8px;height:1px;background:var(--blue);
}
.nus-vs-list li:first-child::before{top:8px}
.nus-roi{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.nus-roi-card{
  position:relative;padding:36px 32px;border-radius:16px;
  background:linear-gradient(180deg,var(--card) 0%,var(--bg2) 100%);
  border:1px solid var(--border);overflow:hidden;
}
.nus-roi-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--blue),transparent);
}
.nus-roi-time{
  display:inline-block;padding:5px 12px;border-radius:4px;
  background:rgba(26,107,255,.1);border:1px solid rgba(26,107,255,.25);
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--blue);
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;
}
.nus-roi-h{font-family:var(--font);font-size:18px;font-weight:600;color:var(--white);line-height:1.2;margin:0 0 22px}
.nus-roi-list{list-style:none;padding:0;margin:0}
.nus-roi-list li{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:14px 0;border-top:1px solid var(--border-soft);
  font-family:var(--font);
}
.nus-roi-list li:first-child{border-top:none}
.nus-roi-lbl{font-size:13px;color:rgba(255,255,255,.55);font-weight:400}
.nus-roi-val{font-family:'JetBrains Mono',monospace;font-size:15px;font-weight:500;color:var(--blue);letter-spacing:-.01em}
.nus-roi-card.b .nus-roi-val{color:var(--cyan)}
.nus-roi-card.b::before{background:linear-gradient(90deg,var(--cyan),transparent)}
.nus-roi-card.c .nus-roi-val{color:var(--accent)}
.nus-roi-card.c::before{background:linear-gradient(90deg,var(--accent),transparent)}
.nus-cta{
  position:relative;padding:64px 56px;border-radius:20px;text-align:center;
  background:
    radial-gradient(ellipse at top,rgba(0,207,255,.14) 0%,transparent 60%),
    linear-gradient(180deg,var(--bg3) 0%,var(--bg2) 100%);
  border:1px solid var(--border);overflow:hidden;
}
.nus-cta::before{
  content:"";position:absolute;top:0;left:50%;width:60%;height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
}
.nus-cta-tag{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--cyan);letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;display:block}
.nus-cta-h{font-family:var(--font);font-size:clamp(28px,3.2vw,42px);font-weight:800;color:var(--white);line-height:1.12;margin:0 auto 16px;letter-spacing:-.02em;max-width:780px}
.nus-cta-h em{font-style:normal;background:linear-gradient(120deg,var(--blue) 10%,var(--blue2) 90%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nus-cta-p{font-family:var(--font);font-size:16px;line-height:1.7;color:rgba(255,255,255,.6);font-weight:300;margin:0 auto 36px;max-width:600px}
.nus-cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.nus-layers-spine{
  position:absolute;left:42px;top:24px;width:1px;height:0;
  background:linear-gradient(180deg,
    var(--blue) 0%, var(--cyan) 18%, var(--accent2) 36%,
    var(--blue) 54%, var(--accent2) 72%, var(--blue) 86%, var(--accent) 100%);
  z-index:1;
  transition:height .6s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 0 12px rgba(26,107,255,.4);
  pointer-events:none;
}
.nus-layer{
  opacity:0;transform:translateY(28px);
  transition:opacity .65s cubic-bezier(.2,.7,.2,1),
             transform .65s cubic-bezier(.2,.7,.2,1),
             border-color .25s ease;
}
.nus-layer.in{opacity:1;transform:translateY(0)}
.nus-spine-pulse{
  position:absolute;left:39px;top:24px;width:7px;height:7px;border-radius:50%;
  background:var(--blue);
  box-shadow:0 0 14px var(--blue),0 0 28px rgba(26,107,255,.5);
  z-index:3;opacity:0;pointer-events:none;
  animation:nusPulseDown 5.5s linear infinite;
  animation-delay:1.4s;
}
.nus-spine-pulse.p2{
  background:var(--blue2);
  box-shadow:0 0 14px var(--blue2),0 0 28px rgba(44,82,204,.5);
  animation-delay:3.8s;
}
.nus-layers.all-revealed .nus-spine-pulse{opacity:1}
@keyframes nusPulseDown{
  0%   {top:24px;opacity:0}
  6%   {opacity:1}
  92%  {opacity:1}
  100% {top:calc(100% - 24px);opacity:0}
}
.btnp{background:linear-gradient(135deg,var(--blue),var(--blue2));border:none;border-radius:11px;padding:15px 28px;color:#fff;font-family:var(--font);font-size:14px;font-weight:800;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all .3s;cursor:pointer}
.btnp:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(26,107,255,.35)}
.btng{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.14);border-radius:11px;padding:15px 28px;color:rgba(255,255,255,.85);font-family:var(--font);font-size:14px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all .3s;cursor:pointer}
.btng:hover{border-color:var(--blue);color:#fff;background:rgba(26,107,255,.06)}

/* ── Work section ─────────────────────────────────────────── */
.work-sec{background:var(--bg);padding:100px 0}
.work-sec .sec-inner{max-width:var(--max-w);padding:0 clamp(20px,5vw,60px)}
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.work-perks{display:flex;flex-direction:column;gap:18px;margin-top:32px}
.work-perk{display:flex;gap:18px;align-items:flex-start;padding:18px;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:14px;transition:all .3s}
.work-perk:hover{border-color:rgba(245,166,35,.3);background:rgba(245,166,35,.025);transform:translateX(4px)}
.work-perk-text h4{font-family:var(--font);font-size:15px;font-weight:800;margin-bottom:4px;letter-spacing:-.2px}
.work-perk-text p{font-family:var(--font);font-size:13px;font-weight:300;color:rgba(255,255,255,.48);line-height:1.7}
.work-right{background:linear-gradient(160deg,rgba(13,27,62,.8),rgba(8,15,34,.5));border:1px solid var(--border);border-radius:20px;padding:36px;position:relative;overflow:hidden}
.work-right::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--accent))}
.work-positions{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.work-pos{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .3s;text-decoration:none;color:inherit;width:100%;text-align:left;font-family:inherit;font-size:inherit}
button.work-pos{font:inherit;outline:none}
button.work-pos:focus-visible{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,107,255,.18)}
.work-pos:hover{background:rgba(26,107,255,.06);border-color:var(--blue);transform:translateX(4px)}
.work-pos-l h5{font-family:var(--font);font-size:14px;font-weight:700;margin-bottom:4px;color:#fff}
.work-pos-meta{display:flex;gap:10px;font-family:var(--mono);font-size:10px;color:var(--gray);letter-spacing:.3px}
.work-pos-meta span{display:flex;align-items:center;gap:4px}
.work-pos-arrow{width:28px;height:28px;border-radius:7px;background:rgba(26,107,255,.1);display:flex;align-items:center;justify-content:center;transition:all .3s}
.work-pos:hover .work-pos-arrow{background:var(--blue);transform:translateX(4px)}
.work-pos-arrow svg{width:13px;height:13px;stroke:var(--blue);fill:none;stroke-width:2}
.work-pos:hover .work-pos-arrow svg{stroke:#fff}

/* ── Demo section ─────────────────────────────────────────── */
.demo-sec{background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);padding:100px 0;position:relative;overflow:hidden}
.demo-sec .sec-inner{max-width:var(--max-w);padding:0 clamp(20px,5vw,60px)}
.demo-sec::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:1200px;height:600px;background:radial-gradient(ellipse at center,rgba(26,107,255,.08) 0%,transparent 60%);pointer-events:none}
.demo-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start;position:relative;z-index:2}
.demo-left{position:sticky;top:100px}
.demo-reasons{display:flex;flex-direction:column;gap:14px;margin-top:32px}
.demo-reason{display:flex;gap:14px;align-items:flex-start}
.demo-reason-icon{width:36px;height:36px;border-radius:10px;background:rgba(245,166,35,.08);border:1px solid rgba(245,166,35,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.demo-reason-icon svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:2}
.demo-reason-text h4{font-family:var(--font);font-size:14px;font-weight:700;margin-bottom:3px}
.demo-reason-text p{font-family:var(--font);font-size:12px;font-weight:300;color:rgba(255,255,255,.45);line-height:1.65}
.demo-form{background:linear-gradient(160deg,rgba(13,27,62,.95),rgba(8,15,34,.8));border:1px solid var(--border);border-radius:20px;padding:36px;backdrop-filter:blur(20px);box-shadow:0 30px 60px rgba(0,0,0,.4);position:relative;overflow:hidden}
.demo-form::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--blue),transparent)}
.demo-form-title{font-family:var(--font);font-size:20px;font-weight:800;margin-bottom:6px;letter-spacing:-.3px}
.demo-form-sub{font-family:var(--font);font-size:13px;font-weight:300;color:rgba(255,255,255,.45);line-height:1.6;margin-bottom:26px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field.full{grid-column:span 2}
.form-field label{font-family:var(--mono);font-size:10px;color:var(--gray);letter-spacing:.8px;text-transform:uppercase}
.form-field .req{color:var(--accent)}
.form-field input,.form-field select,.form-field textarea{background:rgba(255,255,255,.04);border:1px solid rgba(26,107,255,.18);border-radius:10px;padding:12px 14px;color:#fff;font-family:var(--font);font-size:14px;outline:none;transition:all .25s;resize:vertical}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--blue);background:rgba(26,107,255,.06);box-shadow:0 0 0 3px rgba(26,107,255,.1)}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,.18)}
.form-field select{color:rgba(255,255,255,.7);cursor:pointer;-webkit-appearance:none;appearance:none}
.form-field select option{background:var(--bg2);color:#fff}
.form-field textarea{min-height:100px}
.form-checkbox{display:flex;gap:12px;align-items:flex-start;margin-bottom:24px}
.form-checkbox input{width:16px;height:16px;flex-shrink:0;margin-top:2px;accent-color:var(--blue);cursor:pointer}
.form-checkbox label{font-family:var(--font);font-size:12px;color:rgba(255,255,255,.45);line-height:1.65;cursor:pointer}
.form-checkbox label a{color:var(--blue);text-decoration:underline}
.form-submit{width:100%;background:linear-gradient(135deg,var(--blue),var(--blue2));border:none;border-radius:12px;padding:15px;color:#fff;font-family:var(--font);font-size:15px;font-weight:800;cursor:pointer;transition:all .3s;letter-spacing:.2px}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(26,107,255,.32)}
.form-success{display:none;text-align:center;padding:40px 20px}
.form-success.show{display:block}
.form-success-icon{width:64px;height:64px;border-radius:50%;background:rgba(52,199,120,.1);border:1px solid rgba(52,199,120,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.form-success-icon svg{width:28px;height:28px;stroke:var(--success);fill:none;stroke-width:2.5}
.form-success h4{font-family:var(--font);font-size:20px;font-weight:800;margin-bottom:10px}
.form-success p{font-family:var(--font);font-size:14px;color:rgba(255,255,255,.55);line-height:1.7}

/* ── CTA final (kept for backward compat) ───────────────────── */
.cta-section { padding:var(--pad) 0; background:var(--bg2); position:relative; overflow:hidden; }
.cta-glow { position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(26,107,255,.12) 0%,transparent 70%); }
.cta-inner { position:relative; z-index:1; max-width:720px; margin:0 auto; text-align:center; padding:0 clamp(20px,5vw,60px); }
.cta-headline { font-size:clamp(28px,4vw,44px); font-weight:800; letter-spacing:-1px; line-height:1.15; margin-bottom:20px; }
.cta-lede { font-size:17px; color:rgba(255,255,255,.6); line-height:1.7; margin-bottom:36px; }
.cta-inner .section-tag { justify-content:center; }

/* ── Footer ────────────────────────────────────────────────── */
footer { background:var(--bg); border-top:1px solid var(--border-soft); padding:64px 0 32px; }
.foot-grid{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding:0 clamp(20px,5vw,60px) 40px;border-bottom:1px solid var(--border-soft)}
.foot-brand p{font-family:var(--font);font-size:13px;font-weight:300;color:rgba(255,255,255,.62);line-height:1.75;margin-top:16px;max-width:300px}
.foot-col h5{font-family:var(--mono);font-size:10px;color:var(--gray);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:16px}
.foot-col ul{display:flex;flex-direction:column;gap:10px}
.foot-col li a{font-family:var(--font);font-size:13px;color:rgba(255,255,255,.45);transition:color .2s}
.foot-col li a:hover{color:#fff}
.foot-bottom{max-width:var(--max-w);margin:0 auto;padding:28px clamp(20px,5vw,60px) 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.foot-cp{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.28);letter-spacing:.3px}
.foot-sec{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.28);letter-spacing:.3px;display:flex;align-items:center;gap:6px}
.foot-clients-link{color:var(--blue) !important;font-weight:600 !important}
.foot-clients-link:hover{color:#fff !important}

/* Old footer styles kept for backward compat */
.footer { padding:48px 0; border-top:1px solid var(--border); }
.footer-inner { display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.footer-meta { font-size:13px; color:rgba(255,255,255,.62); margin-bottom:4px; margin-top:8px; }
.footer-copy { font-size:12px; color:var(--gray); }
.footer-links { display:flex; gap:24px; flex-wrap:wrap; }
.footer-links a { font-size:13px; color:var(--gray); transition:color .2s; }
.footer-links a:hover { color:var(--cyan); }
.footer-logo-link { text-decoration:none; display:inline-block; }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width:1260px) {
  .nus-vs{grid-template-columns:1fr 1fr}
  .nus-roi{grid-template-columns:1fr 1fr}
}
@media (max-width:1100px) {
  .hero2 { padding:48px 32px 0; }
  .hero2-inner { grid-template-columns:1fr; gap:48px; padding:32px 0 48px; }
  .hero2-stage { border-left:none; padding-left:0; border-top:1px solid var(--border); padding-top:48px; }
  .hero2-rail-l,.hero2-rail-r { display:none; }
  .hero2-atom-card { min-height:420px; }
  .hero2-manifesto { margin:0 -32px; padding:24px 32px; flex-direction:column; align-items:flex-start; gap:12px; font-size:14px; }
  .case-sec { padding:80px 0; }
  .case-wrap { grid-template-columns:1fr; }
  .case-side { position:static; }
  .pipeline { grid-template-columns:repeat(3,1fr); }
  .nus-pillars{grid-template-columns:repeat(2,1fr)}
  .nus-caps{grid-template-columns:repeat(2,1fr)}
  .nus-vs{grid-template-columns:1fr}
  .nus-roi{grid-template-columns:1fr}
  .nus-builton{grid-template-columns:repeat(3,1fr)}
  .nus-layer-body{grid-template-columns:1fr;gap:14px}
  .nus-layer-tech{border-left:none;border-top:1px solid var(--border);padding:14px 0 0;text-align:left}
  .nus-techstack-head{grid-template-columns:1fr;gap:24px}
  .nus-tech-cats{grid-template-columns:repeat(2,1fr)}
  .nus-agnostic-block{grid-template-columns:1fr;gap:28px}
  .nus-agnostic-block-r{order:-1}
  .nus-connector{max-width:180px}
}
@media (max-width:960px) {
  .about-body { grid-template-columns:1fr; gap:40px; }
  .about-text { position:static; }
  .pillars { grid-template-columns:1fr; }
  .modules { grid-template-columns:repeat(2,1fr); }
  .pipeline { grid-template-columns:repeat(2,1fr); }
  .milestones { grid-template-columns:1fr; }
  .collab { grid-template-columns:1fr; }
  .met-top{grid-template-columns:1fr}
  .met-kpis{grid-template-columns:repeat(2,1fr)}
  .work-grid{grid-template-columns:1fr;gap:40px}
  .demo-wrap{grid-template-columns:1fr}
  .demo-left{position:static}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:768px) {
  .nav-links, .nav-cta { display:none; }
  .nav-toggle { display:flex; }
}
@media (min-width:769px) {
  .nav-toggle { display:none; }
  .nav-mobile { display:none !important; }
}
@media (max-width:680px) {
  .nus-block{margin-bottom:80px}
  .nus-pillars{grid-template-columns:1fr;gap:14px;margin-bottom:80px}
  .nus-caps{grid-template-columns:1fr}
  .nus-cta{padding:44px 24px}
  .nus-builton{grid-template-columns:1fr 1fr}
  .nus-builton-it{padding:14px 12px;font-size:9px;letter-spacing:.12em}
  .nus-layer{grid-template-columns:64px 1fr}
  .nus-layer-n{padding:18px 8px}
  .nus-layer-n-num{font-size:18px}
  .nus-layer-body{padding:18px 18px}
  .nus-layer-title{font-size:15px}
  .nus-layer-sub{font-size:12px}
  .nus-tech-cats{grid-template-columns:1fr}
  .nus-agnostic-block{padding:24px 18px}
  .nus-agnostic-block-l h4{font-size:18px}
}
@media (max-width:640px) {
  .modules { grid-template-columns:1fr; }
  .pipeline { grid-template-columns:1fr; }
  .hero2-proof { grid-template-columns:repeat(2,1fr); }
  .hero2-compounds { grid-template-columns:repeat(2,1fr); }
  .met-kpis{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .form-field.full{grid-column:span 1}
  .foot-grid{grid-template-columns:1fr}
}
@media (max-width:560px) {
  .nus-layers-spine{left:32px}
  .nus-spine-pulse{left:29px}
}
@media (max-width:480px) {
  .donut-wrap { flex-direction:column; align-items:flex-start; gap:20px; }
  .donut { width:160px; height:160px; }
}
@media (prefers-reduced-motion:reduce){
  .nus-layer{opacity:1;transform:none}
  .nus-spine-pulse{display:none}
  .nus-layers-spine{transition:none}
}

/* ═══════════════════════════════════════════════════════════
   FAQs Section
   ═══════════════════════════════════════════════════════════ */
.faq-sec {
  padding: var(--pad) 0;
  background: var(--bg2);
  position: relative;
  overflow: hidden;
}
.faq-sec .sec-head { margin-bottom: 64px; }

.faq-wrap {
  max-width: 880px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}

.faq-item {
  border-top: 1px solid var(--border-soft);
  transition: border-color .3s ease;
}
.faq-item:last-of-type { border-bottom: 1px solid var(--border-soft); }
.faq-item[open] { border-top-color: var(--blue); }

.faq-q {
  list-style: none;
  cursor: pointer;
  padding: 22px 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 28px;
  font-family: var(--font);
  font-size: clamp(14px, 1.05vw, 16px);
  font-weight: 600;
  line-height: 1.45;
  color: #fff;
  letter-spacing: -0.005em;
  transition: color .25s ease;
  user-select: none;
}
.faq-q::-webkit-details-marker { display: none; }
.faq-q:hover { color: var(--cyan); }
.faq-q:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 4px;
  border-radius: 4px;
  color: var(--cyan);
}
.faq-item[open] .faq-q { color: var(--cyan); }

.faq-q-num {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  color: var(--cyan);
  letter-spacing: 1.8px;
  margin-right: 16px;
  flex-shrink: 0;
  padding-top: 3px;
}
.faq-q-text {
  flex: 1;
  min-width: 0;
  overflow-wrap: break-word;
}

.faq-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border: 1px solid var(--border);
  border-radius: 50%;
  position: relative;
  transition: transform .35s cubic-bezier(.4,0,.2,1), border-color .25s ease, background .25s ease;
}
.faq-icon::before,
.faq-icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  background: #fff;
  transition: background .25s ease;
}
.faq-icon::before {
  width: 10px;
  height: 1.5px;
  transform: translate(-50%,-50%);
}
.faq-icon::after {
  width: 1.5px;
  height: 10px;
  transform: translate(-50%,-50%);
  transition: transform .35s cubic-bezier(.4,0,.2,1), background .25s ease;
}
.faq-item[open] .faq-icon {
  border-color: var(--blue);
  background: var(--blue);
  transform: rotate(180deg);
}
.faq-item[open] .faq-icon::after {
  transform: translate(-50%,-50%) rotate(90deg);
}

.faq-a {
  padding: 0 0 26px 0;
  max-width: 680px;
  font-family: var(--font);
  font-size: 14.5px;
  font-weight: 300;
  line-height: 1.7;
  color: rgba(255,255,255,.7);
  animation: faqFade .45s cubic-bezier(.4,0,.2,1);
}
.faq-a strong { color: #fff; font-weight: 600; }

@keyframes faqFade {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.faq-cta {
  margin-top: 56px;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
  padding: 32px 36px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(26,107,255,.06), rgba(13,27,62,.4));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.faq-cta-text { flex: 1; min-width: 240px; }
.faq-cta-text h4 {
  font-family: var(--font);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.faq-cta-text p {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 300;
  color: rgba(255,255,255,.55);
  margin: 0;
  line-height: 1.6;
}
.faq-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 24px;
  background: var(--blue);
  color: #fff;
  text-decoration: none;
  border-radius: 10px;
  font-family: var(--font);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.005em;
  transition: background .25s ease, transform .25s ease;
}
.faq-cta-btn:hover {
  background: var(--blue2);
  transform: translateX(2px);
}

@media (max-width:720px) {
  .faq-q { font-size: 16px; padding: 22px 0; gap: 16px; }
  .faq-q-num { display: none; }
  .faq-icon { width: 28px; height: 28px; }
  .faq-a { padding-bottom: 24px; font-size: 15px; }
  .faq-cta { padding: 24px; flex-direction: column; align-items: flex-start; }
}

/* ═══════════════════════════════════════════════════════════
   Timeline 12 meses · Transición Coexistencia → Internalización
   ═══════════════════════════════════════════════════════════ */
.tl-wrap {
  margin-top: 72px;
  padding: clamp(36px, 4vw, 56px) clamp(28px, 3vw, 48px);
  background: linear-gradient(180deg, rgba(13,27,62,.55), rgba(13,27,62,.25));
  border: 1px solid var(--border);
  border-radius: 24px;
  position: relative;
  overflow: hidden;
}
.tl-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 15% 25%, rgba(26,107,255,.07) 0%, transparent 45%),
    radial-gradient(circle at 85% 75%, rgba(77,141,255,.05) 0%, transparent 45%);
}

/* Head */
.tl-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 28px;
  margin-bottom: 56px;
  position: relative;
  z-index: 1;
}
.tl-head-left { flex: 1; min-width: 300px; max-width: 620px; }
.tl-head-title {
  font-family: var(--font);
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 700;
  color: #fff;
  margin: 10px 0 8px;
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.tl-head-title em {
  font-style: normal;
  background: linear-gradient(120deg, var(--blue), var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.tl-head-sub {
  font-family: var(--font);
  font-size: 14.5px;
  color: rgba(255,255,255,.68);
  font-weight: 300;
  line-height: 1.65;
  margin: 0;
}
.tl-head-legend {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-shrink: 0;
  padding: 14px 18px;
  background: rgba(8,15,34,.5);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
}
.tl-legend-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 10.5px;
  color: rgba(255,255,255,.7);
  letter-spacing: 1.2px;
  text-transform: uppercase;
  font-weight: 600;
}
.tl-legend-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.tl-dot-cyan  { background: var(--cyan);   box-shadow: 0 0 8px rgba(77,141,255,.6); }
.tl-dot-blue  { background: var(--blue);   box-shadow: 0 0 8px rgba(26,107,255,.7); }

/* Eje temporal */
.tl-axis {
  position: relative;
  margin-bottom: 40px;
  padding: 0 4px;
}
.tl-axis-track {
  position: relative;
  height: 3px;
  background: rgba(26,107,255,.12);
  border-radius: 3px;
  margin-bottom: 16px;
  overflow: hidden;
}
.tl-axis-fill {
  position: absolute;
  top: 0; left: 0;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--cyan) 0%, var(--cyan) 50%, var(--blue) 100%);
  border-radius: 3px;
  box-shadow: 0 0 12px rgba(26,107,255,.5);
  transition: width 2.2s cubic-bezier(.4,0,.2,1);
}
.tl-wrap.in .tl-axis-fill { width: 100%; }

.tl-axis-marks {
  display: flex;
  justify-content: space-between;
  position: relative;
}
.tl-mark {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  position: relative;
  margin-top: -22px;
}
.tl-mark-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--bg);
  border: 2px solid rgba(26,107,255,.3);
  transition: border-color .4s ease, background .4s ease, transform .4s ease, box-shadow .4s ease;
}
.tl-wrap.in .tl-mark-dot {
  border-color: var(--blue);
  background: var(--blue);
  transform: scale(1.1);
  box-shadow: 0 0 0 4px rgba(26,107,255,.12);
}
.tl-mark:nth-child(1) .tl-mark-dot { transition-delay: 0s; }
.tl-mark:nth-child(2) .tl-mark-dot { transition-delay: .4s; }
.tl-mark:nth-child(3) .tl-mark-dot { transition-delay: .8s; }
.tl-mark:nth-child(4) .tl-mark-dot { transition-delay: 1.2s; }
.tl-mark:nth-child(5) .tl-mark-dot { transition-delay: 1.6s; }
.tl-mark-label {
  font-family: var(--mono);
  font-size: 10px;
  color: rgba(255,255,255,.55);
  letter-spacing: 1.4px;
  font-weight: 600;
}

/* Fases */
.tl-phases {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 48px;
  position: relative;
  z-index: 1;
}
.tl-phase {
  position: relative;
  padding: 24px 22px 22px;
  background: rgba(8,15,34,.4);
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  transition: border-color .35s ease, transform .35s ease, background .35s ease;
  overflow: hidden;
  min-width: 0;
}
.tl-phase:hover {
  border-color: rgba(26,107,255,.4);
  transform: translateY(-3px);
  background: rgba(13,27,62,.55);
}
.tl-phase-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  gap: 10px;
}
.tl-phase-range {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--cyan);
  letter-spacing: 1.8px;
  font-weight: 600;
}
.tl-phase[data-phase="04"] .tl-phase-range { color: var(--blue); }
.tl-phase-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--cyan);
  letter-spacing: 1.5px;
  font-weight: 600;
}
.tl-phase-title {
  font-family: var(--font);
  font-size: clamp(16px, 1.3vw, 18px);
  font-weight: 700;
  color: #fff;
  margin: 0 0 10px;
  letter-spacing: -0.015em;
  line-height: 1.25;
  overflow-wrap: break-word;
}
.tl-opt {
  display: inline-block;
  margin-left: 4px;
  font-family: var(--mono);
  font-size: 9px;
  color: var(--blue);
  letter-spacing: 1.6px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 2px 7px;
  background: rgba(26,107,255,.1);
  border: 1px solid rgba(26,107,255,.3);
  border-radius: 999px;
  vertical-align: middle;
}
.tl-phase-body {
  font-family: var(--font);
  font-size: 13.5px;
  font-weight: 300;
  line-height: 1.6;
  color: rgba(255,255,255,.6);
  margin: 0 0 16px;
  flex: 1;
  overflow-wrap: break-word;
}
.tl-phase-body strong { color: #fff; font-weight: 600; }

.tl-phase-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 18px;
}
.tl-tag {
  font-family: var(--mono);
  font-size: 9.5px;
  color: rgba(255,255,255,.55);
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 500;
  padding: 5px 9px;
  background: rgba(26,107,255,.06);
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  white-space: nowrap;
}
.tl-phase-track {
  height: 3px;
  border-radius: 2px;
  margin-top: auto;
  width: 0;
  transition: width 1.4s cubic-bezier(.4,0,.2,1);
}
.tl-wrap.in .tl-phase-track { width: 100%; }
.tl-phase:nth-child(1) .tl-phase-track { transition-delay: .2s; }
.tl-phase:nth-child(2) .tl-phase-track { transition-delay: .5s; }
.tl-phase:nth-child(3) .tl-phase-track { transition-delay: .8s; }
.tl-phase:nth-child(4) .tl-phase-track { transition-delay: 1.1s; }

.tl-track-cyan     { background: linear-gradient(90deg, var(--cyan), rgba(77,141,255,.3)); }
.tl-track-gradient { background: linear-gradient(90deg, var(--cyan), var(--blue)); }
.tl-track-blue     { background: linear-gradient(90deg, var(--blue), rgba(26,107,255,.3)); }

/* Outcomes */
.tl-outcomes {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 20px;
  padding-top: 32px;
  border-top: 1px solid var(--border-soft);
  position: relative;
  z-index: 1;
}
.tl-outcome {
  padding: 18px 22px;
  background: rgba(8,15,34,.5);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
}
.tl-outcome-end {
  border-color: rgba(26,107,255,.3);
  background: linear-gradient(135deg, rgba(26,107,255,.08), rgba(13,27,62,.5));
}
.tl-outcome-num {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--blue);
  letter-spacing: 1.8px;
  font-weight: 600;
  margin-bottom: 6px;
  text-transform: uppercase;
}
.tl-outcome-text {
  font-family: var(--font);
  font-size: 14px;
  color: #fff;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -0.01em;
}
.tl-outcome-end .tl-outcome-text { color: #fff; }

.tl-outcome-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  opacity: 0;
  transform: translateX(-10px);
  transition: opacity .8s ease 1.6s, transform .8s ease 1.6s;
}
.tl-outcome-arrow svg { width: 28px; height: 28px; }
.tl-wrap.in .tl-outcome-arrow {
  opacity: 1;
  transform: translateX(0);
}

/* Responsive */
@media (max-width: 1024px) {
  .tl-phases { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
}
@media (max-width: 820px) {
  .tl-head { flex-direction: column; align-items: stretch; }
  .tl-head-legend { flex-direction: row; flex-wrap: wrap; }
}
@media (max-width: 600px) {
  .tl-wrap { margin-top: 56px; padding: 28px 20px; }
  .tl-phases { grid-template-columns: 1fr; }
  .tl-axis-marks { font-size: 9px; }
  .tl-outcomes { grid-template-columns: 1fr; gap: 14px; }
  .tl-outcome-arrow { transform: rotate(90deg); }
  .tl-wrap.in .tl-outcome-arrow { transform: rotate(90deg); }
}

/* ═══════════════════════════════════════════════════════════
   Capacidades núcleo · 6 cards
   ═══════════════════════════════════════════════════════════ */
.caps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 22px;
}
.cap-card {
  position: relative;
  padding: clamp(26px, 2.4vw, 34px) clamp(22px, 2vw, 30px);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
  transition: transform .4s ease, border-color .4s ease, background .4s ease;
}
.cap-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--blue), var(--cyan));
  opacity: .65;
  transition: opacity .4s ease;
}
.cap-card:hover {
  transform: translateY(-4px);
  border-color: rgba(26,107,255,.4);
  background: rgba(13,27,62,.6);
}
.cap-card:hover::before { opacity: 1; }

.cap-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px;
}
.cap-card-ico {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: rgba(26,107,255,.1);
  border: 1px solid rgba(26,107,255,.25);
  display: flex; align-items: center; justify-content: center;
  color: var(--cyan);
}
.cap-card-ico svg { width: 22px; height: 22px; }
.cap-card-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--cyan);
  letter-spacing: 1.8px;
  font-weight: 600;
}

.cap-card-title {
  font-family: var(--font);
  font-size: clamp(19px, 1.6vw, 22px);
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1.25;
  margin: 0 0 12px;
  overflow-wrap: break-word;
}
.cap-card-body {
  font-family: var(--font);
  font-size: 14.5px;
  font-weight: 300;
  line-height: 1.7;
  color: rgba(255,255,255,.62);
  margin: 0 0 22px;
  flex: 1;
  overflow-wrap: break-word;
}
.cap-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--border-soft);
}
.cap-tag {
  font-family: var(--mono);
  font-size: 9.5px;
  color: rgba(255,255,255,.6);
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 500;
  padding: 5px 10px;
  background: rgba(26,107,255,.06);
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  white-space: nowrap;
}

@media (max-width: 640px) {
  .caps-grid { gap: 16px; }
  .cap-card { padding: 24px 22px; }
}

/* ═══════════════════════════════════════════════════════════
   Job application modal
   ═══════════════════════════════════════════════════════════ */
.job-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(16px, 3vw, 40px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease;
}
.job-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}
.job-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 18, .82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.job-modal-panel {
  position: relative;
  width: 100%;
  max-width: 720px;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  padding: clamp(32px, 4vw, 56px) clamp(28px, 3.6vw, 56px);
  background: linear-gradient(180deg, var(--bg2), var(--bg));
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: 0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(26,107,255,.12) inset;
  transform: translateY(20px) scale(.97);
  transition: transform .4s cubic-bezier(.4,0,.2,1);
}
.job-modal.is-open .job-modal-panel {
  transform: translateY(0) scale(1);
}

.job-modal-close {
  position: absolute;
  top: 18px; right: 18px;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  color: rgba(255,255,255,.7);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .25s ease, color .25s ease, transform .25s ease;
  padding: 0;
}
.job-modal-close:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
  transform: rotate(90deg);
}
.job-modal-close svg { width: 16px; height: 16px; }

.job-modal-head { margin-bottom: 32px; padding-right: 48px; }
.job-modal-head .ey { margin-bottom: 10px; }
.job-modal-title {
  font-family: var(--font);
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin: 0 0 10px;
}
.job-modal-sub {
  font-family: var(--font);
  font-size: 14.5px;
  font-weight: 300;
  color: rgba(255,255,255,.55);
  line-height: 1.6;
  margin: 0;
}

/* Form */
.job-form { display: flex; flex-direction: column; gap: 22px; }
.job-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.job-form-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}
.job-form-field label {
  font-family: var(--mono);
  font-size: 10.5px;
  color: rgba(255,255,255,.55);
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
}
.job-form-field label .req {
  color: var(--accent);
  margin-left: 2px;
}
.job-form-field input,
.job-form-field textarea {
  font-family: var(--font);
  font-size: 15px;
  font-weight: 400;
  color: #fff;
  background: rgba(8,15,34,.5);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  outline: none;
  width: 100%;
  transition: border-color .25s ease, background .25s ease;
}
.job-form-field input::placeholder,
.job-form-field textarea::placeholder {
  color: rgba(255,255,255,.28);
  font-weight: 300;
}
.job-form-field input:focus,
.job-form-field textarea:focus {
  border-color: var(--blue);
  background: rgba(8,15,34,.7);
  box-shadow: 0 0 0 3px rgba(26,107,255,.12);
}
.job-form-field textarea {
  resize: vertical;
  min-height: 110px;
  font-family: var(--font);
  line-height: 1.55;
}

.job-form-submit {
  margin-top: 8px;
  padding: 16px 24px;
  background: linear-gradient(90deg, var(--blue), var(--blue2));
  color: #fff;
  font-family: var(--font);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.005em;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: transform .25s ease, box-shadow .25s ease, opacity .25s ease;
  box-shadow: 0 8px 24px rgba(26,107,255,.25);
}
.job-form-submit:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(26,107,255,.35);
}
.job-form-submit:disabled { opacity: .6; cursor: wait; }

.job-form-feedback {
  font-family: var(--font);
  font-size: 13.5px;
  text-align: center;
  min-height: 18px;
}
.job-form-feedback .ok {
  color: #4ade80;
  font-weight: 500;
}

@media (max-width: 600px) {
  .job-modal-panel { padding: 32px 22px 28px; border-radius: 18px; }
  .job-modal-head { padding-right: 40px; }
  .job-form-row { grid-template-columns: 1fr; gap: 18px; }
  .job-form { gap: 18px; }
}


/* ═══════════════════════════════════════════════════════════
   Volume counters · Impacto real en negocio
   ═══════════════════════════════════════════════════════════ */
.vol-counters {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 56px;
}
.vol-counter {
  position: relative;
  padding: clamp(28px, 2.4vw, 36px) clamp(24px, 2vw, 32px);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  transition: transform .35s ease, border-color .35s ease, background .35s ease;
}
.vol-counter::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--cyan));
  opacity: .55;
  transition: opacity .35s ease;
}
.vol-counter:hover {
  transform: translateY(-3px);
  border-color: rgba(26,107,255,.32);
  background: rgba(13,27,62,.6);
}
.vol-counter:hover::before { opacity: 1; }

.vol-counter-value {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 14px;
  line-height: 1;
}
.vol-counter-num {
  font-family: var(--font);
  font-size: clamp(40px, 4.5vw, 60px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--white);
  font-variant-numeric: tabular-nums;
}
.vol-counter-suffix {
  font-family: var(--font);
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 700;
  color: var(--cyan);
  letter-spacing: -0.02em;
}
.vol-counter-label {
  font-family: var(--font);
  font-size: clamp(15px, 1.2vw, 17px);
  font-weight: 700;
  color: var(--white);
  margin-bottom: 4px;
  letter-spacing: -0.01em;
}
.vol-counter-sub {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--gray);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  font-weight: 500;
}

@media (max-width: 900px) {
  .vol-counters { grid-template-columns: 1fr; gap: 14px; margin-bottom: 40px; }
}
@media (prefers-reduced-motion: reduce) {
  .vol-counter-num { transition: none !important; }
}

/* ═══════════════════════════════════════════════════════════
   Sección 04 · Diferencial real (vs competencia)
   ═══════════════════════════════════════════════════════════ */
.vs-head { margin-bottom: 48px; max-width: 920px; }
.vs-head .section-title { margin-bottom: 22px; }
.vs-sub {
  font-family: var(--font);
  font-size: 17px;
  font-weight: 300;
  line-height: 1.7;
  color: rgba(255,255,255,.7);
  max-width: 760px;
  margin: 0;
}
.vs-sub .vs-accent {
  color: var(--accent);
  font-weight: 600;
  font-style: normal;
}

/* Claim dual potente */
.vs-claim {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 32px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--card);
  overflow: hidden;
  position: relative;
}
.vs-claim::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--blue), var(--cyan));
  opacity: .65;
}
.vs-claim-half {
  padding: 38px 36px 36px;
  position: relative;
}
.vs-claim-half + .vs-claim-half {
  border-left: 1px solid var(--border-soft);
}
.vs-claim-tag {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 14px;
}
.vs-claim-half.is-us .vs-claim-tag { color: var(--cyan); }
.vs-claim-text {
  font-family: var(--font);
  font-size: clamp(20px, 2.1vw, 28px);
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: -0.015em;
  color: rgba(255,255,255,.5);
  margin: 0;
}
.vs-claim-half.is-us .vs-claim-text {
  color: rgba(255,255,255,.92);
  font-weight: 500;
}
.vs-claim-text .vs-em {
  color: var(--accent);
  font-weight: 700;
  font-style: normal;
}

/* Acordeones */
.vs-expands {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.vs-expand {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .25s ease;
}
.vs-expand[open] {
  border-color: rgba(26,107,255,.32);
}
.vs-expand-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 26px;
  user-select: none;
  transition: background .2s ease;
}
.vs-expand-summary::-webkit-details-marker { display: none; }
.vs-expand-summary:hover { background: rgba(26,107,255,.04); }
.vs-expand-summary-l {
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--font);
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -0.01em;
}
.vs-expand-num {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.8px;
  color: var(--cyan);
}
.vs-expand-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--border);
  position: relative;
  transition: transform .35s cubic-bezier(.4,0,.2,1), border-color .25s, background .25s;
  flex-shrink: 0;
}
.vs-expand-icon::before, .vs-expand-icon::after {
  content: ''; position: absolute; top: 50%; left: 50%; background: #fff;
}
.vs-expand-icon::before { width: 10px; height: 1.5px; transform: translate(-50%,-50%); }
.vs-expand-icon::after { width: 1.5px; height: 10px; transform: translate(-50%,-50%); transition: transform .35s; }
.vs-expand[open] .vs-expand-icon {
  border-color: var(--blue);
  background: var(--blue);
}
.vs-expand[open] .vs-expand-icon::after { transform: translate(-50%,-50%) rotate(90deg); }

.vs-expand-body {
  padding: 0 26px 26px;
  animation: vsFade .4s cubic-bezier(.4,0,.2,1);
}
@keyframes vsFade {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Diagrama de capas dentro del acordeón 01 */
.vs-layers-inner {
  border-top: 1px solid var(--border-soft);
  padding-top: 20px;
}
.vs-layers-legend {
  display: flex;
  gap: 22px;
  align-items: center;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 20px;
}
.vs-legend-item { display: inline-flex; align-items: center; gap: 8px; }
.vs-legend-dot { width: 10px; height: 10px; border-radius: 50%; }
.vs-legend-us { background: var(--cyan); box-shadow: 0 0 8px rgba(77,141,255,.55); }
.vs-legend-other { background: rgba(255,255,255,.18); }

.vs-stack {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.vs-layer {
  display: grid;
  grid-template-columns: 240px 1fr 100px 100px;
  align-items: center;
  padding: 16px 22px;
  background: rgba(8,15,34,.5);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  transition: border-color .3s ease, background .3s ease;
}
.vs-layer:hover {
  border-color: rgba(26,107,255,.28);
  background: rgba(13,27,62,.7);
}
.vs-layer-name {
  font-family: var(--font);
  font-size: 14.5px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -0.01em;
}
.vs-layer-desc {
  font-family: var(--font);
  font-size: 13px;
  font-weight: 300;
  color: rgba(255,255,255,.6);
  line-height: 1.5;
  padding-right: 24px;
}
.vs-layer-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
}
.vs-layer.is-shared {
  background: rgba(245,166,35,.05);
  border-color: rgba(245,166,35,.22);
}

.vs-check {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: rgba(52,199,120,.12);
  border: 1px solid rgba(52,199,120,.4);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--success);
}
.vs-check svg { width: 13px; height: 13px; }
.vs-partial {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: rgba(245,166,35,.12);
  border: 1px solid rgba(245,166,35,.36);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}
.vs-partial svg { width: 11px; height: 11px; }
.vs-dash {
  width: 18px; height: 2px;
  background: rgba(255,255,255,.2);
  border-radius: 1px;
}

.vs-stack-foot {
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid var(--border-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.vs-stack-foot-text {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 400;
  color: rgba(255,255,255,.7);
  line-height: 1.6;
  margin: 0;
  max-width: 720px;
}
.vs-foot-em {
  color: var(--accent);
  font-weight: 700;
}

/* Tabla mini dentro de acordeones 02/03 */
.vs-table {
  border-top: 1px solid var(--border-soft);
  padding-top: 6px;
}
.vs-table-head-mini {
  display: grid;
  grid-template-columns: 1fr 88px 88px;
  padding: 8px 0 4px;
  font-family: var(--mono);
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--gray);
}
.vs-table-head-mini > div:nth-child(2),
.vs-table-head-mini > div:nth-child(3) { text-align: center; }
.vs-table-head-mini .us { color: var(--cyan); }

.vs-cat {
  padding: 18px 0 8px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--cyan);
}
.vs-cat:first-of-type { padding-top: 14px; }

.vs-row {
  display: grid;
  grid-template-columns: 1fr 88px 88px;
  align-items: center;
  padding: 11px 0;
  border-top: 1px solid var(--border-soft);
}
.vs-row:first-of-type { border-top: none; }
.vs-row-label {
  font-family: var(--font);
  font-size: 13.5px;
  font-weight: 400;
  color: rgba(255,255,255,.82);
  line-height: 1.45;
}
.vs-cell {
  display: flex;
  align-items: center;
  justify-content: center;
}
.vs-check-mini {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: rgba(52,199,120,.12);
  border: 1px solid rgba(52,199,120,.35);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--success);
}
.vs-check-mini svg { width: 11px; height: 11px; }
.vs-partial-mini {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: rgba(245,166,35,.12);
  border: 1px solid rgba(245,166,35,.32);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}
.vs-partial-mini svg { width: 10px; height: 10px; }

@media (max-width: 820px) {
  .vs-claim { grid-template-columns: 1fr; }
  .vs-claim-half + .vs-claim-half { border-left: none; border-top: 1px solid var(--border-soft); }
  .vs-claim-half { padding: 28px 24px; }
  .vs-claim-text { font-size: 20px; }
  .vs-layer {
    grid-template-columns: 1fr 56px 56px;
    padding: 14px 16px;
  }
  .vs-layer-desc { display: none; }
  .vs-stack-foot { flex-direction: column; align-items: flex-start; }
  .vs-stack-foot-text { font-size: 13px; }
  .vs-layers-legend { font-size: 9px; gap: 14px; }
  .vs-row { grid-template-columns: 1fr 56px 56px; }
  .vs-table-head-mini { grid-template-columns: 1fr 56px 56px; }
  .vs-expand-summary { padding: 16px 18px; }
  .vs-expand-body { padding: 0 18px 20px; }
}

/* ═══════════ LANG TOGGLE ES/EN — Estilo pill premium ═══════════ */
.lang-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'JetBrains Mono', var(--mono, monospace);
  user-select: none;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(13, 27, 62, 0.35);
  border: 1px solid var(--border, rgba(255,255,255,0.08));
  transition: border-color 0.2s ease, background 0.2s ease;
}
.lang-toggle:hover {
  border-color: rgba(26, 107, 255, 0.35);
  background: rgba(13, 27, 62, 0.55);
}

.lang-toggle-lbl {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: rgba(255, 255, 255, 0.38);
  transition: color 0.25s ease, text-shadow 0.25s ease;
  text-transform: uppercase;
  line-height: 1;
}
.lang-toggle-lbl.active {
  color: #fff;
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.25);
}

/* Track — más grande, dos estados de fondo */
.lang-toggle-track {
  position: relative;
  width: 38px;
  height: 22px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  padding: 0;
  cursor: pointer;
  transition: background 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease;
  flex-shrink: 0;
  outline: none;
}
.lang-toggle-track:hover {
  border-color: rgba(255, 255, 255, 0.3);
}
.lang-toggle-track:focus-visible {
  box-shadow: 0 0 0 3px rgba(26, 107, 255, 0.35);
}

/* Estado ON (idioma EN activo) — fondo azul vivo */
.lang-toggle-track.on {
  background: linear-gradient(135deg, var(--blue, #1A6BFF) 0%, var(--blue2, #4D8DFF) 100%);
  border-color: rgba(26, 107, 255, 0.6);
  box-shadow: 0 0 14px rgba(26, 107, 255, 0.4), inset 0 0 0 1px rgba(255,255,255,0.08);
}

/* Thumb — blanco con sombra suave, como el componente React */
.lang-toggle-thumb {
  position: absolute;
  top: 50%;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.12),
              0 1px 2px rgba(0, 0, 0, 0.24),
              0 2px 6px rgba(0, 0, 0, 0.18);
  transform: translateY(-50%);
  transition: left 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}
.lang-toggle-track.on .lang-toggle-thumb {
  left: 18px;
}

/* Mobile variant */
.lang-toggle-mob {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--border, rgba(255,255,255,0.08));
  border-radius: 0;
  background: transparent;
  padding-left: 0;
  padding-right: 0;
  border-left: none;
  border-right: none;
  border-bottom: none;
  justify-content: flex-start;
}
.lang-toggle-mob:hover {
  background: transparent;
  border-color: transparent;
  border-top-color: var(--border, rgba(255,255,255,0.08));
}

@media (max-width: 980px) {
  .navbar .lang-toggle:not(.lang-toggle-mob) {
    display: none;
  }
}

/* ═══════════ BRAND WORDMARK (NeuronUs.) ═══════════ */
/* Wordmark de texto en Montserrat — fuente corporativa para la marca.
   Hereda tamaño del contexto donde se usa.
   El punto va en azul corporativo. */
.brand-wordmark {
  display: inline;
  font-family: 'Montserrat', 'Plus Jakarta Sans', var(--font, sans-serif);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: inherit;
  white-space: nowrap;
}
.brand-dot {
  color: var(--blue, #1A6BFF);
  font-weight: 700;
  display: inline;
  font-family: 'Montserrat', 'Plus Jakarta Sans', var(--font, sans-serif);
}

/* Cuando el wordmark va dentro de un h2/h3 con color blanco, el dot brilla */
.section-title .brand-wordmark,
h2 .brand-wordmark,
h3 .brand-wordmark {
  color: var(--white, #ffffff);
}

/* En tabla comparativa (.vs-table-head-mini .us): mantener tamaño compacto */
.vs-table-head-mini .us .brand-wordmark {
  font-weight: 700;
}

/* En tags pequeños como .vs-claim-tag: ajustar el dot */
.vs-claim-tag .brand-dot,
.vs-legend-item .brand-dot {
  color: var(--blue, #1A6BFF);
}

/* ═══════════ CASE STUDY · Conceptos clave ═══════════ */
/* Resalta keywords en azul + bold dentro de los párrafos del caso de éxito */
.case-key {
  color: var(--blue, #1A6BFF);
  font-weight: 700;
}

/* Wordmark abreviado "N." — para citas en línea ("integrarse en N.") */
.brand-wordmark-short {
  font-family: 'Montserrat', 'Plus Jakarta Sans', var(--font, sans-serif);
  font-weight: 700;
  letter-spacing: -0.01em;
  display: inline;
  white-space: nowrap;
}
.brand-wordmark-short .brand-dot {
  color: var(--blue, #1A6BFF);
}
