/* ═══════════════════════════════════════════════════
   IMPULSE SOLUTIONS — style.css   (Dark Premium)
═══════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────── */
:root {
  --bg:        #050E1D;
  --bg2:       #0A1628;
  --bg3:       #0F1E35;
  --card:      rgba(255,255,255,0.04);
  --card-h:    rgba(255,255,255,0.07);
  --border:    rgba(255,255,255,0.08);
  --border-h:  rgba(14,165,233,0.45);

  --blue:      #2A6DB5;
  --elec:      #0EA5E9;
  --cyan:      #22D3EE;
  --green:     #10B981;
  --red:       #EF4444;
  --orange:    #F59E0B;
  --purple:    #8B5CF6;

  --white:     #FFFFFF;
  --t1:        #E8F4FF;
  --t2:        #8FAEC5;
  --t3:        #536D82;

  --grad:      linear-gradient(135deg,#2A6DB5,#0EA5E9);
  --grad-glow: radial-gradient(ellipse at 50% 0%,rgba(14,165,233,.16) 0%,transparent 65%);

  --font-h:    'Montserrat',sans-serif;
  --font-b:    'Inter',sans-serif;

  --r:         16px;
  --r-btn:     12px;
  --sec-py:    96px;
  --max-w:     1200px;

  --ease:      cubic-bezier(.4,0,.2,1);
  --t:         .3s var(--ease);
}

/* ── Reset ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-b);background:var(--bg);color:var(--t1);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{text-decoration:none;color:inherit;transition:color var(--t)}
button{cursor:pointer;border:none;background:none;font-family:var(--font-b)}
ul{list-style:none}
input,select,textarea{font-family:var(--font-b)}
:focus-visible{outline:2px solid var(--elec);outline-offset:3px;border-radius:4px}
::selection{background:var(--elec);color:#fff}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--blue)}

/* ── Utilidades ────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.container-sm{max-width:720px}
.text-c{text-align:center}
.d-br{display:block}

.grad-text{
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ── Botones ───────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 26px;
  background:var(--grad);color:#fff;
  font-family:var(--font-h);font-weight:700;font-size:.9rem;
  border-radius:var(--r-btn);
  transition:transform var(--t),box-shadow var(--t),filter var(--t);
  position:relative;overflow:hidden;white-space:nowrap;
}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.1)}
.btn-primary:active{transform:translateY(0)}
.btn-glow{box-shadow:0 4px 22px rgba(14,165,233,.38)}
.btn-glow:hover{box-shadow:0 8px 36px rgba(14,165,233,.6)}
.btn-lg{padding:15px 30px;font-size:.95rem}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 22px;
  border:1.5px solid rgba(255,255,255,.18);color:var(--t1);
  font-family:var(--font-h);font-weight:600;font-size:.9rem;
  border-radius:var(--r-btn);
  transition:border-color var(--t),background var(--t),transform var(--t);
}
.btn-ghost:hover{border-color:var(--elec);background:rgba(14,165,233,.08);transform:translateY(-2px)}

.btn-cta-nav{
  padding:9px 20px;background:var(--grad);color:#fff;
  font-family:var(--font-h);font-weight:700;font-size:.85rem;
  border-radius:var(--r-btn);white-space:nowrap;
  transition:transform var(--t),box-shadow var(--t);
}
.btn-cta-nav:hover{transform:translateY(-1px);box-shadow:0 4px 18px rgba(14,165,233,.45)}

/* ── Section tokens ────────────────────────────── */
.section-eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 14px;
  background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.25);
  border-radius:100px;
  font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--elec);margin-bottom:14px;
}
.section-h2{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(1.9rem,4vw,2.75rem);
  line-height:1.15;color:var(--white);
  margin-bottom:16px;
}
.section-desc{
  font-size:1.05rem;color:var(--t2);
  max-width:540px;margin:0 auto 52px;line-height:1.7;text-align:center;
}

/* ── Secciones base ────────────────────────────── */
.section{padding:var(--sec-py) 0;text-align:center;position:relative;overflow:hidden}
.section-alt{background:var(--bg2)}
.section::before,.section-alt::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(14,165,233,.2),transparent);
}

