/* Sortilège legal pages (privacy, terms).
   Mirrors the promo site's tokens + fonts so the long-form reads as an
   extension of the title. Fonts are self-hosted (same TTFs the site ships
   under /fonts) so these pages make no third-party requests at all. */

/* ---------- Fonts (self-hosted) ---------- */
@font-face {
  font-family: "Cinzel";
  src: url("/fonts/Cinzel.ttf") format("truetype");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Cinzel";
  src: url("/fonts/Cinzel-Bold.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Cinzel Decorative";
  src: url("/fonts/CinzelDecorative.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Cormorant Garamond";
  src: url("/fonts/CormorantGaramond-Regular.ttf") format("truetype");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Cormorant Garamond";
  src: url("/fonts/CormorantGaramond-Italic.ttf") format("truetype");
  font-weight: 400; font-style: italic; font-display: swap;
}

/* ---------- Tokens (from palette.gd, same as index.html) ---------- */
:root {
  --void: #0a0907;
  --base: #14110c;
  --stone: #1f1a14;
  --gold-deep: #a68546;
  --gold: #d4ae61;
  --gold-bright: #eac673;
  --gold-glow: #f5dca0;
  --parchment: #e8d9a8;
  --parchment-dim: #a89a7c;
  --ink: #3a2a1a;
  --arcane: #6f9fc8;

  --font-logo: 'Cinzel Decorative', 'Georgia', serif;
  --font-heading: 'Cinzel', 'Georgia', serif;
  --font-body: 'Cormorant Garamond', 'Georgia', serif;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--void);
  color: var(--parchment);
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Subtle grain, same as the landing page. */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 256px 256px;
}

/* ---------- Top bar: wordmark links home ---------- */
.legal-nav {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  max-width: 820px;
  margin: 0 auto;
  padding: 1.75rem 2rem 0;
}

.legal-nav .wordmark {
  font-family: var(--font-logo);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: 0.16em;
  color: var(--gold-bright);
  text-decoration: none;
  text-shadow: 0 0 30px rgba(212,174,97,0.2);
}

.legal-nav .back {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--parchment-dim);
  text-decoration: none;
  transition: color 0.25s ease;
}
.legal-nav .back:hover { color: var(--gold); }

/* ---------- Reading column ---------- */
.legal {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin: 0 auto;
  padding: 3rem 2rem 5rem;
}

.legal-header { margin-bottom: 3rem; }

.legal h1 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(2rem, 5vw, 2.8rem);
  color: var(--gold-bright);
  letter-spacing: 0.04em;
  line-height: 1.15;
}

.legal h1::after {
  content: '';
  display: block;
  width: 64px;
  height: 1px;
  background: var(--gold-deep);
  margin-top: 1.25rem;
}

.legal .eyebrow {
  display: block;
  font-family: var(--font-heading);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--parchment-dim);
  margin-top: 1.25rem;
}

.legal .lede {
  font-style: italic;
  font-size: 1.18rem;
  color: var(--parchment);
  margin-top: 1.5rem;
}

.legal h2 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--gold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 2.75rem 0 0.5rem;
  padding-top: 1.75rem;
  border-top: 1px solid rgba(166,133,70,0.14);
}

.legal h2:first-of-type { border-top: none; padding-top: 0; }

.legal h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1rem;
  color: var(--gold-bright);
  letter-spacing: 0.04em;
  margin: 1.75rem 0 0.4rem;
}

.legal p { margin: 0.9rem 0; }

.legal ul { margin: 0.9rem 0 0.9rem 1.4rem; }
.legal li { margin: 0.4rem 0; }
.legal li::marker { color: var(--gold-deep); }

.legal a {
  color: var(--arcane);
  text-decoration: none;
  border-bottom: 1px solid rgba(111,159,200,0.35);
  transition: color 0.2s ease, border-color 0.2s ease;
}
.legal a:hover { color: var(--gold-bright); border-color: var(--gold); }

.legal strong { color: var(--parchment); font-weight: 600; }

.legal .callout {
  margin: 1.5rem 0;
  padding: 1.1rem 1.4rem;
  background: rgba(31,26,20,0.6);
  border: 1px solid rgba(166,133,70,0.16);
  border-left: 2px solid var(--gold-deep);
  font-size: 0.98rem;
  color: var(--parchment-dim);
}

.legal .contact-block {
  margin-top: 1rem;
  font-family: var(--font-heading);
  letter-spacing: 0.04em;
  font-size: 0.95rem;
  color: var(--parchment-dim);
  line-height: 2;
}

/* ---------- Footer (matches index.html) ---------- */
footer {
  position: relative;
  z-index: 1;
  padding: 3rem 2rem;
  text-align: center;
  background: var(--void);
}
footer::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: min(400px, 60%);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-deep), transparent);
}
.footer-studio {
  font-family: var(--font-heading);
  font-size: 0.8rem;
  color: var(--parchment-dim);
  letter-spacing: 0.15em;
  margin-bottom: 0.5rem;
}
.footer-links {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 0.75rem;
}
.footer-links a {
  color: var(--parchment-dim);
  text-decoration: none;
  transition: color 0.2s ease;
}
.footer-links a:hover { color: var(--gold); }
.footer-links span { color: rgba(168,154,124,0.4); margin: 0 0.6rem; }
.footer-copy {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: rgba(168,154,124,0.5);
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}
