/* Legal pages (Privacy / Terms / Cookies / Imprint) */

.legal {
    padding: clamp(var(--space-6), 6vw, var(--space-8)) 0 var(--space-8);
    min-height: 60vh;
}

.legal__head {
    border-bottom: 1px solid var(--border-soft);
    padding-bottom: var(--space-5);
    margin-bottom: var(--space-6);
}

.legal__title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--text-primary);
    margin: var(--space-2) 0 var(--space-3);
    line-height: 1.1;
}

.legal__updated {
    font-size: 0.86rem;
    color: var(--text-faint);
    font-family: var(--font-mono);
}

.legal__body { max-width: none; }
.legal__body h2 {
    margin-top: var(--space-7);
    font-family: var(--font-display);
    font-size: 1.5rem;
    color: var(--text-primary);
    letter-spacing: -0.01em;
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--border-soft);
}
.legal__body h3 {
    margin-top: var(--space-5);
    font-family: var(--font-display);
    font-size: 1.12rem;
    color: var(--accent-gold);
}
.legal__body p, .legal__body ul, .legal__body ol { color: var(--text-secondary); }
.legal__body strong { color: var(--text-primary); }
.legal__body a { color: var(--accent-gold); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.legal__body a:hover { color: var(--accent-gold-soft); }
.legal__body code {
    font-family: var(--font-mono);
    font-size: 0.88em;
    color: var(--accent-gold);
    background: var(--surface-1);
    padding: 1px 5px;
    border-radius: 3px;
}

.legal__table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--space-4) 0 var(--space-5);
    background: var(--surface-1);
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--border-soft);
}
.legal__table th,
.legal__table td {
    padding: 0.7rem 1rem;
    text-align: left;
    border-bottom: 1px solid var(--border-soft);
    font-size: 0.92rem;
    vertical-align: top;
}
.legal__table tr:last-child th,
.legal__table tr:last-child td { border-bottom: none; }
.legal__table th {
    width: 160px;
    color: var(--text-faint);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    background: rgba(255, 255, 255, 0.02);
}
.legal__table td { color: var(--text-primary); }

@media (max-width: 640px) {
    .legal__table th, .legal__table td { display: block; width: auto; }
    .legal__table th { padding-bottom: 0; border-bottom: none; }
}

