@charset "UTF-8";
/* ============================================================
   Publinovo — Agencia de Marketing Digital
   Sistema visual: carbón + verde lima + azul cian
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink:#2B2D3A;
  --ink-2:#454857;
  --ink-3:#6B6F80;
  --muted:#9AA0B0;

  --green:#8CC63F;
  --green-d:#6FAE2A;
  --blue:#1C9DD7;
  --blue-d:#1683BB;

  --bg:#FFFFFF;
  --bg-soft:#F5F8FA;
  --bg-soft-2:#EDF2F6;
  --line:#E5EAF0;
  --line-2:#D9E0E8;

  --grad: linear-gradient(120deg, var(--green) 0%, #46b39a 48%, var(--blue) 100%);
  --grad-soft: linear-gradient(120deg, rgba(140,198,63,.14), rgba(28,157,215,.14));

  --shadow-sm: 0 1px 2px rgba(43,45,58,.06), 0 2px 8px rgba(43,45,58,.05);
  --shadow-md: 0 6px 20px rgba(43,45,58,.08), 0 2px 6px rgba(43,45,58,.05);
  --shadow-lg: 0 24px 60px -20px rgba(28,40,64,.30), 0 8px 24px -12px rgba(28,40,64,.18);
  --shadow-brand: 0 18px 40px -14px rgba(28,157,215,.45);

  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-pill:999px;

  --maxw:1200px;
  --gut: clamp(20px, 5vw, 64px);

  --ff-head:"Poppins", system-ui, sans-serif;
  --ff-body:"DM Sans", system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
/* overflow-x: clip recorta el desbordamiento horizontal SIN crear un
   contenedor de scroll, por lo que el header con position:sticky sigue
   funcionando. (overflow-x:hidden sí lo rompe.) */
html{ overflow-x:clip }
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer}
h1,h2,h3,h4{font-family:var(--ff-head); color:var(--ink); line-height:1.08; margin:0; font-weight:700; letter-spacing:-.02em}
p{margin:0}
ul{margin:0; padding:0; list-style:none}
:focus-visible{outline:3px solid rgba(28,157,215,.45); outline-offset:2px; border-radius:6px}

