/* DA Seguridad — landing styles
   Critical CSS (tokens, body, topbar, offerbar, hero, container, base typo)
   ya va inline en index.html. Este archivo contiene el resto. */

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:700;font-size:1rem;
  min-height:52px;padding:16px 24px;border-radius:var(--radius-pill);
  border:2px solid transparent;cursor:pointer;text-align:center;
  transition:transform .15s ease,background-color .15s ease,box-shadow .15s ease;
  text-decoration:none;
}
.btn:hover{text-decoration:none}
.btn:active{transform:scale(.98)}
.btn--primary{background:var(--color-yellow);color:var(--color-blue-deep)}
.btn--primary:hover{background:var(--color-yellow-soft)}
.btn--secondary{background:transparent;color:var(--color-blue-marine);border-color:var(--color-blue-marine)}
.btn--secondary:hover{background:var(--color-blue-marine);color:#fff}
.btn--dark{background:var(--color-blue-marine);color:#fff}
.btn--dark:hover{background:var(--color-blue-deep)}
.btn--block{width:100%}
.btn--lg{min-height:60px;font-size:1rem}
@media(min-width:1024px){.btn--lg{font-size:1.0625rem}}

/* Reset fieldset (evita padding/border default del navegador que desfasa los radios) */
fieldset{padding:0;border:0;margin:0;min-width:0}

/* SECTION BASE */
section{padding:var(--space-16) 0}
@media(min-width:1024px){section{padding:var(--space-20) 0}}
.section__head{text-align:center;max-width:680px;margin:0 auto var(--space-12)}
.section__head p{color:var(--color-text-muted);font-size:1.0625rem}

/* Price section: título en una sola línea en desktop */
@media(min-width:1024px){
  section[aria-labelledby="price-title"] .section__head{max-width:none}
  #price-title{white-space:nowrap}
}

/* Solution section: intro en 2 líneas balanceadas en desktop */
@media(min-width:1024px){
  section[aria-labelledby="solution-title"] .section__head{max-width:920px}
  section[aria-labelledby="solution-title"] .section__head p{text-wrap:balance}
}

/* FORM PRINCIPAL */
.form-card{
  background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  padding:var(--space-6);max-width:920px;margin:0 auto;
}
@media(min-width:768px){.form-card{padding:var(--space-12)}}
.form-card__header{margin-bottom:var(--space-6)}
.form-reminder{display:flex;align-items:center;gap:10px;background:rgba(26,90,171,.08);border:1px solid rgba(26,90,171,.3);color:var(--color-blue-deep);padding:12px 16px;border-radius:var(--radius-md);font-size:var(--fs-small);font-weight:600;margin:var(--space-5) 0 0;line-height:1.35;text-align:left}
.form-reminder svg{fill:var(--color-blue-klein);flex:none}
@media(max-width:520px){.form-reminder{font-size:var(--fs-micro);padding:10px 12px;gap:8px}}
.form-card__title{font-size:1.25rem;margin-bottom:var(--space-4)}
.progress{display:flex;flex-direction:column;gap:var(--space-2)}
.progress__track{height:8px;background:#EEF2F6;border-radius:var(--radius-pill);overflow:hidden}
.progress__fill{height:100%;width:16.66%;background:var(--color-yellow);border-radius:inherit;transition:width .35s ease}
.progress__label{font-size:var(--fs-small);color:var(--color-text-muted);font-weight:600}

.step[hidden]{display:none!important}
.step__legend{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--color-blue-deep);margin:0 0 var(--space-4);padding:0}
.step__help{font-size:var(--fs-small);color:var(--color-text-muted);margin:-8px 0 var(--space-5)}
.step__micro{font-size:var(--fs-small);color:var(--color-text-muted);margin-top:var(--space-3)}
.field__micro{font-size:var(--fs-micro);color:var(--color-text-muted);margin:6px 0 0;line-height:1.4}
.field__coverage{display:inline-flex;align-items:center;gap:6px;margin:8px 0 0;padding:6px 10px;background:rgba(2,122,72,.08);border-radius:var(--radius-md);color:var(--color-success);font-size:var(--fs-small);font-weight:600;line-height:1.3;animation:coverageFadeIn .25s ease-out}
.field__coverage svg{flex:none;fill:var(--color-success)}
@keyframes coverageFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.field__coverage{animation:none}}

.radio-cards{display:flex;flex-direction:column;gap:var(--space-3);margin:0;padding:0;list-style:none;border:0}
.radio-card{position:relative;display:block}
.radio-card input{position:absolute;opacity:0;pointer-events:none}
.radio-card__label{
  display:flex;align-items:center;gap:var(--space-3);
  border:2px solid var(--color-border);background:#fff;
  padding:16px;border-radius:var(--radius-md);
  font-weight:500;min-height:60px;cursor:pointer;
  transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease;
}
.radio-card__label::before{
  content:"";width:22px;height:22px;border-radius:50%;
  border:2px solid var(--color-border);flex:none;background:#fff;
  transition:border-color .15s ease,box-shadow .15s ease;
}
.radio-card input:checked + .radio-card__label{
  border-color:var(--color-blue-klein);background:#F4F8FD;box-shadow:0 0 0 3px rgba(26,90,171,.12);
}
.radio-card input:checked + .radio-card__label::before{
  border-color:var(--color-blue-klein);box-shadow:inset 0 0 0 5px var(--color-blue-klein);
}
.radio-card input:focus-visible + .radio-card__label{outline:3px solid var(--color-yellow);outline-offset:2px}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--space-4)}
.field label{font-weight:600;font-size:var(--fs-small);color:var(--color-text)}
.field input{
  font:inherit;color:var(--color-text);background:#fff;
  border:2px solid var(--color-border);border-radius:var(--radius-md);
  padding:14px 16px;min-height:48px;
  transition:border-color .15s ease,box-shadow .15s ease;
}
.field input:focus{border-color:var(--color-blue-klein);outline:none;box-shadow:0 0 0 3px rgba(26,90,171,.15)}
.field input[aria-invalid="true"]{border-color:#B42318;box-shadow:0 0 0 3px rgba(180,35,24,.12)}

/* intl-tel-input integración con .field */
.field .iti{width:100%;display:block}
.field .iti__tel-input{width:100%}
.iti--separate-dial-code .iti__selected-dial-code{font-weight:500}
.field__error{color:#B42318;font-size:var(--fs-small);font-weight:600;min-height:1.25em}

.checkbox{display:flex;gap:10px;align-items:flex-start;font-size:var(--fs-small);color:var(--color-text-muted);margin:var(--space-2) 0 var(--space-5)}
.checkbox input{margin-top:3px;flex:none;width:18px;height:18px;accent-color:var(--color-blue-klein)}
.checkbox a{color:var(--color-blue-klein);text-decoration:underline}

.step__nav{display:flex;gap:var(--space-3);margin-top:var(--space-6);flex-wrap:wrap}
.step__nav .btn{flex:1;min-width:140px}

.form-success{text-align:center;padding:var(--space-8) var(--space-4)}
.form-success svg{width:64px;height:64px;fill:var(--color-success);margin:0 auto var(--space-4)}
.form-discard svg{fill:var(--color-text-muted)}
.form-success h3,.closer .form-success h3{color:var(--color-blue-deep)}
.form-success p,.closer .form-success p{color:var(--color-text-muted)}
.cierre-fields__back{margin-bottom:var(--space-4)}
.cierre-fields__back .btn{min-height:40px;padding:8px 16px;font-size:.9375rem}
.form-discard [data-cierre-back]{margin-top:var(--space-4)}
[hidden]{display:none!important}

/* Step 6 — Calcula tu alarma */
.step__sub{font-size:1rem;color:var(--color-text-muted);margin:0 0 var(--space-5)}
.step__aux{font-size:var(--fs-micro);color:var(--color-text-muted);text-align:center;margin:var(--space-3) 0 0}
.step__aux a{color:var(--color-blue-klein);text-decoration:underline}

/* Botón en estado loading (spinner) */
.btn[aria-busy="true"]{opacity:.85;cursor:progress}
.btn .btn__spinner{width:18px;height:18px;flex:none;animation:btnSpin .7s linear infinite}
@keyframes btnSpin{to{transform:rotate(360deg)}}

/* Error recuperable del form */
.form-error{margin-top:var(--space-5);padding:var(--space-4);border:1px solid #FECDCA;background:#FEF3F2;border-radius:var(--radius-md);text-align:center}
.form-error p{color:#B42318;font-size:var(--fs-small);font-weight:600;margin:0 0 var(--space-3)}

/* PANTALLA FINAL — confirmación */
.form-final{padding:var(--space-2) 0}
.form-final__head{text-align:center;margin-bottom:var(--space-8)}
.form-final__seal{width:72px;height:72px;border-radius:50%;background:rgba(2,122,72,.12);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4);animation:sealPop .5s cubic-bezier(.34,1.56,.64,1) both}
.form-final__seal svg{width:40px;height:40px;fill:var(--color-success)}
@keyframes sealPop{0%{opacity:0;transform:scale(.4)}100%{opacity:1;transform:scale(1)}}
.form-final__meta{font-size:var(--fs-micro);color:var(--color-text-muted);margin:0 0 var(--space-2);font-weight:600}
.form-final__title{font-size:1.5rem;margin:0 0 var(--space-3);outline:none}
.form-final__intro{color:var(--color-text-muted);font-size:1rem;max-width:46ch;margin:0 auto}

.form-final__summary{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-8)}
.summary-col{background:#FAFBFC;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);display:grid;grid-template-columns:44px 1fr;column-gap:var(--space-4);align-items:center}
.summary-col__icon{width:44px;height:44px;border-radius:var(--radius-md);background:#EEF4FB;display:flex;align-items:center;justify-content:center;grid-row:1 / span 2;align-self:start}
.summary-col__icon svg{width:26px;height:26px;fill:var(--color-blue-klein)}
.summary-col h3{font-size:1rem;color:var(--color-blue-deep);margin:0;align-self:end}
.summary-col ul{list-style:none;margin:var(--space-2) 0 0;padding:0;display:flex;flex-direction:column;gap:6px;grid-column:2}
.summary-col li{font-size:var(--fs-small);color:var(--color-text);padding-left:18px;position:relative;line-height:1.4}
.summary-col li::before{content:"";position:absolute;left:0;top:6px;width:10px;height:10px;border-radius:2px;background:var(--color-yellow)}

/* WhatsApp callout */
.form-final__whatsapp{background:#25D366;color:#fff;border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;margin-bottom:var(--space-6);box-shadow:var(--shadow-md)}
.wa__icon{width:48px;height:48px;margin:0 auto var(--space-3)}
.wa__icon svg{width:48px;height:48px;fill:#fff}
.wa__intro{font-size:var(--fs-small);color:rgba(255,255,255,.95);margin:0 auto var(--space-4);max-width:42ch;line-height:1.45}
.wa__label{font-size:var(--fs-small);font-weight:600;margin:0 0 var(--space-1);opacity:.9}
.wa__number{display:inline-block;font-family:var(--font-display);font-weight:800;font-size:1.75rem;color:#fff;text-decoration:none;letter-spacing:.01em}
.wa__number:hover{text-decoration:underline;color:#fff}

.form-final__next{text-align:center}
.form-final__next p{color:var(--color-text-muted);font-size:var(--fs-small);margin:0 0 var(--space-4)}

@media(min-width:1024px){
  .form-final__whatsapp{padding:var(--space-8)}
  .wa__number{font-size:2rem}
}
@media(prefers-reduced-motion:reduce){
  .form-final__seal{animation:none}
}

/* BLOQUE URGENCIA — promo limitada (fondo amarillo, layout horizontal 2 cols) */
.urgency{padding:var(--space-10) 0;background:linear-gradient(135deg,var(--color-yellow) 0%,var(--color-yellow-soft) 100%);color:var(--color-blue-deep);position:relative;overflow:hidden}
.urgency::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 80% 30%,rgba(15,26,61,.06) 0%,transparent 50%),radial-gradient(circle at 20% 80%,rgba(15,26,61,.04) 0%,transparent 45%);pointer-events:none}
.urgency .container{position:relative}
.urgency__card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-5);text-align:left}
.urgency__text{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);position:relative;padding-left:22px}
.urgency__dot{position:absolute;left:0;top:10px;width:10px;height:10px;border-radius:50%;background:var(--color-blue-marine);box-shadow:0 0 0 0 rgba(31,42,90,.5);animation:urgencyPulse 1.8s ease-out infinite}
@keyframes urgencyPulse{0%{box-shadow:0 0 0 0 rgba(31,42,90,.55)}70%{box-shadow:0 0 0 14px rgba(31,42,90,0)}100%{box-shadow:0 0 0 0 rgba(31,42,90,0)}}
.urgency__title{color:var(--color-blue-deep);font-size:clamp(1.375rem,3.2vw,1.75rem);margin:0;line-height:1.25}
.urgency__sub{margin:0;color:rgba(15,26,61,.8);font-size:1rem;display:flex;flex-wrap:wrap;gap:6px}
.urgency__sub strong{color:var(--color-blue-deep);font-weight:800;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.urgency__action{flex:none}
.urgency__action .btn{white-space:nowrap;background:var(--color-blue-marine);color:#fff;border-color:var(--color-blue-marine)}
.urgency__action .btn:hover{background:var(--color-blue-deep)}
@media(min-width:768px){
  .urgency__card{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-8)}
  .urgency__text{flex:1;min-width:0}
}
@media(prefers-reduced-motion:reduce){.urgency__dot{animation:none}}

/* SECCION 2 — Banner autoridad (chips) */
.authority{background:var(--color-blue-marine);color:#fff;padding:var(--space-10) 0}
.authority__list{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:var(--space-3);list-style:none;margin:0;padding:0}
.authority__chip{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  padding:10px 18px;border-radius:var(--radius-pill);
  font-weight:600;font-size:.9375rem;line-height:1.3;color:#fff;
  transition:background-color .25s cubic-bezier(.16,1,.3,1),transform .25s cubic-bezier(.16,1,.3,1),border-color .25s ease;
}
.authority__chip svg{fill:var(--color-yellow);flex:none}
@media(min-width:768px){
  .authority__chip{padding:12px 22px;font-size:1rem}
  .authority__chip svg{width:22px;height:22px}
}
@media(min-width:1024px){
  .authority__list{flex-wrap:nowrap}
  .authority__chip{flex-shrink:1;min-width:0}
}

/* SECCION 3 — Cards "Lo que nadie te explica" */
.truth-grid{display:grid;gap:var(--space-5)}
.truth-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}
.truth-card__img{display:block;width:100%;aspect-ratio:16/9;object-fit:cover;background:#EEF4FB;border-bottom:1px solid var(--color-border)}
.truth-card__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);flex:1}
.truth-card h3{font-size:1.125rem;color:var(--color-blue-deep);margin:0}
.truth-card p{color:var(--color-text-muted);font-size:1rem;margin:0}
@media(min-width:768px){.truth-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){
  .truth-grid{grid-template-columns:repeat(4,1fr)}
}

/* SECCION 4 — Producto */
.features{display:grid;gap:var(--space-5);grid-template-columns:1fr}
.feature{
  display:flex;flex-direction:column;align-items:flex-start;
  gap:var(--space-4);background:#fff;border:1px solid var(--color-border);
  border-radius:var(--radius-md);padding:var(--space-6);
  transition:transform .2s ease,box-shadow .2s ease;
}
.feature__icon{
  width:64px;height:64px;border-radius:var(--radius-md);
  background:#EEF4FB;color:var(--color-blue-klein);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.feature__icon svg{width:36px;height:36px;fill:var(--color-blue-klein)}
.feature h3{font-size:1.125rem;margin-bottom:var(--space-2)}
.feature p{color:var(--color-text-muted);margin:0}
@media(min-width:768px){.features{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.features{gap:var(--space-6)}}

/* SECCION 5 — Precio */
.price-card{
  background:linear-gradient(160deg,var(--color-blue-marine) 0%,var(--color-blue-deep) 100%);
  color:#fff;border-radius:var(--radius-lg);
  padding:var(--space-10) var(--space-6);text-align:center;
  max-width:720px;margin:0 auto;box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
@media(min-width:768px){.price-card{padding:var(--space-16) var(--space-12)}}
.price-card__amount{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.25rem,8vw,4.25rem);line-height:1.05;color:var(--color-yellow);
  margin:0 0 var(--space-3);letter-spacing:-.02em;
}
.price-card__amount small{display:block;font-size:1rem;color:#fff;font-weight:500;margin-top:var(--space-2);letter-spacing:0}
.price-card__bullets{color:#fff;font-weight:600;margin:0 0 var(--space-5);font-size:1rem;opacity:.95}
.price-card__note{color:rgba(255,255,255,.85);font-size:var(--fs-small);margin:0 auto var(--space-6);max-width:480px}
.price-card .btn{margin-top:var(--space-2)}

/* SECCION 6 — Proceso */
.timeline{display:grid;gap:var(--space-8);position:relative;list-style:none;padding:0;margin:0}
.timeline__step{position:relative;display:grid;grid-template-columns:48px 1fr;gap:var(--space-4);align-items:flex-start}
.timeline__num{
  width:48px;height:48px;border-radius:50%;
  background:var(--color-yellow);color:var(--color-blue-deep);
  font-family:var(--font-display);font-weight:800;font-size:1.25rem;
  display:flex;align-items:center;justify-content:center;flex:none;
}
.timeline__step::before{
  content:"";position:absolute;left:23px;top:48px;bottom:-32px;width:2px;
  background:repeating-linear-gradient(to bottom,var(--color-border) 0 6px,transparent 6px 12px);
}
.timeline__step:last-child::before{display:none}
.timeline__body h3{font-size:1.125rem;margin-bottom:var(--space-2)}
.timeline__body p{color:var(--color-text-muted);margin:0}
@media(min-width:1024px){
  .timeline{grid-template-columns:repeat(3,1fr);gap:var(--space-8)}
  .timeline__step{grid-template-columns:1fr;text-align:center;gap:var(--space-4)}
  .timeline__num{margin:0 auto}
  .timeline__step::before{display:none}
}
.timeline-cta{text-align:center;margin-top:var(--space-10)}

@keyframes logoScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* SECCION 7 — Testimonios (swipe carousel mobile) */
.testimonials{
  display:flex;
  flex-wrap:nowrap;
  gap:var(--space-4);
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:var(--space-2) var(--space-5) var(--space-6);
  margin:0 calc(var(--space-5) * -1);
  scrollbar-width:none;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  touch-action:pan-x pan-y;
}
.testimonials:active{cursor:grabbing}
/* Permite seleccionar texto solo cuando no se está arrastrando — opcional */
.testimonials::-webkit-scrollbar{display:none}
.testimonial{
  flex:0 0 auto;
  width:86%;
  max-width:380px;
  scroll-snap-align:start;
  background:#fff;border:1px solid var(--color-border);
  border-radius:var(--radius-md);padding:var(--space-6);
  position:relative;overflow:hidden;margin:0;
}
.testimonial::before{
  content:"\201C";position:absolute;top:-30px;right:8px;
  font-family:Georgia,serif;font-size:9rem;line-height:1;color:var(--color-yellow);opacity:.18;
  pointer-events:none;
}
.testimonial p{font-size:1rem;color:var(--color-text);margin:0 0 var(--space-4);position:relative}
.testimonial cite{font-style:normal;font-weight:700;color:var(--color-blue-deep)}
.testimonial cite span{display:block;font-weight:500;color:var(--color-text-muted);font-size:var(--fs-small);margin-top:2px}

@media(min-width:1024px){
  .testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);overflow:visible;padding:0;margin:0;flex-wrap:initial;cursor:auto;user-select:auto;-webkit-user-select:auto;touch-action:auto}
  .testimonial{flex:initial;width:auto;max-width:none}
}

/* Forzar visibilidad de testimonios incluso si la animación reveal no completa */
.testimonials .testimonial{opacity:1!important;animation:none!important}

/* SECCION 8 — CTA final */
.closer{background:var(--color-blue-marine);color:#fff;position:relative;overflow:hidden}
.closer::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(45deg,rgba(242,183,5,.08) 1px,transparent 1px),
    linear-gradient(-45deg,rgba(242,183,5,.08) 1px,transparent 1px);
  background-size:36px 36px;opacity:.6;
}
.closer .container{position:relative}
.closer h2,.closer p{color:#fff}
.closer .section__head p{color:rgba(255,255,255,.85)}
.closer .form-card{color:var(--color-text)}
@media(min-width:1024px){
  .closer .section__head{max-width:920px}
  #closer-title span{display:block;text-wrap:balance}
}

/* FOOTER */
.footer{background:var(--color-blue-deep);color:#fff;padding:var(--space-10) 0 var(--space-6)}
.footer__top{display:grid;gap:var(--space-6);grid-template-columns:1fr;margin-bottom:0}
.footer__brand img,.footer__logo{height:44px;width:auto;max-width:180px;object-fit:contain;margin-bottom:var(--space-3);display:block}
.footer__brand p{color:rgba(255,255,255,.6);font-size:var(--fs-micro);max-width:48ch;margin:0 0 var(--space-3);line-height:1.5}
.footer__col h4{font-family:var(--font-display);font-size:.9375rem;color:#fff;margin:0 0 var(--space-3);font-weight:700}
.footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer__col a{color:rgba(255,255,255,.7);font-size:var(--fs-small)}
.footer__col a:hover{color:#fff}
.footer__phone{display:flex;align-items:center;gap:8px;color:var(--color-yellow);font-weight:700;font-size:1.0625rem;margin-bottom:var(--space-3)}
.footer__phone svg{fill:var(--color-yellow)}
.footer__phone a{color:inherit}
@media(max-width:767px){
  .footer{text-align:center}
  .footer__brand{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--space-3) var(--space-4);text-align:center}
  .footer__brand .footer__logo{margin:0;flex:0 0 auto}
  .footer__brand .footer__phone{margin:0;font-size:1rem;flex:0 0 auto}
  .footer__brand p{margin:0;text-align:center;max-width:none;flex:1 1 100%}
  .footer__col{text-align:center}
  .footer__col ul{align-items:center}
}
@media(min-width:768px){
  .footer{padding:var(--space-12) 0 var(--space-8)}
  .footer__top{grid-template-columns:1fr auto;gap:var(--space-12);align-items:start}
  .footer__brand{grid-column:1}
  .footer__brand img,.footer__logo{height:48px}
  .footer__col{grid-column:2;justify-self:end;text-align:right}
  .footer__col ul{align-items:flex-end}
  .footer__col h4{font-size:1rem}
}

/* MODAL */
.modal{
  position:fixed;inset:0;display:none;align-items:center;justify-content:center;
  background:rgba(15,26,61,.6);padding:var(--space-4);z-index:120;
  backdrop-filter:blur(2px);
}
.modal[open]{display:flex}
.modal__panel{
  background:#fff;border-radius:var(--radius-lg);max-width:480px;width:100%;
  padding:var(--space-8) var(--space-6);box-shadow:var(--shadow-lg);
  transform:scale(.96);opacity:0;transition:transform .2s ease,opacity .2s ease;
  max-height:90vh;overflow-y:auto;position:relative;
}
.modal[open] .modal__panel{transform:scale(1);opacity:1}
.modal__close{
  position:absolute;top:16px;right:16px;background:transparent;border:0;
  width:44px;height:44px;border-radius:50%;color:var(--color-text);
  display:flex;align-items:center;justify-content:center;
}
.modal__close:hover{background:#F1F4F8}
.modal__title{margin-bottom:var(--space-3)}
.modal__sub{color:var(--color-text-muted);margin-bottom:var(--space-5);font-size:var(--fs-small)}

/* === Scroll reveal === */
@keyframes revealFallback{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1);
  /* Fallback: si JS falla y no añade is-visible, mostrar a los 2s */
  animation:revealFallback .6s cubic-bezier(.16,1,.3,1) 2s forwards;
}
.reveal.is-visible{opacity:1;transform:none;animation:none}

/* Stagger de hijos dentro de secciones reveladas */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.reveal .truth-card,
.reveal .feature,
.reveal .testimonial,
.reveal .timeline__step{opacity:0}
.reveal.is-visible .truth-card,
.reveal.is-visible .feature,
.reveal.is-visible .testimonial,
.reveal.is-visible .timeline__step{animation:fadeUp .5s cubic-bezier(.16,1,.3,1) forwards}
.reveal.is-visible .truth-card:nth-child(1),
.reveal.is-visible .feature:nth-child(1),
.reveal.is-visible .testimonial:nth-child(1),
.reveal.is-visible .timeline__step:nth-child(1){animation-delay:.05s}
.reveal.is-visible .truth-card:nth-child(2),
.reveal.is-visible .feature:nth-child(2),
.reveal.is-visible .testimonial:nth-child(2),
.reveal.is-visible .timeline__step:nth-child(2){animation-delay:.15s}
.reveal.is-visible .truth-card:nth-child(3),
.reveal.is-visible .feature:nth-child(3),
.reveal.is-visible .testimonial:nth-child(3),
.reveal.is-visible .timeline__step:nth-child(3){animation-delay:.25s}
.reveal.is-visible .truth-card:nth-child(4),
.reveal.is-visible .feature:nth-child(4){animation-delay:.35s}

/* === Microinteracciones === */

/* Botones: solo cambio de color en hover (sin lift, sin shine, sin shadow) */
.btn{transition:background-color .2s ease,color .2s ease,border-color .2s ease}
.btn:active{transform:scale(.98)}

/* Topbar phone: icono jiggle al hover */
.topbar a:hover svg{animation:phoneRing .5s ease}
@keyframes phoneRing{
  0%,100%{transform:rotate(0)}
  20%{transform:rotate(-15deg)}
  40%{transform:rotate(10deg)}
  60%{transform:rotate(-8deg)}
  80%{transform:rotate(4deg)}
}

/* (Offerbar logo: sin hover — no es clickeable) */

/* (Truth cards, feature cards y timeline numbers no son clickeables — sin hover) */

/* Radio card: pop al seleccionar */
@keyframes radioPop{
  0%{transform:scale(.6)}
  60%{transform:scale(1.18)}
  100%{transform:scale(1)}
}
.radio-card input:checked + .radio-card__label::before{
  animation:radioPop .3s cubic-bezier(.34,1.56,.64,1);
}
.radio-card__label{transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease,transform .15s ease}
.radio-card__label:active{transform:scale(.985)}

/* Form inputs: focus ring suave */
.field input{transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}
.field input:focus{background:#fff}

/* (Testimonios sin hover — no son clickeables) */

/* Focus visible siempre tiene prioridad sobre microinteracciones */
.btn:focus-visible,
.radio-card input:focus-visible + .radio-card__label,
.field input:focus-visible{outline:3px solid var(--color-yellow);outline-offset:2px}

/* === Scroll progress bar (top fijo) === */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:transparent;pointer-events:none}
.scroll-progress__bar{height:100%;width:0;background:var(--color-yellow);transform-origin:left center;transition:width .05s linear;box-shadow:0 1px 4px rgba(242,183,5,.4)}
@media(prefers-reduced-motion:reduce){.scroll-progress{display:none}}

/* Lenis smooth scroll — required CSS */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:clip}

/* ============================================================
   COMPONENTES LANDING COMPARADOR
   ============================================================ */

/* Eyebrow (etiqueta pequeña sobre títulos) */
.eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:var(--fs-small);letter-spacing:.04em;text-transform:uppercase;color:var(--color-blue-klein);margin:0 0 var(--space-3)}
.closer .eyebrow{color:var(--color-yellow)}

/* Fila de logos del hero (comparador) */
.hero__logos{margin-top:var(--space-6);margin-bottom:var(--space-12)}
.hero__logos-label{font-size:var(--fs-micro);color:var(--color-text-muted);font-weight:600;margin:0 0 var(--space-3);text-transform:uppercase;letter-spacing:.03em}
.hero__logos-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-5) var(--space-8)}
.hero__logos-row img{height:42px;width:auto;filter:grayscale(1);opacity:.75}
@media(max-width:767px){.hero__logos-row{justify-content:center;gap:var(--space-5)}.hero__logos-row img{height:36px}}

/* Hero logos: marquee infinito */
.hero__logos-marquee{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent)}
.hero__logos-track{display:flex;align-items:center;gap:var(--space-10);width:max-content;animation:logoScroll 35s linear infinite}
.hero__logos-track img{height:42px;width:auto;flex:0 0 auto;filter:grayscale(1);opacity:.75;user-select:none;pointer-events:none}
@media(max-width:767px){.hero__logos-track{gap:var(--space-8);animation-duration:28s}.hero__logos-track img{height:36px}}
@media(hover:hover){.hero__logos-marquee:hover .hero__logos-track{animation-play-state:paused}}
@media(prefers-reduced-motion:reduce){
  .hero__logos-marquee{-webkit-mask-image:none;mask-image:none;overflow:visible}
  .hero__logos-track{animation:none;flex-wrap:wrap;justify-content:center;align-items:center;width:auto;gap:16px 24px}
  .hero__logos-track img{max-width:90px;max-height:32px;height:auto;object-fit:contain}
  .hero__logos-track img[aria-hidden="true"]{display:none}
}

/* Cards numeradas (sección "Cómo funciona" / pasos del proceso) */
.problem-grid{display:grid;gap:var(--space-5);position:relative}
@media(min-width:768px){.problem-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.problem-grid--3{grid-template-columns:repeat(3,1fr);gap:var(--space-10)}}

.problem-card{
  background:#fff;
  border:1px solid var(--color-border);
  border-radius:var(--radius-lg);
  padding:var(--space-8) var(--space-5) var(--space-6);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--space-3);
  position:relative;
  box-shadow:var(--shadow-sm);
  text-align:center;
}
.problem-card__step{
  font-family:var(--font-display);
  font-weight:700;
  font-size:var(--fs-micro);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--color-blue-klein);
  margin:0 0 var(--space-1);
}
.problem-card__num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:64px;height:64px;
  flex:none;
  border-radius:50%;
  background:var(--color-yellow);
  color:var(--color-blue-deep);
  font-family:var(--font-display);
  font-weight:800;
  font-size:1.75rem;
  line-height:1;
  box-shadow:0 10px 20px rgba(242,183,5,.4);
  margin-bottom:var(--space-2);
  position:relative;
  z-index:2;
}
.problem-card h3{font-size:1.125rem;color:var(--color-blue-deep);margin:0;line-height:1.3}
.problem-card p{color:var(--color-text-muted);font-size:1rem;margin:0;line-height:1.5}