/* ═══════════════════════════════════════════════════
   NAVBAR
═══════════════════════════════════════════════════ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background var(--t),backdrop-filter var(--t),box-shadow var(--t);
}
#navbar.stuck{
  background:rgba(5,14,29,.9);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow:0 2px 24px rgba(0,0,0,.3);
}
.nav-inner{
  max-width:var(--max-w);margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;gap:28px;
}
.nav-logo img{
  height:38px;width:auto;
  background:#ffffff;
  border-radius:8px;
  padding:5px 12px;
  box-shadow:0 2px 14px rgba(0,0,0,.35);
  transition:box-shadow var(--t),transform var(--t);
}
.nav-logo:hover img{
  box-shadow:0 4px 20px rgba(14,165,233,.25);
  transform:scale(1.02);
}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links a{
  padding:7px 13px;font-size:.88rem;font-weight:500;
  color:var(--t2);border-radius:8px;
  transition:color var(--t),background var(--t);
}
.nav-links a:hover{color:var(--white);background:rgba(255,255,255,.06)}

.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;margin-left:auto}
.hamburger span{display:block;width:23px;height:2px;background:var(--t1);border-radius:2px;transition:transform var(--t),opacity var(--t)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-mobile{
  display:none;flex-direction:column;gap:4px;padding:10px 20px 18px;
  background:rgba(5,14,29,.97);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-mobile.open{display:flex}
.nav-mobile a{padding:11px 14px;border-radius:10px;font-weight:500;color:var(--t2);transition:background var(--t),color var(--t)}
.nav-mobile a:hover{background:rgba(255,255,255,.05);color:var(--white)}
.nav-mobile .btn-primary{margin-top:6px;justify-content:center}

/* ═══════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  overflow:hidden;
  background:var(--bg) url('../images/hero-bg.png') center top / cover no-repeat;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    to bottom,
    rgba(5,14,29,.55) 0%,
    rgba(5,14,29,.72) 40%,
    rgba(5,14,29,.93) 85%,
    rgba(5,14,29,1)   100%
  );
  z-index:1;
}
#particles{position:absolute;inset:0;z-index:2;pointer-events:none}

/* Orbes flotantes */
.hero::after{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(42,109,181,.22),transparent 70%);
  top:-120px;right:-120px;z-index:1;
  animation:orbPulse 9s ease-in-out infinite;pointer-events:none;
}
@keyframes orbPulse{0%,100%{transform:scale(1) translate(0,0)}50%{transform:scale(1.08) translate(20px,-20px)}}

.hero-body{
  position:relative;z-index:3;
  text-align:center;padding-top:130px;padding-bottom:80px;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;
  padding:7px 18px;
  background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.28);
  border-radius:100px;font-size:.8rem;font-weight:700;
  letter-spacing:.05em;color:var(--elec);margin-bottom:26px;
}
.pulse-dot{
  width:8px;height:8px;background:var(--elec);border-radius:50%;
  animation:pulseDot 2s ease-in-out infinite;
}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 rgba(14,165,233,.5)}50%{box-shadow:0 0 0 7px rgba(14,165,233,0)}}

.hero-h1{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(2.8rem,6.5vw,5.2rem);
  line-height:1.08;color:var(--white);
  margin-bottom:20px;letter-spacing:-.015em;
}
.type-text{
  font-family:var(--font-h);font-weight:700;
  font-size:clamp(1.1rem,2.2vw,1.55rem);
  color:var(--elec);
}
.type-cursor{color:var(--elec);animation:blink .8s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

.hero-sub{
  font-size:clamp(.95rem,1.8vw,1.1rem);color:var(--t2);
  max-width:600px;margin:16px auto 36px;line-height:1.75;
}
.hero-sub strong{color:var(--t1)}

.hero-actions{
  display:flex;align-items:center;justify-content:center;
  gap:14px;flex-wrap:wrap;margin-bottom:52px;
}

.hero-stats{
  display:inline-flex;align-items:center;flex-wrap:wrap;justify-content:center;
  gap:0;padding:18px 28px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;backdrop-filter:blur(14px);
}
.hero-stat{text-align:center;padding:6px 28px}
.hero-stat strong{
  display:block;font-family:var(--font-h);font-weight:900;font-size:1.8rem;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-stat span{font-size:.75rem;color:var(--t2);display:block;margin-top:2px;white-space:nowrap}
.stat-sep{width:1px;height:36px;background:rgba(255,255,255,.1)}

.scroll-hint{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;
}
.scroll-hint span{
  display:block;width:24px;height:38px;
  border:2px solid rgba(255,255,255,.22);border-radius:12px;position:relative;
}
.scroll-hint span::after{
  content:'';position:absolute;top:5px;left:50%;transform:translateX(-50%);
  width:3px;height:8px;background:rgba(255,255,255,.45);border-radius:2px;
  animation:scrollBounce 1.7s ease-in-out infinite;
}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0);opacity:1}75%{transform:translateX(-50%) translateY(11px);opacity:0}}

