/**
 * @file: common.css
 * @description: Общие стили, не зависящие от темы
 * @created: 2025-01-09
 * @updated: 2025-01-09
 */

/* ===== ОСНОВНЫЕ СТИЛИ ===== */
body {
  background-color: var(--bg-primary);
  color: var(--text-primary);
  transition: var(--transition);
}

/* ===== УТИЛИТАРНЫЕ КЛАССЫ ===== */
.large-icon {
  font-size: var(--icon-size-large);
}

.telegram-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.steam-avatar {
  width: var(--avatar-size);
  height: var(--avatar-size);
  border-radius: 4px;
}

.steam-avatar-large {
  width: var(--avatar-size-large);
  height: var(--avatar-size-large);
  border-radius: 4px;
}

.modal-content-custom {
  background: var(--modal-bg);
  padding: var(--modal-padding);
  border-radius: var(--modal-radius);
  max-width: 500px;
  text-align: center;
}

.copy-link-container {
  background: var(--bg-secondary);
  padding: 15px;
  border-radius: 8px;
  margin: 10px 0;
}

/* ===== КОМПОНЕНТЫ ===== */
.footer-theme {
  background-color: var(--footer-bg);
  color: var(--footer-text);
  border-top: 1px solid var(--footer-border);
}

.footer-theme a {
  color: var(--text-secondary);
  text-decoration: none;
}

.footer-theme a:hover {
  color: var(--text-primary);
  text-decoration: underline;
}

/* ===== СТАТУСНЫЕ БЕЙДЖИ ===== */
.status-badge {
  font-size: 0.8em;
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
}

.status-badge-small {
  font-size: 0.7em;
  font-weight: normal;
  padding: 0.2em 0.5em;
}

/* ===== ТЕМАТИЧЕСКИЕ КЛАССЫ ===== */
.text-theme-primary {
  color: var(--text-primary);
}

.text-theme-secondary {
  color: var(--text-secondary);
}

.text-theme-muted {
  color: var(--text-muted);
}

.bg-theme-primary {
  background-color: var(--bg-primary);
}

.bg-theme-secondary {
  background-color: var(--bg-secondary);
}

.bg-theme-tertiary {
  background-color: var(--bg-tertiary);
}

.border-theme {
  border-color: var(--border-color);
}

.border-theme-light {
  border-color: var(--border-light);
}

.border-theme-dark {
  border-color: var(--border-dark);
}

/* ===== АНИМАЦИИ ===== */
.fade-in {
  animation: fadeIn 0.3s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.slide-in {
  animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(0);
  }
}

/* ===== УТИЛИТЫ ДЛЯ РАЗМЕРОВ ===== */
.w-100 {
  width: 100%;
}

.h-100 {
  height: 100%;
}

.mw-100 {
  max-width: 100%;
}

.mh-100 {
  max-height: 100%;
}

/* ===== УТИЛИТЫ ДЛЯ ОТСТУПОВ ===== */
.m-0 { margin: 0; }
.m-1 { margin: 0.25rem; }
.m-2 { margin: 0.5rem; }
.m-3 { margin: 1rem; }
.m-4 { margin: 1.5rem; }
.m-5 { margin: 3rem; }

.p-0 { padding: 0; }
.p-1 { padding: 0.25rem; }
.p-2 { padding: 0.5rem; }
.p-3 { padding: 1rem; }
.p-4 { padding: 1.5rem; }
.p-5 { padding: 3rem; }

/* ===== УТИЛИТЫ ДЛЯ ТЕКСТА ===== */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }
.text-justify { text-align: justify; }

.text-uppercase { text-transform: uppercase; }
.text-lowercase { text-transform: lowercase; }
.text-capitalize { text-transform: capitalize; }

.text-nowrap { white-space: nowrap; }
.text-wrap { white-space: normal; }

/* ===== УТИЛИТЫ ДЛЯ FLEXBOX ===== */
.d-flex { display: flex; }
.d-inline-flex { display: inline-flex; }
.d-none { display: none; }
.d-block { display: block; }
.d-inline { display: inline; }
.d-inline-block { display: inline-block; }

.flex-row { flex-direction: row; }
.flex-column { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }

