:root {
  --primary-color: #000000; /* Основной цвет */
  --secondary-color: #47fdad; /* Акцентный цвет */
  --text-color: #000000; /* Цвет текста */
  --button-text-color: #FFFFFF; 
  --background-color: #fbfbfc; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: #000000; /* Цвет иконок навбара */

  --br-xs: 10px;

  .custom-select-trigger .arrow {
    border-top: 6px solid var(--button-text-color); /* Треугольник */
  }
}

:root.default-black {
  --primary-color: #000000; /* Основной цвет */
  --secondary-color: #47fdad; /* Акцентный цвет */
  --text-color: #fbfbfc; /* Цвет текста */
  --button-text-color: #fbfbfc; 
  --background-color: #000000; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: var(--text-color); /* Цвет иконок навбара */

  --br-xs: 10px;
  
  .btn.danger-grey, #rooms li, .card, .custom-select-trigger, .divider {
    background-color: var(--glass-bg, rgba(0, 0, 0, 0.15));
    color: var(--text-color);
  }

  .toggle-switch input:checked + label {
    background-color: var(--secondary-color);
  }

  .controls button, #rooms li button, .mode-radio.active, #add-first-player-btn {
    color: var(--primary-color);
  }
}


:root.default-white {
  --primary-color: #7228F5; /* Основной цвет */
  --secondary-color: #A0FF00; /* Акцентный цвет */
  --text-color: #000000; /* Цвет текста */
  --button-text-color: #FFFFFF; 
  --background-color: #FFFFFF; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: #7228F5; /* Тёмный цвет иконок для светлой темы */
}

:root.default-violet {
  --primary-color: #7228F5; /* Основной цвет */
  --secondary-color: #A0FF00; /* Акцентный цвет */
  --text-color: #FFFFFF; /* Цвет текста */
  --button-text-color: #FFFFFF; 
  --background-color: #000000; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: #7228F5;
}

:root.space-explorer {
  --primary-color: #001F3F;
  --secondary-color: #A6A6A6;
  --text-color: #000000;
  --background-color: #FFFFFF;
  --header-footer-color: #001F3F;
  --button-color: #A6A6A6; /* Серебристые кнопки */
  --card-color: #001F3F; /* Цвет карточек */
  --nav-btn-color: #001F3F;
}

:root.ocean-depths {
  --primary-color: #1B4D3E;
  --secondary-color: #56C8D8;
  --text-color: #FFFFFF;
  --background-color: #09080d;
  --header-footer-color: #1B4D3E;
  --button-color: #56C8D8; 
  --card-color: #1B4D3E; /* Цвет карточек */
  --nav-btn-color: #ffffff;
}

:root.neon-experiment {
  --primary-color: #191bdf;
  --secondary-color: #fe6807;
  --text-color: #FFFFFF;
  --background-color: #09080d;
  --header-footer-color: #191bdf;
  --button-color: #fe6807; 
  --card-color: #191bdf; /* Цвет карточек */
  --nav-btn-color: #ffffff;
}

:root.midnight-meon {
  --primary-color: #7231ff; /* Основной цвет */
  --secondary-color: #ffc01d; /* Акцентный цвет */
  --text-color: #FFFFFF; /* Цвет текста */
  --button-text-color: #FFFFFF; 
  --background-color: #07080a; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: #ffffff;
}

:root.mystic-pastel {
  --primary-color: #c68dfe; /* Основной цвет */
  --secondary-color: #c9e957; /* Акцентный цвет */
  --text-color: #FFFFFF; /* Цвет текста */
  --button-text-color: #FFFFFF; 
  --background-color: #303843; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: #ffffff;
}

:root.urban-contrast {
  --primary-color: #121318; /* Основной цвет */
  --secondary-color: #ff740f; /* Акцентный цвет */
  --text-color: #121318; /* Цвет текста */
  --button-text-color: #121318; 
  --background-color: #f0f0f0; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: #121318;
}

:root.forest-harmony {
  --primary-color: #133115; /* Основной цвет */
  --secondary-color: #f3e8d4; /* Акцентный цвет */
  --text-color: #121318; /* Цвет текста */
  --button-text-color: #121318; 
  --background-color: #92b774; /* Общий фон */
  --header-footer-color: var(--primary-color); /* Цвет хедера и футера */
  --button-color: var(--secondary-color); /* Цвет кнопок */
  --card-color: var(--primary-color); /* Цвет карточек */
  --nav-btn-color: #133115;
}

:root.new-year {
  --primary-color: #ff4e50; /* Основной праздничный цвет */
  --secondary-color: #f9d423; /* Акцентный цвет, напоминающий золотой */
  --text-color: #ffffff; /* Цвет текста */
  --button-text-color: #ffffff; /* Цвет текста на кнопках */
  --background-color: #1a1a2e; /* Тёмный фон, создающий контраст */
  --header-footer-color: #ff4e50; /* Красный для хедера и футера */
  --button-color: #f9d423; /* Золотой цвет кнопок */
  --card-color: #e84545; /* Цвет карточек, яркий и праздничный */
  --nav-btn-color: #ffffff;
}

:root.golden-hour {
  --primary-color: #FFB74D; /* Золотистый основной */
  --secondary-color: #FF8A65; /* Персиковый акцент */
  --text-color: #4E342E; /* Цвет текста */
  --button-text-color: #FFFFFF; 
  --background-color: #FFF3E0; /* Тёплый светлый фон */
  --header-footer-color: #FFB74D; /* Золотистый для хедера и футера */
  --button-color: #FF8A65; /* Персиковый цвет кнопок */
  --card-color: #FFB74D; /* Цвет карточек */
  --nav-btn-color: #4E342E;
}

:root.cyberpunk-neon {
  --primary-color: #FF007F; /* Ярко-розовый */
  --secondary-color: #00FFFF; /* Неоновый голубой */
  --text-color: #FFFFFF; /* Белый текст */
  --button-text-color: #000000; 
  --background-color: #121212; /* Тёмный фон */
  --header-footer-color: #FF007F; /* Ярко-розовый для хедера и футера */
  --button-color: #00FFFF; /* Голубые кнопки */
  --card-color: #FF007F; /* Цвет карточек */
  --nav-btn-color: #ffffff;
}

:root.spring-blossom {
  --primary-color: #FFB7C5; /* Светло-розовый */
  --secondary-color: #9FE2BF; /* Мятный акцент */
  --text-color: #4B0082; /* Тёмно-фиолетовый текст */
  --button-text-color: #FFFFFF; 
  --background-color: #FFFAF0; /* Сливочно-белый фон */
  --header-footer-color: #FFB7C5; /* Розовый для хедера и футера */
  --button-color: #9FE2BF; /* Мятный для кнопок */
  --card-color: #FFB7C5; /* Цвет карточек */
  --nav-btn-color: #4B0082;
}

:root.autumn-leaves {
  --primary-color: #8B4513; /* Коричневый */
  --secondary-color: #FFA500; /* Оранжевый */
  --text-color: #000000; 
  --button-text-color: #000000; 
  --background-color: #FFF5EE; /* Светлый кремовый */
  --header-footer-color: #8B4513; /* Коричневый для хедера и футера */
  --button-color: #FFA500; /* Оранжевый цвет кнопок */
  --card-color: #8B4513; /* Цвет карточек */
  --nav-btn-color: #8B4513;
}

:root.galaxy-dreams {
  --primary-color: #2C3E50; /* Глубокий тёмно-синий */
  --secondary-color: #8E44AD; /* Фиолетовый акцент */
  --text-color: #ECF0F1; /* Светлый текст */
  --button-text-color: #FFFFFF; 
  --background-color: #1A1A2E; /* Тёмный фон */
  --header-footer-color: #2C3E50; /* Синий для хедера и футера */
  --button-color: #8E44AD; /* Фиолетовые кнопки */
  --card-color: #2C3E50; /* Цвет карточек */
  --nav-btn-color: #ffffff;
}

