.legal {
    background: linear-gradient(to bottom, var(--background), var(--background-dark));
    border-radius: 1rem;
    padding: clamp(1rem, 3vw, 2rem);
    box-shadow: 0 -0.5rem 0.75rem var(--shadow), 0 0.5rem 0.75rem var(--shadow);
    color: var(--text);
}

.legal--cookies .legal__title { color: var(--primary); }
.legal--privacy .legal__title { color: var(--accent); }
.legal--terms   .legal__title { color: var(--highlight); }

.legal__header {
    margin-bottom: clamp(1rem, 3vw, 1.75rem);
    border-bottom: 1px solid var(--border);
    padding-bottom: clamp(0.75rem, 2vw, 1rem);
}

.legal__title {
    margin: 0 0 0.5rem 0;
    text-wrap: balance;
}

.legal__meta {
    margin: 0;
    font-size: 0.95rem;
    color: var(--text-secondary);
}

.legal__meta-label {
    font-weight: 600;
    margin-right: 0.375rem;
}

.legal__updated {
    font-variant-numeric: tabular-nums;
}

.legal__section {
    margin-top: clamp(1.125rem, 3vw, 1.75rem);
}

.legal__section-title {
    margin: 0 0 0.5rem 0;
    color: var(--text);
}

.legal__paragraph {
    margin: 0 0 0.75rem 0;
    line-height: 1.9;
    max-width: 70ch;
}

.legal__list {
    margin: 0 0 0.75rem 0;
    padding-left: clamp(1.125rem, 4vw, 1.75rem);
}

.legal__list-item {
    margin: 0 0 0.5rem 0;
}

.legal__link {
    text-decoration: underline;
    text-underline-offset: 0.125rem;
}

.legal__block {
    background: var(--background);
    border: 1px solid var(--border);
    border-radius: 0.5rem;
    padding: clamp(0.75rem, 2.5vw, 1.25rem);
    overflow: auto;
}

.legal a:focus,
.legal button:focus,
.legal [tabindex]:focus {
    outline: 0.125rem solid var(--secondary);
    outline-offset: 0.125rem;
}

@media (max-width: 42.5rem) {
    .legal {
        background: none;
        padding-left: 8px;
        padding-right: 8px;
        border-radius: 0;
        box-shadow: none;
        max-width: 100%;
    }
    .legal__header { padding-bottom: 0.75rem; }
}

@page {
    margin: 1in;
}

@media print {
    .legal {
        box-shadow: none;
        background: #fff;
        color: #000;
        padding-left: 0;
        padding-right: 0;
        border-radius: 0;
    }
    .legal__header { border-bottom: 1px solid #ccc; }
    .legal__link { color: #000; }
}