:root{
  --dark-blue: #0D1A29;
  --light-beige: #F8F4F2;
  --sea-turquoise: #5FAAB8;
  --card-bg: #ffffff;
  --text: var(--dark-blue);
  --muted: rgba(13,26,41,0.65);
  --green: #1a9b5a;
  --red: #d9534f;
  --shadow: 0 8px 20px rgba(13,26,41,0.06);
  --section-bg: rgba(95,170,184,0.05);
  --body-bg: var(--light-beige);
  --border: rgba(13,26,41,0.1);
}

:root[data-theme="dark"]{
  --card-bg: #1A2837;
  --text: #F8F4F2;
  --muted: rgba(248,244,242,0.72);
  --shadow: 0 8px 30px rgba(0,0,0,0.4);
  --section-bg: rgba(95,170,184,0.08);
  --body-bg: #0F1720;
  --border: rgba(248,244,242,0.15);
  color-scheme: dark;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial;}
body{background:var(--body-bg);color:var(--text);line-height:1.45;display:flex;flex-direction:column;}

/* Header */
.header{background:var(--dark-blue);color:var(--light-beige);padding:14px 20px;position:sticky;top:0;z-index:20;}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.brand-logo{width:44px;height:44px;border-radius:8px;overflow:hidden;background:rgba(255,255,255,0.03);display:flex;align-items:center;justify-content:center}
.brand-logo img{width:36px;height:36px;object-fit:contain;display:block}
.brand-name{font-family:Montserrat,Inter,sans-serif;font-weight:700;font-size:1.15rem;letter-spacing:0.6px}
.header-nav{display:flex;gap:16px;align-items:center}
.header-nav a{color:var(--sea-turquoise);text-decoration:none;font-weight:600;padding:6px 8px;border-radius:6px}
.header-actions{display:flex;gap:12px;align-items:center;}
.theme-toggle{width:40px;height:40px;border-radius:50%;background:rgba(95,171,184,0.2);border:none;color:var(--sea-turquoise);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;}
.profile-btn{width:40px;height:40px;border-radius:50%;background:rgba(95,171,184,0.2);border:none;color:var(--sea-turquoise);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;}

/* Hero Section */
.hero{background:linear-gradient(135deg, var(--dark-blue) 0%, #1a3a53 100%);color:var(--light-beige);padding:80px 20px;text-align:center;}
.hero-content{max-width:800px;margin:0 auto;}
.hero-title{font-family:Montserrat,Inter,sans-serif;font-weight:700;font-size:2.5rem;margin-bottom:16px;}
.hero-subtitle{font-size:1.2rem;margin-bottom:32px;opacity:0.9;max-width:600px;margin-left:auto;margin-right:auto;}
.search-large{max-width:600px;margin:0 auto;position:relative;display:flex;gap:10px;}
.search-large .input{flex:1;padding:16px 20px;padding-left:48px;border-radius:12px;border:2px solid rgba(255,255,255,0.2);font-size:1.05rem;background:rgba(255,255,255,0.1);color:#fff;}
.search-large .input:focus{outline:none;border-color:var(--sea-turquoise);}
.search-large:before{content:"🔍";position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:1.2rem;opacity:0.6;z-index:2;}
.search-btn{padding:0 24px;border-radius:12px;border:none;background:var(--sea-turquoise);color:var(--dark-blue);font-weight:600;cursor:pointer;font-size:1.05rem;}

/* Section titles */
.section-title{font-family:Montserrat,Inter,sans-serif;font-weight:700;font-size:1.6rem;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--sea-turquoise);}

/* Top Companies Section */
.top-companies-section{background:var(--section-bg);padding:30px;border-radius:12px;margin-bottom:40px;}

/* Page layout */
.container{max-width:1200px;margin:18px auto;padding:0 18px;flex:1;}

/* Sector card (accordion) */
.sector{margin-bottom:18px;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);background:var(--card-bg);}
.sector-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--dark-blue);color:var(--light-beige);cursor:pointer}
.sector-title{font-family:Montserrat,Inter,sans-serif;font-weight:700}
.sector-controls{display:flex;gap:8px;align-items:center}
.sector-body{padding:16px;display:none;background:transparent}
.sector-body.active{display:block;}

