/* tokens.css — дизайн-токены. Исходная палитра #061478 / #b4925a / #283593.
   Базовые цвета JS подставляет из site.theme (admin-editable) → переопределяют эти дефолты.
   Здесь же — производные токены (тинты, оверлеи), шкалы, тени, motion, тёмная тема. */

:root {
  /* ── бренд (дефолты; перекрываются из JSON site.theme) ── */
  --navy: #061478;
  --gold: #b4925a;
  --indigo: #283593;
  --text: #26263a;
  --muted: #6b7280;
  --line: #e6e3db;
  --paper: #ffffff;
  --paper-2: #f7f6f2;

  /* ── шрифты (современная строгая пара под юр-контекст) ── */
  --font-display: 'Spectral', Georgia, 'Times New Roman', serif;
  --font-sans: 'Golos Text', system-ui, -apple-system, Arial, sans-serif;

  /* ── производные (тинты/оверлеи через color-mix) ── */
  --navy-ink: color-mix(in srgb, var(--navy) 88%, #000 12%);
  --navy-soft: color-mix(in srgb, var(--navy) 6%, var(--paper));
  --navy-12: color-mix(in srgb, var(--navy) 12%, transparent);
  --gold-soft: color-mix(in srgb, var(--gold) 14%, var(--paper));
  --gold-12: color-mix(in srgb, var(--gold) 16%, transparent);
  --gold-line: color-mix(in srgb, var(--gold) 55%, transparent);
  --on-navy: #f4f3ef;
  --on-navy-muted: color-mix(in srgb, #ffffff 66%, var(--navy));

  /* ── типографика (clamp = fluid, «клиповый» десктоп) ── */
  --t-hero: clamp(2.6rem, 6vw, 5.2rem);
  --t-h1: clamp(2rem, 4vw, 3.25rem);
  --t-h2: clamp(1.6rem, 2.6vw, 2.5rem);
  --t-h3: clamp(1.2rem, 1.6vw, 1.5rem);
  --t-lead: clamp(1.05rem, 1.4vw, 1.3rem);
  --t-body: 1.02rem;
  --t-sm: 0.875rem;
  --t-xs: 0.78rem;
  --lh-tight: 1.08;
  --lh-snug: 1.32;
  --lh-body: 1.66;

  /* ── пространство (8px-grid c воздухом) ── */
  --s-1: 0.25rem; --s-2: 0.5rem; --s-3: 0.75rem; --s-4: 1rem;
  --s-5: 1.5rem; --s-6: 2rem; --s-7: 3rem; --s-8: 4rem; --s-9: 6rem; --s-10: 8rem;
  --container: 1200px;
  --container-narrow: 820px;

  /* ── радиусы / тени / линии ── */
  --r-sm: 6px; --r-md: 12px; --r-lg: 20px; --r-xl: 28px; --r-pill: 999px;
  --shadow-sm: 0 1px 2px rgba(6, 20, 120, .05), 0 1px 3px rgba(6, 20, 120, .04);
  --shadow-md: 0 6px 24px -8px rgba(6, 20, 120, .14);
  --shadow-lg: 0 24px 60px -20px rgba(6, 20, 120, .26);
  --hairline: 1px solid var(--line);

  /* ── motion ── */
  --ease: cubic-bezier(.22, .61, .36, 1);
  --ease-out: cubic-bezier(.16, 1, .3, 1);
  --dur: .45s;
  --dur-fast: .22s;

  --header-h: 76px;
  color-scheme: light;
}

[data-theme="dark"] {
  --navy: #6b8afd;
  --gold: #d4b478;
  --indigo: #8a9cff;
  --text: #e7e8ef;
  --muted: #9aa0ad;
  --line: #2a2f3e;
  --paper: #11131c;
  --paper-2: #171a25;
  --navy-soft: color-mix(in srgb, var(--navy) 10%, var(--paper));
  --on-navy: #f4f3ef;
  --on-navy-muted: color-mix(in srgb, #ffffff 60%, var(--navy));
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);
  --shadow-md: 0 8px 28px -10px rgba(0, 0, 0, .6);
  --shadow-lg: 0 30px 70px -24px rgba(0, 0, 0, .7);
  color-scheme: dark;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
}