.wrap{max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut)}
.divider{ border:0; border-top:1px solid var(--line); height:0; margin:0; }
.section{padding-block:clamp(64px, 9vw, 120px)}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ff-head); font-weight:600; font-size:13px;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--blue-d);
}
.eyebrow::before{content:""; width:22px; height:2px; border-radius:2px; background:var(--grad)}
.eyebrow.center::before{display:none}
.grad-text{
  background:var(--grad); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.lead{font-size:clamp(17px,1.5vw,20px); color:var(--ink-2); line-height:1.65}
.section-head{max-width:680px; margin:0 auto clamp(40px,5vw,64px); text-align:center}
.section-head h2{font-size:clamp(30px,4.4vw,46px)}
.section-head p{margin-top:18px}
.section-head .eyebrow{margin-bottom:16px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--ff-head); font-weight:600; font-size:15.5px;
  padding:14px 26px; border-radius:var(--r-pill); border:1.5px solid transparent;
  transition:transform .18s cubic-bezier(.3,.7,.4,1), box-shadow .25s, background .2s, color .2s;
  white-space:nowrap;
}
.btn svg{width:18px; height:18px}
.btn-primary{ background:var(--grad); color:#fff; box-shadow:var(--shadow-brand) }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 22px 46px -14px rgba(28,157,215,.6) }

.btn-ghost{ background:#fff; color:var(--ink); border-color:var(--line-2) }
.btn-ghost:hover{ border-color:var(--blue); color:var(--blue-d); transform:translateY(-2px) }

.btn-lg{ padding:17px 34px; font-size:17px }
.btn-block{ width:100% }

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky; top:calc(-1 * var(--topbar-h, 45px)); z-index:100;
  background:#fff;
  border-bottom:1px solid transparent;
  transition:border-color .25s, box-shadow .25s;
}
.header.scrolled{ border-bottom-color:var(--line); box-shadow:0 4px 20px rgba(43,45,58,.06) }

/* --- Barra superior (utility) --- */
.topbar{ background:var(--bg-soft); border-bottom:1px solid var(--line) }
.topbar__inner{ display:flex; align-items:center; justify-content:space-between; height:44px; gap:16px }
.topbar__mail{ display:inline-flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-3); transition:color .2s }
.topbar__mail:hover{ color:var(--blue-d) }
.topbar__mail svg{ width:16px; height:16px; opacity:.7 }
.topbar__right{ display:flex; align-items:center; gap:20px }
.topbar__social{ display:flex; align-items:center; gap:4px }
.topbar__social a{ width:30px; height:30px; display:grid; place-items:center; border-radius:8px; color:var(--ink-2); transition:color .2s, background .2s, transform .2s }
.topbar__social a:hover{ color:#fff; background:var(--ink); transform:translateY(-1px) }
.topbar__social a svg{ width:16px; height:16px }
.topbar__wa{ display:flex; align-items:center; gap:10px; padding-left:18px; border-left:1px solid var(--line-2) }
.topbar__wa .ic{ width:34px; height:34px; border-radius:50%; background:#25D366; color:#fff; display:grid; place-items:center; flex-shrink:0; box-shadow:0 4px 12px -3px rgba(37,211,102,.6); transition:transform .22s ease, box-shadow .22s ease }
.topbar__wa .ic svg{ width:19px; height:19px }
.topbar__wa .txt{ line-height:1.05; white-space:nowrap }
.topbar__wa .txt small{ display:block; font-size:10.5px; letter-spacing:.12em; color:var(--ink-3); font-weight:600; font-family:var(--ff-head); text-transform:uppercase }
.topbar__wa .txt b{ font-family:var(--ff-head); font-size:16px; font-weight:700; color:var(--ink); letter-spacing:.01em; transition:color .22s ease }
.topbar__wa:hover .ic{ transform:scale(1.1) rotate(-6deg); box-shadow:0 7px 18px -3px rgba(37,211,102,.85) }
.topbar__wa:hover .txt b{ color:#1Fae57 }
.topbar__wa:hover .txt small{ color:#1Fae57 }

/* --- Barra principal --- */
.header__bar{ display:flex; align-items:center; gap:22px; height:78px }
.brand{ display:flex; align-items:center; flex-shrink:0 }
.brand img{ height:40px; width:auto }

.nav{ display:flex; align-items:center; gap:4px; margin-left:auto }
.nav a{
  font-family:var(--ff-head); font-weight:500; font-size:15.5px; color:var(--ink-2);
  padding:10px 14px; border-radius:var(--r-pill); position:relative; transition:color .2s, background .2s; white-space:nowrap;
}
.nav a:hover{ color:var(--ink); background:var(--bg-soft) }
.nav a.active{ color:var(--green-d); font-weight:600 }
.nav a.active::after{ content:""; position:absolute; left:14px; right:14px; bottom:3px; height:2px; border-radius:2px; background:var(--grad) }

.burger{ display:none; width:46px; height:46px; border:1px solid var(--line); border-radius:12px; margin-left:auto;
  background:#fff; flex-direction:column; gap:5px; align-items:center; justify-content:center }
.burger span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s, opacity .2s }
body.menu-open .burger span:nth-child(1){ transform:translateY(7px) rotate(45deg) }
body.menu-open .burger span:nth-child(2){ opacity:0 }
body.menu-open .burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg) }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0 0 0 auto; width:min(360px,86vw); z-index:210;
  background:#fff; box-shadow:var(--shadow-lg); padding:84px 28px 36px;
  transform:translateX(105%); transition:transform .35s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column; gap:6px; overflow-y:auto;
}
body.menu-open .mobile-menu{ transform:translateX(0) }
.mobile-menu__close{
  position:absolute; top:20px; right:22px; width:44px; height:44px;
  display:grid; place-items:center; border:1px solid var(--line);
  border-radius:12px; background:#fff; color:var(--ink); z-index:1;
  transition:background .2s, color .2s, transform .2s;
}
.mobile-menu__close:hover{ background:var(--ink); color:#fff; transform:rotate(90deg) }
.mobile-menu__close svg{ width:22px; height:22px }
.mobile-menu a{ font-family:var(--ff-head); font-weight:500; font-size:19px; padding:14px 8px; border-bottom:1px solid var(--line); color:var(--ink) }
.mobile-menu .btn{ margin-top:18px }

/* animated WhatsApp CTA inside mobile menu */
.mobile-menu__cta{
  display:inline-flex !important; align-items:center; justify-content:center; gap:11px;
  margin-top:22px; padding:17px 22px !important; border:0 !important; border-radius:var(--r-pill);
  font-family:var(--ff-head); font-weight:700; font-size:17px !important; color:#0e1c2e !important;
  background:linear-gradient(100deg,#a6d957 0%,#7fd0c0 50%,#5bc4e6 100%);
  box-shadow:0 16px 34px -14px rgba(91,196,230,.65);
  position:relative; overflow:hidden;
  animation:waCtaPulse 2.4s ease-in-out infinite;
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s;
}
.mobile-menu__cta::before{ content:""; position:absolute; inset:0; transform:translateX(-120%);
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
  animation:ctaShine 2.8s ease-in-out 1s infinite; }
.mobile-menu__cta:hover{ transform:translateY(-2px); box-shadow:0 22px 44px -14px rgba(91,196,230,.8) }
.mobile-menu__cta-ic{ display:grid; place-items:center; width:26px; height:26px; flex:none; position:relative; z-index:1 }
.mobile-menu__cta-ic svg{ width:22px; height:22px }
@keyframes waCtaPulse{
  0%,100%{ box-shadow:0 16px 34px -14px rgba(91,196,230,.65) }
  50%{ box-shadow:0 16px 40px -10px rgba(91,196,230,.95) }
}
.scrim{ position:fixed; inset:0; background:rgba(20,24,35,.45); opacity:0; visibility:hidden; transition:.3s; z-index:200 }
body.menu-open .scrim{ opacity:1; visibility:visible }

/* ============================================================
   HERO — Dividido
   ============================================================ */
.hero{ position:relative; overflow:hidden }
.hero .wrap{ position:relative; z-index:2 }

/* split */
#hero-a{ padding-block:clamp(56px,7vw,96px) clamp(64px,8vw,110px); background:
   radial-gradient(120% 120% at 90% -10%, rgba(28,157,215,.10), transparent 55%),
   radial-gradient(90% 90% at -5% 110%, rgba(140,198,63,.12), transparent 55%), var(--bg); }
.hero-a__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,5vw,72px); align-items:center }
.hero-a__copy h1{ font-size:clamp(38px,5.4vw,56px); letter-spacing:-.03em }
.hero-a__copy .lead{ margin-top:22px; max-width:520px }
.hero-badge{
  display:inline-flex; align-items:center; gap:10px; padding:8px 16px 8px 10px; margin-bottom:26px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r-pill);
  font-size:14px; font-weight:500; color:var(--ink-2); box-shadow:var(--shadow-sm);
}
.hero-badge b{ font-family:var(--ff-head); color:var(--ink) }
.hero-badge .dot{ width:9px; height:9px; border-radius:50%; background:#8CC63F; box-shadow:0 0 0 4px rgba(140,198,63,.25); animation:pulse 2s infinite }
@keyframes pulse{ 50%{ box-shadow:0 0 0 7px rgba(140,198,63,0) } }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px }
.hero-trust{ display:flex; align-items:center; gap:18px; margin-top:38px; flex-wrap:wrap }
.hero-trust .avatars{ display:flex }
.hero-trust .avatars span{ width:40px; height:40px; border-radius:50%; border:2.5px solid #fff; margin-left:-12px;
  background-size:cover; background-position:center; box-shadow:var(--shadow-sm) }
