/* ══════════════════════════════════════════════════════════════════
   NOSOTROS · Yeapdata® — us.css  (Light Edition)
   Filosofía de color:
     • Todo el sitio: fondos blancos / off-white / subtle greys
     • ÚNICA excepción: sección ADN en azul rey profundo
     • Colores de marca usados como ACENTO, nunca como fondo
   Paleta:
     --pink   #E61667  (acento principal, CTAs, highlights)
     --teal   #6DC0AA  (acento secundario)
     --indigo #4B509C  (acento terciario)
     --royal  #0D1548  (SOLO sección ADN)
══════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap');

/* ── Variables ─────────────────────────────────────────────────── */
:root {
  /* Marca */
  --pink:          #E61667;
  --pink-hover:    #FF1E73;
  --pink-soft:     rgba(230,22,103,.07);
  --pink-mid:      rgba(230,22,103,.14);
  --pink-glow:     rgba(230,22,103,.30);
  --teal:          #6DC0AA;
  --teal-soft:     rgba(109,192,170,.09);
  --indigo:        #4B509C;
  --indigo-soft:   rgba(75,80,156,.07);

  /* Royal blue — EXCLUSIVO sección ADN */
  --royal:         #0D1548;
  --royal-deep:    #090E38;
  --royal-mid:     #111C5A;
  --royal-accent:  #1E3AE8;
  --royal-glow:    rgba(30,58,232,.25);

  /* Fondos claros — jerarquía */
  --bg-0:          #FFFFFF;       /* blanco puro */
  --bg-1:          #F8F9FC;       /* off-white levísimo */
  --bg-2:          #F2F4FA;       /* off-white medio */
  --bg-3:          #ECEEF7;       /* off-white suave */
  --bg-warm:       #FAFAF8;       /* cálido para Valores */

  /* Texto sobre claro */
  --t1:            #0B0A18;
  --t2:            #4A4968;
  --t3:            #8A89A8;
  --t4:            #BBBAD4;

  /* Bordes */
  --brd:           #E4E6F2;
  --brd-2:         #D6D9EE;

  /* Curvas */
  --ease:          cubic-bezier(.22,1,.36,1);
  --spring:        cubic-bezier(.34,1.56,.64,1);
  --hard:          cubic-bezier(.76,0,.24,1);

  --max:           1180px;
}

/* ── Reset ─────────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; font-size:16px }
body {
  font-family:'Poppins', sans-serif;
  background:var(--bg-0);
  color:var(--t1);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
::selection { background:var(--pink); color:#fff }
a { text-decoration:none; color:inherit }


/* ── Shared layout ─────────────────────────────────────────────── */
.section { position:relative; overflow:hidden }
.section-inner {
  max-width:var(--max);
  margin:0 auto;
  padding:0 52px;
  display:flex;
  align-items:flex-start;
  gap:80px;
}

/* Col de label (izquierda, sticky) */
.s-label-col {
  flex:0 0 76px;
  padding-top:120px;
  display:flex; flex-direction:column; align-items:center; gap:20px;
  position:sticky; top:120px; align-self:flex-start;
}
.s-number { font-size:.5rem; font-weight:700; letter-spacing:.2em; color:var(--t4) }
.s-number-light { color:rgba(255,255,255,.2) }
.s-title-vert {
  font-size:.47rem; font-weight:700; letter-spacing:.28em; text-transform:uppercase;
  color:var(--t4);
  writing-mode:vertical-rl; transform:rotate(180deg);
}
.s-title-vert-light { color:rgba(255,255,255,.18) }

/* Col de contenido */
.s-content-col { flex:1; min-width:0 }

/* Barra de acento */
.s-accent-bar {
  width:0; height:2px;
  background:var(--pink);
  margin-bottom:40px;
  transition:width 1s var(--ease);
}
.s-accent-bar-teal   { background:var(--teal) }
.s-accent-bar-royal  { background:var(--royal-accent) }
.s-accent-bar.bar-in { width:80px }

