/* =====================================================================
   FLUENCIA — Sistema de diseño compartido (multipágina)
   Dark · Satoshi + Geist Mono · acentos azul/índigo/cian
   Cargar con: <link rel="stylesheet" href="/assets/fluencia.css">
   ===================================================================== */

/* ── TOKENS ─────────────────────────────────────────────────────── */
:root{
  --bg:#030305;--bg-2:#080810;--surface:#0d0d14;--surface-2:#111118;--surface-3:#16161f;
  --border:#1c1c28;--border-2:#252535;--border-3:#303048;
  --accent:#2563eb;--accent-2:#6366f1;--accent-3:#06b6d4;--accent-h:#1d4ed8;
  --accent-lo:rgba(37,99,235,0.10);--accent-lo2:rgba(37,99,235,0.05);--accent-glow:rgba(37,99,235,0.35);
  --indigo-glow:rgba(99,102,241,0.25);--cyan-glow:rgba(6,182,212,0.20);
  --text-1:#f1f5f9;--text-2:#94a3b8;--text-3:#64748b;
  --green:#22c55e;--green-lo:rgba(34,197,94,0.10);--red:#ef4444;--red-lo:rgba(239,68,68,0.10);--yellow:#f59e0b;
  --font-sans:'Satoshi',-apple-system,sans-serif;--font-mono:'Geist Mono','Courier New',monospace;
  --radius:10px;--radius-lg:16px;--radius-xl:24px;
  --nav-h:60px;--maxw:1160px;
}

/* ── RESET ──────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-sans);background:var(--bg);color:var(--text-1);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
::selection{background:var(--accent);color:#fff;}

/* ── SCROLL PROGRESS ────────────────────────────────────────────── */
#scroll-progress{position:fixed;top:0;left:0;height:2px;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent-3));z-index:1000;transition:width 0.1s linear;}

/* ── BACKGROUND (grid dots + orbs + noise) ─────────────────────── */
.scene-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.scene-bg__grid{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,0.06) 1px,transparent 1px);background-size:32px 32px;mask-image:radial-gradient(ellipse 80% 80% at 50% 40%,#000 40%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 40%,#000 40%,transparent 100%);}
.scene-bg__orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.5;animation:orbFloat 18s ease-in-out infinite;}
.scene-bg__orb--1{width:700px;height:700px;background:radial-gradient(circle,rgba(37,99,235,0.5),transparent 70%);top:-20%;left:-10%;animation-duration:20s;}
.scene-bg__orb--2{width:500px;height:500px;background:radial-gradient(circle,rgba(99,102,241,0.4),transparent 70%);top:30%;right:-5%;animation-delay:-7s;animation-duration:16s;}
.scene-bg__orb--3{width:400px;height:400px;background:radial-gradient(circle,rgba(6,182,212,0.25),transparent 70%);bottom:10%;left:30%;animation-delay:-13s;animation-duration:22s;}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(30px,-40px) scale(1.05);}66%{transform:translate(-20px,30px) scale(0.95);}}
.noise{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:0.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:256px 256px;}

