/* Hapto legal pages — calm, readable companion to the animated home page.
   Static (no scroll-driven gradient): legal text needs to be legible, not poetic.
   Reuses tokens.css fonts/spacing + the brand dusk palette. */

:root {
  --lg-bg: #211b2e;
  --lg-panel: #2a2238;
  --lg-border: #3a3149;
  --lg-strong: #fbf7fd;
  --lg-text: #e7dfee;
  --lg-soft: #b9aecb;
  --lg-faint: #8a7f9c;
  --lg-link: #ff7a93;
  --lg-link-hover: #ff9db0;
}

* { box-sizing: border-box; }
html { background: var(--lg-bg); overflow-x: clip; }
img, svg { max-width: 100%; height: auto; }
a { overflow-wrap: anywhere; }
body {
  margin: 0;
  font-family: var(--font-body, Inter, system-ui, sans-serif);
  font-size: var(--text-base, 16px);
  line-height: 1.7;
  color: var(--lg-text);
  background: radial-gradient(120% 80% at 50% -10%, #2c2340 0%, var(--lg-bg) 60%);
  -webkit-font-smoothing: antialiased;
}

.lg-shell { max-width: 820px; margin: 0 auto; padding: var(--space-7, 48px) var(--space-5, 24px) var(--space-9, 96px); }

/* top bar */
.lg-top { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4, 16px); padding-bottom: var(--space-6, 32px); border-bottom: 1px solid var(--lg-border); flex-wrap: wrap; }
.lg-brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--lg-strong); font-family: var(--font-display, "Space Grotesk", sans-serif); font-weight: 700; font-size: var(--text-xl, 22px); }
.lg-brand img { width: 26px; height: 26px; }
.lg-back { font-family: var(--font-mono, monospace); font-size: var(--text-xs, 12px); color: var(--lg-faint); text-decoration: none; letter-spacing: 0.04em; }
.lg-back:hover { color: var(--lg-soft); }

/* policy rail */
.lg-rail { display: flex; flex-wrap: wrap; gap: 6px; margin: var(--space-6, 32px) 0 var(--space-7, 48px); }
.lg-rail a { font-size: var(--text-sm, 14px); color: var(--lg-soft); text-decoration: none; padding: 6px 12px; border-radius: 999px; border: 1px solid var(--lg-border); white-space: nowrap; transition: color .15s, border-color .15s, background .15s; }
.lg-rail a:hover { color: var(--lg-strong); border-color: var(--lg-link); }
.lg-rail a[aria-current="page"] { color: #fff; background: var(--lg-link); border-color: var(--lg-link); }

/* head */
.lg-eyebrow { font-family: var(--font-mono, monospace); font-size: var(--text-xs, 12px); letter-spacing: 0.12em; text-transform: uppercase; color: var(--lg-faint); }
h1 { font-family: var(--font-display, "Space Grotesk", sans-serif); font-weight: 700; font-size: var(--text-3xl, 44px); line-height: 1.1; color: var(--lg-strong); margin: 8px 0 10px; }
.lg-meta { font-family: var(--font-mono, monospace); font-size: var(--text-xs, 12px); color: var(--lg-faint); }
.lg-intro { font-size: var(--text-lg, 18px); color: var(--lg-soft); margin: 18px 0 0; max-width: 64ch; }

/* prose */
article { max-width: 72ch; }
h2 { font-family: var(--font-display, "Space Grotesk", sans-serif); font-weight: 600; font-size: var(--text-xl, 22px); color: var(--lg-strong); margin: 40px 0 12px; }
h3 { font-weight: 600; font-size: var(--text-base, 16px); color: var(--lg-strong); margin: 22px 0 6px; }
p { margin: 0 0 16px; }
ul { margin: 0 0 16px; padding-left: 22px; display: grid; gap: 8px; }
li { line-height: 1.6; }
strong { color: var(--lg-strong); }
a { color: var(--lg-link); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--lg-link-hover); }
.lg-note { font-size: var(--text-sm, 14px); color: var(--lg-soft); border-top: 1px solid var(--lg-border); padding-top: 18px; margin-top: 28px; }

/* contact cards */
.lg-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 8px 0 28px; }
@media (max-width: 680px) { .lg-cards { grid-template-columns: 1fr; } }
.lg-card { padding: 18px; border-radius: 14px; border: 1px solid var(--lg-border); background: var(--lg-panel); }
.lg-card h3 { margin: 0 0 6px; }
.lg-card p { margin: 0 0 8px; font-size: var(--text-sm, 14px); color: var(--lg-soft); }
.lg-card a { font-family: var(--font-mono, monospace); font-size: var(--text-sm, 14px); }

/* page footer */
.lg-foot { margin-top: var(--space-8, 64px); padding-top: var(--space-5, 24px); border-top: 1px solid var(--lg-border); font-family: var(--font-mono, monospace); font-size: var(--text-xs, 12px); color: var(--lg-faint); display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.lg-foot a { color: var(--lg-faint); }
.lg-foot a:hover { color: var(--lg-soft); }