/* Label inline */
.s-label-inline { display:flex; align-items:center; gap:14px; margin-bottom:28px }
.s-num-inline   { font-size:.5rem; font-weight:700; letter-spacing:.2em; color:var(--pink) }
.s-num-teal     { color:var(--teal) }
.s-num-royal    { color:var(--royal-accent) }
.s-name-inline  {
  font-size:.47rem; font-weight:600; letter-spacing:.26em;
  text-transform:uppercase; color:var(--t3);
}
.s-name-inline-light { color:rgba(255,255,255,.3) }


/* ═══════════════════════════════════════════════════════════════
   HERO — blanco con red de nodos luminosa
═══════════════════════════════════════════════════════════════ */
.hero {
  height:100vh; min-height:700px;
  position:relative;
  display:flex; flex-direction:column;
  background:
    radial-gradient(ellipse 80% 60% at 80% 40%, rgba(109,192,170,.06) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 15% 70%, rgba(230,22,103,.05) 0%, transparent 50%),
    radial-gradient(ellipse 70% 80% at 50% 10%, rgba(75,80,156,.04) 0%, transparent 60%),
    #ffffff;
  overflow:hidden;
}

/* Canvas: red de nodos sobre blanco */
.hero-canvas {
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:1;
}

/* Grid de puntos decorativo */
.hero-grid {
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background-image:radial-gradient(rgba(75,80,156,.06) 1px, transparent 1px);
  background-size:36px 36px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 40%, transparent 100%);
}

/* Scan line */
.hero-scan {
  position:absolute; left:0; right:0; height:1px;
  z-index:5; pointer-events:none;
  background:linear-gradient(to right,
    transparent 0%, rgba(230,22,103,.12) 25%,
    rgba(109,192,170,.18) 50%,
    rgba(230,22,103,.12) 75%, transparent 100%);
  animation:scanLine 12s ease-in-out infinite;
}
@keyframes scanLine {
  0%  { top:-1%; opacity:0 }
  4%  { opacity:1 }
  96% { opacity:.4 }
  100%{ top:101%; opacity:0 }
}

/* HUD corners */
.hud { position:absolute; width:20px; height:20px; z-index:8; pointer-events:none }
.hud-tl { top:1rem; left:1rem;   border-top:1.5px solid rgba(230,22,103,.3); border-left:1.5px solid rgba(230,22,103,.3);  animation:hudBlink 5s ease infinite }
.hud-tr { top:1rem; right:1rem;  border-top:1.5px solid rgba(230,22,103,.3); border-right:1.5px solid rgba(230,22,103,.3); animation:hudBlink 5s 2.5s ease infinite }
.hud-bl { bottom:1rem; left:1rem;  border-bottom:1.5px solid rgba(75,80,156,.2); border-left:1.5px solid rgba(75,80,156,.2) }
.hud-br { bottom:1rem; right:1rem; border-bottom:1.5px solid rgba(75,80,156,.2); border-right:1.5px solid rgba(75,80,156,.2) }
@keyframes hudBlink { 0%,100%{opacity:1} 50%{opacity:.2} }

/* Nav */
.hero-nav {
  position:relative; z-index:10;
  display:flex; align-items:center; justify-content:space-between;
  padding:32px 56px;
}
.nav-logo { font-size:1.15rem; font-weight:800; letter-spacing:-.01em }
.logo-yeap { color:var(--pink) }
.logo-data { color:var(--t1) }
.nav-logo sup { font-size:.44rem; vertical-align:super; color:var(--t3); letter-spacing:.1em }
.nav-label { font-size:.47rem; font-weight:600; letter-spacing:.3em; text-transform:uppercase; color:var(--t3) }

/* Hero body */
.hero-body {
  position:relative; z-index:10;
  flex:1; display:flex; flex-direction:column; justify-content:center;
  padding:0 56px;
  max-width:880px;
}
.hero-kicker {
  display:flex; align-items:center; gap:16px; margin-bottom:44px;
  opacity:0; animation:fadeUp .8s .25s var(--ease) forwards;
}
.kicker-line   { display:block; width:32px; height:1px; background:var(--pink) }
.kicker-text   { font-size:.5rem; font-weight:700; letter-spacing:.28em; text-transform:uppercase; color:var(--pink) }

