/* ===== S24 — estilos de la web pública ===== */
:root{
  --brand:#6d28d9;        /* morado S24 */
  --brand-dark:#4c1d95;
  --brand-light:#ede9fe;
  --ink:#1e1b2e;
  --muted:#6b7280;
  --bg:#ffffff;
  --soft:#f7f6fb;
  --line:#e6e3ef;
  --radius:16px;
  --max:1040px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max);margin:0 auto;padding:0 22px}

/* Header */
header.site{
  position:sticky;top:0;z-index:10;background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;color:var(--ink)}
.logo .badge{
  background:var(--brand);color:#fff;border-radius:10px;
  padding:4px 10px;font-size:18px;letter-spacing:.5px;
}
.logo:hover{text-decoration:none}
.nav a.navlink{color:var(--muted);font-weight:600;font-size:15px;margin-left:22px}
.nav a.navlink:hover{color:var(--brand);text-decoration:none}
@media(max-width:640px){.nav a.navlink{display:none}}

/* Hero */
.hero{
  background:linear-gradient(160deg,var(--brand) 0%,var(--brand-dark) 100%);
  color:#fff;padding:84px 0 92px;text-align:center;
}
.hero h1{font-size:46px;line-height:1.1;font-weight:800;margin-bottom:18px;letter-spacing:-1px}
.hero p{font-size:20px;opacity:.95;max-width:680px;margin:0 auto 28px}
.badges{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.pill{
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);
  color:#fff;border-radius:999px;padding:9px 18px;font-weight:600;font-size:14px;
}
@media(max-width:640px){.hero h1{font-size:34px}.hero p{font-size:17px}}

/* Sections */
section.block{padding:70px 0}
section.block.soft{background:var(--soft)}
.block h2{font-size:30px;font-weight:800;margin-bottom:14px;letter-spacing:-.5px}
.block .lead{color:var(--muted);font-size:18px;max-width:760px;margin-bottom:36px}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:820px){.grid{grid-template-columns:1fr}}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;
}
.card .ic{
  width:46px;height:46px;border-radius:12px;background:var(--brand-light);
  color:var(--brand);display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:800;margin-bottom:14px;
}
.card h3{font-size:19px;margin-bottom:8px}
.card p{color:var(--muted);font-size:15px}

.steps{counter-reset:s;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding-left:8px}
.step .n{
  width:38px;height:38px;border-radius:50%;background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;margin-bottom:12px;
}
.step h3{font-size:18px;margin-bottom:6px}
.step p{color:var(--muted);font-size:15px}

.contact-box{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;text-align:center;max-width:560px;margin:0 auto;
}
.contact-box a{font-size:20px;font-weight:700}

/* Footer */
footer.site{background:var(--ink);color:#cdc9da;padding:46px 0 30px;font-size:14px}
footer.site .cols{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:26px}
footer.site .logo{color:#fff}
footer.site a{color:#cdc9da;display:block;margin:7px 0}
footer.site a:hover{color:#fff}
footer.site h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;opacity:.7}
footer.site .legalrow{border-top:1px solid #322d44;padding-top:18px;opacity:.7;font-size:13px}

/* Legal pages */
.legal{padding:48px 0 70px}
.legal .back{font-weight:600;font-size:14px;display:inline-block;margin-bottom:18px}
.legal h1{font-size:34px;font-weight:800;margin-bottom:6px;letter-spacing:-.5px}
.legal .updated{color:var(--muted);font-size:14px;margin-bottom:8px}
.legal .scope{color:var(--muted);font-size:14px;margin-bottom:30px}
.legal h2{font-size:22px;font-weight:800;margin:34px 0 10px}
.legal h3{font-size:18px;font-weight:700;margin:22px 0 8px}
.legal p,.legal li{font-size:16px;color:#33303f;margin-bottom:12px}
.legal ul,.legal ol{margin:0 0 12px 22px}
.legal li{margin-bottom:7px}
.legal strong{color:var(--ink)}
.legal table{width:100%;border-collapse:collapse;margin:14px 0 22px;font-size:14px}
.legal th,.legal td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}
.legal th{background:var(--soft);font-weight:700}
.legal .note{background:var(--brand-light);border-radius:12px;padding:16px 18px;margin:18px 0;font-size:15px}
.legal hr{border:none;border-top:1px solid var(--line);margin:30px 0}