/* ═══════════════════════════════════════════════════
   PLATAFORMAS BAR
═══════════════════════════════════════════════════ */
.platforms-bar{
  background:rgba(255,255,255,.025);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:24px 0;
}
.platforms-label{
  text-align:center;font-size:.73rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--t3);margin-bottom:18px;
}
.platforms-row{
  display:flex;align-items:center;justify-content:center;
  gap:36px;flex-wrap:wrap;
}
.platform-item{
  display:flex;align-items:center;gap:8px;
  font-size:.82rem;font-weight:600;color:var(--t2);
  opacity:.6;transition:opacity var(--t);
}
.platform-item:hover{opacity:1}

/* ═══════════════════════════════════════════════════
   PROBLEMA / VS
═══════════════════════════════════════════════════ */
.vs-grid{
  display:grid;grid-template-columns:1fr 64px 1fr;
  gap:20px;align-items:center;margin-top:48px;text-align:left;
}
.vs-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:28px;
  transition:border-color var(--t);
}
.vs-card:hover{border-color:var(--border-h)}
.vs-bad{border-top:2px solid var(--red)}
.vs-good{border-top:2px solid var(--green)}
.vs-header{margin-bottom:18px}
.vs-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:100px;
  font-size:.78rem;font-weight:700;letter-spacing:.04em;
}
.bad{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.good{background:rgba(16,185,129,.12);color:var(--green);border:1px solid rgba(16,185,129,.25)}
.vs-list{display:flex;flex-direction:column;gap:11px}
.vs-list li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:.9rem;color:var(--t2);line-height:1.5;
}
.x-icon{
  flex-shrink:0;width:20px;height:20px;background:rgba(239,68,68,.15);
  border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-size:.62rem;font-weight:900;color:var(--red);margin-top:1px;
}
.check-icon{
  flex-shrink:0;width:20px;height:20px;background:rgba(16,185,129,.15);
  border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-size:.68rem;font-weight:900;color:var(--green);margin-top:1px;
}
.vs-divider{display:flex;align-items:center;justify-content:center}
.vs-vs{
  font-family:var(--font-h);font-weight:900;font-size:1.1rem;
  color:var(--t3);padding:10px 0;
}

/* ═══════════════════════════════════════════════════
   SERVICIOS
═══════════════════════════════════════════════════ */
.services-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:22px;text-align:left;margin-top:8px;
}
.srv-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  will-change:transform;
}
.srv-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.35),0 0 0 1px rgba(14,165,233,.2);
  border-color:rgba(14,165,233,.3);
}

/* Imagen del servicio */
.srv-img{position:relative;height:210px;overflow:hidden;background:var(--bg3)}
.srv-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.srv-card:hover .srv-img img{transform:scale(1.06)}
.srv-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(5,14,29,0) 30%,rgba(5,14,29,.85) 100%);
}
.srv-num{
  position:absolute;top:14px;right:16px;
  font-family:var(--font-h);font-weight:900;font-size:2rem;
  color:rgba(255,255,255,.12);line-height:1;
  user-select:none;
}

