/* ============================================================
   MiGuatemala — Sistema de diseño
   Tema CLARO por defecto + modo oscuro (body.dark)
   Tipografía: Space Grotesk (display) + Inter (texto)
   Iconos: Phosphor · Animaciones: GSAP + Lenis
   ============================================================ */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
img,svg,video,iframe{display:block;max-width:100%}
img,svg,video{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}
input,textarea,select{font:inherit;color:inherit}

/* Lenis (scroll suave) — evita conflicto con scroll-behavior */
html:not(.lenis){scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
@media (prefers-reduced-motion:reduce){html:not(.lenis){scroll-behavior:auto}}

/* ---------- Marca (independiente del tema) ---------- */
:root{
  --jade:#12B58F;--jade-deep:#0E9C7C;--jade-soft:#0C8F73;
  --gold:#E1972A;--gold-deep:#C9831C;
  --coral:#FF6A5A;--sky:#4F7DFF;

  --grad-brand:linear-gradient(118deg,#12B58F 0%,#4F7DFF 100%);
  --grad-warm:linear-gradient(118deg,#E1972A 0%,#FF6A5A 100%);
  --grad-mix:linear-gradient(118deg,#12B58F 0%,#E1972A 100%);

  --r-sm:10px;--r:16px;--r-lg:24px;--r-xl:34px;--r-pill:999px;
  --ff-display:'Space Grotesk',system-ui,sans-serif;
  --ff-body:'Inter',system-ui,sans-serif;
  --container:1200px;
  --gut:clamp(20px,5vw,64px);
  --section:clamp(72px,11vw,160px);
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- TEMA CLARO (por defecto) ---------- */
:root{
  --bg:#F6F7F2;
  --bg-2:#EDEFE7;
  --surface:#FFFFFF;
  --surface-2:#F1F3EC;
  --line:rgba(14,20,30,.10);
  --line-strong:rgba(14,20,30,.18);
  --text:#0C111B;
  --text-dim:#4E5763;
  --text-faint:#8A93A1;
  --header-bg:rgba(246,247,242,.72);
  --jade-on:#9bf0d8;          /* tono accent para acentos sutiles */
  --blob-op:.5;
  --shadow-sm:0 2px 12px rgba(20,30,55,.07);
  --shadow:0 24px 60px -22px rgba(20,30,55,.22);
  --grad-fade:linear-gradient(180deg,transparent 40%,rgba(246,247,242,.92));
  color-scheme:light;
}

/* ---------- TEMA OSCURO ---------- */
body.dark{
  --bg:#06080E;
  --bg-2:#0A0D16;
  --surface:#10141F;
  --surface-2:#161B28;
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.17);
  --text:#ECEFF6;
  --text-dim:#9AA4B3;
  --text-faint:#69727F;
  --header-bg:rgba(6,8,14,.7);
  --blob-op:.5;
  --shadow-sm:0 2px 12px rgba(0,0,0,.35);
  --shadow:0 24px 60px -22px rgba(0,0,0,.6);
  --grad-fade:linear-gradient(180deg,transparent 40%,rgba(6,8,14,.9));
  color-scheme:dark;
}

/* ---------- Base ---------- */
body{
  font-family:var(--ff-body);line-height:1.6;background:var(--bg);color:var(--text);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:background-color .55s var(--ease),color .55s var(--ease);
}
::selection{background:var(--jade);color:#04130E}
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px;border:3px solid var(--bg)}

/* ---------- Tipografía ---------- */
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:600;line-height:1.04;letter-spacing:-.02em}
.h-display{font-size:clamp(2.6rem,7.2vw,6.2rem);letter-spacing:-.035em;line-height:.98}
.h1{font-size:clamp(2.2rem,5.2vw,4rem)}
.h2{font-size:clamp(1.9rem,4.2vw,3.2rem)}
.h3{font-size:clamp(1.35rem,2.4vw,1.85rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.32rem);color:var(--text-dim);line-height:1.55;max-width:60ch}
.eyebrow{font-family:var(--ff-display);font-size:.78rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--jade);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--jade);display:inline-block}
.text-grad{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.text-grad-warm{background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:var(--section);position:relative}
.section--tight{padding-block:clamp(48px,7vw,90px)}
.center{text-align:center}
.maxw{max-width:760px}.mx-auto{margin-inline:auto}

/* ---------- Botones ---------- */
.btn{
  --bg-btn:var(--jade);--fg:#04130E;
  position:relative;display:inline-flex;align-items:center;gap:.6em;
  padding:.95em 1.6em;border-radius:var(--r-pill);font-family:var(--ff-display);
  font-weight:600;font-size:.98rem;letter-spacing:-.01em;line-height:1;
  background:var(--bg-btn);color:var(--fg);overflow:hidden;isolation:isolate;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),color .4s var(--ease);
  will-change:transform;
}
.btn i{font-size:1.2em;transition:transform .4s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 36px -12px rgba(18,181,143,.55)}
.btn:hover i{transform:translateX(3px)}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--grad-brand);opacity:0;transition:opacity .45s var(--ease)}
.btn:hover::after{opacity:1}
.btn--warm{--bg-btn:var(--gold)}.btn--warm:hover{box-shadow:0 18px 36px -12px rgba(225,151,42,.55)}
.btn--warm::after{background:var(--grad-warm)}
.btn--ghost{--bg-btn:transparent;--fg:var(--text);box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn--ghost::after{background:var(--jade)}
.btn--ghost:hover{--fg:#04130E;box-shadow:inset 0 0 0 1.5px transparent,0 18px 36px -14px rgba(18,181,143,.5)}
.btn--lg{padding:1.15em 2em;font-size:1.05rem}
.btn--sm{padding:.7em 1.15em;font-size:.85rem}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

.link-arrow{display:inline-flex;align-items:center;gap:.45em;font-family:var(--ff-display);font-weight:600;color:var(--jade)}
.link-arrow i{transition:transform .4s var(--ease)}
.link-arrow:hover i{transform:translateX(5px)}

/* ---------- Theme toggle ---------- */
.theme-toggle{
  width:42px;height:42px;border-radius:var(--r-pill);display:grid;place-items:center;
  box-shadow:inset 0 0 0 1.5px var(--line-strong);font-size:1.2rem;color:var(--text);
  transition:transform .5s var(--ease),box-shadow .4s var(--ease),color .4s var(--ease);
}
.theme-toggle:hover{transform:rotate(20deg) scale(1.06);box-shadow:inset 0 0 0 1.5px var(--jade);color:var(--jade)}

/* ---------- Header ---------- */
.header{position:fixed;inset:0 0 auto 0;z-index:100;padding-block:18px;transition:padding .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease)}
.header.scrolled{padding-block:11px;background:var(--header-bg);backdrop-filter:saturate(160%) blur(16px);-webkit-backdrop-filter:saturate(160%) blur(16px);box-shadow:0 1px 0 var(--line)}
.header__bar{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--ff-display);font-weight:700;font-size:1.18rem;letter-spacing:-.02em}
.brand__mark{width:34px;height:34px;flex:none;transition:transform .5s var(--ease);object-fit:contain}
.brand:hover .brand__mark{transform:rotate(-8deg) scale(1.05)}
.brand b{color:var(--jade)}
.nav{display:flex;align-items:center;gap:6px}
.nav a{position:relative;padding:.55em .9em;border-radius:var(--r-pill);font-size:.94rem;font-weight:500;color:var(--text-dim);transition:color .3s var(--ease)}
.nav a::after{content:"";position:absolute;left:50%;bottom:.35em;width:0;height:2px;background:var(--jade);border-radius:2px;transform:translateX(-50%);transition:width .35s var(--ease)}
.nav a:hover,.nav a.active{color:var(--text)}
.nav a.active::after,.nav a:hover::after{width:18px}
.header__cta{display:flex;align-items:center;gap:12px}
.burger{display:none;width:44px;height:44px;border-radius:var(--r-pill);align-items:center;justify-content:center;box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.burger i{font-size:1.5rem}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:99;background:var(--bg-2);display:flex;flex-direction:column;justify-content:center;gap:8px;padding:var(--gut);transform:translateY(-100%);transition:transform .6s var(--ease)}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{font-family:var(--ff-display);font-size:clamp(1.8rem,7vw,3rem);font-weight:600;padding:.2em 0;border-bottom:1px solid var(--line);opacity:0;transform:translateY(20px)}
.mobile-menu.open a{animation:menuIn .55s var(--ease) forwards}
.mobile-menu.open a:nth-child(1){animation-delay:.08s}
.mobile-menu.open a:nth-child(2){animation-delay:.14s}
.mobile-menu.open a:nth-child(3){animation-delay:.2s}
.mobile-menu.open a:nth-child(4){animation-delay:.26s}
.mobile-menu.open a:nth-child(5){animation-delay:.32s}
.mobile-menu .btn{margin-top:24px;align-self:flex-start;animation-delay:.4s!important}
@keyframes menuIn{to{opacity:1;transform:translateY(0)}}

