/* Zernovoz design system.
 * Источник правды: docs/DESIGN.md
 *
 * Содержит:
 *  - CSS-переменные (light/dark через [data-theme])
 *  - Базовые ресеты и типографика
 *  - Компоненты: .btn, .input, .card, .pill, таблицы, формы
 *  - Утилиты: .muted, .mt-*, .flex, .grid, responsive helpers
 *  - Toast-уведомления (.toast-wrap + .toast)
 *  - Pico 2 override (для /admin, который на Pico)
 */

/* Inter — единственный шрифт для всего интерфейса. Soft-modern вектор
 * 2026-05-08, отказ от Fraunces и Golos Text. Inter v4 хорошо рендерит
 * кириллицу, стабильно выглядит на всех OS.
 *
 * Шрифт подключается через <link rel="stylesheet"> в base.html head, а не
 * @import — потому что @import создаёт вторую round-trip (CSS подгружается,
 * парсер видит @import, новый запрос). С <link> один round-trip + работают
 * preconnect-хинты на fonts.gstatic.com.
 *
 * Weights ограничены 400 + 600 (вместо 400-900) — реально используются
 * только regular и semi-bold. CWV audit 2026-05-13: 6 weights давали +100 KiB
 * (3 woff2 файла) и +500-1000 мс на mobile LCP. */

/* ───── Tokens — Light (default) ─────────────────────────────────────── */
/* Soft-modern палитра 2026-05-08, см. desktop.jsx + mobile.jsx как target.
 * Ключевые цвета: тёплый off-white фон, мшистый зелёный accent, чистый
 * white surface для карточек. Контекстные группы (map / TG / VK / info)
 * отдельно — каждый блок имеет свой identity без перегрузки одной палитры. */
:root,
[data-theme="light"] {
  --bg:              #F6F7F1;  /* тёплый off-white фон */
  --surface:         #ffffff;  /* карточки, panels */
  --surface-2:       #F3F7EF;  /* hover поверх surface, нежный зелёный tint */
  --input-bg:        #F8FAF5;
  --border:          #E2E6DC;
  --border-soft:     #E5E9E0;  /* для тонких разделителей внутри cards */
  --border-input:    #DDE5D6;
  --border-strong:   #B5BCB0;

  --text:            #18211C;  /* почти-чёрный с зелёным подтоном */
  --text-muted:      #6D786E;

  --accent:          #4F7D3A;  /* мшистый зелёный — кнопки */
  --accent-hover:    #426B30;
  --accent-weak:     #EEF6E9;  /* фон активного chip / page-button */
  --accent-text:     #31592E;  /* текст на accent-weak */
  --accent-strong:   #2F7D32;  /* для зелёных текст-акцентов (цены ставок) */
  --accent-border:   rgba(95, 143, 62, 0.35);
  --on-accent:       #ffffff;

  /* Контекстные группы — кнопки/блоки с собственным identity */
  --info-bg:         #FFF7E8;  /* тёплый жёлтый — доп. информация в карточке */
  --info-text:       #382A12;
  --info-border:     #F3E1BC;

  --map-bg:          #EEF6E9;  /* зелёный — кнопка «На карте» */
  --map-hover-bg:    #E2F0DA;
  --map-text:        #31592E;
  --map-border:      rgba(95, 143, 62, 0.35);

  --tg-bg:           #E8F3FF;  /* голубой — Telegram-кнопка */
  --tg-hover-bg:     #DCEEFF;
  --tg-text:         #1D5F9E;

  --vk-bg:           #E8F2FF;  /* голубой VK */
  --vk-hover-bg:     #DCEEFF;
  --vk-text:         #1D5F9E;
  --vk-border:       #BFD9F4;

  /* Семантика — оставляем (используется в .pill, /admin) */
  --danger:          #B14238;
  --danger-weak:     #FCE8E5;
  --warning:         #C49120;
  --warning-weak:    #FBEFCE;
  --success:         #4F7D3A;  /* совпадает с accent */
  --success-weak:    #EEF6E9;
  --info:            #1D5F9E;
  --info-weak:       #E8F2FF;

  --shadow-sm:       0 1px 2px rgba(15, 25, 18, 0.04);
  --shadow-md:       0 2px 10px rgba(15, 25, 18, 0.06);
  --shadow-lg:       0 8px 24px rgba(15, 25, 18, 0.08);
  --shadow-sheet:    0 20px 40px rgba(15, 25, 18, 0.18);
  --shadow-toast:    0 6px 24px rgba(15, 25, 18, 0.14);
}