/* ── LAYOUT ─────────────────────────────────────────────────────── */
section{position:relative;z-index:2;}
.container{max-width:var(--maxw);width:100%;margin:0 auto;padding:0 1.5rem;}
.section-label{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--font-mono);font-size:0.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:0.12em;color:var(--accent);background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);padding:0.35rem 0.875rem;border-radius:100px;margin-bottom:1.25rem;}
.section-label::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);display:block;animation:pulse 2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.5;transform:scale(0.8);}}
.sec{padding:6.5rem 0;}
.sec--tight{padding:0 0 6.5rem;}
.sec__header{margin-bottom:3.5rem;max-width:720px;}
.sec__header--center{margin-left:auto;margin-right:auto;text-align:center;}
.sec__h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-0.04em;line-height:1.14;margin-bottom:0.75rem;text-wrap:balance;}
.sec__h2 em{font-style:normal;background:linear-gradient(135deg,var(--accent),var(--accent-2),var(--accent-3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.sec__sub{font-size:1.0625rem;color:var(--text-2);line-height:1.6;}
.text-gradient{background:linear-gradient(135deg,var(--text-1) 30%,var(--accent-3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.text-mono{font-family:var(--font-mono);}

/* ── ANIMATIONS (reveal + stagger) ─────────────────────────────── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.6s cubic-bezier(0.16,1,0.3,1),transform 0.6s cubic-bezier(0.16,1,0.3,1);}
.fade-up.visible{opacity:1;transform:translateY(0);}
.fade-up[data-delay="1"]{transition-delay:0.08s;}
.fade-up[data-delay="2"]{transition-delay:0.16s;}
.fade-up[data-delay="3"]{transition-delay:0.24s;}
.fade-up[data-delay="4"]{transition-delay:0.32s;}
.fade-up[data-delay="5"]{transition-delay:0.40s;}
/* stagger: hijos directos aparecen en cascada cuando el contenedor entra */
.stagger > *{opacity:0;transform:translateY(20px);transition:opacity 0.55s cubic-bezier(0.16,1,0.3,1),transform 0.55s cubic-bezier(0.16,1,0.3,1);}
.stagger.visible > *{opacity:1;transform:translateY(0);}
.stagger.visible > *:nth-child(1){transition-delay:0.05s;}
.stagger.visible > *:nth-child(2){transition-delay:0.12s;}
.stagger.visible > *:nth-child(3){transition-delay:0.19s;}
.stagger.visible > *:nth-child(4){transition-delay:0.26s;}
.stagger.visible > *:nth-child(5){transition-delay:0.33s;}
.stagger.visible > *:nth-child(6){transition-delay:0.40s;}
.stagger.visible > *:nth-child(7){transition-delay:0.47s;}
.stagger.visible > *:nth-child(8){transition-delay:0.54s;}

/* ── BUTTONS ────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;font-weight:600;border-radius:10px;transition:all 0.2s cubic-bezier(0.16,1,0.3,1);touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden;}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,0.12) 50%,transparent 60%);transform:translateX(-100%);transition:transform 0.5s ease;}
.btn:hover::after{transform:translateX(100%);}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 0 0 0 var(--accent-glow);}
.btn-primary:hover{background:var(--accent-h);box-shadow:0 0 30px var(--accent-glow),0 4px 20px rgba(37,99,235,0.4);transform:translateY(-1px);}
.btn-primary:active{transform:scale(0.97);}
.btn-ghost{color:var(--accent);border:1px solid rgba(37,99,235,0.3);background:var(--accent-lo);}
.btn-ghost:hover{background:rgba(37,99,235,0.15);border-color:rgba(37,99,235,0.5);transform:translateY(-1px);}
.btn-wa{background:#25D366;color:#fff;box-shadow:0 0 0 0 rgba(37,211,102,0.35);}
.btn-wa:hover{background:#20c45c;box-shadow:0 0 28px rgba(37,211,102,0.45),0 4px 16px rgba(37,211,102,0.3);transform:translateY(-1px);}
.btn-wa:active{transform:scale(0.97);}
.btn-sm{font-size:0.8125rem;padding:0.5rem 1rem;min-height:38px;}
.btn-md{font-size:0.875rem;padding:0.625rem 1.25rem;min-height:42px;}
.btn-lg{font-size:0.9375rem;padding:0.75rem 1.5rem;min-height:48px;}
.btn-xl{font-size:1rem;padding:0.875rem 1.75rem;min-height:52px;}

/* ── NAV + MEGA-MENU ───────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 1.5rem;height:var(--nav-h);display:flex;align-items:center;border-bottom:1px solid transparent;transition:background 0.3s ease,border-color 0.3s ease;}
.nav.scrolled{background:rgba(3,3,5,0.82);border-color:var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);}
.nav__inner{max-width:var(--maxw);width:100%;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.nav__logo{display:flex;align-items:center;gap:0.625rem;flex-shrink:0;}
.nav__logo img{height:30px;width:auto;object-fit:contain;}
.nav__wordmark{font-size:1.25rem;font-weight:900;letter-spacing:-0.04em;background:linear-gradient(135deg,#fff 40%,var(--accent-3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.nav__menu{display:flex;align-items:center;gap:0.25rem;margin-left:auto;}
.nav__item{position:relative;}
.nav__link{display:inline-flex;align-items:center;gap:0.3rem;font-size:0.875rem;color:var(--text-2);font-weight:500;padding:0.5rem 0.75rem;border-radius:8px;transition:color 0.2s,background 0.2s;cursor:pointer;background:none;}
.nav__link:hover,.nav__link[aria-expanded="true"]{color:var(--text-1);}
.nav__link .ph-caret-down{font-size:0.75rem;transition:transform 0.25s;}
.nav__link[aria-expanded="true"] .ph-caret-down{transform:rotate(180deg);}
.nav__actions{display:flex;align-items:center;gap:0.625rem;flex-shrink:0;}

/* mega-menu panel */
.mega{position:absolute;top:calc(100% + 2px);left:50%;transform:translateX(-50%) translateY(8px);width:min(680px,92vw);background:rgba(8,8,16,0.97);border:1px solid var(--border-2);border-radius:var(--radius-lg);box-shadow:0 24px 64px rgba(0,0,0,0.6);padding:1rem;opacity:0;visibility:hidden;transition:opacity 0.22s ease,transform 0.22s ease;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:101;}
.mega::before{content:'';position:absolute;top:-14px;left:0;right:0;height:14px;}
.nav__item.open .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.mega__grid{display:grid;grid-template-columns:1fr 1fr;gap:0.625rem;}
.mega__link{display:flex;gap:0.75rem;align-items:flex-start;padding:0.75rem;border-radius:10px;transition:background 0.18s;}
.mega__link:hover{background:var(--surface-2);}
.mega__ic{width:34px;height:34px;flex-shrink:0;border-radius:9px;background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1rem;transition:transform 0.28s cubic-bezier(0.34,1.56,0.64,1);}
.mega__link:hover .mega__ic{transform:scale(1.1) rotate(-6deg);}
.mega__t{font-size:0.875rem;font-weight:700;color:var(--text-1);margin-bottom:0.35rem;display:block;}
.mega__d{font-size:0.75rem;color:var(--text-3);line-height:1.4;display:block;}
.mega__foot{margin-top:0.5rem;padding:0.85rem 0.75rem 0.35rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.mega__foot span{font-size:0.8125rem;color:var(--text-2);}

/* marquee */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.125rem 0;background:rgba(8,8,20,0.5);}
.marquee-wrap__label{text-align:center;font-size:0.6875rem;font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:0.12em;margin-bottom:0.875rem;}
.marquee{display:flex;overflow:hidden;user-select:none;}
.marquee__track{display:flex;align-items:center;animation:marquee-scroll 36s linear infinite;flex-shrink:0;}
.marquee:hover .marquee__track{animation-play-state:paused;}
.marquee__item{display:inline-flex;align-items:center;gap:0.375rem;padding:0 1.75rem;white-space:nowrap;font-size:0.8125rem;font-weight:600;color:var(--text-2);}
.marquee__item i{color:var(--accent);font-size:0.9375rem;}
.marquee__sep{color:var(--border-2);padding:0 0.25rem;font-size:0.5rem;flex-shrink:0;}
@keyframes marquee-scroll{0%{transform:translateX(0);}100%{transform:translateX(-100%);}}
@media(prefers-reduced-motion:reduce){.marquee__track{animation:none;}}

/* hamburger + mobile */
.nav__burger{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--border-2);background:var(--surface);align-items:center;justify-content:center;font-size:1.25rem;color:var(--text-1);}
.mobile-menu{position:fixed;inset:var(--nav-h) 0 0;z-index:99;background:rgba(3,3,5,0.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem;display:none;flex-direction:column;gap:0.25rem;overflow-y:auto;}
.mobile-menu.open{display:flex;}
.mobile-menu a{padding:0.9rem 0.5rem;font-size:1rem;color:var(--text-1);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:0.6rem;}
.mobile-menu a.sub{font-size:0.9rem;color:var(--text-2);padding-left:1.5rem;}
.mobile-menu__label{font-family:var(--font-mono);font-size:0.6875rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-3);margin-top:1rem;padding-left:0.5rem;}

/* ── HERO ───────────────────────────────────────────────────────── */
.hero{padding:8rem 0 4.5rem;display:flex;align-items:center;}
.hero--tall{min-height:100vh;padding-top:9rem;}
.hero__inner{display:grid;grid-template-columns:1.05fr 0.95fr;gap:4rem;align-items:center;}
@media(max-width:900px){.hero__inner{grid-template-columns:1fr;gap:3rem;}.hero,.hero--tall{padding:7rem 0 3rem;min-height:auto;}}
.hero__badge{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--font-mono);font-size:0.6875rem;font-weight:500;color:var(--green);background:var(--green-lo);border:1px solid rgba(34,197,94,0.25);padding:0.35rem 0.875rem;border-radius:100px;margin-bottom:1.5rem;letter-spacing:0.05em;position:relative;overflow:hidden;}
.hero__badge::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 25%,rgba(255,255,255,0.12) 50%,transparent 75%);background-size:200% 100%;animation:badgeShimmer 3.5s linear 1.5s infinite;pointer-events:none;border-radius:inherit;}
.hero__badge-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s ease-in-out infinite;}
.hero__headline{font-size:clamp(2.5rem,5.6vw,4.5rem);font-weight:900;letter-spacing:-0.04em;line-height:1.07;margin-bottom:1.25rem;text-wrap:balance;}
.hero__headline em{font-style:normal;background:linear-gradient(135deg,var(--accent-3) 0%,#a855f7 35%,var(--accent) 65%,var(--accent-3) 100%);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientFlow 5s ease infinite;}
.hero__sub{font-size:1.0625rem;color:var(--text-2);line-height:1.7;margin-bottom:2rem;max-width:520px;}
.hero__cta-group{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;}
.hero__proof{display:flex;align-items:center;gap:0.75rem;flex-wrap:wrap;font-size:0.8125rem;color:var(--text-3);}
.hero__proof strong{color:var(--text-2);}
.hero__proof-dot{width:3px;height:3px;border-radius:50%;background:var(--border-3);}
.hero__panel{position:relative;}
.hero__panel-glow{position:absolute;inset:-40px;background:radial-gradient(circle at 50% 40%,var(--accent-glow),transparent 70%);pointer-events:none;z-index:0;}

/* ── TRUST BAR ─────────────────────────────────────────────────── */
.trust-bar{padding:3.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.trust-bar__head{text-align:center;margin-bottom:2.25rem;}
.trust-bar__eyebrow{font-family:var(--font-mono);font-size:0.6875rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--text-3);}
.trust-bar__eyebrow strong{color:var(--accent);font-weight:700;}
.trust-bar__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;}
@media(max-width:768px){.trust-bar__grid{grid-template-columns:repeat(2,1fr);}}
.trust-cell{background:var(--surface);padding:1.5rem 1.25rem;display:flex;flex-direction:column;gap:0.6rem;align-items:flex-start;transition:background 0.2s;}
.trust-cell:hover{background:var(--surface-2);}
.trust-cell__icon{width:34px;height:34px;border-radius:9px;background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1rem;}
.trust-cell__title{font-size:0.9rem;font-weight:700;color:var(--text-1);line-height:1.25;}
.trust-cell__sub{font-size:0.75rem;color:var(--text-3);line-height:1.45;}

/* ── SERVICE CARDS (grid de apartados) ─────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr;}}
.svc-card{display:flex;flex-direction:column;gap:0.875rem;padding:1.75rem;border:1px solid var(--border-2);border-radius:var(--radius-xl);background:var(--surface);position:relative;overflow:hidden;transition:transform 0.25s cubic-bezier(0.16,1,0.3,1),border-color 0.25s,box-shadow 0.25s;}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity 0.3s;}
.svc-card::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,0.05) 50%,transparent 70%);transform:translateX(-100%);transition:transform 0.65s ease;border-radius:inherit;pointer-events:none;}
.svc-card:hover{transform:translateY(-4px);border-color:var(--border-3);box-shadow:0 16px 40px rgba(0,0,0,0.4),0 0 30px rgba(37,99,235,0.08);}
.svc-card:hover::before{opacity:1;}
.svc-card:hover::after{transform:translateX(100%);}
.svc-card__icon{width:46px;height:46px;border-radius:12px;background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);display:flex;align-items:center;justify-content:center;font-size:1.375rem;color:var(--accent);transition:all 0.25s;}
.svc-card:hover .svc-card__icon{background:var(--accent);color:#fff;box-shadow:0 0 20px var(--accent-glow);}
.svc-card__title{font-size:1.0625rem;font-weight:700;color:var(--text-1);}
.svc-card__desc{font-size:0.875rem;color:var(--text-2);line-height:1.6;flex:1;}
.svc-card__link{display:inline-flex;align-items:center;gap:0.4rem;font-size:0.8125rem;font-weight:600;color:var(--accent);margin-top:0.25rem;}
.svc-card__link i{transition:transform 0.2s;}
.svc-card:hover .svc-card__link i{transform:translateX(3px);}
.svc-card__badge{position:absolute;top:1rem;right:1rem;font-family:var(--font-mono);font-size:0.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--accent);background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);padding:0.25rem 0.55rem;border-radius:100px;}

/* ── STEPS (cómo funciona) ─────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;position:relative;}
@media(max-width:768px){.steps{grid-template-columns:1fr;gap:1rem;}}
.step{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-xl);padding:2rem;position:relative;z-index:1;transition:all 0.3s;}
.step:hover{border-color:rgba(37,99,235,0.35);box-shadow:0 0 30px rgba(37,99,235,0.1);transform:translateY(-3px);}
.step__num{font-family:var(--font-mono);font-size:0.6875rem;font-weight:700;color:var(--accent);letter-spacing:0.1em;margin-bottom:1.25rem;display:flex;align-items:center;gap:0.5rem;transition:text-shadow 0.3s;}
.step:hover .step__num{text-shadow:0 0 22px rgba(37,99,235,0.7);}
.step__num::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(37,99,235,0.3),transparent);}
.step__title{font-size:1.0625rem;font-weight:700;margin-bottom:0.75rem;color:var(--text-1);}
.step__desc{font-size:0.875rem;color:var(--text-2);line-height:1.6;}

/* ── CAPABILITIES GRID ─────────────────────────────────────────── */
.caps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
@media(max-width:900px){.caps{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.caps{grid-template-columns:1fr;}}
.cap{display:flex;flex-direction:column;gap:0.75rem;padding:1.5rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);transition:all 0.2s;}
.cap:hover{border-color:var(--border-3);background:var(--surface-2);transform:translateY(-2px);}
.cap__icon{width:38px;height:38px;border-radius:10px;background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);display:flex;align-items:center;justify-content:center;font-size:1.125rem;color:var(--accent);}
.cap__title{font-size:0.9375rem;font-weight:700;color:var(--text-1);}
.cap__desc{font-size:0.8125rem;color:var(--text-2);line-height:1.55;}

/* ── COMPARE (con / sin) ───────────────────────────────────────── */
.compare{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;border-radius:var(--radius-xl);border:1px solid var(--border);}
@media(max-width:640px){.compare{grid-template-columns:1fr;}}
.compare__col{padding:2.25rem;}
.compare__col--si{background:rgba(34,197,94,0.03);}
.compare__col--no{background:rgba(239,68,68,0.03);border-left:1px solid var(--border);}
@media(max-width:640px){.compare__col--no{border-left:none;border-top:1px solid var(--border);}}
.compare__title{font-family:var(--font-mono);font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;margin-bottom:1.5rem;}
.compare__col--si .compare__title{color:var(--green);}
.compare__col--no .compare__title{color:#f87171;}
.compare__list{list-style:none;display:flex;flex-direction:column;gap:0.875rem;}
.compare__item{display:flex;align-items:flex-start;gap:0.75rem;font-size:0.9rem;color:var(--text-2);line-height:1.5;}
.compare__ic{flex-shrink:0;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.625rem;margin-top:0.1rem;}
.compare__col--si .compare__ic{background:var(--green-lo);color:var(--green);}
.compare__col--no .compare__ic{background:var(--red-lo);color:#f87171;}

/* ── FEATURE SPLIT (texto + bullets) ───────────────────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:3rem;}}
.flist{list-style:none;display:flex;flex-direction:column;gap:0.875rem;margin:1.5rem 0;}
.flist li{display:flex;align-items:flex-start;gap:0.75rem;font-size:0.9375rem;color:var(--text-2);line-height:1.5;}
.flist__ic{flex-shrink:0;width:24px;height:24px;border-radius:7px;background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:0.75rem;margin-top:0.05rem;}
.flist li strong{color:var(--text-1);font-weight:600;}

/* ── STATS (contadores) ────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;}
@media(max-width:768px){.stats{grid-template-columns:1fr 1fr;}}
.stat{background:var(--surface);padding:2rem 1.5rem;text-align:center;}
.stat__val{font-size:clamp(2rem,4vw,2.75rem);font-weight:900;letter-spacing:-0.04em;background:linear-gradient(135deg,var(--text-1),var(--accent-3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.stat__label{font-size:0.8125rem;color:var(--text-2);margin-top:0.5rem;line-height:1.4;}

/* ── DASHBOARD / CHAT MOCKS ────────────────────────────────────── */
.mock{position:relative;z-index:1;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,0.04),0 24px 64px rgba(0,0,0,0.6);}
.mock__header{display:flex;align-items:center;gap:0.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface-2);}
.mock__dots{display:flex;gap:6px;}
.mock__dot{width:10px;height:10px;border-radius:50%;}
.mock__dot:nth-child(1){background:#ef4444;}.mock__dot:nth-child(2){background:#f59e0b;}.mock__dot:nth-child(3){background:#22c55e;}
.mock__title{font-family:var(--font-mono);font-size:0.6875rem;color:var(--text-3);letter-spacing:0.05em;flex:1;}
.mock__live{display:flex;align-items:center;gap:0.375rem;font-family:var(--font-mono);font-size:0.625rem;color:var(--green);}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s ease-in-out infinite;}
.mock__grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);}
.widget{background:var(--surface);padding:1.25rem;transition:background 0.2s;}
.widget:hover{background:var(--surface-2);}
.widget__label{font-family:var(--font-mono);font-size:0.625rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-3);margin-bottom:0.5rem;}
.widget__value{font-size:1.5rem;font-weight:700;letter-spacing:-0.03em;color:var(--text-1);}
.widget__trend{display:inline-flex;align-items:center;gap:0.25rem;font-size:0.6875rem;font-weight:600;margin-top:0.5rem;padding:0.2rem 0.5rem;border-radius:4px;color:var(--green);background:var(--green-lo);}
.widget--accent{background:linear-gradient(135deg,rgba(37,99,235,0.15),rgba(99,102,241,0.08));}
.widget--green{background:linear-gradient(135deg,rgba(34,197,94,0.08),transparent);}
.mock__footer{padding:0.875rem 1.25rem;background:var(--surface-2);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:0.625rem;color:var(--text-3);letter-spacing:0.05em;}
.mock__footer-val{color:var(--accent);}
/* chat */
.chat{padding:1.25rem;display:flex;flex-direction:column;gap:0.625rem;min-height:240px;}
.chat-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#fff;flex-shrink:0;}
.chat-name{font-size:0.9rem;font-weight:600;color:var(--text-1);}
.chat-status{font-size:0.6875rem;color:var(--green);display:flex;align-items:center;gap:0.3rem;}
.msg{font-size:0.8125rem;line-height:1.5;}
.msg--sys{font-family:var(--font-mono);font-size:0.5625rem;color:var(--text-3);text-align:center;letter-spacing:0.05em;padding:0.25rem 0;}
.msg--in{align-self:flex-end;background:var(--surface-3);border:1px solid var(--border);padding:0.5rem 0.875rem;border-radius:12px 0 12px 12px;max-width:82%;color:var(--text-1);}
.msg--out{align-self:flex-start;background:linear-gradient(135deg,var(--accent),var(--accent-h));padding:0.5rem 0.875rem;border-radius:0 12px 12px 12px;max-width:82%;color:#fff;}
.msg--auto{font-family:var(--font-mono);font-size:0.5625rem;color:var(--accent);text-align:center;background:var(--accent-lo);border:1px solid rgba(37,99,235,0.2);padding:0.25rem 0.75rem;border-radius:100px;align-self:center;display:flex;align-items:center;gap:0.3rem;letter-spacing:0.05em;}

/* ── TESTIMONIAL ───────────────────────────────────────────────── */
.testi{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-xl);padding:2rem;}
.testi--center{max-width:680px;margin:0 auto;text-align:center;}
.testi__quote{font-size:1.0625rem;color:var(--text-1);line-height:1.6;font-weight:500;margin-bottom:1.25rem;}
.testi__quote::before{content:'"';color:var(--accent);font-family:Georgia,serif;}
.testi__author{font-size:0.8125rem;color:var(--text-3);}
.testi__author strong{color:var(--text-2);}