/* Search */
.search-row{display:flex;gap:10px;align-items:center;margin-bottom:12px}
.input{flex:1;padding:10px 12px;border-radius:10px;border:1px solid rgba(13,26,41,0.08);background:transparent;color:var(--text);}
:root[data-theme="dark"] .input{color:var(--text);border-color:rgba(248,244,242,0.15);}

/* ============ ИСПРАВЛЕНИЕ СЕТКИ КАРТОЧЕК ============ */

/* Основная сетка карточек */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:16px;width:100%;}

/* Гарантия что карточки имеют правильную ширину */
.company-card:not(.top-company-card){width:100%;min-width:0;max-width:none;}

/* 🔥 КРИТИЧЕСКОЕ ИСПРАВЛЕНИЕ: Правильное отображение карточек при развернутом аккордеоне */
.sector-body.active .cards-grid{display:grid !important;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)) !important;gap:16px !important;}

/* Grid of company cards */
.company-card{background:var(--card-bg);border-radius:12px;padding:12px;box-shadow:var(--shadow);border:1px solid rgba(13,26,41,0.04);transition:transform .12s ease,box-shadow .12s ease;cursor:pointer;display:flex;flex-direction:column;gap:10px;position:relative;}
.company-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(13,26,41,0.08);}

.company-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.comp-left{display:flex;gap:10px;align-items:center}
.comp-logo{width:44px;height:44px;border-radius:8px;background:rgba(95,171,184,0.12);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--sea-turquoise);}
.comp-title{font-weight:700}
.comp-ticker{font-size:0.9rem;color:var(--muted);display:flex;align-items:center;gap:4px;}
.price-change{display:flex;align-items:center;gap:4px;font-size:0.85rem;font-weight:600;cursor:pointer;}
.price-change.positive{color:var(--green)}
.price-change.negative{color:var(--red)}
.price-change.neutral{color:var(--muted)}
.period-toggle{padding:2px 6px;border-radius:4px;background:rgba(95,171,184,0.1);color:var(--sea-turquoise);font-weight:600;font-size:0.8rem;cursor:pointer;}
.price{font-weight:700;color:var(--dark-blue)}
:root[data-theme="dark"] .price{color:var(--light-beige)}

/* 🔥 СТИЛИ ДЛЯ ПЕРЕКЛЮЧАТЕЛЯ АКЦИЙ */
.stock-switcher{
    cursor: pointer;
    margin: 0 6px;
    font-weight: bold;
    color: var(--sea-turquoise);
    transition: all 0.2s ease;
    font-size: 0.8rem;
    padding: 2px 4px;
    border-radius: 3px;
    background: rgba(95, 170, 184, 0.1);
}

.stock-switcher:hover{
    background: var(--sea-turquoise);
    color: var(--dark-blue);
    transform: scale(1.1);
}

.company-card.stock-switching {
    transition: all 0.3s ease;
}

.current-ticker, .preferred-ticker {
    font-weight: 600;
}

/* Metrics grid */
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.metric{padding:10px;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(13,26,41,0.02));min-height:64px;display:flex;flex-direction:column;justify-content:center;gap:6px;border:1px solid rgba(13,26,41,0.04);position:relative;}
.metric .name{font-size:12px;color:var(--muted);cursor:help;}
.metric .value{font-weight:700;font-size:1.05rem}

/* Metric color hints */
.val-positive{color:var(--green)}
.val-negative{color:var(--red)}
.val-neutral{color:var(--sea-turquoise)}

/* Key metrics row (ВАЖНЫЕ ПОКАЗАТЕЛИ - Доля, Цена MAX) */
.key-metrics{display:flex;gap:8px;margin-top:12px;padding:10px;background:linear-gradient(135deg,rgba(95,171,184,0.08),rgba(95,171,184,0.04));border-radius:10px;border:1px solid rgba(95,171,184,0.12);}
.key-metric{flex:1;text-align:center;padding:8px;position:relative;}
.key-metric .label{font-size:12px;color:var(--muted);margin-bottom:4px;cursor:help;}
.key-metric .value{font-weight:700;font-size:1.1rem;}
.key-metric .value.positive{color:var(--green)}
.key-metric .value.negative{color:var(--red)}

/* ============ ИСПРАВЛЕННЫЕ ПОДСКАЗКИ ДЛЯ КАРТОЧЕК ============ */

/* Базовые стили для триггеров подсказок карточек */
.card-tooltip{
  position:relative;
  display:inline-block;
}

