/*
 * Common CSS для юр-документов МедАссист (privacy / offer / dpa / cookies).
 * Подключается через <link rel="stylesheet" href="/legal/_template.css"> из каждой страницы.
 * Палитра 1-в-1 с лендингом и /app/ (UI 2.0): zinc + sapphire + Inter.
 */
:root {
  --bg: #fafafa; --bg-elev: #ffffff; --bg-soft: #f4f4f5;
  --fg: #18181b; --fg-muted: #71717a; --fg-soft: #a1a1aa;
  --border: #e4e4e7; --border-strong: #d4d4d8;
  --sapphire-500: oklch(0.55 0.18 260);
  --sapphire-600: oklch(0.50 0.20 260);
  --sapphire-700: oklch(0.45 0.20 260);
  --sapphire-300: oklch(0.76 0.12 260);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.04);
}
.dark {
  --bg: #09090b; --bg-elev: #18181b; --bg-soft: #1f1f22;
  --fg: #fafafa; --fg-muted: #a1a1aa; --fg-soft: #71717a;
  --border: #27272a; --border-strong: #3f3f46;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  font-feature-settings: "cv11";
  background: var(--bg);
  color: var(--fg);
  line-height: 1.7;
  font-size: 16px;
}
a { color: var(--sapphire-600); text-decoration: none; border-bottom: 1px solid color-mix(in oklab, var(--sapphire-500) 25%, transparent); }
a:hover { border-bottom-color: var(--sapphire-600); }
.dark a { color: var(--sapphire-300); border-bottom-color: color-mix(in oklab, var(--sapphire-400) 30%, transparent); }
.dark a:hover { border-bottom-color: var(--sapphire-300); }
.container { max-width: 820px; margin: 0 auto; padding: 0 1.5rem; }
@media (min-width: 768px) { .container { padding: 0 2rem; } }
.header { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(16px); background: color-mix(in oklab, var(--bg) 80%, transparent); border-bottom: 1px solid var(--border); }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 1rem 0; max-width: 1200px; margin: 0 auto; padding-left: 1.5rem; padding-right: 1.5rem; }
@media (min-width: 768px) { .header-inner { padding-left: 2rem; padding-right: 2rem; } }
.logo { display: flex; align-items: center; gap: .75rem; font-size: 17px; font-weight: 700; letter-spacing: -0.02em; color: var(--fg); border-bottom: none; }
.logo-icon { width: 32px; height: 32px; border-radius: 9px; background: var(--sapphire-600); display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px color-mix(in oklab, var(--sapphire-500) 30%, transparent); }
.theme-toggle { display: inline-flex; gap: 2px; padding: 3px; border-radius: 9px; background: var(--bg-soft); border: 1px solid var(--border); }
.theme-toggle button { width: 30px; height: 30px; border: none; background: transparent; border-radius: 6px; color: var(--fg-soft); display: flex; align-items: center; justify-content: center; cursor: pointer; }
.theme-toggle button.active { background: var(--bg-elev); color: var(--sapphire-600); box-shadow: var(--shadow-sm); }
.dark .theme-toggle button.active { color: var(--sapphire-300); }

main { padding: 3.5rem 0 5rem; }
.eyebrow { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--sapphire-600); margin-bottom: 1rem; }
.dark .eyebrow { color: var(--sapphire-300); }
h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); letter-spacing: -0.025em; line-height: 1.15; font-weight: 700; margin-bottom: 1rem; }
h2 { font-size: 1.4rem; font-weight: 700; letter-spacing: -0.015em; margin-top: 2.75rem; margin-bottom: 1rem; line-height: 1.3; }
h3 { font-size: 1.05rem; font-weight: 600; margin-top: 1.75rem; margin-bottom: .65rem; }
p { margin-bottom: 1rem; color: var(--fg); }
strong { font-weight: 600; }
.lead { font-size: 1.075rem; color: var(--fg-muted); margin-bottom: 2rem; }
.meta { display: flex; flex-wrap: wrap; gap: 0.65rem 1.25rem; padding: 1rem 1.25rem; background: var(--bg-soft); border: 1px solid var(--border); border-radius: 12px; font-size: 13.5px; color: var(--fg-muted); margin-bottom: 2.5rem; }
.meta b { color: var(--fg); font-weight: 600; }
ul, ol { margin-bottom: 1rem; padding-left: 1.5rem; }
li { margin-bottom: .35rem; }
.toc { background: var(--bg-elev); border: 1px solid var(--border); border-radius: 14px; padding: 1.25rem 1.5rem; margin-bottom: 2.5rem; }
.toc h4 { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--fg-muted); margin-bottom: .75rem; }
.toc ol { padding-left: 1.5rem; margin: 0; }
.toc li { margin-bottom: .25rem; font-size: 14px; }
.toc a { color: var(--fg); border-bottom-color: transparent; }
.toc a:hover { color: var(--sapphire-600); border-bottom-color: var(--sapphire-600); }
.box { background: var(--bg-elev); border: 1px solid var(--border); border-radius: 14px; padding: 1.25rem 1.5rem; margin: 1.5rem 0; }
.box.accent { background: color-mix(in oklab, var(--sapphire-500) 6%, var(--bg-elev)); border-color: color-mix(in oklab, var(--sapphire-500) 25%, var(--border)); }
.dl { display: grid; gap: .65rem 1.25rem; grid-template-columns: max-content 1fr; font-size: 14.5px; }
.dl dt { color: var(--fg-muted); }
.dl dd { color: var(--fg); }
@media (max-width: 640px) { .dl { grid-template-columns: 1fr; gap: .15rem 0; } .dl dd { margin-bottom: .65rem; } }

.legal-footer { padding: 2.5rem 0; border-top: 1px solid var(--border); margin-top: 3rem; font-size: 13.5px; color: var(--fg-muted); }
.legal-footer .container { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; align-items: center; }
.legal-footer a { color: var(--fg-muted); border-bottom-color: transparent; }
.legal-footer a:hover { color: var(--sapphire-600); }
.legal-footer-links { display: flex; flex-wrap: wrap; gap: .5rem 1.25rem; }
