/* Catppuccin Mocha — тёмная + минимализм + компактность */
/* 2026-06-19: pair-mode-chip — карточка «Режимы пар» */
.pair-mode-chip {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 6px;
  background: #313244;
  border: 1px solid #45475a;
  cursor: pointer;
  font-size: 0.85em;
  transition: background 0.15s, border-color 0.15s;
  user-select: none;
}
.pair-mode-chip:hover {
  background: #45475a;
  border-color: #6c7086;
}
.pair-mode-chip[data-mode="instant"]      { border-left: 3px solid #22c55e; }
.pair-mode-chip[data-mode="watchlist"]    { border-left: 3px solid #eab308; }
.pair-mode-chip[data-mode="monitor_only"] { border-left: 3px solid #94a3b8; }

/* 2026-06-23: при отсутствии сделок карточка «Открытые позиции» растягивается на всю ширину, Капитал переезжает на следующую строку */
.card-positions.hide-when-empty {
  grid-column: 1 / -1;
}

/* 2026-06-24: stale-строки в «Активные сетапы» — серым (данные устарели >30 сек) */
.spreads-table .row-main.row-stale {
  opacity: 0.45;
  filter: saturate(0.3);
}
.spreads-table .row-main.row-stale td {
  color: #6c7086;
}


:root {
  --base: #1e1e2e;
  --mantle: #181825;
  --crust: #11111b;
  --surface0: #313244;
  --surface1: #45475a;
  --surface2: #585b70;
  --text: #cdd6f4;
  --subtext1: #bac2de;
  --subtext0: #a6adc8;
  --overlay0: #6c7086;
  --blue: #89b4fa;
  --lavender: #b4befe;
  --mauve: #cba6f7;
  --pink: #f5c2e7;
  --red: #f38ba8;
  --peach: #fab387;
  --yellow: #f9e2af;
  --green: #a6e3a1;
  --teal: #94e2d5;
  --sky: #89dceb;

  --mono: ui-monospace, "JetBrains Mono", "Cascadia Code", Consolas, monospace;
  --shadow-1: 0 1px 2px rgba(0,0,0,0.18);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

/* hidden-атрибут должен побеждать display:flex/grid в наших компонентах */
[hidden] { display: none !important; }

html, body {
  background: var(--base);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  font-size: 13.5px;
  line-height: 1.5;
}

.container {
  max-width: 1320px;
  margin: 0 auto;
  padding: 16px 20px 24px;
}

/* ============================================================
   TOPBAR — однострочный header
   ============================================================ */

/* ============================================================
   ТОПБАР (редизайн 2026-06-15 v2, консенсус 4 агентов)
   Высота 52px, 3 блока, gap 32px вместо border, Inter + tabular-nums,
   DEMO крупно, PnL дня — главное число, KILL pulse при срабатывании.
   ============================================================ */
.topbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 32px;
  min-height: 52px;
  padding: 0 18px;
  margin-bottom: 12px;
  background: var(--mantle);
  border: 1px solid var(--surface0);
  border-radius: 10px;
  font-feature-settings: "tnum" 1, "lnum" 1;
  transition: background-color 250ms ease;
}
/* KILL active: фон топбара плавно red 8% — спокойно но заметно */
.topbar.kill-active {
  background: color-mix(in srgb, var(--red) 10%, var(--mantle));
}

/* ---- Блок 1: бренд + DEMO ---- */
.topbar-left {
  display: flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
}
.topbar-left .logo { font-size: 17px; }
.brand-name {
  font-weight: 600;
  color: var(--text);
  font-size: 15px;
  letter-spacing: 0.1px;
}
.mode-pill {
  background: color-mix(in srgb, var(--yellow) 18%, transparent);
  color: var(--yellow);
  padding: 4px 9px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  cursor: help;
}
.mode-pill.mainnet {
  background: color-mix(in srgb, var(--red) 20%, transparent);
  color: var(--red);
}

/* ---- Блок 2: PnL дня + открытые + полоска до стопа ---- */
.topbar-center {
  display: flex;
  align-items: center;
  gap: 28px;
  justify-content: center;
}
.topbar-pnl {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.topbar-pnl-label {
  font-size: 10.5px;
  color: var(--subtext0);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.topbar-pnl-value {
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.topbar-pnl-value.pos { color: var(--green); }
.topbar-pnl-value.neg { color: var(--red); }
.topbar-pnl-pct {
  font-size: 12px;
  font-weight: 500;
  color: var(--subtext0);
  font-variant-numeric: tabular-nums;
}
.topbar-open {
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.topbar-open-label {
  font-size: 10.5px;
  color: var(--subtext0);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.topbar-open-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.topbar-dailystop {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 3px;
  min-width: 110px;
}
.topbar-dailystop-bar {
  position: relative;
  width: 100%;
  height: 4px;
  background: var(--surface1);
  border-radius: 2px;
  overflow: hidden;
}
.topbar-dailystop-fill {
  height: 100%;
  width: 0%;
  background: var(--green);
  border-radius: 2px;
  transition: width 300ms ease, background-color 200ms ease;
}
.topbar-dailystop-fill.warn { background: var(--yellow); }
.topbar-dailystop-fill.danger {
  background: var(--red);
  animation: dailystop-pulse 1.5s ease-in-out infinite;
}
@keyframes dailystop-pulse {
  0%, 100% { opacity: 0.9; }
  50% { opacity: 0.55; }
}
.topbar-dailystop-text {
  font-size: 10px;
  color: var(--subtext0);
  font-variant-numeric: tabular-nums;
  text-align: center;
  letter-spacing: 0.03em;
}

/* ---- Блок 3: статусы + STOP ---- */
.topbar-right {
  display: flex;
  align-items: center;
  gap: 14px;
  white-space: nowrap;
}
.status-dots {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.status-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--overlay0);
  cursor: help;
  transition: background-color 250ms ease;
}
.status-dot.up { background: color-mix(in srgb, var(--green) 75%, transparent); }
.status-dot.down { background: var(--red); }
.status-dot.warn { background: var(--yellow); }

.topbar-icon-btn {
  background: transparent;
  border: none;
  color: var(--subtext0);
  cursor: pointer;
  font-size: 15px;
  padding: 4px;
  border-radius: 4px;
  transition: color 150ms ease;
}
.topbar-icon-btn:hover { color: var(--text); }

/* ============================================================
   KILL-switch (Этап 2 — agent-zashita-torgovli, 2026-06-12)
   ============================================================ */

/* KILL — плоский стиль (creative-director + wow-effects):
   фон red 20% opacity, текст red, без тени. Hover — 35% opacity.
   При активации — пульсация и фон полный red. */
.kill-button {
  background: color-mix(in srgb, var(--red) 20%, transparent);
  color: var(--red);
  border: 0;
  padding: 7px 16px;
  border-radius: 6px;
  font-weight: 700;
  font-size: 12px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background-color 150ms ease, color 150ms ease;
  user-select: none;
  letter-spacing: 0.5px;
  font-family: inherit;
}
.kill-button:hover {
  background: color-mix(in srgb, var(--red) 35%, transparent);
}
.kill-button.holding {
  background: color-mix(in srgb, var(--peach) 40%, transparent);
  color: var(--peach);
  animation: kill-pulse 2s linear forwards;
}
.kill-button.active {
  background: var(--red);
  color: var(--base);
  animation: kill-pulse-active 1.5s ease-in-out infinite;
}
@keyframes kill-pulse {
  0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--peach) 50%, transparent); }
  100% { box-shadow: 0 0 0 18px transparent; }
}
@keyframes kill-pulse-active {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

.kill-banner {
  position: fixed;
  top: 0; left: 0; right: 0;
  background: var(--red);
  color: var(--crust);
  padding: 10px 16px;
  text-align: center;
  font-weight: 700;
  z-index: 100;
  font-size: 13px;
}

/* AutoRecovery toggle (2026-06-14) — в topbar справа от настроек */
.auto-recovery-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  user-select: none;
  font-size: 11px;
  color: var(--subtext0);
  padding: 4px 8px;
  border: 1px solid var(--surface1);
  border-radius: 6px;
  margin-left: 6px;
  transition: border-color 0.15s ease, color 0.15s ease;
}
.auto-recovery-toggle:hover { border-color: var(--surface2); color: var(--text); }
.auto-recovery-toggle input { accent-color: var(--green); margin: 0; }
.auto-recovery-toggle.off { border-color: var(--red); }
.auto-recovery-toggle.off .ar-label { color: var(--red); }

/* ============================================================
   ONBOARDING
   ============================================================ */

.onboarding {
  display: flex;
  gap: 14px;
  background: linear-gradient(135deg, rgba(180, 190, 254, 0.08), rgba(203, 166, 247, 0.05));
  border: 1px solid var(--surface1);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 14px;
  align-items: center;
}
.onboarding-content { flex: 1; }
.onboarding-content strong {
  display: block;
  color: var(--lavender);
  margin-bottom: 4px;
  font-size: 13px;
}
.onboarding-content p {
  font-size: 12.5px;
  color: var(--subtext1);
  margin-top: 4px;
}
.onboarding-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  white-space: nowrap;
}

.btn-primary {
  background: var(--lavender);
  color: var(--crust);
  border: 0;
  padding: 6px 14px;
  border-radius: 6px;
  font-weight: 600;
  font-size: 12px;
  cursor: pointer;
}
.btn-primary:hover { background: var(--mauve); }
.btn-text {
  background: transparent;
  border: 0;
  color: var(--subtext0);
  cursor: pointer;
  font-size: 11.5px;
  text-decoration: underline;
}
.btn-text:hover { color: var(--text); }

/* ============================================================
   CARDS
   ============================================================ */

.card {
  background: var(--mantle);
  border: 1px solid var(--surface0);
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  border-bottom: 1px solid var(--surface0);
}

.card-header h2 {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0.3px;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.muted {
  font-size: 11.5px;
  color: var(--subtext0);
}

/* ============================================================
   Watchlist (карточка «Наблюдение», 2026-06-16)
   ============================================================ */
.watchlist-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  padding: 10px 14px;
  background: var(--mantle);
  border-bottom: 1px solid var(--surface0);
  font-size: 11px;
  color: var(--subtext0);
  font-variant-numeric: tabular-nums;
}
.wl-meta-item { display: inline-flex; gap: 5px; align-items: baseline; }
.wl-meta-label { color: var(--overlay0); }
.wl-meta-item span:not(.wl-meta-label) { color: var(--text); font-weight: 500; }
.wl-meta-sep { color: var(--surface2); user-select: none; }

.watchlist-list {
  padding: 6px 0;
  max-height: 420px;
  overflow-y: auto;
}
.watchlist-stats {
  display: flex;
  gap: 14px;
  padding: 10px 14px;
  background: var(--mantle);
  border-bottom: 1px solid var(--surface0);
  align-items: center;
  flex-wrap: wrap;
}
.wl-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 85px;
}
.wl-stat-label {
  font-size: 10px;
  color: var(--subtext0);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.wl-stat-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.wl-stat-value.pos { color: var(--green); }
.wl-stat-value.neg { color: var(--red); }

.watch-row {
  display: grid;
  grid-template-columns: 90px 1fr 80px 80px 80px 80px 60px 50px;
  gap: 10px;
  padding: 10px 14px 14px 14px;
  border-bottom: 1px solid var(--surface0);
  align-items: center;
  font-size: 11.5px;
  font-variant-numeric: tabular-nums;
  position: relative;
  border-left: 3px solid transparent;
  transition: background-color 150ms ease, border-left-color 200ms ease;
  animation: watch-row-in 200ms cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes watch-row-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.watch-row:hover { background: var(--surface0); }
.watch-row:last-child { border-bottom: none; }
/* Heat-индикатор: cold blue → warm yellow → hot red */
.watch-row.heat-cold { border-left-color: color-mix(in srgb, var(--blue) 60%, transparent); }
.watch-row.heat-warm { border-left-color: color-mix(in srgb, var(--yellow) 70%, transparent); }
.watch-row.heat-hot {
  border-left-color: var(--peach);
  background: color-mix(in srgb, var(--peach) 5%, transparent);
}
/* Состояние fading — приглушённое */
.watch-row.tag-fading {
  opacity: 0.65;
}
/* Confirmed → зелёная вспышка перед удалением */
.watch-row.confirmed-flash {
  background: color-mix(in srgb, var(--green) 30%, transparent);
  border-left-color: var(--green);
  transition: background-color 80ms ease;
}
/* Progress bar времени снизу */
.watch-row::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  height: 2px;
  width: var(--time-progress, 100%);
  background: var(--green);
  transition: width 400ms linear, background-color 200ms ease;
}
.watch-row.time-warn::after { background: var(--yellow); }
.watch-row.time-danger::after { background: var(--red); }

.watch-sparkline {
  width: 70px;
  height: 18px;
}
.watch-sparkline path {
  fill: none;
  stroke: var(--blue);
  stroke-width: 1.2;
}
.watch-sparkline.up path { stroke: var(--green); }
.watch-sparkline.down path { stroke: var(--red); }

.watch-pnl {
  display: flex;
  flex-direction: column;
  gap: 1px;
  text-align: right;
}
.watch-pnl-net {
  font-weight: 600;
}
.watch-pnl-net.pos { color: var(--green); }
.watch-pnl-net.neg { color: var(--red); }
.watch-pnl-fees {
  font-size: 9.5px;
  color: var(--overlay0);
}

.watch-actions {
  display: flex;
  gap: 4px;
  justify-content: flex-end;
}
.watch-action-btn {
  background: transparent;
  border: none;
  color: var(--subtext0);
  cursor: pointer;
  font-size: 13px;
  padding: 2px 5px;
  border-radius: 4px;
  transition: color 120ms ease, background-color 120ms ease;
}
.watch-action-btn:hover {
  background: var(--surface1);
  color: var(--text);
}
.watch-action-btn.danger:hover { color: var(--red); }
.watch-pair {
  font-weight: 600;
  color: var(--text);
}
.watch-exchanges {
  color: var(--subtext0);
  font-size: 11px;
}
.watch-spread {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.watch-spread-first {
  font-size: 10px;
  color: var(--overlay0);
}
.watch-spread-last {
  font-weight: 600;
  color: var(--text);
}
.watch-spread-last.up { color: var(--green); }
.watch-spread-last.down { color: var(--red); }
.watch-signals {
  display: flex;
  align-items: center;
  gap: 4px;
  font-weight: 600;
}
.watch-signals-progress {
  display: inline-flex;
  gap: 2px;
}
.watch-signals-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--surface2);
}
.watch-signals-dot.filled { background: var(--green); }
.watch-expires {
  color: var(--subtext0);
  font-size: 11px;
  text-align: right;
}
.watch-expires.warn { color: var(--yellow); }
.watch-expires.danger { color: var(--red); }

.link-btn {
  background: transparent;
  border: none;
  color: var(--blue);
  font-size: 11.5px;
  cursor: pointer;
  padding: 2px 6px;
  margin-left: auto;
  text-decoration: underline dotted;
  text-underline-offset: 3px;
}
.link-btn:hover { color: var(--lavender); }
.link-btn:active { color: var(--mauve); }

.card-actions {
  display: flex;
  gap: 6px;
}

/* ============================================================
   Pinned-лента дня (под топбаром, всегда видна)
   ============================================================ */
.pinned-tape {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 14px;
  margin-top: 8px;
  background: linear-gradient(180deg, var(--mantle), var(--base));
  border: 1px solid var(--surface1);
  border-radius: 8px;
  font-size: 12.5px;
  flex-wrap: wrap;
}
.pinned-tape .pt-item {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
}
.pinned-tape .pt-label {
  color: var(--subtext0);
  font-size: 11.5px;
}
.pinned-tape .pt-value {
  font-weight: 600;
  color: var(--text);
}
.pinned-tape .pt-value.pos { color: var(--green); }
.pinned-tape .pt-value.neg { color: var(--red); }
.pinned-tape .pt-sep {
  color: var(--surface2);
  user-select: none;
}
.pinned-tape .pt-collapse-btn {
  margin-left: auto;
}

/* ============================================================
   Collapsible cards (2026-06-14 — редизайн дашборда)
   Все секции по умолчанию свёрнуты, видим только заголовок.
   ============================================================ */
.collapsible-header {
  cursor: pointer;
  user-select: none;
  transition: border-color 150ms ease, filter 150ms ease;
  border-left: 3px solid transparent;
  padding-left: 11px;
}
.collapsible-header:hover {
  border-left-color: var(--blue);
  filter: brightness(1.12);
}
.collapsible-arrow {
  margin-left: 8px;
  color: var(--subtext0);
  font-size: 13px;
  transition: transform 180ms cubic-bezier(0.4, 0, 0.2, 1);
  display: inline-flex;
  align-items: center;
}
.card.collapsed .collapsible-arrow {
  transform: rotate(-90deg);
}
.collapsible-body {
  overflow: hidden;
  transition: max-height 200ms cubic-bezier(0.4, 0, 0.2, 1),
              opacity 180ms ease,
              padding 180ms ease;
  max-height: 4000px;
  opacity: 1;
}
.card.collapsed .collapsible-body {
  max-height: 0;
  opacity: 0;
  padding-top: 0;
  padding-bottom: 0;
  pointer-events: none;
}

/* Locked — секция авто-раскрыта системой и нельзя свернуть (head-of-trading) */
.card.locked .collapsible-header {
  cursor: not-allowed;
  border-left-color: var(--red);
}
.card.locked .collapsible-arrow {
  opacity: 0.3;
}
.card.locked.danger .collapsible-header h2 {
  color: var(--red);
}

/* Summary-info — текст справа от заголовка (счётчик, статус) */
.summary-info {
  margin-left: auto;
  margin-right: 8px;
}
.summary-info.pos { color: var(--green); }
.summary-info.neg { color: var(--red); }
.summary-info.warn { color: var(--yellow); }

/* Карточка-приглушка (для отключённых секций — Алёрты) */
.card.card-faded {
  opacity: 0.65;
}
.card.card-faded:hover {
  opacity: 1;
}

/* ============================================================
   Team card — табы (Рекомендации / Обсуждения / История)
   ============================================================ */
.team-tabs {
  display: flex;
  gap: 4px;
  padding: 8px 12px 0 12px;
  border-bottom: 1px solid var(--surface1);
}
.team-tab {
  background: transparent;
  border: none;
  color: var(--subtext0);
  padding: 8px 14px;
  cursor: pointer;
  font-size: 12.5px;
  border-bottom: 2px solid transparent;
  transition: color 150ms ease, border-color 150ms ease;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.team-tab:hover {
  color: var(--text);
}
.team-tab.active {
  color: var(--text);
  border-bottom-color: var(--blue);
  font-weight: 600;
}
.tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: var(--surface1);
  border-radius: 9px;
  font-size: 10.5px;
  color: var(--subtext0);
}
.team-tab.active .tab-badge {
  background: var(--blue);
  color: var(--base);
}
.team-pane {
  display: none;
}
.team-pane.active {
  display: block;
}

/* ============================================================
   HINT (?) — глоссарий
   ============================================================ */

.hint-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--surface1);
  color: var(--subtext1);
  font-size: 10px;
  font-weight: 700;
  cursor: help;
  text-transform: none;
  letter-spacing: 0;
}
.hint-icon:hover { background: var(--surface2); color: var(--text); }