/* ПОДСКАЗКИ ПОЗИЦИОНИРУЮТСЯ ОТНОСИТЕЛЬНО КАРТОЧКИ КОМПАНИИ */
.metrics-grid .metric-card .card-tooltip .card-tiptext,
.metric-card .card-tooltip .card-tiptext,
.company-card .card-tooltip .card-tiptext,
.key-metric .card-tooltip .card-tiptext,
.metric .card-tooltip .card-tiptext {
  position: absolute;
  z-index: 100;
  background: var(--card-bg);
  color: var(--text);
  padding: 20px;
  border-radius: 12px;
  box-shadow: var(--shadow);
  font-size: 13px;
  line-height: 1.5;
  max-width: none;
  word-wrap: break-word;
  white-space: normal;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  
  /* 🔥 ИСПРАВЛЕНИЕ: Оверлей на всю КАРТОЧКУ КОМПАНИИ */
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  border: 2px solid var(--sea-turquoise);
  
  /* Центрирование контента */
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: left;
  overflow-y: auto;
}

/* Контейнер для контента подсказки */
.card-tiptext .tooltip-content {
  max-width: 100%;
  max-height: 100%;
  overflow-y: auto;
  padding: 10px;
}

/* Кнопка закрытия для мобильных */
.card-tiptext .tooltip-close-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 30px;
  height: 30px;
  border: none;
  background: var(--sea-turquoise);
  border-radius: 50%;
  color: var(--card-bg);
  font-size: 18px;
  font-weight: bold;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 101;
}

/* Индикатор для мобильных устройств */
@media (max-width: 768px) {
  .metric .name::after,
  .key-metric .label::after {
    content: "i";
    font-size: 0.7em;
    opacity: 0.5;
    margin-left: 4px;
    font-style: italic;
    font-weight: bold;
  }
  
  .card-tiptext .tooltip-close-btn {
    display: flex;
  }
}

/* Задержка для десктопных подсказок */
@media (min-width: 769px) {
  .card-tooltip .card-tiptext {
    transition-delay: 0.4s;
  }
}

/* Гарантия что подсказки не мешают клику на заголовок */
.company-head .comp-title {
  position: relative;
  z-index: 5;
}

/* ============ ПОДСКАЗКИ ДЛЯ ТАБЛИЦ (table-tooltip) ============ */

/* Базовые стили для триггеров подсказок таблиц */
.table-tooltip{
  position:relative;
  display:inline-block;
  cursor:help;
  border-bottom:1px dotted var(--sea-turquoise);
}

/* Правильное позиционирование подсказок таблиц относительно viewport */
.data-table .table-tooltip .table-tiptext {
  position: fixed;
  z-index: 1500;
  background: var(--dark-blue);
  color: var(--light-beige);
  padding: 12px;
  border-radius: 8px;
  box-shadow: var(--shadow);
  font-size: 13px;
  line-height: 1.4;
  max-width: 320px;
  min-width: 200px;
  word-wrap: break-word;
  white-space: normal;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  isolation: isolate;
  
  /* Убираем стандартные позиции */
  top: auto;
  left: auto;
  right: auto;
  bottom: auto;
}

/* Стрелка подсказки для таблиц */
.data-table .table-tooltip .table-tiptext::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  background: inherit;
  transform: rotate(45deg);
}

/* Позиционирование стрелки для таблиц */
.data-table .table-tooltip .table-tiptext[data-placement^="top"]::after {
  bottom: -4px;
  left: 50%;
  margin-left: -4px;
}

.data-table .table-tooltip .table-tiptext[data-placement^="bottom"]::after {
  top: -4px;
  left: 50%;
  margin-left: -4px;
}

.data-table .table-tooltip .table-tiptext[data-placement^="left"]::after {
  right: -4px;
  top: 50%;
  margin-top: -4px;
}

.data-table .table-tooltip .table-tiptext[data-placement^="right"]::after {
  left: -4px;
  top: 50%;
  margin-top: -4px;
}

.data-table .table-tooltip:hover .table-tiptext {
  visibility: visible;
  opacity: 1;
}

/* ============ ИСПРАВЛЕНИЕ ДЛЯ ПОДСКАЗОК ТАБЛИЦ ============ */

