/* Shared styling for CYBERVIS legal pages (privacy, terms, cookies).
   Brand tokens mirror index.html :root. */
:root {
  --bg: #F5F5F5;
  --surface: #FFFFFF;
  --ink: #1A1A2E;
  --ink-2: #2D2D44;
  --muted: #6B6B6B;
  --line: rgba(26, 26, 46, 0.08);
  --line-strong: rgba(26, 26, 46, 0.14);
  --accent: #FF6B2B;
  --brand: #6C3CE1;
  --radius: 16px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--bg);
  color: var(--ink-2);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Top bar */
.legal-topbar {
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 10;
}
.legal-topbar .inner {
  max-width: 880px; margin: 0 auto; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between;
}
.legal-topbar .brand {
  font-weight: 800; letter-spacing: 0.04em; color: var(--ink);
  font-size: 18px; text-decoration: none;
}
.legal-topbar .brand span { color: var(--brand); }
.legal-topbar .back { font-size: 14px; font-weight: 500; }

/* Document */
.legal-doc { max-width: 880px; margin: 0 auto; padding: 56px 24px 96px; }
.legal-doc h1 {
  font-family: 'Instrument Serif', Georgia, serif;
  font-weight: 400; font-size: 46px; line-height: 1.1;
  color: var(--ink); margin-bottom: 12px; letter-spacing: -0.01em;
}
.legal-doc .updated { color: var(--muted); font-size: 14px; margin-bottom: 8px; }
.legal-doc .intro { font-size: 17px; color: var(--ink-2); margin: 18px 0 8px; }
.legal-doc h2 {
  font-size: 22px; font-weight: 700; color: var(--ink);
  margin: 40px 0 14px; padding-top: 8px;
}
.legal-doc h3 { font-size: 17px; font-weight: 600; color: var(--ink); margin: 24px 0 8px; }
.legal-doc p { margin: 12px 0; }
.legal-doc ul, .legal-doc ol { margin: 12px 0 12px 24px; }
.legal-doc li { margin: 6px 0; }
.legal-doc strong { color: var(--ink); }

/* Placeholder highlighting so unfilled fields are obvious before publishing */
.ph {
  background: #FFF3D6; border: 1px dashed #E0A800; border-radius: 6px;
  padding: 0 5px; font-size: 0.92em; color: #7A5800; white-space: nowrap;
}

/* Callout */
.legal-note {
  background: #FFF0EA; border-left: 4px solid var(--accent);
  border-radius: 8px; padding: 14px 18px; margin: 20px 0; font-size: 15px;
}

/* Tables (cookie list) */
.legal-table { width: 100%; border-collapse: collapse; margin: 18px 0; font-size: 14.5px; }
.legal-table th, .legal-table td {
  text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.legal-table th { background: #FAFAFA; font-weight: 600; color: var(--ink); }

/* TOC */
.legal-toc {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 18px 22px; margin: 28px 0;
}
.legal-toc h4 { font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); margin-bottom: 10px; }
.legal-toc ol { margin: 0 0 0 18px; }
.legal-toc li { margin: 4px 0; }

/* Footer */
.legal-footer {
  border-top: 1px solid var(--line); background: var(--surface);
  padding: 28px 24px; text-align: center; color: var(--muted); font-size: 13.5px;
}
.legal-footer a { margin: 0 10px; }

@media (max-width: 600px) {
  .legal-doc h1 { font-size: 34px; }
  .legal-doc { padding: 36px 18px 72px; }
}