.hint {
  border-bottom: 1px dotted var(--subtext0);
  cursor: help;
}
.hint:hover { color: var(--lavender); }

.tooltip-pop {
  position: fixed;
  z-index: 1000;
  background: var(--crust);
  border: 1px solid var(--surface1);
  color: var(--text);
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 12px;
  max-width: 320px;
  line-height: 1.4;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
  pointer-events: none;
}
.tooltip-pop strong {
  color: var(--lavender);
  display: block;
  margin-bottom: 3px;
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

/* ============================================================
   CONNECTORS
   ============================================================ */

.connectors {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
  padding: 10px 14px;
}

.connector {
  background: var(--surface0);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12.5px;
}

.connector-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.connector .exchange-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  user-select: none;
}
.connector .exchange-toggle input[type="checkbox"] {
  width: 13px;
  height: 13px;
  cursor: pointer;
  accent-color: var(--green);
}

.connector .name {
  font-size: 12px;
  font-weight: 600;
  color: var(--mauve);
  letter-spacing: 0.4px;
}

.connector .pill {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 8px;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
}
.connector .pill.up { background: var(--green); color: var(--crust); }
.connector .pill.down { background: var(--red); color: var(--crust); }

.connector .pairs {
  color: var(--subtext0);
  font-size: 11px;
  font-family: var(--mono);
}