/* ИСПРАВЛЕНИЕ: Убираем display: none который блокирует подсказки */
.table-tooltip .table-tiptext {
  display: block !important;
}

/* Гарантируем, что подсказки будут видны при наведении */
.table-tooltip:hover .table-tiptext,
.data-table .table-tooltip:hover .table-tiptext {
  visibility: visible !important;
  opacity: 1 !important;
}

/* Гарантия что body не ограничивает подсказки */
body{
  overflow-x:visible !important;
}

/* Отключение overflow для всех потенциальных контейнеров */
.table-container,
.table-scroll-wrapper,
.card,
.tab-content{
  overflow:visible !important;
}

/* Footer */
footer{background:var(--card-bg);padding:40px 20px;text-align:center;color:var(--muted);margin-top:auto;box-shadow:0 -4px 20px rgba(13,26,41,0.04);}
.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:left;}
.footer-section h3{color:var(--text);margin-bottom:15px;font-size:1.1rem;}
.footer-section a{display:block;color:var(--muted);text-decoration:none;margin-bottom:8px;}
.footer-section a:hover{color:var(--sea-turquoise);}
.footer-bottom{margin-top:30px;padding-top:20px;border-top:1px solid rgba(13,26,41,0.1);}

/* Disclaimer */
.disclaimer{background-color:#f8f9fa;border:1px solid #ddd;border-radius:5px;padding:15px;margin-bottom:20px;font-size:13px;color:#666;}
.disclaimer-title{font-weight:bold;margin-bottom:5px;color:#2c3e50;}
:root[data-theme="dark"] .disclaimer{background-color:#1a2837;border-color:#34495e;color:#bdc3c7;}
:root[data-theme="dark"] .disclaimer-title{color:#ecf0f1;}

/* ============ СТИЛИ ДЛЯ ДЕТАЛЬНОЙ СТРАНИЦАХ ============ */

/* Breadcrumb */
.breadcrumb{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:20px;
  font-size:0.9rem;
  color:var(--muted);
}
.breadcrumb a{
  color:var(--sea-turquoise);
  text-decoration:none;
}

/* Company Header */
.company-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  margin-bottom:24px;
  gap:20px;
  flex-wrap:wrap;
}
.company-info{
  flex:1;
}
.company-title{
  font-family:Montserrat,Inter,sans-serif;
  font-weight:700;
  font-size:2rem;
  margin-bottom:8px;
}
.company-meta{
  display:flex;
  flex-wrap:wrap;
  gap:24px;
  margin-bottom:20px;
}
.meta-item{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.meta-label{
  font-size:0.85rem;
  color:var(--muted);
}
.meta-value{
  font-weight:600;
  font-size:1.05rem;
}
.company-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:12px;
}
.btn{
  padding:10px 16px;
  border-radius:8px;
  border:none;
  font-weight:600;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:0.95rem;
}
.btn-primary{
  background:var(--sea-turquoise);
  color:var(--dark-blue);
}
.btn-secondary{
  background:var(--section-bg);
  color:var(--text);
  border:1px solid var(--border);
}
.update-info{
  color:var(--muted);
  font-size:0.9rem;
  text-align:right;
}

/* Tabs */
.tabs{
  display:flex;
  gap:0;
  border-bottom:1px solid var(--border);
  margin-bottom:24px;
  overflow-x:auto;
}
.tab{
  background:none;
  border:none;
  padding:12px 20px;
  cursor:pointer;
  font-weight:600;
  color:var(--muted);
  border-bottom:2px solid transparent;
  transition:all 0.2s ease;
  white-space:nowrap;
}
.tab.active{
  color:var(--sea-turquoise);
  border-bottom-color:var(--sea-turquoise);
}

/* Tab Content */
.tab-content{
  display:none;
}
.tab-content.active{
  display:block;
}

/* Cards */
.card{
  background:var(--card-bg);
  border-radius:12px;
  padding:20px;
  box-shadow:var(--shadow);
  margin-bottom:24px;
  border:1px solid var(--border);
}
.card-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:16px;
}
.card-title{
  font-family:Montserrat,Inter,sans-serif;
  font-weight:700;
  font-size:1.3rem;
}

/* Table Container with Scroll */
.table-container{
  position:relative;
  overflow:hidden;
  margin:16px 0;
}
.table-scroll-wrapper{
  overflow-x:auto;
  overflow-y:auto;
  max-height:600px;
  scroll-behavior:smooth;
}

/* Table */
.data-table{
  width:100%;
  border-collapse:collapse;
}
.data-table th, .data-table td{
  padding:12px;
  text-align:right;
  border-bottom:1px solid var(--border);
  white-space:nowrap;
}
.data-table th{
  font-weight:600;
  color:var(--muted);
  cursor:pointer;
  user-select:none;
  position:sticky;
  top:0;
  background:var(--card-bg);
  z-index:10;
  box-shadow:0 1px 0 var(--border);
}
.data-table th:hover{
  background:var(--section-bg);
}
.data-table th:first-child, .data-table td:first-child{
  text-align:left;
  position:sticky;
  left:0;
  background:var(--card-bg);
  z-index:11;
  box-shadow:2px 0 4px rgba(0,0,0,0.05);
}
.data-table tr:last-child td{
  border-bottom:none;
}
.data-table .positive{
  color:var(--green);
}
.data-table .negative{
  color:var(--red);
}

/* Table row hover effects - ИСПРАВЛЕННАЯ ПОДСВЕТКА */
.data-table tbody tr{
  transition:background-color 0.2s ease;
}
.data-table tbody tr:hover{
  background-color:var(--section-bg);
}

/* Table visual separators for better grouping */
.data-table tbody tr.separator {
    height: 4px;
    background-color: transparent;
}

.data-table tbody tr.separator td {
    border-bottom: 6px solid var(--border);
    padding: 0;
    background: linear-gradient(90deg, transparent 0%, var(--border) 20%, var(--border) 80%, transparent 100%);
}

.data-table tbody tr.separator:hover {
    background-color: transparent;
}

/* Table vertical separators */
.data-table th:not(:first-child),
.data-table td:not(:first-child){
  border-left:1px solid var(--border);
}

/* Charts */
.chart-container{
  width:100%;
  height:300px;
  margin:16px 0;
  position:relative;
}
.chart-placeholder{
  width:100%;
  height:100%;
  background:var(--section-bg);
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
}

/* Metric Cards */
/* 🔥 ИЗМЕНЕНИЕ: Фиксированные 4 колонки с центрированием последнего ряда */
.metrics-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
  margin:16px 0;
  justify-items:center;
}

.metric-card{
  background:var(--card-bg);
  border-radius:10px;
  padding:16px;
  box-shadow:var(--shadow);
  border:1px solid var(--border);
  width:100%;
  max-width:220px;
}

.metric-name{
  font-size:0.9rem;
  color:var(--muted);
  margin-bottom:8px;
  display:block;
}

.metric-value{
  font-weight:700;
  font-size:1.4rem;
  margin-bottom:4px;
  display:block;
}

.metric-change{
  font-size:0.85rem;
  display:flex;
  align-items:center;
  gap:4px;
}

.metric-change.positive{
  color:var(--green);
}

.metric-change.negative{
  color:var(--red);
}

/* 🔥 ДОБАВЛЕНО: ЦЕНТРИРОВАНИЕ ПОСЛЕДНЕГО РЯДА КОГДА КАРТОЧЕК МЕНЬШЕ 4 */
.metrics-grid .metric-card:nth-last-child(1):nth-child(4n+1) {
    grid-column: 2 / span 2;
}

.metrics-grid .metric-card:nth-last-child(2):nth-child(4n+1),
.metrics-grid .metric-card:nth-last-child(1):nth-child(4n+2) {
    grid-column: auto;
}

.metrics-grid .metric-card:nth-last-child(2):nth-child(4n+1) {
    grid-column: 2;
}

.metrics-grid .metric-card:nth-last-child(1):nth-child(4n+2) {
    grid-column: 3;
}

/* Sub-tabs */
.subtab-content{
  display:none;
}
.subtab-content.active{
  display:block;
}

/* Cards Filter Dropdown - ЕДИНСТВЕННЫЙ ПРАВИЛЬНЫЙ БЛОК СТИЛЕЙ */
.cards-filter{
  position:relative;
  display:inline-block;
}
.filter-toggle{
  width:36px;
  height:36px;
  background:var(--section-bg);
  border:1px solid var(--border);
  border-radius:8px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:0.9rem;
  color:var(--sea-turquoise);
  transition:all 0.2s ease;
}
.filter-toggle:hover{
  background:var(--sea-turquoise);
  color:var(--dark-blue);
}
.filter-toggle::after{
  content:"▼";
  font-size:0.7rem;
  transition:transform 0.2s ease;
}
.filter-dropdown{
  position:absolute;
  top:100%;
  right:0;
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:8px;
  padding:8px 0;
  min-width:160px;
  box-shadow:0 8px 25px rgba(0,0,0,0.15);
  z-index:1000;
  display:none;
  margin-top:5px;
  opacity:0;
  transform:translateY(-10px);
  transition:all 0.2s ease;
}
.filter-dropdown.show{
  display:block;
  opacity:1;
  transform:translateY(0);
}
.filter-option{
  padding:10px 16px;
  cursor:not-allowed;
  transition:background 0.2s ease;
  color:var(--muted);
  opacity:0.4;
  font-size:0.9rem;
  border:none;
  background:none;
  width:100%;
  text-align:left;
}
.filter-option:hover{
  background:var(--section-bg);
}
.filter-option.active{
  color:var(--sea-turquoise);
  opacity:1;
  font-weight:700;
  background:rgba(95, 170, 184, 0.1);
  border-left:3px solid var(--sea-turquoise);
  cursor:default;
}

/* Strategy subtitle */
.strategy-subtitle{
  font-size:0.9rem;
  color:var(--muted);
  margin-top:-8px;
  margin-bottom:16px;
}

/* ============ ИСПРАВЛЕНИЯ ДЛЯ ТАБЛИЦ ============ */

/* Гарантия что таблицы не выходят за границы контейнеров */
.table-scroll-wrapper {
  max-width: 100%;
  overflow-x: auto !important;
}

/* Фиксируем ширину контейнеров таблиц */
.table-container {
  max-width: 100%;
  overflow: hidden !important;
}

/* Убеждаемся что таблица адаптируется */
.data-table {
  min-width: auto;
  table-layout: auto;
}

/* Для широких таблиц добавляем горизонтальный скролл */
.table-scroll-wrapper.has-horizontal-scroll {
  overflow-x: scroll !important;
}

/* Mobile scroll buttons - только для мобильных */
@media (max-width:768px){
  .scroll-controls{
    display:flex;
    justify-content:space-between;
    position:absolute;
    top:50%;
    left:0;
    right:0;
    transform:translateY(-50%);
    pointer-events:none;
    z-index:10;
  }
  .scroll-btn{
    pointer-events:auto;
    width:36px;
    height:36px;
    border-radius:50%;
    background:var(--card-bg);
    border:2px solid var(--sea-turquoise);
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    box-shadow:0 4px 12px rgba(0,0,0,0.15);
    color:var(--sea-turquoise);
    font-size:1.1rem;
    font-weight:bold;
    transition:all 0.3s ease;
    position:absolute;
    top:50%;
    transform:translateY(-50%);
  }
  .scroll-btn:hover{
    background:var(--sea-turquoise);
    color:var(--card-bg);
    transform:translateY(-50%) scale(1.1);
  }
  .scroll-btn.left{
    left:10px;
  }
  .scroll-btn.right{
    right:10px;
  }
  
  .header-inner{flex-wrap:wrap;}
  .header-search{order:3;max-width:100%;margin:10px 0 0;}
  .hero-title{font-size:2rem;}
  .hero-subtitle{font-size:1.1rem;}
  .search-large{flex-direction:column;}
  .search-btn{padding:12px;}
  .company-header{flex-direction:column;}
  .company-actions{width:100%;align-items:flex-start;}
  .update-info{text-align:left;}
  .tabs{overflow-x:auto;white-space:nowrap;}
  
  /* 🔥 ИЗМЕНЕНИЕ: Адаптация для мобильных устройств */
  .metrics-grid{grid-template-columns:1fr;justify-items:stretch;}
  .metric-card{max-width:none;}
  
  /* 🔥 Сбрасываем центрирование на мобильных */
  .metrics-grid .metric-card:nth-last-child(1):nth-child(4n+1),
  .metrics-grid .metric-card:nth-last-child(2):nth-child(4n+1),
  .metrics-grid .metric-card:nth-last-child(1):nth-child(4n+2) {
      grid-column: auto;
  }
  
  /* Disable row hover on mobile */
  .data-table tbody tr:hover{
    background-color:transparent;
  }
  .data-table tbody tr:hover td:first-child{
    background-color:transparent;
  }
}

/* Responsive */
@media (max-width:980px){
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .footer-content{grid-template-columns:repeat(2,1fr);}
  
  /* 🔥 ИЗМЕНЕНИЕ: Адаптация для планшетов */
  .metrics-grid{grid-template-columns:repeat(2,1fr);}
  
  /* 🔥 Сбрасываем центрирование на планшетах */
  .metrics-grid .metric-card:nth-last-child(1):nth-child(4n+1),
  .metrics-grid .metric-card:nth-last-child(2):nth-child(4n+1),
  .metrics-grid .metric-card:nth-last-child(1):nth-child(4n+2) {
      grid-column: auto;
  }
}

@media (max-width:620px){
  .cards-grid{grid-template-columns:1fr} 
  .header-inner{flex-direction:column;align-items:flex-start} 
  .key-metrics{flex-direction:column;} 
  .footer-content{grid-template-columns:1fr;}
  .metrics-grid{grid-template-columns:1fr;}
  .data-table{font-size:0.85rem;}
  .data-table th, .data-table td{padding:8px 4px;}
  .scroll-btn{
    width:32px;
    height:32px;
    font-size:1rem;
  }
}

/* ============ КРИТИЧЕСКИЕ ИСПРАВЛЕНИЯ ДЛЯ ТАБЛИЦ ============ */

/* FIX: Закрепление первого столбца ВСЕХ строк */
.data-table td:first-child {
    position: sticky;
    left: 0;
    background: var(--card-bg);
    z-index: 9;
}

/* FIX: Решение проблемы прозрачности при подсветке первого столбца */
.data-table tbody tr td:first-child {
    position: sticky;
    left: 0;
    z-index: 9;
}

.data-table tbody tr:hover td:first-child::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--section-bg);
    z-index: -1;
}

