/* dashboard.css — продуктовый слой поверх frozen ms-токенов и Bootstrap.
   ms_design/base.css задаёт палитру corporate (#2553A0). Здесь — мост к
   Bootstrap-переменным, ширина дашборда, тулбар, KPI, панели, графики. */

:root {
  --good: #16a34a;
  --bad: #dc2626;
  --warn: #d97706;
  --teal: #0d9488;

  /* Мост к Bootstrap: чтобы Reboot не перекрашивал страницу в дефолт */
  --bs-body-bg: var(--ms-bg);
  --bs-body-color: var(--ms-text);
  --bs-body-font-family: var(--ms-font);
  --bs-border-color: var(--ms-border);
  --bs-primary: var(--ms-primary);
  --bs-primary-rgb: 37, 83, 160;
}

body {
  background: var(--ms-bg);
  color: var(--ms-text);
  font-family: 'Inter', var(--ms-font);
}

/* Шире, чем дефолтные 960px — это рабочий дашборд */
.ms-shell { max-width: 1280px; }

/* Хедер: слева, с иконкой Steam */
.ms-header .ms-shell { text-align: left; }
.ms-header h1 {
  text-align: left;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: var(--ms-fs-2xl);
}
.ms-header h1 .fa-steam { opacity: .92; }
.ms-header p { text-align: left; max-width: 70ch; }

.dash { display: flex; flex-direction: column; gap: 20px; }

/* ── Тулбар ──────────────────────────────────────────────────────── */
.toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  padding: 14px 18px;
  box-shadow: var(--ms-shadow-sm);
  position: sticky;
  top: 8px;
  z-index: 20;
}
.toolbar-left { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.toolbar-right { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.toolbar-cap {
  font-size: var(--ms-fs-s);
  font-weight: 600;
  color: var(--ms-text-soft);
  display: inline-flex; align-items: center; gap: 7px;
}
.toolbar-cap i { color: var(--ms-primary); }

.period-switch {
  display: inline-flex;
  background: var(--ms-surface-2);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius-pill);
  padding: 4px;
  gap: 2px;
}
.period-switch .seg {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--ms-text-soft);
  font: inherit;
  font-weight: 600;
  font-size: var(--ms-fs-s);
  padding: 7px 18px;
  border-radius: var(--ms-radius-pill);
  cursor: pointer;
  text-decoration: none;
  transition: background var(--ms-transition), color var(--ms-transition), box-shadow var(--ms-transition);
}
.period-switch .seg:hover { color: var(--ms-text); }
.period-switch .seg--active {
  background: var(--ms-primary);
  color: #fff;
  box-shadow: 0 2px 8px rgba(37, 83, 160, .35);
}

.source-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--ms-fs-s);
  font-weight: 500;
  color: var(--ms-text-soft);
  padding: 6px 12px;
  border-radius: var(--ms-radius-pill);
  border: 1px solid var(--ms-border);
  background: var(--ms-surface-2);
}
.src-dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.source-badge--live .src-dot { background: var(--good); box-shadow: 0 0 0 3px rgba(22,163,74,.18); }
.source-badge--demo .src-dot { background: var(--warn); box-shadow: 0 0 0 3px rgba(217,119,6,.18); }

