/* assets/css/legales.css */
/* Legales — Documento premium (compatible con tus variables globales) */

.legal-wrap{
  /* Layout */
  padding: clamp(120px, 4vw, 64px) 0;
  position: relative;
  z-index: 1;
}

/* Variables locales (no ensucian :root global) */
.legal-wrap{
  --legal-max: 980px;

  /* Fallbacks de color: si tu base define --color-text/--color-primary/etc., se usan */
  --legal-text: var(--color-text, #0f172a);
  --legal-muted: var(--color-muted, rgba(15, 23, 42, 0.72));
  --legal-primary: var(--color-primary, #0d77be);

  --legal-border: rgba(15, 23, 42, 0.12);
  --legal-border-strong: rgba(15, 23, 42, 0.18);

  --legal-surface: rgba(255, 255, 255, 0.72);
  --legal-surface-strong: rgba(255, 255, 255, 0.86);

  --legal-shadow: 0 22px 60px rgba(15, 23, 42, 0.10);
  --legal-shadow-hover: 0 28px 84px rgba(15, 23, 42, 0.16);

  --legal-radius: 18px;
  --legal-radius-lg: 24px;

  --legal-pad: 18px;
}

/* Contenedor: respeta tu .container pero controla ancho y lectura */
.legal-hero,
.legal-article{
  max-width: var(--legal-max);
  margin: 0 auto;
}

/* Tipografía y ritmo de lectura */
.legal-article{
  color: var(--legal-text);
  font-size: 16px;
  line-height: 1.70;
  letter-spacing: -0.01em;
}

.legal-article > * + *{
  margin-top: 12px;
}

/* Títulos */
.legal-title,
.legal-article h1{
  margin: 0 0 10px;
  font-size: clamp(30px, 3.6vw, 44px);
  line-height: 1.10;
  letter-spacing: -0.03em;
}

.legal-hero .legal-lead,
.legal-article p{
  margin: 0;
  color: var(--legal-text);
}

.legal-hero .legal-lead{
  max-width: 74ch;
  color: var(--legal-muted);
  margin-top: 20px;
  margin-bottom: 35px;
}

/* Meta de actualización */
.legal-updated{
  margin: 8px 0 18px;
  color: var(--legal-muted);
  font-size: 14px;
}

/* Subtítulos (sección) */
.legal-article h2{
  margin: 18px 0 8px;
  font-size: 18px;
  line-height: 1.35;
  letter-spacing: -0.015em;
}

.legal-article h3{
  margin: 16px 0 6px;
  font-size: 16px;
  line-height: 1.35;
}

/* Separador suave opcional */
.legal-article hr{
  border: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--legal-border), transparent);
  margin: 18px 0;
}

/* Lists */
.legal-article ul,
.legal-article ol{
  margin: 8px 0 0;
  padding-left: 20px;
}

.legal-article li{
  margin: 6px 0;
  color: var(--legal-text);
}

.legal-article li::marker{
  color: var(--legal-primary);
}

/* Links */
.legal-article a{
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: rgba(13, 119, 190, 0.55);
  transition: text-decoration-color .16s ease, opacity .16s ease;
}

.legal-article a:hover{
  text-decoration-color: rgba(13, 119, 190, 0.95);
  opacity: .95;
}

/* Énfasis */
.legal-article strong{
  font-weight: 650;
}