/* Línea conectora entre cards en desktop (efecto "pasos") */
@media(min-width:1024px){
  .problem-grid--3{position:relative}
  .problem-grid--3 .problem-card:not(:last-child)::after{
    content:"";
    position:absolute;
    top:96px;
    right:calc(var(--space-10) * -1);
    width:var(--space-10);
    height:3px;
    background:repeating-linear-gradient(to right, var(--color-yellow) 0 8px, transparent 8px 14px);
    z-index:1;
  }
}

/* Tabla comparativa (sección La solución) */
.compare{max-width:880px;margin:0 auto;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-sm)}
.compare table{width:100%;border-collapse:collapse;font-size:var(--fs-small)}
.compare thead th{background:var(--color-blue-marine);color:#fff;font-family:var(--font-display);font-weight:700;text-align:left;padding:14px 16px;font-size:var(--fs-small)}
.compare thead th:last-child{background:var(--color-blue-klein)}
.compare tbody th{font-weight:600;color:var(--color-text);text-align:left;padding:14px 16px;border-top:1px solid var(--color-border);vertical-align:top}
.compare tbody td{padding:14px 16px;border-top:1px solid var(--color-border);color:var(--color-text-muted);vertical-align:top}
.compare tbody td.is-yes{color:var(--color-success);font-weight:600}
.compare tbody td.is-yes::before{content:"✓ ";font-weight:800}
.compare tbody tr:nth-child(even) th,.compare tbody tr:nth-child(even) td{background:#FAFBFC}
@media(max-width:639px){
  .compare table,.compare thead,.compare tbody,.compare tr,.compare th,.compare td{display:block;width:100%}
  .compare thead{display:none}
  .compare tbody tr{border-top:1px solid var(--color-border);padding:var(--space-3) 0}
  .compare tbody tr:first-child{border-top:0}
  .compare tbody th{border-top:0;padding-bottom:6px;font-size:1rem;color:var(--color-blue-deep)}
  .compare tbody td{border-top:0;padding-top:4px;padding-bottom:4px}
  .compare tbody td::before{font-weight:700;color:var(--color-text)}
  .compare tbody td.cell-solo::before{content:"Si buscas solo: "}
  .compare tbody td.cell-asesor::before{content:"Con tu asesor: "}
  .compare tbody td.cell-asesor.is-yes::before{content:"Con tu asesor: ✓ ";color:var(--color-success)}
}

/* Estrellas testimonios */
.stars{color:var(--color-yellow);font-size:1rem;letter-spacing:2px;margin:0 0 var(--space-3)}

/* === Mobile: hero + cards centrados === */
@media(max-width:767px){
  .hero__text{text-align:center}
  .hero__sub{margin-left:auto;margin-right:auto}
  .hero__ctas{align-items:stretch}
  .hero__ctas .btn{width:100%;justify-content:center}

  /* Comparador: hero alineado a la izquierda (tiene bullets) */
  [data-lead-source="comparador-alarmas"] .hero__text,
  [data-lead-source="comparador-alarmas"] .hero__bullets,
  [data-lead-source="comparador-alarmas"] .hero__bullets li{text-align:left}
  [data-lead-source="comparador-alarmas"] .hero__sub{margin-left:0;margin-right:0;text-align:left}
  /* …salvo H1 y label de logos, que van centrados */
  [data-lead-source="comparador-alarmas"] .hero h1,
  [data-lead-source="comparador-alarmas"] .hero__logos-label{text-align:center}

  .truth-card__body{text-align:center;align-items:center}
  .feature{align-items:center;text-align:center}
  .testimonial{text-align:center}
  .testimonial figcaption{text-align:center}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal,.reveal .truth-card,.reveal .feature,.reveal .testimonial,.reveal .timeline__step{opacity:1;transform:none}
}

/* Utilidades */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