.hero-trust .avatars span:first-child{ margin-left:0 }
.hero-trust__txt small{ display:block; color:var(--ink-3); font-size:13.5px }
.hero-trust__txt b{ font-family:var(--ff-head); color:var(--ink) }
.stars{ color:#FFB020; letter-spacing:2px; font-size:14px }

.hero-a__media{ position:relative }
.hero-a__media--cutout{ display:flex; justify-content:center }
.hero-a__media--cutout img{ width:100%; max-width:520px; height:auto; filter:drop-shadow(0 24px 50px rgba(20,40,30,.18)) }

.float-card{
  position:absolute; background:#fff; border-radius:var(--r-md); box-shadow:var(--shadow-md);
  padding:14px 18px; display:flex; align-items:center; gap:12px; border:1px solid var(--line);
}
.float-card .fc-ic{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; color:#fff; flex-shrink:0 }
.float-card small{ display:block; font-size:12px; color:var(--ink-3) }
.float-card b{ font-family:var(--ff-head); font-size:19px; color:var(--ink); line-height:1 }
.fc-1{ top:-26px; left:-26px; animation:floaty 5s ease-in-out infinite }
.fc-2{ bottom:30px; right:-24px; animation:floaty 6s ease-in-out infinite .6s }
@keyframes floaty{ 50%{ transform:translateY(-12px) } }

/* ============================================================
   PROBLEMA / Solución
   ============================================================ */
.prob-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(20px,2.6vw,40px); align-items:stretch }
.prob-list{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(24px,2.4vw,36px); box-shadow:var(--shadow-sm) }
.prob-list__tag{ display:inline-block; font-family:var(--ff-head); font-weight:600; font-size:13px;
  letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); margin-bottom:18px }
.prob-list ul{ list-style:none; margin:0; padding:0 }
.prob-item{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-top:1px solid var(--line) }
.prob-item:first-child{ border-top:0; padding-top:4px }
.prob-item:last-child{ padding-bottom:4px }
.prob-item__ic{ flex:none; width:46px; height:46px; border-radius:13px; display:grid; place-items:center;
  background:var(--bg-soft-2); color:var(--ink-2) }
.prob-item__ic svg{ width:23px; height:23px }
.prob-item p{ font-size:clamp(15.5px,1.2vw,17px); color:var(--ink-2); line-height:1.55; margin:0 }
.prob-item p b{ color:var(--ink); font-weight:600 }

.prob-solve{ position:relative; overflow:hidden; isolation:isolate; border-radius:var(--r-lg);
  padding:clamp(30px,3vw,46px); color:#fff; display:flex; flex-direction:column;
  background:
    radial-gradient(90% 90% at 100% 0%, rgba(28,157,215,.22), transparent 55%),
    radial-gradient(70% 70% at 0% 100%, rgba(140,198,63,.18), transparent 55%), var(--ink);
  box-shadow:var(--shadow-lg) }
.prob-solve__deco{ position:absolute; z-index:-1; width:220px; height:220px; border-radius:50%;
  top:-90px; right:-70px; background:rgba(255,255,255,.05) }
