/* 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; }
#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); }

@media (max-width: 640px) {
  .app-header-inner, .app-main { padding-left: 12px; padding-right: 12px; }
  .hdr-sep { display: none; }   /* при переносе строк разделители не нужны */
  .kpi-value { font-size: 19px; }
}