.srv-body{padding:22px 24px 26px}
.srv-icon{
  width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.srv-icon.blue  {background:rgba(14,165,233,.14);color:var(--elec)}
.srv-icon.green {background:rgba(16,185,129,.14);color:var(--green)}
.srv-icon.purple{background:rgba(139,92,246,.14);color:var(--purple)}
.srv-icon.orange{background:rgba(245,158,11,.14);color:var(--orange)}

.srv-title{
  font-family:var(--font-h);font-weight:700;font-size:1.05rem;
  color:var(--white);margin-bottom:9px;
}
.srv-desc{font-size:.875rem;color:var(--t2);line-height:1.65;margin-bottom:14px}
.srv-benefits{display:flex;flex-direction:column;gap:6px}
.srv-benefits li{
  display:flex;align-items:center;gap:8px;
  font-size:.82rem;color:var(--t2);
}
.srv-benefits li::before{
  content:'✓';color:var(--green);font-weight:700;font-size:.85rem;flex-shrink:0;
}

/* ═══════════════════════════════════════════════════
   PROCESO
═══════════════════════════════════════════════════ */
.steps-grid{
  display:grid;grid-template-columns:1fr 40px 1fr 40px 1fr;
  align-items:start;gap:20px;margin-top:52px;
}
.step{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:30px 22px;text-align:center;
  transition:border-color var(--t),background var(--t),transform var(--t);
}
.step:hover{border-color:rgba(14,165,233,.3);background:var(--card-h);transform:translateY(-4px)}
.step-num{
  font-family:var(--font-h);font-weight:900;font-size:2.8rem;line-height:1;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;margin-bottom:14px;opacity:.3;
}
.step-icon{
  width:54px;height:54px;
  background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.2);
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;color:var(--elec);
  transition:background var(--t),box-shadow var(--t);
}
.step:hover .step-icon{background:rgba(14,165,233,.18);box-shadow:0 0 24px rgba(14,165,233,.2)}
.step-title{font-family:var(--font-h);font-weight:700;font-size:1rem;color:var(--white);margin-bottom:9px}
.step-desc{font-size:.85rem;color:var(--t2);line-height:1.65;margin-bottom:14px}
.step-tag{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.75rem;color:var(--elec);font-weight:600;
  background:rgba(14,165,233,.08);padding:4px 10px;border-radius:100px;
}
.step-arrow{
  display:flex;align-items:center;justify-content:center;
  padding-top:80px;color:var(--t3);
}

/* ═══════════════════════════════════════════════════
   MÉTRICAS
═══════════════════════════════════════════════════ */
.section-metrics{background:var(--bg2)}
.metrics-glow{
  position:absolute;width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(14,165,233,.1) 0%,transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;
}
.metrics-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:18px;margin-top:48px;
}
.metric-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:36px 18px;text-align:center;
  transition:transform var(--t),border-color var(--t),background var(--t);
}
.metric-card:hover{transform:translateY(-4px);border-color:rgba(14,165,233,.3);background:var(--card-h)}
.metric-icon{
  width:46px;height:46px;border-radius:13px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
}
.blue-i  {background:rgba(14,165,233,.15);color:var(--elec)}
.cyan-i  {background:rgba(34,211,238,.12);color:var(--cyan)}
.green-i {background:rgba(16,185,129,.12);color:var(--green)}
.orange-i{background:rgba(245,158,11,.12);color:var(--orange)}

.metric-num{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(2.4rem,4.5vw,3.4rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;margin-bottom:8px;
}
.metric-label{font-size:.83rem;color:var(--t2);font-weight:500}

/* ═══════════════════════════════════════════════════
   TESTIMONIOS
═══════════════════════════════════════════════════ */
.testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:18px;margin-top:8px;text-align:left;
}
.testi-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:28px;
  transition:border-color var(--t),background var(--t),transform var(--t);
}
.testi-card:hover{border-color:rgba(14,165,233,.25);background:var(--card-h);transform:translateY(-3px)}
.testi-featured{
  border-color:rgba(14,165,233,.25);
  background:linear-gradient(160deg,rgba(14,165,233,.05),rgba(42,109,181,.05));
}
.testi-stars{font-size:1.1rem;color:#F59E0B;margin-bottom:14px;letter-spacing:1px}
.testi-quote{
  font-size:.9rem;line-height:1.7;color:var(--t2);
  margin-bottom:20px;font-style:italic;
  border-left:2px solid var(--elec);padding-left:14px;
}
.testi-quote strong{color:var(--t1);font-style:normal}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{
  width:46px;height:46px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-weight:800;font-size:.9rem;color:#fff;
}
.testi-author strong{display:block;font-size:.88rem;color:var(--white);margin-bottom:2px}
.testi-author span{font-size:.77rem;color:var(--t2)}

/* ═══════════════════════════════════════════════════
   FAQ
═══════════════════════════════════════════════════ */
.faq-wrap{margin-top:40px;text-align:left}
.faq{border-bottom:1px solid var(--border);overflow:hidden}
.faq:first-child{border-top:1px solid var(--border)}
.faq summary{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:19px 0;list-style:none;cursor:pointer;
  font-family:var(--font-h);font-weight:600;font-size:.93rem;color:var(--t1);
  transition:color var(--t);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--elec)}