.connector .profile-btn {
  background: transparent;
  color: var(--subtext0);
  border: 0;
  padding: 2px 0 0;
  font-size: 11px;
  cursor: pointer;
  text-align: left;
}
.connector .profile-btn:hover { color: var(--lavender); }

.connector.disabled {
  opacity: 0.45;
  background: var(--mantle);
}

/* ============================================================
   ANTI-BAN
   ============================================================ */

.antiban-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 6px;
  padding: 10px 14px;
}

.antiban-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 6px 10px;
  background: var(--surface0);
  border-radius: 6px;
  font-size: 12px;
}
.antiban-row .ab-name {
  font-weight: 600;
  color: var(--mauve);
  font-family: var(--mono);
  font-size: 11.5px;
  min-width: 65px;
}
.antiban-bar {
  position: relative;
  height: 6px;
  background: var(--mantle);
  border-radius: 3px;
  overflow: hidden;
}
.antiban-bar-fill {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  border-radius: 3px;
  transition: width 0.3s ease, background 0.3s ease;
}
.antiban-bar-fill.green { background: var(--green); }
.antiban-bar-fill.yellow { background: var(--yellow); }
.antiban-bar-fill.red { background: var(--red); }

.antiban-row .ab-stats {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--subtext0);
  text-align: right;
}
.antiban-row .ab-stats .pct {
  color: var(--text);
  font-weight: 700;
}
.antiban-row .ab-stats .pct.warn { color: var(--yellow); }
.antiban-row .ab-stats .pct.danger { color: var(--red); }
.antiban-row.disconnected { opacity: 0.4; }

