/* ============================================
   evolutiondf — Hoja de estilos principal
   Paleta: arena/dorado + grafito
   ============================================ */

:root{
  --arena:#cfb593;
  --arena-claro:#e6d6bd;
  --arena-suave:#f4ece0;
  --arena-oscuro:#a98e66;
  --grafito:#3f3f3f;
  --grafito-claro:#5f5e5a;
  --negro:#222020;
  --blanco:#ffffff;
  --crema:#faf6f0;
  --texto:#454340;
  --borde:rgba(63,63,63,.12);
  --sombra:0 18px 50px -22px rgba(63,46,20,.45);
  --sombra-suave:0 10px 30px -16px rgba(63,46,20,.35);
  --radio:14px;
  --radio-lg:22px;
  --max:1200px;
  --display:'Fraunces',Georgia,serif;
  --texto-font:'Manrope',-apple-system,BlinkMacSystemFont,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--texto-font);
  color:var(--texto);
  background:var(--blanco);
  line-height:1.75;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{
  font-family:var(--display);
  color:var(--grafito);
  line-height:1.15;
  font-weight:500;
  letter-spacing:-.02em;
}
h1{font-size:clamp(2.4rem,5.2vw,4rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.85rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}

.container{max-width:var(--max);margin:0 auto;padding:0 28px}
.seccion{padding:clamp(4rem,9vw,7.5rem) 0}
.seccion-crema{background:var(--crema)}
.centro{text-align:center}
.estrecho{max-width:720px;margin-left:auto;margin-right:auto}

.eyebrow{
  font-family:var(--texto-font);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:700;
  color:var(--arena-oscuro);
  margin-bottom:1rem;
  display:inline-block;
}
.lead{font-size:1.12rem;color:var(--grafito-claro)}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--texto-font);font-weight:700;font-size:.92rem;
  padding:.95rem 1.9rem;border-radius:100px;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
  cursor:pointer;border:none;letter-spacing:.01em;
}
.btn-primario{background:var(--grafito);color:var(--blanco)}
.btn-primario:hover{background:var(--negro);transform:translateY(-3px);box-shadow:var(--sombra-suave)}
.btn-arena{background:var(--arena);color:var(--negro)}
.btn-arena:hover{background:var(--arena-oscuro);transform:translateY(-3px);box-shadow:var(--sombra-suave)}
.btn-linea{background:transparent;border:1.5px solid currentColor}
.btn-linea:hover{transform:translateY(-3px)}
.btn-grande{padding:1.1rem 2.4rem;font-size:1rem}