/* ── OFFER ─────────────────────────────────────────────────────── */
.offer{padding:6.5rem 0;}
.offer__inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-xl);padding:3.5rem;position:relative;overflow:hidden;box-shadow:0 40px 80px rgba(0,0,0,0.5);}
.offer__inner::before{content:'';position:absolute;top:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(37,99,235,0.12),transparent 70%);pointer-events:none;}
@media(max-width:768px){.offer__inner{grid-template-columns:1fr;gap:2.5rem;padding:2rem;}}
.offer__h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:900;letter-spacing:-0.04em;line-height:1.12;margin-bottom:0.75rem;}
.offer__sub{font-size:1rem;color:var(--accent);font-weight:600;}
.offer__checklist{list-style:none;display:flex;flex-direction:column;gap:0.875rem;margin-bottom:2rem;}
.offer__check{display:flex;align-items:flex-start;gap:0.75rem;font-size:0.9rem;color:var(--text-2);}
.offer__check-icon{width:20px;height:20px;border-radius:50%;background:var(--green-lo);border:1px solid rgba(34,197,94,0.25);display:flex;align-items:center;justify-content:center;font-size:0.625rem;color:var(--green);flex-shrink:0;margin-top:0.1rem;}
.offer__cta-sub{font-size:0.8125rem;color:var(--text-3);margin-top:1rem;}