.data-table tbody tr:hover td:first-child {
    background: var(--card-bg) !important;
    z-index: 12;
}

/* FIX: Гарантия что другие ячейки при hover не становятся прозрачными */
.data-table tbody tr:hover td:not(:first-child) {
    background-color: var(--section-bg);
}

/* FIX: Улучшенные z-index для правильного наложения */
.data-table th:first-child {
    z-index: 11;
    position: sticky;
    left: 0;
}

.data-table thead th {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--card-bg);
    box-shadow: 0 1px 0 var(--border);
}

/* ============ КРАСИВЫЕ КАСТОМНЫЕ СКРОЛЛБАРЫ ============ */

/* Стилизация для Webkit браузеров (Chrome, Safari, Edge) */
.table-scroll-wrapper::-webkit-scrollbar {
    width: 14px;
    height: 14px;
}

.table-scroll-wrapper::-webkit-scrollbar-track {
    background: rgba(95, 170, 184, 0.08);
    border-radius: 7px;
    margin: 2px;
}

.table-scroll-wrapper::-webkit-scrollbar-thumb {
    background: var(--sea-turquoise);
    border-radius: 7px;
    border: 3px solid transparent;
    background-clip: content-box;
    transition: all 0.3s ease;
}

.table-scroll-wrapper::-webkit-scrollbar-thumb:hover {
    background: var(--sea-turquoise);
    border: 2px solid transparent;
}