.antiban-footer {
  display: flex;
  justify-content: space-between;
  padding: 8px 16px 12px;
  font-size: 11.5px;
  color: var(--subtext0);
  border-top: 1px solid var(--surface0);
  font-family: var(--mono);
}
.antiban-footer .ip-ok { color: var(--green); }
.antiban-footer .ip-warn { color: var(--peach); }

/* 2026-06-12: индикатор Binance-эталона в шапке Anti-ban */
.anchor-indicator {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-family: var(--mono);
  cursor: help;
}
.anchor-indicator.anchor-active {
  background: rgba(166, 227, 161, 0.15);
  color: var(--green);
}
.anchor-indicator.anchor-inactive {
  background: rgba(108, 112, 134, 0.15);
  color: var(--overlay0);
}

/* Cooldown badge в строке таблицы */
.cooldown-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  font-size: 10px;
  font-family: var(--mono);
  background: rgba(250, 179, 135, 0.18);
  color: var(--peach);
  border-radius: 8px;
  font-weight: 600;
}

/* ============================================================
   CHIPS — категории
   ============================================================ */

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 14px;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 14px;
  background: transparent;
  border: 1px solid var(--surface1);
  color: var(--subtext0);
  cursor: pointer;
  font-size: 11.5px;
  font-weight: 500;
  user-select: none;
  transition: all 0.12s ease;
}
.chip:hover {
  border-color: var(--lavender);
  color: var(--text);
}
.chip.enabled {
  background: var(--lavender);
  color: var(--crust);
  border-color: var(--lavender);
  font-weight: 600;
}
.chip .chip-count {
  font-family: var(--mono);
  font-size: 10.5px;
  opacity: 0.8;
}

/* ============================================================
   SPREADS TABLE
   ============================================================ */

.spreads-table {
  width: 100%;
  border-collapse: collapse;
}
.spreads-table th, .spreads-table td {
  padding: 7px 12px;
  text-align: left;
}
.spreads-table thead {
  background: var(--surface0);
}
.spreads-table th {
  font-size: 10.5px;
  text-transform: uppercase;
  color: var(--subtext0);
  letter-spacing: 0.4px;
  font-weight: 600;
}
.spreads-table th.th-expand { width: 30px; }
.spreads-table th.sortable { cursor: pointer; user-select: none; }
.spreads-table th.sortable:hover { color: var(--text); }
.sort-ico {
  display: inline-block;
  margin-left: 2px;
  color: var(--lavender);
  font-size: 10px;
}

/* sticky header */
.spreads-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--surface0);
}

/* fresh-dot inline в основной строке */
.exchange-name .fresh-dot {
  width: 6px;
  height: 6px;
  margin-right: 4px;
  vertical-align: middle;
}

.spreads-table tbody tr {
  border-bottom: 1px solid var(--surface0);
  transition: background 0.12s ease;
}
.spreads-table tbody tr:last-child { border-bottom: none; }
.spreads-table tbody tr.row-main:hover { background: var(--surface0); cursor: pointer; }

.spreads-table td {
  font-family: var(--mono);
  font-size: 12.5px;
}
.spreads-table td.empty {
  text-align: center;
  color: var(--subtext0);
  padding: 22px;
  font-family: inherit;
}

.spread-cell {
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background 0.2s ease;
  padding: 2px 6px;
  border-radius: 4px;
  margin: -2px -6px;
}
.spread-cell.alert { color: var(--green); }
.spread-cell.high { color: var(--yellow); }
.spread-cell.low { color: var(--subtext0); }

.spread-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.spread-dot.alert { background: var(--green); }
.spread-dot.high { background: var(--yellow); }
.spread-dot.low { background: var(--overlay0); }

.tier-pill {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3px;
  font-family: inherit;
}
.tier-pill.top50 { background: var(--blue); color: var(--crust); }
.tier-pill.midcap { background: var(--mauve); color: var(--crust); }
.tier-pill.lowcap { background: var(--peach); color: var(--crust); }

.exchange-name { color: var(--subtext0); font-size: 11.5px; }

.row-expand {
  background: var(--crust);
  font-family: var(--mono);
  font-size: 11.5px;
  color: var(--subtext1);
}
.row-expand td { padding: 10px 18px; }
.row-expand .expand-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}
.row-expand .expand-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.row-expand .expand-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext0);
}

.expand-arrow {
  color: var(--overlay0);
  font-family: inherit;
  user-select: none;
}

/* свежесть данных в expand */
.fresh-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  margin-right: 5px;
}
.fresh-dot.fresh { background: var(--green); }
.fresh-dot.warn { background: var(--yellow); }
.fresh-dot.stale { background: var(--red); }

/* number-flip animation */
@keyframes flash-up {
  0% { background: rgba(166, 227, 161, 0.4); }
  100% { background: transparent; }
}
@keyframes flash-down {
  0% { background: rgba(243, 139, 168, 0.4); }
  100% { background: transparent; }
}
.spread-cell.flip-up { animation: flash-up 500ms ease-out; }
.spread-cell.flip-down { animation: flash-down 500ms ease-out; }

/* ============================================================
   ALERTS TIMELINE
   ============================================================ */

.alerts-timeline {
  font-family: var(--mono);
  font-size: 12.5px;
}

.alert-row {
  display: grid;
  grid-template-columns: 60px 110px 70px 60px 70px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--surface0);
}
.alert-row:last-child { border-bottom: none; }
.alert-row:hover { background: var(--surface0); }

