/* Shared style for /vine/terms, /vine/privacy, /vine/childrens-privacy.
   Same tokens as the rest of /vine. Linked from each legal page. */
:root {
  --ink:           #0d1117;
  --ink-soft:      #1a1a1a;
  --charcoal:      #3d444d;
  --slate:         #6b6b6d;
  --rule:          #e4e4e4;
  --paper:         #fdfdfd;
  --paper-warm:    #faf7f3;
  --accent:        #ee7625;
  --accent-deep:   #c95a13;
  --font-heading:  'Raleway', system-ui, sans-serif;
  --font-body:     'Work Sans', system-ui, sans-serif;
  --font-serif:    'Source Serif 4', Georgia, serif;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  color: var(--charcoal);
  background: var(--paper);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
a:hover { color: var(--accent-deep); }

.site-nav { background: var(--paper); border-bottom: 1px solid var(--rule); }
.site-nav-inner { max-width: 1100px; margin: 0 auto; padding: 1.1rem 1.5rem; display: flex; align-items: center; gap: 0.7rem; }
.brand { display: flex; align-items: center; gap: 0.7rem; color: var(--ink); text-decoration: none; }
.brand-mark { width: 30px; height: 30px; color: var(--accent); }
.brand-mark svg { width: 100%; height: 100%; }
.brand-text { font-family: var(--font-heading); font-size: 1rem; font-weight: 600; color: var(--ink); }

main {
  max-width: 760px;
  margin: 0 auto;
  padding: 3rem 1.5rem 5rem;
}
.eyebrow {
  font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.75rem; display: block;
}
h1 {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 2.6rem);
  font-weight: 500; color: var(--ink);
  line-height: 1.15; letter-spacing: -0.01em;
  margin-bottom: 0.5rem;
}
.effective {
  font-size: 0.88rem; color: var(--slate); margin-bottom: 2.5rem;
}
h2 {
  font-family: var(--font-heading);
  font-size: 1.35rem; font-weight: 600;
  color: var(--ink); margin: 2.5rem 0 0.75rem;
  letter-spacing: -0.005em;
}
h3 {
  font-family: var(--font-heading);
  font-size: 1.05rem; font-weight: 600;
  color: var(--ink); margin: 1.5rem 0 0.5rem;
}
p, ul, ol { margin-bottom: 1rem; font-size: 0.98rem; }
ul, ol { padding-left: 1.5rem; }
li { margin-bottom: 0.35rem; }
strong { color: var(--ink); font-weight: 600; }
.callout {
  background: var(--paper-warm);
  border-left: 3px solid var(--accent);
  padding: 1rem 1.25rem;
  border-radius: 0 6px 6px 0;
  margin: 1.25rem 0;
  font-size: 0.93rem;
}
.callout.legal-note {
  border-left-color: var(--slate);
  font-size: 0.85rem;
  color: var(--slate);
  font-style: italic;
}
.toc {
  background: var(--paper-warm);
  border: 1px solid var(--rule);
  padding: 1.25rem 1.5rem;
  border-radius: 6px;
  margin-bottom: 2.5rem;
}
.toc strong { display: block; margin-bottom: 0.5rem; font-family: var(--font-heading); font-size: 0.9rem; }
.toc ol { margin: 0; padding-left: 1.25rem; column-count: 2; column-gap: 1.5rem; }
.toc li { font-size: 0.88rem; margin-bottom: 0.25rem; break-inside: avoid; }
.toc a { text-decoration: none; }
@media (max-width: 600px) { .toc ol { column-count: 1; } }

footer {
  background: var(--ink-soft);
  color: rgba(255,255,255,0.55);
  padding: 2.5rem 1.5rem 2rem;
  text-align: center;
}
.footer-links { display: flex; justify-content: center; gap: 1.5rem; margin-bottom: 1rem; font-size: 0.85rem; flex-wrap: wrap; }
.footer-links a { color: rgba(255,255,255,0.7); text-decoration: none; }
.footer-links a:hover { color: white; }
.footer-copy { font-size: 0.78rem; color: rgba(255,255,255,0.3); }