/* ───── Tokens — Dark ─────────────────────────────────────────────────── */
/* Холодный графит с зелёным accent — как в JSX target. Важная деталь:
 * primary button в JSX в обеих темах остаётся #4F7D3A (НЕ переключается
 * на салатовый в dark). Поэтому --accent (button bg) одинаковый, а
 * салатовый #8FD36A применяется только в --accent-strong (для ярких
 * текстовых акцентов типа цены ставки) и --accent-text (текст на
 * accent-weak фоне). */
[data-theme="dark"] {
  --bg:              #0F1115;  /* page */
  --surface:         #171A20;  /* cards */
  --surface-2:       #202631;  /* hover */
  --panel:           #151820;  /* большие panels (если отличаем от card) */
  --input-bg:        #101318;
  --border:          #2A2F38;
  --border-soft:     #2A2F38;
  --border-input:    #303744;
  --border-strong:   #404754;

  --text:            #EEF2F0;
  --text-muted:      #9AA3AD;

  --accent:          #4F7D3A;  /* button bg — тот же что в light */
  --accent-hover:    #426B30;
  --accent-weak:     #223026;  /* фон активного chip / page-button */
  --accent-text:     #B8E69C;  /* текст на accent-weak (active chip text) */
  --accent-strong:   #8FD36A;  /* зелёный для текст-акцентов (цены) */
  --accent-border:   rgba(143, 211, 106, 0.30);
  --on-accent:       #ffffff;  /* белый текст на button — как в light */

  --info-bg:         #1E232B;
  --info-text:       #D8DEE5;
  --info-border:     #303744;

  --map-bg:          #223026;
  --map-hover-bg:    #2A3A2E;
  --map-text:        #B8E69C;
  --map-border:      rgba(143, 211, 106, 0.30);

  --tg-bg:           #172B3F;
  --tg-hover-bg:     #1D354D;
  --tg-text:         #A8D4FF;

  --vk-bg:           #172B3F;
  --vk-hover-bg:     #1D354D;
  --vk-text:         #A8D4FF;
  --vk-border:       #244761;

  --danger:          #E66A5C;
  --danger-weak:     #3A1E1A;
  --warning:         #D49A4A;
  --warning-weak:    #3A2F1C;
  --success:         #8FD36A;
  --success-weak:    #223026;
  --info:            #8FB8D6;
  --info-weak:       #1A2533;

  --shadow-sm:       none;
  --shadow-md:       none;
  --shadow-lg:       0 8px 24px rgba(0, 0, 0, 0.40);
  --shadow-sheet:    0 20px 40px rgba(0, 0, 0, 0.55);
  --shadow-toast:    0 4px 20px rgba(0, 0, 0, 0.60);
}

