
/* ════════════════════════════════════════════════════════
   LEGAL — contenedor sobrio para páginas legales
   ════════════════════════════════════════════════════════ */
.legal {
    color:var(--text-soft);
}

.legal__interior {
    max-width: 90ch;
    margin-inline: auto;
}

/* ─── Cabecera ────────────────────────────────── */
.legal__cabecera {
    margin-bottom: var(--space-7);
    padding-bottom: var(--space-5);
    border-bottom: 1px solid var(--border-soft);
}

.legal__titulo {
    margin: 0 0 var(--space-s);
}

.legal__actualizado {
    font-family: var(--ff-mono);
    font-size: var(--fs-mono);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0;
}

/* ─── Contenido ───────────────────────────────── */
.legal__contenido {
    font-size: var(--fs-body);
    line-height: 1.7;
}

.legal__contenido h2 {
    font-family: var(--font-heading);
    font-size: var(--fs-3);
    font-weight: 700;
    line-height: 1.2;
    margin: var(--space-7) 0 var(--space-2);
    color: var(--text-dark);
    text-transform: none;
}

.legal__contenido h3 {
    font-family: var(--ff-headings);
    font-size: var(--fs-4);
    font-weight: 700;
    line-height: 1.3;
    margin: var(--space-2) 0 var(--space-1);
    text-transform: none;
}

.legal__contenido h2:first-child,
.legal__contenido h3:first-child {
    margin-top: 0;
}

.legal__contenido p {
    margin: 0 0 var(--space-2);
}

.legal__contenido p:last-child {
    margin-bottom: 0;
}

.legal__contenido ul,
.legal__contenido ol {
    margin: 0 0 var(--space-2);
    padding-left: var(--space-3);
}

.legal__contenido li {
    margin-bottom: var(--space-0);
}

.legal__contenido li:last-child {
    margin-bottom: 0;
}

.legal__contenido a {
    color: var(--text-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: text-decoration-thickness 150ms ease;
}

.legal__contenido a:hover,
.legal__contenido a:focus-visible {
    text-decoration-thickness: 2px;
    outline: none;
}

.legal__contenido strong {
    font-weight: 700;
    color: var(--text-dark);
}

.legal__contenido em {
    font-style: italic;
}

.legal__contenido hr {
    border: none;
    border-top: 1px solid var(--border-soft);
    margin: var(--space-7) 0;
}

.legal__contenido blockquote {
    margin: var(--space-l) 0;
    padding-left: var(--space-2);
    border-left: 2px solid var(--text-accent);
    font-style: italic;
}

.legal__contenido code {
    font-family: var(--ff-mono);
    font-size: 0.9em;
    background-color: var(--border-soft);
    padding: 0.15em 0.4em;
    border-radius: 3px;
}

.legal__contenido table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--space-2) 0;
    font-size: var(--fs-ui);
}

.legal__contenido th,
.legal__contenido td {
    padding: var(--space-1);
    text-align: left;
    border-bottom: 1px solid var(--border-soft);
}

.legal__contenido th {
    font-weight: 700;

}

/* ─── Foco accesible ──────────────────────────── */
.legal :focus-visible {
    outline: 2px solid var(--text-accent);
    outline-offset: 4px;
}