.alert-time { color: var(--subtext0); font-size: 11.5px; }
.alert-pair { color: var(--mauve); font-weight: 600; }
.alert-tier { color: var(--subtext0); font-size: 11px; }
.alert-spread { color: var(--green); font-weight: 700; }
.alert-pos { color: var(--subtext1); }
.alert-direction { color: var(--text); }
.alert-arrow { color: var(--lavender); padding: 0 4px; }
.alert-ago { color: var(--overlay0); font-size: 11px; text-align: right; }

/* ============================================================
   CONFIG — 4 секции
   ============================================================ */

.card-config .config-sections {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.config-section {
  padding: 12px 16px;
  border-bottom: 1px solid var(--surface0);
}
.config-section:last-child { border-bottom: none; }

.config-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.config-section-title h3 {
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext1);
}
.config-section-title .badge-critical {
  font-size: 10px;
  background: var(--red);
  color: var(--crust);
  padding: 2px 7px;
  border-radius: 8px;
  font-weight: 700;
}

.config-section.protection .config-section-title h3 { color: var(--red); }
.config-section.protection .config-section-title h3::before {
  content: "🛡 ";
  margin-right: 2px;
}

.config-grid {
  display: grid;
  gap: 8px;
}
.config-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.config-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.config-grid.protection-grid { grid-template-columns: repeat(3, 1fr); }

@media (max-width: 900px) {
  .config-grid.cols-3, .config-grid.cols-2, .config-grid.protection-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 580px) {
  .config-grid { grid-template-columns: 1fr !important; }
}

.config-tile {
  background: var(--surface0);
  padding: 8px 10px;
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.config-section.protection .config-tile {
  background: rgba(243, 139, 168, 0.08);
  border: 1px solid rgba(243, 139, 168, 0.18);
}

/* ============================================================
   Editable settings drawer — редизайн 2026-06-15 (gap-spacing, минимализм)
   ============================================================ */
.config-group {
  margin: 0 0 6px 0;
  background: transparent;
  border-radius: 8px;
  overflow: hidden;
}
.config-group-summary {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  cursor: pointer;
  font-size: 12.5px;
  font-weight: 600;
  user-select: none;
  list-style: none;
  border-radius: 8px;
  transition: background-color 120ms ease;
}
.config-group-summary:hover { background: var(--surface0); }
.config-group-summary::-webkit-details-marker { display: none; }
.config-group-summary::before {
  content: "›";
  color: var(--subtext0);
  font-size: 16px;
  line-height: 1;
  transition: transform 180ms cubic-bezier(0.4, 0, 0.2, 1);
  width: 10px;
  display: inline-block;
}
.config-group[open] .config-group-summary::before { transform: rotate(90deg); }
.config-group-icon { font-size: 14px; }
.config-group-title {
  flex: 1;
  color: var(--text);
  letter-spacing: 0.1px;
}
.config-group-count {
  color: var(--subtext0);
  font-size: 10.5px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.config-group-body {
  padding: 4px 12px 10px 30px;
}

.cfg-row {
  padding: 12px 0;
  border-bottom: 1px solid var(--surface0);
}
.cfg-row:last-child { border-bottom: none; }
.cfg-row-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.cfg-row-label {
  flex: 1;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: 0.05px;
}
.cfg-save-btn {
  background: color-mix(in srgb, var(--blue) 18%, transparent);
  color: var(--blue);
  border: none;
  padding: 4px 11px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  transition: background-color 140ms ease, color 140ms ease;
  font-family: inherit;
}
.cfg-save-btn:hover {
  background: color-mix(in srgb, var(--blue) 32%, transparent);
}
.cfg-save-btn:disabled { opacity: 0.4; cursor: wait; }

.cfg-row-input { margin: 5px 0; }
.cfg-input, .cfg-select {
  width: 100%;
  background: var(--surface0);
  border: 1px solid var(--surface1);
  color: var(--text);
  padding: 7px 10px;
  border-radius: 6px;
  font-size: 12.5px;
  font-family: inherit;
  font-variant-numeric: tabular-nums;
  transition: border-color 140ms ease, background-color 140ms ease;
}
.cfg-input:focus, .cfg-select:focus {
  outline: none;
  background: var(--mantle);
  border-color: color-mix(in srgb, var(--blue) 60%, var(--surface2));
}
.cfg-input-long { min-height: 60px; resize: vertical; line-height: 1.45; }
/* Подсветка числовых полей с моноширинным выравниванием */
.cfg-input[type="number"] { font-family: var(--mono, "JetBrains Mono", monospace); }

.cfg-toggle {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
}
.cfg-toggle input { opacity: 0; width: 0; height: 0; }
.cfg-toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--surface2);
  border-radius: 20px;
  transition: background 150ms ease;
  cursor: pointer;
}
.cfg-toggle-slider::before {
  content: "";
  position: absolute;
  height: 14px; width: 14px;
  left: 3px; top: 3px;
  background: var(--text);
  border-radius: 50%;
  transition: transform 150ms ease;
}
.cfg-toggle input:checked + .cfg-toggle-slider { background: var(--green); }
.cfg-toggle input:checked + .cfg-toggle-slider::before { transform: translateX(16px); }

.cfg-row-desc {
  font-size: 11px;
  color: var(--subtext0);
  margin: 4px 0 2px 0;
  line-height: 1.5;
  text-wrap: balance;
}
.cfg-row-rec {
  font-size: 11px;
  color: color-mix(in srgb, var(--lavender) 90%, var(--text));
  margin: 4px 0;
  line-height: 1.5;
  padding-left: 16px;
  position: relative;
  text-wrap: balance;
}
.cfg-row-rec::before {
  content: "💡";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 10px;
}
.cfg-row-rec { background: none; }
/* Перебиваем эмодзи в тексте — он уже есть в ::before */
.cfg-row-status {
  font-size: 10.5px;
  min-height: 14px;
  margin-top: 6px;
  letter-spacing: 0.2px;
}
.cfg-row-status.pending { color: var(--yellow); }
.cfg-row-status.saved { color: var(--green); }
.cfg-row-status.error { color: var(--red); }

.config-tile-label {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--subtext0);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.config-tile-value {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--text);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.config-advanced {
  margin-top: 4px;
}
.config-advanced summary {
  cursor: pointer;
  padding: 10px 16px;
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext1);
  border-bottom: 1px solid var(--surface0);
  user-select: none;
}
.config-advanced summary:hover { color: var(--text); }
.config-advanced[open] summary { color: var(--text); }

.config-advanced-body {
  padding: 12px 16px;
}
.config-subsection {
  margin-bottom: 14px;
}
.config-subsection:last-child { margin-bottom: 0; }
.config-subsection h4 {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext0);
  margin-bottom: 6px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.config-note {
  padding: 10px 16px;
  font-size: 11px;
  color: var(--subtext0);
  background: var(--crust);
  border-top: 1px solid var(--surface0);
  display: flex;
  align-items: flex-start;
  gap: 6px;
}
.config-note::before { content: "ℹ"; color: var(--blue); }

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer {
  text-align: center;
  padding: 20px 0 10px;
  font-size: 11px;
  color: var(--overlay0);
}
.footer-disclaimer { margin-bottom: 6px; }
.footer-disclaimer a { color: var(--subtext0); text-decoration: underline; }
.footer-disclaimer a:hover { color: var(--lavender); }
.footer-sep { padding: 0 6px; opacity: 0.5; }
.footer-meta { font-family: var(--mono); font-size: 10.5px; opacity: 0.7; }