/* Если тема не задана вручную — следуем OS. Дублируем dark-токены. */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bg:              #0F1115;
    --surface:         #171A20;
    --surface-2:       #202631;
    --panel:           #151820;
    --input-bg:        #101318;
    --border:          #2A2F38;
    --border-soft:     #2A2F38;
    --border-input:    #303744;
    --border-strong:   #404754;
    --text:            #EEF2F0;
    --text-muted:      #9AA3AD;
    --accent:          #4F7D3A;
    --accent-hover:    #426B30;
    --accent-weak:     #223026;
    --accent-text:     #B8E69C;
    --accent-strong:   #8FD36A;
    --accent-border:   rgba(143, 211, 106, 0.30);
    --on-accent:       #ffffff;
    --info-bg:         #1E232B;
    --info-text:       #D8DEE5;
    --info-border:     #303744;
    --map-bg:          #223026;
    --map-hover-bg:    #2A3A2E;
    --map-text:        #B8E69C;
    --map-border:      rgba(143, 211, 106, 0.30);
    --tg-bg:           #172B3F;
    --tg-hover-bg:     #1D354D;
    --tg-text:         #A8D4FF;
    --vk-bg:           #172B3F;
    --vk-hover-bg:     #1D354D;
    --vk-text:         #A8D4FF;
    --vk-border:       #244761;
    --danger:          #E66A5C;
    --danger-weak:     #3A1E1A;
    --warning:         #D49A4A;
    --warning-weak:    #3A2F1C;
    --success:         #8FD36A;
    --success-weak:    #223026;
    --info:            #8FB8D6;
    --info-weak:       #1A2533;
    --shadow-sm:       none;
    --shadow-md:       none;
    --shadow-lg:       0 8px 24px rgba(0, 0, 0, 0.40);
    --shadow-sheet:    0 20px 40px rgba(0, 0, 0, 0.55);
    --shadow-toast:    0 4px 20px rgba(0, 0, 0, 0.60);
  }
}

/* ───── Static tokens ────────────────────────────────────────────────── */
:root {
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;

  /* Soft-modern radii 2026-05-08 — JSX target использует крупные радиусы:
   * inputs/buttons rounded-xl (12), cards rounded-2xl (16), panels
   * rounded-3xl (24). Pill — 9999. Старые --radius-sm/md/lg остаются
   * для обратной совместимости компонентов, но размеры подняты. */
  --radius-sm: 8px;     /* badges, small pills внутри cards */
  --radius-md: 12px;    /* inputs, buttons (default) */
  --radius-lg: 16px;    /* cards, .card, средние блоки */
  --radius-xl: 20px;    /* промежуточный для крупных panels */
  --radius-2xl: 24px;   /* hero, big panels (sections / filter wrappers) */
  --radius-pill: 9999px;/* chips, theme-toggle, pill-кнопки */

  --font-sans:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI',
                  Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-display: var(--font-sans);  /* legacy alias — теперь нет serif */
  --font-mono:    ui-monospace, SFMono-Regular, 'SF Mono', Menlo, monospace;

  /* Размеры под JSX target. JSX в основном НЕ использует responsive scaling,
   * но мы держим лёгкое уменьшение на мобиле для крупных headings —
   * иначе хедер h1=30px доминирует над карточками 16px. */
  --fs-display: 26px;     /* hero h1, brand-block desktop */
  --fs-h1:      22px;     /* page h1 */
  --fs-h2:      18px;     /* section h2 */
  --fs-h3:      16px;     /* card h3, sheet h */
  --fs-body:    15px;     /* default body — компактнее JSX text-sm 14, мягче 16 */
  --fs-small:   13px;     /* metadata, muted */
  --fs-xs:      12px;     /* labels, ultra-small */

  /* Letter-spacing: tracking-tight для display, normal для body */
  --tracking-tight:  -0.02em;
  --tracking-normal: 0;
  --tracking-wide:   0.05em;

  --ease:       cubic-bezier(0.4, 0, 0.2, 1);
}

@media (min-width: 768px) {
  :root {
    --fs-display: 30px;
    --fs-h1:      28px;
    --fs-h2:      20px;
    --fs-h3:      18px;
  }
}

/* ───── Reset ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html {
  color-scheme: light dark;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: 1.5;
  color: var(--text);
  background: var(--bg);
  font-feature-settings: "cv02", "cv03", "cv04", "cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Headings — soft-modern: жирные веса 700-800 как в JSX (font-bold/extrabold/black),
 * tracking-tight для крупных, normal для card-titles. Все sans, без serif. */