/* ---------- Intro / cortina de entrada ---------- */
.intro{position:fixed;inset:0;z-index:1000;background:var(--bg-2);display:grid;place-items:center;transition:transform 1s var(--ease),opacity .6s ease}
.intro.done{transform:translateY(-101%)}
.intro__inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.intro__logo{width:74px;height:74px;opacity:0;transform:scale(.7) translateY(12px);animation:introLogo .9s var(--ease) forwards;object-fit:contain}
.intro__word{font-family:var(--ff-display);font-weight:700;font-size:1.6rem;letter-spacing:-.02em;opacity:0;transform:translateY(14px);animation:introLogo .8s var(--ease) .18s forwards}
.intro__word b{color:var(--jade)}
.intro__bar{width:140px;height:3px;border-radius:9px;background:var(--line);overflow:hidden}
.intro__bar::after{content:"";display:block;height:100%;width:40%;border-radius:9px;background:var(--grad-brand);animation:introBar 1.1s var(--ease) forwards}
@keyframes introLogo{to{opacity:1;transform:none}}
@keyframes introBar{0%{transform:translateX(-100%)}100%{transform:translateX(360%)}}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:120px;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.blob{position:absolute;border-radius:50%;filter:blur(64px);opacity:var(--blob-op);will-change:transform;transform:translateZ(0)}
.blob--1{width:46vw;height:46vw;background:radial-gradient(circle,#12B58F,transparent 70%);top:-12vw;left:-8vw;animation:float1 18s ease-in-out infinite}
.blob--2{width:42vw;height:42vw;background:radial-gradient(circle,#4F7DFF,transparent 70%);bottom:-16vw;right:-6vw;opacity:calc(var(--blob-op) * .85);animation:float2 22s ease-in-out infinite}
.blob--3{width:30vw;height:30vw;background:radial-gradient(circle,#E1972A,transparent 70%);top:40%;left:55%;opacity:calc(var(--blob-op) * .65);animation:float3 16s ease-in-out infinite}
@keyframes float1{50%{transform:translate(6vw,4vw) scale(1.08)}}
@keyframes float2{50%{transform:translate(-5vw,-3vw) scale(1.1)}}
@keyframes float3{50%{transform:translate(-4vw,5vw) scale(.92)}}
.hero__grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,#000 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,#000 30%,transparent 75%);opacity:.6}
.hero__inner{position:relative;z-index:2;width:100%;padding-block:clamp(40px,7vw,80px)}
.hero__tag{display:inline-flex;align-items:center;gap:.6em;padding:.5em 1em;border-radius:var(--r-pill);background:color-mix(in srgb,var(--jade) 12%,transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--jade) 35%,transparent);font-size:.82rem;font-weight:500;color:var(--jade-deep);margin-bottom:1.6rem}
.hero__tag .dot{width:7px;height:7px;border-radius:50%;background:var(--jade);box-shadow:0 0 0 4px color-mix(in srgb,var(--jade) 25%,transparent);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px transparent}}
.hero h1{margin-bottom:1.4rem;max-width:16ch}
.hero .lead{margin-bottom:2.2rem}
.hero__stats{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,56px);margin-top:clamp(48px,7vw,84px)}
.stat__num{font-family:var(--ff-display);font-size:clamp(2rem,4vw,3rem);font-weight:600;line-height:1;letter-spacing:-.03em;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__label{font-size:.86rem;color:var(--text-dim);margin-top:.4rem;max-width:18ch}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-faint);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase}
.scroll-cue .mouse{width:22px;height:36px;border:1.5px solid var(--line-strong);border-radius:14px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;background:var(--jade);border-radius:2px;transform:translateX(-50%);animation:wheel 1.6s infinite}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

/* ---------- Marquee ---------- */
.marquee{position:relative;overflow:hidden;border-block:1px solid var(--line);padding-block:22px;background:var(--bg-2)}
.marquee__track{display:flex;width:max-content;animation:marquee 36s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{display:inline-flex;align-items:center;gap:.7em;padding-inline:clamp(24px,4vw,48px);font-family:var(--ff-display);font-size:clamp(1.1rem,2vw,1.6rem);font-weight:500;color:var(--text-dim);white-space:nowrap;transition:color .3s var(--ease)}
.marquee__item:hover{color:var(--jade)}
.marquee__item i{color:var(--jade);font-size:.7em}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Section header ---------- */
.sec-head{max-width:720px;margin-bottom:clamp(40px,5vw,68px)}
.sec-head.center{margin-inline:auto}
.sec-head .eyebrow{margin-bottom:1rem}
.sec-head h2{margin-bottom:1rem}

/* ---------- Cards ---------- */
.card{position:relative;background:var(--surface);border-radius:var(--r-lg);padding:clamp(24px,3vw,38px);box-shadow:inset 0 0 0 1px var(--line),var(--shadow-sm);overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--grad-brand);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s var(--ease);pointer-events:none}
.card:hover{transform:translateY(-7px);box-shadow:inset 0 0 0 1px var(--line),var(--shadow)}
.card:hover::before{opacity:1}

.icon-badge{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;flex:none;background:linear-gradient(150deg,color-mix(in srgb,var(--jade) 18%,transparent),color-mix(in srgb,var(--sky) 12%,transparent));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--jade) 28%,transparent);color:var(--jade-deep);font-size:1.7rem;transition:transform .5s var(--ease)}
.card:hover .icon-badge,.sys:hover .icon-badge,.contact-card:hover .icon-badge,.feature:hover .icon-badge{transform:scale(1.08) rotate(-4deg)}
.icon-badge--warm{background:linear-gradient(150deg,color-mix(in srgb,var(--gold) 20%,transparent),color-mix(in srgb,var(--coral) 12%,transparent));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--gold) 30%,transparent);color:var(--gold-deep)}