/* ============================================================
   BUTTONS
   ============================================================ */

.btn {
  background: var(--surface0);
  color: var(--text);
  border: 1px solid var(--surface1);
  border-radius: 5px;
  padding: 4px 10px;
  cursor: pointer;
  font-size: 11px;
  font-weight: 500;
  font-family: inherit;
  transition: background 0.12s ease;
}
.btn:hover { background: var(--surface1); }
.btn-sm { padding: 3px 9px; font-size: 10.5px; }

/* ============================================================
   MODAL
   ============================================================ */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.modal {
  background: var(--mantle);
  border: 1px solid var(--surface1);
  border-radius: 10px;
  padding: 24px;
  max-width: 600px;
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  position: relative;
}
.modal-wide { max-width: 760px; }

.modal h2 {
  font-size: 16px;
  color: var(--lavender);
  margin-bottom: 16px;
}

.modal-close {
  position: absolute;
  top: 10px;
  right: 14px;
  background: transparent;
  border: 0;
  color: var(--subtext0);
  font-size: 22px;
  cursor: pointer;
  line-height: 1;
}
.modal-close:hover { color: var(--text); }

.legal-list {
  padding-left: 20px;
  font-size: 13px;
  color: var(--subtext1);
}
.legal-list li {
  margin-bottom: 12px;
  line-height: 1.5;
}
.legal-list strong { color: var(--text); }
.legal-list code {
  background: var(--surface0);
  padding: 1px 5px;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 11.5px;
}

.modal-note {
  margin-top: 16px;
  font-size: 11px;
  color: var(--overlay0);
}

/* ============================================================
   EXCHANGE PROFILE MODAL
   ============================================================ */

.profile {
  font-size: 13px;
}
.profile-title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.profile-title h2 {
  margin: 0;
  font-size: 18px;
}
.profile-risk {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 6px;
  font-weight: 700;
  text-transform: uppercase;
}
.profile-risk.green { background: var(--green); color: var(--crust); }
.profile-risk.yellow { background: var(--yellow); color: var(--crust); }
.profile-risk.red { background: var(--red); color: var(--crust); }

