:root {
  --sage-50:#F0F5F1; --sage-100:#D6E3D9; --sage-500:#3F6B4A; --sage-600:#2F5138; --sage-700:#243E2A;
  --cream-50:#FDF9F1; --cream-100:#FAF2DC; --cream-200:#F3E9CC;
  --gold-400:#F7D25A; --gold-500:#F4C430; --gold-600:#E6A817;
  --ink-100:#F5F1EA; --ink-200:#E5E0D6; --ink-300:#A69E8E; --ink-500:#6B6555; --ink-700:#3D392F; --ink-900:#1C1A13;
  --danger:#B42318;
  --serif:"Newsreader", Georgia, serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, Consolas, monospace;
  --radius-md:12px; --radius-lg:18px;
  --shadow-sm:0 2px 6px rgba(29,25,13,.07);
  --shadow-md:0 8px 24px rgba(29,25,13,.09);
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; } }
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  font-family: var(--sans);
  color: var(--ink-900);
  background: var(--cream-50);
  line-height: 1.7;
  font-feature-settings: "cv11","ss01","ss03";
}
::selection { background: var(--sage-500); color: var(--cream-50); }

a { color: var(--sage-600); text-decoration: none; border-bottom: 1px solid rgba(63,107,74,.3); transition: border-color .2s, color .2s; }
a:hover { color: var(--sage-700); border-bottom-color: var(--sage-500); }

.container { max-width: 780px; margin-inline: auto; padding-inline: 24px; }
.container-wide { max-width: 1200px; margin-inline: auto; padding-inline: 24px; }

/* Nav (shared with main site) */
.nav {
  position: sticky; top: 0; z-index: 100;
  padding: 14px 0;
  background: rgba(253, 249, 241, 0.85);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid rgba(29, 25, 13, 0.06);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.nav-brand {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--serif); font-size: 23px; font-weight: 500;
  font-variation-settings: "opsz" 24;
  letter-spacing: -0.012em; color: var(--ink-900);
  border: 0;
  line-height: 1;
}
.nav-brand span { line-height: 1; display: inline-block; padding-top: 2px; }
.nav-brand:hover { border: 0; color: var(--sage-700); }
.nav-brand svg,
.nav-brand img {
  width: 44px; height: 44px;
  transform-origin: center center;
  display: block;
  object-fit: contain;
  flex-shrink: 0;
  animation: logoBloom 4.8s ease-in-out infinite;
  transition: transform .35s cubic-bezier(0.34, 1.3, 0.64, 1), filter .35s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes logoBloom {
  0%, 100% {
    transform: scale(1);
    filter: drop-shadow(0 0 0 rgba(244, 196, 48, 0));
  }
  50% {
    transform: scale(1.04);
    filter: drop-shadow(0 0 10px rgba(244, 196, 48, 0.38));
  }
}
.nav-brand:hover img {
  animation-play-state: paused;
  transform: scale(1.1);
  filter: drop-shadow(0 4px 14px rgba(244, 196, 48, 0.5));
}
@keyframes spinMark { to { transform: rotate(360deg); } }
.nav-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 500;
  color: var(--ink-500); border: 0;
  padding: 8px 14px; border-radius: 999px;
  transition: background .2s, color .2s;
}
.nav-back:hover { background: var(--ink-100); color: var(--ink-900); border: 0; }

/* Header */
.legal-header { padding: 64px 0 32px; border-bottom: 1px solid var(--ink-200); margin-bottom: 48px; }
.legal-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sage-600);
  background: rgba(63, 107, 74, 0.08);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(63, 107, 74, 0.16);
  margin-bottom: 24px;
}
.legal-eyebrow .dot { width: 6px; height: 6px; background: var(--sage-500); border-radius: 50%; }
h1 {
  font-family: var(--sans);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.035em;
  margin-bottom: 16px;
}
h1 em {
  font-family: var(--sans);
  font-style: normal;
  font-weight: inherit;
  color: var(--sage-600);
  letter-spacing: inherit;
  hyphens: manual;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 12' preserveAspectRatio='none'%3E%3Cpath d='M3 7 Q40 2 80 6 T160 5 T237 6' stroke='%23F4C430' stroke-width='3.2' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 100% 0.14em;
  padding-bottom: 0.1em;
}
.legal-updated { color: var(--ink-500); font-size: 14px; }
.legal-updated strong { color: var(--ink-900); font-weight: 600; }

/* Content */
.legal-content { padding-bottom: 80px; }
.legal-content h2 {
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.025em;
  margin-top: 48px;
  margin-bottom: 12px;
  color: var(--ink-900);
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content h2 .num {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--sage-500);
  margin-right: 10px;
  letter-spacing: -0.01em;
}
.legal-content h3 {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 600;
  margin-top: 28px;
  margin-bottom: 8px;
  color: var(--ink-900);
  letter-spacing: -0.015em;
}
.legal-content p { margin-bottom: 16px; color: var(--ink-700); font-size: 16px; }
.legal-content ul, .legal-content ol { margin: 0 0 16px 24px; color: var(--ink-700); font-size: 16px; }
.legal-content li { margin-bottom: 8px; }
.legal-content strong { color: var(--ink-900); font-weight: 600; }
.legal-content code {
  font-family: var(--mono);
  font-size: 13.5px;
  background: var(--ink-100);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--ink-900);
}

/* TOC */
.legal-toc {
  background: #fff;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-md);
  padding: 20px 24px;
  margin-bottom: 48px;
}
.legal-toc-title {
  font-size: 11px; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-500);
  margin-bottom: 12px;
}
.legal-toc ol { list-style: none; counter-reset: toc; margin: 0; padding: 0; }
.legal-toc li { counter-increment: toc; margin-bottom: 6px; font-size: 14.5px; }
.legal-toc li::before {
  content: counter(toc, decimal-leading-zero);
  font-family: var(--serif); font-style: italic; color: var(--sage-500);
  margin-right: 10px; font-size: 16px;
}
.legal-toc a { border: 0; color: var(--ink-700); font-weight: 500; }
.legal-toc a:hover { color: var(--sage-600); border: 0; }

/* Callout */
.callout {
  background: var(--sage-50);
  border: 1px solid var(--sage-100);
  border-left: 3px solid var(--sage-500);
  border-radius: var(--radius-md);
  padding: 18px 22px;
  margin: 24px 0;
  font-size: 15px;
  color: var(--sage-700);
}
.callout strong { color: var(--sage-700); }
.callout.warn {
  background: #FFF8EC;
  border-color: rgba(244, 196, 48, 0.3);
  border-left-color: var(--gold-600);
  color: var(--ink-700);
}
.callout.warn strong { color: var(--ink-900); }

/* Footer */
footer {
  background: var(--cream-100);
  border-top: 1px solid rgba(29, 25, 13, 0.06);
  padding: 48px 0 32px;
  color: var(--ink-500);
  font-size: 13.5px;
  margin-top: 64px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  flex-wrap: wrap;
}
@media (max-width: 640px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-links { display: flex; gap: 20px; flex-wrap: wrap; }
.footer-links a { color: var(--ink-500); border: 0; }
.footer-links a:hover { color: var(--sage-600); border: 0; }