/* Feature grid */
.features{display:grid;gap:1px;background:var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:inset 0 0 0 1px var(--line);grid-template-columns:repeat(3,1fr)}
.feature{background:var(--bg);padding:clamp(26px,3vw,40px);transition:background .45s var(--ease),transform .45s var(--ease)}
.feature:hover{background:var(--surface)}
.feature .icon-badge{margin-bottom:1.2rem}
.feature h3{font-size:1.2rem;margin-bottom:.5rem}
.feature p{color:var(--text-dim);font-size:.95rem}

/* Offer */
.offer{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.5vw,32px)}
.offer__card{display:flex;flex-direction:column;gap:1.2rem;min-height:100%}
.offer__card .icon-badge{margin-bottom:.4rem}
.offer__card h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}
.offer__card ul{display:grid;gap:.7rem;margin-top:.4rem}
.offer__card li{display:flex;gap:.7em;align-items:flex-start;color:var(--text-dim);font-size:.96rem}
.offer__card li i{color:var(--jade);font-size:1.15em;margin-top:.1em;flex:none}
.offer__card .btn{margin-top:auto;align-self:flex-start}

/* ---------- System cards ---------- */
.systems{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,28px)}
.sys{position:relative;display:flex;flex-direction:column;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);box-shadow:inset 0 0 0 1px var(--line),var(--shadow-sm);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.sys:hover{transform:translateY(-7px);box-shadow:inset 0 0 0 1px var(--line),var(--shadow)}
.sys__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg-2)}
.sys__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .9s var(--ease);filter:saturate(1.02)}
.sys:hover .sys__media img{transform:scale(1.07)}
.sys__media::after{content:"";position:absolute;inset:0;background:var(--grad-fade)}
.sys__chip{position:absolute;z-index:2;top:14px;left:14px;padding:.4em .8em;border-radius:var(--r-pill);font-size:.74rem;font-weight:600;font-family:var(--ff-display);letter-spacing:.02em;background:color-mix(in srgb,var(--surface) 70%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:inset 0 0 0 1px var(--line-strong);color:var(--jade-deep)}
.sys__body{padding:clamp(22px,2.6vw,30px);display:flex;flex-direction:column;gap:.8rem;flex:1}
.sys__body h3{font-size:1.45rem;display:flex;align-items:center;gap:.5em}
.sys__body h3 i{color:var(--jade)}
.sys__body p{color:var(--text-dim);font-size:.96rem;flex:1}
.sys__tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{font-size:.74rem;font-weight:500;padding:.35em .75em;border-radius:var(--r-pill);background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--line);color:var(--text-dim)}
.sys__foot{display:flex;align-items:center;justify-content:space-between;margin-top:.4rem;padding-top:1rem;border-top:1px solid var(--line)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.5vw,28px);counter-reset:step}
.step{position:relative;padding-top:2.4rem}
.step::before{counter-increment:step;content:"0" counter(step);position:absolute;top:0;left:0;font-family:var(--ff-display);font-size:1rem;font-weight:600;color:var(--jade);letter-spacing:.1em}
.step::after{content:"";position:absolute;top:.55rem;left:2.6rem;right:-1rem;height:1px;background:var(--line)}
.step:last-child::after{display:none}
.step h3{font-size:1.2rem;margin-bottom:.5rem}
.step p{color:var(--text-dim);font-size:.93rem}

