/* =============================================================================
   Legal Pages (Privacy Policy / Terms of Service)
   -----------------------------------------------------------------------------
   Long-form, readable legal documents. Uses tokens.css exclusively for
   color/spacing/typography. Shared by views/privacy.pug and views/terms.pug.
   ========================================================================== */

.legal-page {
    max-width: 820px;
    margin: 0 auto;
    padding: var(--space-xl) var(--space-lg) var(--space-2xl);
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: var(--font-size-md);
    line-height: 1.7;
}

/* --- Hero --------------------------------------------------------------- */
.legal-hero {
    padding: var(--space-xl);
    background: var(--gradient-hero, var(--color-primary));
    color: var(--color-on-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    margin-bottom: var(--space-xl);
}

.legal-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-xs);
    opacity: 0.9;
    margin: 0 0 var(--space-sm);
}

.legal-hero h1 {
    font-family: var(--font-display);
    font-size: var(--font-size-4xl);
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 var(--space-sm);
    font-weight: var(--font-weight-bold);
}

.legal-meta {
    font-size: var(--font-size-sm);
    opacity: 0.9;
    margin: 0 0 var(--space-md);
}

.legal-lede {
    font-size: var(--font-size-md);
    opacity: 0.97;
    margin: 0;
    max-width: 70ch;
}

/* --- Table of contents -------------------------------------------------- */
.legal-toc {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-lg) var(--space-xl);
    margin-bottom: var(--space-xl);
    box-shadow: var(--shadow-card);
}

.legal-toc__title {
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-muted);
    margin: 0 0 var(--space-sm);
}

.legal-toc ol {
    columns: 2;
    column-gap: var(--space-xl);
    margin: 0;
    padding-left: var(--space-lg);
    font-size: var(--font-size-sm);
}

.legal-toc li {
    margin-bottom: var(--space-xs);
    break-inside: avoid;
}

.legal-toc a {
    color: var(--color-link);
    text-decoration: none;
}

.legal-toc a:hover {
    text-decoration: underline;
}

/* --- Body --------------------------------------------------------------- */
.legal-body section {
    margin-bottom: var(--space-xl);
    scroll-margin-top: var(--space-xl);
}

.legal-body h2 {
    font-family: var(--font-display);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin: 0 0 var(--space-sm);
    padding-bottom: var(--space-xs);
    border-bottom: 2px solid var(--color-border-soft);
}

.legal-body h3 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin: var(--space-lg) 0 var(--space-xs);
}

.legal-body p {
    margin: 0 0 var(--space-md);
}

.legal-body ul {
    margin: 0 0 var(--space-md);
    padding-left: var(--space-lg);
}

.legal-body li {
    margin-bottom: var(--space-xs);
}

.legal-body a {
    color: var(--color-link);
    text-decoration: underline;
}

.legal-body strong {
    font-weight: var(--font-weight-bold);
}

.legal-contact {
    list-style: none;
    padding: var(--space-md) var(--space-lg);
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

.legal-contact li {
    margin-bottom: var(--space-xs);
}

.legal-related {
    margin-top: var(--space-xl);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* --- Responsive --------------------------------------------------------- */
@media (max-width: 640px) {
    .legal-toc ol {
        columns: 1;
    }

    .legal-hero {
        padding: var(--space-lg);
    }

    .legal-hero h1 {
        font-size: var(--font-size-3xl);
    }
}