/* ── FORM ──────────────────────────────────────────────────────── */
.form{display:flex;flex-direction:column;gap:1rem;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-xl);padding:2rem;}
.field{display:flex;flex-direction:column;gap:0.5rem;}
.field label{font-size:0.8125rem;font-weight:600;color:var(--text-2);}
.field input,.field textarea{background:var(--surface-2);border:1px solid var(--border-2);border-radius:var(--radius);padding:0.75rem 1rem;font-size:0.9375rem;font-family:var(--font-sans);color:var(--text-1);transition:border-color 0.2s,box-shadow 0.2s;outline:none;width:100%;}
.field input::placeholder,.field textarea::placeholder{color:var(--text-3);}
.field input:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,0.15);}
.form__legal{font-size:0.75rem;color:var(--text-3);line-height:1.4;}
.form__success{display:none;text-align:center;padding:2.5rem;color:var(--green);font-size:1rem;font-weight:600;}
.form__success.show{display:block;}

/* ── FAQ / ACCORDION ───────────────────────────────────────────── */
.faq__inner{display:grid;grid-template-columns:320px 1fr;gap:4rem;align-items:start;}
@media(max-width:768px){.faq__inner{grid-template-columns:1fr;gap:2.5rem;}}
.faq__h2{font-size:clamp(1.75rem,3.5vw,2.25rem);font-weight:800;letter-spacing:-0.04em;line-height:1.2;margin-bottom:0.75rem;}
.faq__sub{font-size:0.9375rem;color:var(--text-2);}
.accordion{display:flex;flex-direction:column;}
.accordion-item{border-bottom:1px solid var(--border);}
.accordion-item:first-child{border-top:1px solid var(--border);}
.accordion-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 0;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--font-sans);}
.accordion-q{font-size:0.9375rem;font-weight:600;color:var(--text-1);line-height:1.4;flex:1;}
.accordion-icon{width:28px;height:28px;border-radius:8px;background:var(--surface);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-size:0.875rem;color:var(--text-2);flex-shrink:0;transition:all 0.25s;}
.accordion-btn.open .accordion-icon{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(45deg);}
.accordion-body{max-height:0;overflow:hidden;transition:max-height 0.3s ease;}
.accordion-body.open{max-height:320px;}
.accordion-a{font-size:0.9rem;color:var(--text-2);line-height:1.65;padding-bottom:1.25rem;}