h1, h2, h3, h4, h5, h6 {
  margin: 0 0 var(--space-3);
  line-height: 1.2;
  font-family: var(--font-sans);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
}
h1 { font-size: var(--fs-h1); font-weight: 800; }
h2 { font-size: var(--fs-h2); font-weight: 700; letter-spacing: -0.015em; }
h3 { font-size: var(--fs-h3); font-weight: 700; letter-spacing: -0.01em; }
h4, h5, h6 { font-weight: 600; letter-spacing: -0.005em; }

/* Hero/display заголовок — отдельный класс для главной (text-3xl font-black
 * tracking-tight как в JSX). Применять как `<h1 class="hero-title">` или
 * прямо `.hero-h1`. */
.hero-title,
.display-title {
  font-size: var(--fs-display);
  font-weight: 900;
  line-height: 1.15;
  letter-spacing: -0.025em;
  margin: 0 0 var(--space-3);
}

p { margin: 0 0 var(--space-3); }
small { font-size: var(--fs-small); }

a {
  color: var(--accent);
  text-decoration: none;
  transition: color 150ms var(--ease);
}
a:hover { color: var(--accent-hover); text-decoration: underline; }

code, pre {
  font-family: var(--font-mono);
  font-size: 0.9em;
}

/* Reduced motion: убираем всю анимацию кроме focus ring */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ───── Buttons ──────────────────────────────────────────────────────── */
/* Размеры под JSX: default h-10 (40px) ≈ rounded-xl (12px). Мобильные
 * touch-targets ≥ 44px. Радиусы крупные = soft-modern.
 * Веса 600 (semibold), как в JSX UiButton. */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 40px;
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: var(--radius-md);     /* 12px */
  background: var(--accent);
  color: var(--on-accent);
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: background 150ms var(--ease), transform 100ms var(--ease),
              border-color 150ms var(--ease), color 150ms var(--ease);
  text-decoration: none;
  white-space: nowrap;
  user-select: none;
  -webkit-appearance: none;
  appearance: none;
}
.btn:hover { background: var(--accent-hover); text-decoration: none; }
.btn:active { transform: scale(0.98); }
.btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Размерные модификаторы. JSX: h-8 / h-9 / h-10 / h-11 → у нас sm/md/lg/xl. */
.btn-sm { min-height: 32px; font-size: 13px; padding: 0 12px; gap: 5px; }
.btn-lg { min-height: 44px; font-size: 15px; padding: 0 22px; }
.btn-xl { min-height: 48px; font-size: 15px; padding: 0 24px; border-radius: var(--radius-lg); }
.btn-icon { padding: 0; width: 40px; min-width: 40px; }
.btn-icon.btn-sm { width: 32px; min-width: 32px; }
.btn-icon.btn-lg { width: 44px; min-width: 44px; }

/* Pill / round — для theme-toggle и round VK-кнопки в шапке. */
.btn-pill { border-radius: var(--radius-pill); }

/* Outline — нейтральная вторичная кнопка. JSX:
 *   "border border-current/15 bg-transparent hover:bg-current/5"
 * У нас прозрачная с лёгким border для предсказуемости. */
.btn-outline {
  background: transparent;
  color: var(--text);
  border-color: var(--border);
}
.btn-outline:hover { background: var(--surface-2); border-color: var(--border-strong); }

/* Карточный secondary — solid surface (для кнопок в карточках). */
.btn-secondary {
  background: var(--surface);
  color: var(--text);
  border-color: var(--border);
}
.btn-secondary:hover { background: var(--surface-2); }

.btn-ghost {
  background: transparent;
  color: var(--text);
  border-color: transparent;
}
.btn-ghost:hover { background: var(--surface-2); }

/* Контекстные акцент-кнопки — каждая со своим identity, как в JSX. */

/* Map — зелёный pill для «На карте» в карточках */
.btn-map {
  background: var(--map-bg);
  color: var(--map-text);
  border-color: var(--map-border);
}
.btn-map:hover { background: var(--map-hover-bg); color: var(--map-text); }

/* Telegram — голубой для «написать в TG» */
.btn-tg {
  background: var(--tg-bg);
  color: var(--tg-text);
  border-color: transparent;
}
.btn-tg:hover { background: var(--tg-hover-bg); color: var(--tg-text); }