.profile-section {
  margin-bottom: 14px;
}
.profile-section h3 {
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext0);
  margin-bottom: 6px;
  font-weight: 700;
}
.profile-fees {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.profile-fee-block {
  background: var(--surface0);
  padding: 8px 10px;
  border-radius: 6px;
}
.profile-fee-block .fee-label {
  font-size: 11px;
  color: var(--subtext0);
  text-transform: uppercase;
}
.profile-fee-block .fee-value {
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 600;
}
.profile-fee-block .fee-note {
  margin-top: 4px;
  font-size: 11px;
  color: var(--peach);
}

.profile-list {
  list-style: none;
  padding: 0;
}
.profile-list li {
  padding: 4px 0 4px 18px;
  position: relative;
  font-size: 12.5px;
  color: var(--subtext1);
}
.profile-list li::before {
  content: "•";
  position: absolute;
  left: 4px;
  color: var(--overlay0);
}
.profile-list.antiban li::before { content: "⚠"; color: var(--peach); }

.profile-row {
  display: flex;
  gap: 8px;
  font-size: 12.5px;
  margin-bottom: 4px;
}
.profile-row .k {
  color: var(--subtext0);
  min-width: 110px;
}
.profile-row .v { color: var(--text); }

.profile-risk-note {
  padding: 8px 10px;
  background: rgba(243, 139, 168, 0.08);
  border-left: 3px solid var(--red);
  border-radius: 4px;
  font-size: 12px;
  color: var(--subtext1);
}

/* ============================================================
   TradingView сигналы (минимальная карточка)
   ============================================================ */

.tv-signals-list {
  padding: 0;
  max-height: 220px;
  overflow-y: auto;
}
.tv-signal {
  display: grid;
  grid-template-columns: 60px 100px 1fr 80px;
  gap: 10px;
  padding: 6px 16px;
  border-bottom: 1px solid var(--surface0);
  font-family: var(--mono);
  font-size: 12px;
}
.tv-signal:last-child { border-bottom: none; }
.tv-signal .tv-time { color: var(--subtext0); }
.tv-signal .tv-ticker { color: var(--mauve); font-weight: 600; }
.tv-signal .tv-action.buy { color: var(--green); }
.tv-signal .tv-action.sell { color: var(--red); }
.tv-signal .tv-action.alert { color: var(--yellow); }
.tv-signal .tv-msg {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ============================================================
   STEP 5 — Trading Dashboard widgets (PnL, Risk, Positions, Donut, Health, Drawer)
   2026-06-12 — agent-senior-coder
   ============================================================ */

/* topbar — иконка-кнопка и ссылка-калькулятор */
.topbar-icon-btn {
  background: var(--surface0);
  color: var(--text);
  border: 1px solid var(--surface1);
  border-radius: 6px;
  padding: 4px 9px;
  font-size: 14px;
  cursor: pointer;
  margin-left: 8px;
  transition: all 0.12s ease;
}
.topbar-icon-btn:hover { background: var(--surface1); border-color: var(--lavender); }

.topbar-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  color: var(--subtext1);
  background: var(--surface0);
  border: 1px solid var(--surface1);
  border-radius: 6px;
  padding: 4px 9px;
  font-size: 12px;
  margin-left: 8px;
  transition: all 0.12s ease;
}
.topbar-link:hover { color: var(--lavender); border-color: var(--lavender); background: var(--surface1); }
.topbar-link .link-label { font-size: 11px; font-weight: 600; }

/* dashboard rows (PnL+Risk, Positions+Donut) */
.dash-row {
  display: grid;
  gap: 12px;
  margin-bottom: 12px;
}
.dash-row-top { grid-template-columns: 2fr 1fr; }
.dash-row-mid { grid-template-columns: 2fr 1fr; }

@media (max-width: 980px) {
  .dash-row-top, .dash-row-mid { grid-template-columns: 1fr; }
}

/* ---------- PnL strip ---------- */
.card-pnl .pnl-body {
  padding: 14px 16px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
}
.pnl-main {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 200px;
}
.pnl-big-value {
  font-family: var(--mono);
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.5px;
  line-height: 1.1;
}
.pnl-big-value.up { color: var(--green); }
.pnl-big-value.down { color: var(--red); }
.pnl-big-value.zero { color: var(--subtext1); }
.pnl-breakdown {
  font-family: var(--mono);
  font-size: 11.5px;
  color: var(--subtext0);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.pnl-breakdown span b { color: var(--text); font-weight: 600; }
.pnl-breakdown .up { color: var(--green); }
.pnl-breakdown .down { color: var(--red); }

.pnl-spark {
  width: 100%;
  height: 60px;
  display: block;
}

.pnl-off {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.pnl-off-msg { color: var(--subtext1); font-size: 12.5px; }
.pnl-off-msg strong { color: var(--text); display: block; margin-bottom: 4px; font-size: 13px; }

/* ---------- Risk gauges ---------- */
.card-risk .risk-body { padding: 12px 14px; }
.risk-gauges {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.risk-gauge {
  background: var(--surface0);
  border-radius: 8px;
  padding: 10px 6px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.gauge-svg {
  width: 100%;
  height: 70px;
}
.gauge-label {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext0);
}
.gauge-value {
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}
.gauge-value.warn { color: var(--yellow); }
.gauge-value.danger { color: var(--red); }
.gauge-value.ok { color: var(--green); }

/* Глобальный мягкий red-glow когда риск/просадка в опасной зоне */
body.danger-glow {
  box-shadow: inset 0 0 60px rgba(243, 139, 168, 0.18);
}

/* ---------- Positions table ---------- */
.card-positions table {
  width: 100%;
  border-collapse: collapse;
}
.positions-tbl th, .positions-tbl td {
  padding: 7px 12px;
  text-align: left;
  font-size: 12px;
}
.positions-tbl thead {
  background: var(--surface0);
}
.positions-tbl th {
  font-size: 10.5px;
  text-transform: uppercase;
  color: var(--subtext0);
  letter-spacing: 0.4px;
  font-weight: 600;
}
.positions-tbl tbody tr { border-bottom: 1px solid var(--surface0); }
.positions-tbl tbody tr:last-child { border-bottom: none; }
.positions-tbl tbody td {
  font-family: var(--mono);
  font-size: 12px;
}
.positions-tbl .pos-pnl.up { color: var(--green); font-weight: 700; }
.positions-tbl .pos-pnl.down { color: var(--red); font-weight: 700; }
.positions-tbl .pos-pair { color: var(--mauve); font-weight: 600; }
.positions-empty {
  padding: 24px 16px;
  text-align: center;
  color: var(--subtext0);
}
.positions-empty .small {
  display: block;
  font-size: 11px;
  margin-top: 4px;
  color: var(--overlay0);
}
.positions-more {
  padding: 8px 16px;
  text-align: center;
  border-top: 1px solid var(--surface0);
}

/* ---------- Capital donut ---------- */
.donut-body {
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.donut-svg {
  width: 100%;
  max-width: 180px;
  height: auto;
}
.donut-center-value {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 700;
  fill: var(--text);
}
.donut-center-label {
  font-size: 9px;
  fill: var(--subtext0);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.donut-legend {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--subtext1);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2px 8px;
  width: 100%;
}
.donut-legend .leg-row {
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.donut-legend .leg-dot {
  width: 8px;
  height: 8px;
  border-radius: 2px;
  flex-shrink: 0;
}

/* ---------- Health matrix (11 бирж × 4 колонки) ---------- */
.health-matrix {
  display: block;
  padding: 0;
}
.health-row {
  display: grid;
  grid-template-columns: 110px 80px 1fr 90px 70px;
  gap: 10px;
  align-items: center;
  padding: 8px 14px;
  border-bottom: 1px solid var(--surface0);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.12s ease;
}
.health-row:hover { background: var(--surface0); }
.health-row:last-child { border-bottom: none; }
.health-row.disconnected { opacity: 0.5; }
.health-row .h-name {
  font-family: var(--mono);
  font-weight: 600;
  color: var(--mauve);
  font-size: 11.5px;
}
.health-row .h-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
}
.health-row .h-status .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.health-row .h-status.green .dot { background: var(--green); }
.health-row .h-status.yellow .dot { background: var(--yellow); }
.health-row .h-status.red .dot { background: var(--red); }
.health-row .h-status.green { color: var(--green); }
.health-row .h-status.yellow { color: var(--yellow); }
.health-row .h-status.red { color: var(--red); }
.health-row .h-flow {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--subtext1);
  display: flex;
  align-items: center;
  gap: 8px;
}
.health-row .h-flow .h-bar {
  flex: 1;
  height: 5px;
  background: var(--mantle);
  border-radius: 3px;
  overflow: hidden;
  min-width: 40px;
}
.health-row .h-flow .h-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.3s ease, background 0.3s ease;
}
.health-row .h-flow .h-bar-fill.green { background: var(--green); }
.health-row .h-flow .h-bar-fill.yellow { background: var(--yellow); }
.health-row .h-flow .h-bar-fill.red { background: var(--red); }

.health-row .h-clock {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--subtext0);
  text-align: right;
}
.health-row .h-clock.warn { color: var(--peach); }
.health-row .h-clock.danger { color: var(--red); }

.health-row .h-toggle {
  display: flex;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  user-select: none;
  justify-content: flex-end;
}
.health-row .h-toggle input { accent-color: var(--green); cursor: pointer; }

.health-header-row {
  display: grid;
  grid-template-columns: 110px 80px 1fr 90px 70px;
  gap: 10px;
  padding: 6px 14px;
  background: var(--surface0);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext0);
  font-weight: 600;
}
.health-header-row .h-toggle { text-align: right; }

/* ---------- Settings drawer ---------- */
/* ============================================================
   DRAWER «Настройки» — редизайн 2026-06-15 (стиль топбара v2)
   ============================================================ */
.drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(2px);
  z-index: 900;
  animation: backdrop-fade 180ms ease-out;
}
@keyframes backdrop-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
.drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 460px;
  max-width: 96vw;
  background: var(--base);
  border-left: 1px solid var(--surface1);
  z-index: 910;
  display: flex;
  flex-direction: column;
  box-shadow: -12px 0 32px rgba(0,0,0,0.45);
  animation: drawer-slide 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  font-feature-settings: "tnum" 1, "lnum" 1;
}
@keyframes drawer-slide {
  from { transform: translateX(100%); }
  to { transform: translateX(0); }
}

.drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 18px;
  background: var(--mantle);
  border-bottom: 1px solid var(--surface1);
  min-height: 56px;
}
.drawer-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.drawer-icon {
  font-size: 17px;
  color: var(--subtext0);
}
.drawer-header h2 {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.1px;
  color: var(--text);
  margin: 0;
  text-transform: none;
}
.drawer-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  justify-content: flex-end;
}
.drawer-search {
  background: var(--surface0);
  border: 1px solid var(--surface1);
  color: var(--text);
  padding: 6px 11px;
  border-radius: 6px;
  font-size: 12px;
  font-family: inherit;
  width: 200px;
  transition: border-color 150ms ease;
}
.drawer-search:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--blue) 60%, var(--surface2));
}
.drawer-search::placeholder { color: var(--overlay0); }

.drawer-close {
  background: transparent;
  border: 0;
  color: var(--subtext0);
  font-size: 16px;
  cursor: pointer;
  line-height: 1;
  padding: 6px 8px;
  border-radius: 6px;
  transition: color 150ms ease, background-color 150ms ease;
}
.drawer-close:hover {
  color: var(--text);
  background: var(--surface0);
}

.drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 16px 24px;
  scrollbar-width: thin;
  scrollbar-color: var(--surface2) transparent;
}
.drawer-body::-webkit-scrollbar { width: 8px; }
.drawer-body::-webkit-scrollbar-track { background: transparent; }
.drawer-body::-webkit-scrollbar-thumb { background: var(--surface1); border-radius: 4px; }
.drawer-body::-webkit-scrollbar-thumb:hover { background: var(--surface2); }

.drawer-footer {
  padding: 12px 18px;
  background: var(--mantle);
  border-top: 1px solid var(--surface1);
  font-size: 10.5px;
  color: var(--subtext0);
  line-height: 1.5;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.drawer-footer-warn { color: var(--yellow); }

.restart-btn {
  background: color-mix(in srgb, var(--blue) 18%, transparent);
  color: var(--blue);
  border: none;
  padding: 9px 14px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.3px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background-color 150ms ease, color 150ms ease;
  font-family: inherit;
}
.restart-btn:hover {
  background: color-mix(in srgb, var(--blue) 32%, transparent);
}
.restart-btn:disabled {
  opacity: 0.5;
  cursor: wait;
}
.restart-btn-icon {
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
  transition: transform 600ms ease;
}
.restart-btn.spinning .restart-btn-icon {
  animation: restart-spin 800ms linear infinite;
}
@keyframes restart-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.drawer-body .config-grid.cols-3 { grid-template-columns: repeat(2, 1fr); }
.drawer-body .config-grid.protection-grid { grid-template-columns: repeat(2, 1fr); }

/* Скрытый row через поиск */
.cfg-row.hidden-by-search,
.config-group.hidden-by-search { display: none; }

/* ============================================================
   Calculator page (calculator.html)
   ============================================================ */

.calc-container {
  max-width: 1320px;
  margin: 0 auto;
  padding: 16px 20px 24px;
}
.calc-back {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  color: var(--subtext1);
  font-size: 12px;
  margin-left: 8px;
}
.calc-back:hover { color: var(--lavender); }

.calc-summary {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 12px;
}
@media (max-width: 900px) { .calc-summary { grid-template-columns: repeat(2, 1fr); } }

.calc-tile {
  background: var(--mantle);
  border: 1px solid var(--surface0);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.calc-tile-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--subtext0);
}
.calc-tile-value {
  font-family: var(--mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
}
.calc-tile-value.up { color: var(--green); }
.calc-tile-value.down { color: var(--red); }

.calc-row {
  display: grid;
  gap: 12px;
  margin-bottom: 12px;
}
.calc-row.two { grid-template-columns: 2fr 1fr; }
.calc-row.three { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 980px) {
  .calc-row.two, .calc-row.three { grid-template-columns: 1fr; }
}

.calc-chart {
  width: 100%;
  height: 220px;
  display: block;
  padding: 10px 14px;
}
.calc-chart-tall { height: 280px; }

.calc-filters {
  display: flex;
  gap: 8px;
  padding: 10px 14px;
  flex-wrap: wrap;
  align-items: center;
}
.calc-filters select {
  background: var(--surface0);
  color: var(--text);
  border: 1px solid var(--surface1);
  border-radius: 5px;
  padding: 4px 8px;
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
}
.calc-filters .filter-label {
  font-size: 10.5px;
  color: var(--subtext0);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.calc-top-list {
  padding: 0;
}
.calc-top-row {
  display: grid;
  grid-template-columns: 110px 1fr 80px 70px;
  gap: 8px;
  align-items: center;
  padding: 6px 14px;
  border-bottom: 1px solid var(--surface0);
  font-family: var(--mono);
  font-size: 11.5px;
}
.calc-top-row:last-child { border-bottom: none; }
.calc-top-row .pair { color: var(--mauve); font-weight: 600; }
.calc-top-row .pnl.up { color: var(--green); font-weight: 700; }
.calc-top-row .pnl.down { color: var(--red); font-weight: 700; }
.calc-top-row .time { color: var(--subtext0); font-size: 11px; }

/* TradingView toggle (вкл/выкл webhook) — в card-header справа от tv-count */
.tv-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  user-select: none;
  font-size: 11px;
  color: var(--subtext0);
  margin-left: 12px;
}
.tv-toggle input { accent-color: var(--green); cursor: pointer; }
.tv-toggle.off { color: var(--red); }
.tv-toggle.off input { accent-color: var(--red); }

/* ============================================================
   Trade Insights Loop — карточка «Рекомендации команды»
   ============================================================ */

.insights-select {
  background: var(--base);
  color: var(--text);
  border: 1px solid var(--surface1);
  border-radius: 6px;
  padding: 3px 8px;
  font-size: 11px;
  cursor: pointer;
}
.insights-list {
  padding: 0;
  max-height: 420px;
  overflow-y: auto;
}
.insight-item {
  padding: 10px 16px;
  border-bottom: 1px solid var(--surface0);
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: 12px;
  align-items: start;
}
.insight-item:last-child { border-bottom: 0; }
.insight-item .severity {
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 6px;
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  align-self: start;
}
.insight-item .severity.info { background: var(--blue); color: var(--crust); }
.insight-item .severity.warning { background: var(--yellow); color: var(--crust); }
.insight-item .severity.critical { background: var(--red); color: var(--crust); }
.insight-item .body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.insight-item .title {
  font-weight: 600;
  font-size: 13px;
  color: var(--text);
}
.insight-item .description {
  font-size: 12px;
  color: var(--subtext1);
  line-height: 1.45;
}
.insight-item .suggested {
  font-size: 12px;
  color: var(--green);
  line-height: 1.4;
}
.insight-item .meta {
  font-size: 11px;
  color: var(--subtext0);
  font-family: var(--mono);
}
.insight-item .actions {
  display: flex;
  gap: 4px;
  flex-direction: column;
}
.insight-item .actions button {
  padding: 4px 10px;
  font-size: 12px;
  border: 0;
  border-radius: 4px;
  cursor: pointer;
  font-weight: 700;
  min-width: 36px;
}
.insight-item .accept-btn { background: var(--green); color: var(--crust); }
.insight-item .reject-btn { background: var(--red); color: var(--crust); }
.insight-item .defer-btn { background: var(--overlay0); color: var(--text); }
.insight-item .accept-btn:hover,
.insight-item .reject-btn:hover,
.insight-item .defer-btn:hover { filter: brightness(1.1); }

/* ============================================================
   Peer Consensus Queue — голоса агентов в карточке «Обсуждения команды»
   ============================================================ */
.consensus-votes {
  margin-top: 6px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  border-left: 2px solid var(--surface1);
  padding-left: 8px;
}
.consensus-vote {
  font-size: 11px;
  color: var(--subtext1);
  line-height: 1.4;
}
.consensus-vote .vote-pos {
  display: inline-block;
  min-width: 56px;
  padding: 1px 6px;
  border-radius: 4px;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 10px;
  margin-right: 4px;
  text-align: center;
}
.consensus-vote.for .vote-pos { background: var(--green); color: var(--crust); }
.consensus-vote.against .vote-pos { background: var(--red); color: var(--crust); }
.consensus-vote.abstain .vote-pos { background: var(--overlay0); color: var(--text); }