.justify-content-start { justify-content: flex-start; }
.justify-content-end { justify-content: flex-end; }
.justify-content-center { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-around { justify-content: space-around; }

.align-items-start { align-items: flex-start; }
.align-items-end { align-items: flex-end; }
.align-items-center { align-items: center; }
.align-items-baseline { align-items: baseline; }
.align-items-stretch { align-items: stretch; }

/* ===== УТИЛИТЫ ДЛЯ ПОЗИЦИОНИРОВАНИЯ ===== */
.position-relative { position: relative; }
.position-absolute { position: absolute; }
.position-fixed { position: fixed; }
.position-sticky { position: sticky; }

/* ===== УТИЛИТЫ ДЛЯ ВИДИМОСТИ ===== */
.visible { visibility: visible; }
.invisible { visibility: hidden; }

.opacity-0 { opacity: 0; }
.opacity-25 { opacity: 0.25; }
.opacity-50 { opacity: 0.5; }
.opacity-75 { opacity: 0.75; }
.opacity-100 { opacity: 1; }

/* ===== УТИЛИТЫ ДЛЯ ПЕРЕПОЛНЕНИЯ ===== */
.overflow-auto { overflow: auto; }
.overflow-hidden { overflow: hidden; }
.overflow-visible { overflow: visible; }
.overflow-scroll { overflow: scroll; }

/* ===== УТИЛИТЫ ДЛЯ КУРСОРА ===== */
.cursor-pointer { cursor: pointer; }
.cursor-default { cursor: default; }
.cursor-not-allowed { cursor: not-allowed; }

/* ===== УТИЛИТЫ ДЛЯ ПОЛЬЗОВАТЕЛЬСКОГО ВЫБОРА ===== */
.user-select-none { user-select: none; }
.user-select-auto { user-select: auto; }
.user-select-text { user-select: text; }
.user-select-all { user-select: all; }

/* ===== УТИЛИТЫ ДЛЯ ПЕРЕХОДОВ ===== */
.transition { transition: var(--transition); }
.transition-none { transition: none; }

/* ===== УТИЛИТЫ ДЛЯ ТРАНСФОРМАЦИЙ ===== */
.transform-none { transform: none; }
.scale-0 { transform: scale(0); }
.scale-50 { transform: scale(0.5); }
.scale-75 { transform: scale(0.75); }
.scale-100 { transform: scale(1); }
.scale-110 { transform: scale(1.1); }
.scale-125 { transform: scale(1.25); }
.scale-150 { transform: scale(1.5); }

/* ===== УТИЛИТЫ ДЛЯ ТЕНИ ===== */
.shadow-none { box-shadow: none; }
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow { box-shadow: var(--shadow); }
.shadow-lg { box-shadow: var(--shadow-lg); }

/* ===== УТИЛИТЫ ДЛЯ РАДИУСА ===== */
.rounded-none { border-radius: 0; }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded { border-radius: var(--radius); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-full { border-radius: 50%; }

/* ===== СТИЛИ ДЛЯ ТАБЛИЦЫ ЭТАПОВ ===== */
/* Выравнивание ячеек по центру */
.table td {
  vertical-align: middle;
}

.table th {
  vertical-align: middle;
  text-align: center;
  font-weight: 600;
  font-size: 0.9em;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-primary);
  background-color: var(--bg-secondary);
  border-bottom: 2px solid var(--border-color);
}

/* Улучшенная типографика для таблицы этапов */
.stage-number {
  font-weight: 700;
  font-size: 1.1em;
  color: var(--primary);
}

.stage-name {
  font-weight: 600;
  font-size: 1em;
  color: var(--text-primary);
}

.stage-date {
  font-weight: 500;
  font-size: 0.95em;
  color: var(--text-secondary);
}

.track-name {
  font-weight: 600;
  font-size: 0.9em;
  color: var(--text-primary);
  font-style: italic;
}

.status-badge {
  font-weight: 600;
  font-size: 0.85em;
  padding: 0.4rem 0.8rem;
  border-radius: var(--radius-sm);
}

.action-button {
  font-weight: 500;
  font-size: 0.85em;
  padding: 0.3rem 0.6rem;
  border-radius: var(--radius-sm);
  transition: all 0.2s ease;
}

.action-button:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow);
}

.streams-button {
  font-weight: 500;
  font-size: 0.85em;
  padding: 0.3rem 0.6rem;
  border-radius: var(--radius-sm);
  transition: all 0.2s ease;
}

.streams-button:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow);
}

/* ===== СТИЛИ ДЛЯ СЕССИЙ В ТАБЛИЦЕ ЭТАПОВ ===== */
.sessions-container-compact {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 140px;
  max-width: 180px;
}

.session-item-compact {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-color);
  background-color: var(--bg-secondary);
  font-size: 0.85em;
  font-weight: 500;
  color: var(--text-primary);
  white-space: nowrap;
  min-width: 100%;
}

.session-time {
  font-size: 0.9em;
  color: var(--text-secondary);
  font-weight: 600;
  margin-left: 0.25rem;
}

.session-duration-compact {
  font-size: 0.8em;
  color: var(--primary);
  font-weight: 600;
  margin-left: 0.25rem;
}

/* Стили для разных типов сессий */
.session-practice {
  border-left: 3px solid var(--info);
}

.session-qualifying {
  border-left: 3px solid var(--warning);
}

.session-race {
  border-left: 3px solid var(--success);
}