:root.minimal-elegance {
  --primary-color: #000000; /* Чёрный */
  --secondary-color: #FFFFFF; /* Белый */
  --text-color: #000000; 
  --button-text-color: #FFFFFF; 
  --background-color: #F5F5F5; /* Светло-серый */
  --header-footer-color: #000000; /* Чёрный для хедера и футера */
  --button-color: #FFFFFF; /* Белые кнопки */
  --card-color: #000000; /* Чёрные карточки */
  --nav-btn-color: #000000;
}

:root.tropical-sunset {
  --primary-color: #FF6347; /* Томатный */
  --secondary-color: #FFD700; /* Золотисто-жёлтый */
  --text-color: #FFFFFF; 
  --button-text-color: #000000; 
  --background-color: #FFA07A; /* Светло-коралловый */
  --header-footer-color: #FF6347; /* Томатный для хедера и футера */
  --button-color: #FFD700; /* Золотисто-жёлтые кнопки */
  --card-color: #FF6347; /* Цвет карточек */
  --nav-btn-color: #7a1f00;
}

.prime {
  color: var(--secondary-color);
  filter: drop-shadow(0 0 6px color-mix(in srgb, var(--button-color) 70%, transparent));
}

/* Индикатор NEW */
.indicator {
  background-color: #FF3D00;
  color: white;
  font-size: 0.8rem;
  padding: 2px 5px;
  border-radius: var(--br-xs);
  margin-left: 10px;
  font-weight: 600;
}

/* Если это select */
select option.new {
  font-weight: 600;
  color: #FF3D00;
}

/* Для кастомного селектора */
.custom-option.new {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.custom-option.new .indicator {
  margin-left: auto;
}


#hint-container {
  position: fixed;
  top: 10px; 
  right: 10px; 
  z-index: 9999; 
  background: var(--secondary-color); 
  color: #000; 
  padding: 10px; 
  border-radius: var(--br-xs); 
  display: none;
  font-family: 'Montserrat', 'sans-serif';
  box-shadow: 0 0 10px rgba(0,0,0,0.3);
}

/* Новый лоадер */
#loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: #000000; /* Чёрный фон */
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  transition: opacity 0.6s ease-out;
  opacity: 1;
}

.loader-container {
  text-align: center;
  color: white;
}

.loader-logo {
  width: auto;
  height: 220px;
  margin-bottom: 20px;
  border-radius: 999px;
  background: linear-gradient(90deg, #47fdad, #7228F5);
  animation: pulse 2s infinite;

}

.loader-title {
  font-size: 1.8em;
  margin: 0 0 30px 0;
  font-weight: bold;
  /* letter-spacing: 2px; */
  /* background: linear-gradient(90deg, #47fdad, #7228F5); */
  background: white;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.loader-text {
  font-size: 0.7em;
  margin: 20px 0;
  min-height: 1.5em;
  opacity: 0.9;
  font-style: italic;
}

.loader-spinner {
  width: 50px;
  height: 50px;
  border: 4px solid rgba(71, 253, 173, 0.3);
  border-top: 4px solid #47fdad;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin: 30px auto;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

@keyframes pulse {
  0% { box-shadow: 0 0 20px rgba(71, 253, 173, 0.5); }
  50% { box-shadow: 0 0 50px rgba(71, 253, 173, 0.8); }
  100% { box-shadow: 0 0 20px rgba(71, 253, 173, 0.5); }
}

/* Когда лоадер скрывается */
#loader.hidden {
  opacity: 0;
  pointer-events: none;
}





/* Общие стили для кнопок */
button {
  background-color: var(--button-color);
  color: var(--text-color);
  border: none;
  padding: 10px;
  border-radius:  var(--br-xs);
  cursor: pointer;
  font-size: 1em;
  transition: background-color 0.3s ease, color 0.3s ease;
}

button:hover {
  background-color: var(--primary-color);
}

/* Стили списка комнат */
#rooms li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--card-color); /* Цвет карточек меняется в зависимости от темы */
  /* color: var(--text-color); */
  color: #FFFFFF;
  margin: 10px 0;
  padding: 10px;
  border-radius: var(--br-xs);
  /* box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); */
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
}

#rooms li h3 {
  margin: 0;
  flex: 1;
  font-size: 1.5em;
}

#rooms li p {
  margin: 0 10px;
  font-size: 0.9em;
}

#rooms li button {
  background: var(--button-color); /* Акцентный цвет кнопок */
  color: var(--button-text-color);
  border-radius: 50%;
}

#rooms li button:hover {
  background: var(--primary-color); /* Основной цвет при наведении */
}

/* ===== GLASS VARS: все темы ===== */

/* DEFAULT — зелёный светлый фон */
:root {
  --glass-bg: rgba(255, 255, 255, 0.75);
  --glass-border: rgba(255, 255, 255, 0.08);
  --modal-bg: rgba(251, 251, 252, 0.85);
  --modal-overlay: rgba(0, 0, 0, 0.55);
}

/* DEFAULT-VIOLET — тёмный зелёный фон */
:root.default-black {
  --glass-bg: rgba(42, 43, 52, 0.6);
  --glass-border: rgba(160, 255, 0, 0.12);
  --modal-bg: rgba(42, 43, 52, 0.92);
  --modal-overlay: rgba(0, 0, 0, 0.6);
}

/* DEFAULT-WHITE — чисто белый, светлая тема */
:root.default-white {
  --glass-bg: rgba(255, 255, 255, 0.75);
  --glass-border: rgba(114, 40, 245, 0.18);
  --modal-bg: rgba(255, 255, 255, 0.95);
  --modal-overlay: rgba(0, 0, 0, 0.35);
}

/* DEFAULT-VIOLET — тёмный серый фон */
:root.default-violet {
  --glass-bg: rgba(42, 43, 52, 0.6);
  --glass-border: rgba(160, 255, 0, 0.12);
  --modal-bg: rgba(42, 43, 52, 0.92);
  --modal-overlay: rgba(0, 0, 0, 0.6);
}

/* SPACE-EXPLORER — белый фон, тёмно-синие акценты */
:root.space-explorer {
  --glass-bg: rgba(255, 255, 255, 0.78);
  --glass-border: rgba(0, 31, 63, 0.18);
  --modal-bg: rgba(255, 255, 255, 0.95);
  --modal-overlay: rgba(0, 0, 0, 0.35);
}

/* OCEAN-DEPTHS — очень тёмный фон */
:root.ocean-depths {
  --glass-bg: rgba(9, 8, 13, 0.5);
  --glass-border: rgba(86, 200, 216, 0.15);
  --modal-bg: rgba(20, 30, 40, 0.92);
  --modal-overlay: rgba(0, 0, 0, 0.65);
}

/* NEON-EXPERIMENT — очень тёмный фон */
:root.neon-experiment {
  --glass-bg: rgba(9, 8, 13, 0.5);
  --glass-border: rgba(254, 104, 7, 0.2);
  --modal-bg: rgba(15, 15, 25, 0.93);
  --modal-overlay: rgba(0, 0, 0, 0.65);
}

/* MIDNIGHT-NEON — почти чёрный фон */
:root.midnight-meon {
  --glass-bg: rgba(7, 8, 10, 0.55);
  --glass-border: rgba(255, 192, 29, 0.15);
  --modal-bg: rgba(15, 12, 25, 0.93);
  --modal-overlay: rgba(0, 0, 0, 0.7);
}

/* MYSTIC-PASTEL — тёмно-серый фон */
:root.mystic-pastel {
  --glass-bg: rgba(48, 56, 67, 0.55);
  --glass-border: rgba(198, 141, 254, 0.18);
  --modal-bg: rgba(48, 56, 67, 0.92);
  --modal-overlay: rgba(0, 0, 0, 0.55);
}

/* URBAN-CONTRAST — светлый серый фон */
:root.urban-contrast {
  --glass-bg: rgba(240, 240, 240, 0.82);
  --glass-border: rgba(18, 19, 24, 0.15);
  --modal-bg: rgba(240, 240, 240, 0.95);
  --modal-overlay: rgba(0, 0, 0, 0.35);
}

/* FOREST-HARMONY — зелёный средний фон */
:root.forest-harmony {
  --glass-bg: rgba(19, 49, 21, 0.45);
  --glass-border: rgba(243, 232, 212, 0.18);
  --modal-bg: rgba(146, 183, 116, 0.88);
  --modal-overlay: rgba(0, 0, 0, 0.45);
}

