/* Legal page styles — shared by the Legal Page template (privacy, terms, security). */
/* Sourced from the approved designref legal mockups. */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root { --black:#000; --near-black:#111; --mid:#555; --subtle:#888; --border:#e2e2e2; --surface:#f7f7f7; --white:#fff; --font:Helvetica,'Helvetica Neue',Arial,sans-serif; }
html { scroll-behavior: smooth; }
body { font-family: var(--font); background: var(--white); color: var(--near-black); line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 200; height: 60px; background: rgba(255,255,255,0.94); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); display: flex; align-items: center; }
.nav-inner { display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: 1160px; margin: 0 auto; padding: 0 40px; }
.nav-brand { display: flex; align-items: center; gap: 10px; }
.nav-logo { width: auto; height: 15px; object-fit: contain; }
.nav-brand-name { font-size: 15px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--black); }
.back-link { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 500; color: var(--mid); padding: 8px 16px; border: 1px solid var(--border); border-radius: 6px; transition: border-color 0.15s; }
.back-link:hover { border-color: #999; color: var(--black); }
.page-wrap { max-width: 720px; margin: 0 auto; padding: 100px 40px 80px; }
.page-label { font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--subtle); margin-bottom: 14px; display: block; }
h1 { font-size: 38px; font-weight: 700; letter-spacing: -0.022em; line-height: 1.1; color: var(--black); margin-bottom: 10px; }
.last-updated { font-size: 12.5px; color: var(--subtle); margin-bottom: 48px; padding-bottom: 24px; border-bottom: 1px solid var(--border); }
h2 { font-size: 18px; font-weight: 700; color: var(--black); margin-top: 40px; margin-bottom: 12px; letter-spacing: -0.01em; }
p { font-size: 14.5px; line-height: 1.75; color: var(--mid); margin-bottom: 14px; }
ul { margin: 12px 0 16px 0; padding-left: 0; list-style: none; }
ul li { font-size: 14.5px; color: var(--mid); line-height: 1.7; padding: 6px 0 6px 20px; position: relative; border-bottom: 1px solid var(--border); }
ul li:last-child { border-bottom: none; }
ul li::before { content: '—'; position: absolute; left: 0; color: var(--border); font-weight: 600; }
.security-pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; margin: 36px 0; }
.sec-pillar { background: var(--white); padding: 28px 24px; }
.sec-pillar-icon { font-size: 22px; color: var(--near-black); margin-bottom: 14px; display: block; }
.sec-pillar-title { font-size: 14px; font-weight: 700; color: var(--black); margin-bottom: 8px; }
.sec-pillar-text { font-size: 13px; line-height: 1.65; color: var(--mid); }
.contact-box { margin-top: 40px; padding: 24px 28px; border: 1px solid var(--border); border-radius: 8px; background: var(--surface); }
.contact-box p { margin-bottom: 6px; }
.contact-box a { color: var(--black); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.footer-note { display: block; margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--border); font-size: 12px; color: var(--subtle); }
@media (max-width: 600px) { .security-pillars { grid-template-columns: 1fr; } .page-wrap { padding: 90px 20px 60px; } }
