/* Shared styling for Nova legal pages (Privacy, Terms). Self-contained — does
   not depend on app.css, so these pages stay light and load fast. */
:root {
  --bg: oklch(0.985 0.004 85);
  --bg-2: oklch(0.965 0.006 80);
  --ink: oklch(0.19 0.005 60);
  --ink-2: oklch(0.32 0.005 60);
  --ink-3: oklch(0.48 0.005 60);
  --rule: oklch(0.86 0.006 80);
  --accent: oklch(0.58 0.13 45);
  --serif: "Newsreader", Georgia, serif;
  --sans: "Schibsted Grotesk", system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, Menlo, monospace;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: var(--sans); -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}

/* Header */
.lg-top {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px clamp(20px, 5vw, 56px);
  background: color-mix(in oklch, var(--bg) 88%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--rule);
}
.lg-brand { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--ink); }
.lg-brand svg { display: block; }
.lg-brand__name { font-family: var(--serif); font-style: italic; font-size: 22px; }
.lg-back { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); text-decoration: none; }
.lg-back:hover { color: var(--ink); }

/* Body */
.lg-wrap { max-width: 760px; margin: 0 auto; padding: clamp(40px, 7vw, 88px) clamp(20px, 5vw, 32px) 40px; }
.lg-eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); }
.lg-wrap h1 { font-family: var(--serif); font-weight: 400; font-size: clamp(34px, 6vw, 56px); line-height: 1.05; margin: 14px 0 10px; }
.lg-updated { font-family: var(--mono); font-size: 12px; color: var(--ink-3); margin: 0 0 8px; }
.lg-note {
  margin: 24px 0 0; padding: 14px 16px; font-size: 14px; color: var(--ink-2);
  background: var(--bg-2); border: 1px solid var(--rule); border-radius: 6px;
}
.lg-wrap h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(22px, 3vw, 28px); margin: 48px 0 12px; }
.lg-wrap h3 { font-size: 17px; font-weight: 600; margin: 28px 0 8px; }
.lg-wrap p, .lg-wrap li { font-size: 16px; color: var(--ink-2); }
.lg-wrap ul { padding-left: 22px; margin: 12px 0; }
.lg-wrap li { margin: 6px 0; }
.lg-wrap a { color: var(--ink); text-decoration: underline; text-underline-offset: 2px; text-decoration-color: var(--rule); }
.lg-wrap a:hover { text-decoration-color: var(--ink); }
.lg-fill { background: oklch(0.92 0.08 95); padding: 0 4px; border-radius: 3px; color: var(--ink); font-style: italic; }

/* TOC */
.lg-toc { margin: 28px 0 0; padding: 18px 20px; background: var(--bg-2); border: 1px solid var(--rule); border-radius: 8px; }
.lg-toc__k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px; }
.lg-toc ol { margin: 0; padding-left: 20px; columns: 2; column-gap: 28px; font-size: 14px; }
.lg-toc a { color: var(--ink-2); text-decoration: none; }
.lg-toc a:hover { color: var(--ink); text-decoration: underline; }

/* Footer */
.lg-footer {
  border-top: 1px solid var(--rule); margin-top: 64px;
  padding: 32px clamp(20px, 5vw, 56px);
  display: flex; flex-wrap: wrap; gap: 16px; justify-content: space-between;
  font-size: 13px; color: var(--ink-3);
}
.lg-footer a { color: var(--ink-2); text-decoration: none; }
.lg-footer a:hover { color: var(--ink); }
.lg-footer__links { display: flex; gap: 18px; flex-wrap: wrap; }

@media (max-width: 640px) { .lg-toc ol { columns: 1; } }