/* ── CTA FINAL ─────────────────────────────────────────────────── */
.cta-final{padding:6.5rem 0;text-align:center;position:relative;overflow:hidden;}
.cta-final__bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(37,99,235,0.08),transparent 70%);pointer-events:none;}
.cta-final__border{position:absolute;inset:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.cta-final__inner{position:relative;z-index:1;}
.cta-final__h2{font-size:clamp(2rem,5vw,3.25rem);font-weight:900;letter-spacing:-0.04em;line-height:1.1;margin-bottom:1.25rem;}
.cta-final__sub{font-size:1.0625rem;color:var(--text-2);line-height:1.7;max-width:560px;margin:0 auto 2.5rem;}
.cta-final__group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.cta-final__proof{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap;margin-top:2rem;}
.cta-final__proof span{font-size:0.8125rem;color:var(--text-3);display:flex;align-items:center;gap:0.5rem;}
.cta-final__proof span::before{content:'✓';color:var(--green);font-weight:700;}

/* ── FOOTER ────────────────────────────────────────────────────── */
.footer{padding:4rem 0 2.5rem;border-top:1px solid var(--border);position:relative;z-index:2;}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem;}
@media(max-width:768px){.footer__top{grid-template-columns:1fr;gap:2rem;}}
.footer__tagline{font-size:0.875rem;color:var(--text-3);margin-top:0.75rem;max-width:300px;line-height:1.6;}
.footer__col h4{font-family:var(--font-mono);font-size:0.6875rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-3);margin-bottom:1rem;}
.footer__col a{display:block;font-size:0.875rem;color:var(--text-2);padding:0.3rem 0;transition:color 0.2s;}
.footer__col a:hover{color:var(--text-1);}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.75rem;border-top:1px solid var(--border);}
.footer__copy{font-size:0.8125rem;color:var(--text-3);}
.footer__legal{display:flex;gap:1.5rem;}
.footer__legal a{font-size:0.8125rem;color:var(--text-3);}
.footer__legal a:hover{color:var(--text-2);}