/* Título hero animado (letras entran por filas) */
.hero-h1       { display:flex; flex-direction:column; gap:2px; margin-bottom:36px }
.h1-row        { display:block; overflow:hidden }
.h1-mask       { display:block; overflow:hidden }
.h1-inner {
  display:block;
  font-size:clamp(52px, 8.5vw, 112px);
  font-weight:900; line-height:.93; letter-spacing:-.03em; text-transform:uppercase;
  color:var(--t1);
  opacity:0; transform:translateY(115%);
  animation:slideUp .9s var(--ease) forwards;
  padding-top: 15px;
}
.h1-row[data-delay="0"]   .h1-inner { animation-delay:.38s }
.h1-row[data-delay="120"] .h1-inner { animation-delay:.54s }
.h1-inner.pink    { color:var(--pink) }
.h1-inner.outline {
  color:transparent;
  -webkit-text-stroke:1.5px rgba(11,10,24,.18);
}

.hero-sub {
  font-size:clamp(.88rem, 1.3vw, 1.05rem);
  font-weight:300; line-height:1.8; color:var(--t2); max-width:520px;
  opacity:0; animation:fadeUp .8s .95s var(--ease) forwards;
}

/* Scroll hint */
.hero-scroll {
  position:absolute; bottom:40px; left:56px; z-index:10;
  display:flex; align-items:center; gap:14px;
  opacity:0; animation:fadeUp .6s 1.3s var(--ease) forwards;
}
.scroll-line {
  width:1px; height:36px;
  background:linear-gradient(to bottom, transparent, var(--pink));
  animation:scrollPulse 2.2s 1.6s ease-in-out infinite;
}
.hero-scroll span { font-size:.44rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--t3) }

/* Side index */
.hero-index {
  position:absolute; right:40px; top:50%; transform:translateY(-50%);
  z-index:10; display:flex; flex-direction:column; gap:8px;
  opacity:0; animation:fadeUp .6s 1.1s var(--ease) forwards;
}
.hi-item {
  font-size:.8rem; font-weight:600; letter-spacing:.15em; text-transform:uppercase;
  color:var(--t3); cursor:pointer; padding:4px 0;
  transition:color .3s, padding-right .3s; white-space:nowrap; text-align:right;
}
.hi-item.active, .hi-item:hover { color:var(--pink); padding-right:8px }


/* ═══════════════════════════════════════════════════════════════
   MISIÓN — fondo blanco
═══════════════════════════════════════════════════════════════ */
.s-mision {
  padding:120px 0;
  background:var(--bg-0);
  border-top:1px solid var(--brd);
}

/* Blockquote estilizada */
.s-quote {
  font-size:clamp(1rem, 1.55vw, 1.22rem);
  font-weight:300; line-height:1.88; color:var(--t1);
  padding-top:120px; padding-bottom:64px; max-width:660px;
  position:relative;
}
/* Comilla decorativa */
.s-quote::before {
  content:'"';
  position:absolute; top:72px; left:-38px;
  font-size:9rem; font-weight:900; line-height:1;
  color:rgba(230,22,103,.06);
  font-family:Georgia,serif; pointer-events:none;
  animation:quoteFloat 8s ease-in-out infinite;
}
@keyframes quoteFloat {
  0%,100%{ transform:translateY(0) }
  50%    { transform:translateY(-10px) }
}

