/* ═══════════════════════════════════════════════════════════════
   DEFIENDETUMULTA · WEB PRINCIPAL (HUB) — v2 LIGHT
   Base clara y premium · navy solo como tinta y bandas de contraste
   Tipografía: Plus Jakarta Sans (títulos) + Inter (texto)
═══════════════════════════════════════════════════════════════ */

:root{
  /* Paleta oficial (Manual de marca defiendetumulta v1.0) */
  --navy:#0D2352;          /* Azul Marino */
  --navy-2:#1E3360;        /* navy claro (gradiente) */
  --navy-deep:#14161A;     /* Tinta — footer / ancla oscura */
  --red:#E1153D;           /* Rojo Multa (principal) */
  --red-dark:#C10E33;      /* Rojo hover */
  --pink:#FBECEF;          /* Rosa niebla */
  --pink-on-dark:#F4A9B8;  /* rosa acento sobre oscuro */
  --cream:#F4A9B8;         /* (compat) acento sobre oscuro */
  --gold:#C9A24B;          /* estrellas de valoración */
  --ink:#0D2352;           /* títulos (azul marino) */
  --ink-soft:#3A3F4A;      /* texto cuerpo (grafito) */
  --ink-mute:#8A8F99;      /* texto tenue */
  --bg:#FFFFFF;
  --bg-soft:#F6F5F2;       /* Hueso */
  --bg-soft-2:#FBFAF9;
  --line:#E7E4DF;          /* borde de marca */
  --line-2:#DDD8CF;
  --green:#1F8A5B;
  --maxw:1180px;
  --ease:cubic-bezier(.4,0,.2,1);
  --shadow-sm:0 4px 18px rgba(13,35,82,.06);
  --shadow-md:0 14px 40px rgba(13,35,82,.10);
  --shadow-lg:0 26px 60px rgba(13,35,82,.16);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--ink-soft);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.08;margin:0;color:var(--ink)}
p{margin:0}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:'Space Mono',monospace;font-size:12px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:18px}
.eyebrow::before{content:"";width:20px;height:2px;background:var(--red);border-radius:2px}
.eyebrow.on-navy{color:var(--cream)}
.eyebrow.on-navy::before{background:var(--cream)}
.eyebrow.center{justify-content:center}
.h2{font-size:clamp(28px,4vw,46px)}
.lead{font-family:'Inter',sans-serif;font-size:clamp(16px,1.85vw,19px);line-height:1.62;color:var(--ink-soft)}
.accent-red{color:var(--red)}
.accent-gold{color:var(--gold)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--red);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.skip-link:focus{left:0}

/* ─── LOGO ────────────────────────────────────────────────── */
.logo{display:inline-flex;align-items:center;gap:10px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:21px;letter-spacing:-.03em;line-height:1;color:var(--ink)}
.logo-mark{width:38px;height:38px;flex-shrink:0;border-radius:10px;display:block}
.logo.on-dark{color:#fff}

/* ─── BOTONES ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:15px;letter-spacing:-.01em;
  padding:15px 26px;border-radius:12px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
  line-height:1.2;white-space:nowrap;
}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 24px rgba(225,21,61,.30)}
.btn-red:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 16px 32px rgba(225,21,61,.42)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-outline{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-outline:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-lg{padding:18px 32px;font-size:16px}

/* ─── NAV ─────────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-family:'Inter',sans-serif;font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{padding:11px 20px;font-size:14px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;width:44px;height:44px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px auto;transition:.25s var(--ease);border-radius:2px}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;overflow:hidden;max-height:0;transition:max-height .3s var(--ease);background:#fff;border-bottom:1px solid var(--line)}
.nav-mobile.open{max-height:440px}
.nav-mobile a{display:block;padding:15px 24px;color:var(--ink-soft);font-family:'Inter',sans-serif;font-size:15px;border-top:1px solid var(--line)}
.nav-mobile .btn{margin:16px 24px 20px;display:flex;width:calc(100% - 48px)}

/* ─── HERO (light) ────────────────────────────────────────── */
.hero{position:relative;overflow:hidden;background:var(--bg);padding:72px 0 76px}
.hero::before{content:"";position:absolute;top:-160px;right:-120px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(225,21,61,.12),transparent 68%);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-200px;left:-160px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(13,35,82,.09),transparent 66%);pointer-events:none}
.hero-inner{position:relative;z-index:2;text-align:center;max-width:900px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line-2);color:var(--ink);padding:8px 18px;border-radius:50px;font-family:'Inter',sans-serif;font-size:12.5px;font-weight:600;letter-spacing:.01em;margin-bottom:26px;box-shadow:var(--shadow-sm)}
.hero-badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(31,164,99,.5);animation:pulse-ring 2s infinite}
@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(31,164,99,.5)}70%{box-shadow:0 0 0 8px rgba(31,164,99,0)}100%{box-shadow:0 0 0 0 rgba(31,164,99,0)}}
.hero h1{font-size:clamp(34px,5.6vw,62px);color:var(--ink);margin-bottom:22px;letter-spacing:-.03em;text-wrap:balance}
.hero h1 .accent-red{color:var(--red)}
.hero-sub{font-size:clamp(17px,2.1vw,20px);color:var(--ink-soft);max-width:640px;margin:0 auto;line-height:1.55;text-wrap:balance}
.hero-microtrust{display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:center;margin-top:26px}
.hero-microtrust span{display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif;font-size:13.5px;color:var(--ink-soft);font-weight:500}
.hero-microtrust .ic{color:var(--green);font-weight:800}