/* NEW-YEAR — тёмно-синий фон */
:root.new-year {
  --glass-bg: rgba(26, 26, 46, 0.55);
  --glass-border: rgba(249, 212, 35, 0.18);
  --modal-bg: rgba(26, 26, 46, 0.92);
  --modal-overlay: rgba(0, 0, 0, 0.65);
}

/* GOLDEN-HOUR — тёплый светлый фон */
:root.golden-hour {
  --glass-bg: rgba(255, 243, 224, 0.82);
  --glass-border: rgba(255, 183, 77, 0.30);
  --modal-bg: rgba(255, 248, 235, 0.96);
  --modal-overlay: rgba(80, 40, 10, 0.35);
}

/* CYBERPUNK-NEON — почти чёрный фон */
:root.cyberpunk-neon {
  --glass-bg: rgba(18, 18, 18, 0.55);
  --glass-border: rgba(0, 255, 255, 0.18);
  --modal-bg: rgba(18, 18, 18, 0.93);
  --modal-overlay: rgba(255, 0, 127, 0.2);
}

/* SPRING-BLOSSOM — сливочно-белый фон */
:root.spring-blossom {
  --glass-bg: rgba(255, 250, 240, 0.82);
  --glass-border: rgba(255, 183, 197, 0.35);
  --modal-bg: rgba(255, 250, 240, 0.96);
  --modal-overlay: rgba(75, 0, 130, 0.2);
}

/* AUTUMN-LEAVES — светлый кремовый фон */
:root.autumn-leaves {
  --glass-bg: rgba(255, 245, 238, 0.82);
  --glass-border: rgba(139, 69, 19, 0.20);
  --modal-bg: rgba(255, 245, 238, 0.96);
  --modal-overlay: rgba(80, 30, 0, 0.3);
}

/* GALAXY-DREAMS — тёмный фон */
:root.galaxy-dreams {
  --glass-bg: rgba(26, 26, 46, 0.55);
  --glass-border: rgba(142, 68, 173, 0.2);
  --modal-bg: rgba(26, 26, 46, 0.92);
  --modal-overlay: rgba(0, 0, 0, 0.65);
}

/* MINIMAL-ELEGANCE — светло-серый фон */
:root.minimal-elegance {
  --glass-bg: rgba(245, 245, 245, 0.85);
  --glass-border: rgba(0, 0, 0, 0.12);
  --modal-bg: rgba(245, 245, 245, 0.98);
  --modal-overlay: rgba(0, 0, 0, 0.3);
}

/* TROPICAL-SUNSET — коралловый фон */
:root.tropical-sunset {
  --glass-bg: rgba(255, 160, 122, 0.45);
  --glass-border: rgba(255, 215, 0, 0.25);
  --modal-bg: rgba(255, 140, 100, 0.88);
  --modal-overlay: rgba(80, 20, 0, 0.4);
}

/* ========================================
   🖤 ONYX — глубокий тёмный камень
   ======================================== */
:root.onyx {
  --primary-color: #5865f2;        /* Холодный discord-фиолетовый */
  --secondary-color: #5865f2;      /* Ледяной акцент */
  --text-color: #e8eaf6;           /* Мягкий светлый текст */
  --button-text-color: #ffffff;
  --background-color: #050509;     /* Почти чёрный, onyx-камень */
  --header-footer-color: #181824;
  --button-color: #5865f2;
  --card-color: #0c0c11;           /* Глубокий тёмный для карточек */
  --nav-btn-color: #e8eaf6;

  /* Glass */
  --glass-bg: rgba(8, 8, 20, 0.70);
  --glass-border: rgba(88, 101, 242, 0.28);
  --modal-bg: rgba(11, 11, 16, 0.96);
  --modal-overlay: rgba(0, 0, 0, 0.80);

  /* Тени с холодным свечением */
  --shadow-sm: 0 2px 6px rgba(0, 0, 0, 0.7);
  --shadow-md: 0 4px 14px rgba(0, 0, 0, 0.9), 0 0 10px rgba(88, 101, 242, 0.32);
  --shadow-lg: 0 10px 30px rgba(0, 0, 0, 0.95), 0 0 22px rgba(88, 101, 242, 0.38);
}

/* ===== HEADER + NAVBAR ===== */
header, .navbar {
  background: var(--glass-bg);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--glass-border);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
  transition: background 0.7s ease;
}

/* Светлые темы — усиленный стеклянный эффект, чтобы контент под шапкой не просвечивал грязно */
:root.default-white header,
:root.default-white .navbar,
:root.space-explorer header,
:root.space-explorer .navbar,
:root.urban-contrast header,
:root.urban-contrast .navbar,
:root.golden-hour header,
:root.golden-hour .navbar,
:root.spring-blossom header,
:root.spring-blossom .navbar,
:root.autumn-leaves header,
:root.autumn-leaves .navbar,
:root.minimal-elegance header,
:root.minimal-elegance .navbar,
:root.forest-harmony header,
:root.forest-harmony .navbar,
:root.tropical-sunset header,
:root.tropical-sunset .navbar {
  backdrop-filter: blur(24px) saturate(200%);
  -webkit-backdrop-filter: blur(24px) saturate(200%);
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.12);
}

/* Onyx — усиленное свечение */
:root.onyx header,
:root.onyx .navbar {
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.7), 0 0 16px rgba(88, 101, 242, 0.2);
}

/* ===== MODAL OVERLAY + BLUR ===== */
.modal {
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  background: var(--modal-overlay, rgba(0, 0, 0, 0.55)) !important;
}

.modal-content {
  background: var(--modal-bg, var(--background-color)) !important;
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  border: 1px solid var(--glass-border, rgba(255,255,255,0.08));
}

.modal-content-clear {
  background: var(--modal-bg, var(--background-color)) !important;
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  border: 1px solid var(--glass-border, rgba(255,255,255,0.08));
}



/* Остальной интерфейс */
body {
  background-color: var(--background-color);
  color: var(--text-color);
  transition: background-color 0.7s ease, color 0.7s ease;
}



/* Стили для карточек игроков */
.card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: var(--card-color); /* Цвет карточки игрока зависит от темы */
  color: var(--text-color);
  margin: 10px 0;
  padding: 10px;
  border-radius: var(--br-xs);
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
  transition: background-color 0.3s ease, color 0.3s ease;
}

.card-info h3 {
  margin: 0;
  font-size: 1.2em;
}

.card-info p {
  margin: 5px 0 0;
  font-size: 1em;
}

.controls {
  display: flex;
  gap: 10px;
}

.controls button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  color: var(--text-color);
  transition: background-color 0.3s ease, color 0.3s ease;
}

.controls button:hover {
  background-color: var(--primary-color); /* Основной цвет при наведении */
}

.delete-btn {
  background-color: var(--button-text-color); /* Цвет кнопки удаления */
}

.delete-btn:hover {
  background-color: var(--primary-color);
}

.add-btn {
  background-color: var(--secondary-color); /* Цвет кнопки добавления */
}

.add-btn:hover {
  background-color: var(--primary-color);
}


.modal-content {
  color: var(--text-color);
  box-shadow: 0px 2px 30px rgba(0, 0, 0, 0.25);
}
.modal-content-clear {
  color: var(--text-color);
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
}

#cancel-add-player, #cancel-add-points {
  background-color: var(--primary-color);
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
  color: #fff;
}