.table-scroll-wrapper::-webkit-scrollbar-corner {
    background: transparent;
}

/* Стилизация для Firefox */
.table-scroll-wrapper {
    scrollbar-width: thin;
    scrollbar-color: var(--sea-turquoise) rgba(95, 170, 184, 0.08);
}

/* Адаптация для темной темы */
:root[data-theme="dark"] .table-scroll-wrapper::-webkit-scrollbar-track {
    background: rgba(95, 170, 184, 0.12);
}

:root[data-theme="dark"] .table-scroll-wrapper {
    scrollbar-color: var(--sea-turquoise) rgba(95, 170, 184, 0.12);
}

/* ============ СТИЛИ ДЛЯ ГЛОБАЛЬНОГО ПОИСКА ============ */

/* Секция результатов поиска */
.search-results-section {
    background: var(--section-bg);
    padding: 30px;
    border-radius: 12px;
    margin-bottom: 40px;
}

.search-results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}

/* Сообщение "Ничего не найдено" */
#noResultsMessage {
    display: none;
    text-align: center;
    padding: 40px;
    color: var(--muted);
}

#noResultsMessage div:first-child {
    font-size: 3rem;
    margin-bottom: 16px;
}

#noResultsMessage h3 {
    margin-bottom: 8px;
}

/* ============ БАЗОВЫЕ СТИЛИ ССЫЛОК ДЛЯ КАРТОЧЕК ============ */