/* ---------- Cabecera ---------- */
.cabecera{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--borde);
  transition:box-shadow .3s ease;
}
.cabecera.scrolled{box-shadow:0 8px 30px -18px rgba(63,46,20,.4)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;
}
.logo{display:flex;align-items:center;gap:.7rem}
.logo img{height:54px;width:auto}
.logo-texto{display:flex;flex-direction:column;line-height:1}
.logo-texto strong{
  font-family:var(--display);font-size:1.45rem;font-weight:600;
  color:var(--grafito);letter-spacing:-.03em;
}
.logo-texto span{
  font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--arena-oscuro);font-weight:700;margin-top:2px;
}
.menu{display:flex;align-items:center;gap:2.2rem;list-style:none}
.menu a{
  font-size:.92rem;font-weight:600;color:var(--grafito);
  position:relative;padding:.3rem 0;transition:color .2s ease;
}
.menu a::after{
  content:'';position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--arena);transition:width .28s ease;
}
.menu a:hover,.menu a.activo{color:var(--arena-oscuro)}
.menu a:hover::after,.menu a.activo::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.menu-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:42px;height:42px;flex-direction:column;justify-content:center;
  gap:5px;align-items:center;
}
.menu-toggle span{
  display:block;width:24px;height:2px;background:var(--grafito);
  transition:transform .3s ease,opacity .3s ease;
}
.menu-toggle.abierto span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.abierto span:nth-child(2){opacity:0}
.menu-toggle.abierto span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  background:linear-gradient(135deg,#e6d6bd 0%,#cfb593 55%,#bfa078 100%);
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:url('../img/hero-pattern.jpg');
  background-size:520px;opacity:.16;mix-blend-mode:overlay;
}
.hero-inner{
  position:relative;display:grid;grid-template-columns:1.05fr .95fr;
  gap:3rem;align-items:center;
  padding-top:clamp(3.5rem,8vw,6.5rem);padding-bottom:clamp(3.5rem,8vw,6.5rem);
}
.hero-texto h1{color:var(--negro);margin-bottom:1.4rem}
.hero-texto .eyebrow{color:#7a5f37}
.hero-texto p{
  font-size:1.18rem;color:#5b4628;max-width:480px;margin-bottom:2rem;
}
.hero-acciones{display:flex;gap:1rem;flex-wrap:wrap}
.hero-visual{
  position:relative;aspect-ratio:4/5;border-radius:var(--radio-lg);
  background:var(--crema);overflow:hidden;box-shadow:var(--sombra);
}
.hero-visual .ph-foto{height:100%}
.hero-marca{
  position:absolute;right:-40px;bottom:-40px;width:230px;opacity:.5;
}

/* placeholder de foto */
.ph-foto{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:repeating-linear-gradient(45deg,var(--arena-suave),var(--arena-suave) 18px,#efe4d2 18px,#efe4d2 36px);
  color:var(--arena-oscuro);text-align:center;gap:.6rem;padding:1.5rem;
  font-size:.82rem;font-weight:700;letter-spacing:.04em;
  border:1px dashed var(--arena-oscuro);
}
.ph-foto svg{width:38px;height:38px;opacity:.6}
.ph-foto small{font-weight:500;opacity:.75;letter-spacing:0;font-size:.72rem}

/* Imagen real que rellena su contenedor */
.foto{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- Tira de valores ---------- */
.valores{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--borde);
}
.valor{
  padding:2.4rem 1.6rem;text-align:center;
  border-right:1px solid var(--borde);
}
.valor:last-child{border-right:none}
.valor .ico{
  width:52px;height:52px;margin:0 auto 1rem;
  display:flex;align-items:center;justify-content:center;
  background:var(--arena-suave);border-radius:50%;color:var(--arena-oscuro);
}
.valor .ico svg{width:24px;height:24px}
.valor h3{font-size:1.05rem;font-family:var(--texto-font);font-weight:700;color:var(--grafito);margin-bottom:.3rem}
.valor p{font-size:.88rem;color:var(--grafito-claro)}

/* ---------- Encabezado de sección ---------- */
.sec-head{margin-bottom:3.2rem}
.sec-head.centro{margin-left:auto;margin-right:auto}
.sec-head h2{margin-bottom:1rem}

/* ---------- Tarjetas de servicio ---------- */
.grid-servicios{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;
}
.tarjeta{
  background:var(--blanco);border:1px solid var(--borde);
  border-radius:var(--radio-lg);overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;
  display:flex;flex-direction:column;
}
.tarjeta:hover{transform:translateY(-8px);box-shadow:var(--sombra)}
.tarjeta-foto{aspect-ratio:3/2}
.tarjeta-cuerpo{padding:1.7rem 1.6rem;display:flex;flex-direction:column;flex:1}
.tarjeta-cuerpo h3{margin-bottom:.7rem}
.tarjeta-cuerpo p{font-size:.95rem;color:var(--grafito-claro);margin-bottom:1.2rem;flex:1}
.tarjeta-link{
  font-weight:700;font-size:.88rem;color:var(--arena-oscuro);
  display:inline-flex;align-items:center;gap:.4rem;
}
.tarjeta-link svg{width:16px;height:16px;transition:transform .25s ease}
.tarjeta:hover .tarjeta-link svg{transform:translateX(5px)}

/* ---------- Bloque imagen + texto ---------- */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:3.4rem;align-items:center;
}
.split.invertido .split-media{order:2}
.split-media{
  aspect-ratio:5/4;border-radius:var(--radio-lg);overflow:hidden;
  box-shadow:var(--sombra-suave);
}
.split-texto h2{margin-bottom:1.2rem}
.lista-check{list-style:none;margin-top:1.6rem;display:flex;flex-direction:column;gap:.9rem}
.lista-check li{display:flex;gap:.8rem;align-items:flex-start;font-size:.98rem}
.lista-check li::before{
  content:'';flex:none;width:22px;height:22px;border-radius:50%;
  background:var(--arena);margin-top:3px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23222' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-size:13px;background-repeat:no-repeat;background-position:center;
}

/* ---------- Detalle de servicios (página servicios) ---------- */
.servicio-bloque{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:2.8rem;
  align-items:start;padding:2.8rem 0;border-bottom:1px solid var(--borde);
}
.servicio-bloque:last-child{border-bottom:none}
.servicio-bloque.inv .sb-media{order:2}
.sb-media{
  aspect-ratio:4/3;border-radius:var(--radio-lg);overflow:hidden;
  box-shadow:var(--sombra-suave);position:sticky;top:110px;
}
.sb-texto h3{font-size:1.6rem;margin-bottom:.4rem}
.sb-tagline{color:var(--arena-oscuro);font-weight:700;font-size:.95rem;margin-bottom:1.2rem}
.sb-sub{margin-top:1.4rem}
.sb-sub h4{
  font-family:var(--texto-font);font-size:1rem;font-weight:700;
  color:var(--grafito);margin-bottom:.3rem;
}
.sb-sub p{font-size:.95rem;color:var(--grafito-claro)}

/* ---------- Técnicas (grid) ---------- */
.grid-tecnicas{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;
}
.tecnica{
  background:var(--blanco);border:1px solid var(--borde);
  border-radius:var(--radio);padding:1.7rem 1.6rem;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.tecnica:hover{transform:translateY(-5px);box-shadow:var(--sombra-suave);border-color:var(--arena)}
.tecnica .num{
  font-family:var(--display);font-size:1.1rem;color:var(--arena-oscuro);
  font-weight:600;
}
.tecnica h3{font-size:1.12rem;margin:.5rem 0 .6rem}
.tecnica p{font-size:.9rem;color:var(--grafito-claro)}
.tecnica-cat{
  grid-column:1/-1;margin-top:1.4rem;
}
.tecnica-cat:first-child{margin-top:0}
.tecnica-cat h2{font-size:1.5rem;display:flex;align-items:center;gap:.8rem}
.tecnica-cat h2::after{content:'';flex:1;height:1px;background:var(--borde)}

/* ---------- Equipo ---------- */
.grid-equipo{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;
}
.miembro{text-align:center}
.miembro-foto{
  aspect-ratio:1;border-radius:var(--radio-lg);overflow:hidden;
  margin-bottom:1rem;box-shadow:var(--sombra-suave);
}
.miembro h3{font-size:1.15rem;margin-bottom:.15rem}
.miembro .esp{color:var(--arena-oscuro);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em}
.miembro p{font-size:.9rem;color:var(--grafito-claro);margin-top:.5rem}

/* ---------- Horarios ---------- */
.horarios{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;
}
.horario{
  background:var(--blanco);border:1px solid var(--borde);
  border-radius:var(--radio);padding:1.5rem 1.6rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.horario .h-serv{font-weight:700;color:var(--grafito);font-size:1rem}
.horario .h-dias{font-size:.86rem;color:var(--grafito-claro);margin-top:.2rem}
.horario .h-hora{
  text-align:right;font-size:.9rem;color:var(--arena-oscuro);
  font-weight:700;flex:none;
}

/* ---------- Testimonios ---------- */
.grid-testimonios{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.4rem;align-items:stretch;
}
.testimonio{
  background:var(--blanco);border:1px solid var(--borde);
  border-radius:var(--radio-lg);padding:1.8rem 1.6rem;
  display:flex;flex-direction:column;
}
.testimonio .comillas{
  font-family:var(--display);font-size:3rem;color:var(--arena);
  line-height:.5;display:block;margin-bottom:1rem;
}
.testimonio p{font-style:italic;color:var(--grafito);margin-bottom:1.2rem;flex:1;font-size:.94rem;line-height:1.65}
.testimonio .autor{font-weight:700;font-size:.88rem;color:var(--arena-oscuro)}

/* ---------- CTA final ---------- */
.cta{
  background:linear-gradient(135deg,#3f3f3f,#2a2a28);
  color:var(--blanco);text-align:center;position:relative;overflow:hidden;
}
.cta::before{
  content:'';position:absolute;inset:0;
  background-image:url('../img/hero-pattern.jpg');
  background-size:420px;opacity:.07;
}
.cta-inner{position:relative}
.cta h2{color:var(--blanco);margin-bottom:1rem}
.cta p{color:rgba(255,255,255,.78);max-width:520px;margin:0 auto 2rem}

/* ---------- Banner de página interior ---------- */
.banner{
  background:linear-gradient(135deg,#e6d6bd,#cfb593);
  position:relative;overflow:hidden;
}
.banner::before{
  content:'';position:absolute;inset:0;
  background-image:url('../img/hero-pattern.jpg');
  background-size:480px;opacity:.15;mix-blend-mode:overlay;
}
.banner-inner{
  position:relative;padding-top:clamp(3rem,7vw,5rem);padding-bottom:clamp(3rem,7vw,5rem);
}
.banner h1{color:var(--negro);margin-bottom:.8rem}
.banner p{color:#5b4628;font-size:1.1rem;max-width:560px}
.migas{
  font-size:.82rem;color:#7a5f37;margin-bottom:1rem;font-weight:600;
}
.migas a:hover{color:var(--negro)}

/* ---------- Página de contacto ---------- */
.contacto-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.info-bloque{margin-bottom:1.8rem;display:flex;gap:1rem;align-items:flex-start}
.info-bloque .ico{
  width:46px;height:46px;flex:none;border-radius:12px;
  background:var(--arena-suave);color:var(--arena-oscuro);
  display:flex;align-items:center;justify-content:center;
}
.info-bloque .ico svg{width:22px;height:22px}
.info-bloque h3{font-size:1rem;font-family:var(--texto-font);font-weight:700;margin-bottom:.2rem}
.info-bloque p,.info-bloque a{font-size:.95rem;color:var(--grafito-claro)}
.info-bloque a:hover{color:var(--arena-oscuro)}
.form-grupo{margin-bottom:1.2rem}
.form-grupo label{
  display:block;font-size:.85rem;font-weight:700;color:var(--grafito);
  margin-bottom:.4rem;
}
.form-grupo input,.form-grupo select,.form-grupo textarea{
  width:100%;padding:.85rem 1rem;border:1px solid var(--borde);
  border-radius:10px;font-family:var(--texto-font);font-size:.95rem;
  background:var(--blanco);color:var(--texto);transition:border-color .2s ease;
}
.form-grupo input:focus,.form-grupo select:focus,.form-grupo textarea:focus{
  outline:none;border-color:var(--arena);
}
.form-grupo textarea{resize:vertical;min-height:120px}
.mapa-wrap{
  border-radius:var(--radio-lg);overflow:hidden;margin-top:2.5rem;
  box-shadow:var(--sombra-suave);border:1px solid var(--borde);
}
.mapa-wrap iframe{display:block;width:100%;height:340px;border:0}

/* ---------- WhatsApp flotante ---------- */
.wa-flotante{
  position:fixed;right:24px;bottom:24px;z-index:200;
  width:62px;height:62px;border-radius:50%;
  background:linear-gradient(135deg,#25d366 0%,#1ebd5b 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 32px -10px rgba(37,211,102,.55), 0 4px 10px rgba(0,0,0,.12);
  transition:transform .25s ease, box-shadow .25s ease;
}
.wa-flotante::before{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:2px solid #25d366;opacity:.6;
  animation:wa-pulso 2.2s ease-out infinite;
}
.wa-flotante:hover{
  transform:scale(1.08);
  box-shadow:0 16px 40px -10px rgba(37,211,102,.7), 0 6px 12px rgba(0,0,0,.18);
}
.wa-flotante:hover::before{animation-play-state:paused}
.wa-flotante svg{width:34px;height:34px;fill:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}
@keyframes wa-pulso{
  0%{transform:scale(1);opacity:.6}
  70%{transform:scale(1.5);opacity:0}
  100%{transform:scale(1.5);opacity:0}
}

/* ---------- Pie ---------- */
.pie{background:var(--negro);color:rgba(255,255,255,.7);padding:4rem 0 2rem}
.pie-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem;
  padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1);
}
.pie h4{
  color:var(--blanco);font-family:var(--texto-font);font-size:.95rem;
  font-weight:700;margin-bottom:1.2rem;text-transform:uppercase;
  letter-spacing:.08em;
}
.pie-marca img{height:42px;margin-bottom:1rem}
.pie-marca p{font-size:.9rem;line-height:1.7}
.pie ul{list-style:none}
.pie ul li{margin-bottom:.6rem}
.pie ul a{font-size:.9rem;transition:color .2s ease}
.pie ul a:hover{color:var(--arena)}
.pie-contacto p{font-size:.9rem;margin-bottom:.6rem}
.pie-contacto a:hover{color:var(--arena)}
.pie-abajo{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:2rem;font-size:.82rem;flex-wrap:wrap;gap:1rem;
}

/* ---------- Animación de entrada ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{max-width:420px}
  .valores{grid-template-columns:repeat(2,1fr)}
  .valor:nth-child(2){border-right:none}
  .valor:nth-child(1),.valor:nth-child(2){border-bottom:1px solid var(--borde)}
  .grid-servicios,.grid-testimonios{grid-template-columns:1fr}
  .grid-tecnicas{grid-template-columns:repeat(2,1fr)}
  .grid-equipo{grid-template-columns:repeat(2,1fr)}
  .split,.servicio-bloque,.contacto-grid{grid-template-columns:1fr;gap:2rem}
  .split.invertido .split-media,.servicio-bloque.inv .sb-media{order:0}
  .sb-media{position:static}
  .horarios{grid-template-columns:1fr}
  .pie-grid{grid-template-columns:1fr 1fr;gap:2rem}
}

/* Menú móvil: activo en móvil Y tablet (hasta 980px) */
@media(max-width:980px){
  .menu{
    position:fixed;top:84px;left:0;right:0;
    background:var(--blanco);flex-direction:column;
    padding:1.5rem 28px 2rem;gap:1.2rem;align-items:flex-start;
    border-bottom:1px solid var(--borde);
    transform:translateY(-130%);transition:transform .35s ease;
    box-shadow:var(--sombra-suave);
  }
  .menu.abierto{transform:translateY(0)}
  .menu-toggle{display:flex}
  .nav-cta .btn{display:none}
}

@media(max-width:680px){
  body{font-size:16px}
  .grid-tecnicas,.grid-equipo{grid-template-columns:1fr}
  .pie-grid{grid-template-columns:1fr}
  .tecnica-cat h2{font-size:1.3rem}
}

/* ============================================
   RGPD: banner de cookies, formulario y páginas legales
   ============================================ */

/* Banner de cookies */
.cookie-banner{
  position:fixed;left:20px;right:20px;bottom:20px;z-index:300;
  background:var(--blanco);border:1px solid var(--borde);
  border-radius:var(--radio-lg);box-shadow:var(--sombra);
  padding:1.4rem 1.6rem;max-width:560px;margin:0 auto;
  display:none;
}
.cookie-banner.visible{display:block;animation:cookie-in .4s ease}
@keyframes cookie-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.cookie-banner h3{font-size:1.05rem;font-family:var(--texto-font);font-weight:700;color:var(--grafito);margin-bottom:.5rem}
.cookie-banner p{font-size:.88rem;color:var(--grafito-claro);line-height:1.6;margin-bottom:1rem}
.cookie-banner p a{color:var(--arena-oscuro);text-decoration:underline}
.cookie-banner .cookie-acciones{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-banner .btn{padding:.7rem 1.3rem;font-size:.85rem}

/* Checkbox del formulario */
.form-grupo-check{margin:1.2rem 0;display:flex;gap:.7rem;align-items:flex-start}
.form-grupo-check input[type="checkbox"]{
  width:18px;height:18px;flex:none;margin-top:3px;accent-color:var(--arena-oscuro);cursor:pointer;
}
.form-grupo-check label{font-size:.82rem;color:var(--grafito-claro);line-height:1.55;cursor:pointer}
.form-grupo-check label a{color:var(--arena-oscuro);text-decoration:underline}

.aviso-datos{
  background:var(--arena-suave);border-radius:var(--radio);
  padding:.9rem 1.1rem;font-size:.78rem;color:var(--grafito-claro);
  line-height:1.55;margin-top:1rem;
}
.aviso-datos strong{color:var(--grafito)}

/* Página legal (aviso legal, privacidad, cookies) */
.legal{padding:clamp(2.5rem,6vw,4.5rem) 0}
.legal h2{font-size:1.4rem;margin:2.2rem 0 .8rem;color:var(--grafito)}
.legal h2:first-of-type{margin-top:1rem}
.legal p,.legal li{font-size:.95rem;color:var(--texto);line-height:1.75;margin-bottom:.9rem}
.legal ul{margin:0 0 1rem 1.4rem}
.legal ul li{margin-bottom:.4rem}
.legal table{
  width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;
  font-size:.88rem;
}
.legal table th,.legal table td{
  text-align:left;padding:.7rem .9rem;border:1px solid var(--borde);
  vertical-align:top;
}
.legal table th{background:var(--arena-suave);font-weight:700;color:var(--grafito)}
.legal .placeholder{
  background:#fff7d6;border-radius:4px;padding:1px 6px;
  font-weight:700;color:#8a6a0c;font-size:.92em;
}

/* Enlaces del pie */
.pie-legal{display:flex;gap:1.2rem;flex-wrap:wrap}
.pie-legal a{font-size:.82rem}
