/* ============================================================
   RECAUDOPLUS — vanguardia institucional (fintech oscuro serio)
   Carbón + rojo de marca (#C72D39) · Space Grotesk + Inter
   ============================================================ */
:root{
  /* ===== MODO CLARO (por defecto) ===== */
  --ink:#FFFFFF; --ink-1:#F3F4F0; --ink-2:#FFFFFF; --ink-3:#EAEAE4; --ink-4:#DADAD2;
  --red:#C72D39; --red-2:#CF303D; --red-deep:#9E2029; --red-glow:rgba(199,45,57,.30);
  --paper:#EFEFE9; --paper-2:#E4E4DD;
  --white:#15161A;
  --tx:rgba(21,22,26,.66); --tx-2:rgba(21,22,26,.44);
  --line:rgba(21,22,26,.12); --line-2:rgba(21,22,26,.07);
  --ink-on-light:#15161A; --tx-on-light:rgba(21,22,26,.62); --line-on-light:rgba(21,22,26,.12);
  --steel:#6B7280;
  --sh:0 34px 70px -36px rgba(21,22,26,.28);
  --nav-bg:rgba(255,255,255,.82); --nav-bg-sc:rgba(255,255,255,.9);
  --aura-1:rgba(199,45,57,.15); --aura-2:rgba(199,45,57,.08);
  --r:16px; --r-lg:24px; --maxw:1200px;
  --ff-d:"Space Grotesk",system-ui,sans-serif; --ff-t:"Inter",system-ui,sans-serif;
}
:root[data-theme="dark"]{
  /* ===== MODO OSCURO ===== */
  --ink:#0E0F12; --ink-1:#141519; --ink-2:#1B1D22; --ink-3:#23262D; --ink-4:#2C3038;
  --red-2:#E23B47; --red-glow:rgba(199,45,57,.5);
  --paper:#F5F5F2; --paper-2:#E9E9E3;
  --white:#F6F6F4;
  --tx:rgba(246,246,244,.70); --tx-2:rgba(246,246,244,.46);
  --line:rgba(246,246,244,.11); --line-2:rgba(246,246,244,.06);
  --steel:#8B93A1;
  --sh:0 30px 70px -30px rgba(0,0,0,.7);
  --nav-bg:rgba(14,15,18,.72); --nav-bg-sc:rgba(14,15,18,.9);
  --aura-1:rgba(199,45,57,.34); --aura-2:rgba(199,45,57,.14);
}
html{background:var(--ink)}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; background:var(--ink); color:var(--white);
  font-family:var(--ff-t); font-size:clamp(15px,1.02vw,17px); line-height:1.6; letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--ff-d); font-weight:600; line-height:1.04; letter-spacing:-.03em; margin:0}
p{margin:0 0 1em}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.num{font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1}
.wrap{width:min(92%,var(--maxw)); margin-inline:auto}
.eyebrow{font-family:var(--ff-t); font-weight:600; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--red-2); display:inline-flex; align-items:center; gap:9px}
.eyebrow::before{content:""; width:22px; height:2px; background:var(--red); border-radius:2px}
.red{color:var(--red-2)}
section{position:relative; padding:clamp(70px,9vw,130px) 0}

/* ---------- topbar ---------- */
.topbar{background:var(--ink-1); border-bottom:1px solid var(--line-2); font-size:.8rem; color:var(--tx)}
.topbar .wrap{display:flex; align-items:center; justify-content:space-between; padding:9px 0; gap:16px; flex-wrap:wrap}
.topbar a{color:var(--tx); display:inline-flex; align-items:center; gap:7px}
.topbar a:hover{color:var(--white)}
.topbar .tb-left{display:flex; gap:22px; flex-wrap:wrap}
.topbar .tb-right{display:flex; gap:14px}
.topbar svg{width:14px;height:14px;opacity:.8}
@media(max-width:640px){.topbar .tb-left{gap:14px} .topbar{font-size:.72rem}}