/* Pills de pilares */
.s-pillars { display:flex; gap:12px; flex-wrap:wrap }
.pillar {
  display:flex; align-items:center; gap:12px;
  padding:14px 20px; border:1px solid var(--brd);
  border-radius:10px; background:var(--bg-1);
  transition:border-color .3s, background .3s, transform .35s var(--ease), box-shadow .35s;
}
.pillar:hover {
  border-color:rgba(230,22,103,.25); background:var(--bg-0);
  transform:translateY(-3px); box-shadow:0 8px 24px rgba(11,10,24,.07);
}
.pillar-icon { width:20px; height:20px; flex-shrink:0; color:var(--pink) }
.pillar-icon svg { width:100%; height:100% }
.pillar span { font-size:.7rem; font-weight:500; letter-spacing:.04em; color:var(--t2) }


/* ═══════════════════════════════════════════════════════════════
   VISIÓN — fondo bg-2 (levísimamente gris) con gráfico orbital
═══════════════════════════════════════════════════════════════ */
.s-vision {
  padding:120px 0;
  background:var(--bg-2);
  border-top:1px solid var(--brd); position:relative; overflow:hidden;
}
.s-vision .section-inner { align-items:center }

/* Texto BG gigante */
.vision-bg-text {
  position:absolute; bottom:-50px; right:-40px;
  font-size:clamp(110px, 18vw, 260px); font-weight:900;
  letter-spacing:-.05em; text-transform:uppercase;
  color:rgba(11,10,24,.028); pointer-events:none; user-select:none; line-height:1;
}
.s-vision-content { flex:1; max-width:560px }
.vision-h2 {
  font-size:clamp(26px, 3.8vw, 50px); font-weight:900; line-height:1.08;
  letter-spacing:-.02em; text-transform:uppercase; color:var(--t1); margin-bottom:24px;
}
.vision-h2 em { font-style:normal; color:var(--pink) }
.vision-body {
  font-size:clamp(.88rem, 1.2vw, 1rem);
  font-weight:400; line-height:1.85; color:var(--t2); max-width:480px;
}

/* Gráfico orbital (JS le añade rotación extra) */
.vision-graphic {
  flex:0 0 300px; height:300px;
  position:relative; display:flex; align-items:center; justify-content:center;
}
.vg-orbit {
  position:absolute; border-radius:50%; border:1px solid;
  animation:orbitSpin linear infinite;
}
.vg-orbit-1 {
  width:100%; height:100%;
  border-color:rgba(230,22,103,.10); animation-duration:24s;
}
.vg-orbit-2 {
  width:68%; height:68%;
  border-color:rgba(230,22,103,.20); animation-duration:16s; animation-direction:reverse;
}
.vg-orbit-3 {
  width:38%; height:38%;
  border-color:rgba(230,22,103,.38); animation-duration:9s;
}
/* Dot en cada órbita */
.vg-orbit::before {
  content:''; position:absolute; top:-5px; left:calc(50% - 4px);
  width:8px; height:8px; border-radius:50%;
  background:var(--pink);
  box-shadow:0 0 12px rgba(230,22,103,.7);
}
.vg-orbit-2::before { background:var(--teal); box-shadow:0 0 12px rgba(109,192,170,.7); width:6px; height:6px; top:-3px }
.vg-orbit-3::before { background:var(--indigo); box-shadow:0 0 10px rgba(75,80,156,.7); width:5px; height:5px; top:-2.5px }

.vg-core {
  width:64px; height:64px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; background:var(--t1); color:#fff; z-index:2;
  box-shadow:0 0 0 8px rgba(11,10,24,.07), 0 12px 40px rgba(11,10,24,.22);
}
.vg-core svg { width:30px; height:30px }

@keyframes orbitSpin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }


/* ═══════════════════════════════════════════════════════════════
   ADN — ÚNICA sección oscura: azul rey profundo
   Aquí la animación DNA brilla con fuerza máxima
═══════════════════════════════════════════════════════════════ */
.s-adn {
  padding:50px 0;
  background:
    radial-gradient(ellipse 70% 50% at 15% 50%, rgba(30,58,232,.14) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 85% 30%, rgba(109,192,170,.06) 0%, transparent 55%),
    linear-gradient(160deg, var(--royal) 0%, var(--royal-deep) 60%, #070C30 100%);
  border-top:none; position:relative; overflow:hidden;
}

/* Grid tenue sobre azul */
.s-adn::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
  background-size:60px 60px;
}