/* VK — голубой с border (отличается от TG, у JSX vk имеет border) */
.btn-vk {
  background: var(--vk-bg);
  color: var(--vk-text);
  border-color: var(--vk-border);
  font-weight: 700;
}
.btn-vk:hover { background: var(--vk-hover-bg); color: var(--vk-text); }

.btn-danger {
  background: var(--danger);
  color: #ffffff;
}
.btn-danger:hover { background: var(--danger); filter: brightness(1.08); }

@media (max-width: 480px) {
  .btn { min-height: 44px; }  /* touch targets на мобайле */
  .btn-sm { min-height: 36px; }
  .btn-icon { width: 44px; min-width: 44px; }
  .btn-icon.btn-sm { width: 36px; min-width: 36px; }
}

/* ───── Inputs ───────────────────────────────────────────────────────── */
/* JSX: rounded-xl, h-11, padding 0 12px, font-size 14, border --border-input.
 * Touch-target ≥44px на мобиле — у нас уже h-44 base.
 * Focus ring через accent-weak shadow (тонкий glow). */
.input,
input:not([type="range"], [type="checkbox"], [type="radio"], [type="submit"],
          [type="button"], [type="reset"], [type="file"], [type="color"],
          [type="image"]),
textarea,
select {
  width: 100%;
  min-height: 44px;
  padding: 0 14px;
  font: inherit;
  font-size: 14px;
  color: var(--text);
  background: var(--input-bg);
  border: 1px solid var(--border-input);
  border-radius: var(--radius-md);     /* 12px */
  transition: border-color 150ms var(--ease), box-shadow 150ms var(--ease),
              background 150ms var(--ease);
}
textarea { padding: 10px 14px; min-height: 100px; line-height: 1.5; }

.input:focus,
input:not([type="range"], [type="checkbox"], [type="radio"], [type="submit"],
          [type="button"], [type="reset"]):focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-weak);
}

input::placeholder, textarea::placeholder {
  color: var(--text-muted);
  opacity: 1;
}

label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: 6px;
  letter-spacing: 0.005em;
}

/* На мобайле iOS zoom'ит при font-size <16px — поэтому 16px на узких. */
@media (max-width: 480px) {
  .input,
  input:not([type="range"], [type="checkbox"], [type="radio"], [type="submit"],
            [type="button"], [type="reset"], [type="file"], [type="color"]),
  textarea, select { font-size: 16px; }
}

/* ───── Range slider — под нашу палитру ───────────────────────────────── */
input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 36px;
  background: transparent;
  padding: 0;
  cursor: pointer;
}
input[type="range"]:focus { outline: none; }

/* WebKit (Chrome/Safari) */
input[type="range"]::-webkit-slider-runnable-track {
  height: 6px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  height: 20px;
  width: 20px;
  margin-top: -8px;
  background: var(--accent);
  border: 2px solid var(--surface);
  border-radius: 50%;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: transform 100ms var(--ease), box-shadow 100ms var(--ease);
}
input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.1); }
input[type="range"]:focus-visible::-webkit-slider-thumb {
  box-shadow: 0 0 0 4px var(--accent-weak);
}

/* Firefox */
input[type="range"]::-moz-range-track {
  height: 6px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
input[type="range"]::-moz-range-thumb {
  height: 20px;
  width: 20px;
  background: var(--accent);
  border: 2px solid var(--surface);
  border-radius: 50%;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
}
input[type="range"]:focus-visible::-moz-range-thumb {
  box-shadow: 0 0 0 4px var(--accent-weak);
}

/* Визуальный error-state инпутов (для client-side валидации) */
input.error, input[aria-invalid="true"] {
  border-color: var(--danger);
  background: var(--danger-weak);
}
.field-error {
  display: block;
  color: var(--danger);
  font-size: 13px;
  margin-top: var(--space-1);
  min-height: 1.3em;
}

/* ───── Cards ────────────────────────────────────────────────────────── */
/* JSX rounded-2xl (16px) для cards, padding 12-14px, soft shadow. */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);    /* 16px */
  padding: 14px;
  box-shadow: var(--shadow-sm);
}
.card-compact { padding: 12px; }