.btn-refresh {
  appearance: none;
  border: 1px solid var(--ms-primary);
  background: var(--ms-surface);
  color: var(--ms-primary);
  font: inherit;
  font-weight: 600;
  font-size: var(--ms-fs-s);
  padding: 7px 14px;
  border-radius: var(--ms-radius-s);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
  transition: background var(--ms-transition), color var(--ms-transition);
}
.btn-refresh:hover { background: var(--ms-primary); color: #fff; }
.btn-refresh:disabled { opacity: .6; cursor: progress; }
.btn-refresh i.spin { animation: ms-spin .9s linear infinite; }

.refresh-note {
  font-size: var(--ms-fs-s);
  padding: 10px 14px;
  border-radius: var(--ms-radius-s);
  background: rgba(37,83,160,.07);
  border-left: 4px solid var(--ms-primary);
  color: var(--ms-text);
}

/* ── KPI ─────────────────────────────────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.kpi {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  padding: 18px;
  box-shadow: var(--ms-shadow-sm);
  position: relative;
  overflow: hidden;
}
.kpi::before {
  content: "";
  position: absolute; inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, var(--ms-primary), var(--ms-primary-2));
}
.kpi-ico {
  flex: none;
  width: 44px; height: 44px;
  border-radius: 12px;
  display: grid; place-items: center;
  background: rgba(37,83,160,.10);
  color: var(--ms-primary);
  font-size: 18px;
}
.kpi-body { min-width: 0; }
.kpi-label { margin: 0; font-size: var(--ms-fs-xs); text-transform: uppercase; letter-spacing: .04em; color: var(--ms-text-muted); font-weight: 700; }
.kpi-value { margin: 3px 0 4px; font-size: var(--ms-fs-xl); font-weight: 700; line-height: 1.15; }
.kpi-sub { margin: 0; font-size: var(--ms-fs-s); color: var(--ms-text-soft); display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

/* ── Панели ──────────────────────────────────────────────────────── */
.panel {
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  padding: 20px 22px;
  box-shadow: var(--ms-shadow-sm);
}
.panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.panel-title { margin: 0; font-size: var(--ms-fs-l); font-weight: 700; display: flex; align-items: center; gap: 9px; }
.panel-title i { color: var(--ms-primary); }
.panel-sub { margin: 5px 0 0; font-size: var(--ms-fs-s); color: var(--ms-text-soft); max-width: 70ch; }
.panel-foot { margin: 12px 0 0; font-size: var(--ms-fs-s); color: var(--ms-text-soft); }
.panel-body { margin: 0; }

/* Собственная адаптивная сетка (не зависит от Bootstrap — работает на любом хосте) */
.cols { display: grid; gap: 24px; align-items: stretch; }
.cols-7-5 { grid-template-columns: 1fr; }
@media (min-width: 992px) { .cols-7-5 { grid-template-columns: 1.45fr 1fr; } }

.metric-switch { display: inline-flex; border: 1px solid var(--ms-border); border-radius: var(--ms-radius-s); overflow: hidden; }
.metric-switch .mseg {
  appearance: none; border: none; background: var(--ms-surface);
  color: var(--ms-text-soft); font: inherit; font-weight: 600; font-size: var(--ms-fs-s);
  padding: 8px 16px; cursor: pointer; transition: background var(--ms-transition), color var(--ms-transition);
}
.metric-switch .mseg + .mseg { border-left: 1px solid var(--ms-border); }
.metric-switch .mseg--active { background: var(--ms-primary); color: #fff; }

/* ── Графики ─────────────────────────────────────────────────────── */
.chart-wrap { width: 100%; }
.chart-wrap--tall { min-height: 0; }
.chart-svg { width: 100%; height: auto; display: block; font-family: var(--ms-font); }

.bar-axis { stroke: var(--ms-border); stroke-width: 1; }
.bar-track { fill: var(--ms-surface-2); }
.bar-fill { fill: var(--ms-primary); transition: opacity var(--ms-transition); }
.chart-bars--teal .bar-fill { fill: var(--teal); }
.bar-fill:hover { opacity: .82; }
.bar-label { fill: var(--ms-text); font-size: 13px; font-weight: 600; }
.bar-value { fill: var(--ms-text-soft); font-size: 12px; font-weight: 700; }

.grid { stroke: var(--ms-border); stroke-width: 1; opacity: .55; }
.axis { stroke: var(--ms-text-muted); stroke-width: 1.2; }
.median-line { stroke: var(--ms-text-muted); stroke-width: 1.2; stroke-dasharray: 4 4; opacity: .55; }
.tick { fill: var(--ms-text-muted); font-size: 11px; }
.axis-title { fill: var(--ms-text-soft); font-size: 11px; font-weight: 700; }

.quad-good { fill: rgba(22,163,74,.08); }
.quad-bad { fill: rgba(220,38,38,.06); }
.pt { stroke: #fff; stroke-width: 1.6; opacity: .9; transition: opacity var(--ms-transition); cursor: default; }
.pt:hover { opacity: 1; }
.pt-good { fill: var(--good); }
.pt-bad { fill: var(--bad); }
.pt-info { fill: var(--ms-primary); }
.pt-muted { fill: #94a3b8; }
.pt-label { fill: var(--ms-text-soft); font-size: 11px; font-weight: 600; }

.line-series { fill: none; stroke-width: 2.6; stroke-linejoin: round; stroke-linecap: round; }
.line-dot { stroke: var(--ms-surface); stroke-width: 1.4; }

.quad-legend, .line-legend { display: flex; flex-wrap: wrap; gap: 8px 14px; margin-top: 14px; }
.qchip, .lchip { font-size: var(--ms-fs-xs); font-weight: 600; color: var(--ms-text-soft); display: inline-flex; align-items: center; gap: 7px; }
.qchip::before { content: ""; width: 12px; height: 12px; border-radius: 4px; display: inline-block; }
.qchip--good::before { background: var(--good); }
.qchip--bad::before { background: var(--bad); }
.qchip--info::before { background: var(--ms-primary); }
.qchip--muted::before { background: #94a3b8; }
.lswatch { width: 16px; height: 4px; border-radius: 2px; display: inline-block; }

.insight {
  display: flex; gap: 12px; align-items: flex-start;
  margin-top: 16px; padding: 14px 16px;
  background: rgba(22,163,74,.07);
  border: 1px solid rgba(22,163,74,.22);
  border-radius: var(--ms-radius-s);
  font-size: var(--ms-fs-s);
}
.insight > i { color: var(--good); margin-top: 2px; }
.insight .pill {
  display: inline-block; margin: 4px 6px 0 0;
  background: var(--ms-surface); border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius-pill); padding: 4px 11px; font-weight: 600; font-size: var(--ms-fs-xs);
}

/* ── Таблица ─────────────────────────────────────────────────────── */
.table-scroll { overflow-x: auto; border-radius: var(--ms-radius-s); border: 1px solid var(--ms-border); }
.gtable { width: 100%; border-collapse: collapse; font-size: var(--ms-fs-s); }
.gtable th, .gtable td { padding: 9px 12px; text-align: left; white-space: nowrap; }
.gtable thead th {
  background: var(--ms-surface-2); color: var(--ms-text-soft);
  font-weight: 700; font-size: var(--ms-fs-xs); text-transform: uppercase; letter-spacing: .03em;
  position: sticky; top: 0;
  border-bottom: 1px solid var(--ms-border);
}
.gtable td.num, .gtable th.num { text-align: right; font-variant-numeric: tabular-nums; }
.gtable tbody tr + tr td { border-top: 1px solid var(--ms-border); }
.gtable tbody tr:hover td { background: rgba(37,83,160,.04); }
.gtable .g-name { font-weight: 600; }
.gtable .strong { font-weight: 700; color: var(--ms-text); }

/* ── Теги ────────────────────────────────────────────────────────── */
.cloud { display: flex; flex-wrap: wrap; gap: 9px 12px; align-items: center; align-content: flex-start; }
.tag {
  display: inline-flex; align-items: center;
  line-height: 1.1; padding: 7px 13px; border-radius: var(--ms-radius-pill);
  font-weight: 700; border: 1px solid transparent; cursor: default;
}
.tag--up { background: rgba(22,163,74,.10); color: #15803d; border-color: rgba(22,163,74,.25); }
.tag--down { background: rgba(220,38,38,.08); color: #b91c1c; border-color: rgba(220,38,38,.22); }
.tag--flat { background: var(--ms-surface-2); color: var(--ms-text-soft); border-color: var(--ms-border); }

.tag-rank { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.tag-rank li { display: flex; align-items: center; gap: 10px; font-size: var(--ms-fs-s); }
.tr-rank { flex: none; width: 22px; height: 22px; border-radius: 6px; background: var(--ms-surface-2); color: var(--ms-text-soft); font-weight: 700; font-size: var(--ms-fs-xs); display: grid; place-items: center; }
.tr-name { flex: none; width: 130px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tr-bar { flex: 1; height: 8px; background: var(--ms-surface-2); border-radius: var(--ms-radius-pill); overflow: hidden; }
.tr-bar-fill { display: block; height: 100%; background: linear-gradient(90deg, var(--ms-primary), var(--ms-primary-2)); border-radius: inherit; }

/* ── Тренд-бейдж ─────────────────────────────────────────────────── */
.trend { display: inline-flex; align-items: center; gap: 4px; font-weight: 700; font-size: .86em; white-space: nowrap; }
.trend i { font-size: .85em; }
.trend--up { color: var(--good); }
.trend--down { color: var(--bad); }
.trend--flat { color: var(--ms-text-muted); }

/* ── Методология ─────────────────────────────────────────────────── */
.method {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: var(--ms-fs-xs); color: var(--ms-text-muted);
  padding: 4px 2px 8px; line-height: 1.5;
}
.method i { margin-top: 2px; color: var(--ms-text-soft); }
.method a { color: var(--ms-primary); font-weight: 600; }

/* ── Адаптив ─────────────────────────────────────────────────────── */
@media (max-width: 1100px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) {
  .kpi-grid { grid-template-columns: 1fr; }
  .toolbar { position: static; }
  .ms-header h1 { font-size: var(--ms-fs-xl); }
  .tr-name { width: 96px; }
  .panel { padding: 16px; }
}

/* Доступность фокуса */
.seg:focus-visible, .mseg:focus-visible, .btn-refresh:focus-visible, .method a:focus-visible {
  outline: 3px solid rgba(37,83,160,.4); outline-offset: 2px;
}
