/* ============================================================
   Atlas legal page — page-specific styles.
   Loaded by templates/index.html only.

   Externalized from the inline <style> block on 2026-05-04.
   Selectors and rules are unchanged from the original; markup
   still references the same class names, so visual output is
   identical pre-externalization.

   Subsequent migration passes (logged in memory/TODO.md) move
   legacy classes here to the shared .f-* / .fm-* foundation
   in components.css / marketing.css and delete duplicates.
   ============================================================ */
:root {
            --accent: #00b0f1;
            --accent-hover: #009ad3;
            --bg: #ffffff;
            --bg-tint: #f4f6f9;
            --bg-soft: #fafafa;
            --bg-hover: #ebecef;
            --border-light: #eef0f3;
            --border: #e5e7eb;
            --border-strong: #d4d4d8;
            --text: #111827;
            --text-2: #525866;
            --text-3: #374151;
            --text-muted: #9ca3af;
            --red: #dc2626;
            --red-bg: #fee2e2;

            --header-bg: rgba(255, 255, 255, 0.78);
            --card-bg: #ffffff;
            --tab-active-bg: #ffffff;
            --search-focus-bg: #ffffff;
            --footer-bg: #ffffff;
            --mobile-nav-bg: rgba(255, 255, 255, 0.98);
            --overlay: rgba(0, 0, 0, 0.45);
            --title-grad: linear-gradient(180deg, #4b4b4b 0%, #000000 100%);
            --back-bg: linear-gradient(180deg, #1a1a1a 0%, #050505 100%);
            --back-bg-hover: linear-gradient(180deg, #2a2a2a 0%, #0a0a0a 100%);
            --back-color: #ffffff;
        }

        body.dark {
            --bg: #000000;
            --bg-tint: #0a0a0a;
            --bg-soft: #141414;
            --bg-hover: #1f1f1f;
            --border-light: #1f1f1f;
            --border: #2a2a2a;
            --border-strong: #3a3a3a;
            --text: #f4f4f5;
            --text-2: #a1a1aa;
            --text-3: #d4d4d8;
            --text-muted: #71717a;

            --header-bg: rgba(15, 15, 15, 0.72);
            --card-bg: #101010;
            --tab-active-bg: #1a1a1a;
            --search-focus-bg: #1a1a1a;
            --footer-bg: #0a0a0a;
            --mobile-nav-bg: rgba(10, 10, 10, 0.96);
            --overlay: rgba(0, 0, 0, 0.6);
            --title-grad: linear-gradient(180deg, #d4dae3 0%, #ffffff 100%);
            --back-bg: #ffffff;
            --back-bg-hover: #f0f0f0;
            --back-color: #000000;
        }

        mark { background: rgba(0, 176, 241, 0.22); color: inherit; border-radius: 2px; padding: 0 1px; }



        /* App shell */
        .legal-shell {
            display: flex;
            flex-direction: column;
            min-height: 100dvh;
        }

        /* Floating header pill (matches index) */
        .legal-header {
            position: sticky;
            top: 0;
            z-index: 50;
            padding: 0.55rem 1rem;
            pointer-events: none;
            background: transparent;
        }
        .legal-header-inner {
            pointer-events: auto;
            position: relative;
            max-width: 1560px;
            margin: 0 auto;
            padding: 0 0.7rem 0 1.25rem;
            height: 64px;
            display: flex;
            align-items: center;
            gap: 1rem;
            border-radius: 1.4rem;
            background: var(--header-bg);
            border: 1px solid var(--border-light);
            backdrop-filter: blur(8px) saturate(140%);
            -webkit-backdrop-filter: blur(8px) saturate(140%);
            font-family: "Mona Sans", Inter, system-ui, sans-serif;
        }
        .legal-logo {
            display: inline-flex;
            align-items: center;
            gap: 0.6rem;
            flex-shrink: 0;
        }
        .legal-logo-icon { height: 32px; width: 32px; }
        .legal-logo-text {
            font-family: "Druk Wide", "Mona Sans", Inter, sans-serif;
            font-size: 1rem;
            font-weight: 700;
            color: var(--text);
            text-transform: uppercase;
        }
        .legal-logo-divider {
            width: 1px;
            height: 22px;
            background: var(--border);
            margin-left: 0.25rem;
        }
        .legal-logo-tag {
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-2);
            letter-spacing: -0.01em;
        }
        .legal-search {
            flex: 1;
            max-width: 540px;
            margin: 0 auto;
            position: relative;
        }
        .legal-search svg {
            position: absolute;
            left: 14px;
            top: 50%;
            transform: translateY(-50%);
            width: 16px;
            height: 16px;
            color: var(--text-muted);
            pointer-events: none;
        }
        .legal-search input {
            width: 100%;
            padding: 0.6rem 1rem 0.6rem 2.5rem;
            background: var(--bg-soft);
            border: 1px solid var(--border-light);
            border-radius: 999px;
            font-family: Inter, sans-serif;
            font-size: 0.9rem;
            color: var(--text);
            transition: background 0.18s, border-color 0.18s;
            outline: none;
        }
        .legal-search input::placeholder { color: var(--text-muted); }
        .legal-search input:focus {
            background: var(--search-focus-bg);
            border-color: var(--accent);
        }
        .legal-back {
            display: inline-flex;
            align-items: center;
            gap: 0.4rem;
            background: var(--back-bg);
            color: var(--back-color);
            font-size: 0.85rem;
            font-weight: 600;
            padding: 0.55rem 1rem;
            border-radius: 0.85rem;
            transition: background 0.2s;
            flex-shrink: 0;
        }
        .legal-back:hover { background: var(--back-bg-hover); }

        .legal-theme-toggle {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 38px;
            height: 38px;
            border-radius: 0.75rem;
            background: var(--bg-soft);
            border: 1px solid var(--border-light);
            color: var(--text-2);
            transition: background 0.18s, color 0.18s, border-color 0.18s;
            flex-shrink: 0;
        }
        .legal-theme-toggle:hover {
            background: var(--bg-hover);
            color: var(--text);
        }
        .legal-theme-toggle svg { width: 18px; height: 18px; }
        .legal-theme-toggle .icon-moon { display: inline; }
        .legal-theme-toggle .icon-sun { display: none; }
        body.dark .legal-theme-toggle .icon-moon { display: none; }
        body.dark .legal-theme-toggle .icon-sun { display: inline; }

        .legal-nav-toggle {
            display: none;
            flex-direction: column;
            justify-content: center;
            gap: 4px;
            width: 38px;
            height: 38px;
            padding: 0 9px;
            border-radius: 9999px;
            background: var(--bg-soft);
            border: 1px solid var(--border-light);
            transition: background 0.2s;
            flex-shrink: 0;
        }
        .legal-nav-toggle:hover { background: var(--bg-hover); }
        .legal-nav-toggle span {
            display: block;
            width: 18px;
            height: 2px;
            background: var(--text);
            border-radius: 2px;
        }
        @media (max-width: 900px) {
            .legal-nav-toggle { display: inline-flex; }
            .legal-search { display: none; }
            .legal-logo-divider, .legal-logo-tag { display: none; }
        }

        /* Tab strip */
        .legal-tabs {
            max-width: 1560px;
            margin: 0.5rem auto 0;
            padding: 0 1.5rem;
            display: flex;
            gap: 0.25rem;
            overflow-x: auto;
            -ms-overflow-style: none;
            scrollbar-width: none;
        }
        .legal-tabs::-webkit-scrollbar { display: none; }
        .legal-tab {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.84rem;
            font-weight: 600;
            color: var(--text-2);
            padding: 0.55rem 0.95rem;
            border-radius: 999px;
            transition: background 0.18s, color 0.18s;
            white-space: nowrap;
            display: inline-flex;
            align-items: center;
            gap: 0.4rem;
        }
        .legal-tab:hover { color: var(--text); background: var(--bg-soft); }
        .legal-tab.is-active {
            background: var(--tab-active-bg);
            color: var(--text);
            border: 1px solid var(--border-light);
            box-shadow: 0 2px 8px -4px rgba(0, 0, 0, 0.18);
        }
        .legal-tab svg { width: 14px; height: 14px; }

        /* Body grid */
        .legal-body {
            max-width: 1560px;
            margin: 1.5rem auto 0;
            padding: 0 1.5rem 4rem;
            display: grid;
            grid-template-columns: 240px minmax(0, 1fr) 220px;
            grid-template-areas: "sidebar main toc";
            gap: 2.5rem;
            align-items: flex-start;
        }
        .legal-sidebar { grid-area: sidebar; }
        .legal-main { grid-area: main; }
        .legal-toc { grid-area: toc; }
        @media (max-width: 1200px) {
            .legal-body {
                grid-template-columns: 240px minmax(0, 1fr);
                grid-template-areas: "sidebar main";
                gap: 2rem;
            }
            .legal-toc { display: none; }
        }
        @media (max-width: 900px) {
            .legal-body {
                grid-template-columns: minmax(0, 1fr);
                grid-template-areas: "main";
                padding: 0 1rem 3rem;
                margin-top: 1rem;
            }
        }

        /* Sidebar */
        .legal-sidebar {
            position: sticky;
            top: 88px;
            max-height: calc(100dvh - 100px);
            overflow-y: auto;
            padding: 0.5rem 0.25rem 0.5rem 0;
        }
        .legal-sidebar::-webkit-scrollbar { width: 4px; }
        .legal-sidebar::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 4px; }
        .legal-sidebar-section { display: none; }
        .legal-sidebar-section.is-active { display: block; }
        .legal-sidebar-heading {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.66rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-muted);
            padding: 0.6rem 0.85rem 0.4rem;
        }
        .legal-sidebar-link {
            display: block;
            padding: 0.5rem 0.85rem;
            border-radius: 0.6rem;
            font-size: 0.86rem;
            color: var(--text-2);
            transition: background 0.15s, color 0.15s;
            margin-bottom: 1px;
        }
        .legal-sidebar-link:hover {
            background: var(--bg-soft);
            color: var(--text);
        }
        .legal-sidebar-link.is-active {
            background: rgba(0, 176, 241, 0.10);
            color: var(--accent);
            font-weight: 600;
        }
        @media (max-width: 900px) {
            .legal-sidebar {
                position: fixed;
                inset: 64px 0 0 0;
                top: 64px;
                background: var(--mobile-nav-bg);
                backdrop-filter: blur(20px);
                -webkit-backdrop-filter: blur(20px);
                z-index: 49;
                max-height: calc(100dvh - 64px);
                padding: 1rem 1.25rem 2rem;
                opacity: 0;
                visibility: hidden;
                transform: translateY(-8px);
                transition: opacity 0.2s, transform 0.2s, visibility 0s linear 0.2s;
            }
            body.legal-nav-open .legal-sidebar {
                opacity: 1;
                visibility: visible;
                transform: translateY(0);
                transition: opacity 0.2s, transform 0.2s, visibility 0s;
            }
            body.legal-nav-open { overflow: hidden; }
        }

        /* Main content */
        .legal-main {
            min-width: 0;
            background: var(--card-bg);
            border: 1px solid var(--border-light);
            border-radius: 22px;
            padding: 2.25rem 2.5rem 2.5rem;
            box-shadow: 0 4px 20px -10px rgba(0, 0, 0, 0.10);
        }
        @media (max-width: 768px) {
            .legal-main { padding: 1.75rem 1.4rem 2rem; border-radius: 18px; }
        }

        /* Eyebrow (matches index style) */
        .eyebrow {
            display: inline-flex;
            align-items: center;
            gap: 0.55rem;
            padding: 0.16rem 0.7rem;
            border-radius: 0.5rem;
            background: linear-gradient(204deg,
                rgb(41, 41, 41) 3%,
                rgb(102, 102, 102) 51.5948%,
                rgb(41, 41, 41) 100%);
            color: #fff;
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 14px;
            font-weight: 600;
            letter-spacing: 0.005em;
        }
        .eyebrow::before, .eyebrow::after {
            content: '';
            display: inline-block;
            width: 10px;
            height: 10px;
            border-radius: 50%;
            border: 1px solid rgb(161, 161, 161);
            background:
                radial-gradient(circle at center, rgb(102, 102, 102) 0 2px, transparent 2.4px),
                rgb(201, 201, 201);
            flex-shrink: 0;
        }

        /* Page header */
        .content-header {
            margin-bottom: 2.25rem;
            padding-bottom: 1.5rem;
            border-bottom: 1px solid var(--border-light);
        }
        .content-section-label { display: inline-flex; margin-bottom: 0.65rem; }
        .content-header h1 {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: clamp(1.85rem, 3.4vw, 2.6rem);
            font-weight: 800;
            letter-spacing: -0.03em;
            line-height: 1.08;
            margin: 0.4rem 0 0.85rem;
            background: var(--title-grad);
            -webkit-background-clip: text;
            background-clip: text;
            -webkit-text-fill-color: transparent;
            color: transparent;
        }
        .content-date-badge {
            display: inline-flex;
            align-items: center;
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.72rem;
            font-weight: 700;
            color: var(--accent);
            background: rgba(0, 176, 241, 0.10);
            padding: 4px 10px;
            border-radius: 6px;
            text-transform: uppercase;
            letter-spacing: 0.04em;
        }
        .header-sub {
            margin-top: 0.5rem;
            font-size: 0.95rem;
            color: var(--text-2);
        }

        /* Content sections */
        .content-section {
            margin-bottom: 2rem;
            padding-bottom: 2rem;
            border-bottom: 1px solid var(--border-light);
        }
        .content-section:last-of-type { border-bottom: 0; }
        .content-section h2 {
            font-family: Inter, sans-serif;
            font-size: 1.35rem;
            font-weight: 600;
            color: var(--text);
            letter-spacing: -0.02em;
            line-height: 1.25;
            margin-bottom: 1rem;
            scroll-margin-top: 96px;
        }
        .content-section h3 {
            font-family: Inter, sans-serif;
            font-size: 1.02rem;
            font-weight: 600;
            color: var(--text);
            letter-spacing: -0.01em;
            margin: 1.25rem 0 0.6rem;
        }
        .content-section p {
            font-size: 0.96rem;
            color: var(--text-2);
            line-height: 1.7;
            margin-bottom: 0.75rem;
        }
        .content-section strong { color: var(--text); font-weight: 600; }
        .content-section ul, .content-section ol {
            margin: 0.5rem 0 0.75rem 1.4rem;
            color: var(--text-2);
            font-size: 0.96rem;
            line-height: 1.7;
        }
        .content-section ul { list-style: disc; }
        .content-section ol { list-style: decimal; }
        .content-section li { margin-bottom: 0.25rem; }
        .content-section ul ul, .content-section ol ol { margin-top: 0.25rem; margin-bottom: 0.25rem; }
        .content-section a { color: var(--accent); transition: color 0.15s; }
        .content-section a:hover { color: var(--accent-hover); text-decoration: underline; }

        /* Highlight callout */
        .highlight {
            border-left: 3px solid var(--accent);
            background: rgba(0, 176, 241, 0.05);
            padding: 0.85rem 1rem;
            margin: 1rem 0;
            border-radius: 0 8px 8px 0;
        }
        .highlight strong { color: var(--text); font-weight: 700; }
        .highlight p { margin-top: 0.5rem; margin-bottom: 0; }

        /* Need help box */
        .need-help-box {
            margin-top: 2rem;
            padding: 1.6rem 1.25rem;
            text-align: center;
            background: var(--bg-tint);
            border-radius: 14px;
            border: 1px solid var(--border-light);
        }
        .need-help-box h3 {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 1.05rem;
            font-weight: 700;
            color: var(--text);
            margin-bottom: 0.4rem;
        }
        .need-help-box p { color: var(--text-2); font-size: 0.9rem; margin: 0.15rem 0; }
        .need-help-box a { color: var(--accent); }
        .need-help-box a:hover { color: var(--accent-hover); }
        .fine-print {
            margin-top: 0.75rem;
            font-size: 0.78rem;
            color: var(--text-muted);
        }

        /* Page nav (prev/next) */
        .page-nav {
            display: flex;
            justify-content: space-between;
            gap: 1rem;
            margin-top: 2.5rem;
            padding-top: 1.5rem;
            border-top: 1px solid var(--border-light);
        }
        .page-nav-link {
            display: flex;
            flex-direction: column;
            gap: 0.2rem;
            padding: 0.85rem 1.1rem;
            background: var(--bg-tint);
            border: 1px solid var(--border-light);
            border-radius: 12px;
            transition: background 0.18s, border-color 0.18s;
            min-width: 0;
            max-width: 48%;
            flex: 1 1 auto;
        }
        .page-nav-link:hover {
            background: var(--card-bg);
            border-color: var(--border);
        }
        .page-nav-link--next { text-align: right; align-items: flex-end; }
        .page-nav-label {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.7rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-muted);
        }
        .page-nav-title {
            font-size: 0.92rem;
            font-weight: 600;
            color: var(--accent);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 100%;
        }
        .page-nav-link:hover .page-nav-title { color: var(--accent-hover); }
        @media (max-width: 640px) {
            .page-nav { flex-direction: column; }
            .page-nav-link { max-width: 100%; }
            .page-nav-link--next { text-align: left; align-items: flex-start; }
        }

        /* TOC */
        .legal-toc {
            position: sticky;
            top: 88px;
            max-height: calc(100dvh - 100px);
            overflow-y: auto;
            padding: 0.25rem 0;
        }
        .legal-toc::-webkit-scrollbar { width: 3px; }
        .legal-toc::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 3px; }
        .legal-toc-heading {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.66rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-muted);
            margin-bottom: 0.6rem;
        }
        .legal-toc ul {
            list-style: none;
            border-left: 1px solid var(--border);
            padding: 0;
            margin: 0;
        }
        .legal-toc li { margin: 0; }
        .legal-toc a {
            display: block;
            padding: 0.35rem 0 0.35rem 0.85rem;
            font-size: 0.78rem;
            color: var(--text-muted);
            border-left: 2px solid transparent;
            margin-left: -1px;
            transition: color 0.15s, border-color 0.15s;
        }
        .legal-toc a:hover { color: var(--text-2); }
        .legal-toc a.is-active {
            color: var(--accent);
            border-left-color: var(--accent);
        }
        .legal-toc.is-empty { display: none; }

        /* Mobile nav backdrop */
        .legal-mobile-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: var(--overlay);
            z-index: 48;
        }
        body.legal-nav-open .legal-mobile-overlay { display: block; }
        @media (min-width: 901px) {
            .legal-mobile-overlay { display: none !important; }
        }

        /* Page visibility */
        [data-page] { display: none; }
        [data-page].is-active { display: block; }

        /* Search states */
        .search-hidden { display: none !important; }
        .legal-no-results {
            display: none;
            text-align: center;
            padding: 4rem 1rem;
            color: var(--text-muted);
        }
        .legal-no-results.is-active { display: block; }
        .legal-no-results svg {
            width: 44px; height: 44px;
            margin: 0 auto 1rem;
            opacity: 0.4;
        }

        /* Footer (mirrors index page) */
        .footer { background: var(--footer-bg); margin-top: auto; }
        .footer-inner {
            max-width: 1110px;
            margin: 0 auto;
            padding: 3.5rem 1.5rem;
        }
        @media (min-width: 768px) { .footer-inner { padding: 4rem 2rem; } }
        .footer-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 2.5rem;
        }
        @media (min-width: 768px) {
            .footer-grid { grid-template-columns: repeat(5, 1fr); gap: 2rem; }
        }
        .footer-brand { grid-column: span 2; }
        .footer-logo { display: inline-flex; align-items: center; gap: 0.5rem; }
        .footer-logo-icon { height: 26px; width: 26px; }
        .footer-logo-text {
            font-family: "Druk Wide", "Mona Sans", Inter, system-ui, sans-serif;
            font-size: 0.85rem;
            font-weight: 700;
            color: var(--text);
            letter-spacing: 0;
            text-transform: uppercase;
        }
        .footer-brand p {
            margin-top: 1rem;
            font-size: 0.875rem;
            color: var(--text-2);
            line-height: 1.6;
            max-width: 320px;
        }
        .footer-cta {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            margin-top: 1.25rem;
            background: linear-gradient(180deg, #1a1a1a 0%, #050505 100%);
            color: #fff;
            font-family: "Mona Sans", Inter, system-ui, sans-serif;
            font-size: 0.92rem;
            font-weight: 600;
            padding: 0.72rem 1.35rem;
            border-radius: 0.75rem;
            transition: background 0.2s;
        }
        .footer-cta:hover {
            background: linear-gradient(180deg, #2a2a2a 0%, #0a0a0a 100%);
        }
        .footer-cta svg {
            width: 16px;
            height: 16px;
            flex-shrink: 0;
            transition: transform 0.25s ease;
        }
        .footer-cta:hover svg { transform: translate(2px, -2px); }
        body.dark .footer-cta {
            background: #ffffff;
            color: #000000;
        }
        body.dark .footer-cta:hover {
            background: #f0f0f0;
        }
        .footer-col { display: flex; flex-direction: column; gap: 0.625rem; }
        .footer-col h4 {
            font-family: Inter, system-ui, sans-serif;
            font-size: 1rem;
            font-weight: 600;
            letter-spacing: -0.005em;
            color: var(--text);
            margin-bottom: 0.5rem;
        }
        .footer-col a { font-size: 0.875rem; color: var(--text-2); transition: color 0.2s; }
        .footer-col a:hover { color: var(--text); }
        .footer-bottom {
            margin-top: 3rem;
            padding-top: 1.5rem;
            border-top: 1px solid var(--border-light);
            display: flex; flex-direction: column; gap: 0.75rem;
            font-size: 0.75rem; color: var(--text-muted);
        }
        @media (min-width: 768px) {
            .footer-bottom {
                flex-direction: row;
                justify-content: space-between;
                align-items: center;
            }
        }