/* Panel — крупнее карточек, для секций фильтров и hero. JSX rounded-3xl. */
.panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-2xl);   /* 24px */
  padding: 18px;
  box-shadow: var(--shadow-sm);
}
.panel-compact { padding: 12px; }

/* ───── Pill / Badge ─────────────────────────────────────────────────── */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 600;
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--text);
  line-height: 1.4;
  letter-spacing: 0.005em;
}
.pill-new      { background: var(--info-weak);    color: var(--info); }
.pill-notified { background: var(--accent-weak);  color: var(--accent-text); }
.pill-spam     { background: var(--danger-weak);  color: var(--danger); }
.pill-expired  { background: var(--surface-2);    color: var(--text-muted); }
.pill-warning  { background: var(--warning-weak); color: var(--warning); }

/* ───── Chip — фильтр-чип (любое / за час / до 500 км / Пшеница) ──────── */
/* JSX: h-9 rounded-full px-3 text-sm font-medium. Активный — accent-weak
 * фон + accent-text цвет + solid accent-border (не rgba — иначе визуально
 * толщина бордера прыгает active/inactive). line-height: 1 убирает
 * наследование 1.5 от body — текст центрируется ровно через align-items. */
.chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 36px;
  padding: 0 14px;
  flex-shrink: 0;
  border: 1px solid var(--border-input);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text);
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: background 150ms var(--ease), border-color 150ms var(--ease),
              color 150ms var(--ease), transform 100ms var(--ease);
  white-space: nowrap;
  user-select: none;
  -webkit-appearance: none;
  appearance: none;
}
.chip:hover { background: var(--surface-2); border-color: var(--border-strong); }
.chip:active { transform: scale(0.97); }
.chip:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.chip.is-active,
.chip[aria-pressed="true"] {
  background: var(--accent-weak);
  border-color: var(--accent);
  color: var(--accent-text);
}

/* Mini-chip — для inline-метатэгов внутри карточек. */
.chip-sm {
  height: 28px;
  padding: 0 10px;
  font-size: 12px;
}

@media (max-width: 480px) {
  .chip { height: 40px; }
}

/* ───── Icons ─────────────────────────────────────────────────────────── */
/* SVG-спрайт `/static/icons.svg`. Использование:
 *   <svg class="icon" aria-hidden="true">
 *     <use href="/static/icons.svg#filter"/>
 *   </svg>
 * Все символы наследуют currentColor, stroke 2, round. По умолчанию 18×18,
 * модификаторы -sm/-md/-lg/-xl. flex-shrink: 0 защищает от сжимания
 * иконок в flex-row рядом с длинным текстом. */
.icon {
  display: inline-block;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  vertical-align: -3px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}
.icon-xs { width: 12px; height: 12px; vertical-align: -2px; }
.icon-sm { width: 14px; height: 14px; vertical-align: -2px; }
.icon-md { width: 16px; height: 16px; vertical-align: -2px; }
.icon-lg { width: 20px; height: 20px; vertical-align: -3px; }
.icon-xl { width: 24px; height: 24px; vertical-align: -4px; }

/* Polygon-based иконки (star) — используют fill, не stroke. */
.icon-fill { fill: currentColor; stroke: none; }

