/* ===== SprintWeb — estilos · negro elegante + lima ===== */
:root{
  /* Paleta oficial de marca: lima #C8FF33 + negro */
  --bg:#0a0a0a;
  --bg-2:#0f0f10;
  --negro:#0a0a0a;
  --panel:#101012;
  --panel-2:#16161a;
  --lime:#c8ff33;
  --lime-soft:rgba(200,255,51,.12);
  --lime-deep:#9fd400;
  --ink:#0a0a0a;
  --blanco:#ffffff;
  --tenue:rgba(255,255,255,.55);
  --tenue-2:rgba(255,255,255,.4);
  --linea:rgba(255,255,255,.08);
  --maxw:1180px;
  --radius:16px;
  --trans:.25s ease;
  --ff-title:"Geist","Sora",system-ui,sans-serif;
  --ff-body:"Barlow",system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--ff-body);color:#e9eaec;
  background:var(--bg);line-height:1.62;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-title);font-weight:800;line-height:1.04;margin:0 0 .4em;letter-spacing:-.01em}
p{margin:0 0 1rem}
.container{width:min(100% - 2.5rem,var(--maxw));margin-inline:auto}
.section{padding:clamp(3.5rem,8vw,7rem) 0;position:relative}
[id]{scroll-margin-top:84px}
.accent{color:var(--lime)}
.eyebrow{display:inline-block;font-family:var(--ff-title);font-weight:600;text-transform:uppercase;letter-spacing:3px;color:var(--lime);font-size:.82rem;margin-bottom:.7rem}
.section__title{font-size:clamp(1.9rem,4.5vw,3.1rem);color:#fff;text-transform:none}
.section__title--center{text-align:center}
.section__head{text-align:center;max-width:680px;margin:0 auto clamp(2rem,5vw,3.5rem)}
.section__sub{color:var(--tenue);font-size:1.12rem}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;background:#fff;color:#000;padding:.6rem 1rem;z-index:1000;border-radius:8px}

/* ===== Botones ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--ff-title);font-weight:700;
  letter-spacing:.2px;font-size:1rem;padding:.85rem 1.7rem;border-radius:50px;border:2px solid transparent;
  cursor:pointer;text-align:center;will-change:transform;
  transition:transform .16s cubic-bezier(.34,1.56,.64,1),background .25s ease,color .25s ease,box-shadow .25s ease,border-color .25s ease
}
.btn:active{transform:scale(.94)}
.btn--lime{background:var(--lime);color:#0a0a0a;box-shadow:0 8px 30px rgba(200,255,51,.18)}
.btn--lime:hover{background:#d8ff5f;transform:translateY(-2px);box-shadow:0 14px 40px rgba(200,255,51,.3)}
.btn--lime:active{transform:translateY(-1px) scale(.95)}
.btn--ghost{border-color:rgba(255,255,255,.25);color:#fff;background:transparent}
.btn--ghost:hover{border-color:var(--lime);color:var(--lime);transform:translateY(-2px)}
.btn--lg{padding:1.05rem 2.3rem;font-size:1.1rem}
.btn--block{width:100%}
.btn svg{width:18px;height:18px}

/* ===== Header ===== */
/* Nota: NO usar backdrop-filter/transform/filter aquí — convierten al header en
   containing block y rompen el position:fixed del menú móvil (queda atrapado). */
.site-header{position:sticky;top:0;z-index:100;background:rgba(10,10,10,.94);border-bottom:1px solid var(--linea)}
.header__inner{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0}
.brand{display:flex;align-items:center;gap:.6rem}
.brand__icon{width:38px;height:38px;border-radius:9px;display:block}
.brand__word{font-family:var(--ff-title);font-weight:800;font-size:1.32rem;letter-spacing:-.5px;color:#fff;line-height:1}
.brand__word b{font-weight:800}
.brand__word span{font-weight:400;color:#e9eaec}
.nav__menu{display:flex;align-items:center;gap:1.5rem;list-style:none;margin:0;padding:0}
.nav__menu a{color:#cfd2d6;font-family:var(--ff-title);font-weight:500;font-size:1rem;transition:var(--trans)}
.nav__menu a:not(.btn):hover,.nav__menu a.is-current:not(.btn){color:var(--lime)}
/* El CTA del header es botón lima → texto negro (contraste AA), no hereda el color claro del nav */
.nav__menu a.btn--lime,.nav__menu a.btn--lime:hover{color:#0a0a0a}
.nav__toggle{display:none;position:relative;z-index:110;align-items:center;justify-content:center;width:42px;height:42px;background:none;border:1px solid var(--linea);border-radius:10px;cursor:pointer;color:#fff;transition:border-color .2s ease,background .2s ease,color .2s ease}
.nav__toggle[aria-expanded="true"]{background:rgba(255,255,255,.06);border-color:var(--lime);color:var(--lime)}
.nav__toggle:hover{border-color:var(--lime);color:var(--lime)}
.nav__toggle:active{transform:scale(.94)}
.hamb path{transform-origin:center;transition:transform .3s cubic-bezier(.5,.85,.25,1.1)}
.hamb__top{transform:translateY(-7px)}
.hamb__bot{transform:translateY(7px)}
.nav__toggle[aria-expanded="true"] .hamb__top{transform:rotate(315deg)}
.nav__toggle[aria-expanded="true"] .hamb__mid{transform:rotate(45deg);transition-timing-function:cubic-bezier(.5,.85,.25,1.8)}
.nav__toggle[aria-expanded="true"] .hamb__bot{transform:rotate(135deg)}

/* Barra de progreso de scroll */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--lime),#e6ff8a);box-shadow:0 0 10px rgba(200,255,51,.5)}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;padding:clamp(3.5rem,8vw,6.5rem) 0 clamp(3rem,7vw,5.5rem);
  background:radial-gradient(ellipse at 75% 8%,rgba(200,255,51,.14),transparent 52%),
             radial-gradient(ellipse at 8% 95%,rgba(200,255,51,.06),transparent 55%),#0a0a0a}
.hero__grid{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(ellipse at 60% 30%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse at 60% 30%,#000,transparent 75%)}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero__pill{display:inline-flex;align-items:center;gap:.5rem;background:var(--lime-soft);border:1px solid rgba(200,255,51,.3);
  color:var(--lime);font-family:var(--ff-title);font-weight:600;font-size:.82rem;letter-spacing:.5px;
  padding:.4rem 1rem;border-radius:50px;margin-bottom:1.5rem}
.hero__pill .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(200,255,51,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(200,255,51,.5)}70%{box-shadow:0 0 0 9px rgba(200,255,51,0)}100%{box-shadow:0 0 0 0 rgba(200,255,51,0)}}
.hero__title{font-size:clamp(2.5rem,6.2vw,4.6rem);font-weight:800;line-height:1.02;color:#fff;margin-bottom:.5em}
.hero__title em{font-style:normal;color:var(--lime)}
.hero__lead{font-size:clamp(1.1rem,2.2vw,1.32rem);max-width:540px;margin-bottom:2rem;color:#c4c7cc}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero__note{margin:1.6rem 0 0;font-size:.92rem;color:var(--tenue-2);display:flex;align-items:center;gap:.5rem}
.hero__note svg{width:16px;height:16px;color:var(--lime);flex-shrink:0}

/* Hero visual: mockup de navegador con ilustración */
.hero__visual{position:relative}
.browser{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.1);
  background:#fff;box-shadow:0 40px 90px rgba(0,0,0,.6),0 0 0 1px rgba(200,255,51,.12);
  transform:perspective(1400px) rotateY(-7deg) rotateX(3deg);transform-origin:center}
.browser__bar{display:flex;align-items:center;gap:.45rem;padding:.7rem .9rem;background:#101012;border-bottom:1px solid rgba(255,255,255,.06)}
.browser__bar i{width:11px;height:11px;border-radius:50%;background:#3a3a3e}
.browser__bar i:first-child{background:#ff5f57}.browser__bar i:nth-child(2){background:#febc2e}.browser__bar i:nth-child(3){background:#28c840}
.browser__url{margin-left:.6rem;flex:1;height:22px;border-radius:6px;background:#1c1c20;display:flex;align-items:center;padding:0 .6rem;font-size:.7rem;color:#7a7d82;font-family:var(--ff-title)}
.browser__img{width:100%;display:block;background:#fff}
.hero__badge{position:absolute;bottom:-18px;left:-18px;background:#0f0f12;border:1px solid rgba(200,255,51,.3);
  border-radius:14px;padding:.8rem 1.1rem;display:flex;align-items:center;gap:.7rem;box-shadow:0 20px 50px rgba(0,0,0,.5);z-index:3}
.hero__badge b{font-family:var(--ff-title);font-size:1.5rem;color:var(--lime);line-height:1}
.hero__badge span{font-size:.78rem;color:var(--tenue);line-height:1.2;font-family:var(--ff-title);text-transform:uppercase;letter-spacing:1px}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media(prefers-reduced-motion:no-preference){.hero__badge{animation:floaty 5s ease-in-out infinite}}

/* ===== Trust strip ===== */
.trust{border-block:1px solid var(--linea);background:#0c0c0e}
.trust__inner{display:flex;flex-wrap:wrap;gap:1rem 2.4rem;justify-content:center;align-items:center;padding:1.3rem 0}
.trust__item{display:flex;align-items:center;gap:.55rem;color:var(--tenue);font-family:var(--ff-title);font-weight:500;font-size:.95rem}
.trust__item svg{width:18px;height:18px;color:var(--lime)}

/* ===== Sample-first (gancho) ===== */
.sample{background:linear-gradient(180deg,#0a0a0a,#0d0e0b)}
.sample__card{position:relative;border-radius:28px;padding:clamp(2rem,5vw,3.5rem);border:1px solid rgba(200,255,51,.22);
  background:radial-gradient(ellipse at 80% 0%,rgba(200,255,51,.1),transparent 60%),linear-gradient(160deg,#101210,#0c0c0d);
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,3.5rem);align-items:center}
.sample__steps{display:flex;flex-direction:column;gap:1rem}
.sample__step{display:flex;gap:1rem;align-items:flex-start;background:rgba(255,255,255,.025);border:1px solid var(--linea);border-radius:14px;padding:1.1rem 1.25rem}
.sample__step b{flex-shrink:0;width:34px;height:34px;border-radius:9px;background:var(--lime);color:#0a0a0a;font-family:var(--ff-title);font-weight:800;display:grid;place-items:center;font-size:1.05rem}
.sample__step p{margin:0;color:#d4d6da;font-size:1rem}
.sample__step strong{color:#fff;font-weight:600}

/* ===== Comparación (diferenciación) ===== */
.compare__wrap{border-radius:18px;border:1px solid rgba(255,255,255,.14);overflow:hidden;background:#0c0c0e}
.compare{width:100%;border-collapse:collapse;font-size:1rem}
.compare th,.compare td{padding:1.05rem 1.2rem;text-align:left;border-bottom:1px solid var(--linea)}
.compare th:not(:first-child),.compare td:not(:first-child){border-left:1px solid var(--linea);text-align:center}
.compare thead th{font-family:var(--ff-title);font-weight:700;color:#dfe2e6;font-size:.92rem;text-transform:uppercase;letter-spacing:.5px;background:#15151a}
.compare thead th.is-us{color:#0a0a0a;background:var(--lime);border-left-color:rgba(200,255,51,.4)}
.compare tbody tr:nth-child(odd){background:rgba(255,255,255,.022)}
.compare tbody td:first-child{color:#fff;font-family:var(--ff-title);font-weight:500;text-align:left}
.compare td.is-us{background:rgba(200,255,51,.09);color:#fff;font-weight:600;font-family:var(--ff-title);border-left:1px solid rgba(200,255,51,.3)}
.compare td.is-us .ok{color:var(--lime)}
.compare .muted{color:var(--tenue-2)}
.compare tr:last-child td{border-bottom:0}

/* Móvil: la tabla se vuelve tarjetas apiladas (sin scroll horizontal) */
@media(max-width:680px){
  .compare__wrap{border:0;background:transparent;overflow:visible}
  .compare,.compare tbody,.compare tr,.compare td{display:block;width:100%}
  .compare thead{display:none}
  .compare tr{border:1px solid var(--linea);border-radius:14px;background:#0f0f11;margin-bottom:1rem;overflow:hidden}
  .compare tbody tr:nth-child(odd){background:#0f0f11}
  .compare td{border:0!important;border-bottom:1px solid var(--linea)!important;padding:.75rem 1rem;
    display:flex;justify-content:space-between;align-items:center;gap:1rem;text-align:right;font-size:.95rem}
  .compare td:first-child{background:#15151a;color:#fff;font-family:var(--ff-title);font-weight:700;font-size:1.05rem;
    justify-content:flex-start;text-align:left}
  .compare td:not(:first-child)::before{content:attr(data-label);color:var(--tenue);font-family:var(--ff-title);font-weight:500;font-size:.85rem;text-align:left;flex-shrink:0}
  .compare td:nth-of-type(2)::before{content:"Freelancer"}
  .compare td:nth-of-type(3)::before{content:"Agencia"}
  .compare td:nth-of-type(4)::before{content:"SprintWeb"}
  .compare td.is-us{background:rgba(200,255,51,.1);color:var(--lime)}
  .compare td.is-us::before{color:var(--lime);font-weight:600}
  .compare tr td:last-child{border-bottom:0!important}
}

/* ===== Grid de tarjetas (incluido / ads / valores) ===== */
.cards{display:grid;gap:1.25rem}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.card{
  position:relative;border-radius:22px;padding:2rem 1.8rem;border:1px solid var(--linea);
  background:linear-gradient(160deg,#0f0f11,#0c0c0d);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease
}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(0,0,0,.4);border-color:rgba(200,255,51,.3)}
.card__icon{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:13px;background:var(--lime-soft);color:var(--lime);margin-bottom:1.2rem;transition:var(--trans)}
.card__icon svg{width:27px;height:27px}
.card:hover .card__icon{background:var(--lime);color:#0a0a0a}
.card h3{font-size:1.22rem;color:#fff}
.card p{color:var(--tenue);margin:0;font-size:.97rem}

/* ===== Por qué 7 días (timeline) ===== */
.metodo__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.timeline{display:flex;flex-direction:column;gap:0}
.tl{display:flex;gap:1.1rem;padding-bottom:1.6rem;position:relative}
.tl:not(:last-child)::before{content:"";position:absolute;left:18px;top:40px;bottom:0;width:2px;background:linear-gradient(var(--lime),rgba(200,255,51,.12))}
.tl__day{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:var(--lime-soft);border:1px solid rgba(200,255,51,.35);color:var(--lime);font-family:var(--ff-title);font-weight:800;display:grid;place-items:center;font-size:.95rem;z-index:1}
.tl__body h4{margin:.2rem 0 .25rem;color:#fff;font-size:1.1rem}
.tl__body p{margin:0;color:var(--tenue);font-size:.96rem}
.metodo__aside{border-radius:24px;padding:2px;background:linear-gradient(150deg,rgba(200,255,51,.5),rgba(200,255,51,.05))}
.metodo__aside-in{border-radius:22px;background:linear-gradient(160deg,#101210,#0b0b0c);padding:clamp(1.8rem,4vw,2.6rem)}
.metodo__big{font-family:var(--ff-title);font-weight:800;font-size:clamp(3rem,7vw,4.5rem);color:var(--lime);line-height:1;margin-bottom:.3rem}
.metodo__aside p{color:var(--tenue);margin:0}

/* ===== Portfolio (estilo ProjectCard) ===== */
.port__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
.pcard{group:portfolio;position:relative;display:flex;flex-direction:column;overflow:hidden;border-radius:18px;
  border:1px solid var(--linea);background:linear-gradient(160deg,#0f0f11,#0c0c0d);
  transition:transform .5s cubic-bezier(.22,.61,.36,1),box-shadow .5s ease,border-color .4s ease}
.pcard:hover{transform:translateY(-8px);border-color:rgba(200,255,51,.3);box-shadow:0 30px 70px rgba(0,0,0,.55)}
.pcard__shot{display:block;width:100%;aspect-ratio:16/9;overflow:hidden;background:#16161a;cursor:zoom-in;border:0;padding:0;position:relative}
.pcard__shot img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .7s cubic-bezier(.22,.61,.36,1)}
.pcard:hover .pcard__shot img{transform:scale(1.08)}
.pcard__view{position:absolute;top:.8rem;right:.8rem;display:inline-flex;align-items:center;gap:.35rem;
  background:rgba(10,10,10,.7);backdrop-filter:blur(6px);color:#fff;font-family:var(--ff-title);font-weight:600;font-size:.78rem;
  padding:.35rem .7rem;border-radius:50px;opacity:0;transform:translateY(-4px);transition:opacity .3s ease,transform .3s ease;border:1px solid rgba(255,255,255,.12)}
.pcard__view svg{width:13px;height:13px;color:var(--lime)}
.pcard:hover .pcard__view{opacity:1;transform:none}
.pcard__body{display:flex;flex-direction:column;flex:1;padding:1.5rem}
.pcard__body h3{font-size:1.25rem;color:#fff;margin-bottom:.5rem;transition:color .3s ease}
.pcard:hover .pcard__body h3{color:var(--lime)}
.pcard__body p{color:var(--tenue);margin:0;flex:1;font-size:.96rem}
.pcard__link{margin-top:1.1rem;display:inline-flex;align-items:center;gap:.45rem;color:var(--lime);
  font-family:var(--ff-title);font-weight:600;font-size:.92rem;align-self:flex-start}
.pcard__link svg{width:16px;height:16px;transition:transform .3s ease}
.pcard__link:hover svg{transform:translateX(4px)}
.pcard__link--soon{color:#8b8f95;font-style:italic;cursor:default}

/* Plantillas por rubro: cabecera + chips de filtro */
.tpl-head{text-align:center;max-width:680px;margin:clamp(3rem,6vw,4.5rem) auto 1.6rem}
.tpl-filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2.2rem}
.tpl-chip{font-family:var(--ff-title);font-weight:600;font-size:.9rem;color:#cfd2d6;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.14);padding:.5rem 1.1rem;border-radius:50px;cursor:pointer;
  transition:border-color .2s ease,background .2s ease,color .2s ease,transform .16s cubic-bezier(.34,1.56,.64,1)}
.tpl-chip:hover{border-color:var(--lime);color:#fff}
.tpl-chip:active{transform:scale(.95)}
.tpl-chip.is-active{background:var(--lime);border-color:var(--lime);color:#0a0a0a}
.pcard--tpl .pcard__view{background:rgba(10,10,10,.7)}
.pcard__cat{font-family:var(--ff-title);font-weight:600;font-size:.78rem;color:var(--lime);text-transform:uppercase;letter-spacing:1px;margin-bottom:.3rem;display:block}

/* Preview modal — barra de controles fija abajo + mockups iMac/iPhone */
.preview{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:1.5rem}
.preview.is-open{display:flex}
.preview__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);animation:fadeIn .3s ease}
.preview__panel{position:relative;z-index:2;width:min(1040px,96vw);height:min(88vh,880px);display:flex;flex-direction:column;
  background:#0d0d0f;border:1px solid var(--linea);border-radius:18px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.6)}
.preview__stage{flex:1;min-height:0;overflow:auto;display:flex;align-items:center;justify-content:center;padding:1.8rem;
  background:radial-gradient(ellipse at 50% 0%,rgba(200,255,51,.05),transparent 60%),#0a0a0a}
.device{display:flex;align-items:center;justify-content:center;width:100%}
.preview__bar{flex-shrink:0;border-top:1px solid var(--linea);background:#101012;padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.8rem}
.preview__title{font-family:var(--ff-title);font-weight:700;color:#fff;font-size:1.1rem}
.preview__controls{display:flex;gap:.55rem;flex-wrap:wrap;align-items:center}
.pv-btn{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--ff-title);font-weight:600;font-size:.9rem;
  padding:.55rem 1rem;border-radius:10px;cursor:pointer;border:1px solid var(--linea);background:#1a1a1e;color:#cfd2d6;transition:var(--trans)}
.pv-btn svg{width:15px;height:15px}
.pv-btn:hover{border-color:rgba(255,255,255,.3);color:#fff}
.pv-btn:active{transform:scale(.96)}
.pv-btn.is-active{background:var(--lime);border-color:var(--lime);color:#0a0a0a}
.pv-btn--open{margin-left:auto;background:transparent;color:var(--lime);border-color:rgba(200,255,51,.4)}
.pv-btn--open:hover{background:var(--lime-soft);color:var(--lime);border-color:var(--lime)}
.pv-btn--close{background:transparent;color:var(--tenue)}
.pv-btn--close:hover{color:#fff;border-color:rgba(255,255,255,.3)}

/* Mockup iMac (desktop) */
.dev-mac{display:flex;flex-direction:column;align-items:center;width:100%;max-width:780px}
.dev-mac__screen{width:100%;border:11px solid #1b1b1f;border-radius:16px;background:#000;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.dev-mac__screen img{display:block;width:100%}
.dev-mac__neck{width:96px;height:28px;background:linear-gradient(#cbced3,#a1a5ab);clip-path:polygon(20% 0,80% 0,100% 100%,0 100%)}
.dev-mac__foot{width:160px;height:11px;background:linear-gradient(#b8bbc1,#8c8f95);border-radius:0 0 9px 9px}
/* Mockup iPhone (móvil) */
.dev-phone{position:relative;width:282px;max-width:80vw;border:12px solid #1b1b1f;border-radius:42px;background:#000;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.dev-phone__island{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:92px;height:25px;background:#000;border-radius:14px;z-index:2}
.dev-phone__screen{border-radius:30px;overflow:hidden}
.dev-phone__screen img{display:block;width:100%}

/* ===== Cómo funciona (pasos) ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:step}
.step{position:relative;border-radius:20px;padding:1.9rem 1.5rem;border:1px solid var(--linea);background:linear-gradient(160deg,#0f0f11,#0c0c0d)}
.step__n{font-family:var(--ff-title);font-weight:800;font-size:2.6rem;color:var(--lime);line-height:1;opacity:.95}
.step h4{margin:.7rem 0 .4rem;color:#fff;font-size:1.12rem}
.step p{margin:0;color:var(--tenue);font-size:.95rem}
.step__free{display:inline-block;margin-top:.7rem;font-family:var(--ff-title);font-weight:600;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--lime);background:var(--lime-soft);padding:.25rem .6rem;border-radius:50px}

/* ===== Planes ===== */
.planes__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;align-items:stretch}
.plan{display:flex;flex-direction:column;border-radius:24px;padding:2.1rem 1.9rem;border:1px solid var(--linea);
  background:linear-gradient(165deg,#0f0f11,#0b0b0c);position:relative;transition:transform .25s ease,border-color .25s ease}
.plan:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.18)}
.plan--pop{border-color:rgba(200,255,51,.5);background:radial-gradient(ellipse at 50% -10%,rgba(200,255,51,.12),transparent 60%),linear-gradient(165deg,#111310,#0b0b0c);box-shadow:0 30px 70px rgba(0,0,0,.5)}
.plan--pop:hover{border-color:var(--lime)}
.plan__tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--lime);color:#0a0a0a;font-family:var(--ff-title);font-weight:700;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;padding:.35rem .9rem;border-radius:50px;white-space:nowrap}
.plan__name{font-family:var(--ff-title);font-weight:700;color:#fff;font-size:1.3rem;margin-bottom:.2rem}
.plan__for{color:var(--tenue-2);font-size:.9rem;margin-bottom:1.2rem;min-height:2.6em}
.plan__price{display:flex;align-items:baseline;gap:.3rem;margin-bottom:.2rem}
.plan__price b{font-family:var(--ff-title);font-weight:800;font-size:2.5rem;color:#fff;line-height:1}
.plan__price .cur{color:var(--tenue);font-family:var(--ff-title);font-size:1.1rem}
.plan__iva{color:var(--tenue-2);font-size:.82rem;margin-bottom:.4rem}
.plan__plazo{display:inline-flex;align-items:center;gap:.4rem;color:var(--lime);font-family:var(--ff-title);font-weight:600;font-size:.9rem;margin-bottom:1.3rem}
.plan__plazo svg{width:15px;height:15px}
.plan ul{list-style:none;margin:0 0 1.6rem;padding:0;display:flex;flex-direction:column;gap:.65rem;flex:1}
.plan li{display:flex;gap:.6rem;align-items:flex-start;color:#d2d4d8;font-size:.95rem}
.plan li svg{width:17px;height:17px;color:var(--lime);flex-shrink:0;margin-top:.18rem}
.planes__note{text-align:center;color:var(--tenue-2);font-size:.9rem;margin-top:1.6rem}

/* ===== Servicios adicionales ===== */
.adic__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.svc{display:flex;flex-direction:column;border-radius:20px;padding:1.8rem;border:1px solid var(--linea);
  background:linear-gradient(160deg,#0f0f11,#0c0c0d);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}
.svc:hover{transform:translateY(-5px);border-color:rgba(200,255,51,.3);box-shadow:0 22px 50px rgba(0,0,0,.4)}
.svc--feat{grid-column:span 2;flex-direction:column;border-color:rgba(200,255,51,.3);
  background:radial-gradient(ellipse at 90% 0%,rgba(200,255,51,.08),transparent 55%),linear-gradient(160deg,#101210,#0b0b0c)}
.svc__top{display:flex;align-items:center;gap:1rem;margin-bottom:.3rem}
.svc__icon{display:inline-grid;place-items:center;width:50px;height:50px;border-radius:13px;background:var(--lime-soft);color:var(--lime);flex-shrink:0;margin-bottom:1.1rem;transition:var(--trans)}
.svc__top .svc__icon{margin-bottom:0}
.svc:hover .svc__icon{background:var(--lime);color:#0a0a0a}
.svc__icon svg{width:25px;height:25px}
.svc h4{color:#fff;font-size:1.18rem;margin:0 0 .1rem}
.svc__tag{font-family:var(--ff-title);font-weight:600;font-size:.78rem;color:var(--lime);background:var(--lime-soft);padding:.18rem .6rem;border-radius:50px}
.svc__tag--google{background:#fff;color:#3c4043;display:inline-flex;align-items:center;gap:.35rem}
.svc__tag--google svg{display:block;flex-shrink:0}
.svc p{color:var(--tenue);font-size:.95rem;margin:.6rem 0 1.2rem;flex:1}
.svc--feat p{max-width:680px}
.svc__price{display:flex;flex-wrap:wrap;gap:1.5rem;border-top:1px solid var(--linea);padding-top:1.1rem;margin-top:auto}
.svc__price-row b{font-family:var(--ff-title);font-weight:800;color:var(--lime);font-size:1.5rem;line-height:1;display:block}
.svc__price-row span{color:var(--tenue-2);font-size:.82rem;display:block;margin-top:.2rem}

/* ===== Garantía band ===== */
.garantia{background:linear-gradient(110deg,#c8ff33,#a6e000);color:#0a0a0a;border-radius:0}
.garantia__inner{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;justify-content:space-between;padding:clamp(2rem,5vw,3rem) 0}
.garantia__icon{flex-shrink:0;width:64px;height:64px;border-radius:16px;background:rgba(10,10,10,.1);display:grid;place-items:center}
.garantia__icon svg{width:34px;height:34px;color:#0a0a0a}
.garantia h2{color:#0a0a0a;font-size:clamp(1.6rem,3.5vw,2.4rem);margin:0 0 .2rem}
.garantia p{color:rgba(10,10,10,.78);margin:0;font-size:1.05rem;max-width:560px}
.garantia .btn--dark{background:#0a0a0a;color:var(--lime)}
.garantia .btn--dark:hover{background:#000;transform:translateY(-2px)}

/* ===== Ads-ready ===== */
.ads__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.ads__panel{border-radius:24px;border:1px solid rgba(200,255,51,.2);padding:2rem;background:radial-gradient(ellipse at 30% 0%,rgba(200,255,51,.1),transparent 60%),#0e0f0c}
.ads__bars{display:flex;align-items:flex-end;gap:.8rem;height:160px;margin-bottom:1.2rem}
.ads__bar{flex:1;border-radius:8px 8px 0 0;background:linear-gradient(var(--lime),rgba(200,255,51,.3));position:relative}
.ads__bar span{position:absolute;top:-1.4rem;left:0;right:0;text-align:center;font-family:var(--ff-title);font-size:.72rem;color:var(--tenue)}
.ads__panel small{color:var(--tenue-2);font-size:.82rem}
.checklist{list-style:none;margin:1.4rem 0 0;padding:0;display:flex;flex-direction:column;gap:.8rem}
.checklist li{display:flex;gap:.7rem;align-items:flex-start;color:#d2d4d8}
.checklist li svg{width:20px;height:20px;color:var(--lime);flex-shrink:0;margin-top:.15rem}
.checklist b{color:#fff;font-weight:600;font-family:var(--ff-title)}

/* ===== Testimonios ===== */
.testi__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.testi{border-radius:22px;padding:2rem;border:1px solid var(--linea);background:linear-gradient(160deg,#0f0f11,#0c0c0d)}
.testi__stars{display:flex;gap:.25rem;margin-bottom:1.1rem;color:var(--lime)}
.testi__stars svg{width:18px;height:18px}
.testi__quote{font-size:1.1rem;line-height:1.6;color:#e8eaed;margin:0 0 1.5rem;font-weight:500}
.testi__author{display:flex;align-items:center;gap:.9rem}
.testi__avatar{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:var(--ff-title);font-weight:700;color:#0a0a0a;background:var(--lime);flex-shrink:0}
.testi__name{font-family:var(--ff-title);font-weight:600;color:#fff;line-height:1.2}
.testi__role{color:var(--tenue);font-size:.88rem;margin:.1rem 0 0}
.testi__role a{color:var(--lime)}

/* ===== FAQ ===== */
.faq{max-width:780px;margin-inline:auto}
.faq__item{border:1px solid var(--linea);border-radius:14px;margin-bottom:.8rem;background:#0f0f11;overflow:hidden;transition:border-color .25s ease}
.faq__item[open]{border-color:rgba(200,255,51,.3)}
.faq__q{cursor:pointer;list-style:none;padding:1.2rem 1.4rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-family:var(--ff-title);font-weight:600;color:#fff;font-size:1.05rem}
.faq__q::-webkit-details-marker{display:none}
.faq__q .ico{flex-shrink:0;width:24px;height:24px;position:relative;transition:transform .3s ease}
.faq__q .ico::before,.faq__q .ico::after{content:"";position:absolute;background:var(--lime);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq__q .ico::before{width:14px;height:2px}.faq__q .ico::after{width:2px;height:14px;transition:transform .3s ease}
.faq__item[open] .faq__q .ico::after{transform:translate(-50%,-50%) scaleY(0)}
.faq__a{padding:0 1.4rem 1.3rem;color:var(--tenue);font-size:.98rem;line-height:1.6}

/* ===== CTA final (sección dedicada) ===== */
.cta-final__box{position:relative;text-align:center;max-width:720px;margin-inline:auto;border-radius:28px;
  border:1px solid rgba(200,255,51,.22);overflow:hidden;padding:clamp(2.4rem,6vw,4rem) clamp(1.5rem,5vw,3.5rem);
  background:radial-gradient(ellipse at 50% 0%,rgba(200,255,51,.12),transparent 60%),linear-gradient(160deg,#101210,#0b0b0c)}
.cta-final__box .section__title{margin-bottom:.6rem}
.cta-final__btn{margin-top:1.8rem}
.cta-final__foot{margin:1rem 0 0;color:var(--tenue-2);font-size:.82rem}
.cta__list{list-style:none;margin:1.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.7rem}
.cta__list li{display:flex;gap:.6rem;align-items:center;color:#d2d4d8}
.cta__list svg{width:18px;height:18px;color:var(--lime);flex-shrink:0}
.cta__list--center{display:inline-flex;align-items:flex-start;text-align:left;gap:.7rem;margin-top:1.6rem}

/* ===== Modal del formulario (Typeform flotante) ===== */
.fmodal{position:fixed;inset:0;z-index:1100;display:none;align-items:center;justify-content:center;padding:1.5rem}
.fmodal.is-open{display:flex}
.fmodal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:fadeIn .3s ease}
.fmodal__panel{position:relative;z-index:2;width:min(540px,96vw);max-height:92vh;overflow-y:auto;
  background:radial-gradient(ellipse at 90% 0%,rgba(200,255,51,.1),transparent 55%),#0e0f0c;
  border:1px solid rgba(200,255,51,.25);border-radius:20px;padding:clamp(1.6rem,4vw,2.4rem);
  box-shadow:0 40px 100px rgba(0,0,0,.6);transform-origin:center;animation:fmIn .35s cubic-bezier(.34,1.4,.64,1)}
@keyframes fmIn{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.fmodal__panel{animation:none}}
.fmodal__close{position:absolute;top:1rem;right:1rem;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);
  color:#fff;border:0;font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;z-index:3;transition:var(--trans)}
.fmodal__close:hover{background:rgba(255,255,255,.22)}
.fmodal__head{margin-bottom:1.6rem;padding-right:2.5rem}
.fmodal__head h2{font-family:var(--ff-title);font-weight:800;color:#fff;font-size:clamp(1.4rem,3.5vw,1.8rem);margin-bottom:.3rem}
.fmodal__head p{color:var(--tenue);font-size:.98rem;margin:0}
/* ===== Formulario multi-paso (estilo Typeform) ===== */
.tf{position:relative}
.tf__progress{height:5px;border-radius:50px;background:rgba(255,255,255,.1);overflow:hidden;margin-bottom:1.8rem}
.tf__progress span{display:block;height:100%;width:20%;border-radius:50px;background:linear-gradient(90deg,var(--lime),#e6ff8a);transition:width .45s cubic-bezier(.22,.61,.36,1)}
.tf__step{display:none;border:0;margin:0;padding:0;min-width:0}
.tf__step.is-active{display:block;animation:tfIn .45s cubic-bezier(.22,.61,.36,1)}
@keyframes tfIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.tf__step.is-active{animation:none}}
.tf__q{font-family:var(--ff-title);font-weight:700;color:#fff;font-size:1.3rem;line-height:1.25;margin-bottom:1.2rem;display:flex;gap:.55rem;align-items:baseline}
.tf__num{flex-shrink:0;color:#0a0a0a;background:var(--lime);font-size:.85rem;font-weight:800;width:26px;height:26px;border-radius:7px;display:inline-grid;place-items:center;transform:translateY(2px)}
.tf__opts{display:flex;flex-direction:column;gap:.7rem}
.tf__opts--grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.tf__opt{text-align:left;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.14);border-radius:12px;
  padding:.95rem 1.1rem;cursor:pointer;color:#fff;font-family:var(--ff-body);display:flex;flex-direction:column;gap:.15rem;
  transition:border-color .2s ease,background .2s ease,transform .16s cubic-bezier(.34,1.56,.64,1)}
.tf__opt:hover{border-color:var(--lime);background:rgba(200,255,51,.06)}
.tf__opt:active{transform:scale(.97)}
.tf__opt.is-sel{border-color:var(--lime);background:rgba(200,255,51,.1)}
.tf__opt b{font-family:var(--ff-title);font-weight:600;font-size:1.02rem}
.tf__opt em{font-style:normal;color:var(--tenue);font-size:.85rem}
.tf__opt--chip{flex-direction:row;align-items:center;justify-content:center;text-align:center;font-family:var(--ff-title);font-weight:600;font-size:.92rem;padding:.8rem .6rem}
.tf__input{width:100%;padding:.85rem .95rem;margin-bottom:.7rem;border-radius:10px;border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.3);color:#fff;font-family:var(--ff-body);font-size:1rem;transition:border-color .2s ease}
.tf__input:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px rgba(200,255,51,.15)}
.tf__next{margin-top:.4rem}
.tf__nav{display:flex;align-items:center;justify-content:space-between;margin-top:1.4rem;min-height:24px}
.tf__back{background:none;border:0;color:var(--tenue);font-family:var(--ff-title);font-weight:600;cursor:pointer;font-size:.92rem;padding:0;transition:color .2s ease}
.tf__back:hover{color:var(--lime)}
.tf__count{color:var(--tenue-2);font-family:var(--ff-title);font-size:.85rem;margin-left:auto}

.form__row{margin-bottom:.9rem;display:flex;flex-direction:column;gap:.35rem}
.form__row label{font-family:var(--ff-title);font-weight:500;font-size:.9rem;color:#cfd2d6}
.form__row input,.form__row textarea,.form__row select{
  width:100%;padding:.8rem .95rem;border-radius:10px;border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.3);color:#fff;font-family:var(--ff-body);font-size:1rem;transition:border-color .2s ease}
.form__row input:focus,.form__row textarea:focus,.form__row select:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px rgba(200,255,51,.15)}
.form__row select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23c8ff33' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center}
.form__row select option{background:#101012}
.form__status{margin:.8rem 0 0;font-weight:600;min-height:1.2em;font-size:.95rem}
.form__status.ok{color:var(--lime)}
.form__status.err{color:#ff9b9b}
.form__legal{margin:.6rem 0 0;font-size:.78rem;color:var(--tenue-2)}
.form__legal a{color:var(--tenue);text-decoration:underline}
.tf__hint{margin:.5rem 0 .2rem;font-size:.82rem;color:var(--tenue);line-height:1.4}

/* ===== Footer (estilo footer-section: gradiente radial + divisor difuminado + blur stagger) ===== */
.site-footer{position:relative;background:radial-gradient(60% 130px at 50% 0%,rgba(200,255,51,.08),transparent),#080808;
  border-top:1px solid var(--linea);padding:3.8rem 0 1.5rem;color:#aeb2b8;margin-top:2rem}
.footer__divider{position:absolute;top:-1px;left:50%;transform:translateX(-50%);height:2px;width:34%;
  background:rgba(200,255,51,.5);filter:blur(3px);border-radius:50px}
.footer__grid{display:grid;grid-template-columns:1.6fr 2.4fr;gap:2.5rem}
.footer__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.footer__brand .brand{margin-bottom:1rem}
.footer__brand p{max-width:280px;color:var(--tenue);font-size:.95rem}

/* Animación blur escalonada (footer-section): blur+translateY+opacity al entrar */
html.anim-ready .fade-blur{opacity:0;filter:blur(4px);transform:translateY(-8px);transition:opacity .8s ease,filter .8s ease,transform .8s ease}
html.anim-ready .fade-blur.is-in{opacity:1;filter:none;transform:none}
@media(prefers-reduced-motion:reduce){html.anim-ready .fade-blur{opacity:1!important;filter:none!important;transform:none!important;transition:none}}
.footer__social{display:flex;gap:1rem;margin-top:1.1rem}
.footer__social a{width:38px;height:38px;border-radius:10px;border:1px solid var(--linea);display:grid;place-items:center;color:#cfd2d6;transition:var(--trans)}
.footer__social a:hover{border-color:var(--lime);color:var(--lime);transform:translateY(-2px)}
.footer__social svg{width:18px;height:18px}
.footer__col h4{color:#fff;font-size:1.05rem;margin-bottom:1rem}
.footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer__col a:hover,.footer__col li a:hover{color:var(--lime)}
.footer__col .muted{color:var(--tenue);font-size:.92rem}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;border-top:1px solid var(--linea);margin-top:2.5rem;padding-top:1.5rem;font-size:.88rem;color:var(--tenue-2)}
.footer__bottom a{color:var(--tenue)}.footer__bottom a:hover{color:var(--lime)}

/* ===== Modal legal (Términos / Privacidad) ===== */
.legal{position:fixed;inset:0;z-index:1100;display:none;align-items:center;justify-content:center;padding:2rem}
.legal.is-open{display:flex}
.legal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:fadeIn .3s ease}
.legal__panel{position:relative;z-index:2;width:min(720px,96vw);max-height:90vh;display:flex;flex-direction:column;
  background:#0e0e10;border:1px solid var(--linea);border-radius:18px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.6)}
.legal__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.4rem;border-bottom:1px solid var(--linea);background:#101012}
.legal__title{font-family:var(--ff-title);font-weight:700;color:#fff;font-size:1.2rem}
.legal__close{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;border:0;font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:var(--trans)}
.legal__close:hover{background:rgba(255,255,255,.22)}
.legal__content{overflow-y:auto;padding:1.6rem 1.8rem 2rem}
.legal__content .legal__meta{color:var(--tenue-2);font-size:.85rem;background:rgba(255,255,255,.03);border:1px solid var(--linea);border-radius:10px;padding:.8rem 1rem;margin-bottom:1.4rem}
.legal__content h3{color:#fff;font-size:1.05rem;margin:1.6rem 0 .5rem}
.legal__content h3:first-of-type{margin-top:0}
.legal__content p{color:var(--tenue);font-size:.95rem;line-height:1.65;margin:0 0 .8rem}
.legal__content ul{margin:0 0 1rem;padding-left:1.2rem;color:var(--tenue);font-size:.95rem;line-height:1.6}
.legal__content li{margin-bottom:.4rem}
.legal__content strong{color:#e9eaec}

/* ===== Asistente Matías (flotante) ===== */
.matias{position:fixed;right:1.2rem;bottom:1.2rem;z-index:300;display:flex;flex-direction:column;align-items:flex-end;gap:.8rem}
.matias__btn{display:inline-flex;align-items:center;gap:.6rem;background:var(--lime);color:#0a0a0a;
  padding:.65rem 1.15rem .65rem .7rem;border:0;border-radius:50px;cursor:pointer;font-family:var(--ff-title);font-weight:700;
  box-shadow:0 12px 30px rgba(200,255,51,.3);transition:transform .2s ease,box-shadow .2s ease}
.matias__btn:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 16px 40px rgba(200,255,51,.45)}
.matias__label{font-size:.92rem}
.matias__ava{width:34px;height:34px;border-radius:50%;background:#0a0a0a;color:var(--lime);display:grid;place-items:center;flex-shrink:0}
.matias__ava svg{width:20px;height:20px}
.matias__ava--lg{width:42px;height:42px;background:var(--lime-soft)}
.matias__ava--lg svg{width:24px;height:24px}
.matias__panel{width:min(340px,calc(100vw - 2rem));background:#0e0e10;border:1px solid var(--linea);border-radius:18px;
  overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.6);transform-origin:bottom right;animation:matIn .3s cubic-bezier(.34,1.4,.64,1)}
@keyframes matIn{from{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:none}}
.matias__head{display:flex;align-items:center;gap:.7rem;padding:1rem 1.1rem;border-bottom:1px solid var(--linea);background:#101012}
.matias__id b{font-family:var(--ff-title);color:#fff;font-size:1.05rem;display:block;line-height:1.1}
.matias__status{color:var(--tenue);font-size:.8rem;display:flex;align-items:center;gap:.35rem}
.matias__status i{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 8px var(--lime)}
.matias__close{margin-left:auto;background:none;border:0;color:var(--tenue);font-size:1.5rem;line-height:1;cursor:pointer;width:30px;height:30px;border-radius:50%;transition:var(--trans)}
.matias__close:hover{background:rgba(255,255,255,.1);color:#fff}
.matias__body{padding:1.1rem;display:flex;flex-direction:column;gap:.7rem;background:radial-gradient(ellipse at 100% 0%,rgba(200,255,51,.05),transparent 60%)}
.matias__bubble{background:rgba(255,255,255,.05);border:1px solid var(--linea);border-radius:14px 14px 14px 4px;padding:.8rem .95rem;color:#e2e4e7;font-size:.92rem;line-height:1.5;max-width:90%}
.matias__bubble--soft{color:var(--tenue)}
.matias__bubble b{color:#fff}
.matias__foot{padding:0 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.6rem;align-items:center}
.matias__cta{font-size:.95rem}
.matias__alt{color:var(--tenue);font-size:.85rem;text-decoration:underline}
.matias__alt:hover{color:var(--lime)}

/* ===== Reveal al scroll ===== */
html.anim-ready .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,.61,.36,1)}
html.anim-ready .reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html.anim-ready .reveal{opacity:1!important;transform:none!important;transition:none}
  .hero__badge,.hero__pill .dot{animation:none}
}

/* ===== Responsive ===== */
@media(max-width:960px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__visual{max-width:520px;margin-inline:auto}
  .browser{transform:none}
  .sample__card{grid-template-columns:1fr}
  .metodo__grid,.ads__grid,.cta__wrap{grid-template-columns:1fr}
  .cards--4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .planes__grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto}
  .adic__grid{grid-template-columns:1fr;max-width:480px;margin-inline:auto}
  .svc--feat{grid-column:span 1}
  .footer__grid{grid-template-columns:1fr;gap:2.5rem}
  .port__grid,.testi__grid{grid-template-columns:1fr}
  #tpl-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .nav__toggle{display:flex}
  .nav__menu{position:fixed;z-index:105;inset:0 0 0 auto;width:min(82vw,330px);background:#0c0c0e;flex-direction:column;
    align-items:flex-start;gap:1.5rem;padding:5.5rem 2rem 2rem;transform:translateX(100%);transition:transform .3s ease;box-shadow:-10px 0 40px rgba(0,0,0,.5);border-left:1px solid var(--linea)}
  .nav__menu.is-open{transform:translateX(0)}
  .nav__menu .btn{width:100%}
  .cards--3,.cards--4,.steps{grid-template-columns:1fr}
  .hero__title{font-size:clamp(2.2rem,9vw,3rem)}
  .garantia__inner{flex-direction:column;text-align:center;align-items:center}
  .garantia p{margin-inline:auto}
  /* Footer minimalista en móvil: solo marca + redes + legal */
  .site-footer{padding:2.5rem 0 1.3rem;margin-top:1rem}
  .footer__grid{grid-template-columns:1fr;text-align:center}
  .footer__cols{display:none}
  .footer__brand .brand{justify-content:center}
  .footer__brand p{margin-inline:auto;max-width:300px}
  .footer__social{justify-content:center}
  /* Plantillas en 2x2 (sin descripción para que respiren) */
  #tpl-grid{grid-template-columns:repeat(2,1fr);gap:.7rem}
  #tpl-grid .pcard__body{padding:.85rem}
  #tpl-grid .pcard__body h3{font-size:.95rem}
  #tpl-grid .pcard__body p{display:none}
  .footer__bottom{flex-direction:column;text-align:center}
  .matias__label{display:none}
  .matias__btn{padding:.7rem}
  .matias__ava{width:32px;height:32px}
}

/* ===== Estado de éxito del formulario ===== */
.fsuccess{text-align:center;padding:1rem .5rem 1.5rem;animation:fsuccessIn .45s cubic-bezier(.2,.8,.2,1) both}
.fsuccess__badge{width:84px;height:84px;margin:0 auto 1.3rem;border-radius:50%;
  display:grid;place-items:center;background:var(--lime-soft);color:var(--lime);
  animation:fsuccessPop .5s .1s cubic-bezier(.2,1.3,.4,1) both, fsuccessRing 1.8s 1s ease-out}
.fsuccess__badge svg{width:42px;height:42px;stroke-dasharray:30;stroke-dashoffset:30;animation:fsuccessCheck .5s .35s ease forwards}
.fsuccess__pill{display:inline-flex;align-items:center;gap:.5rem;background:var(--lime-soft);
  border:1px solid rgba(200,255,51,.3);color:var(--lime);font-family:var(--ff-title);font-weight:600;
  font-size:.78rem;letter-spacing:.5px;text-transform:uppercase;padding:.32rem .85rem;border-radius:999px;margin-bottom:1rem}
.fsuccess__pill .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);animation:pulse 2s infinite}
.fsuccess__title{font-size:clamp(1.5rem,4vw,2rem);margin-bottom:.7rem}
.fsuccess__text{color:var(--tenue);font-size:1.05rem;max-width:30rem;margin:0 auto 1.6rem}
.fsuccess__text b{color:#fff;font-weight:600}
.fsuccess__cta{display:flex;flex-direction:column;gap:.7rem;max-width:24rem;margin:0 auto}
.fsuccess__foot{color:var(--tenue);font-size:.85rem;margin-top:1.1rem}
@keyframes fsuccessIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes fsuccessPop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
@keyframes fsuccessCheck{to{stroke-dashoffset:0}}
@keyframes fsuccessRing{0%{box-shadow:0 0 0 0 rgba(200,255,51,.4)}100%{box-shadow:0 0 0 22px rgba(200,255,51,0)}}