/* ---------- nav ---------- */
.nav{position:sticky; top:0; z-index:60; display:flex; align-items:center; justify-content:space-between;
  padding:14px clamp(16px,4vw,48px); background:var(--nav-bg); backdrop-filter:blur(14px); border-bottom:1px solid var(--line-2); transition:padding .3s,background .3s}
.nav.scrolled{padding-block:10px; background:var(--nav-bg-sc)}
.nav-right{display:flex; align-items:center; gap:20px}
.theme-toggle{width:40px; height:40px; flex:0 0 auto; border-radius:50%; border:1px solid var(--line); background:transparent; color:var(--white); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:border-color .2s,color .2s,transform .2s}
.theme-toggle:hover{border-color:var(--red); color:var(--red-2); transform:translateY(-1px)}
.theme-toggle .ic-sun{display:none}
:root[data-theme="dark"] .theme-toggle .ic-moon{display:none}
:root[data-theme="dark"] .theme-toggle .ic-sun{display:block}
img.logo-d{display:none}
:root[data-theme="dark"] img.logo-l{display:none}
:root[data-theme="dark"] img.logo-d{display:block}
.brand-logo{height:34px; width:auto; display:block}
.nav-links{display:flex; gap:32px; align-items:center}
.nav-links a{font-size:.92rem; color:var(--tx); font-weight:500; position:relative}
.nav-links a:hover{color:var(--white)}
.nav-links a::after{content:""; position:absolute; left:0; right:100%; bottom:-4px; height:1.5px; background:var(--red); transition:right .3s}
.nav-links a:hover::after{right:0}
.nav-cta{display:inline-flex; align-items:center; gap:8px; background:var(--red); color:#fff; padding:11px 20px; border-radius:999px; font-weight:600; font-size:.88rem; box-shadow:0 8px 24px -8px var(--red-glow); transition:transform .2s,background .2s,box-shadow .2s}
.nav-cta:hover{background:var(--red-2); transform:translateY(-2px); box-shadow:0 12px 30px -8px var(--red-glow)}
.nav-burger{display:none; background:none; border:0; color:var(--white); cursor:pointer}
@media(max-width:900px){
  .nav-links{position:fixed; inset:0 0 0 auto; width:min(80%,340px); flex-direction:column; justify-content:center; gap:28px;
    background:var(--ink-1); transform:translateX(100%); transition:transform .4s; box-shadow:var(--sh); padding:48px; border-left:1px solid var(--line)}
  .nav-links.open{transform:none}
  .nav-burger{display:block}
}

/* ---------- botones ---------- */
.btn{display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:.98rem; padding:15px 28px; border-radius:999px; cursor:pointer; border:0; transition:transform .2s,background .2s,box-shadow .2s,color .2s; font-family:var(--ff-t)}
.btn-primary{background:var(--red); color:#fff; box-shadow:0 12px 30px -10px var(--red-glow)}
.btn-primary:hover{background:var(--red-2); transform:translateY(-2px); box-shadow:0 18px 40px -12px var(--red-glow)}
.btn-ghost{background:transparent; color:var(--white); box-shadow:inset 0 0 0 1.5px var(--line)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--white); transform:translateY(-2px)}
.wa-ic{width:19px;height:19px;flex:0 0 auto}

/* ---------- HERO ---------- */
.hero{min-height:100svh; display:grid; grid-template-columns:1.08fr .92fr; align-items:center; gap:48px; padding:clamp(48px,7vw,90px) clamp(16px,4vw,48px) 70px; overflow:hidden}
.hero-aura{position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden}
.hero-aura span{position:absolute; border-radius:50%; filter:blur(90px)}
.hero-aura .a1{width:52vw;height:52vw; left:-14vw; top:-16vw; background:radial-gradient(circle,var(--aura-1),transparent 68%); animation:drift1 24s ease-in-out infinite alternate}
.hero-aura .a2{width:40vw;height:40vw; right:-8vw; bottom:-14vw; background:radial-gradient(circle,var(--aura-2),transparent 70%); animation:drift2 30s ease-in-out infinite alternate}
.hero-aura .grid{position:absolute; inset:0; background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px); background-size:64px 64px; mask-image:radial-gradient(ellipse 80% 60% at 30% 40%,#000,transparent 75%); opacity:.5}
@keyframes drift1{to{transform:translate(6vw,4vw) scale(1.12)}}
@keyframes drift2{to{transform:translate(-5vw,-4vw) scale(1.1)}}
.hero-copy{position:relative; z-index:2; max-width:620px}
.hero h1{font-size:clamp(2.5rem,5.6vw,4.5rem); font-weight:700; margin:.35em 0 .4em}
.hero h1 em{font-style:normal; color:var(--red-2)}
.hero .lede{font-size:clamp(1.05rem,1.5vw,1.28rem); color:var(--tx); max-width:46ch; margin-bottom:1.9em}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:2.4em}
.hero-chips{display:flex; gap:26px; flex-wrap:wrap}
.hchip b{font-family:var(--ff-d); font-size:1.7rem; color:var(--white); line-height:1; display:block}
.hchip span{font-size:.8rem; color:var(--tx-2)}
/* visual col */
.hero-visual{position:relative; z-index:1; align-self:center}
@media(max-width:900px){.hero{grid-template-columns:1fr; min-height:auto; padding-top:40px} .hero-visual{display:none}}

/* mini panel de reporte (hero) */
.report-card{position:relative; background:linear-gradient(180deg,var(--ink-2),var(--ink-1)); border:1px solid var(--line); border-radius:var(--r-lg); padding:22px; box-shadow:var(--sh); transform:perspective(1200px) rotateY(-11deg) rotateX(5deg); transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.report-card:hover{transform:perspective(1200px) rotateY(-6deg) rotateX(3deg)}
.rc-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:16px}
.rc-head .t{font-family:var(--ff-d); font-weight:600; font-size:.98rem}
.rc-dot{display:flex; gap:6px} .rc-dot i{width:9px;height:9px;border-radius:50%;background:var(--ink-4)} .rc-dot i:first-child{background:var(--red)}
.rc-big{font-family:var(--ff-d); font-size:clamp(2rem,3.4vw,2.8rem); font-weight:700; line-height:1; letter-spacing:-.03em}
.rc-big small{font-size:.9rem; color:var(--tx-2); font-family:var(--ff-t); font-weight:500; display:block; margin-top:4px; letter-spacing:0}
.rc-bars{display:flex; flex-direction:column; gap:12px; margin-top:20px}
.rc-bar{display:grid; grid-template-columns:1fr auto; gap:4px 10px; font-size:.82rem; color:var(--tx)}
.rc-bar .track{grid-column:1/-1; height:7px; background:var(--ink-3); border-radius:6px; overflow:hidden}
.rc-bar .fill{height:100%; background:linear-gradient(90deg,var(--red),var(--red-2)); border-radius:6px; width:0; transition:width 1.2s cubic-bezier(.2,.7,.2,1)}
.report-float{position:absolute; right:-18px; bottom:26px; background:var(--ink-2); border:1px solid var(--line); border-radius:14px; padding:12px 16px; box-shadow:var(--sh); display:flex; align-items:center; gap:10px; animation:floaty 6s ease-in-out infinite}
.report-float .rf-ic{width:34px;height:34px;border-radius:10px;background:rgba(199,45,57,.15);display:flex;align-items:center;justify-content:center;color:var(--red-2)}
.report-float b{font-family:var(--ff-d);font-size:1.1rem;line-height:1} .report-float span{font-size:.7rem;color:var(--tx-2)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ---------- barra de confianza ---------- */
.trust{border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); background:var(--ink-1)}
.trust .wrap{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding:40px 0}
.tstat b{font-family:var(--ff-d); font-size:clamp(2rem,3.6vw,2.9rem); font-weight:700; line-height:1; letter-spacing:-.03em; display:block}
.tstat b .u{color:var(--red-2)}
.tstat span{font-size:.82rem; color:var(--tx-2); margin-top:6px; display:block}
@media(max-width:720px){.trust .wrap{grid-template-columns:1fr 1fr; gap:28px 20px}}

/* ---------- section head ---------- */
.sec-head{max-width:64ch; margin-bottom:54px}
.sec-head.center{margin-inline:auto; text-align:center}
.sec-head h2{font-size:clamp(1.9rem,4vw,3.1rem); font-weight:700; margin:.3em 0 .35em}
.sec-head p{color:var(--tx); font-size:1.08rem}

/* ---------- FLUJO DE RECAUDO (showpiece) ---------- */
.flow{background:var(--ink-1); border-top:1px solid var(--line-2)}
.flow-stage{position:relative; margin-top:20px}
.flow-svg{width:100%; height:auto; display:block; overflow:visible}
.flow-node text{font-family:var(--ff-t)}
.flow-labels{display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:26px}
.flnode{text-align:center}
.flnode .fi{width:52px;height:52px;margin:0 auto 12px;border-radius:14px;background:var(--ink-3);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--red-2);position:relative;transition:border-color .3s,background .3s}
.flnode.on .fi{border-color:var(--red);background:rgba(199,45,57,.14);box-shadow:0 0 0 5px rgba(199,45,57,.08)}
.flnode h4{font-size:.98rem;font-weight:600;margin-bottom:4px}
.flnode p{font-size:.82rem;color:var(--tx-2);margin:0}
.flnode .n{font-family:var(--ff-d);font-size:.72rem;color:var(--red-2);letter-spacing:.1em}
@media(max-width:820px){.flow-labels{grid-template-columns:1fr 1fr 1fr} .flow-svg{display:none}}

