/* ============================================================
   Aviso Legal — estilos de prosa legal
   Hereda tokens de ../home/styles.css (--color-ink, --font-sans, etc.)
   ============================================================ */

/* Alias del design system real (home/styles.css): evita que los tokens
   --color-* caigan a literales hardcodeados y que un cambio de marca no propague. */
:root {
  --color-ink: var(--ink);
  --color-surface: var(--surface-alt);
  --color-surface-subtle: var(--surface);
  --color-border: var(--line);
  --color-muted: var(--ink-65);
  --color-brand-lime: var(--lima);
  --font-sans: var(--font);
  --ring-focus: #2563eb;
}

/* ── Hero de página legal ── */
.dg-legal__hero {
  background-color: var(--color-surface, #F3F5F8);
  padding: clamp(3rem, 6vw, 5rem) 1.5rem clamp(2rem, 4vw, 3.5rem);
  border-bottom: 1px solid var(--color-border, #dde1e7);
}

.dg-legal__container {
  max-width: 760px;
  margin-inline: auto;
  padding-inline: 1.5rem;
}

.dg-legal__title {
  font-family: var(--font-sans, "DM Sans", system-ui, sans-serif);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  color: var(--color-ink, #263b4a);
  margin-bottom: 0.75rem;
}

.dg-legal__subtitle {
  font-family: var(--font-sans, "DM Sans", system-ui, sans-serif);
  font-size: 1rem;
  color: var(--color-muted, #5a6672);
  line-height: 1.6;
  max-width: 60ch;
}

.dg-legal__updated {
  font-family: var(--font-sans, "DM Sans", system-ui, sans-serif);
  font-size: 0.875rem;
  color: var(--color-muted, #5a6672);
  margin-top: 0.5rem;
}

/* ── Cuerpo del texto legal ── */
.dg-legal__body {
  padding: clamp(2.5rem, 5vw, 4.5rem) 1.5rem;
}

/* ── Prosa ── */
.dg-legal__prose {
  font-family: var(--font-sans, "DM Sans", system-ui, sans-serif);
  font-size: 1rem;
  line-height: 1.75;
  color: var(--color-ink, #263b4a);
}

.dg-legal__prose h2 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-ink, #263b4a);
  margin-top: 2.5rem;
  margin-bottom: 0.875rem;
  padding-bottom: 0.4rem;
  border-bottom: 2px solid var(--color-border, #dde1e7);
}

.dg-legal__prose h2:first-child {
  margin-top: 0;
}

.dg-legal__prose h3 {
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--color-ink, #263b4a);
  margin-top: 1.75rem;
  margin-bottom: 0.625rem;
}

.dg-legal__prose p {
  margin-bottom: 1rem;
}

.dg-legal__prose p:last-child {
  margin-bottom: 0;
}

.dg-legal__prose ul,
.dg-legal__prose ol {
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}

.dg-legal__prose ul {
  list-style-type: disc;
}

.dg-legal__prose ol {
  list-style-type: decimal;
}

.dg-legal__prose li {
  margin-bottom: 0.5rem;
  line-height: 1.7;
}

.dg-legal__prose li ul,
.dg-legal__prose li ol {
  margin-top: 0.375rem;
  margin-bottom: 0;
}

.dg-legal__prose a {
  color: var(--color-ink, #263b4a);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--color-brand-lime, #b5ff82);
  text-decoration-thickness: 2px;
  transition: color 150ms ease, text-decoration-color 150ms ease;
}

.dg-legal__prose a:hover {
  color: var(--color-ink, #263b4a);
  text-decoration-color: var(--color-ink, #263b4a);
}

.dg-legal__prose a:focus-visible {
  outline: 2px solid var(--ring-focus, #2563eb);
  outline-offset: 2px;
  border-radius: 2px;
}

.dg-legal__prose strong {
  font-weight: 600;
}

/* ── Tabla de finalidades / relación de cookies ── */
.dg-legal__table-wrap {
  overflow-x: auto;
  margin-bottom: 1.25rem;
  border-radius: 8px;
  border: 1px solid var(--color-border, #dde1e7);
}

.dg-legal__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
  line-height: 1.5;
}

.dg-legal__table thead {
  background-color: var(--color-surface, #F3F5F8);
}

.dg-legal__table th {
  text-align: left;
  font-weight: 600;
  padding: 0.75rem 1rem;
  border-bottom: 2px solid var(--color-border, #dde1e7);
  color: var(--color-ink, #263b4a);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dg-legal__table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--color-border, #dde1e7);
  vertical-align: top;
}

.dg-legal__table tr:last-child td {
  border-bottom: none;
}

.dg-legal__table tbody tr:nth-child(even) {
  background-color: var(--color-surface-subtle, #f8fafb);
}

/* ── Responsive ── */
@media (min-width: 768px) {
  .dg-legal__container {
    padding-inline: 2rem;
  }

  .dg-legal__prose {
    font-size: 1.0625rem;
  }
}
