/* base.css — токены темы, layout, шапка, общие элементы.
   Тёмная тема слоистая (градиент + edge-line), углы острые (2-4px). */

:root {
  --radius: 3px;
  --radius-lg: 4px;
  --gap: 16px;
  --maxw: 1280px;
  --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
}

/* --- светлая (по умолчанию) --- */
:root, [data-theme='light'] {
  --bg:        #f4f6fa;
  --panel:     #ffffff;
  --panel-2:   #fbfcfe;
  --ink:       #1a2230;
  --ink-soft:  #5b6678;
  --ink-mute:  #8a94a6;
  --line:      #e3e8f0;
  --line-soft: #eef1f6;
  --accent:    #2f6df0;
  --accent-ink:#ffffff;
  --up:        #1f9d57;
  --down:      #d23b3b;
  --shadow:    0 1px 2px rgba(20,30,50,.06), 0 2px 8px rgba(20,30,50,.05);
  --group-tint:#eef1f7;
}

/* --- тёмная: слоистая, не плоская --- */
[data-theme='dark'] {
  --bg:        #0b1018;
  --panel:     linear-gradient(180deg, #18202e 0%, #141b27 100%);
  --panel-2:   #1b2330;
  --ink:       #e7edf6;
  --ink-soft:  #9fadc2;
  --ink-mute:  #6b7689;
  --line:      #2a3445;
  --line-soft: #222b3a;
  --accent:    #5b8dff;
  --accent-ink:#0b1018;
  --up:        #3ecb7e;
  --down:      #ef5b5b;
  --shadow:    0 1px 0 rgba(255,255,255,.03) inset, 0 2px 10px rgba(0,0,0,.4);
  --group-tint:#121925;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
}

/* --- шапка --- */
.app-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--panel);
  border-bottom: 1px solid var(--line);
  box-shadow: var(--shadow);
}
/* шапка — одна компактная строка ~40px, переносится на узких экранах */
.app-header-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 5px 16px;
  display: flex; flex-wrap: wrap; align-items: center; gap: 5px 8px;
  min-height: 40px;
}
.app-title { font-size: 13px; font-weight: 700; white-space: nowrap; }
.hdr-sep {
  width: 1px; align-self: stretch; min-height: 18px;
  background: var(--line); margin: 0 3px;
}
.control-group { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
/* переключатель площадок WB/Ozon — после него кнопка темы уезжает к правому краю */
#mp-control { margin-right: auto; }

/* --- chips --- */
.chip {
  font: inherit; font-size: 12px;
  padding: 3px 9px;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--ink-soft);
  border-radius: var(--radius);
  cursor: pointer;
  white-space: nowrap;
  transition: background .12s, color .12s, border-color .12s;
}
.chip:hover { border-color: var(--accent); color: var(--ink); }
.chip.is-active {
  background: var(--accent); color: var(--accent-ink);
  border-color: var(--accent); font-weight: 600;
}
.chip-apply { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.period-custom { display: inline-flex; align-items: center; gap: 6px; }
.period-custom.is-hidden { display: none; }
.period-custom input[type=date] {
  font: inherit; padding: 4px 7px;
  border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--panel-2); color: var(--ink);
}
.period-error { color: var(--down); font-size: 12px; }

.theme-btn {
  font: inherit; cursor: pointer;
  width: 27px; height: 27px;
  border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--panel-2); color: var(--ink-soft);
}

/* --- main / группы / секции --- */
.app-main { max-width: var(--maxw); margin: 0 auto; padding: 20px; }
.app-status { padding: 6px 20px; font-size: 13px; color: var(--ink-mute); }
.app-status.is-error { color: var(--down); }

.dash-group {
  background: var(--group-tint);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  padding: 14px;
  margin-bottom: 18px;
}
.group-label {
  font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  color: var(--ink-mute); margin-bottom: 10px;
}
.dash-section {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
  margin-bottom: 12px;
}
.dash-section:last-child { margin-bottom: 0; }
.sec-error { color: var(--down); font-size: 13px; }