/* ---------- servicios (bento tilt) ---------- */
.svc-grid{display:grid; grid-template-columns:repeat(6,1fr); gap:18px}
.svc{grid-column:span 2; background:var(--ink-1); border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; position:relative; overflow:hidden; transition:transform .25s,border-color .25s; transform-style:preserve-3d}
.svc.wide{grid-column:span 3}
.svc:hover{border-color:rgba(199,45,57,.5)}
.svc .glow{position:absolute; width:280px;height:280px;border-radius:50%; background:radial-gradient(circle,rgba(199,45,57,.16),transparent 65%); opacity:0; transition:opacity .3s; pointer-events:none; transform:translate(-50%,-50%)}
.svc:hover .glow{opacity:1}
.svc .svc-ic{width:46px;height:46px;border-radius:12px;background:var(--ink-3);display:flex;align-items:center;justify-content:center;color:var(--red-2);margin-bottom:18px}
.svc h3{font-size:1.28rem;font-weight:600;margin-bottom:.4em}
.svc p{color:var(--tx);font-size:.95rem;margin:0}
.svc .tag{display:inline-block;margin-top:14px;font-size:.72rem;font-weight:600;color:var(--red-2);letter-spacing:.06em;text-transform:uppercase}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr 1fr} .svc,.svc.wide{grid-column:span 1}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}