/* ---------- Split / about ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.media-frame{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.media-frame img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1s var(--ease)}
.media-frame:hover img{transform:scale(1.05)}
.media-frame--wide img{aspect-ratio:16/11}
.media-frame__badge{position:absolute;bottom:18px;left:18px;right:18px;display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:var(--r);background:color-mix(in srgb,var(--surface) 62%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:inset 0 0 0 1px var(--line-strong)}
.media-frame__badge .icon-badge{width:46px;height:46px;font-size:1.4rem}
.media-frame__badge b{display:block;font-family:var(--ff-display)}
.media-frame__badge span{font-size:.84rem;color:var(--text-dim)}

.value-list{display:grid;gap:1.2rem;margin-top:1.8rem}
.value-list li{display:flex;gap:1rem;align-items:flex-start;transition:transform .4s var(--ease)}
.value-list li:hover{transform:translateX(5px)}
.value-list .icon-badge{width:46px;height:46px;font-size:1.3rem}
.value-list h4{font-family:var(--ff-display);font-size:1.05rem;margin-bottom:.2rem}
.value-list p{color:var(--text-dim);font-size:.93rem}

/* ---------- Stats band ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:inset 0 0 0 1px var(--line)}
.statband__cell{background:var(--surface);padding:clamp(26px,3.4vw,42px);text-align:center;transition:background .4s var(--ease)}
.statband__cell:hover{background:var(--surface-2)}
.statband__num{font-family:var(--ff-display);font-size:clamp(2.2rem,4.5vw,3.4rem);font-weight:600;letter-spacing:-.03em;line-height:1}
.statband__label{color:var(--text-dim);font-size:.9rem;margin-top:.5rem}

/* ---------- Accordion ---------- */
.accordion{display:grid;gap:12px}
.acc{border-radius:var(--r);background:var(--surface);box-shadow:inset 0 0 0 1px var(--line),var(--shadow-sm);overflow:hidden;transition:box-shadow .4s var(--ease)}
.acc.open{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--jade) 45%,transparent),var(--shadow-sm)}
.acc__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;text-align:left;padding:clamp(18px,2.2vw,26px);font-family:var(--ff-display);font-weight:500;font-size:clamp(1rem,1.6vw,1.18rem);transition:color .3s var(--ease)}
.acc__q:hover{color:var(--jade)}
.acc__q .ic{flex:none;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;box-shadow:inset 0 0 0 1.5px var(--line-strong);transition:transform .4s var(--ease),background .4s var(--ease),color .4s var(--ease)}
.acc.open .acc__q .ic{transform:rotate(45deg);background:var(--jade);color:#04130E;box-shadow:none}
.acc__q:hover .ic{color:var(--jade)}
.acc.open .acc__q:hover .ic{color:#04130E}
.acc__a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.acc__a-inner{padding:0 clamp(18px,2.2vw,26px) clamp(20px,2.2vw,26px);color:var(--text-dim);max-width:75ch}
.acc__a-inner a{color:var(--jade);text-decoration:underline;text-underline-offset:3px}

.faq-cats{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px}
.chip-btn{padding:.6em 1.1em;border-radius:var(--r-pill);font-family:var(--ff-display);font-weight:500;font-size:.9rem;color:var(--text-dim);box-shadow:inset 0 0 0 1.5px var(--line);transition:all .3s var(--ease)}
.chip-btn.active,.chip-btn:hover{color:#04130E;background:var(--jade);box-shadow:none;transform:translateY(-2px)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:clamp(40px,6vw,84px);background:var(--bg-2);box-shadow:inset 0 0 0 1px var(--line)}
.cta-band .blob{opacity:calc(var(--blob-op) * .8)}
.cta-band__inner{position:relative;z-index:2;max-width:680px}
.cta-band h2{margin-bottom:1rem}
.cta-band .lead{margin-bottom:2rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(28px,4vw,56px);align-items:start}
.contact-cards{display:grid;gap:14px}
.contact-card{display:flex;gap:16px;align-items:center;padding:20px 22px;border-radius:var(--r);background:var(--surface);box-shadow:inset 0 0 0 1px var(--line),var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.contact-card:hover{transform:translateY(-3px);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--jade) 45%,transparent),var(--shadow)}
.contact-card span{font-size:.8rem;color:var(--text-faint);display:block;text-transform:uppercase;letter-spacing:.12em}
.contact-card b{font-family:var(--ff-display);font-size:1.08rem;font-weight:500}
.form{display:grid;gap:16px;padding:clamp(24px,3vw,38px);border-radius:var(--r-lg);background:var(--surface);box-shadow:inset 0 0 0 1px var(--line),var(--shadow-sm)}
.field{display:grid;gap:7px}
.field label{font-size:.85rem;font-weight:500;color:var(--text-dim)}
.field input,.field textarea,.field select{width:100%;padding:.85em 1em;border-radius:var(--r-sm);background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--line);color:var(--text);transition:box-shadow .3s var(--ease)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;box-shadow:inset 0 0 0 1.5px var(--jade)}
.field textarea{resize:vertical;min-height:120px}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---------- Footer ---------- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding-top:clamp(56px,7vw,90px)}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,48px);padding-bottom:clamp(40px,5vw,64px)}
.footer h4{font-family:var(--ff-display);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);margin-bottom:1.2rem}
.footer__links{display:grid;gap:.7rem}
.footer__links a{color:var(--text-dim);font-size:.95rem;transition:color .3s var(--ease),transform .3s var(--ease);display:inline-flex;align-items:center;gap:.4em;width:fit-content}
.footer__links a:hover{color:var(--jade);transform:translateX(3px)}
.footer__brand p{color:var(--text-dim);font-size:.95rem;max-width:34ch;margin-block:1rem}
.socials{display:flex;gap:10px;margin-top:1.2rem}
.socials a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;box-shadow:inset 0 0 0 1.5px var(--line-strong);font-size:1.2rem;color:var(--text-dim);transition:all .3s var(--ease)}
.socials a:hover{color:#04130E;background:var(--jade);box-shadow:none;transform:translateY(-3px)}
.footer__bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;padding-block:24px;border-top:1px solid var(--line);font-size:.85rem;color:var(--text-faint)}