.prob-solve__kicker{ font-family:var(--ff-head); font-weight:600; font-size:13px; letter-spacing:.08em;
  text-transform:uppercase; color:#a6d957 }
.prob-solve h3{ color:#fff; font-size:clamp(22px,2.3vw,30px); line-height:1.2; margin:14px 0 18px; letter-spacing:-.02em }
.prob-solve p{ color:rgba(255,255,255,.78); font-size:clamp(15px,1.15vw,16.5px); line-height:1.65; margin:0 0 14px }
.prob-solve .hero-actions{ margin-top:auto; padding-top:10px }

/* ============================================================
   TRUST / Contadores
   ============================================================ */
.trust{ padding-block:clamp(56px,7vw,96px); background:var(--bg-soft) }
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,1.8vw,24px) }
.trust-card{ position:relative; overflow:hidden; isolation:isolate;
  border-radius:var(--r-lg); padding:clamp(26px,2.4vw,36px) clamp(22px,2vw,30px);
  min-height:clamp(180px,16vw,220px); display:flex; flex-direction:column; justify-content:flex-end;
  color:#fff; box-shadow:var(--shadow-md); transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s }
.trust-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg) }
.trust-card--green{ background:linear-gradient(150deg,#9BD24B 0%,#6FAE2A 100%) }
.trust-card--blue{ background:linear-gradient(150deg,#34AEE3 0%,#1683BB 100%) }
.trust-card--teal{ background:linear-gradient(150deg,#4FC3A4 0%,#2C8E8E 100%) }
.trust-card--ink{ background:linear-gradient(150deg,#3A4150 0%,#23252F 100%) }
.trust-card b{ font-family:var(--ff-head); font-weight:700; line-height:.95; letter-spacing:-.03em;
  font-size:clamp(40px,4.6vw,60px); display:block }
.trust-card small{ font-size:clamp(13.5px,1vw,15px); line-height:1.45; color:rgba(255,255,255,.88);
  margin-top:14px; font-weight:500; max-width:22ch }
.trust-card__deco{ position:absolute; z-index:-1; width:130px; height:130px; border-radius:50%;
  top:-44px; right:-40px; background:rgba(255,255,255,.16); transition:transform .5s cubic-bezier(.2,.7,.2,1) }
.trust-card::after{ content:""; position:absolute; z-index:-1; width:80px; height:80px; border-radius:50%;
  bottom:-34px; left:-24px; background:rgba(255,255,255,.08) }
.trust-card:hover .trust-card__deco{ transform:scale(1.35) translate(-6px,6px) }

/* ============================================================
   SERVICIOS
   ============================================================ */
.svc-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px }
.svc{
  position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:42px 28px 32px; text-align:center; display:flex; flex-direction:column; align-items:center;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, border-color .3s;
  overflow:hidden; isolation:isolate;
}
.svc::before{ content:""; position:absolute; z-index:-1; top:26px; left:50%; transform:translateX(-50%);
  width:128px; height:128px; border-radius:50%; background:var(--grad-soft); opacity:.55; filter:blur(12px); transition:opacity .45s, transform .45s }
.svc:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:transparent }
.svc:hover::before{ opacity:1; transform:translateX(-50%) scale(1.18) }
.svc__ic{ height:78px; display:flex; align-items:center; justify-content:center; margin-bottom:22px;
  color:var(--green);
  transform:translateZ(0); will-change:transform; backface-visibility:hidden;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), color .4s }
.svc:hover .svc__ic{ transform:translateY(-4px) scale(1.1); color:var(--blue) }
.svc__ic svg{ width:62px; height:62px; stroke-width:1.6; filter:drop-shadow(0 10px 18px rgba(140,198,63,.4)); transition:filter .4s;
  will-change:filter; backface-visibility:hidden; transform:translateZ(0) }
.svc:hover .svc__ic svg{ filter:drop-shadow(0 14px 24px rgba(28,157,215,.45)) }
.svc h3{ font-size:19px; margin-bottom:10px }
.svc p{ font-size:14.5px; color:var(--ink-3); line-height:1.55; max-width:24ch }
.svc.featured{ grid-column:span 2; background:var(--ink); border-color:transparent; color:#fff;
  display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:start; padding:34px }
.svc.featured h3{ color:#fff; font-size:23px }
.svc.featured p{ color:rgba(255,255,255,.75); font-size:15.5px }
.svc.featured .svc__ic{ background:var(--grad); color:#fff }

.svc .more{ display:inline-flex; align-items:center; gap:7px; margin-top:auto; padding-top:18px;
  font-family:var(--ff-head); font-weight:600; font-size:14px; color:var(--blue-d);
  opacity:0; transform:translateY(8px); pointer-events:none;
  transition:opacity .3s, transform .3s, color .25s }
.svc:hover .more{ opacity:1; transform:translateY(0); pointer-events:auto }
.svc .more span{ display:inline-grid; place-items:center; width:22px; height:22px; border-radius:50%;
  background:var(--grad-soft); color:var(--blue-d); font-size:13px; transition:transform .3s, background .3s, color .3s }
.svc .more:hover{ color:var(--green-d) }
.svc:hover .more span{ background:var(--grad); color:#fff; transform:translateX(3px) }

/* ============================================================
   VIDEOS IA — diferenciador
   ============================================================ */
.ai{ background:
  radial-gradient(80% 120% at 100% 0%, rgba(28,157,215,.16), transparent 55%),
  radial-gradient(70% 100% at 0% 100%, rgba(140,198,63,.12), transparent 55%), var(--ink);
  color:#fff; overflow:hidden; position:relative }
.ai .grad-text{ background:linear-gradient(120deg,#a6d957,#5bc4e6); -webkit-background-clip:text; background-clip:text }

/* Formulario de guía (sección oscura) */
.ai__form{ max-width:960px; margin:0 auto }
.ai__form .section-head{ margin-bottom:clamp(28px,3.4vw,40px) }
.ai__form .eyebrow{ color:#7dd3e6 }
.ai__form .eyebrow::before{ background:linear-gradient(90deg,#a6d957,#5bc4e6) }
.ai__form .section-head h2{ color:#fff; font-size:clamp(30px,4.4vw,48px) }
.ai__form .section-head .lead{ color:rgba(255,255,255,.74); margin-top:18px }
.ai__form .section-head .lead b{ color:#fff; font-weight:700 }
.lead-form__hint{ text-align:center; color:rgba(255,255,255,.58); font-size:14.5px; margin-bottom:26px }
.lead-form__grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px }
.lf-field{ position:relative; display:flex; flex-direction:column }
.lf-field input, .lf-field select{ width:100%; height:58px; padding:0 20px; border:1.5px solid transparent;
  border-radius:14px; background:#fff; color:var(--ink); font-family:var(--ff-body); font-size:15.5px;
  transition:box-shadow .2s, border-color .2s; -webkit-appearance:none; appearance:none }
.lf-field input::placeholder{ color:var(--muted) }
.lf-field select{ color:var(--muted); cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%239AA0B0' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 18px center; padding-right:48px }
.lf-field select.has-value{ color:var(--ink) }
.lf-field input:focus, .lf-field select:focus{ outline:none; border-color:#5bc4e6; box-shadow:0 0 0 4px rgba(91,196,230,.22) }
.lf-field.invalid input, .lf-field.invalid select{ border-color:#ff6f6f; box-shadow:0 0 0 4px rgba(255,111,111,.18) }
.lf-error{ display:none; color:#ffb0b0; font-size:12.5px; margin:7px 4px 0; font-weight:500 }
.lf-field.invalid .lf-error{ display:block }
/* Campo opcional del lead-form (app.js no valida los que no son .lf-field) */
.lf-optional{ margin-top:18px }
.lead-form__grid .lf-optional{ margin-top:0 }   /* dentro de la retícula = media columna como .lf-field */
.lf-optional input{ width:100%; height:58px; padding:0 20px; border:1.5px solid transparent;
  border-radius:14px; background:#fff; color:var(--ink); font-family:var(--ff-body); font-size:15.5px;
  transition:box-shadow .2s, border-color .2s; -webkit-appearance:none; appearance:none }
.lf-optional input::placeholder{ color:var(--muted) }
.lf-optional input:focus{ outline:none; border-color:#5bc4e6; box-shadow:0 0 0 4px rgba(91,196,230,.22) }
/* Teléfono + toggle WhatsApp embebido (no altera la altura/simetría) */
.lf-field--phone input[type="tel"]{ padding-left:54px !important; padding-right:148px }

/* ── intl-tel-input: apariencia general del selector de país ────────────────
   Conserva borde, fondo, tipografía, sombra y :focus del input original.    */
.iti{ display:block; width:100% }
.iti__country-container{ top:0; bottom:0; left:4px; padding:0 }
.iti__selected-country{ height:100%; background:transparent; border-radius:12px 0 0 12px }
.iti__selected-country-primary{ height:100%; padding:0 6px 0 10px }
.iti__selected-country:hover,
.iti__selected-country:focus{ background:rgba(28,157,215,.07) }
.iti__search-input{ font-family:var(--ff-body); font-size:14.5px; color:var(--ink) }
.iti__dropdown-content{
  font-family:var(--ff-body); border-radius:12px;
  box-shadow:0 16px 40px rgba(13,30,52,.18); max-width:calc(100vw - 32px);
}
.iti__country-name{ color:var(--ink) }
.iti__dial-code{ color:var(--muted) }
/* Cualquier input de teléfono ya envuelto por intl-tel-input deja hueco a la bandera */
.iti input[type="tel"]{ padding-left:54px !important }
.lf-field--phone .iti__selected-country{ border-radius:14px 0 0 14px }


.lf-wa{ position:absolute; top:29px; right:7px; transform:translateY(-50%);
  display:flex; align-items:center; gap:7px; height:42px; padding:0 13px 0 11px;
  border-radius:11px; background:#eef4e2; cursor:pointer; user-select:none;
  transition:background .18s, box-shadow .18s }
.lf-wa input{ position:absolute; opacity:0; width:0; height:0; margin:0 }
.lf-wa__box{ display:flex; align-items:center; justify-content:center; flex:none;
  width:24px; height:24px; border-radius:7px; background:#fff; color:#cfd6c4;
  box-shadow:inset 0 0 0 1.5px #d4ddc4; transition:background .18s, color .18s, box-shadow .18s }
.lf-wa__box svg{ width:16px; height:16px }
.lf-wa__txt{ font-family:var(--ff-body); font-size:13.5px; font-weight:600; color:#6f7d57; transition:color .18s }
.lf-wa:hover{ background:#e6efd5 }
.lf-wa input:checked ~ .lf-wa__box{ background:#25D366; color:#fff; box-shadow:inset 0 0 0 1.5px #25D366 }
.lf-wa input:checked ~ .lf-wa__txt{ color:#3f7a25 }
.lf-wa input:focus-visible ~ .lf-wa__box{ box-shadow:0 0 0 3px rgba(91,196,230,.45) }
.lf-check{ display:flex; align-items:center; justify-content:center; gap:11px; margin-top:24px;
  color:rgba(255,255,255,.82); font-size:14.5px; cursor:pointer }
.lf-check input{ width:19px; height:19px; flex:none; accent-color:#8CC63F; cursor:pointer }
.lf-check a{ color:#a6d957; text-decoration:none; transition:color .2s }
.lf-check a:hover{ color:#fff }
.lf-check.invalid{ color:#ffb0b0 }
.lf-actions{ display:flex; justify-content:center; margin-top:28px }
.lf-success{ text-align:center; margin-top:20px; color:#a6d957; font-family:var(--ff-head); font-weight:600; font-size:16px }

/* ============================================================
   PROCESO
   ============================================================ */
.proc-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; counter-reset:step }
.proc{ position:relative; padding-top:18px }
.proc__num{ font-family:var(--ff-head); font-weight:700; font-size:54px; line-height:1;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent }
.proc h3{ font-size:20px; margin:16px 0 10px }
.proc p{ font-size:15px; color:var(--ink-3) }
.proc::before{ content:""; position:absolute; top:8px; left:0; width:34px; height:4px; border-radius:4px; background:var(--grad) }

/* ============================================================
   Fondo gris de sección (Casos)
   ============================================================ */
.stats{ background:var(--bg-soft) }

/* ============================================================
   CASOS DE ÉXITO
   ============================================================ */
.cases-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px }
.cases-more{ display:flex; justify-content:center; margin-top:44px }
.btn-shine{ position:relative; overflow:hidden; isolation:isolate }
.btn-shine span{ transition:transform .3s }
.btn-shine:hover span{ transform:translateX(4px) }
.btn-shine::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(110deg, transparent 20%, rgba(255,255,255,.55) 50%, transparent 80%);
  transform:translateX(-130%); }
.btn-shine:hover::after{ animation:btnShine .9s ease }
@keyframes btnShine{ from{ transform:translateX(-130%) } to{ transform:translateX(130%) } }
.case{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  position:relative; display:flex; flex-direction:column; transition:transform .25s, box-shadow .25s }
.case:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md) }
.case__img{ aspect-ratio:16/10; background:var(--grad-soft); overflow:hidden; position:relative }
.case__img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s }
.case:hover .case__img img{ transform:scale(1.06) }
.case__tag{ position:absolute; top:14px; left:14px; background:rgba(255,255,255,.92); color:var(--ink);
  font-family:var(--ff-head); font-weight:600; font-size:12.5px; padding:6px 12px; border-radius:var(--r-pill) }
#casos .case__tag{ top:auto; left:auto; bottom:14px; right:14px }
.case__body{ padding:24px; display:flex; flex-direction:column; flex:1 }
.case__body h3{ font-size:19px }
.case__body p{ font-size:14.5px; color:var(--ink-3); margin-top:8px }
.case__quote{ margin:14px 0 0; padding:13px 16px; background:var(--bg-soft);
  border-left:3px solid var(--green-d); border-radius:var(--r-md) }
.case__quote p{ margin:0; font-size:14px; line-height:1.55; color:var(--ink-2); font-style:italic }
.case__quote cite{ display:block; margin-top:8px; font-style:normal; font-family:var(--ff-head);
  font-weight:600; font-size:12.5px; color:var(--green-d) }

.case__tags{ display:flex; flex-wrap:wrap; gap:8px }
.case__chip{ font-family:var(--ff-head); font-weight:600; font-size:12px; color:var(--ink-2);
  background:var(--grad-soft); border:1px solid var(--line); padding:5px 11px; border-radius:var(--r-pill) }
.case__foot{ display:flex; align-items:center; flex-wrap:wrap; justify-content:flex-start; gap:12px;
  margin-top:18px; margin-bottom:16px; padding-top:18px; border-top:1px solid var(--line) }
.case__cta{ width:100%; margin-top:auto; padding:13px 20px; font-size:14.5px }
.case__cta span{ transition:transform .25s }
.case__cta:hover span{ transform:translateX(4px) }

/* --- Posts del blog (WordPress) --- */
.post__meta{ display:flex; align-items:center; flex-wrap:wrap; gap:8px 14px; font-family:var(--ff-head);
  font-size:12.5px; color:var(--ink-3); margin-bottom:12px }
.post__meta .pm-item{ display:inline-flex; align-items:center; gap:6px }
.post__meta svg{ width:14px; height:14px; opacity:.75 }
.post__meta .pm-dot{ width:3px; height:3px; border-radius:50%; background:var(--line-2) }
.post__body h3{ transition:color .2s }
.case:hover .post__body h3{ color:var(--blue-d) }
.post__more{ display:inline-flex; align-items:center; gap:8px; margin-top:16px;
  font-family:var(--ff-head); font-weight:600; font-size:14px; color:var(--blue-d) }
.post__more svg{ width:15px; height:15px; transition:transform .25s }
.case:hover .post__more svg{ transform:translateX(4px) }
.case__tag--cat{ background:var(--ink); color:#fff }

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.testi{ background:var(--bg-soft); padding-bottom:clamp(28px,3.5vw,44px) }
#casos{ padding-top:clamp(28px,3.5vw,44px) }
.testi .wrap{ max-width:1320px }
.testi-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:28px }
.tcard{ flex:1 1 320px; max-width:480px; margin:0; position:relative; overflow:hidden; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:38px 36px;
  display:flex; flex-direction:column; box-shadow:var(--shadow-sm); transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s }
.tcard:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md) }
.tcard .stars{ font-size:16px; margin-bottom:16px; position:relative; z-index:1 }
.tcard p{ font-size:16.5px; color:var(--ink-2); line-height:1.65; flex:1; position:relative; z-index:1 }
.tcard .quote{ position:absolute; top:6px; right:26px; z-index:0; pointer-events:none;
  font-family:var(--ff-head); font-weight:700; font-size:120px; line-height:1; color:var(--green); opacity:.13; height:auto }
.tcard__who{ position:relative; z-index:1; display:flex; align-items:center; gap:13px; margin-top:24px; padding-top:22px; border-top:1px solid var(--line) }
.tcard__who .av{ width:48px; height:48px; border-radius:50%; background-size:cover; background-position:center; flex-shrink:0; background-color:var(--bg-soft-2) }
.tcard__who b{ font-family:var(--ff-head); font-size:15.5px; display:block }
.tcard__who small{ color:var(--ink-3); font-size:13px }

/* ============================================================
   PLANES
   ============================================================ */
.plans-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch }
.plan{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:34px 30px;
  display:flex; flex-direction:column; transition:transform .25s, box-shadow .25s }
.plan:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md) }
.plan__name{ font-family:var(--ff-head); font-weight:600; font-size:14px; letter-spacing:.06em; text-transform:uppercase; color:var(--blue-d) }
.plan h3{ font-size:26px; margin:14px 0 6px }
.plan__sub{ color:var(--ink-3); font-size:14.5px; min-height:42px }

.plan ul{ display:flex; flex-direction:column; gap:13px; margin:8px 0 28px; flex:1 }
.plan li{ display:flex; gap:11px; font-size:15px; color:var(--ink-2); align-items:flex-start }
.plan li svg{ width:19px; height:19px; color:var(--green-d); flex-shrink:0; margin-top:2px }
.plan.featured{ background:var(--ink); border-color:transparent; color:#fff; box-shadow:var(--shadow-lg); position:relative }
.plan.featured h3{ color:#fff }
.plan.featured .plan__sub,.plan.featured li{ color:rgba(255,255,255,.78) }

.plan.featured .plan__name{ color:var(--green) }
.plan.featured li svg{ color:var(--green) }
.plan__flag{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--grad); color:#fff;
  font-family:var(--ff-head); font-weight:600; font-size:12px; padding:6px 16px; border-radius:var(--r-pill); white-space:nowrap }

.socials{ display:flex; gap:12px; margin-top:30px }
.socials a{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center;
  background:rgba(255,255,255,.1); color:#fff; transition:transform .2s, background .2s }
.socials a:hover{ transform:translateY(-3px); background:var(--grad) }
.socials a svg{ width:21px; height:21px }

.cform{ background:#fff; border-radius:var(--r-lg); padding:clamp(26px,3vw,38px); color:var(--ink); box-shadow:var(--shadow-lg) }
.cform h3{ font-size:22px; margin-bottom:6px }
.cform > p{ color:var(--ink-3); font-size:14.5px; margin-bottom:22px }
.field{ margin-bottom:16px }
.field label{ display:block; font-family:var(--ff-head); font-weight:500; font-size:13.5px; margin-bottom:7px; color:var(--ink-2) }
.field input,.field select,.field textarea{ width:100%; padding:13px 15px; border:1.5px solid var(--line-2);
  border-radius:12px; font-family:var(--ff-body); font-size:15px; color:var(--ink); background:var(--bg-soft); transition:border-color .2s, background .2s }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--blue); background:#fff }
.field textarea{ resize:vertical; min-height:96px }

/* floating WhatsApp */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:90; width:60px; height:60px; border-radius:50%;
  background:#25D366; color:#fff; display:grid; place-items:center; box-shadow:0 14px 34px -8px rgba(37,211,102,.6);
  transition:transform .2s; }
.wa-float:hover{ transform:scale(1.08) }
.wa-float svg{ width:30px; height:30px }
.wa-float::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #25D366; animation:ripple 2.4s infinite }

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-final{ position:relative; overflow:hidden; isolation:isolate;
  padding-block:clamp(72px,9vw,120px); text-align:center; color:#fff;
  background:
    radial-gradient(120% 140% at 85% 0%, rgba(28,157,215,.55), transparent 55%),
    radial-gradient(110% 130% at 10% 100%, rgba(140,198,63,.42), transparent 52%),
    linear-gradient(135deg, #15324a 0%, #11253a 55%, #0e1c2e 100%) }
.cta-final__blob{ position:absolute; z-index:-1; border-radius:50%; filter:blur(8px); opacity:.5; pointer-events:none }
.cta-final__blob--1{ width:300px; height:300px; top:-90px; right:-60px;
  background:radial-gradient(circle at 30% 30%, rgba(28,157,215,.8), transparent 70%); animation:ctaFloat 11s ease-in-out infinite }
.cta-final__blob--2{ width:260px; height:260px; bottom:-80px; left:-50px;
  background:radial-gradient(circle at 60% 40%, rgba(140,198,63,.7), transparent 70%); animation:ctaFloat 13s ease-in-out infinite reverse }
.cta-final__grid-deco{ position:absolute; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(70% 60% at 50% 50%, #000, transparent 80%);
  mask-image:radial-gradient(70% 60% at 50% 50%, #000, transparent 80%) }
@keyframes ctaFloat{ 0%,100%{ transform:translate(0,0) scale(1) } 50%{ transform:translate(18px,22px) scale(1.08) } }

.cta-final__inner{ max-width:780px; margin:0 auto; position:relative }
.cta-final__eyebrow{ display:inline-block; font-family:var(--ff-head); font-weight:600; font-size:13px;
  letter-spacing:.16em; text-transform:uppercase; color:#a6d957;
  padding:8px 18px; border:1px solid rgba(166,217,87,.35); border-radius:var(--r-pill); margin-bottom:24px }
.cta-final h2{ font-size:clamp(32px,5vw,56px); line-height:1.08; letter-spacing:-.025em; color:#fff; margin-bottom:24px; text-wrap:balance }
.cta-final__hl{ position:relative; background:linear-gradient(100deg,#a6d957,#5bc4e6); -webkit-background-clip:text; background-clip:text; color:transparent }
.cta-final p{ font-size:clamp(16px,1.5vw,18.5px); line-height:1.7; color:rgba(255,255,255,.78); max-width:68ch; margin:0 auto 16px }
.cta-final p b{ color:#fff; font-weight:600 }
.cta-final__kick{ font-family:var(--ff-head); font-weight:600; color:#fff !important; font-size:clamp(17px,1.6vw,20px); margin-top:4px; margin-bottom:38px }

.cta-final__actions{ display:flex; flex-direction:column; align-items:center; gap:14px }
.cta-final__btn{ display:inline-flex; align-items:center; gap:13px; font-family:var(--ff-head); font-weight:700;
  font-size:clamp(17px,1.6vw,19px); color:#0e1c2e; background:linear-gradient(100deg,#a6d957 0%,#7fd0c0 50%,#5bc4e6 100%);
  padding:19px 34px; border-radius:var(--r-pill); box-shadow:0 18px 40px -14px rgba(91,196,230,.6);
  position:relative; overflow:hidden; transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s }
.cta-final__btn::before{ content:""; position:absolute; inset:0; transform:translateX(-120%);
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent); transition:none }
.cta-final__btn:hover{ transform:translateY(-3px); box-shadow:0 24px 50px -14px rgba(91,196,230,.75) }
.cta-final__btn:hover::before{ animation:ctaShine .9s ease }
@keyframes ctaShine{ from{ transform:translateX(-120%) } to{ transform:translateX(120%) } }
.cta-final__btn-ic{ display:grid; place-items:center; width:30px; height:30px; flex:none }
.cta-final__btn-ic svg{ width:24px; height:24px }
.cta-final__free{ font-size:14px; color:rgba(255,255,255,.6) }

@media (prefers-reduced-motion: no-preference){
  .cta-pop{ opacity:0; transform:translateY(22px) }
  .cta-final__inner.in .cta-pop{ animation:ctaPop .7s cubic-bezier(.2,.8,.25,1) both; animation-delay:calc(var(--i) * .12s) }
}
@keyframes ctaPop{ from{ opacity:0; transform:translateY(22px) } to{ opacity:1; transform:none } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:#eff1f3; color:var(--ink-3); padding-block:64px 28px }
.footer__top{ display:grid; grid-template-columns:2fr .85fr; column-gap:clamp(36px,4vw,64px); row-gap:16px; padding-bottom:42px; border-bottom:1px solid var(--line-2) }
.footer__top > *{ min-width:0 }
.footer__about, .footer__links, .footer__contact{ min-width:0 }
.footer h3{ color:var(--ink); font-size:14px; font-family:var(--ff-head); text-transform:uppercase; letter-spacing:.08em; margin-bottom:18px }

.footer__about p{ font-size:14.5px; line-height:1.75; max-width:62ch }
.footer__about p a{ color:var(--green-d); font-weight:600; text-decoration:none;
  border-bottom:1px solid transparent; transition:border-color .2s, color .2s }
.footer__about p a:hover{ color:var(--ink); border-bottom-color:currentColor }
.footer__about p b, .footer__about p strong{ color:var(--ink) }
.footer__more{ display:inline-flex; align-items:center; gap:7px; margin-top:18px;
  font-family:var(--ff-head); font-weight:600; font-size:13.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink) }
.footer__more span{ color:var(--green-d); font-size:17px; transition:transform .25s }
.footer__more:hover span{ transform:translateX(4px) }

.footer__links{ grid-column:1 / 2; display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:4px }
.footer ul{ display:flex; flex-direction:column; gap:12px }
.footer ul a{ position:relative; display:inline-flex; align-items:baseline; gap:9px; padding-left:15px;
  font-size:14px; transition:color .2s, padding .2s }
.footer ul a::before{ content:"\203A"; position:absolute; left:0; color:var(--green-d); font-weight:700 }
.footer ul a:hover{ color:var(--ink); padding-left:19px }

.footer__contact{ grid-column:2 / 3; grid-row:1 / 3 }
.fc-line{ display:flex; align-items:center; gap:13px; margin-bottom:16px; font-size:14.5px; color:var(--ink-3); transition:color .2s; min-width:0 }
.fc-line > span:last-child, .fc-line > div{ min-width:0; overflow-wrap:anywhere }
a.fc-line:hover{ color:var(--ink) }
a.fc-line:hover b{ color:var(--green-d); transition:color .2s }
a.fc-line[href^="https://wa.me"]:hover b{ color:#25d366 }
a.fc-line[href^="https://wa.me"]:hover .fc-ic{ border-color:#25d366; color:#25d366 }
a.fc-line[href^="tel:"]:hover .fc-ic{ border-color:var(--green-d); color:var(--green-d) }
.fc-line--lg b{ font-family:var(--ff-head); font-size:21px; font-weight:700; color:var(--ink); letter-spacing:-.01em }
.fc-line--text b{ color:var(--ink); font-weight:600 }
.fc-ic{ flex:none; width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
  border:1.5px solid var(--line-2); color:var(--green-d) }
.fc-ic svg{ width:19px; height:19px }
.fc-ic--wa{ color:#25D366 }
.footer__social-title{ margin-top:30px }

.socials{ display:flex; gap:11px; margin-top:0; flex-wrap:wrap }
.socials a{ width:42px; height:42px; border-radius:50%; display:grid; place-items:center;
  background:#fff; border:1px solid var(--line-2); color:var(--ink-2); transition:transform .2s, background .2s, color .2s, border-color .2s }
.socials a:hover{ color:#fff; border-color:transparent }
.socials a:hover{ transform:translateY(-3px); background:var(--grad) }
.socials a svg{ width:19px; height:19px }
.footer__logo-link{ display:inline-block; transition:opacity .2s }
.footer__logo-link:hover{ opacity:.7 }
.footer__logo{ display:block; height:54px; width:auto; margin:34px 0 0; opacity:1 }

.footer__bottom{ display:flex; align-items:center; justify-content:center; text-align:center; gap:14px; padding-top:24px; font-size:13px; flex-wrap:wrap; color:var(--muted) }
.footer__brand-link{ color:inherit; transition:color .2s }
.footer__brand-link:hover{ color:var(--ink) }

/* ============================================================
   Scroll reveal  (estado base = VISIBLE; se anima DESDE oculto)
   El estado visible es la base, así que si el JS o la animación
   no llegan a completarse, el contenido SIEMPRE se ve.
   ============================================================ */
.reveal{ opacity:1; transform:none }
@media (prefers-reduced-motion: no-preference){
  /* Con JS activo: ocultar lo aún no revelado para que no destelle (flashazo)
     antes de animar al entrar en viewport. Sin JS o reduced-motion: queda visible. */
  html.js .reveal:not(.in){ opacity:0; transform:translateY(26px) }
  .reveal.in{ animation:revealUp .7s cubic-bezier(.2,.7,.3,1) both }
  .reveal.in[data-d="1"]{ animation-delay:.08s }
  .reveal.in[data-d="2"]{ animation-delay:.16s }
  .reveal.in[data-d="3"]{ animation-delay:.24s }
  .reveal.in[data-d="4"]{ animation-delay:.32s }
}
@keyframes revealUp{ from{ opacity:0; transform:translateY(26px) } to{ opacity:1; transform:none } }
@media (prefers-reduced-motion: no-preference){
  .testi-grid .reveal.in{ animation-name:testiIn; animation-duration:.8s;
    animation-timing-function:cubic-bezier(.2,.85,.25,1); animation-fill-mode:both }
}
@keyframes testiIn{ from{ opacity:0; transform:translateY(38px) scale(.94) } to{ opacity:1; transform:none } }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; animation:none }
  *{ animation:none !important }
  html{ scroll-behavior:auto }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .svc-grid{ grid-template-columns:repeat(2,1fr) }
  .svc.featured{ grid-column:span 2 }
  .proc-grid{ grid-template-columns:repeat(2,1fr); gap:36px 24px }
  .footer__top{ grid-template-columns:1fr 1fr }
  .footer__links{ grid-column:1 / 2; margin-top:20px }
  .footer__contact{ grid-column:2 / 3; grid-row:1 / 3 }
}
@media (max-width:1080px){
  .nav{ display:none }
  .burger{ display:flex }
  .hero-a__grid,.prob-grid{ grid-template-columns:1fr }
  .hero-a__media{ max-width:520px; margin-inline:auto }
  .trust-grid{ grid-template-columns:repeat(2,1fr) }
  .cases-grid,.plans-grid{ grid-template-columns:1fr; max-width:480px; margin-inline:auto }
  .plan.featured{ order:-1 }
  .float-card{ scale:.9 }
}

/* Footer: columna única bajo LG (769px–992px) */
@media (max-width:992px){
  .footer__top{ grid-template-columns:1fr; gap:44px }
  .footer__about, .footer__links, .footer__contact{ grid-column:1; grid-row:auto; margin-top:0 }
  .footer__links{ grid-template-columns:repeat(3,minmax(0,1fr)); gap:28px 24px }
  .footer__logo{ margin-top:26px }
}
/* Footer: rango LG 993px–1199px */
@media (min-width:993px) and (max-width:1199px){
  .footer__top{ grid-template-columns:1.4fr 1fr }
}

@media (max-width:768px){
  .footer__top{ grid-template-columns:1fr; gap:44px }
  .footer__about, .footer__links, .footer__contact{ grid-column:1; grid-row:auto; margin-top:0 }
  .footer__links{ grid-template-columns:repeat(3,minmax(0,1fr)); gap:28px 24px }
  .footer__logo{ margin-top:26px }
}
@media (max-width:640px){
  .topbar__mail{ display:none }
  .topbar__social{ display:none }
  .topbar__inner{ justify-content:center }
  .topbar__wa{ padding-left:0; border-left:0 }
}
/* ---------- FAQ ---------- */
.faq{ background:var(--bg-soft) }
.faq__list{ max-width:840px; margin:0 auto; display:flex; flex-direction:column; gap:14px }
.faq__item{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-md);
  box-shadow:var(--shadow-sm); overflow:hidden;
  transition:border-color .2s, box-shadow .25s;
}
.faq__item[open]{ border-color:var(--line-2); box-shadow:var(--shadow-md) }
.faq__q{
  list-style:none; cursor:pointer;
  display:flex; align-items:center; gap:20px;
  padding:24px clamp(20px,3vw,30px);
  font-family:var(--ff-head); font-weight:600;
  font-size:16.5px; color:var(--ink); line-height:1.35;
  transition:color .2s;
}
.faq__q::-webkit-details-marker{ display:none }
.faq__q:hover{ color:var(--blue-d) }
.faq__q-text{ flex:1; text-wrap:balance }
.faq__ic{
  flex-shrink:0; width:34px; height:34px; border-radius:var(--r-pill);
  display:grid; place-items:center; color:#fff; background:var(--grad);
  transition:transform .3s cubic-bezier(.3,.7,.4,1);
}
.faq__ic svg{ width:18px; height:18px }
.faq__item[open] .faq__ic{ transform:rotate(135deg) }
.faq__a{
  padding:0 clamp(20px,3vw,30px) 26px;
  color:var(--ink-2); font-size:15px; line-height:1.7;
  max-width:72ch;
}
.faq__item[open] .faq__a{ animation:faqReveal .35s ease both }
@keyframes faqReveal{ from{ opacity:0; transform:translateY(-6px) } to{ opacity:1; transform:none } }
@media (prefers-reduced-motion:reduce){
  .faq__ic{ transition:none } .faq__item[open] .faq__a{ animation:none }
}

@media (max-width:560px){
  body{ font-size:16px }
  .hero-a__copy h1{ font-size:clamp(26px,7.5vw,36px) }
  .svc-grid{ grid-template-columns:1fr }
  .svc.featured{ grid-column:span 1; grid-template-columns:1fr }
  .proc-grid{ grid-template-columns:1fr }
  .lead-form__grid{ grid-template-columns:1fr }
  .trust-grid{ grid-template-columns:repeat(2,1fr) }
  .footer__links{ grid-template-columns:repeat(2,1fr) }
  .hero-a__media{ margin-top:40px }
  .fc-1{ left:-8px } .fc-2{ right:-8px }
  .hero-actions .btn{ flex:1 }
}