/* ---------- banda honorarios (cero costo) ---------- */
.zero{background:linear-gradient(120deg,var(--red-deep),var(--red)); overflow:hidden}
.zero::before{content:""; position:absolute; inset:0; background-image:radial-gradient(circle at 80% 20%,rgba(255,255,255,.12),transparent 40%); pointer-events:none}
.zero .wrap{display:grid; grid-template-columns:1.2fr .8fr; gap:40px; align-items:center; position:relative}
.zero h2{font-size:clamp(1.9rem,4.2vw,3.2rem); font-weight:700; color:#fff}
.zero p{color:rgba(255,255,255,.9); font-size:1.1rem; margin:1em 0 0}
.zero .big{font-family:var(--ff-d); font-size:clamp(3.4rem,8vw,6rem); font-weight:700; color:#fff; line-height:.9; text-align:right; letter-spacing:-.04em}
.zero .big small{display:block; font-size:1rem; font-weight:500; color:rgba(255,255,255,.85); letter-spacing:0; margin-top:10px}
@media(max-width:760px){.zero .wrap{grid-template-columns:1fr} .zero .big{text-align:left}}

/* ---------- cómo funciona (proceso) ---------- */
.proc{background:var(--ink)}
.proc-grid{display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,70px); align-items:start}
.proc-sticky{position:sticky; top:120px}
.proc-steps{display:flex; flex-direction:column; gap:16px}
.pstep{border:1px solid var(--line); border-radius:var(--r); padding:22px 24px; background:var(--ink-1); transition:border-color .3s,background .3s}
.pstep.on{border-color:var(--red); background:var(--ink-2)}
.pstep .pnum{font-family:var(--ff-d); font-size:.8rem; color:var(--red-2); letter-spacing:.1em}
.pstep h3{font-size:1.3rem; font-weight:600; margin:6px 0 .3em}
.pstep p{color:var(--tx); font-size:.95rem; margin:0}
.proc-visual{position:sticky; top:120px; aspect-ratio:4/3.4; border:1px solid var(--line); border-radius:var(--r-lg); background:linear-gradient(180deg,var(--ink-2),var(--ink-1)); overflow:hidden; box-shadow:var(--sh); display:flex; align-items:center; justify-content:center}
.pv-scene{position:absolute; inset:0; opacity:0; transition:opacity .5s; display:flex; align-items:center; justify-content:center; padding:34px; text-align:center; flex-direction:column; gap:14px}
.pv-scene.on{opacity:1}
.pv-scene .pv-ic{width:80px;height:80px;border-radius:20px;background:rgba(199,45,57,.14);border:1px solid rgba(199,45,57,.4);display:flex;align-items:center;justify-content:center;color:var(--red-2)}
.pv-scene .pv-big{font-family:var(--ff-d);font-size:2.4rem;font-weight:700}
.pv-scene p{color:var(--tx);font-size:.92rem;max-width:32ch;margin:0}
@media(max-width:820px){.proc-grid{grid-template-columns:1fr} .proc-visual{display:none} .proc-sticky{position:static}}

/* ---------- sectores ---------- */
.sect-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.sector{border:1px solid var(--line); border-radius:var(--r); padding:26px 22px; background:var(--ink-1); transition:transform .25s,border-color .25s}
.sector:hover{transform:translateY(-4px); border-color:rgba(199,45,57,.5)}
.sector .se-ic{color:var(--red-2); margin-bottom:16px}
.sector h4{font-size:1.1rem; font-weight:600; margin-bottom:.3em}
.sector p{font-size:.86rem; color:var(--tx-2); margin:0}
@media(max-width:820px){.sect-grid{grid-template-columns:1fr 1fr}}

/* ---------- clientes + testimonios ---------- */
.rev{background:var(--paper); color:var(--ink-on-light)}
.rev .eyebrow{color:var(--red)}
.rev .sec-head h2{color:var(--ink-on-light)}
.rev .sec-head p{color:var(--tx-on-light)}
.rev-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.tcard{background:#fff; border:1px solid var(--line-on-light); border-radius:var(--r-lg); padding:28px; box-shadow:0 20px 50px -30px rgba(22,23,27,.35)}
.tcard .q{font-family:var(--ff-d); font-size:2.2rem; color:var(--red); line-height:.4; height:.5em; display:block}
.tcard blockquote{font-size:1.02rem; line-height:1.5; margin:.6em 0 1.2em; color:var(--ink-on-light)}
.tcard .by{display:flex; align-items:center; gap:12px}
.tcard .av{width:42px;height:42px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-weight:600;flex:0 0 auto}
.tcard .by b{font-size:.92rem; display:block} .tcard .by span{font-size:.78rem; color:var(--tx-on-light)}
.clients{margin-top:44px; border-top:1px solid var(--line-on-light); padding-top:34px}
.clients .cl-t{text-align:center; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--tx-on-light); margin-bottom:24px}
.cl-wall{display:flex; flex-wrap:wrap; gap:14px 30px; justify-content:center; align-items:center}
.cl-wall span{font-family:var(--ff-d); font-weight:600; font-size:1.05rem; color:rgba(22,23,27,.55); transition:color .25s}
.cl-wall span:hover{color:var(--red)}
@media(max-width:820px){.rev-grid{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{background:var(--ink)}
.faq-list{max-width:840px; margin-inline:auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{cursor:pointer; list-style:none; padding:24px 0; font-family:var(--ff-d); font-size:1.15rem; font-weight:500; display:flex; justify-content:space-between; gap:20px; align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+"; color:var(--red-2); font-size:1.5rem; transition:transform .3s; flex:0 0 auto}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{color:var(--tx); padding:0 0 24px; margin:0; max-width:72ch}

/* ---------- CTA final ---------- */
.cta{text-align:center; overflow:hidden}
.cta .aura{position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 50% 30%,rgba(199,45,57,.24),transparent 70%); pointer-events:none}
.cta h2{position:relative; font-size:clamp(2.2rem,5vw,3.8rem); font-weight:700; margin-bottom:.35em}
.cta p{position:relative; color:var(--tx); max-width:52ch; margin:0 auto 2em; font-size:1.1rem}
.cta .hero-cta{position:relative; justify-content:center}

/* ---------- footer ---------- */
.foot{background:var(--ink-1); border-top:1px solid var(--line-2); padding:64px 0 30px}
.foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:34px; margin-bottom:40px}
.foot h5{font-family:var(--ff-d); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:var(--tx-2); margin:0 0 16px}
.foot a{color:var(--tx); font-size:.92rem; display:block; padding:4px 0}
.foot a:hover{color:var(--red-2)}
.foot .flogo{height:32px; margin-bottom:16px}
.foot .fdesc{color:var(--tx-2); font-size:.9rem; max-width:36ch}
.foot .socials{display:flex; gap:12px; margin-top:14px}
.foot .socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0}
.foot .socials a:hover{border-color:var(--red);color:var(--red-2)}
.foot-bottom{border-top:1px solid var(--line-2); padding-top:22px; display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; font-size:.78rem; color:var(--tx-2)}
.foot-legal{max-width:70ch; font-size:.74rem; color:var(--tx-2); margin-top:14px; line-height:1.5}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr} .foot-grid>div:first-child{grid-column:1/-1}}