/* ─── PATH CHOOSER ────────────────────────────────────────── */
.chooser{margin-top:44px}
.chooser-q{font-family:'Space Mono',monospace;font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:20px}
.chooser-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;text-align:left}
.path-card{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px 28px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);display:flex;flex-direction:column}
.path-card::after{content:"";position:absolute;left:0;top:0;height:100%;width:5px;background:var(--navy);transition:width .25s var(--ease)}
.path-card--part::after{background:var(--red)}
.path-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.path-icon{width:56px;height:56px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:27px;margin-bottom:18px}
.path-card--part .path-icon{background:rgba(225,21,61,.10)}
.path-card--emp .path-icon{background:rgba(13,35,82,.07)}
.path-card h3{font-size:24px;color:var(--ink);margin-bottom:8px;letter-spacing:-.02em}
.path-card p{font-family:'Inter',sans-serif;font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin-bottom:22px;flex:1}
.path-go{display:inline-flex;align-items:center;gap:9px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:14.5px}
.path-card--part .path-go{color:var(--red)}
.path-card--emp .path-go{color:var(--navy)}
.path-go .arrow{transition:transform .25s var(--ease)}
.path-card:hover .path-go .arrow{transform:translateX(6px)}
.path-tag{position:absolute;top:16px;right:16px;font-family:'Space Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 11px;border-radius:50px}
.path-card--part .path-tag{background:var(--pink);color:var(--red-dark)}
.path-card--emp .path-tag{background:rgba(13,35,82,.07);color:var(--navy)}

/* ─── STATS (banda clara cálida) ──────────────────────────── */
.stats{background:var(--bg-soft);padding:46px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-num{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:clamp(30px,3.8vw,46px);color:var(--navy);line-height:1;letter-spacing:-.03em}
.stat-num .accent{color:var(--red)}
.stat-label{font-family:'Space Mono',monospace;font-size:11px;color:var(--ink-mute);font-weight:400;margin-top:9px;letter-spacing:.14em;text-transform:uppercase}

/* ─── MEDIA STRIP ─────────────────────────────────────────── */
.media{background:#fff;padding:26px 0 30px;overflow:hidden}
.media-label{text-align:center;font-family:'Space Mono',monospace;font-size:10.5px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.24em;font-weight:400;margin-bottom:16px}
.media-track-wrap{overflow:hidden;position:relative}
.media-track-wrap::before,.media-track-wrap::after{content:"";position:absolute;top:0;width:70px;height:100%;z-index:2;pointer-events:none}
.media-track-wrap::before{left:0;background:linear-gradient(90deg,#fff,transparent)}
.media-track-wrap::after{right:0;background:linear-gradient(-90deg,#fff,transparent)}
.media-track{display:flex;gap:40px;align-items:center;width:max-content;animation:marquee 34s linear infinite}
.media-track img{height:32px;width:auto;object-fit:contain;filter:grayscale(100%) opacity(.55);transition:.3s}
.media-track img:hover{filter:grayscale(0) opacity(1)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─── SECTIONS base ───────────────────────────────────────── */
.section{padding:90px 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-head .lead{margin-top:16px}
.bg-soft{background:var(--bg-soft)}
.bg-navy{background:var(--navy);color:rgba(255,255,255,.85);position:relative;overflow:hidden}
.bg-navy h2,.bg-navy h3,.bg-navy h4{color:#fff}
.bg-navy .lead{color:rgba(255,255,255,.82)}

/* ─── SERVICIO ────────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:34px 28px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.svc-ic{width:58px;height:58px;border-radius:16px;background:linear-gradient(150deg,rgba(225,21,61,.12),rgba(225,21,61,.04));display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:20px}
.svc-card h3{font-size:22px;margin-bottom:11px;letter-spacing:-.02em}
.svc-card p{font-family:'Inter',sans-serif;font-size:15px;color:var(--ink-soft);line-height:1.6}

/* ─── CÓMO TRABAJAMOS (steps claros) ──────────────────────── */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step-card{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:20px;padding:36px 30px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.step-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.step-bignum{position:absolute;top:-8px;right:14px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:120px;line-height:1;color:var(--navy);opacity:.05;pointer-events:none;letter-spacing:-.05em}
.step-badge{display:inline-flex;background:var(--pink);color:var(--red-dark);padding:6px 14px;border-radius:50px;font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;position:relative;z-index:2}
.step-ic{width:58px;height:58px;border-radius:16px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:18px;position:relative;z-index:2}
.step-card h3{font-size:21px;color:var(--ink);margin-bottom:11px;position:relative;z-index:2;letter-spacing:-.02em}
.step-card h3 .hl{color:var(--red)}
.step-card p{font-family:'Inter',sans-serif;font-size:14.5px;color:var(--ink-soft);line-height:1.6;position:relative;z-index:2}

/* ─── CASES MARQUEE ───────────────────────────────────────── */
.cases{background:var(--bg-soft);padding:84px 0;overflow:hidden}
.cases-track-wrap{position:relative;margin-top:52px}
.cases-track-wrap::before,.cases-track-wrap::after{content:"";position:absolute;top:0;width:100px;height:100%;z-index:2;pointer-events:none}
.cases-track-wrap::before{left:0;background:linear-gradient(90deg,var(--bg-soft),transparent)}
.cases-track-wrap::after{right:0;background:linear-gradient(-90deg,var(--bg-soft),transparent)}
.cases-track{display:flex;gap:26px;width:max-content;align-items:center;animation:marquee 90s linear infinite}
.cases-track:hover{animation-play-state:paused}
.case-item{flex-shrink:0;height:440px}
.case-item img{height:100%;width:auto;border-radius:12px;box-shadow:var(--shadow-md);background:#fff}

/* ─── NOSOTROS / AUTORIDAD (claro) ────────────────────────── */
#nosotros{position:relative;overflow:hidden}
#nosotros::before{content:"";position:absolute;top:-140px;right:-100px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(225,21,61,.07),transparent 66%);pointer-events:none}
.about-grid{display:grid;grid-template-columns:1fr 1.35fr;gap:56px;align-items:center;margin-top:52px;position:relative;z-index:2}
.about-photo{width:100%;aspect-ratio:1/1;border-radius:22px;overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--shadow-lg)}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-quote{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:clamp(20px,2.5vw,26px);line-height:1.35;color:var(--ink);margin-bottom:22px;letter-spacing:-.02em}
.about-quote .accent-red{color:var(--red)}
.about-body{font-family:'Inter',sans-serif;font-size:16px;line-height:1.7;color:var(--ink-soft);margin-bottom:16px}
.about-body strong{color:var(--ink)}
.about-list{list-style:none;padding:0;margin:22px 0}
.about-list li{padding:7px 0;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink-soft);display:flex;gap:12px;align-items:center}
.about-list li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--red);flex-shrink:0}
.about-name{margin-top:26px;padding-top:22px;border-top:1px solid var(--line-2)}
.about-name-line{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:24px;color:var(--ink);line-height:1;letter-spacing:-.02em}
.about-name-role{font-family:'Space Mono',monospace;font-size:12px;color:var(--red-dark);letter-spacing:.14em;text-transform:uppercase;margin-top:7px}

/* ─── TESTIMONIOS ─────────────────────────────────────────── */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tst-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow-sm)}
.tst-savings{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:30px;color:var(--red);line-height:1;letter-spacing:-.03em;margin-bottom:5px}
.tst-detail{font-family:'Inter',sans-serif;font-size:13px;color:var(--ink-mute);font-weight:500;margin-bottom:12px}
.tst-stars{color:var(--gold);font-size:15px;letter-spacing:2px;margin-bottom:10px}
.tst-quote{font-family:'Inter',sans-serif;font-size:14.5px;color:var(--ink);line-height:1.55;margin-bottom:14px}
.tst-author{font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--ink)}

/* ─── FAQ ─────────────────────────────────────────────────── */
.faq-wrap{max-width:820px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:14px;margin-bottom:14px;background:#fff;overflow:hidden;transition:box-shadow .2s,border-color .2s}
.faq-item.open{border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;background:none;border:none;cursor:pointer;padding:22px 24px;text-align:left;font-family:'Plus Jakarta Sans',sans-serif;font-size:16.5px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.faq-icon{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--red);transition:transform .25s var(--ease),background .2s,color .2s}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--red);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a-inner{padding:0 24px 22px;font-family:'Inter',sans-serif;font-size:15px;line-height:1.65;color:var(--ink-soft)}

/* ─── FINAL CTA (claro) ───────────────────────────────────── */
.final{position:relative;overflow:hidden;background:var(--bg-soft);color:var(--ink);padding:86px 0;text-align:center;border-top:1px solid var(--line)}
.final::before{content:"";position:absolute;top:-120px;right:-80px;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(225,21,61,.10),transparent 64%);pointer-events:none}
.final::after{content:"";position:absolute;bottom:-160px;left:-100px;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(13,35,82,.06),transparent 64%);pointer-events:none}
.final .inner{position:relative;z-index:2}
.final h2{font-size:clamp(30px,4.6vw,52px);color:var(--ink);margin-bottom:16px}
.final .lead{color:var(--ink-soft);max-width:600px;margin:0 auto 40px}
.final .chooser-grid{max-width:760px;margin:0 auto}

/* ─── FOOTER ──────────────────────────────────────────────── */
.footer{background:var(--navy-deep);color:rgba(255,255,255,.66);padding:56px 0 30px;font-family:'Inter',sans-serif}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand .logo{margin-bottom:16px}
.footer-brand p{font-size:13.5px;line-height:1.6;max-width:330px;color:rgba(255,255,255,.6)}
.footer-col h4{font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--pink-on-dark);margin-bottom:16px}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.7);padding:5px 0;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:24px;font-size:12.5px;color:rgba(255,255,255,.5)}
.footer-bottom strong{color:#fff;font-weight:600}
.footer-legal{font-size:11.5px;color:rgba(255,255,255,.4);margin-top:18px;line-height:1.6}

/* ─── REVEAL ──────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ═══════════════ RESPONSIVE ═══════════════════════════════ */
@media (max-width:940px){
  .nav-links{display:none}
  .nav-toggle{display:block}
  .nav-mobile{display:block}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .about-photo{max-width:300px;margin:0 auto}
  .svc-grid,.steps-grid,.tst-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px 20px}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .hero{padding:48px 0 56px}
  .section{padding:60px 0}
  .cases{padding:56px 0}
  .section-head{margin-bottom:38px}
  .chooser-grid{grid-template-columns:1fr;gap:16px}
  .path-card{padding:26px 22px}
  .case-item{height:320px}
  .cases-track{gap:16px;animation-duration:64s}
  .stats-grid{grid-template-columns:1fr;gap:26px}
  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  .btn{width:100%}
  .hero-microtrust{gap:8px 16px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ═══════════════════════════════════════════════════════════════
   CONSULTA · money page post-survey (particulares)
═══════════════════════════════════════════════════════════════ */
.topbar{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:64px}
.topbar .trust-mini{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
@media (max-width:640px){.topbar .trust-mini{display:none}}

.mhero{position:relative;overflow:hidden;background:var(--bg);padding:56px 0 64px}
.mhero::before{content:"";position:absolute;top:-160px;right:-120px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(225,21,61,.10),transparent 68%);pointer-events:none}
.mhero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.confirm-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(31,164,99,.10);border:1px solid rgba(31,164,99,.28);color:#177a49;padding:8px 16px;border-radius:50px;font-family:'Space Mono',monospace;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:22px}
.confirm-badge .ck{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:11px;font-weight:800}
.mhero h1{font-size:clamp(30px,4.4vw,50px);color:var(--ink);letter-spacing:-.03em;margin-bottom:18px;text-wrap:balance}
.mhero h1 .accent-red{color:var(--red)}
.mhero-sub{font-size:clamp(16px,1.9vw,19px);color:var(--ink-soft);line-height:1.55;margin-bottom:24px;max-width:520px}
.mhero-checks{display:flex;flex-direction:column;gap:12px}
.mhero-checks li{list-style:none;display:flex;align-items:flex-start;gap:11px;font-size:15px;color:var(--ink-soft);line-height:1.45}
.mhero-checks .ic{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--pink);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;margin-top:1px}

/* Form card */
.lead-form{background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px 30px;box-shadow:var(--shadow-lg)}
.lead-form h3{font-size:22px;color:var(--ink);letter-spacing:-.02em;margin-bottom:6px}
.lead-form .lf-sub{font-family:'Inter',sans-serif;font-size:14px;color:var(--ink-soft);margin-bottom:22px;line-height:1.5}
.lf-input{width:100%;padding:14px 16px;border:1.5px solid var(--line-2);border-radius:11px;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);background:#fff;margin-bottom:12px;transition:border-color .2s,box-shadow .2s}
.lf-input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(225,21,61,.12)}
.lf-consent{display:flex;align-items:flex-start;gap:10px;margin:6px 0 18px}
.lf-consent input{margin-top:3px;width:16px;height:16px;accent-color:var(--red);flex-shrink:0;cursor:pointer}
.lf-consent label{font-size:12px;color:var(--ink-mute);line-height:1.5;cursor:pointer}
.lf-consent a{color:var(--ink);text-decoration:underline}
.lead-form .btn-red{width:100%;padding:17px;font-size:15.5px}
.lf-trust{text-align:center;font-family:'Space Mono',monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);margin-top:14px}
.lf-msg{margin-top:16px;padding:15px 18px;border-radius:11px;font-size:14px;line-height:1.5}
.lf-ok{background:rgba(31,164,99,.10);border-left:3px solid var(--green);color:#177a49}
.lf-err{background:var(--pink);border-left:3px solid var(--red);color:var(--red-dark)}

/* Urgency strip */
.urgency{background:var(--pink);border-top:1px solid #F3D6DD;border-bottom:1px solid #F3D6DD;padding:16px 0}
.urgency .container{display:flex;align-items:center;justify-content:center;gap:12px;text-align:center;flex-wrap:wrap}
.urgency .u-tag{font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--red);padding:5px 12px;border-radius:50px}
.urgency p{font-family:'Inter',sans-serif;font-size:14.5px;color:var(--red-dark);font-weight:500}

/* Velocidad case cards */
.vcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.vcase{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.vcase:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.vcase-top{background:var(--navy);color:#fff;padding:15px 22px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.vcase-place{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.vcase-anul{background:var(--green);color:#fff;font-family:'Space Mono',monospace;font-size:10.5px;font-weight:700;letter-spacing:.06em;padding:5px 11px;border-radius:50px}
.vcase-body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}
.vcase-amount{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.vcase-amount .val{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:34px;color:var(--ink-mute);text-decoration:line-through;text-decoration-color:var(--red);text-decoration-thickness:3px;line-height:1}
.vcase-amount .stamp{background:var(--red);color:#fff;font-family:'Space Mono',monospace;font-weight:700;font-size:12px;letter-spacing:.08em;padding:6px 12px;border-radius:7px;transform:rotate(-4deg)}
.vcase-desc{font-size:14px;color:var(--ink-soft);line-height:1.55;margin-bottom:14px}
.vcase-list{list-style:none;padding:0;margin:0 0 16px}
.vcase-list li{font-size:13.5px;color:var(--ink-soft);line-height:1.5;padding:7px 0 7px 22px;position:relative;border-bottom:1px solid var(--bg-soft)}
.vcase-list li:last-child{border-bottom:none}
.vcase-list li::before{content:"▸";position:absolute;left:0;color:var(--red);font-weight:700}
.vcase-result{margin-top:auto;background:var(--bg-soft);border-radius:12px;padding:14px 16px;font-size:13.5px;color:var(--ink);line-height:1.5}
.vcase-result strong{color:var(--green)}

@media (max-width:940px){
  .mhero-grid{grid-template-columns:1fr;gap:32px}
  .vcase-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .mhero{padding:40px 0 48px}
}

/* ═══════════════════════════════════════════════════════════════
   QUIZ · survey de particulares (primera página)
═══════════════════════════════════════════════════════════════ */
.qhero{position:relative;overflow:hidden;background:var(--bg);padding:56px 0 72px;text-align:center}
.qhero::before{content:"";position:absolute;top:-160px;right:-120px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(225,21,61,.10),transparent 68%);pointer-events:none}
.qhero-inner{position:relative;z-index:2;max-width:720px;margin:0 auto}
.qhero h1{font-size:clamp(30px,4.6vw,48px);color:var(--ink);letter-spacing:-.03em;line-height:1.08;margin-bottom:16px;text-wrap:balance}
.qhero h1 .accent-red{color:var(--red)}
.qhero-sub{font-size:clamp(16px,2vw,19px);color:var(--ink-soft);line-height:1.55;max-width:560px;margin:0 auto 34px;text-wrap:balance}

.quiz-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px 30px 30px;box-shadow:var(--shadow-lg);max-width:600px;margin:0 auto;text-align:left}
.quiz-progress{height:6px;background:var(--bg-soft);border-radius:3px;margin-bottom:26px;overflow:hidden}
.quiz-progress-bar{height:100%;background:var(--red);width:20%;border-radius:3px;transition:width .4s var(--ease)}
.quiz-step{display:none}
.quiz-step.active{display:block;animation:qstep .35s var(--ease)}
@keyframes qstep{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.quiz-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:var(--ink-mute);font-family:'Inter',sans-serif;font-size:13px;font-weight:600;padding:0 0 12px;transition:color .15s}
.quiz-back:hover{color:var(--ink)}
.quiz-step h3{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:20px;color:var(--ink);line-height:1.3;letter-spacing:-.01em;margin:0 0 20px}
.quiz-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quiz-opts.cols-1{grid-template-columns:1fr}
.quiz-opt{position:relative;display:block;cursor:pointer;margin:0}
.quiz-opt input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.quiz-opt-box{display:flex;align-items:center;gap:12px;padding:15px 16px;border:1.5px solid var(--line-2);border-radius:12px;background:#fff;font-family:'Inter',sans-serif;font-size:14.5px;font-weight:500;color:var(--ink);line-height:1.35;transition:all .15s var(--ease);min-height:54px}
.quiz-opt-box::before{content:"";flex-shrink:0;width:20px;height:20px;border:2px solid var(--line-2);border-radius:50%;background:#fff;transition:all .15s}
.quiz-opt:hover .quiz-opt-box{border-color:var(--navy);background:var(--bg-soft)}
.quiz-opt input:checked + .quiz-opt-box{border-color:var(--red);background:var(--pink);font-weight:600}
.quiz-opt input:checked + .quiz-opt-box::before{border-color:var(--red);background:var(--red);box-shadow:inset 0 0 0 4px #fff}
.quiz-opt input:focus-visible + .quiz-opt-box{outline:2px solid var(--navy);outline-offset:2px}
.quiz-submit-wrap{margin-top:22px}
.quiz-submit{width:100%;justify-content:center}
.quiz-submit:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.quiz-counter{margin:22px auto 0;max-width:600px;text-align:center;font-family:'Inter',sans-serif;font-size:14px;color:var(--ink-mute)}
.quiz-counter .ck{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:11px;font-weight:800;margin-right:7px;vertical-align:-3px}
.quiz-counter strong{color:var(--ink)}
@media (max-width:600px){
  .qhero{padding:40px 0 52px}
  .quiz-card{padding:24px 20px}
  .quiz-opts{grid-template-columns:1fr}
  .quiz-step h3{font-size:18px}
}