.undo-btn {
  width: 100%;
  margin-top: 8px;
  padding: 10px 16px;
  background: transparent;
  border: 2px dashed var(--primary-color);
  color: var(--primary-color);
  border-radius: 10px;
  font-size: 0.9rem;
  cursor: pointer;
  opacity: 0.85;
  transition: opacity 0.2s, background 0.2s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.undo-btn:hover {
  opacity: 1;
  background: rgba(var(--primary-color-rgb, 100,100,200), 0.08);
}

.undo-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/* Общие стили */

img {
  user-select: none; /* Запрет на выделение */
  -webkit-user-drag: none; /* Отключение перетаскивания в WebKit-браузерах */
  pointer-events: none; /* Отключение любых взаимодействий с мышью (опционально) */
}

img, a {
  -webkit-user-drag: none; /* Отключает перетаскивание */
  -webkit-touch-callout: none; /* Отключает контекстное меню на iOS */
}



body, html {
    font-family: 'Montserrat', 'sans-serif';
    font-weight: 500;
    margin: 0;
    padding: 0;
    -webkit-user-select: none; /* Отключает выделение текста на iOS */
    user-select: none; /* Отключает выделение текста на других устройствах */
    
  }

  input, textarea {
    -webkit-user-select: text; /* Разрешает выделение текста в формах */
    user-select: text;
  }
  
  
  #install-pwa {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 1000;
  }
  
  #install-pwa .modal-content {
    /* background: #2A2B34;
    color: #FFFFFF; */
    padding: 20px;
    border-radius: var(--br-xs);
    text-align: center;
    width: 90%;
    max-width: 300px;
  }
  

  header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--text-color);
    padding: 10px 20px;
    min-height: 44px;
  }
  
  header h1 {
    margin: 0;
    font-size: 1.5em;
  }
  
  header div {
    display: flex;
    gap: 10px;
  }
  
article img {
  width: 100%;
  border-radius: var(--br-xs);
}

  button {
    /* background-color: #A0FF00; */
    color: #2A2B34;
    border: none;
    padding: 10px;
    border-radius: var(--br-xs);
    cursor: pointer;
    font-size: 1em;
    transition: background-color 0.3s ease;
  }
  
  button:hover {
    background-color: var(--primary-color);
  }
  
  button.negative {
    background-color: #FF0000;
  }
  
  button.positive {
    background-color: var(--secondary-color);
  }
  
  button:hover.negative {
    background-color: #CC0000;
  }
  
  button:hover.positive {
    background-color: #008000;
  }
  
  .material-icons {
    font-size: 1.5em;
    vertical-align: middle;
  }
  
  main {
    padding: 60px 10px 90px;
  }

  article {
    margin-bottom: 80px;
    padding: 15px 0;

  }
  

  /* Карточка игрока */
  .card {
    /* background: #7228F5; */
    color: #FFFFFF;
    margin: 10px 0;
    padding: 15px;
    border-radius: var(--br-xs);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  
  .card h3 {
    margin: 0;
    font-size: 1.2em;
  }
  
  .card .controls {
    display: flex;
    gap: 10px;
  }
  
  .card .controls button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
  }
  
  /* Стили модального окна */
  .modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 1000;
  }
  
  .modal-content {
    /* background: #2A2B34;
    color: #FFFFFF; */
    padding: 20px;
    border-radius: var(--br-xs);
    text-align: center;
    width: 90%; /* Уменьшаем ширину модальных окон */
    max-width: 300px; /* Максимальная ширина модального окна */
  }
  
  
  .modal-buttons button {
    flex: 1;
  }
  
  .modal-content input {
    width: calc(100% - 20px);
    padding: 10px;
    margin: 15px 0;
    font-size: 1em;
    border: 2px solid var(--nav-btn-color);
    border-radius: var(--br-xs);
    outline: none;
  }
  
  .modal-buttons {
    display: flex;
    justify-content: space-between;
    gap: 10px;
  }
  /* Основной контент */

button, a {
  user-select: none; /* Запрещает выделение текста */
  outline: none; /* Убирает рамку */
  -webkit-tap-highlight-color: transparent; /* Отключает эффект нажатия на мобильных устройствах */
  -webkit-user-drag: none; /* Отключает перетаскивание изображения в WebKit-браузерах */
  pointer-events: auto; /* Отключает все действия мыши (если ссылка только для внешнего вида) */
  cursor: pointer; /* Добавляет указатель мыши */
}


.page {
  display: none;
  /* padding: 20px; */
}

.page.active {
  display: block;
}

/* Фиксированный футер */
.navbar {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 10px 0;
  z-index: 1000;
  box-shadow: 0px -5px 15px rgb(0 0 0 / 19%);
}

.page {
  opacity: 0;
  transform: scale(0.95);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.page.active {
  opacity: 1;
  transform: scale(1);
}

.nav-btn {
  transition: transform 0.2s ease;
  font-family: 'Montserrat', 'sans-serif';
}

button {
  font-family: 'Montserrat', 'sans-serif';
  font-weight: 600;
}

.nav-btn:active {
  transform: scale(0.9);
}

.nav-btn {
  background: none;
  border: none;
  color: var(--nav-btn-color, #FFFFFF);
  text-align: center;
  cursor: pointer;
  font-size: 1.5em;
  flex: 1;
  transition: color 0.3s ease;
}

.nav-btn:hover {
  color: var(--secondary-color);
  background: none;
}

.nav-btn svg {
  fill: var(--nav-btn-color, #FFFFFF); /* Цвет иконок зависит от темы */
  width: 35px;
  transition: fill 0.3s ease;
}

.nav-btn:hover svg {
  fill: var(--secondary-color); /* Меняем цвет иконки при hover */
}

.nav-btn:active svg {
  fill: #FF4500; /* Устанавливаем цвет для SVG в состоянии active */
}

.nav-btn.active svg {
  fill: var(--button-color);
  filter: drop-shadow(0 0 6px color-mix(in srgb, var(--button-color) 70%, transparent));
}


/* Стили для формы создания комнаты */
form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  /* margin-top: 20px; */
}

form input {
  padding: 10px;
  font-size: 1em;
  border: 2px solid var(--nav-btn-color);
  border-radius: var(--br-xs);
  outline: none;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
}

.search-input {
  padding: 5px;
  font-size: 1em;
  border: 2px solid var(--nav-btn-color);
  border-radius: var(--br-xs);
  outline: none;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
  margin-top: 10px;
}

input:focus-visible {
  border: 2px solid var(--secondary-color);
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.479);
}

form button {
  padding: 10px;
  /* background-color: #A0FF00; */
  color: #2A2B34;
  font-size: 1.2em;
  border: none;
  border-radius: var(--br-xs);
  cursor: pointer;
  font-weight: 600;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
  transition: background-color 0.3s ease;
}

form button:hover {
  /* background-color: #88CC00; */
}

form button span, .modal-content .f16 {
  font-size: 1.6em !important;
}


/* Список комнат */
#rooms {
  list-style: none;
  padding: 0;
  margin: 10px 0 40px;
  padding-bottom: 60px;
}

#room-players-list {
  padding-bottom: 100px;
}

#rooms li button {
  background: #FF0000;
  color: var(--text-color);
  border-radius: 50%;
}

#rooms li button:hover {
  color: #CC0000;
}


/* Стили для карточек игроков */
.card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: white;
  margin: 10px 0;
  padding: 10px;
  border-radius: var(--br-xs);
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
}

.card-info h3 {
  margin: 0;
  font-size: 1.2em;
}

.card-info p {
  margin: 5px 0 0;
  font-size: 1em;
}

.card-info{
  display: flex;
  align-items: center;
}

.controls {
  display: flex;
  gap: 10px;
}

.controls button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 50%;
  cursor: pointer;
}

.delete-btn {
  background: #FF0000;
  color: white;
}

.delete-btn:hover {
  background: #CC0000;
}

.add-btn {
  color: black;
}