.logo-link, .title-link {
    text-decoration: none;
    color: inherit;
    transition: opacity 0.2s ease;
}

.logo-link:hover, .title-link:hover {
    opacity: 0.7;
}

/* 🔥 КРИТИЧЕСКИЕ СТИЛИ ДЛЯ ПЕРИОДА РАСЧЕТА */
.metrics-grid .metric-card .period-note,
.metric-card .period-note {
    font-size: 0.7rem;
    color: var(--muted);
    text-align: left;
    margin-top: 2px;
    line-height: 1;
    display: block;
}

.metrics-grid .metric-card .growth-value,
.metric-card .growth-value {
    display: block;
    line-height: 1.2;
}

/* ============ ИСПРАВЛЕНИЕ ДЛЯ ПОДСКАЗОК ВНЕ ТАБЛИЦ ============ */

/* Стили для подсказок вне таблиц */
.table-tooltip .table-tiptext {
    display: none;
    position: fixed;
    z-index: 1500;
    background: var(--dark-blue);
    color: var(--light-beige);
    padding: 12px;
    border-radius: 8px;
    box-shadow: var(--shadow);
    font-size: 13px;
    line-height: 1.4;
    max-width: 320px;
    min-width: 200px;
    word-wrap: break-word;
    white-space: normal;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.table-tooltip:hover .table-tiptext {
    display: block;
    visibility: visible;
    opacity: 1;
}

/* Стрелка для подсказок */
.table-tooltip .table-tiptext::after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    background: inherit;
    transform: rotate(45deg);
}