/* ── WHATSAPP FLOAT ────────────────────────────────────────────── */
.whatsapp-float{position:fixed;bottom:1.75rem;right:1.75rem;z-index:200;display:flex;align-items:center;gap:0.625rem;background:#25D366;color:#fff;padding:0.75rem 1.25rem;border-radius:100px;font-size:0.875rem;font-weight:700;box-shadow:0 4px 20px rgba(37,211,102,0.4);animation:waPulse 3s ease-in-out infinite;transition:all 0.2s;}
.whatsapp-float svg{width:20px;height:20px;flex-shrink:0;}
.whatsapp-float:hover{box-shadow:0 8px 30px rgba(37,211,102,0.5);transform:translateY(-2px);}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.4),0 0 0 0 rgba(37,211,102,0.25);}50%{box-shadow:0 4px 20px rgba(37,211,102,0.4),0 0 0 12px rgba(37,211,102,0);}}
.whatsapp-float__text{display:none;}
@media(min-width:640px){.whatsapp-float__text{display:block;}}

/* ── RESPONSIVE NAV ────────────────────────────────────────────── */
@media(max-width:920px){
  .nav__menu,.nav__actions .btn{display:none;}
  .nav__burger{display:flex;}
}

/* ── ANIMACIONES PROFESIONALES ──────────────────────────────────── */