.add-btn:hover {
  background: #00CC00;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}

.modal-buttons {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.modal-buttons button {
  flex: 1;
}

/* карусель */
.carousel {
  display: flex;
  overflow-x: auto;
  scroll-behavior: smooth;
  gap: 10px;
  padding: 10px 7px;
}

.carousel1 {
  display: flex;
  overflow-x: auto;
  scroll-behavior: smooth;
  gap: 10px;
  margin: 10px 0;
}

.carousel-item {
  flex: 0 0 95%; /* Баннер занимает 80% ширины контейнера */
  max-width: 600px; /* Максимальная ширина баннера */
  border-radius: var(--br-xs);
  overflow: hidden; /* Скрываем части, которые выходят за границы */
  padding: 0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.carousel-item img {
  width: 100%; /* Изображение растягивается на весь блок */
  height: auto; /* Пропорциональная высота */
  margin: 0px 0 -7px;
  object-fit: cover; /* Контент обрезается, чтобы полностью заполнить блок */
}

.carousel-item a {
  display: block; /* Делает ссылку блочным элементом */
  width: 100%; /* Устанавливает ширину ссылки */
  height: 100%; /* Устанавливает высоту ссылки */
  text-decoration: none; /* Убирает стандартное подчеркивание */
}

.carousel-item a img {
  display: block; /* Убирает отступы картинки внутри ссылки */
  width: 100%; /* Задает ширину картинки на всю ширину ссылки */
  height: auto; /* Сохраняет пропорции изображения */
}




.divider {
  margin: 20px 0;
  border: 0;
  height: 1px;
  background: var(--primary-color);
}

.settings-section {
  margin-bottom: 20px;
}

.settings-section label {
  display: block;
  margin-bottom: 10px;
  font-weight: 600;
}

.settings-section select {
  width: 100%;
  padding: 10px;
  border-radius: var(--br-xs);
  border: 1px solid #ccc;
  background: white;
  font-size: 1em;
}

.info-section p {
  margin: 10px 0;
  font-size: 1em;
}

.info-section a {
  color: var(--primary-color);
  text-decoration: none;
}

.info-section a:hover {
  text-decoration: underline;
}

#app-version {
  color: var(--primary-color);
}

/* ============ ОБЁРТКА ============ */
.custom-select-wrapper {
  position: relative;
  width: 100%; /* Растягиваем на всю ширину родителя */
}

/* ============ ОСНОВА СЕЛЕКТОРА ============ */
.custom-select {
  position: relative;
  cursor: pointer;
  user-select: none;
  width: 100%;
}

/* ============ «ШАПКА» (триггер) ============ */
.custom-select-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;

  background-color: var(--primary-color);
  /* border: 1px solid var(--nav-btn-color); */
  border-radius: var(--br-xs);
  
  padding: 10px 12px;
  margin: 0;          /* Можно добавить отступы по вкусу */
  font-size: 14px;
  color: #fff;

  /* width: 95%; */
  transition: background-color 0.2s, border-color 0.2s;
}

/* При наведении: меняем цвет фона, рамки */
/* .custom-select-trigger:hover {
  background-color: #f6f6f6;
  border-color: #7228F5;
} */

.custom-select-trigger:hover {
  background-color: var(--primary-color);
  border-color: var(--secondary-color);
}

/* При фокусе: outline или подсветка рамки */
.custom-select-trigger:focus {
  outline: none;         /* убираем стандартную обводку */
  border-color: var(--secondary-color);    /* меняем цвет рамки */
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1); /* небольшой glow */
}

/* ============ СТРЕЛКА ▼ ============ */
.custom-select-trigger .arrow {
  width: 0;
  height: 0;
  margin-left: 10px;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid var(--text-color); /* Треугольник */
  transition: transform 0.2s;
}

/* Если класс .open — поворачиваем стрелку вверх */
.custom-select.open .arrow {
  transform: rotate(-180deg);
}

/* ============ СПИСОК ОПЦИЙ ============ */
.custom-options {
  position: absolute;
  top: 100%;        /* сразу под «шапкой» */
  left: 0;
  right: 0;

  border: 1px solid #ccc;
  border-radius: var(--br-xs);
  background-color: #fff;

  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
  max-height: 200px;   /* ограничение по высоте */
  overflow-y: auto;    /* скролл, если вариантов много */
  z-index: 999;

  /* По умолчанию скрыт */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

/* Когда .custom-select имеет класс .open — показываем список */
.custom-select.open .custom-options {
  opacity: 1;
  pointer-events: all; /* клики включены */
}

/* ============ КАЖДАЯ ОПЦИЯ ============ */
.custom-option {
  display: block;
  padding: 8px 12px;
  font-size: 14px;
  color: #333;
  transition: background-color 0.1s;
}

/* Hover-эффект для опции */
.custom-option:hover {
  background-color: #f2f2f2;
}

/* Подсвечиваем выбранную опцию */
.custom-option.active {
  background-color: var(--secondary-color); /* пример */
  font-weight: 600;          /* выделяем текст жирным */
}


/* Стили для тумблера */
.toggle-switch {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 25px;
  margin: 10px 0 0;
}

.toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-switch label {
  position: absolute;
  cursor: pointer;
  width: 50px;
  height: 25px;
  right: 1%;
  background-color: #ccc;
  border-radius: 25px;
  transition: background-color 0.3s;
}

.toggle-switch label::after {
  content: "";
  position: absolute;
  width: 21px;
  height: 21px;
  background-color: white;
  border-radius: 50%;
  top: 2px;
  left: 2px;
  transition: transform 0.3s;
}

.toggle-switch input:checked + label {
  background-color: var(--primary-color); /* Цвет для активного состояния */
  right: 1%;
}

.toggle-switch input:checked + label::after {
  transform: translateX(25px);
}

.toggle-switch span {
  display: block;
}

#player-history {
  max-height: 150px;
  overflow-y: auto;
  margin-top: 10px;
  border: 1px solid #ccc;
  border-radius: var(--br-xs);
  background: var(--background-color);
  list-style: none;
  color: var(--text-color);
  font-size: 14px;
}

.player-history h3 {
  margin: 0;
}

.page {
  display: none; /* Скрываем все страницы */
  height: 100%; /* Устанавливаем высоту для каждой страницы */
}

.page.active {
  display: flex; /* Показываем активную страницу */
  flex-direction: column;
}


#history-page {
  margin: -60px 0 0; /* Компенсируем отступ шапки */
  padding: 0 10px 100px;
  overflow-x: hidden;
}

#history-page h1 {
  margin: 0; /* Убираем отступы заголовка */
  padding: 10px; /* Добавляем внутренний отступ для заголовка */
  text-align: center;
  
  color: var(--text-color); /* Цвет текста заголовка */
}

#history-container {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0;
  overflow: visible;
}

.history-card {
  background-color: var(--background-color); /* Цвет фона карточки */
  border: 2px solid var(--primary-color); /* Цвет рамки */
  border-radius:  var(--br-xs); /* Скругление углов */
  padding: 15px; /* Внутренний отступ */
  color: var(--text-color); /* Цвет текста */
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
}

.history-card h2 {
  margin: 0 0 10px 0; /* Отступы для заголовка */
  font-size: 18px; /* Размер шрифта заголовка */
  color: var(--primary-color); /* Цвет заголовка */
}

.history-card ul {
  list-style: none; /* Убираем маркеры списка */
  padding: 0; /* Убираем отступы списка */
  margin: 0;
}

.history-card li {
  display: flex; /* Используем флекс для горизонтального выравнивания */
  align-items: center; /* Выравниваем элементы по центру */
  margin-bottom: 5px; /* Отступ между элементами списка */
}

.history-card li strong {
  margin-left: 5px; /* Отступ между эмодзи и текстом */
}

.history-card li:last-child {
  margin-bottom: 0; /* Убираем нижний отступ для последнего элемента */
}

#history-btn {
  background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
  color: white;
  border: none;
  border-radius: var(--br-xs);
  padding: 10px 20px;
  font-size: 18px;
  cursor: pointer;
  font-family: 'Montserrat', 'sans-serif';
  /* box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3); */
  transition: all 0.2s ease-in-out;
}

/* No global button override in history-page */

.btn {
  font-weight: 600;
}

/* button {
  font-weight: 500;
} */

.btn.danger-grey {
  background-color: var(--background-color);
  color: var(--primary-color);
}
.btn.danger-grey:hover {
  background-color: var(--primary-color);
  color: var(--secondary-color);
}

.btn.danger {
  background-color: #ff4d4d;
  color: #fff;
}


.btn.danger:hover {
  background-color: #e60000;
}

/* .modal structural duplicate removed */

.modal-content-clear {
  padding: 20px;
  margin: 15% auto;
  border-radius: var(--br-xs);
  text-align: center;
  width: 90%;
  max-width: 300px;
}

.set-buttons {
  display: flex;
  font-size: 16px;

}

.set-buttons button {
  width: 49%;
  margin: 0 1%;
  border-radius: var(--br-xs);
}

input {
  font-family: 'Montserrat', 'sans-serif';
  font-weight: 500;
}


.warning {
  padding: 0 10px;
  font-size: 11px;
  border: 1px solid var(--primary-color);
  border-radius: var(--br-xs);
  margin: 5px 0 20px;
  /* background-color: var(--background-color); */
}