.faq[open] summary{color:var(--elec)}
.faq-ico{
  flex-shrink:0;width:22px;height:22px;border-radius:50%;
  border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  position:relative;transition:border-color var(--t),background var(--t);
}
.faq-ico::before,.faq-ico::after{
  content:'';position:absolute;background:var(--t2);border-radius:2px;
  transition:transform var(--t),opacity var(--t),background var(--t);
}
.faq-ico::before{width:9px;height:1.5px}
.faq-ico::after{width:1.5px;height:9px}
.faq[open] .faq-ico{border-color:var(--elec);background:rgba(14,165,233,.1)}
.faq[open] .faq-ico::after{transform:rotate(90deg);opacity:0}
.faq[open] .faq-ico::before{background:var(--elec)}
.faq-ans{padding:0 0 18px;animation:fadeSlide .22s var(--ease)}
.faq-ans p{font-size:.88rem;color:var(--t2);line-height:1.7}
.faq-ans strong{color:var(--t1)}
@keyframes fadeSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ═══════════════════════════════════════════════════
   CTA / CONTACTO
═══════════════════════════════════════════════════ */
.section-cta{background:var(--bg2)}
.cta-glow{
  position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(42,109,181,.12) 0%,transparent 70%);
  top:-200px;left:-100px;pointer-events:none;
}
.cta-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:center;
}
.cta-left{text-align:left}
.cta-left .section-h2{margin-bottom:14px}
.cta-checks{display:flex;flex-direction:column;gap:9px;margin-bottom:22px}
.cta-check{
  display:flex;align-items:center;gap:10px;
  font-size:.88rem;color:var(--t2);
}
.cta-check span{
  width:20px;height:20px;background:rgba(16,185,129,.15);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.65rem;font-weight:900;color:var(--green);flex-shrink:0;
}
.urgency-box{
  display:flex;align-items:flex-start;gap:9px;
  padding:13px 16px;
  background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.18);
  border-radius:10px;font-size:.83rem;color:var(--orange);line-height:1.5;
}
.urgency-box strong{color:#FBBF24}
.urgency-box svg{flex-shrink:0;margin-top:1px}

/* Formulario */
.contact-form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  border-radius:20px;padding:34px;backdrop-filter:blur(12px);
}
.form-title{
  font-family:var(--font-h);font-weight:700;font-size:1.15rem;
  color:var(--white);margin-bottom:22px;
}
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group label{font-size:.77rem;font-weight:600;color:var(--t2);letter-spacing:.03em}
.form-group input,
.form-group select,
.form-group textarea{
  padding:11px 14px;
  background:rgba(255,255,255,.055);border:1.5px solid rgba(255,255,255,.09);
  border-radius:9px;color:var(--t1);font-size:.88rem;
  transition:border-color var(--t),background var(--t),box-shadow var(--t);
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:rgba(139,163,185,.4)}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;border-color:var(--elec);
  background:rgba(14,165,233,.05);box-shadow:0 0 0 3px rgba(14,165,233,.1);
}
.form-group select{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%236B8FA8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;
}
.form-group select option{background:var(--bg2);color:var(--t1)}
.form-group textarea{resize:vertical;min-height:78px;line-height:1.6}
.btn-submit{width:100%;justify-content:center;padding:15px;font-size:.95rem;margin-top:6px}
@keyframes submitPulse{0%,100%{box-shadow:0 4px 22px rgba(14,165,233,.38)}50%{box-shadow:0 4px 36px rgba(14,165,233,.65),0 0 0 7px rgba(14,165,233,.07)}}
.btn-submit{animation:submitPulse 2.5s ease-in-out infinite}
.btn-submit:hover{animation:none;box-shadow:0 8px 38px rgba(14,165,233,.65)}

.form-alt{text-align:center;margin-top:14px;font-size:.8rem;color:var(--t2)}
.wa-link{display:inline-flex;align-items:center;gap:5px;color:var(--green);font-weight:600}
.wa-link:hover{opacity:.8}