/* Partículas flotantes decorativas (JS las añade con canvas) */
.adn-canvas-bg {
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:1;
}

/* Contenido ADN */
.s-adn .section-inner { position:relative; z-index:2 }

/* Texto ADN grande */
.adn-headline {
  display:flex; flex-direction:column; gap:6px;
  padding-top:120px; padding-bottom:56px;
}
.adn-word {
  display:block;
  font-size:clamp(28px, 5vw, 62px); font-weight:900;
  letter-spacing:-.02em; text-transform:uppercase; line-height:1;
  color:rgba(255,255,255,.88);
}
.adn-word-pink { color:var(--pink) }
.adn-word-teal { color:var(--teal) }

/* Canvas ADN — hélice doble, brilla sobre el oscuro */
.adn-dna-visual {
  position:relative; margin-bottom:48px;
}
.dna-canvas {
  display:block; width:100%; max-width:600px; height:130px;
}

/* Chips de ADN */
.adn-chips { display:flex; flex-wrap:wrap; gap:.55rem }
.adn-chip {
  padding:.3rem .85rem; border-radius:999px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.05);
  font-size:.6rem; font-weight:500; letter-spacing:.07em;
  color:rgba(255,255,255,.5);
  transition:all .3s var(--ease); cursor:default;
}
.adn-chip:hover {
  border-color:rgba(230,22,103,.55);
  color:var(--pink); background:rgba(230,22,103,.08);
  transform:translateY(-2px);
}


/* ═══════════════════════════════════════════════════════════════
   VALORES — fondo cálido (bg-warm) / casi blanco
═══════════════════════════════════════════════════════════════ */
.s-valores {
  padding:120px 0;
  background:var(--bg-warm);
  border-top:1px solid var(--brd); position:relative;
}
.valores-bg-strip {
  position:absolute; top:0; left:0;
  width:3px; height:100%;
  background:linear-gradient(to bottom, var(--pink) 0%, transparent 100%);
}

.s-valores-inner { flex-direction:column; gap:56px; max-width:var(--max) }
.valores-header { width:100% }
.valores-title {
  font-size:clamp(26px, 3.5vw, 44px); font-weight:900;
  letter-spacing:-.02em; text-transform:uppercase; color:var(--t1);
}

/* Grid de valores — 5 columnas, diseño editorial */
.valores-grid {
  display:grid; grid-template-columns:repeat(5,1fr); gap:2px; width:100%;
}
.valor-card {
  background:var(--bg-0); padding:42px 28px;
  position:relative; overflow:hidden;
  transition:transform .45s var(--ease), box-shadow .45s, background .3s;
  cursor:default; transform-style:preserve-3d; perspective:700px;
  /* Animación de entrada personalizada */
  opacity:0; transform:translateY(30px);
}
.valor-card.in { opacity:1; transform:translateY(0) }

/* Barra inferior en hover */
.valor-card::after {
  content:''; position:absolute; bottom:0; left:0;
  width:100%; height:0; background:var(--pink);
  transition:height .4s var(--ease);
}
.valor-card:hover { transform:translateY(-7px); box-shadow:0 20px 48px rgba(11,10,24,.1) }
.valor-card:hover::after { height:3px }

/* Glow en hover */
.valor-card::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 50% 110%, rgba(230,22,103,.06), transparent 55%);
  opacity:0; transition:opacity .4s;
}
.valor-card:hover::before { opacity:1 }

.vc-number { font-size:.44rem; font-weight:700; letter-spacing:.22em; color:var(--pink); margin-bottom:28px }
.vc-bar {
  width:24px; height:1px; background:var(--brd-2); margin-bottom:18px;
  transition:width .45s var(--ease), background .3s;
}
.valor-card:hover .vc-bar { width:42px; background:var(--pink) }
.vc-name {
  font-size:clamp(.8rem, 1.1vw, .94rem); font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; color:var(--t1);
  transition:color .3s;
}
.valor-card:hover .vc-name { color:var(--pink) }
.vc-glyph {
  position:absolute; bottom:20px; right:20px;
  font-size:1.6rem; color:rgba(11,10,24,.05);
  transition:color .4s, transform .5s var(--spring);
}
.valor-card:hover .vc-glyph { color:rgba(230,22,103,.14); transform:scale(1.5) rotate(20deg) }


