/* ── Legal page overrides ───────────────────────────────────── */

/* Sidebar TOC nav */
.legal-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 64px;
    padding-top: 80px;
    padding-bottom: 120px;
}

@media (min-width: 1024px) {
    .legal-layout {
        grid-template-columns: 220px 1fr;
        gap: 80px;
        align-items: start;
    }
}

/* sticky sidebar */
.legal-toc {
    position: static;
}

@media (min-width: 1024px) {
    .legal-toc {
        position: sticky;
        top: 88px;
    }
}

.legal-toc-title {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--ash);
    margin-bottom: 20px;
}

.legal-toc-links {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.legal-toc-links a {
    font-size: 13px;
    color: var(--ash);
    padding: 6px 0;
    border-left: 2px solid var(--hair);
    padding-left: 14px;
    transition: color 0.2s, border-color 0.2s;
    line-height: 1.4;
}

.legal-toc-links a:hover,
.legal-toc-links a.active {
    color: var(--ink);
    border-left-color: var(--clay);
}

/* Effective date badge */
.legal-meta {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 64px;
    padding-bottom: 32px;
    border-bottom: 1px solid var(--hair);
}

.legal-meta-date {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ash);
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

.legal-meta-badge {
    font-family: var(--font-mono);
    font-size: 9.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--clay);
    padding: 3px 8px;
    border: 1px solid rgba(181, 137, 99, 0.35);
    border-radius: 2px;
}

/* Document sections */
.legal-doc {
    margin-bottom: 96px;
    padding-bottom: 64px;
    border-bottom: 1px solid var(--hair);
}

.legal-doc:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

.legal-doc-header {
    margin-bottom: 40px;
}

.legal-doc-eyebrow {
    font-family: var(--font-mono);
    font-size: 9.5px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--clay);
    margin-bottom: 16px;
}

.legal-doc-title {
    font-family: var(--font-serif);
    font-size: clamp(26px, 3vw, 38px);
    line-height: 1.05;
    letter-spacing: -0.01em;
}

.legal-doc-lead {
    margin-top: 20px;
    font-size: 15px;
    line-height: 1.65;
    color: var(--ink-2);
    max-width: 66ch;
}

/* Clause blocks */
.legal-clause {
    margin-bottom: 40px;
}

.legal-clause-num {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ash);
    margin-bottom: 8px;
}

.legal-clause-title {
    font-family: var(--font-serif);
    font-size: 20px;
    line-height: 1.1;
    margin-bottom: 14px;
}

.legal-clause p {
    font-size: 14px;
    line-height: 1.75;
    color: var(--ink-2);
    margin-bottom: 12px;
    max-width: 72ch;
}

.legal-clause p:last-child {
    margin-bottom: 0;
}

.legal-clause ul {
    list-style: none;
    padding-left: 0;
    margin-top: 10px;
    margin-bottom: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.legal-clause ul li {
    font-size: 14px;
    line-height: 1.7;
    color: var(--ink-2);
    padding-left: 20px;
    position: relative;
    max-width: 70ch;
}

.legal-clause ul li::before {
    content: "—";
    position: absolute;
    left: 0;
    color: var(--ash);
    font-size: 11px;
    top: 3px;
}

/* Divider within doc */
.legal-divider {
    border: none;
    border-top: 1px solid var(--hair);
    margin: 40px 0;
}

/* Contact box */
.legal-contact-box {
    background: var(--hair-2);
    border: 1px solid var(--hair);
    border-radius: 4px;
    padding: 28px 32px;
    margin-top: 32px;
    max-width: 60ch;
}

.legal-contact-box-title {
    font-family: var(--font-serif);
    font-size: 17px;
    margin-bottom: 10px;
}

.legal-contact-box p {
    font-size: 13px;
    line-height: 1.65;
    color: var(--ink-2);
}

.legal-contact-box a {
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-color: var(--hair);
    transition: text-decoration-color 0.2s;
}

.legal-contact-box a:hover {
    text-decoration-color: var(--ink);
}

/* Hero for legal */
.legal-hero {
    border-bottom: 1px solid var(--hair);
    padding-top: 64px;
    padding-bottom: 48px;
}

@media (min-width: 768px) {
    .legal-hero {
        padding-top: 96px;
        padding-bottom: 64px;
    }
}

.legal-hero-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--ash);
    margin-bottom: 40px;
    transition: color 0.2s;
}

.legal-hero-back:hover {
    color: var(--ink);
}

.legal-hero-back svg {
    display: inline;
    width: 14px;
    height: 14px;
}

.legal-hero h1 {
    font-family: var(--font-serif);
    font-size: clamp(34px, 4vw, 54px);
    line-height: 1.02;
    letter-spacing: -0.012em;
    max-width: 20ch;
}

.legal-hero-sub {
    margin-top: 20px;
    font-size: 14px;
    line-height: 1.65;
    color: var(--ash);
    max-width: 60ch;
}