#player-info {
    /* font-size: 14px; */
    text-align: center;
    display: inline-grid;
    align-items: center;
}

#player-info img {
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2);
}


.modal-content button {
  width: 49%;
}

#restart-game-btn {
  width: 90% !important;
}

.modal-title {
  margin: 0;
}

#loser-info {
  align-items: center;
  display: inline-flex;
  gap: 5px;
  text-align: center;
}

#winners li {
  list-style-type: circle;
  text-align: center;
  align-items: center;
  margin: 0 auto;
  display: flex;
  gap: 5px;
  margin-bottom: 5px;
}

#winners {
  overflow-y: scroll;
  max-height: 300px;
}


/* Контейнер остается похожим */
.snow-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    pointer-events: none;
    overflow: hidden;
    z-index: 9999;
}


.toast {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--secondary-color);
  color: var(--text-color);
  padding: 15px 25px;
  border-radius: var(--br-xs);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  font-size: 1em;
  font-weight: bold;
  z-index: 10000;
  animation: fadeIn 0.5s ease-in-out;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translate(-50%, 20px); }
  to { opacity: 1; transform: translate(-50%, 0); }
}

/* Плейсхолдер для пустой комнаты */
.placeholder {
  display: none; /* По умолчанию скрыт */
  text-align: center;
  padding: 40px 20px;
  color: var(--text-color);
  opacity: 0.8;
}

.placeholder p {
  font-size: 1.2em;
  margin-bottom: 30px;
}

.big-add-btn {
  background: var(--secondary-color);
  color: var(--text-color);
  border: none;
  padding: 16px 32px;
  border-radius: var(--br-xs);
  font-size: 1.3em;
  font-weight: bold;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}

.big-add-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
  background: var(--primary-color);
}


/* styles.css */
/* ... (все предыдущие стили без изменений) ... */

/* Свитчер для режима в создании комнаты */
.mode-switcher {
  display: flex;
  justify-content: space-around;
  margin: 15px 0;
  font-size: 0.9em;
}

.mode-switcher label {
  display: flex;
  align-items: center;
  cursor: pointer;
}

.mode-switcher input {
  margin-right: 5px;
}

/* Индикатор режима */
.mode-indicator {
  font-size: 0.75em;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: var(--br-xs);
  background-color: var(--secondary-color);
  color: #2A2B34;
  margin-left: 10px;
}

.mode-lose {
  background-color: #ff4d4d; /* Красный для проигрыша */
  font-size: 0.75em;
}

/* Заголовок комнаты с контролами */
.room-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.room-controls {
  display: flex;
  gap: 10px;
}

.room-title {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Чипсы для недавних игроков */
.chips-container {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0;
}

.chip {
  background-color: var(--primary-color);
  color: white;
  padding: 6px 12px;
  border-radius: 20px;
  cursor: pointer;
  font-size: 0.9em;
  transition: background-color 0.3s;
}

.chip:hover {
  background-color: var(--secondary-color);
  color: var(--text-color);
}

.mode-radio-group {
  display: flex;
  justify-content: flex-start;
  gap: 10px;
  margin: 5px 0;
  overflow-x: auto;
  padding: 0 4px 4px;
  scrollbar-width: none; /* скрыть полосу прокрутки */
}

.mode-radio-group::-webkit-scrollbar {
  display: none;
}

.mode-radio {
  /* min-width: 120px; */
  flex-shrink: 0;
}
.mode-radio {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 4px;
  background-color: rgba(128, 128, 128, 0.2);
  border-radius: var(--br-xs);
  cursor: pointer;
  transition: all 0.3s ease;
  font-weight: 600;
  min-width: 33%;
  outline: none !important;                    /* Убирает контур */
  -webkit-tap-highlight-color: transparent;   /* Убирает тап-хайлайт на мобильных */
  tap-highlight-color: transparent;
}

.mode-radio span {
  /* color: #2A2B34; */
  opacity: 0.7;
  transition: opacity 0.3s;
}

.mode-radio.active {
  background-color: var(--secondary-color);
  outline: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.mode-radio.active span {
  opacity: 1;
  font-weight: bold;
}

/* При выборе — подсвечиваем */
.mode-radio-group input:checked + .mode-radio,
.mode-radio-group input:checked ~ .mode-radio {
  background-color: var(--secondary-color);
}

.mode-tag {
  display: inline-block;
  font-size: 0.75em;
  padding: 4px 10px;
  border-radius: var(--br-xs);
  color: #2A2B34;
  /* margin-top: 5px; */
  font-weight: bold;
}

.mode-reset {
  background-color: var(--secondary-color);
  color: #2A2B34;
}

/* Активный цвет по режиму вместо универсального --secondary-color */
.mode-radio.active[data-mode="reset"] {
  background-color: var(--secondary-color); /* зелёный — обнуление */
  color: #0a3d2b;
}

.mode-radio.active[data-mode="lose"] {
  background-color: #ff4d4d; /* красный — проигрыш */
  color: #fff;
}

.mode-radio.active[data-mode="goal"] {
  background: linear-gradient(135deg, #f59e0b, #d97706); /* золотой — цель */
  color: #3d2a00;
}

/* .mode-lose {
  background-color: var(--text-color);
  color: white;
} */

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: .4s;
  border-radius: 34px;
}

.slider:before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  transition: .4s;
  border-radius: 50%;
}

input:checked + .slider {
  background-color: var(--secondary-color);
}

input:checked + .slider:before {
  transform: translateX(26px);
}

/* Активный текст */
.mode-toggle-container .mode-label:first-of-type {
  opacity: 1; /* Обнуление активно по умолчанию */
}

input:checked ~ .mode-label:first-of-type {
  opacity: 0.6;
}

input:checked ~ .mode-label:last-of-type {
  opacity: 1;
}


/* Блок компании и продуктов */
.company-section {
  /* padding: 20px; */
}

.company-title {
  font-size: 1.5em;
  margin: 0 0 5px 0;
  background: var(--text-color);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: bold;
}

.company-subtitle {
  font-size: 0.8em;
  opacity: 0.8;
  color: var(--text-color);
}

.products-grid {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-behavior: smooth;
  padding: 10px 0 10px 5px;
}

.product-card {
  /* background-color: rgba(128, 128, 128, 0.1); */
  border-radius: var(--br-xs);
  /* padding: 10px; */
  transition: all 0.3s ease;
  align-items: center;
  backdrop-filter: blur(10px);
}

.product-card.link {
  text-decoration: none;
  color: inherit;
}

.product-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 10px 30px rgba(71, 253, 173, 0.2);
  background-color: rgba(71, 253, 173, 0.1);
}

.product-icon {
  width: auto;
  height: 150px;
  border-radius: var(--br-xs);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.product-card h3 {
  margin: 10px 0 8px 0;
  font-size: 1em;
  color: var(--secondary-color);
}

.product-card p {
  font-size: 0.7em;
  opacity: 0.8;
  margin: 0 0 10px 0;
}

.product-version {
  font-size: 0.9em;
  opacity: 0.7;
  font-style: italic;
  font-weight: bold;
}

.author-info {
  font-size: 1em;
  opacity: 0.9;
}

.author-info a {
  color: var(--secondary-color);
  text-decoration: none;
}

.author-info a:hover {
  text-decoration: underline;
}
/* ===== РЕЖИМ ЦЕЛЬ ===== */
.mode-goal {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #fff;
  border-radius: var(--br-xs);
  padding: 2px 8px;
  font-size: 0.8em;
  font-weight: 700;
}

/* ===== КНОПКА СТАТИСТИКИ ===== */
.stats-btn {
  background: var(--card-bg, rgba(255,255,255,0.1));
  border: none;
  border-radius: 8px;
  padding: 6px;
  cursor: pointer;
  color: var(--secondary-color) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.2s;
}
.stats-btn:hover { opacity: 0.7; }

/* ===== СЕТКА СТАТИСТИКИ ===== */
.stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  margin: 10px 0;
}
.stat-item {
  background: var(--card-bg, rgba(255,255,255,0.08));
  border-radius: 10px;
  padding: 10px 6px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.stat-value {
  font-size: 1.3em;
  font-weight: 700;
  color: var(--accent, #4caf50);
}
.stat-label {
  font-size: 0.7em;
  opacity: 0.65;
  line-height: 1.2;
}

/* ===== ТИТУЛЫ ===== */
.titles-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.title-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--card-bg, rgba(255,255,255,0.07));
  border-radius: 10px;
  padding: 8px 12px;
}
.title-icon {
  font-size: 1.6em;
  min-width: 32px;
  text-align: center;
}
/* ===== КНОПКА ЗНАКА +/- ===== */
#toggle-sign {
  width: 40px;
  height: 40px;
  font-size: 1em;
  font-weight: 700;
  border-radius: 50%;
  /* border: 2px solid var(--secondary-color, #4caf50); */
  background: var(--secondary-color);
  color: #000;
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
#toggle-sign:active {
  transform: scale(0.92);
}

