/* ============================================
   LEGAL PAGES — Linky
   ============================================ */

/* --- Reset básico para legal --- */
.legal-page {
    margin: 0;
    padding: 0;
    min-height: 100vh;
    background: #0f0f14;
    color: #d1d1d6;
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
}

/* --- Contenedor principal --- */
.legal-page main {
    max-width: 720px;
    margin: 0 auto;
    padding: 3rem 1.5rem 4rem;
}

/* --- Título principal --- */
.legal-page h1 {
    color: #ffffff;
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
    letter-spacing: -0.02em;
}

/* --- Fecha de actualización (primer <p> después del h1) --- */
.legal-page h1 + p {
    color: #8888a0;
    font-size: 0.875rem;
    margin-bottom: 2.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #1e1e2a;
}

/* --- Subtítulos h3 (secciones) --- */
.legal-page h3 {
    color: #e0e0e8;
    font-size: 1.125rem;
    font-weight: 600;
    margin-top: 2.25rem;
    margin-bottom: 0.75rem;
    padding-top: 0.5rem;
}

/* --- Subtítulos h4 (sub-secciones) --- */
.legal-page h4 {
    color: #c0c0d0;
    font-size: 1rem;
    font-weight: 600;
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
}

/* --- Párrafos --- */
.legal-page p {
    color: #b0b0c0;
    font-size: 0.9375rem;
    margin-bottom: 1rem;
}

/* --- Links --- */
.legal-page a {
    color: #818cf8;
    text-decoration: underline;
    text-decoration-color: rgba(129, 140, 248, 0.3);
    text-underline-offset: 3px;
    transition: color 0.2s, text-decoration-color 0.2s;
}

.legal-page a:hover {
    color: #a5b4fc;
    text-decoration-color: rgba(165, 180, 252, 0.6);
}

/* --- Listas --- */
.legal-page ul,
.legal-page ol {
    margin: 0.5rem 0 1.25rem 0;
    padding-left: 1.25rem;
}

.legal-page li {
    color: #b0b0c0;
    font-size: 0.9375rem;
    margin-bottom: 0.5rem;
    padding-left: 0.25rem;
}

.legal-page li::marker {
    color: #555570;
}

.legal-page ol li::marker {
    color: #818cf8;
    font-weight: 600;
}

/* --- Negritas --- */
.legal-page strong {
    color: #e0e0e8;
    font-weight: 600;
}

/* --- Código inline --- */
.legal-page code {
    background: #1a1a28;
    color: #818cf8;
    padding: 0.15em 0.45em;
    border-radius: 4px;
    font-size: 0.85em;
    font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
    border: 1px solid #2a2a3a;
}

/* --- Emojis en listas (contenido prohibido) --- */
.legal-page li:has(> :first-child) {
    line-height: 1.6;
}

/* --- Tablas --- */
.legal-page table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0 1.5rem;
    font-size: 0.875rem;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #1e1e2a;
}

.legal-page thead {
    background: #16161f;
}

.legal-page th {
    color: #c0c0d0;
    font-weight: 600;
    text-align: left;
    padding: 0.75rem 1rem;
    border-bottom: 2px solid #2a2a3a;
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.legal-page td {
    color: #a0a0b5;
    padding: 0.625rem 1rem;
    border-bottom: 1px solid #1a1a28;
    vertical-align: top;
}

.legal-page tbody tr:last-child td {
    border-bottom: none;
}

.legal-page tbody tr:hover {
    background: rgba(129, 140, 248, 0.04);
}

/* --- Separador visual entre secciones grandes --- */
.legal-page h3:not(:first-of-type)::before {
    content: '';
    display: block;
    height: 1px;
    background: #1e1e2a;
    margin-bottom: 1.75rem;
}

/* --- Botón de regreso (opcional, si lo agregas) --- */
.legal-page .back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: #818cf8;
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 2rem;
    padding: 0.4rem 0;
    transition: color 0.2s, gap 0.2s;
}

.legal-page .back-link:hover {
    color: #a5b4fc;
    gap: 0.6rem;
}

.legal-page .back-link::before {
    content: '←';
}

/* --- Email destacado --- */
.legal-page p:has(> a[href^="mailto:"]:only-child) {
    background: #16161f;
    border: 1px solid #1e1e2a;
    border-left: 3px solid #818cf8;
    padding: 0.75rem 1rem;
    border-radius: 6px;
    margin: 1rem 0;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 640px) {
    .legal-page main {
        padding: 2rem 1.25rem 3rem;
    }

    .legal-page h1 {
        font-size: 1.625rem;
    }

    .legal-page h3 {
        font-size: 1.05rem;
    }

    /* Tablas responsivas */
    .legal-page table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .legal-page th,
    .legal-page td {
        padding: 0.5rem 0.75rem;
        white-space: nowrap;
    }

    .legal-page th {
        font-size: 0.75rem;
    }

    .legal-page td {
        font-size: 0.8125rem;
    }
}

@media (max-width: 380px) {
    .legal-page main {
        padding: 1.5rem 1rem 2.5rem;
    }

    .legal-page h1 {
        font-size: 1.4rem;
    }

    .legal-page p,
    .legal-page li {
        font-size: 0.875rem;
    }
}