/* ---------- Page hero interior ---------- */
.page-hero{position:relative;padding-top:clamp(140px,16vw,200px);padding-bottom:clamp(48px,6vw,80px);overflow:hidden}
.breadcrumb{display:flex;gap:.5em;align-items:center;font-size:.85rem;color:var(--text-faint);margin-bottom:1.4rem}
.breadcrumb a:hover{color:var(--jade)}
.breadcrumb i{font-size:.9em}

/* ---------- WhatsApp float ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:90;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:#1FBF5A;color:#fff;font-size:1.9rem;box-shadow:0 14px 34px -10px rgba(31,191,90,.6);transition:transform .35s var(--ease)}
.wa-float:hover{transform:scale(1.08) rotate(6deg)}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #1FBF5A;animation:ring 2.4s infinite}
@keyframes ring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}

/* ---------- Reveal animations (con blur, JS-driven) ---------- */
[data-reveal]{opacity:0;transform:translateY(36px);filter:blur(8px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out),filter 1s var(--ease-out);will-change:opacity,transform,filter}
[data-reveal].in{opacity:1;transform:none;filter:none}
[data-reveal="left"]{transform:translateX(-44px)}
[data-reveal="right"]{transform:translateX(44px)}
[data-reveal="scale"]{transform:scale(.93);filter:blur(10px)}
[data-delay="1"]{transition-delay:.09s}
[data-delay="2"]{transition-delay:.18s}
[data-delay="3"]{transition-delay:.27s}
[data-delay="4"]{transition-delay:.36s}
[data-delay="5"]{transition-delay:.45s}