.table-tooltip .table-tiptext[data-placement^="top"]::after {
    bottom: -4px;
    left: 50%;
    margin-left: -4px;
}

.table-tooltip .table-tiptext[data-placement^="bottom"]::after {
    top: -4px;
    left: 50%;
    margin-left: -4px;
}

.table-tooltip .table-tiptext[data-placement^="left"]::after {
    right: -4px;
    top: 50%;
    margin-top: -4px;
}

.table-tooltip .table-tiptext[data-placement^="right"]::after {
    left: -4px;
    top: 50%;
    margin-top: -4px;
}

/* ============ КРИТИЧЕСКОЕ ИСПРАВЛЕНИЕ ДЛЯ ОВЕРЛЕЙНЫХ ПОДСКАЗОК ============ */

/* Гарантируем что карточки имеют относительное позиционирование */
.company-card {
    position: relative;
}

/* Абсолютное позиционирование подсказок поверх карточек */
.company-card > .card-tiptext {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 100;
    background: var(--card-bg);
    border: 2px solid var(--sea-turquoise);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: left;
    overflow-y: auto;
    padding: 20px;
    box-shadow: var(--shadow);
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Контейнер для контента подсказки */
.company-card > .card-tiptext > .tooltip-content {
    max-width: 100%;
    max-height: 100%;
    overflow-y: auto;
    padding: 10px;
}

/* Кнопка закрытия для мобильных */
.company-card > .card-tiptext > .tooltip-close-btn {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    border: none;
    background: var(--sea-turquoise);
    border-radius: 50%;
    color: var(--card-bg);
    font-size: 18px;
    font-weight: bold;
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 101;
}

/* Показываем кнопку закрытия на мобильных */
@media (max-width: 768px) {
    .company-card > .card-tiptext > .tooltip-close-btn {
        display: flex;
    }
}

/* Задержка для десктопных подсказок */
@media (min-width: 769px) {
    .company-card > .card-tiptext {
        transition-delay: 0.4s;
    }
}

/* 🔥 ДОБАВИТЬ В КОНЕЦ main.css */
.period-note {
    font-size: 0.7rem !important;
    color: var(--muted) !important;
    text-align: left;
    margin-top: 2px;
    line-height: 1;
    display: block;
}

/* ============ МОБИЛЬНАЯ АДАПТАЦИЯ СЕТКИ ============ */

@media (max-width: 768px) {
    .cards-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}