#modal-add-points .modal-content {
  position: relative;
  padding-top: 90px; /* увеличили под большую аватарку */
  overflow: visible;
}

#player-info {
  position: absolute;
  top: -60px; /* сдвигаем выше */
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

#player-info img {
  width: 120px;  /* было 70px */
  height: 120px;
  border-radius: 50%;
  border: 3px solid var(--secondary-color);
  background: var(--bg-color);
}

/* ========================================
   🔽 DROPDOWN "ЧТО ЗА РЕЖИМЫ?"
   ======================================== */
.modes-dropdown {
  border: 1px solid var(--glass-border, rgba(255,255,255,0.1));
  border-radius: var(--br-xs);
  background: var(--glass-bg, rgba(0,0,0,0.15));
  overflow: hidden;
  margin-top: 4px;
}

.modes-dropdown summary {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.9em;
  color: var(--text-color);
  list-style: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.modes-dropdown summary::-webkit-details-marker { display: none; }

.modes-dropdown-icon {
  color: var(--text-color);
  font-size: 1.1em;
}

.modes-dropdown-arrow {
  margin-left: auto;
  font-size: 1.2em;
  transition: transform 0.25s ease;
  color: var(--text-color);
}

.modes-dropdown[open] .modes-dropdown-arrow {
  transform: rotate(180deg);
}

.modes-dropdown-body {
  padding: 4px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mode-info-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.mode-info-row p {
  margin: 2px 0 0;
  font-size: 0.82em;
  opacity: 0.75;
  line-height: 1.4;
}

.mode-info-row strong {
  font-size: 0.92em;
}

.mode-info-badge {
  font-size: 1.3em;
  min-width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.mode-reset-bg { background: rgba(71, 253, 173, 0.15); }
.mode-lose-bg  { background: rgba(255, 77, 77, 0.15); }
.mode-goal-bg  { background: rgba(255, 193, 29, 0.15); }


/* ========================================
   📊 СТАТИСТИКА НА ГЛАВНОЙ
   ======================================== */
.home-stats-section {
  margin: 16px 0 30px;
}

.home-stats-title {
  font-size: 1.05em;
  font-weight: 700;
  margin: 0 0 10px;
  color: var(--text-color);
  opacity: 0.85;
}

.home-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}

.home-stat-item {
  background: var(--glass-bg, rgba(0,0,0,0.15));
  border: 1px solid var(--glass-border, rgba(255,255,255,0.07));
  border-radius: var(--br-xs);
  padding: 12px 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  text-align: center;
  backdrop-filter: blur(8px);
}

.home-stat-champ {
  border-color: rgba(255, 193, 29, 0.35);
  background: rgba(255, 193, 29, 0.08);
}

.home-stat-icon { font-size: 1.4em; }

.home-stat-value {
  font-size: 1.5em;
  font-weight: 800;
  color: var(--text-color);
  line-height: 1.1;
}

.home-stat-label {
  font-size: 0.72em;
  opacity: 0.65;
  line-height: 1.2;
}

.home-stat-empty {
  text-align: center;
  padding: 16px;
  opacity: 0.55;
  font-size: 0.9em;
  border: 1px dashed var(--glass-border, rgba(255,255,255,0.1));
  border-radius: var(--br-xs);
}

/* Лидерборд */
.home-leaderboard-title {
  font-size: 0.95em;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--text-color);
}

.home-leaderboard-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.home-lb-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.home-lb-medal { font-size: 1.1em; min-width: 24px; text-align: center; }

.home-lb-name {
  font-size: 0.88em;
  font-weight: 600;
  min-width: 60px;
  max-width: 90px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-color);
}

.home-lb-bar-wrap {
  flex: 1;
  height: 8px;
  background: rgba(128,128,128,0.15);
  border-radius: 99px;
  overflow: hidden;
}

.home-lb-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
  border-radius: 99px;
  transition: width 0.5s ease;
}

.home-lb-count {
  font-size: 0.8em;
  font-weight: 700;
  min-width: 20px;
  text-align: right;
  color: var(--primary-color);
}

.home-lb-antirecord {
  margin-top: 8px;
  font-size: 0.78em;
  opacity: 0.6;
  text-align: center;
  padding: 6px 10px;
  border: 1px solid rgba(255,77,77,0.2);
  border-radius: var(--br-xs);
  background: rgba(255,77,77,0.06);
}


/* ========================================
   🃏 ИСТОРИЯ ИГР — НОВЫЙ ДИЗАЙН
   ======================================== */
.history-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0 12px;
  width: 100%;
  box-sizing: border-box;
}

.history-header h1 {
  flex: 1;
  margin: 0;
  font-size: 1.25em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.history-header-icon {
  font-size: 1.3em;
  flex-shrink: 0;
}

.history-back-btn {
  background: none !important;
  background-color: transparent !important;
  border: none;
  width: 36px !important;
  height: 36px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: var(--text-color) !important;
  flex-shrink: 0;
  padding: 0;
  box-shadow: none !important;
  min-width: unset !important;
}
.history-back-btn:hover {
  background: var(--glass-bg) !important;
  background-color: var(--glass-bg) !important;
}

/* Сводка */
.history-stat-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}

.history-stat-card {
  background: var(--glass-bg, rgba(0,0,0,0.18));
  border: 1px solid var(--glass-border, rgba(255,255,255,0.08));
  border-radius: var(--br-xs);
  padding: 10px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2px;
  backdrop-filter: blur(8px);
}

.history-stat-champ {
  grid-column: span 2;
  flex-direction: row;
  justify-content: center;
  gap: 10px;
  background: linear-gradient(135deg, rgba(255,193,29,0.12), rgba(255,193,29,0.04));
  border-color: rgba(255,193,29,0.3);
}

.history-stat-value {
  font-size: 1.5em;
  font-weight: 800;
  color: var(--text-color);
  line-height: 1;
}

.history-stat-label {
  font-size: 0.7em;
  opacity: 0.6;
}

.history-stat-name {
  font-size: 1em;
  font-weight: 700;
  color: var(--text-color);
}

.history-stat-wins {
  font-size: 0.75em;
  opacity: 0.65;
  color: var(--text-color);
}

/* Фильтры */
.history-filters {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

.history-search-input {
  width: calc(100% - 20px);
  padding: 9px 10px;
  border-radius: var(--br-xs);
  border: 1px solid var(--glass-border, rgba(114,40,245,0.2));
  background: var(--glass-bg, rgba(255,255,255,0.5));
  color: var(--text-color);
  font-family: 'Montserrat', sans-serif;
  font-size: 0.9em;
  outline: none;
  backdrop-filter: blur(8px);
}

.history-search-input:focus {
  border-color: var(--text-color);
}

.history-filter-tabs {
  display: flex;
  gap: 6px;
}

.filter-tab {
  flex: 1;
  padding: 7px 4px;
  border-radius: var(--br-xs);
  border: 1px solid var(--glass-border, rgba(255,255,255,0.08));
  background: var(--glass-bg, rgba(0,0,0,0.12));
  color: var(--text-color);
  font-size: 0.8em;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  font-family: 'Montserrat', sans-serif;
}

.filter-tab.active {
  background: var(--primary-color);
  color: #fff;
  border-color: var(--primary-color);
}

/* История — пустое состояние */
.history-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 40px 20px;
  opacity: 0.65;
  text-align: center;
}

