/* Legal document layout */

.legal-shell {
    position: relative;
    padding-top: 80px;
    padding-bottom: 140px;
}

.legal-container {
    max-width: 56rem;
}

.legal-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 32px;
    padding: clamp(28px, 4vw, 56px);
    border-radius: var(--radius-card);
    border: 1px solid color-mix(in srgb, var(--border-color) 70%, transparent);
    background: linear-gradient(
        160deg,
        color-mix(in srgb, var(--surface-elevated) 92%, var(--primary-color) 8%) 0%,
        var(--surface-color) 55%,
        var(--surface-color) 100%
    );
    box-shadow: 0 28px 70px -40px var(--shadow-color);
}

.legal-card > p {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--text-body);
}

.legal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 20px;
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--text-body) 85%, transparent);
}

.legal-card > p,
.legal-card > .legal-meta {
    grid-column: 1 / -1;
}

.legal-toc {
    border-radius: 18px;
    border: 1px solid color-mix(in srgb, var(--border-color) 65%, transparent);
    background: color-mix(in srgb, var(--surface-muted) 70%, transparent);
    padding: 20px 20px 18px;
}

.legal-toc h2 {
    font-size: 0.7rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--text-body) 80%, transparent);
    margin-bottom: 12px;
}

.legal-toc ul {
    display: grid;
    gap: 8px;
}

.legal-toc a {
    color: var(--text-hero);
    font-size: 0.95rem;
}

.legal-toc a:hover {
    color: var(--primary-color);
}

.legal-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
    color: var(--text-body);
}

.legal-content h2 {
    font-size: 1.5rem;
    margin-top: 28px;
    color: var(--text-hero);
}

.legal-content h2:first-of-type {
    margin-top: 0;
}

.legal-content p {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--text-body);
}

.legal-content ul {
    list-style: disc;
    padding-left: 20px;
    display: grid;
    gap: 10px;
    color: var(--text-body);
}

.legal-content li {
    line-height: 1.6;
}

.legal-content strong {
    color: var(--text-hero);
}

.legal-content a {
    color: var(--primary-color);
}

.legal-content a:hover {
    color: color-mix(in srgb, var(--primary-color) 70%, var(--text-hero));
}

@media (min-width: 980px) {
    .legal-card {
        grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
        gap: 40px;
    }

    .legal-toc {
        position: sticky;
        top: 120px;
        align-self: start;
    }
}

@media (max-width: 720px) {
    .legal-card {
        padding: 26px 22px;
        gap: 24px;
    }

    .legal-content h2 {
        font-size: 1.35rem;
    }
}