.sec-head {
  display: flex; align-items: baseline; gap: 10px;
  margin-bottom: 14px; flex-wrap: wrap;
}
.sec-head h2 { font-size: 15px; margin: 0; }
.window-badge {
  font-size: 11px; padding: 2px 8px; border-radius: var(--radius);
  font-weight: 600; letter-spacing: .02em;
}
.window-period   { background: rgba(47,109,240,.12); color: var(--accent); }
.window-snapshot { background: rgba(214,138,40,.16); color: #d68a28; }

/* --- KPI --- */
.kpi-grid {
  display: grid; gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.kpi-card {
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: 12px 14px;
}
.kpi-title { font-size: 12px; color: var(--ink-mute); margin-bottom: 6px; }
.kpi-value { font-size: 21px; font-weight: 700; }

.delta { font-size: 12px; font-weight: 600; margin-left: 4px; }
.delta-up   { color: var(--up); }
.delta-down { color: var(--down); }
.muted { color: var(--ink-mute); }

/* --- таблицы --- */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.data-table th, .data-table td {
  padding: 7px 10px;
  text-align: left;
  border-bottom: 1px solid var(--line-soft);
}
.data-table th {
  font-size: 11px; font-weight: 600;
  color: var(--ink-mute); text-transform: uppercase; letter-spacing: .03em;
}
.data-table td.num, .data-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.data-table tbody tr:hover { background: var(--panel-2); }
.data-table tfoot td {
  font-weight: 700;
  border-top: 2px solid var(--line);
  border-bottom: none;
}
.data-table tr.row-strong td { font-weight: 600; }
.table-scroll { overflow-x: auto; }
.cell-sub { font-size: 11px; color: var(--ink-mute); font-weight: 400; }

/* --- карточки «По кабинетам» --- */
.mp-grid {
  display: grid; gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.mp-card {
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: 12px 14px;
}
.mp-card-title { font-size: 13px; font-weight: 700; margin-bottom: 8px; }
.mp-row {
  display: flex; justify-content: space-between; gap: 10px;
  font-size: 13px; padding: 3px 0;
}
.mp-row span { color: var(--ink-mute); }
.mp-row b { font-variant-numeric: tabular-nums; }
.mp-card-win {
  font-size: 11px; color: var(--ink-mute);
  margin-top: 6px; padding-top: 6px;
  border-top: 1px solid var(--line-soft);
}

/* --- ABC-анализ товаров --- */
.abc-summary { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.abc-box {
  display: flex; align-items: center; gap: 8px;
  flex: 1 1 150px;
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: 8px 10px;
}
.abc-letter { font-size: 18px; font-weight: 700; width: 22px; text-align: center; }
.abc-meta { font-size: 12px; color: var(--ink-soft); }
.abc-meta b { color: var(--ink); font-size: 14px; }
.abc-A .abc-letter { color: var(--up); }
.abc-B .abc-letter { color: #d68a28; }
.abc-C .abc-letter { color: var(--ink-mute); }
.abc-tag { font-size: 11px; font-weight: 700; padding: 1px 7px; border-radius: var(--radius); }
.abc-tag.abc-A { background: rgba(31,157,87,.14);  color: var(--up); }
.abc-tag.abc-B { background: rgba(214,138,40,.16); color: #d68a28; }
.abc-tag.abc-C { background: var(--line-soft);     color: var(--ink-mute); }
.abc-more { margin-top: 8px; font-size: 12px; }

/* --- ритм продаж по дням недели --- */
.rhythm-list { display: flex; flex-direction: column; gap: 6px; }
.rhythm-row { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.rhythm-day { width: 26px; color: var(--ink-soft); font-weight: 600; }
.rhythm-bar-wrap {
  flex: 1; height: 18px;
  background: var(--panel-2);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  overflow: hidden;
}
.rhythm-bar { display: block; height: 100%; background: var(--accent); }
.rhythm-val { width: 128px; text-align: right; font-variant-numeric: tabular-nums; }
.rhythm-best .rhythm-day { color: var(--accent); }
.rhythm-best .rhythm-bar { background: var(--up); }

.turnover-lead { margin-bottom: 10px; }
.turnover-lead b { color: var(--ink); }

/* --- подпись секции: пояснение + точность данных --- */
.sec-note {
  margin-top: 12px; padding-top: 10px;
  border-top: 1px solid var(--line-soft);
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 4px 10px;
  font-size: 12px; color: var(--ink-soft); line-height: 1.5;
}
.note-text { flex: 1 1 240px; }
.accuracy-badge {
  font-size: 11px; font-weight: 600;
  padding: 2px 8px; border-radius: var(--radius);
  white-space: nowrap; align-self: center;
}
.accuracy-exact { background: rgba(31,157,87,.14);  color: var(--up); }
.accuracy-range { background: rgba(214,138,40,.16); color: #d68a28; }

/* --- плашка-предупреждение для финансовых секций на custom-периоде --- */
.coverage-warn {
  margin: 0 0 12px;
  padding: 10px 14px;
  border-left: 3px solid #d68a28;
  background: rgba(214,138,40,.10);
  border-radius: var(--radius);
  font-size: 12.5px; color: var(--ink);
  line-height: 1.45;
}
.coverage-warn-head {
  font-weight: 600;
  margin-bottom: 6px;
  color: #d68a28;
}
.coverage-warn ul {
  margin: 4px 0 6px 18px;
  padding: 0;
  color: var(--ink-soft);
}
.coverage-warn li { margin: 2px 0; }
.coverage-warn-suggest {
  margin-top: 6px;
  color: var(--ink);
}
.coverage-warn-suggest b {
  font-variant-numeric: tabular-nums;
  color: #d68a28;
}

/* --- график «Динамика» --- */
.metric-switch { display: inline-flex; gap: 4px; margin-left: auto; }
.chart-scroll { overflow-x: auto; margin-top: 6px; }
.chart { display: block; }
.ch-grid { stroke: var(--line-soft); }
.ch-axis { stroke: var(--line); }
.ch-bar  { fill: var(--accent); transition: opacity .12s; }
.ch-bar:hover { opacity: .75; }
.ch-ylab, .ch-xlab { fill: var(--ink-mute); font-size: 10px; font-family: var(--font); }
.chart-summary {
  display: flex; flex-wrap: wrap; gap: 4px 18px;
  margin-top: 10px; font-size: 13px; color: var(--ink-soft);
}
.chart-summary b { color: var(--ink); font-variant-numeric: tabular-nums; }

@media (max-width: 640px) {
  .app-header-inner, .app-main { padding-left: 12px; padding-right: 12px; }
  .hdr-sep { display: none; }   /* при переносе строк разделители не нужны */
  .kpi-value { font-size: 19px; }
  /* на узких экранах ужимаем вложенные рамки и таблицы — двойная вложенность
     group→section съедала ~84px горизонтали, 4-колоночные таблицы не влезали */
  .dash-group { padding: 10px; }
  .dash-section { padding: 12px; }
  .data-table { font-size: 12px; }
  .data-table th, .data-table td { padding: 6px 7px; }
  /* мобильный хидер — читаемые строки: заголовок+тема / период / кабинеты /
     площадки. Раньше всё сваливалось в один flex-wrap и переносилось хаотично. */
  .app-title { order: 1; flex: 1 1 auto; }
  #theme-toggle { order: 2; }
  #period-control { order: 3; flex-basis: 100%; }
  #account-control { order: 4; flex-basis: 100%; }
  #mp-control { order: 5; flex-basis: 100%; margin-right: 0; }
}