/* Карточка истории v2 */
.history-card-v2 {
  background: var(--glass-bg, rgba(0,0,0,0.18));
  border: 1px solid var(--glass-border, rgba(255,255,255,0.08));
  border-radius: var(--br-xs);
  margin-bottom: 10px;
  overflow: hidden;
  backdrop-filter: blur(8px);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.history-card-v2:active {
  transform: scale(0.99);
}

.hc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px 8px;
  border-bottom: 1px solid var(--glass-border, rgba(255,255,255,0.06));
}

.hc-room-info {
  display: flex;
  align-items: center;
  gap: 6px;
}

.hc-game-num {
  font-size: 0.72em;
  font-weight: 700;
  background: var(--primary-color);
  color: #fff;
  padding: 2px 6px;
  border-radius: 6px;
  flex-shrink: 0;
}

.hc-room-name {
  font-size: 0.95em;
  font-weight: 700;
  color: var(--text-color);
}

.hc-date {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 1px;
}

.hc-date-day {
  font-size: 0.75em;
  font-weight: 600;
  opacity: 0.75;
  color: var(--text-color);
}

.hc-date-time {
  font-size: 0.68em;
  opacity: 0.5;
  color: var(--text-color);
}

.hc-players {
  padding: 6px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.hc-player-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 8px;
  border-radius: 8px;
  font-size: 0.88em;
}

.hc-winner {
  background: linear-gradient(90deg, rgba(255,193,29,0.14), transparent);
  border-left: 3px solid #ffc01d;
}

.hc-loser {
  background: linear-gradient(90deg, rgba(255,77,77,0.1), transparent);
  border-left: 3px solid rgba(255,77,77,0.5);
}

.hc-medal { font-size: 1em; min-width: 20px; }

.hc-player-name {
  flex: 1;
  font-weight: 600;
  color: var(--text-color);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hc-player-score {
  font-size: 0.85em;
  font-weight: 700;
  color: var(--text-color);
  white-space: nowrap;
}

.hc-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 12px 10px;
  border-top: 1px solid var(--glass-border, rgba(255,255,255,0.05));
}

.hc-players-count {
  font-size: 0.72em;
  opacity: 0.5;
  color: var(--text-color);
}

.hc-winner-label {
  font-size: 0.72em;
  font-weight: 700;
  color: #ffc01d;
  background: rgba(255,193,29,0.1);
  padding: 2px 8px;
  border-radius: 6px;
}

/* Light theme adjustments */
:root.default-white .home-stat-item,
:root.default-white .history-card-v2,
:root.default-white .history-stat-card,
:root.space-explorer .home-stat-item,
:root.space-explorer .history-card-v2,
:root.space-explorer .history-stat-card,
:root.urban-contrast .home-stat-item,
:root.urban-contrast .history-card-v2,
:root.urban-contrast .history-stat-card,
:root.golden-hour .home-stat-item,
:root.golden-hour .history-card-v2,
:root.golden-hour .history-stat-card,
:root.spring-blossom .home-stat-item,
:root.spring-blossom .history-card-v2,
:root.spring-blossom .history-stat-card,
:root.autumn-leaves .home-stat-item,
:root.autumn-leaves .history-card-v2,
:root.autumn-leaves .history-stat-card,
:root.minimal-elegance .home-stat-item,
:root.minimal-elegance .history-card-v2,
:root.minimal-elegance .history-stat-card {
  background: rgba(255,255,255,0.65);
  border-color: rgba(0,0,0,0.08);
}

:root.default-white .home-lb-bar-wrap,
:root.space-explorer .home-lb-bar-wrap,
:root.urban-contrast .home-lb-bar-wrap,
:root.golden-hour .home-lb-bar-wrap,
:root.spring-blossom .home-lb-bar-wrap,
:root.autumn-leaves .home-lb-bar-wrap,
:root.minimal-elegance .home-lb-bar-wrap {
  background: rgba(0,0,0,0.1);
}

/* #history-page padding handled above */

/* ========================================
   📱 MOBILE FIXES — History page
   ======================================== */

/* Summary grid — не выходим за экран */
.history-stat-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 14px;
  box-sizing: border-box;
}

/* Filter tabs — equal width, no overflow */
.history-filter-tabs {
  display: flex;
  gap: 6px;
  width: 100%;
  box-sizing: border-box;
}

.filter-tab {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  box-sizing: border-box;
}

/* history-card-v2 — ensure no horizontal overflow */
.history-card-v2 {
  box-sizing: border-box;
  width: 100%;
  overflow: hidden;
}

/* hc-room-name — truncate long room names */
.hc-room-name {
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* hc-player-row — no overflow on small screens */
.hc-player-row {
  box-sizing: border-box;
  min-width: 0;
}

/* search input — full width */
.history-search-input {
  width: 100%;
  box-sizing: border-box;
}

/* home stats grid — mobile safe */
.home-stats-grid {
  box-sizing: border-box;
}

/* ============================================================
   🆕 ADDITIONS — режимные бейджи, аутсайдер, новые элементы
   ============================================================ */

/* ── Бейдж режима внутри карточки истории ── */
.hc-mode-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.65em;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 6px;
  white-space: nowrap;
  flex-shrink: 0;
  line-height: 1.4;
}
.hc-mode-goal  { background: rgba(255,193,29,0.15);  color: #c89000; border: 1px solid rgba(255,193,29,0.35); }
.hc-mode-lose  { background: rgba(255,77,77,0.12);   color: #d94444; border: 1px solid rgba(255,77,77,0.3); }
.hc-mode-reset { background: rgba(71,253,173,0.12);  color: #1fa368; border: 1px solid rgba(71,253,173,0.3); }

/* Правая колонка хедера карточки: бейдж + дата */
.hc-header-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
}

/* Блок с лейблами победитель/проигравший в футере */
.hc-footer-badges {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* Лейбл проигравшего в футере */
.hc-loser-label {
  font-size: 0.72em;
  font-weight: 700;
  color: #e05c5c;
  background: rgba(255,77,77,0.1);
  padding: 2px 8px;
  border-radius: 6px;
  white-space: nowrap;
}

/* Место игрока (#1, #2...) в строке */
.hc-place {
  font-size: 0.72em;
  font-weight: 700;
  opacity: 0.45;
  min-width: 16px;
  text-align: center;
}

/* Карточка аутсайдера в сводке истории */
.history-stat-loser {
  background: linear-gradient(135deg, rgba(255,77,77,0.1), rgba(255,77,77,0.03)) !important;
  border-color: rgba(255,77,77,0.28) !important;
}
.history-stat-loser .history-stat-value { color: #e05c5c !important; }

/* ── Поиск — всегда full width ── */
.history-search-input {
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Табы истории скрыты (убраны из HTML), safety-hide */
.history-filter-tabs { display: none !important; }

/* ── history-stat-champ: не span 2 col в мобиле ── */
@media (max-width: 400px) {
  .history-stat-champ {
    grid-column: span 1;
    flex-direction: column;
  }
}

/* ── Light themes: mode badge colors ── */
:root.default-white .hc-mode-goal,
:root.space-explorer .hc-mode-goal,
:root.golden-hour .hc-mode-goal,
:root.spring-blossom .hc-mode-goal,
:root.autumn-leaves .hc-mode-goal,
:root.minimal-elegance .hc-mode-goal,
:root.urban-contrast .hc-mode-goal { color: #9a6d00; }

:root.default-white .hc-mode-lose,
:root.space-explorer .hc-mode-lose,
:root.golden-hour .hc-mode-lose,
:root.spring-blossom .hc-mode-lose,
:root.autumn-leaves .hc-mode-lose,
:root.minimal-elegance .hc-mode-lose,
:root.urban-contrast .hc-mode-lose { color: #b02020; }

:root.default-white .hc-mode-reset,
:root.space-explorer .hc-mode-reset,
:root.golden-hour .hc-mode-reset,
:root.spring-blossom .hc-mode-reset,
:root.autumn-leaves .hc-mode-reset,
:root.minimal-elegance .hc-mode-reset,
:root.urban-contrast .hc-mode-reset { color: #177a4d; }

