/* Shared layout and typography for Terms of Service, Privacy Policy, and other legal pages.
   Use: <body class="legal-page"> */

html {
    scroll-behavior: smooth;
}

body.legal-page {
    --legal-bg: #000000;
    --legal-border: rgba(255, 255, 255, 0.1);
    --legal-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    margin: 0;
    background: var(--legal-bg);
    color: #ffffff;
    font-family: 'Outfit', sans-serif;
    line-height: 1.8;
    overflow-x: hidden;
}

body.legal-page * {
    box-sizing: border-box;
}

/* Navigation */
body.legal-page .site-header--sticky {
    padding: 20px 24px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    border-bottom: 1px solid var(--legal-border);
    position: sticky;
    top: 0;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(12px);
    z-index: 1000;
}

@media (min-width: 768px) {
    body.legal-page .site-header--sticky {
        padding: 24px 40px;
    }
}

body.legal-page .site-header__links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 18px;
    justify-content: flex-end;
}

body.legal-page .site-header__links a {
    text-decoration: none;
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: var(--legal-transition);
}

body.legal-page .site-header__links a:hover {
    opacity: 0.88;
}

body.legal-page .site-header__links .nav-link-key {
    border: 1px solid #ffffff;
    padding: 7px 12px;
    border-radius: 4px;
    color: #ffffff !important;
}

body.legal-page .site-header__links .nav-link-key:hover {
    background: #ffffff;
    color: #000000 !important;
}

body.legal-page .logo {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: white;
    font-weight: 800;
    font-size: 20px;
    letter-spacing: 2px;
}

body.legal-page .logo img {
    height: 28px;
    width: auto;
}

body.legal-page .container {
    max-width: 900px;
    margin: 80px auto;
    padding: 0 40px;
    animation: legal-fade-in 0.8s ease-out;
}

@keyframes legal-fade-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

body.legal-page .last-updated {
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    color: #ffffff;
    margin-bottom: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

body.legal-page h1.legal-doc-title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin: 0 0 12px;
    line-height: 1.2;
    color: #ffffff;
}

body.legal-page .legal-doc-nav {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 28px;
    line-height: 1.6;
}

body.legal-page .legal-doc-nav a {
    color: #ffffff;
    text-decoration: none;
    font-weight: 700;
    border-bottom: 1px solid rgba(255, 255, 255, 0.35);
    transition: var(--legal-transition);
}

body.legal-page .legal-doc-nav a:hover {
    border-bottom-color: #ffffff;
}

body.legal-page .legal-doc-nav .legal-doc-nav__sep {
    margin: 0 10px;
    opacity: 0.45;
    font-weight: 400;
}

body.legal-page .legal-doc-nav .legal-doc-nav__current {
    opacity: 0.72;
    font-weight: 700;
    border-bottom: none;
    pointer-events: none;
}

body.legal-page h2 {
    font-size: 1.35rem;
    margin: 56px 0 20px;
    color: #ffffff;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-left: 3px solid #ffffff;
    padding-left: 20px;
}

body.legal-page #main-content h2:first-of-type {
    margin-top: 40px;
}

body.legal-page .legal-intro {
    font-size: 17px;
    line-height: 1.85;
    margin-bottom: 8px;
    max-width: 52rem;
    color: #ffffff;
}

body.legal-page h3.legal-subhead {
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #ffffff;
    margin: 28px 0 12px;
}

body.legal-page section.legal-section {
    margin-bottom: 8px;
}

body.legal-page section.legal-section p.sub-p {
    margin-top: -8px;
    margin-bottom: 20px;
}

body.legal-page p {
    color: #ffffff;
    margin-bottom: 20px;
    font-size: 16px;
}

body.legal-page .legal-list {
    list-style: none;
    margin: 0 0 24px;
    padding: 0;
}

body.legal-page .legal-list li {
    color: #ffffff;
    padding-left: 28px;
    position: relative;
    margin-bottom: 14px;
    line-height: 1.65;
}

body.legal-page .legal-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.65em;
    width: 6px;
    height: 1px;
    background: #ffffff;
    opacity: 0.9;
}

body.legal-page .legal-divider {
    height: 1px;
    background: var(--legal-border);
    margin: 16px 0 36px;
    max-width: 120px;
}

body.legal-page .legal-contact-link {
    color: #ffffff;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

body.legal-page .legal-contact-link:hover {
    border-bottom-color: #ffffff;
}

body.legal-page .site-footer {
    margin-top: 120px;
    border-top: 1px solid var(--legal-border);
    padding: 80px 40px 40px;
    text-align: center;
}

body.legal-page .footer-bottom {
    font-size: 14px;
    color: #ffffff;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 16px;
    text-align: center;
}

body.legal-page .footer-bottom a {
    color: #ffffff;
    text-decoration: none;
    font-weight: 700;
    transition: var(--legal-transition);
}

body.legal-page .footer-bottom a:hover {
    text-decoration: underline;
}

@media (max-width: 480px) {
    body.legal-page .container {
        padding: 0 24px;
        margin: 56px auto;
    }

    body.legal-page .legal-doc-nav .legal-doc-nav__sep {
        display: inline-block;
        margin: 4px 6px;
    }
}
