/*
 * KP Generator — CSS-переменные с дизайн-токенами Stitch.
 *
 * Используются:
 *  1. В WeasyPrint PDF-шаблонах (app/pdf/templates/) — там Tailwind CDN не работает,
 *     нужны нативные CSS-переменные.
 *  2. Как запасной канал для кастомных компонентов, где Tailwind-классов не хватает.
 *
 * Источник правды: .design/design_system.md §7–8. При изменении — синхронизировать
 * с tailwind.config.js.
 */

:root {
  /* --- Surface (tonal hierarchy) --- */
  --color-background: #fcf8fb;
  --color-surface: #fcf8fb;
  --color-surface-bright: #fcf8fb;
  --color-surface-dim: #dcd9dc;
  --color-surface-variant: #e4e2e4;
  --color-surface-tint: #005cbb;

  --color-surface-container: #f0edef;
  --color-surface-container-lowest: #ffffff;
  --color-surface-container-low: #f6f3f5;
  --color-surface-container-high: #eae7ea;
  --color-surface-container-highest: #e4e2e4;

  --color-on-surface: #1b1b1d;
  --color-on-surface-variant: #414753;
  --color-on-background: #1b1b1d;

  /* --- Primary --- */
  --color-primary: #0059b5;
  --color-primary-container: #0071e3;
  --color-primary-fixed: #d7e2ff;
  --color-primary-fixed-dim: #abc7ff;
  --color-on-primary: #ffffff;
  --color-on-primary-container: #fcfbff;

  /* --- Secondary --- */
  --color-secondary: #5e5e63;
  --color-secondary-container: #e0dfe4;
  --color-on-secondary: #ffffff;
  --color-on-secondary-container: #626267;

  /* --- Tertiary --- */
  --color-tertiary: #9b3f00;
  --color-tertiary-container: #c25100;
  --color-on-tertiary: #ffffff;
  --color-on-tertiary-container: #fffaf9;

  /* --- Error --- */
  --color-error: #ba1a1a;
  --color-error-container: #ffdad6;
  --color-on-error: #ffffff;
  --color-on-error-container: #93000a;

  /* --- Outline (для ghost borders) --- */
  --color-outline: #717785;
  --color-outline-variant: #c1c6d6;

  /* --- Inverse (тосты, tooltip) --- */
  --color-inverse-surface: #303032;
  --color-inverse-on-surface: #f3f0f2;
  --color-inverse-primary: #abc7ff;

  /* --- Радиусы --- */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;

  /* --- Тени --- */
  --shadow-ambient: 0 4px 20px rgba(27, 27, 29, 0.06);
  --shadow-lift: 0 2px 8px rgba(27, 27, 29, 0.04);

  /* --- Типографика --- */
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
}

/* --- Базовые правила (§6 design_system.md «Do's and Don'ts») --- */

html {
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  background-color: var(--color-background);
  color: var(--color-on-surface); /* НЕ #000 — §6 Don't */
  font-feature-settings: 'cv11', 'ss01', 'ss03'; /* Inter stylistic sets */
}

/* Focus-visible — ghost border primary, §5 Input Fields */
*:focus-visible {
  outline: 2px solid var(--color-primary-container);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* Alpine.js x-cloak — скрыть элементы до инициализации Alpine
   (используется колокольчиком уведомлений и другими dropdown'ами) */
[x-cloak] {
  display: none !important;
}
