/**
 * @file: variables.css
 * @description: CSS переменные для системы тем - полностью переработанная версия
 * @created: 2025-01-09
 * @updated: 2025-01-21
 */

@layer tokens {
/* ===== СВЕТЛАЯ ТЕМА (по умолчанию) ===== */
:root {
  /*
   * НОВАЯ СХЕМА ТОКЕНОВ (design tokens):
   * - surface-*   : фоновые уровни
   * - text-*      : текст (primary/secondary/muted/accent)
   * - on-*        : текст на цветных фонах (primary/warning/etc)
   * Важно: для обратной совместимости сохраняем существующие --bg-* / --text-* / --primary-*.
   */

  /* Surface */
  --surface-0: #ffffff;
  --surface-1: #f8f9fa;
  --surface-2: #e9ecef;
  --surface-3: #dee2e6;
  /* Back-compat: bg-* */
  --bg-primary: var(--surface-0);
  --bg-secondary: var(--surface-1);
  --bg-tertiary: var(--surface-2);
  --bg-quaternary: var(--surface-3);
  
  /* Размеры аватаров (вернули прежние значения) */
  --avatar-size: 24px;
  --avatar-size-large: 48px;
  
  /* Text */
  --text-primary: #212529;
  --text-secondary: #6c757d;
  --text-muted: #adb5bd;
  --text-inverse: #ffffff;
  --text-hover: #495057;

  /* Accent text (используем точечно, не как основной) */
  --text-accent: var(--primary);

  /* On-color (текст на заливках) */
  --on-primary: #ffffff;
  --on-secondary: #ffffff;
  --on-success: #0b1b0b;
  --on-danger: #ffffff;
  --on-warning: #212529;
  --on-info: #ffffff;

  /* Bootstrap color vars (чтобы утилиты типа .text-muted работали предсказуемо) */
  --bs-body-bg: var(--surface-0);
  --bs-body-color: var(--text-primary);
  --bs-secondary-color: var(--text-secondary);
  --bs-tertiary-color: var(--text-muted);
  --bs-emphasis-color: var(--text-primary);
  --bs-border-color: var(--border-color);
  --bs-link-color: var(--link);
  --bs-link-hover-color: var(--link-hover);
  
  /* Границы */
  --border-color: #dee2e6;
  --border-light: #e9ecef;
  --border-dark: #adb5bd;
  --border-hover: #6c757d;
  
  /* Акцентные цвета */
  --primary: #0077b6;
  --primary-hover: #005f8c;
  --secondary: #6c757d;
  --secondary-hover: #5c636a;
  --success: #32CD32;
  --success-hover: #28a745;
  --danger: #ff3333;
  --danger-hover: #ff0000;
  --warning: #ffa500;
  --warning-hover: #ff8c00;
  --info: #0077b6;
  --info-hover: #005f8c;
  --pilot: #0077b6;
  --pilot-hover: #005f8c;

  /* Градиенты для светлой темы */
  --gradient-primary: linear-gradient(135deg, #0077b6 0%, #005f8c 100%);
  --gradient-secondary: linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
  --gradient-header: linear-gradient(135deg, #0077b6 0%, #005f8c 100%);
  
  /* Цвета для toast уведомлений */
  --success-color: #32CD32;
  --danger-color: #ff3333;
  --warning-color: #ffa500;
  --info-color: #0077b6;
  
  /* Тени */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  
  /* Радиусы */
  --radius-sm: 0.25rem;
  --radius: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-2xl: 1.5rem;
  
  /* Переходы */
  --transition-fast: 0.15s ease-in-out;
  --transition-normal: 0.3s ease-in-out;
  --transition-slow: 0.5s ease-in-out;
  
  /* Z-index */
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;
  
  /* Переменные для погодных блоков (светлая тема) */
  --practice-weather-bg: #e3f2fd;
  --practice-weather-border: #90caf9;
  --practice-weather-text: #1565c0;
  --qualify-weather-bg: #fff8e1;
  --qualify-weather-border: #ffcc02;
  --qualify-weather-text: #e65100;
  --race-weather-bg: #e8f5e8;
  --race-weather-border: #81c784;
  --race-weather-text: #2e7d32;
}

/* ===== ТЕМНАЯ ТЕМА ===== */
[data-theme="dark"] {
  color-scheme: dark;

  /* Racing Dark Luxury palette */
  --bg-main: #07090d;
  --bg-secondary: #0d1117;
  --bg-panel: #11161d;
  --carbon: #161b22;
  --metal-dark: #1f242b;
  --metal-light: #2c323a;
  --accent-red: #ff2b2b;
  --accent-red-glow: #ff3c3c;
  --accent-dark-red: #8b1111;
  --gold: #c8a45d;

  /* Surface */
  --surface-0: var(--bg-main);
  --surface-1: var(--bg-secondary);
  --surface-2: var(--bg-panel);
  --surface-3: var(--metal-dark);

  /* Основные цвета фона */
  --bg-primary: var(--surface-0);
  --bg-secondary: var(--surface-1);
  --bg-tertiary: var(--surface-2);
  --bg-quaternary: var(--surface-3);

  /* Размеры аватаров (наследуются от :root, дублируем явно для ясности) */
  --avatar-size: 24px;
  --avatar-size-large: 48px;

  /* Text */
  --text-primary: #f1f5f9;
  --text-secondary: #a8b0bb;
  --text-muted: #6f7a87;
  /* Back-compat: инверсный текст (много legacy кода использует var(--text-inverse)) */
  --text-inverse: #ffffff;
  --text-hover: #ffffff;

  /* Accent text */
  --text-accent: var(--accent-red-glow);

  /* Границы */
  --border-color: rgba(255, 255, 255, 0.10);
  --border-light: rgba(255, 255, 255, 0.06);
  --border-dark: rgba(255, 255, 255, 0.20);
  --border-hover: rgba(255, 43, 43, 0.42);
  --border-accent: rgba(255, 40, 40, 0.15);

  /* Акцентные цвета */
  --primary: var(--accent-red);
  --primary-hover: var(--accent-dark-red);
  --secondary: #a8b0bb;
  --secondary-hover: #cbd5e1;
  --success: #31c48d;
  --success-hover: #28a876;
  --danger: #ff4d4d;
  --danger-hover: #d91d1d;
  --warning: #ffa500;
  --warning-hover: #ff8c00;
  --info: #c8a45d;
  --info-hover: #e3c27a;
  --pilot: var(--accent-red);
  --pilot-hover: var(--accent-red-glow);

  /* Цвета для toast уведомлений */
  --success-color: #31c48d;
  --danger-color: #ff4d4d;
  --warning-color: #ffa500;
  --info-color: #c8a45d;

  /* Тени и glow */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow: 0 8px 24px rgba(0, 0, 0, 0.42);
  --shadow-lg: 0 18px 46px rgba(0, 0, 0, 0.55);
  --shadow-xl: 0 28px 70px rgba(0, 0, 0, 0.68);
  --shadow-panel: 0 18px 45px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.04);
  --glow-red-sm: 0 0 8px rgba(255, 40, 40, 0.15), 0 0 22px rgba(255, 40, 40, 0.08);
  --glow-red-md: 0 0 14px rgba(255, 40, 40, 0.25), 0 0 36px rgba(255, 40, 40, 0.12);
  --glow-gold-md: 0 0 16px rgba(200, 164, 93, 0.22), 0 0 34px rgba(200, 164, 93, 0.12);

  /* Переменные для погодных блоков (темная тема) */
  --practice-weather-bg: rgba(31, 36, 43, 0.92);
  --practice-weather-border: rgba(255, 43, 43, 0.24);
  --practice-weather-text: #f1f5f9;
  --qualify-weather-bg: rgba(139, 17, 17, 0.42);
  --qualify-weather-border: rgba(255, 43, 43, 0.35);
  --qualify-weather-text: #ffd6d6;
  --race-weather-bg: rgba(31, 36, 43, 0.92);
  --race-weather-border: rgba(200, 164, 93, 0.35);
  --race-weather-text: #e9d7b2;

  /* Градиенты для темной темы */
  --gradient-primary: linear-gradient(180deg, #ff3434 0%, #b81212 100%);
  --gradient-secondary: linear-gradient(145deg, var(--bg-panel) 0%, #0b0f14 100%);
  --gradient-header: linear-gradient(180deg, #131820 0%, #0c1015 100%);
  --header-primary-bg: var(--gradient-header);
  --on-header-primary: #ffffff;

  /* Typography */
  --font-display: 'Rajdhani', 'Orbitron', 'Exo 2', 'Segoe UI', sans-serif;
  --font-body: 'Inter', 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Bootstrap color vars (dark) */
  --bs-body-bg: var(--surface-0);
  --bs-body-color: var(--text-primary);
  --bs-primary: var(--accent-red);
  --bs-primary-rgb: 255, 43, 43;
  --bs-secondary: var(--secondary);
  --bs-secondary-rgb: 168, 176, 187;
  --bs-success: var(--success);
  --bs-success-rgb: 49, 196, 141;
  --bs-info: var(--info);
  --bs-info-rgb: 200, 164, 93;
  --bs-warning: var(--warning);
  --bs-warning-rgb: 255, 165, 0;
  --bs-danger: var(--danger);
  --bs-danger-rgb: 255, 77, 77;
  --bs-secondary-color: var(--text-secondary);
  --bs-tertiary-color: var(--text-muted);
  --bs-emphasis-color: var(--text-primary);
  --bs-border-color: var(--border-color);
  --bs-border-color-translucent: rgba(255, 255, 255, 0.14);
  --bs-link-color: var(--link);
  --bs-link-hover-color: var(--link-hover);
  --bs-card-color: var(--text-primary);
  --bs-primary-text-emphasis: #ff9a9a;
  --bs-primary-bg-subtle: rgba(139, 17, 17, 0.30);
  --bs-primary-border-subtle: rgba(255, 43, 43, 0.38);
  --bs-secondary-bg: var(--metal-dark);
  --bs-secondary-bg-rgb: 31, 36, 43;
  --bs-tertiary-bg: var(--bg-panel);
  --bs-tertiary-bg-rgb: 17, 22, 29;
}

/* ===== ТОКЕНЫ ДЛЯ КОНТРАСТА И СОСТОЯНИЙ (общие) ===== */
:root {
  --header-primary-bg: var(--gradient-header);
  --on-header-primary: var(--text-inverse);

  --link: var(--primary);
  --link-hover: var(--primary-hover);
  --focus-ring: var(--primary);
}

/* Dark overrides для on-* (текст на заливках) */
[data-theme="dark"] {
  --on-primary: #ffffff;
  --on-secondary: #07090d;
  --on-success: #06120d;
  --on-danger: #ffffff;
  --on-warning: #212529;
  --on-info: #07090d;

  --on-header-primary: #ffffff;

  --link: var(--text-accent);
  --link-hover: #ff9a9a;
  --focus-ring: var(--text-accent);
}

/* ===== ОБЩИЕ СТИЛИ ДЛЯ ВСЕХ ТЕМ ===== */
* {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  line-height: 1.5;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;
  background-color: var(--bg-primary);
  color: var(--text-primary);
  transition: background-color var(--transition-normal), color var(--transition-normal);
}

/* ===== УТИЛИТЫ ДЛЯ ТЕМ ===== */
.theme-transition {
  transition: background-color var(--transition-normal), 
              color var(--transition-normal), 
              border-color var(--transition-normal),
              box-shadow var(--transition-normal);
}

.text-theme-primary {
  color: var(--text-primary) !important;
}

.text-theme-secondary {
  color: var(--text-secondary) !important;
}

.text-theme-muted {
  color: var(--text-muted) !important;
}

.bg-theme-primary {
  background-color: var(--bg-primary) !important;
}

.bg-theme-secondary {
  background-color: var(--bg-secondary) !important;
}

.bg-theme-tertiary {
  background-color: var(--bg-tertiary) !important;
}

.border-theme {
  border-color: var(--border-color) !important;
}

.border-theme-light {
  border-color: var(--border-light) !important;
}

.border-theme-dark {
  border-color: var(--border-dark) !important;
}