/**
 * Стили таблиц для РПЛ 2025
 * Турнирные таблицы, аналитические таблицы команд
 */

/* ===== ФИКСАЦИЯ КОЛОНОК ПРИ ГОРИЗОНТАЛЬНОМ СКРОЛЛЕ ===== */

/* Контейнер для таблиц с фиксированными колонками */
.table-container-fixed {
  position: relative;
  overflow: auto;
  max-width: 100%;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
}

/* Фиксированная шапка таблицы */
.team-analysis-table thead th {
  position: sticky;
  top: 0;
  z-index: 10;
  background-color: #f5f5f5;
  border-bottom: 2px solid #ddd;
}

/* Фиксированная первая колонка (параметры) */
.team-analysis-table .param-column,
.team-analysis-table th:first-child {
  position: sticky;
  left: 0;
  z-index: 8;
  background-color: #fafafa;
  border-right: 0; /* линия будет у второго столбца */
  box-shadow: 2px 0 4px rgba(0,0,0,0.1);
  min-width: var(--param-col-width) !important;
  max-width: var(--param-col-width) !important;
  width: var(--param-col-width) !important;
}

/* Фиксированная вторая колонка (если нужна) */
.team-analysis-table .second-fixed-column,
.team-analysis-table th:nth-child(2).fixed {
  position: sticky;
  left: var(--param-col-width); /* вплотную к первому столбцу */
  z-index: 9;
  background-color: #f9f9f9;
  border-left: 1px solid #ddd; /* единая разделительная линия между 1 и 2 столбцами */
  box-shadow: 1px 0 2px rgba(0,0,0,0.06);
  will-change: left;
}
/* В шапке второй столбец должен быть выше остальных */
.team-analysis-table thead th:nth-child(2).fixed { z-index: 13; }

/* Угловая ячейка (пересечение шапки и первой колонки) */
.team-analysis-table thead th:first-child {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 11;
  background-color: #e8e8e8;
}

/* Угловая ячейка для второй колонки */
.team-analysis-table thead th:nth-child(2).fixed {
	position: sticky;
	top: 0;
	left: var(--param-col-width);
	z-index: 10;
	background-color: #e8e8e8;
}

/* Для компактных таблиц */
.team-analysis-table.compact .param-column,
.team-analysis-table.compact th:first-child {
  position: sticky;
  left: 0;
  z-index: 8;
  background-color: #fafafa;
  border-right: 2px solid #ddd;
}

.team-analysis-table.compact thead th:first-child {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 11;
  background-color: #e8e8e8;
}

/* Для таблиц в team-season-analysis */
.team-season-analysis .team-analysis-table.compact {
  overflow-x: auto;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
}

/* ===== КОНЕЦ ФИКСАЦИИ КОЛОНОК ===== */

/* Для таблиц статистики по периодам */
.periods-stats-table {
  overflow-x: auto;
  border-collapse: collapse;
  width: 100%;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
}

.periods-stats-table thead th {
  position: sticky;
  top: 0;
  z-index: 10;
  background-color: #f5f5f5;
  border-bottom: 2px solid #ddd;
  padding: 8px 12px;
  text-align: center;
  font-weight: bold;
}

/* Фиксированная первая колонка в periods-stats-table */
.periods-stats-table th:first-child,
.periods-stats-table td:first-child {
  position: sticky;
  left: 0;
  z-index: 8;
  background-color: #fafafa;
  border-right: 2px solid #ddd;
  text-align: left;
  padding-left: 12px;
  min-width: 150px;
}

/* Угловая ячейка periods-stats-table */
.periods-stats-table thead th:first-child {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 11;
  background-color: #e8e8e8;
}

/* ===== КОНЕЦ ФИКСАЦИИ КОЛОНОК ===== */

/* Базовые стили таблиц */
table {
  border-collapse: collapse;
  width: 100%;
}

th, td {
  text-align: left;
  padding: 8px;
  border-bottom: 1px solid var(--gray-200);
}

th {
  background-color: var(--gray-100);
  font-weight: 600;
  color: var(--gray-800);
}

/* Аналитические таблицы команд */
.team-analysis-table {
  --param-col-width: 70px; /* ещё в 2 раза уже первая колонка */
  --dyn-col-width: 60px;   /* ширина второй (Среднее) и прочих при старте */
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  background: white;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  border-radius: 8px;
  overflow: visible;
  margin-top: 15px;
}

.team-analysis-table th,
.team-analysis-table td {
  padding: 8px 10px;
  border: 1px solid #e0e0e0;
  text-align: center;
  vertical-align: middle;
  font-size: 13px;
}