/* Tarjeta / “documento” (si querés envolver el artículo) */
.legal-sheet{
  background: var(--legal-surface);
  border: 1px solid var(--legal-border);
  border-radius: var(--legal-radius-lg);
  padding: clamp(16px, 2.2vw, 24px);
  box-shadow: var(--legal-shadow);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Callouts opcionales */
.legal-callout{
  margin-top: 14px;
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid var(--legal-border);
  background: var(--legal-surface-strong);
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
}

.legal-callout--info{
  border-color: rgba(13, 119, 190, 0.25);
}

.legal-callout--warn{
  border-color: rgba(245, 158, 11, 0.25);
}

.legal-callout p{
  margin: 0;
  color: var(--legal-muted);
}

/* Tablas (por si las usás en legales) */
.legal-article table{
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid var(--legal-border);
  background: var(--legal-surface);
}

.legal-article th,
.legal-article td{
  padding: 12px 12px;
  border-bottom: 1px solid var(--legal-border);
  vertical-align: top;
}

.legal-article th{
  text-align: left;
  font-weight: 650;
  color: var(--legal-text);
  background: rgba(255, 255, 255, 0.45);
}

.legal-article tr:last-child td{
  border-bottom: 0;
}

/* Anchors: evita que el header tape los títulos */
.legal-article h2,
.legal-article h3{
  scroll-margin-top: 110px;
}

/* Portada / índice de Legales (cards) */
.legal-grid{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
  margin-top: 22px;
}

.legal-card{
  grid-column: span 6;
  display: block;
  padding: 16px 16px;
  border-radius: var(--legal-radius);
  text-decoration: none;
  border: 1px solid var(--legal-border);
  background: var(--legal-surface);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: var(--legal-shadow);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  color: var(--legal-text);
}

.legal-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--legal-shadow-hover);
  border-color: var(--legal-border-strong);
}

.legal-card h2{
  margin: 0 0 6px;
  font-size: 18px;
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.legal-card p{
  margin: 0;
  color: var(--legal-muted);
  max-width: 70ch;
}

/* Índice interno opcional (si luego lo agregás) */
.legal-toc{
  margin: 14px 0 18px;
  padding: 14px 14px;
  border: 1px solid var(--legal-border);
  border-radius: 16px;
  background: var(--legal-surface);
  box-shadow: 0 14px 45px rgba(15, 23, 42, 0.08);
}

.legal-toc .toc-title{
  margin: 0 0 8px;
  font-size: 14px;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--legal-muted);
}

.legal-toc a{
  text-decoration: none;
  border-bottom: 1px solid rgba(13, 119, 190, 0.30);
}

.legal-toc a:hover{
  border-bottom-color: rgba(13, 119, 190, 0.80);
}

/* Responsive */
@media (max-width: 920px){
  .legal-card{ grid-column: span 12; }
  .legal-article{ font-size: 15.5px; }
}


/* Print (queda como documento limpio) */
@media print{
  .wa-float, .wa-strip { display: none !important; }
  .site-header, .site-footer { display: none !important; }
  .legal-wrap{ padding: 0 !important; }
  .legal-sheet, .legal-card, .legal-toc{
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  .legal-article a{
    text-decoration: underline !important;
    text-decoration-color: #000 !important;
  }
}

/* CTA interno de cards (Legales index) */
.legal-card__cta{
  margin-top: 10px;
  font-weight: 650;
  color: var(--legal-muted);
  text-decoration: none;
  border-bottom: 1px solid rgba(13, 119, 190, 0.25);
  width: fit-content;
}
.legal-card:hover .legal-card__cta{
  color: var(--legal-text);
  border-bottom-color: rgba(13, 119, 190, 0.70);
}

/* ===========================
   FIX: Cards del index NO deben heredar el underline de .legal-article a
   =========================== */
.legal-article a.legal-card{
  text-decoration: none !important;
  text-decoration-color: transparent !important;
}

.legal-card h2,
.legal-card p,
.legal-card span{
  text-decoration: none !important;
}

/* CTA de la card: subrayado elegante solo para el CTA */
.legal-card__cta{
  margin-top: 10px;
  font-weight: 650;
  color: var(--legal-muted);
  text-decoration: none !important;
  border-bottom: 1px solid rgba(13, 119, 190, 0.25);
  width: fit-content;
}

.legal-card:hover .legal-card__cta{
  color: var(--legal-text);
  border-bottom-color: rgba(13, 119, 190, 0.70);
}

