/* =========================================================
   Riven — Legal pages (Privacy, Terms)
   Long-form document styling, matched to the landing brand.
   ========================================================= */

@import url('./assets/riven/colors_and_type.css');

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { background: var(--paper); }
body {
  font-family: var(--font-sans);
  color: var(--fg-1);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ===== Top nav (matches landing, simplified) ===== */
.nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 32px;
  background: var(--paper);
  border-bottom: 1px solid var(--hairline);
}
.nav a.nav-logo { display: inline-flex; align-items: center; text-decoration: none; }
.nav a.nav-logo img { display: block; height: 26px; width: auto; }
.nav .nav-back {
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  color: var(--fg-2);
  text-decoration: none;
  letter-spacing: -0.005em;
  padding: 8px 14px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--hairline);
  transition: background var(--dur-fast) var(--ease-out);
}
.nav .nav-back:hover { background: var(--bone); }

/* ===== Document container ===== */
.legal {
  max-width: 760px;
  margin: 0 auto;
  padding: 56px 24px 96px;
}

.legal .doc-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-overline);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--riven);
  margin-bottom: 12px;
}

.legal h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-h2);
  line-height: 1.0;
  letter-spacing: -0.03em;
  margin: 0 0 12px;
  color: var(--fg-1);
}

.legal .doc-meta {
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  color: var(--fg-3);
  letter-spacing: 0.01em;
  margin: 0 0 40px;
}

.legal .lede {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: var(--fs-body-lg);
  line-height: 1.55;
  color: var(--fg-2);
  margin: 0 0 40px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--hairline);
}

.legal h2 {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--fs-h5);
  line-height: 1.25;
  letter-spacing: -0.015em;
  margin: 48px 0 16px;
  color: var(--fg-1);
}

.legal h3 {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--fs-h6);
  line-height: 1.3;
  margin: 32px 0 12px;
  color: var(--fg-1);
}

.legal p,
.legal ul,
.legal ol {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--fg-1);
  margin: 0 0 16px;
}

.legal ul, .legal ol { padding-left: 24px; }
.legal li { margin-bottom: 8px; }
.legal li > ul, .legal li > ol { margin-top: 8px; }

.legal strong { font-weight: 600; color: var(--fg-1); }
.legal em     { font-style: italic; }

.legal a {
  color: var(--riven-rust);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
.legal a:hover { color: var(--riven); }

.legal code, .legal kbd {
  font-family: var(--font-mono);
  font-size: 0.92em;
  background: var(--bone);
  padding: 1px 6px;
  border-radius: 4px;
}

.legal .callout {
  background: var(--bone);
  border-left: 3px solid var(--riven);
  padding: 16px 20px;
  margin: 24px 0;
  border-radius: 0 var(--radius-3) var(--radius-3) 0;
  font-size: var(--fs-body);
  color: var(--fg-2);
}

.legal .table-wrap { overflow-x: auto; margin: 20px 0; }
.legal table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-caption);
  font-family: var(--font-sans);
}
.legal th, .legal td {
  text-align: left;
  vertical-align: top;
  padding: 12px 16px;
  border-bottom: 1px solid var(--hairline);
}
.legal th {
  font-weight: 600;
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-3);
  background: var(--bone);
}
.legal td:first-child { font-weight: 500; width: 32%; }

/* ===== Footer ===== */
.legal-footer {
  border-top: 1px solid var(--hairline);
  padding: 32px 24px;
  text-align: center;
  font-size: var(--fs-caption);
  color: var(--fg-3);
  background: var(--paper);
}
.legal-footer a {
  color: var(--fg-2);
  text-decoration: none;
  margin: 0 12px;
}
.legal-footer a:hover { color: var(--fg-1); text-decoration: underline; }

@media (max-width: 600px) {
  .legal { padding: 32px 20px 64px; }
  .legal h1 { font-size: var(--fs-h3); }
  .nav { padding: 16px 20px; }
}
