/* Estilos compartidos páginas legales + footer reutilizable */
:root{
  --c-blue:#1A4FCC;
  --c-navy:#0D2B6E;
  --c-cream:#F8F5EF;
  --c-white:#FFFFFF;
  --c-sand:#D4B483;
  --c-coral:#E8816A;
  --c-ink:#0A1A3A;
  --f-head:"Cormorant Garamond",Georgia,serif;
  --f-body:"DM Sans",system-ui,sans-serif;
  --pad:clamp(1.2rem,4vw,3rem);
  --radius:14px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--f-body);font-size:16px;line-height:1.7;color:var(--c-ink);background:var(--c-cream)}
img{max-width:100%;display:block;height:auto}
a{color:var(--c-blue);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- Header reutilizable ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:.6rem var(--pad);
  background:rgba(13,43,110,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  color:#fff;box-shadow:0 6px 24px -10px rgba(0,0,0,.4);
}
.brand{font-family:var(--f-head);font-size:1.7rem;letter-spacing:.05em;font-weight:700;color:#fff}
.brand small{display:block;font-family:var(--f-body);font-size:.55rem;letter-spacing:.4em;text-transform:uppercase;opacity:.8;margin-top:-4px}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;opacity:.9;color:#fff}
.nav a:hover{opacity:1;text-decoration:none}
@media(max-width:760px){.nav a:not(.btn){display:none}}

.btn{display:inline-flex;align-items:center;padding:.75em 1.5em;border-radius:999px;font-weight:500;font-size:.9rem;letter-spacing:.05em}
.btn-coral{background:var(--c-coral);color:#fff!important}
.btn-coral:hover{background:#d8694f;text-decoration:none}

/* ---------- Contenido legal ---------- */
.legal-wrap{
  max-width:820px;margin:0 auto;padding:7rem var(--pad) 4rem;
}
.legal h1{
  font-family:var(--f-head);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--c-navy);
  margin:0 0 1rem;line-height:1.1;letter-spacing:-.01em;
}
.legal h2{
  font-family:var(--f-head);color:var(--c-navy);
  font-size:clamp(1.3rem,2.2vw,1.7rem);
  margin:2.4rem 0 .6rem;
  padding-top:1rem;border-top:1px solid rgba(13,43,110,.12);
}
.legal h2:first-of-type{border-top:0;padding-top:0}
.legal p{margin:0 0 1em}
.legal ul{padding-left:1.2em;margin:0 0 1em}
.legal ul li{margin:.3em 0}
.legal .kicker{
  font-size:1.05rem;color:#444;
  padding:1rem 1.2rem;border-left:3px solid var(--c-coral);
  background:#fff;border-radius:0 8px 8px 0;margin-bottom:2rem;
}
.legal .updated{
  margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(13,43,110,.12);
  font-size:.85rem;color:#666;text-align:center;
}

/* dl bonita para datos fiscales */
dl.data{
  display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1.4rem;
  background:#fff;padding:1.4rem 1.6rem;border-radius:var(--radius);
  border:1px solid rgba(13,43,110,.08);margin:1rem 0 1.5rem;
}
dl.data dt{font-weight:500;color:var(--c-navy);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;align-self:center}
dl.data dd{margin:0;font-size:1rem}
@media(max-width:520px){
  dl.data{grid-template-columns:1fr;gap:0}
  dl.data dt{margin-top:.8rem}
}

/* tablas */
.legal-table{
  width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:0 2px 12px -6px rgba(13,43,110,.15);font-size:.95rem;
}
.legal-table th,.legal-table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid rgba(13,43,110,.08);vertical-align:top}
.legal-table th{background:var(--c-navy);color:#fff;font-weight:500;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase}
.legal-table tr:last-child td{border-bottom:0}

/* ---------- Footer reutilizable (también lo usa el index) ---------- */
.footer{
  background:#06112E;color:rgba(248,245,239,.7);
  padding:4rem var(--pad) 2rem;
  font-size:.92rem;line-height:1.7;
}
.footer-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr 1fr 1.1fr;gap:3rem;
}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr}}
.footer a{color:rgba(248,245,239,.85);text-decoration:none}
.footer a:hover{color:var(--c-sand);text-decoration:none}
.footer-brand{font-family:var(--f-head);font-size:1.8rem;color:#fff;letter-spacing:.04em;margin-bottom:.5rem}
.footer-brand small{display:block;font-family:var(--f-body);font-size:.55rem;letter-spacing:.4em;text-transform:uppercase;opacity:.7;margin-top:-2px}
.footer-lbl{
  display:block;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--c-sand);margin-bottom:.7rem;
}
.footer-credits .credit-block{
  display:inline-block;background:rgba(255,255,255,.06);padding:.7rem 1rem;border-radius:8px;
  transition:background .2s;
}
.footer-credits .credit-block:hover{background:rgba(255,255,255,.12)}
.footer-credits img{max-height:36px;width:auto;filter:brightness(0) invert(1);opacity:.9}
.footer-credits img.logo-imc{filter:none;max-height:42px;border-radius:6px}
.footer-bottom{
  max-width:1200px;margin:3rem auto 0;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.08);
  text-align:center;font-size:.8rem;color:rgba(248,245,239,.5);
}
