/* Legal layout — privacy / terms / 404. Reading register, not marketing
   chrome. Inherits tokens + themes from luna/colors_and_type.css. */

*, *::before, *::after { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--backgroundPage);
  color: var(--textPrimary);
  font-family: var(--font-serif);
  transition: background var(--motion-medium) var(--ease-standard), color var(--motion-medium) var(--ease-standard);
}
::selection { background: color-mix(in srgb, var(--accent) 38%, var(--backgroundPage)); color: var(--textPrimary); }

/* Same frame as the brochure so the wordmark/toggle don't jump when
   navigating between pages; only the text column narrows. */
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 28px; }

/* ---- Calm header: wordmark + back-to-home only ---- */
header.legal-nav { border-bottom: var(--hairline) solid var(--border); }
.nav-inner { height: 70px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.brand .name { font-family: var(--font-sans); font-weight: 700; font-size: 15.5px; letter-spacing: 0.04em; color: var(--textPrimary); text-transform: uppercase; }
.brand .name span { color: var(--textSecondary); font-weight: 400; }
.lmark rect.seam { fill: var(--accent); }
.lmark rect.slab { fill: var(--textPrimary); }
.lmark path.slab { fill: var(--textPrimary); opacity: 0.5; }
.nav-right { display: flex; align-items: center; gap: 10px; }
.back-home {
  font-family: var(--font-sans); font-size: 14px; color: var(--textSecondary);
  text-decoration: none; padding: 8px 13px; border-radius: var(--radius-md);
  transition: color var(--motion-fast) var(--ease-standard), background var(--motion-fast) var(--ease-standard);
}
.back-home:hover { color: var(--textPrimary); background: var(--backgroundElevated); }
.toggle {
  width: 38px; height: 38px; display: grid; place-items: center; cursor: pointer;
  border-radius: var(--radius-circle); border: var(--hairline) solid var(--border);
  background: transparent; color: var(--textSecondary);
  transition: color var(--motion-fast) var(--ease-standard), border-color var(--motion-fast) var(--ease-standard), background var(--motion-fast) var(--ease-standard);
}
.toggle:hover { color: var(--accent); border-color: var(--accent); background: var(--backgroundElevated); }
.toggle svg { display: block; }
.toggle .icon-sun { display: none; }
[data-theme="light"] .toggle .icon-sun, [data-theme="light-hc"] .toggle .icon-sun { display: block; }
[data-theme="light"] .toggle .icon-moon, [data-theme="light-hc"] .toggle .icon-moon { display: none; }

/* ---- Document ---- */
main.legal { padding: 72px 0 88px; }
article.doc { max-width: 800px; margin: 0 auto; }

.eyebrow {
  font-family: var(--font-sans); font-weight: 600; font-size: 12px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--textSecondary);
}
article.doc h1 {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(34px, 5.4vw, 46px); line-height: 1.08; letter-spacing: -0.015em;
  margin: 14px 0 10px; text-wrap: balance;
}
.effective { font-family: var(--font-sans); font-size: 13.5px; color: var(--textMuted); margin: 0 0 44px; }

article.doc h2 {
  font-family: var(--font-serif); font-weight: 400;
  font-size: 25px; line-height: 1.25; letter-spacing: -0.01em;
  margin: 46px 0 14px; text-wrap: balance;
}
article.doc p, article.doc li {
  font-size: 17px; line-height: 1.7; color: var(--textPrimary);
  text-wrap: pretty;
}
article.doc p { margin: 0 0 18px; }
article.doc ul { margin: 0 0 18px; padding-left: 1.2em; }
article.doc li { margin-bottom: 10px; }
article.doc strong { font-weight: 600; }
article.doc a { color: var(--accentText); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
article.doc a:hover { text-decoration-thickness: 2px; }

/* ---- Footer ---- */
footer.legal-foot { border-top: var(--hairline) solid var(--border); padding: 28px 0 40px; }
footer.legal-foot p { font-family: var(--font-sans); font-size: 12.5px; color: var(--textMuted); margin: 0; line-height: 1.7; }
footer.legal-foot a { color: inherit; text-decoration: none; }
footer.legal-foot a:hover { color: var(--accent); }

/* ---- 404 ---- */
main.notfound { min-height: calc(100vh - 70px - 100px); display: flex; align-items: center; }
main.notfound .doc { text-align: left; }
.btn-home {
  font-family: var(--font-sans); font-weight: 600; font-size: 15px;
  border-radius: var(--radius-pill); padding: 13px 24px; margin-top: 14px;
  display: inline-block; text-decoration: none;
  background: var(--accent); color: #1a1816;
  transition: background var(--motion-fast) var(--ease-standard);
}
.btn-home:hover { background: color-mix(in srgb, var(--accent) 88%, #fff); }

@media (max-width: 520px) {
  .wrap { padding: 0 20px; }
  main.legal { padding: 52px 0 64px; }
  .back-home { display: none; } /* brand already links home */
}