.team-analysis-table th {
  background-color: #f5f5f5;
  font-weight: bold;
  color: #333;
  font-size: 12px;
  line-height: 1.3;
}

.team-analysis-table .param-column {
  min-width: var(--param-col-width);
  max-width: var(--param-col-width);
  text-align: left;
  padding-left: 12px;
  font-weight: 500;
  background-color: #fafafa;
  font-size: 12px;
}
/* Сверхкомпактная версия первого столбца (почти впритык к тексту) */
.team-analysis-table .param-column.param-column--compact {
  min-width: var(--param-col-width) !important;
  max-width: var(--param-col-width) !important;
  width: var(--param-col-width) !important;
  padding-left: 4px;
  padding-right: 2px;
  font-size: 11px;
  white-space: normal; /* переносим, чтобы колонка оставалась узкой */
  overflow-wrap: anywhere;
}

/* Заголовок первой колонки — принудительно узкий, с обрезкой */
.team-analysis-table thead th.param-column.param-column--compact {
  min-width: var(--param-col-width) !important;
  max-width: var(--param-col-width) !important;
  width: var(--param-col-width) !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.team-analysis-table .category-header {
  background-color: #e5e7eb !important;
  color: #333 !important;
  font-weight: bold;
  text-align: center;
  font-size: 13px;
  padding: 10px;
  border: 1px solid #e0e0e0;
}

/* Force shrink-to-text for first column unless in edit-mode */
.team-analysis-table:not(.edit-mode) thead th.param-column,
.team-analysis-table:not(.edit-mode) tbody td.param-column {
  min-width: max-content !important;
  max-width: max-content !important;
  white-space: nowrap;
}

/* Компактные таблицы для отчетов матчей */
.team-season-analysis {
  background: white;
  border-radius: 10px;
  padding: 20px;
  margin: 40px 0;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
  overflow-x: auto;
}

.team-season-analysis h3 {
  color: #ff6b35;
  margin-bottom: 15px;
  border-bottom: 2px solid #ff6b35;
  padding-bottom: 10px;
  font-size: 18px;
}

.compact-table-info {
  background: #e8f4fd;
  border: 1px solid #b3d9f2;
  border-radius: 5px;
  padding: 10px 15px;
  margin-bottom: 15px;
}

.compact-table-info p {
  margin: 0;
  font-size: 13px;
  color: #2c5aa0;
  font-weight: 500;
  line-height: 1.4;
}

/* Компактная версия аналитической таблицы */
.team-analysis-table.compact {
  --param-col-width: 120px;
  font-size: 10px;
  margin-top: 10px;
}

.team-analysis-table.compact th,
.team-analysis-table.compact td {
  padding: 3px 4px;
  font-size: 9px;
  text-align: center;
  min-width: 45px;
}

.team-analysis-table.compact .param-column {
  text-align: left;
  min-width: var(--param-col-width);
  font-size: 9px;
  padding-left: 8px;
}

.team-analysis-table.compact .match-column {
  min-width: 40px;
  width: 40px;
}

.team-analysis-table.compact .category-header {
  font-size: 10px;
  padding: 6px 8px;
}

/* Цветовые схемы результатов матчей */
.match-column.result-win {
  background-color: #e8f5e8;
  border-left: 3px solid #4caf50;
  border-right: 3px solid #4caf50;
}

.match-column.result-win th {
  background-color: #4caf50;
  color: white;
}

.match-column.result-draw {
  background-color: #fff8e1;
  border-left: 3px solid #ff9800;
  border-right: 3px solid #ff9800;
}

.match-column.result-draw th {
  background-color: #ff9800;
  color: white;
}

.match-column.result-loss {
  background-color: #ffebee;
  border-left: 3px solid #f44336;
  border-right: 3px solid #f44336;
}

.match-column.result-loss th {
  background-color: #f44336;
  color: white;
}

.match-column.result-upcoming {
  background-color: #e3f2fd;
  border-left: 3px solid #2196f3;
  border-right: 3px solid #2196f3;
}

.match-column.result-upcoming th {
  background-color: #2196f3;
  color: white;
}

/* Стили для кликабельных заголовков матчей */
.match-column.clickable-match {
  cursor: pointer;
  transition: all 0.3s ease;
}

.match-column.clickable-match:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.match-column.clickable-match th {
  transition: all 0.2s ease;
  position: relative;
}

.match-column.clickable-match:hover th {
  opacity: 0.9;
  filter: brightness(1.1);
}

/* Добавляем иконку для индикации кликабельности */
.match-column.clickable-match th::after {
  content: '👆';
  position: absolute;
  top: 2px;
  right: 2px;
  font-size: 8px;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.match-column.clickable-match:hover th::after {
  opacity: 0.7;
}

/* Ячейки по типам данных */
.score-cell {
  text-align: center;
  font-weight: bold;
  font-variant-numeric: tabular-nums;
}

.clickable-score { cursor: pointer; position: relative; }
.clickable-score:hover { background-color: rgba(33,150,243,0.12); }

/* Выделение строки (мультивыбор по клику) — синяя обводка */
.team-analysis-table tr.row-selected td {
  border-top: 2px solid #1e88e5 !important;
  border-bottom: 2px solid #1e88e5 !important;
  filter: saturate(1.6) brightness(1.15);
  transition: filter 120ms ease-in-out;
}
.team-analysis-table tr.row-selected td { color: #111; }
.team-analysis-table tr.row-selected td:first-child {
  border-left: 2px solid #1e88e5 !important;
}
.team-analysis-table tr.row-selected td:last-child {
  border-right: 2px solid #1e88e5 !important;
}

/* Повышаем насыщенность/яркость фоновых цветов в выделенной строке */
.team-analysis-table tr.row-selected td.percent-cell.excellent { background-color: rgba(76, 175, 80, 0.70) !important; }
.team-analysis-table tr.row-selected td.percent-cell.good { background-color: rgba(139, 195, 74, 0.70) !important; }
.team-analysis-table tr.row-selected td.percent-cell.average { background-color: rgba(255, 152, 0, 0.65) !important; }
.team-analysis-table tr.row-selected td.percent-cell.poor { background-color: rgba(244, 67, 54, 0.65) !important; }

.team-analysis-table tr.row-selected td.comparison-cell.comparison-better { background-color: rgba(76, 175, 80, 0.70) !important; }
.team-analysis-table tr.row-selected td.comparison-cell.comparison-worse { background-color: rgba(244, 67, 54, 0.70) !important; }
.team-analysis-table tr.row-selected td.comparison-cell.comparison-equal { background-color: rgba(255, 152, 0, 0.65) !important; }

.team-analysis-table tr.row-selected td.goal-interval-cell.interval-green { background-color: rgba(76, 175, 80, 0.70) !important; border-color: rgba(76, 175, 80, 0.95) !important; }
.team-analysis-table tr.row-selected td.goal-interval-cell.interval-yellow { background-color: rgba(255, 152, 0, 0.65) !important; border-color: rgba(255, 152, 0, 0.95) !important; }
.team-analysis-table tr.row-selected td.goal-interval-cell.interval-red { background-color: rgba(244, 67, 54, 0.70) !important; border-color: rgba(244, 67, 54, 0.95) !important; }

.team-analysis-table tr.row-selected td.clean-sheet-cell.clean-sheet-green { background-color: rgba(76, 175, 80, 0.70) !important; border-color: rgba(76, 175, 80, 0.95) !important; }
.team-analysis-table tr.row-selected td.clean-sheet-cell.clean-sheet-yellow { background-color: rgba(255, 152, 0, 0.65) !important; border-color: rgba(255, 152, 0, 0.95) !important; }
.team-analysis-table tr.row-selected td.clean-sheet-cell.clean-sheet-red { background-color: rgba(244, 67, 54, 0.70) !important; border-color: rgba(244, 67, 54, 0.95) !important; }

/* Edit-toolbar для таблицы команды */
.team-table-edit-toolbar {
  margin-top: 10px;
  margin-bottom: 10px;
  padding: 10px 12px;
  background: #f8f9fa;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.team-table-edit-toolbar .toolbar-group { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.team-table-edit-toolbar .toolbar-check { display: inline-flex; gap: 6px; align-items: center; font-size: 13px; }
.team-table-edit-toolbar .toolbar-hint { font-size: 12px; color: #666; }

/* Сворачивание строки */
.team-analysis-table tr.row-collapsed td:not(.param-column):not(.avg-cell) { height: 0; padding-top: 0; padding-bottom: 0; overflow: hidden; border-top: none; border-bottom: none; }
.team-analysis-table tr.row-collapsed td { transition: all 120ms ease; }

.number-cell {
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.percent-cell {
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.comparison-cell {
  text-align: center;
  font-weight: 600;
}

/* Цветовые схемы для ячеек */
.percent-cell.excellent {
  background-color: rgba(76, 175, 80, 0.3);
  color: #1b5e20;
}

.percent-cell.good {
  background-color: rgba(139, 195, 74, 0.3);
  color: #33691e;
}

.percent-cell.average {
  background-color: rgba(255, 152, 0, 0.2);
  color: #e65100;
}

.percent-cell.poor {
  background-color: rgba(244, 67, 54, 0.2);
  color: #b71c1c;
}

.comparison-cell.comparison-better {
  background-color: rgba(76, 175, 80, 0.3);
  color: #1b5e20;
}

.comparison-cell.comparison-worse {
  background-color: rgba(244, 67, 54, 0.3);
  color: #b71c1c;
}

.comparison-cell.comparison-equal {
  background-color: rgba(255, 152, 0, 0.2);
  color: #e65100;
}

/* Интервалы голов */
.goal-interval-cell.interval-green {
  background-color: rgba(76, 175, 80, 0.3);
  color: #1b5e20;
  border: 1px solid #e0e0e0;
}

.goal-interval-cell.interval-yellow {
  background-color: rgba(255, 152, 0, 0.25);
  color: #e65100;
  border: 1px solid #e0e0e0;
}

.goal-interval-cell.interval-red {
  background-color: rgba(244, 67, 54, 0.3);
  color: #b71c1c;
  border: 1px solid #e0e0e0;
}

.goal-interval-cell.interval-white {
  background-color: #ffffff;
  color: #6c757d;
  border: 1px solid #e0e0e0;
}

/* Сухие игры */
.clean-sheet-cell.clean-sheet-green {
  background-color: rgba(76, 175, 80, 0.3);
  color: #1b5e20;
  border: 1px solid #e0e0e0;
}

.clean-sheet-cell.clean-sheet-yellow {
  background-color: rgba(255, 152, 0, 0.25);
  color: #e65100;
  border: 1px solid #e0e0e0;
}

.clean-sheet-cell.clean-sheet-red {
  background-color: rgba(244, 67, 54, 0.3);
  color: #b71c1c;
  border: 1px solid #e0e0e0;
}

.clean-sheet-cell.clean-sheet-white {
  background-color: #ffffff;
  color: #6c757d;
  border: 1px solid #e0e0e0;
}

/* Владение мячом — градиентная шкала */
.percent-cell.pos-yellow { background: rgba(255, 193, 7, 0.35); color:#3d2f00; }
.percent-cell.pos-green-1 { background: rgba(76, 175, 80, 0.28); color:#1b5e20; }
.percent-cell.pos-green-2 { background: rgba(76, 175, 80, 0.40); color:#12451a; }
.percent-cell.pos-green-3 { background: rgba(76, 175, 80, 0.55); color:#0e3513; }
.percent-cell.pos-green-4 { background: rgba(76, 175, 80, 0.70); color:#0b2a0f; }
.percent-cell.pos-red-1 { background: rgba(244, 67, 54, 0.28); color:#7f1d1d; }
.percent-cell.pos-red-2 { background: rgba(244, 67, 54, 0.40); color:#671616; }
.percent-cell.pos-red-3 { background: rgba(244, 67, 54, 0.55); color:#4f1111; }
.percent-cell.pos-red-4 { background: rgba(244, 67, 54, 0.70); color:#3a0c0c; }

/* Адаптивность для мобильных */
@media (max-width: 768px) {
  .team-season-analysis {
    padding: 15px;
    margin: 20px 0;
  }
  
  .team-analysis-table.compact {
    font-size: 8px;
  }
  
  .team-analysis-table.compact th,
  .team-analysis-table.compact td {
    padding: 2px 3px;
    font-size: 7px;
    min-width: 35px;
  }
  
  .team-analysis-table.compact .param-column {
    min-width: 90px;
    font-size: 8px;
    padding-left: 5px;
  }
  
  .team-analysis-table.compact .match-column {
    min-width: 30px;
    width: 30px;
  }
} 

/* Классы для выравнивания данных из бекапа */
.text-left {
  text-align: left !important;
}

.text-center {
  text-align: center !important;
}

.text-right {
  text-align: right !important;
}

.number-cell {
  text-align: right !important;
  font-variant-numeric: tabular-nums;
}

.date-cell {
  text-align: center !important;
  font-size: 11px;
}

.text-cell {
  font-size: 12px;
  color: #666;
} 

/* ПРИНУДИТЕЛЬНОЕ ЦЕНТРИРОВАНИЕ ВСЕХ ЯЧЕЕК ДАННЫХ */
.score-cell,
.number-cell,
.percent-cell,
.goals-cell,
.cards-cell,
.comparison-cell,
.goal-interval-cell,
.clean-sheet-cell,
.goals-minutes-cell,
.date-cell,
.text-cell {
  text-align: center !important;
}

/* Только первый столбец (параметры) остается по левому краю */
.analysis-table td.param-column,
.analysis-table th.param-column {
  text-align: left !important;
}

/* Убираем все лишние толстые рамки */
.analysis-table .match-column {
  border-left: 1px solid #e0e0e0 !important;
  border-right: 1px solid #e0e0e0 !important;
}

/* Заголовки категорий тоже по центру */
.category-header {
  text-align: center !important;
  background: #e5e7eb !important;
  color: #333 !important;
  border: 1px solid #e0e0e0 !important;
} 

/* ===== МОЩНАЯ ПАНЕЛЬ УПРАВЛЕНИЯ ТАБЛИЦЕЙ ===== 🎛️ */

.advanced-table-controls {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 20px;
  box-shadow: 0 8px 32px rgba(102, 126, 234, 0.3);
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: center;
  color: white;
}

.control-group {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255, 255, 255, 0.1);
  padding: 12px 16px;
  border-radius: 8px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  min-width: 200px;
}

.control-label {
  font-weight: 600;
  font-size: 14px;
  margin-right: 8px;
  white-space: nowrap;
  color: rgba(255, 255, 255, 0.9);
}

.control-btn {
  background: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: white;
  padding: 8px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 13px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.control-btn:hover {
  background: rgba(255, 255, 255, 0.25);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.control-btn.active {
  background: linear-gradient(135deg, #28a745, #20c997) !important;
  border-color: #28a745 !important;
  color: white !important;
  box-shadow: 0 0 25px rgba(40, 167, 69, 0.6) !important;
  transform: scale(1.05) !important;
  animation: pulse-green 2s infinite !important;
}

.control-btn.active .btn-icon {
  animation: rotate 2s infinite linear !important;
}

@keyframes pulse-green {
  0%, 100% { 
    box-shadow: 0 0 25px rgba(40, 167, 69, 0.6);
  }
  50% { 
    box-shadow: 0 0 35px rgba(40, 167, 69, 0.9);
  }
}

@keyframes rotate {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.control-btn.zoom-btn {
  width: 35px;
  height: 35px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: bold;
}

.control-btn.reset-btn {
  background: rgba(255, 255, 255, 0.2);
  font-weight: 600;
}

.control-display {
  background: rgba(0, 0, 0, 0.2);
  padding: 6px 12px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 13px;
  min-width: 50px;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.btn-icon {
  font-size: 14px;
}

.btn-text {
  font-size: 12px;
}

.btn-counter {
  font-size: 11px;
  opacity: 0.8;
  margin-left: 4px;
}

.mobile-controls {
  display: none;
}

/* ===== ПАНЕЛЬ СКРЫТЫХ СТРОК ===== 👁️ */

.hidden-rows-panel {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.panel-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(5px);
}

.panel-content {
  background: white;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  max-width: 500px;
  width: 90%;
  max-height: 80vh;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.panel-header {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  padding: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.panel-header h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
}

.close-btn {
  background: rgba(255, 255, 255, 0.2);
  border: none;
  color: white;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

.close-btn:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: scale(1.1);
}

.panel-body {
  padding: 20px;
  max-height: 400px;
  overflow-y: auto;
}

.hidden-row-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid #eee;
}

.hidden-row-item:last-child {
  border-bottom: none;
}

.row-name {
  font-weight: 500;
  color: #333;
}

.restore-btn {
  background: #4caf50;
  color: white;
  border: none;
  padding: 6px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  transition: all 0.3s ease;
}

.restore-btn:hover {
  background: #45a049;
  transform: translateY(-1px);
}

.panel-footer {
  padding: 20px;
  border-top: 1px solid #eee;
  text-align: center;
}

.restore-all-btn {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
  transition: all 0.3s ease;
}

.restore-all-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(102, 126, 234, 0.4);
}

/* ===== АДАПТИВНОСТЬ ===== 📱 */

@media (max-width: 768px) {
  .advanced-table-controls {
    flex-direction: column;
    gap: 15px;
  }
  
  .control-group {
    min-width: auto;
    width: 100%;
    justify-content: center;
  }
  
  .mobile-controls {
    display: flex;
  }
  
  .panel-content {
    width: 95%;
    margin: 10px;
  }
} 

/* ===== РЕЖИМ РЕДАКТИРОВАНИЯ ТАБЛИЦЫ ===== ✏️ */

.analysis-row.edit-mode {
  background: rgba(102, 126, 234, 0.05);
  border-left: 3px solid #667eea;
}

.param-cell-content {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 30px;
}

.drag-handle {
  width: 20px;
  height: 20px;
  background: #667eea;
  color: white;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
  font-size: 12px;
  font-weight: bold;
  transition: all 0.3s ease;
  user-select: none;
}

.drag-handle:hover {
  background: #5a6fd8;
  transform: scale(1.1);
}

.drag-handle:active {
  cursor: grabbing;
  transform: scale(0.95);
}

.param-label {
  flex: 1;
  font-weight: 500;
}

.hide-row-btn {
  width: 20px;
  height: 20px;
  background: #ff6b6b;
  color: white;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  opacity: 0.7;
}

.hide-row-btn:hover {
  background: #ff5252;
  opacity: 1;
  transform: scale(1.1);
}

/* Эффекты перетаскивания — упрощённые для скорости */
.analysis-row.dragging { opacity: 0.9 !important; background: #eef2ff !important; }
.analysis-row.dragging td { border-color: #667eea33 !important; }

/* Drop-indicator — отключен для снижения визуальных перегрузок */
.drop-indicator { display: none !important; }

.drop-indicator::before { display: none !important; }

@keyframes pulse-bright {
  0%, 100% { 
    opacity: 0.7; 
    transform: scaleY(1);
  }
  50% { 
    opacity: 1; 
    transform: scaleY(1.5);
  }
}

@keyframes bounce {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-3px); }
}

/* Визуальная обратная связь — минимальная */
.analysis-row.drag-over { background: rgba(102,126,234,0.08) !important; }
.full-match-report .analysis-row.drag-over { background: rgba(102,126,234,0.06) !important; }

/* Адаптивность для мобильных */
@media (max-width: 768px) {
  .param-cell-content {
    gap: 4px;
  }
  
  .drag-handle,
  .hide-row-btn {
    width: 18px;
    height: 18px;
    font-size: 10px;
  }
} 

.control-btn.reset-table-btn {
  background: linear-gradient(135deg, #dc3545, #c82333) !important;
  border-color: #dc3545 !important;
  color: white !important;
  animation: pulse-red 3s infinite !important;
}

.control-btn.reset-table-btn:hover {
  background: linear-gradient(135deg, #c82333, #bd2130) !important;
  transform: scale(1.05) !important;
  box-shadow: 0 0 20px rgba(220, 53, 69, 0.6) !important;
}

.control-btn.reset-table-btn .btn-icon {
  animation: spin-slow 4s infinite linear !important;
}

@keyframes pulse-red {
  0%, 100% { 
    box-shadow: 0 0 10px rgba(220, 53, 69, 0.4);
  }
  50% { 
    box-shadow: 0 0 20px rgba(220, 53, 69, 0.8);
  }
}

@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
} 

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

@keyframes slideOut {
  from { 
    transform: translateX(0); 
    opacity: 1; 
  }
  to { 
    transform: translateX(100%); 
    opacity: 0; 
  }
} 

/* ===== MATCH REPORT COMPONENTS STYLES ===== ⚽💎 */

/* 1. MATCH DETAILS GRID - КРАСИВАЯ СЕТКА! 📋 */
.match-details-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin: 25px 0;
  padding: 20px;
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  border-radius: 15px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}

.match-detail {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 20px;
  background: white;
  border-radius: 12px;
  border-left: 4px solid #667eea;
  box-shadow: 0 3px 10px rgba(0,0,0,0.05);
  transition: all 0.3s ease;
}

.match-detail:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(102, 126, 234, 0.15);
  border-left-color: #5a6fd8;
}

.detail-icon {
  font-size: 24px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #667eea, #764ba2);
  border-radius: 50%;
  color: white;
  flex-shrink: 0;
}

.detail-content {
  flex: 1;
  min-width: 0;
}

.detail-content strong {
  display: block;
  color: #495057;
  font-size: 14px;
  margin-bottom: 5px;
  font-weight: 600;
}

.detail-content span {
  color: #212529;
  font-size: 16px;
  font-weight: 500;
  word-break: break-word;
}

/* Статусы матча */
.status-finished { color: #28a745; font-weight: bold; }
.status-live { color: #dc3545; font-weight: bold; animation: pulse 2s infinite; }
.status-not-started { color: #6c757d; }
.status-halftime { color: #ffc107; font-weight: bold; }
.status-postponed { color: #fd7e14; }
.status-cancelled { color: #dc3545; }

/* 2. MATCH STATS - 3 КОЛОНКИ КАК В BACKUP! 📊 */
.match-stats {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  gap: 25px;
  margin: 30px 0;
  align-items: start;
}

.team-stats {
  text-align: center;
  padding: 25px 20px;
  border-radius: 15px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.1);
  position: relative;
  overflow: hidden;
}

.home-team-stats {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
}

.away-team-stats {
  background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
  color: white;
}

.team-stats::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(10px);
  z-index: 0;
}

.team-stats h4 {
  position: relative;
  z-index: 1;
  margin: 0 0 15px 0;
  font-size: 18px;
  font-weight: 700;
  text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.team-logo-placeholder {
  position: relative;
  z-index: 1;
  font-size: 48px;
  margin: 10px 0;
  text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.stats-labels {
  background: white;
  border-radius: 15px;
  padding: 25px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.1);
  border: 1px solid #e9ecef;
}

.stats-labels h4 {
  text-align: center;
  margin: 0 0 25px 0;
  color: #495057;
  font-size: 20px;
  font-weight: 700;
  padding-bottom: 15px;
  border-bottom: 2px solid #e9ecef;
}

.stat-line {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  padding: 12px 0;
  border-bottom: 1px solid #f1f3f4;
  align-items: center;
  transition: all 0.2s ease;
}

.stat-line:last-child {
  border-bottom: none;
}

.stat-line:hover {
  background: rgba(102, 126, 234, 0.05);
  border-radius: 8px;
  padding-left: 10px;
  padding-right: 10px;
}

.stat-home, .stat-away {
  text-align: center;
  font-weight: 600;
  font-size: 16px;
  padding: 8px;
  border-radius: 6px;
  transition: all 0.2s ease;
}

.stat-label {
  text-align: center;
  color: #495057;
  font-size: 14px;
  font-weight: 500;
}

/* Цветовая индикация статистики */
.stat-better {
  background: linear-gradient(135deg, #d4edda, #c3e6cb);
  color: #155724;
  border: 1px solid #c3e6cb;
}

.stat-worse {
  background: linear-gradient(135deg, #f8d7da, #f5c6cb);
  color: #721c24;
  border: 1px solid #f5c6cb;
}

.stat-equal {
  background: linear-gradient(135deg, #e2e3e5, #d6d8db);
  color: #383d41;
  border: 1px solid #d6d8db;
}

/* 3. МОБИЛЬНАЯ АДАПТАЦИЯ - КРАСОТА НА ВСЕХ УСТРОЙСТВАХ! 📱 */
@media (max-width: 768px) {
  .match-details-grid {
    grid-template-columns: 1fr;
    gap: 15px;
    padding: 15px;
  }
  
  .match-detail {
    flex-direction: column;
    text-align: center;
    gap: 10px;
  }
  
  .detail-icon {
    width: 35px;
    height: 35px;
    font-size: 20px;
  }
  
  .match-stats {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .team-stats {
    padding: 20px 15px;
  }
  
  .team-stats h4 {
    font-size: 16px;
  }
  
  .team-logo-placeholder {
    font-size: 36px;
  }
  
  .stats-labels {
    padding: 20px 15px;
  }
  
  .stat-line {
    grid-template-columns: 1fr;
    gap: 8px;
    text-align: center;
  }
  
  .stat-home, .stat-away {
    font-size: 14px;
  }
}

/* 4. АНИМАЦИИ И ЭФФЕКТЫ - ЖИВАЯ КРАСОТА! ✨ */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

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

.match-overview {
  animation: slideInUp 0.6s ease-out;
}

.match-detail {
  animation: slideInUp 0.6s ease-out;
  animation-fill-mode: both;
}

.match-detail:nth-child(1) { animation-delay: 0.1s; }
.match-detail:nth-child(2) { animation-delay: 0.2s; }
.match-detail:nth-child(3) { animation-delay: 0.3s; }
.match-detail:nth-child(4) { animation-delay: 0.4s; }
.match-detail:nth-child(5) { animation-delay: 0.5s; }
.match-detail:nth-child(6) { animation-delay: 0.6s; } 

/* Отчеты */
.report-section h2 {
  color: #2c3e50;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid #e74c3c;
}

/* ЦВЕТОВАЯ КОДИРОВКА ПРОЦЕНТОВ ДЛЯ ТАБЛИЦЫ КОМАНДЫ (из шаблона betting_results_table_modernized.html) */
.team-analysis-table .percentage-orange,
.team-analysis-table td.percentage-orange {
    background-color: #ff8c00 !important;
    color: white !important;
    font-weight: bold !important;
}

.team-analysis-table .percentage-blue,
.team-analysis-table td.percentage-blue {
    background-color: #1e90ff !important;
    color: white !important;
    font-weight: bold !important;
}

.team-analysis-table .percentage-lightblue,
.team-analysis-table td.percentage-lightblue {
    background-color: #87ceeb !important;
    color: #333 !important;
    font-weight: bold !important;
}

.team-analysis-table .percentage-gray,
.team-analysis-table td.percentage-gray {
    background-color: #d3d3d3 !important;
    color: #666 !important;
    font-weight: bold !important;
} 

.avg-column { min-width: var(--dyn-col-width); width: var(--dyn-col-width); text-align: center; color:#444; }
.avg-cell { min-width: var(--dyn-col-width); width: var(--dyn-col-width); font-weight: 600; text-align: center; background: rgba(0,0,0,0.03); } 

/* Окраска ячеек результата (секции Голы и Таймы) */
.score-cell.result-win { background-color: rgba(76, 175, 80, 0.28); color:#1b5e20; border: 1px solid #e0e0e0 !important; }
.score-cell.result-draw { background-color: rgba(255, 193, 7, 0.25); color:#7a4e00; border: 1px solid #e0e0e0 !important; }
.score-cell.result-loss { background-color: rgba(244, 67, 54, 0.28); color:#7f1d1d; border: 1px solid #e0e0e0 !important; } 

	/* Ячейки результатов ставок (букмекерская таблица) */
	.win-cell { background-color: rgba(76, 175, 80, 0.25); color:#1b5e20; font-weight: 600; }
	.lose-cell { background-color: rgba(244, 67, 54, 0.22); color:#7f1d1d; font-weight: 600; }
	.team-analysis-table tr.row-selected td.win-cell { background-color: rgba(76,175,80,0.70) !important; color:#0f3e12 !important; }
	.team-analysis-table tr.row-selected td.lose-cell { background-color: rgba(244,67,54,0.70) !important; color:#4a0e0e !important; }

	.team-analysis-table.edit-mode .param-column {
	  max-width: none;
	  min-width: calc(var(--param-col-width) + 120px);
	  white-space: nowrap;
	  overflow: visible;
	}
	.team-analysis-table .param-cell-content { display: flex; align-items: center; gap: 8px; }
	.team-analysis-table .param-cell-content .drag-handle { cursor: grab; }
	.team-analysis-table .param-cell-content .param-label { white-space: nowrap; }
	.team-analysis-table .param-cell-content .hide-row-btn { border: 1px solid #ddd; background: #fff; border-radius: 4px; padding: 2px 6px; cursor: pointer; }
	.team-analysis-table .param-cell-content .hide-row-btn:hover { background: #f3f3f3; } 

.team-analysis-table .category-header { position: relative; }
.team-analysis-table .category-header .category-toggle { 
  margin-right: 8px; 
  border: 1px solid #fff; 
  background: rgba(255,255,255,0.25); 
  color: #fff; 
  border-radius: 4px; 
  padding: 2px 6px; 
  cursor: pointer; 
  font-weight: 700; 
}
.team-analysis-table tr.hidden-by-category { display: none; }
.team-analysis-table tr.category-row.category-collapsed .category-header { opacity: 0.95; } 
.team-analysis-table .category-row:first-of-type .category-header { margin-top: 2px; } 

.team-analysis-table .param-column,
.team-analysis-table th:first-child {
  background-color: #eaf2ff !important;
  border-right: 0;
}

.team-analysis-table .second-fixed-column,
.team-analysis-table th:nth-child(2).fixed,
.team-analysis-table .avg-column {
  background-color: #eaf2ff !important;
  border-left: 1px solid #e0e0e0;
} 

/* Компакт для единой таблицы БК */
.team-analysis-table.betting-compact th,
.team-analysis-table.betting-compact td { padding: 2px 3px; font-size: 9px; }
.team-analysis-table.betting-compact .param-column { --param-col-width: 100px; padding-left: 6px; min-width:max-content; max-width:max-content; }
.team-analysis-table.betting-compact .match-column { min-width: 34px; width: 34px; }
.team-analysis-table.betting-compact .avg-column { min-width: 46px; width: 46px; }
.team-analysis-table.betting-compact .win-cell, .team-analysis-table.betting-compact .lose-cell { font-size: 10px; padding: 0; }
.team-analysis-table.betting-compact thead th { line-height: 1.1; }
.team-analysis-table.betting-compact .category-header { padding: 4px 6px; font-size: 10px; } 

/* === FINAL OVERRIDE: make first column shrink to text in non-edit mode (wins cascade) === */
.team-analysis-table:not(.edit-mode) thead th.param-column,
.team-analysis-table:not(.edit-mode) tbody td.param-column {
	min-width: max-content !important;
	max-width: max-content !important;
	white-space: nowrap !important;
} 

/* When not in edit-mode, let the second column anchor align to the actual measured width by treating var as auto if not set */
.team-analysis-table:not(.edit-mode) { --param-col-width: auto; } 