/* ───── Tables ───────────────────────────────────────────────────────── */
table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-body);
}
th, td {
  text-align: left;
  padding: var(--space-3) var(--space-3);
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
th {
  font-weight: 600;
  font-size: 13px;
  color: var(--text-muted);
  background: var(--surface-2);
  position: sticky;
  top: 0;
  z-index: 1;
}
tbody tr { transition: background 100ms var(--ease); }
tbody tr:hover { background: var(--surface-2); }

/* ───── Toast (снизу на мобайле, сверху справа на десктопе) ───────────── */
.toast-wrap {
  position: fixed;
  bottom: var(--space-4);
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  pointer-events: none;
  max-width: calc(100vw - var(--space-5));
}
@media (min-width: 768px) {
  .toast-wrap {
    top: var(--space-4); right: var(--space-4);
    bottom: auto; left: auto; transform: none;
    max-width: 400px;
  }
}
.toast {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-toast);
  font-size: 14px;
  color: var(--text);
  pointer-events: auto;
  animation: toast-in 200ms var(--ease);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.toast-error   { border-left-color: var(--danger); }
.toast-warning { border-left-color: var(--warning); }
@keyframes toast-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ───── Spinner для htmx-запросов ─────────────────────────────────────── */
.htmx-indicator {
  display: none;
  width: 14px; height: 14px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}
.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator { display: inline-block; }
.htmx-request { opacity: 0.7; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ───── Theme toggle ──────────────────────────────────────────────────── */
/* JSX: rounded-full h-9 w-9 — круглая icon-кнопка, как outline. */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px; height: 38px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  color: var(--text);
  cursor: pointer;
  transition: background 150ms var(--ease), border-color 150ms var(--ease);
}
.theme-toggle:hover { background: var(--surface-2); border-color: var(--border-strong); }
.theme-toggle svg { width: 16px; height: 16px; }

/* Конвенция: показываем иконку того, во ЧТО переключит клик.
 *   light-режим → луна (клик = перейти в dark).
 *   dark-режим  → солнце (клик = перейти в light). */

/* Default — пока тема не задана, следуем системе. */
.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: inline-block; }

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-toggle .icon-sun { display: inline-block; }
  :root:not([data-theme="light"]) .theme-toggle .icon-moon { display: none; }
}

/* Явный выбор пользователя: всегда перебивает system. */
[data-theme="light"] .theme-toggle .icon-sun { display: none !important; }
[data-theme="light"] .theme-toggle .icon-moon { display: inline-block !important; }

[data-theme="dark"] .theme-toggle .icon-sun { display: inline-block !important; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none !important; }

/* ───── Layout utilities ──────────────────────────────────────────────── */
.container { max-width: 1280px; margin: 0 auto; padding: 0 var(--space-4); }
.container-sm { max-width: 720px; }
.stack { display: flex; flex-direction: column; gap: var(--space-3); }
.stack-lg { gap: var(--space-5); }
.row { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.spacer { flex: 1; }

.muted     { color: var(--text-muted); font-size: var(--fs-small); }
.strong    { font-weight: 600; }
.mono      { font-family: var(--font-mono); }
.nowrap    { white-space: nowrap; }
.hidden    { display: none !important; }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); }
@media (max-width: 768px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
@media (min-width: 481px) and (max-width: 768px) {
  .grid-4 { grid-template-columns: 1fr 1fr; }
}

/* ───── hr ───────────────────────────────────────────────────────────── */
hr {
  border: 0;
  border-top: 1px solid var(--border);
  margin: var(--space-4) 0;
}

/* ───── Focus default (keyboard users) ────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 2px;
}
:focus:not(:focus-visible) { outline: none; }

/* ───── Pico override (только на /admin) ──────────────────────────────── */
/* Нижеследующее применяется если на странице подключён Pico: переключаем
 * его палитру на нашу, чтобы не переписывать все шаблоны. */
:root {
  --pico-background-color: var(--bg);
  --pico-color: var(--text);
  --pico-muted-color: var(--text-muted);
  --pico-primary: var(--accent);
  --pico-primary-background: var(--accent);
  --pico-primary-hover: var(--accent-hover);
  --pico-primary-focus: var(--accent-weak);
  --pico-form-element-background-color: var(--input-bg);
  --pico-form-element-border-color: var(--border);
  --pico-form-element-focus-color: var(--accent);
  --pico-card-background-color: var(--surface);
  --pico-card-border-color: var(--border);
  --pico-border-radius: var(--radius-md);
  --pico-font-family: var(--font-sans);
  --pico-font-size: var(--fs-body);
}