/* ═══════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════ */
.footer{
  background:var(--bg);
  border-top:1px solid var(--border);
  padding:60px 0 28px;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:44px;margin-bottom:44px;
}
.footer-brand img{
  height:36px;width:auto;margin-bottom:16px;
  background:#ffffff;
  border-radius:8px;
  padding:5px 12px;
  box-shadow:0 2px 12px rgba(0,0,0,.3);
  opacity:.92;
  transition:opacity var(--t);
}
.footer-brand img:hover{opacity:1;}
.footer-brand p{font-size:.85rem;color:var(--t2);line-height:1.7;margin-bottom:18px}
.footer-social{display:flex;gap:9px}
.footer-social a{
  width:36px;height:36px;border:1.5px solid var(--border);border-radius:9px;
  display:flex;align-items:center;justify-content:center;color:var(--t2);
  transition:all var(--t);
}
.footer-social a:hover{border-color:var(--elec);color:var(--elec);background:rgba(14,165,233,.08)}
.footer-col h4{
  font-family:var(--font-h);font-weight:700;font-size:.75rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--white);margin-bottom:14px;
}
.footer-col a{
  display:block;font-size:.85rem;color:var(--t2);
  margin-bottom:8px;transition:color var(--t);
}
.footer-col a:hover{color:var(--elec)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:22px;border-top:1px solid var(--border);
  font-size:.78rem;color:var(--t3);
}
.footer-legal{display:flex;gap:18px}
.footer-legal a{color:var(--t3);transition:color var(--t)}
.footer-legal a:hover{color:var(--t1)}

/* ═══════════════════════════════════════════════════
   FLOTANTES
═══════════════════════════════════════════════════ */
.wa-float{
  position:fixed;bottom:26px;right:26px;z-index:999;
  width:56px;height:56px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 4px 18px rgba(37,211,102,.48);
  animation:waFloat 3.2s ease-in-out infinite;
  transition:transform var(--t),box-shadow var(--t);
}
.wa-float:hover{transform:scale(1.1);box-shadow:0 8px 28px rgba(37,211,102,.65);animation:none}
@keyframes waFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.wa-tip{
  position:absolute;right:66px;
  background:var(--bg3);color:var(--t1);
  font-size:.76rem;font-weight:600;padding:5px 11px;
  border-radius:7px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity var(--t);
}
.wa-tip::after{
  content:'';position:absolute;right:-5px;top:50%;transform:translateY(-50%);
  border:5px solid transparent;border-left-color:var(--bg3);
}
.wa-float:hover .wa-tip{opacity:1}

.scroll-top{
  position:fixed;bottom:92px;right:26px;z-index:999;
  width:42px;height:42px;
  background:rgba(10,22,40,.92);border:1.5px solid var(--border);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--t2);backdrop-filter:blur(12px);
  opacity:0;pointer-events:none;transition:all var(--t);
}
.scroll-top.vis{opacity:1;pointer-events:auto}
.scroll-top:hover{background:var(--blue);border-color:var(--blue);color:#fff;transform:translateY(-2px)}

/* ═══════════════════════════════════════════════════
   REVEAL ANIMATIONS
═══════════════════════════════════════════════════ */
.reveal,.reveal-left,.reveal-right{
  opacity:0;transition:opacity .65s var(--ease),transform .65s var(--ease);
}
.reveal     {transform:translateY(28px)}
.reveal-left{transform:translateX(-28px)}
.reveal-right{transform:translateX(28px)}
.in{opacity:1 !important;transform:none !important}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media(max-width:1024px){
  :root{--sec-py:72px}
  .steps-grid{grid-template-columns:1fr;gap:16px}
  .step-arrow{display:none}
  .metrics-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .cta-grid{grid-template-columns:1fr;gap:44px}
  .cta-left{text-align:center}
  .cta-left .section-desc{text-align:center}
  .cta-checks{align-items:center}
}

@media(max-width:768px){
  :root{--sec-py:56px}
  .d-br{display:none}
  .nav-links,.btn-cta-nav{display:none}
  .hamburger{display:flex}
  .hero-h1{font-size:clamp(2.2rem,8vw,3rem)}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions a{justify-content:center}
  .hero-stats{flex-direction:column;gap:0;width:100%}
  .hero-stat{padding:12px 20px}
  .stat-sep{width:50%;height:1px;margin:0 auto}
  .vs-grid{grid-template-columns:1fr;gap:12px}
  .vs-divider{display:none}
  .services-grid{grid-template-columns:1fr}
  .metrics-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr;text-align:center}
  .footer-social{justify-content:center}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:22px}
  .platforms-row{gap:20px}
}

@media(max-width:480px){
  .hero-h1{font-size:2rem}
  .metrics-grid{grid-template-columns:1fr}
  .section-h2{font-size:1.7rem}
  .testi-card{padding:20px}
}