/* ---------- FAB WhatsApp ---------- */
.fab{position:fixed; right:22px; bottom:22px; z-index:55; display:inline-flex; align-items:center; gap:10px; background:#25D366; color:#062e16; padding:13px 18px; border-radius:999px; font-weight:700; font-size:.9rem; box-shadow:0 14px 34px -10px rgba(37,211,102,.6); transition:transform .25s}
.fab:hover{transform:translateY(-3px)}
.fab svg{width:22px;height:22px}
@media(max-width:560px){.fab span{display:none} .fab{padding:15px}}

/* ---------- reveal robusto ---------- */
.is-anim [data-r]{opacity:0; transform:translateY(30px); transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.is-anim [data-r].in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){
  .is-anim [data-r]{opacity:1!important; transform:none!important}
  .hero-aura span,.report-float{animation:none!important}
  .report-card{transform:none!important}
}

/* ---------- link "¿Eres deudor?" en topbar ---------- */
.tb-deudor{color:var(--red-2)!important; font-weight:600; border:1px solid rgba(199,45,57,.4); border-radius:999px; padding:3px 12px; transition:background .2s,border-color .2s}
.tb-deudor:hover{background:rgba(199,45,57,.14); border-color:var(--red)}

/* ---------- MODAL contacto (acreedor / deudor) ---------- */
.rp-modal{position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center; padding:20px}
.rp-modal[hidden]{display:none!important}
.rp-overlay{position:absolute; inset:0; background:rgba(6,7,9,.74); backdrop-filter:blur(5px)}
.rp-card{position:relative; width:100%; max-width:440px; background:var(--ink-1); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px 28px 26px; box-shadow:var(--sh); animation:rpPop .3s cubic-bezier(.2,.7,.2,1)}
@keyframes rpPop{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.rp-x{position:absolute; top:14px; right:16px; width:34px;height:34px; border:0; background:none; color:var(--tx-2); font-size:1.7rem; line-height:1; cursor:pointer; border-radius:50%}
.rp-x:hover{background:var(--ink-3); color:var(--white)}
.rp-view{display:none} .rp-view.on{display:block}
.rp-card h3{font-family:var(--ff-d); font-size:1.5rem; margin:.35em 0 .1em}
.rp-card .rp-sub{color:var(--tx-2); font-size:.9rem; margin:0 0 20px}
.rp-opts{display:flex; flex-direction:column; gap:10px}
.rp-opt{display:flex; align-items:center; gap:14px; text-align:left; width:100%; background:var(--ink-2); border:1px solid var(--line); border-radius:14px; padding:15px 16px; cursor:pointer; color:var(--white); transition:border-color .2s,background .2s,transform .2s; font-family:var(--ff-t)}
.rp-opt:hover{border-color:var(--red); background:var(--ink-3); transform:translateY(-1px)}
.rp-opt .rp-oic{width:42px;height:42px;flex:0 0 auto;border-radius:11px;background:rgba(199,45,57,.14);border:1px solid rgba(199,45,57,.35);display:flex;align-items:center;justify-content:center;color:var(--red-2)}
.rp-opt .rp-ot b{font-size:.98rem;display:block;font-weight:600} .rp-opt .rp-ot span{font-size:.8rem;color:var(--tx-2)}
.rp-opt .rp-arr{margin-left:auto;color:var(--tx-2);transition:transform .2s,color .2s;font-size:1.2rem}
.rp-opt:hover .rp-arr{color:var(--red-2);transform:translateX(3px)}
.rp-back{display:inline-flex;align-items:center;gap:6px;background:none;border:0;color:var(--tx-2);font-size:.84rem;cursor:pointer;padding:0;margin-bottom:12px;font-family:var(--ff-t)}
.rp-back:hover{color:var(--white)}
.rp-qr-wrap{text-align:center}
.rp-qr{width:210px;height:210px;margin:6px auto 14px;background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 30px -12px rgba(0,0,0,.6)}
.rp-qr img{width:100%;height:100%;display:block;image-rendering:pixelated}
.rp-hint{font-size:.85rem;color:var(--tx);margin:0 0 6px;display:flex;align-items:center;gap:8px;justify-content:center}
.rp-num{font-size:.8rem;color:var(--tx-2);margin:12px 0 0}
.rp-open{width:100%;justify-content:center;background:#25D366!important;color:#062e16!important;box-shadow:0 12px 30px -10px rgba(37,211,102,.5)!important}
.rp-open:hover{background:#1fbe5b!important}
@media (prefers-reduced-motion:reduce){.rp-card{animation:none}}
@media(max-width:420px){.rp-qr{width:180px;height:180px}}

/* ---------- asesoría jurídica ---------- */
.aseso{background:var(--ink-1); border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2)}
.aseso-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,64px); align-items:center}
.aseso-copy h2{font-size:clamp(1.9rem,4vw,3rem); font-weight:700; margin:.3em 0 .4em}
.aseso-copy p{color:var(--tx); font-size:1.08rem; margin-bottom:1.7em}
.aseso-areas{display:flex; flex-wrap:wrap; gap:12px}
.al{display:inline-flex; align-items:center; gap:9px; border:1px solid var(--line); background:var(--ink-2); border-radius:12px; padding:12px 16px; font-weight:600; font-size:.94rem; transition:border-color .2s,transform .2s}
.al:hover{border-color:var(--red); transform:translateY(-2px)}
.al::before{content:""; width:7px; height:7px; border-radius:50%; background:var(--red); flex:0 0 auto}
@media(max-width:820px){.aseso-grid{grid-template-columns:1fr}}