/* ═══════════════════════════════════════════════════════════════
   FILOSOFÍA — fondo bg-3 (levísimamente azulado)
═══════════════════════════════════════════════════════════════ */
.s-filosofia {
  padding:120px 0;
  background:var(--bg-3);
  border-top:1px solid var(--brd);
}
.s-filo-inner { flex-direction:column; gap:60px }
.filo-header  { max-width:520px }
.filo-title {
  font-size:clamp(26px, 3.8vw, 48px); font-weight:900; line-height:1.08;
  letter-spacing:-.02em; text-transform:uppercase; color:var(--t1);
}
.filo-title em { font-style:normal; color:var(--teal) }

/* 4 pasos — grid horizontal */
.filo-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; width:100% }
.filo-step {
  padding:50px 34px; background:var(--bg-0);
  position:relative; overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s, background .3s;
  cursor:default;
}
/* Línea superior en hover */
.filo-step::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--pink), var(--teal));
  transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.filo-step:hover { transform:translateY(-5px); box-shadow:0 18px 44px rgba(11,10,24,.09) }
.filo-step:hover::after { transform:scaleX(1) }

/* Flood de color en hover */
.filo-step::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to right, rgba(109,192,170,.06), transparent);
  width:0; transition:width .5s var(--ease);
}
.filo-step:hover::before { width:100% }

.fs-arrow {
  font-size:1.4rem; color:var(--t3); margin-bottom:26px; display:block;
  transition:color .3s, transform .35s var(--ease);
}
.filo-step:hover .fs-arrow { color:var(--t1); transform:translateX(6px) }
.fs-arrow-teal { color:var(--teal) }

.fs-verb {
  font-size:clamp(1.1rem, 1.9vw, 1.65rem); font-weight:900;
  letter-spacing:-.02em; text-transform:uppercase; color:var(--t1);
  line-height:1; margin-bottom:10px; transition:color .3s;
}
.fs-verb-teal { color:var(--teal) }
.fs-index { font-size:.42rem; font-weight:700; letter-spacing:.22em; color:var(--t3) }

/* Subtítulo emergente */
.fs-sub {
  position:absolute; bottom:20px; left:34px; right:20px;
  font-size:.6rem; font-weight:500; color:var(--pink);
  opacity:0; transform:translateY(8px);
  transition:opacity .3s, transform .3s;
}
.filo-step:hover .fs-sub { opacity:1; transform:translateY(0) }

/* Efecto dimming en vecinos */
.filo-steps.hover-active .filo-step { opacity:.4 }
.filo-steps.hover-active .filo-step:hover { opacity:1 }


/* ═══════════════════════════════════════════════════════════════
   CTA FINAL — fondo bg-1 (casi blanco) con partículas
═══════════════════════════════════════════════════════════════ */
.s-cta {
  padding:150px 48px;
  background:
    radial-gradient(ellipse 80% 70% at 50% 50%, rgba(230,22,103,.04) 0%, transparent 60%),
    var(--bg-1);
  position:relative; overflow:hidden; text-align:center;
  border-top:1px solid var(--brd);
}
/* Dot pattern decorativo */
.s-cta::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(rgba(75,80,156,.05) 1.5px, transparent 1.5px);
  background-size:30px 30px;
}
.cta-canvas {
  position:absolute; inset:0; width:100%; height:100%; pointer-events:none; z-index:1;
}
.cta-inner { position:relative; z-index:2; max-width:660px; margin:0 auto }
.cta-eyebrow {
  font-size:.5rem; font-weight:700; letter-spacing:.28em; text-transform:uppercase;
  color:var(--t3); margin-bottom:24px;
}
.cta-h2 {
  font-size:clamp(30px, 5.5vw, 70px); font-weight:900;
  letter-spacing:-.03em; text-transform:uppercase; color:var(--t1);
  line-height:1.05; margin-bottom:48px;
}
.cta-h2 em { font-style:normal; color:var(--pink) }
.cta-btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 44px; background:var(--pink); color:#fff;
  font-size:.7rem; font-weight:700; letter-spacing:.17em; text-transform:uppercase;
  border-radius:4px; transition:all .35s var(--ease);
  box-shadow:0 8px 32px rgba(230,22,103,.28);
}
.cta-btn:hover {
  background:var(--pink-hover); transform:translateY(-3px);
  box-shadow:0 16px 48px rgba(230,22,103,.42);
}
.cta-btn svg { transition:transform .3s }
.cta-btn:hover svg { transform:translateX(5px) }

