/* Shared styling for legal pages: terms, privacy, data-protection, cookies */
:root {
    --brand-red: #7c1823;
    --brand-red-dark: #5a111a;
    --brand-gold: #d4af37;
    --brand-ink: #0f172a;
    --brand-slate: #475569;
    --brand-mist: #f8fafc;
    --brand-border: #e2e8f0;
}
* { box-sizing: border-box; }
body {
    font-family: 'Manrope', 'Helvetica Neue', Arial, sans-serif;
    color: var(--brand-ink);
    background: var(--brand-mist);
    margin: 0;
    line-height: 1.65;
}
header.topbar {
    background: #fff;
    border-bottom: 1px solid var(--brand-border);
    padding: 18px 28px;
    display: flex;
    align-items: center;
    gap: 14px;
}
header.topbar img { width: 52px; height: 52px; object-fit: contain; flex-shrink: 0; }
header.topbar .brand-name {
    font-family: 'Outfit', sans-serif;
    font-weight: 800;
    color: var(--brand-red);
    font-size: 16px;
    line-height: 1.15;
}
header.topbar .brand-sub {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.26em;
    text-transform: uppercase;
    color: var(--brand-slate);
    margin-top: 2px;
}
header.topbar .back {
    margin-left: auto;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--brand-slate);
    padding: 8px 14px;
    border: 1px solid var(--brand-border);
}
header.topbar .back:hover { color: var(--brand-red); border-color: var(--brand-red); }

main {
    max-width: 760px;
    margin: 56px auto;
    padding: 48px 40px;
    background: #fff;
    border: 1px solid var(--brand-border);
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}
main .eyebrow {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--brand-red);
    font-weight: 700;
    margin: 0 0 10px;
}
main h1 {
    font-family: 'Outfit', sans-serif;
    font-weight: 900;
    font-size: 2.4em;
    letter-spacing: -0.01em;
    margin: 0 0 8px;
    color: var(--brand-ink);
}
main .effective {
    color: var(--brand-slate);
    font-size: 14px;
    margin: 0 0 36px;
}
main h2 {
    font-family: 'Outfit', sans-serif;
    font-weight: 800;
    font-size: 1.25em;
    margin: 36px 0 10px;
    color: var(--brand-ink);
    border-top: 3px solid var(--brand-gold);
    padding-top: 20px;
}
main h2:first-of-type { border-top: none; padding-top: 0; margin-top: 0; }
main h3 {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.05em;
    margin: 24px 0 6px;
    color: var(--brand-ink);
}
main p, main li { font-size: 15px; color: #334155; }
main ul, main ol { padding-left: 22px; }
main ul li, main ol li { margin: 6px 0; }
main a { color: var(--brand-red); }
main a:hover { color: var(--brand-red-dark); }
main table {
    width: 100%;
    border-collapse: collapse;
    margin: 14px 0;
    font-size: 14px;
}
main table th, main table td {
    text-align: left;
    padding: 10px 12px;
    border-bottom: 1px solid var(--brand-border);
    vertical-align: top;
}
main table th {
    background: var(--brand-mist);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--brand-slate);
    font-weight: 600;
}

footer.bottombar {
    text-align: center;
    padding: 24px;
    color: var(--brand-slate);
    font-size: 13px;
    border-top: 1px solid var(--brand-border);
}
footer.bottombar a { color: var(--brand-slate); text-decoration: none; margin: 0 8px; }
footer.bottombar a:hover { color: var(--brand-red); }

@media (max-width: 640px) {
    main { margin: 20px; padding: 28px 22px; }
    main h1 { font-size: 1.8em; }
    header.topbar .back { display: none; }
}