/* ===== СТИЛИ ДЛЯ ВЫПАДАЮЩЕГО МЕНЮ ТЕМЫ ===== */
.dropdown-menu {
  background: var(--bg-primary) !important;
  border: 1px solid var(--border-color) !important;
  box-shadow: var(--shadow-lg) !important;
}

.dropdown-header {
  color: var(--text-primary) !important;
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 0.5rem 1rem 0.25rem;
}

.dropdown-item {
  color: var(--text-primary) !important;
  padding: 0.5rem 1rem;
  transition: all 0.2s ease;
}

.dropdown-item:hover {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

.dropdown-item:focus {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
  outline: none;
}

/* ===== СТИЛИ ДЛЯ ОПЦИЙ ТЕМЫ ===== */
.navbar .dropdown-menu .dropdown-item.theme-option {
  display: flex !important;
  align-items: center !important;
  gap: 0.75rem !important;
  font-weight: 500 !important;
  color: var(--text-primary) !important;
  padding: 0.75rem 1rem !important;
  transition: all var(--transition-fast) !important;
  border-radius: var(--radius) !important;
  margin: 0.125rem 0.5rem !important;
  width: calc(100% - 1rem) !important;
}

.navbar .dropdown-menu .dropdown-item.theme-option i {
  font-size: 1.1rem !important;
  width: 20px !important;
  text-align: center !important;
  flex-shrink: 0 !important;
}

/* Активная тема */
.navbar .dropdown-menu .dropdown-item.theme-option.active {
  background: var(--primary) !important;
  color: var(--text-inverse) !important;
  font-weight: 600 !important;
  box-shadow: var(--shadow) !important;
}

.navbar .dropdown-menu .dropdown-item.theme-option.active:hover,
.navbar .dropdown-menu .dropdown-item.theme-option.active:focus {
  background: var(--primary-hover) !important;
  color: var(--text-inverse) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* Неактивная тема */
.navbar .dropdown-menu .dropdown-item.theme-option:not(.active) {
  color: var(--text-primary) !important; /* Светлая: черный, Тёмная: белый */
  opacity: 1 !important;
}

.navbar .dropdown-menu .dropdown-item.theme-option:not(.active):hover,
.navbar .dropdown-menu .dropdown-item.theme-option:not(.active):focus {
  background: var(--primary) !important;
  color: var(--text-inverse) !important;
  transform: translateX(4px) !important;
  box-shadow: var(--shadow) !important;
}

/* Дополнительные стили для принудительного переопределения Bootstrap */
.navbar-nav .dropdown-menu .dropdown-item.theme-option {
  color: var(--text-primary) !important;
}

.navbar-nav .dropdown-menu .dropdown-item.theme-option:not(.active) {
  color: var(--text-primary) !important; /* Светлая: черный, Тёмная: белый */
  opacity: 1 !important;
}

.navbar-nav .dropdown-menu .dropdown-item.theme-option:not(.active):hover,
.navbar-nav .dropdown-menu .dropdown-item.theme-option:not(.active):focus {
  background: var(--primary) !important;
  color: var(--text-inverse) !important;
  opacity: 1 !important;
}

/* ===== FORCE VISIBILITY FOR THEME MENU ITEMS ===== */
/* Light theme: inactive should be dark text, full opacity */
[data-theme="light"] .navbar .dropdown-menu .dropdown-item.theme-option:not(.active),
[data-theme="light"] .navbar-nav .dropdown-menu .dropdown-item.theme-option:not(.active) {
  color: #212529 !important;
  opacity: 1 !important;
  filter: none !important;
}

/* Dark theme: inactive should be light text, full opacity */
[data-theme="dark"] .navbar .dropdown-menu .dropdown-item.theme-option:not(.active),
[data-theme="dark"] .navbar-nav .dropdown-menu .dropdown-item.theme-option:not(.active) {
  color: #f0f6fc !important;
  opacity: 1 !important;
  filter: none !important;
}

/* Hover state: always blue background with white text */
[data-theme] .navbar .dropdown-menu .dropdown-item.theme-option:not(.active):hover,
[data-theme] .navbar .dropdown-menu .dropdown-item.theme-option:not(.active):focus,
[data-theme] .navbar-nav .dropdown-menu .dropdown-item.theme-option:not(.active):hover,
[data-theme] .navbar-nav .dropdown-menu .dropdown-item.theme-option:not(.active):focus {
  background: var(--primary) !important;
  color: var(--text-inverse) !important;
  opacity: 1 !important;
  filter: none !important;
}

/* Defensive: ignore Bootstrap disabled visuals if added accidentally */
.navbar .dropdown-menu .dropdown-item.theme-option.disabled,
.navbar .dropdown-menu .dropdown-item.theme-option[aria-disabled="true"],
.navbar-nav .dropdown-menu .dropdown-item.theme-option.disabled,
.navbar-nav .dropdown-menu .dropdown-item.theme-option[aria-disabled="true"] {
  opacity: 1 !important;
  filter: none !important;
}