/* Certificaciones */
.cta-certs { display:flex; align-items:center; justify-content:center; gap:12px; margin-top:3rem; flex-wrap:wrap }
.cert-item {
  padding:.35rem 1rem; background:var(--bg-0);
  border:1px solid var(--brd); border-radius:50px;
  font-size:.57rem; font-weight:500; color:var(--t2);
  box-shadow:0 2px 8px rgba(11,10,24,.04);
  transition:border-color .3s, transform .3s var(--ease);
}
.cert-item:hover { border-color:rgba(230,22,103,.3); transform:translateY(-2px) }


/* ═══════════════════════════════════════════════════════════════
   REVEAL ANIMATIONS
═══════════════════════════════════════════════════════════════ */
.reveal-up {
  opacity:0; transform:translateY(38px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal-up.in { opacity:1; transform:translateY(0) }

.reveal-scale {
  opacity:0; transform:scale(.86);
  transition:opacity 1s var(--ease), transform 1s var(--ease);
}
.reveal-scale.in { opacity:1; transform:scale(1) }

.reveal-card {
  opacity:0; transform:translateY(30px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal-card.in { opacity:1; transform:translateY(0) }

.reveal-step {
  opacity:0; transform:translateX(-24px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal-step.in { opacity:1; transform:translateX(0) }

.reveal-bar { transition:width 1.1s var(--ease) }
.reveal-bar.bar-in { width:80px }


/* ═══════════════════════════════════════════════════════════════
   KEYFRAMES GLOBALES
═══════════════════════════════════════════════════════════════ */
@keyframes slideUp    { from{opacity:0;transform:translateY(110%)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeUp     { from{opacity:0;transform:translateY(18px)}  to{opacity:1;transform:translateY(0)} }
@keyframes scrollPulse{ 0%,100%{transform:scaleY(1);opacity:.9} 50%{transform:scaleY(.5);opacity:.3} }


/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .section-inner { padding:0 32px; gap:48px }
  .hero-nav  { padding:24px 32px }
  .hero-body { padding:0 32px }
  .hero-scroll { left:32px }
  .hero-index  { display:none }
  .valores-grid { grid-template-columns:repeat(3,1fr) }
  .filo-steps   { grid-template-columns:repeat(2,1fr) }
  .vision-graphic { flex:0 0 230px; height:230px }
}
@media(max-width:768px){
  .section-inner { flex-direction:column; gap:32px; padding:0 24px }
  .s-label-col   { display:none }
  .s-quote       { padding-top:0 }
  .adn-headline  { padding-top:0 }
  .hero-nav      { padding:20px 24px }
  .hero-body     { padding:0 24px }
  .hero-scroll   { left:24px; bottom:24px }
  .valores-grid  { grid-template-columns:1fr 1fr }
  .filo-steps    { grid-template-columns:1fr }
  .s-cta         { padding:100px 24px }
  .vision-graphic{ align-self:center; width:220px; height:220px; flex:none }
}
@media(max-width:480px){
  .valores-grid  { grid-template-columns:1fr }
}