/* gradientFlow — hero em texto */
@keyframes gradientFlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* heroFloat — panel mock sube y baja suavemente */
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero__panel .mock{animation:heroFloat 7s ease-in-out 1s infinite;}

/* badgeShimmer — barrido de luz en el hero badge */
@keyframes badgeShimmer{0%{background-position:200% center}100%{background-position:-200% center}}

/* btnGlow — glow pulsante verde en CTAs clave */
.hero .btn-wa,.cta-final .btn-wa{animation:waPulse 3s ease-in-out infinite;}
.hero .btn-wa:hover,.cta-final .btn-wa:hover{animation:none;}

/* iconPop — iconos trust-bar hacen spring cuando aparecen */
@keyframes iconPop{0%{transform:scale(0.35)}65%{transform:scale(1.22)}100%{transform:scale(1)}}
.stagger.visible > .trust-cell .trust-cell__icon{animation:iconPop 0.55s cubic-bezier(0.34,1.56,0.64,1) both;}
.stagger.visible > .trust-cell:nth-child(1) .trust-cell__icon{animation-delay:0.35s;}
.stagger.visible > .trust-cell:nth-child(2) .trust-cell__icon{animation-delay:0.46s;}
.stagger.visible > .trust-cell:nth-child(3) .trust-cell__icon{animation-delay:0.57s;}
.stagger.visible > .trust-cell:nth-child(4) .trust-cell__icon{animation-delay:0.68s;}

/* statPop — cifras de resultados hacen pop al entrar */
@keyframes statPop{0%{transform:scale(0.55) translateY(10px);opacity:0}72%{transform:scale(1.08) translateY(0)}100%{transform:scale(1) translateY(0);opacity:1}}
.stats.fade-up.visible .stat__val{animation:statPop 0.72s cubic-bezier(0.34,1.56,0.64,1) both;}
.stats.fade-up.visible .stat:nth-child(1) .stat__val{animation-delay:0.05s;}
.stats.fade-up.visible .stat:nth-child(2) .stat__val{animation-delay:0.17s;}
.stats.fade-up.visible .stat:nth-child(3) .stat__val{animation-delay:0.29s;}
.stats.fade-up.visible .stat:nth-child(4) .stat__val{animation-delay:0.41s;}

/* ── REDUCED MOTION ────────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.001ms!important;animation-iteration-count:1!important;transition-duration:0.001ms!important;scroll-behavior:auto!important;}
  .fade-up,.stagger > *{opacity:1!important;transform:none!important;}
}