/* Encabezados palabra por palabra */
.split-word{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.04em}
.split-word > span{display:inline-block;transform:translateY(115%);transition:transform 1s var(--ease-out)}
.reveal-words.in .split-word > span{transform:none}
.reveal-words .split-word:nth-child(1) > span{transition-delay:.02s}
.reveal-words .split-word:nth-child(2) > span{transition-delay:.07s}
.reveal-words .split-word:nth-child(3) > span{transition-delay:.12s}
.reveal-words .split-word:nth-child(4) > span{transition-delay:.17s}
.reveal-words .split-word:nth-child(5) > span{transition-delay:.22s}
.reveal-words .split-word:nth-child(6) > span{transition-delay:.27s}
.reveal-words .split-word:nth-child(7) > span{transition-delay:.32s}
.reveal-words .split-word:nth-child(8) > span{transition-delay:.37s}
.reveal-words .split-word:nth-child(9) > span{transition-delay:.42s}
.reveal-words .split-word:nth-child(n+10) > span{transition-delay:.47s}

@media (prefers-reduced-motion:reduce){
  [data-reveal],.reveal-words .split-word > span{opacity:1!important;transform:none!important;filter:none!important}
  .blob{animation:none!important}
  .intro{display:none!important}
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .nav{display:none}
  .header__cta .btn{display:none}
  .burger{display:flex}
  .features{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .step::after{display:none}
  .statband{grid-template-columns:1fr 1fr}
  .split,.contact-grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}
@media (max-width:680px){
  .systems,.offer{grid-template-columns:1fr}
  .features{grid-template-columns:1fr}
  .form .row2{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .hero{padding-top:100px}
}
