/* ── Reset & base ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #0d0d0d;
  --bg2:       #111111;
  --bg3:       #181818;
  --border:    #2a2a2a;
  --green:     #00cc66;
  --yellow:    #ffcc00;
  --red:       #ff4444;
  --cyan:      #00ccff;
  --dimgray:   #555555;
  --text:      #cccccc;
  --text-dim:  #666666;
  --font:      "Courier New", Courier, monospace;
}

html[data-theme="light"] {
  --bg:        #f0f0f0;
  --bg2:       #e6e6e6;
  --bg3:       #d8d8d8;
  --border:    #b8b8b8;
  --green:     #007a3d;
  --yellow:    #a07000;
  --red:       #cc2222;
  --cyan:      #006699;
  --dimgray:   #777777;
  --text:      #1a1a1a;
  --text-dim:  #555555;
}

html, body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 13px;
  line-height: 1.4;
  min-height: 100vh;
}

/* ── Layout ───────────────────────────────────────────────────────────────── */

#header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 8px;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
}

#header h1 {
  font-size: 13px;
  color: var(--green);
  letter-spacing: 1px;
  text-transform: uppercase;
}

#header .ws-status {
  font-size: 11px;
  color: var(--dimgray);
}
#header .ws-status.connected { color: var(--green); }

.bots-grid {
  display: grid;
  gap: 4px;
  padding: 4px;
  grid-template-columns: repeat(3, 1fr);
  align-items: start;
}

/* Portrait orientation or narrow viewport → single column */
@media (orientation: portrait), (max-width: 600px) {
  .bots-grid { grid-template-columns: 1fr; }
}

/* ── Bot card ─────────────────────────────────────────────────────────────── */

.bot-card {
  border: 1px solid var(--border);
  background: var(--bg2);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.bot-card.selected { border-color: var(--yellow); }
.bot-card.stopped  { border-color: #333333; opacity: 0.7; }

.bot-card-title {
  padding: 3px 6px;
  border-bottom: 1px solid var(--border);
  background: var(--bg3);
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  white-space: nowrap;
  overflow: hidden;
}

.bot-card-title .status-dot { color: var(--green); }
.bot-card.stopped .status-dot { color: var(--dimgray); }
.bot-card-title .mode-dry  { color: var(--cyan); }
.bot-card-title .mode-live { color: var(--yellow); }
.bot-card-title .rank-badge { color: var(--dimgray); font-size: 10px; }
.bot-card-title .cycle-ts  { color: var(--dimgray); margin-left: auto; }

/* ── Section headings ─────────────────────────────────────────────────────── */

.section { padding: 0; }

.section-title {
  padding: 2px 6px;
  font-size: 10px;
  color: var(--dimgray);
  border-bottom: 1px solid var(--border);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ── Chart ────────────────────────────────────────────────────────────────── */

.chart-section {
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.chart-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 10px;
  color: var(--dimgray);
  padding: 2px 6px 0;
}

.chart-svg-wrap {
  width: 100%;
  height: 48px;
  display: block;
  overflow: hidden;
}

.chart-stats {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding: 3px 6px;
  font-size: 10px;
  color: var(--dimgray);
  border-top: 1px solid var(--border);
}

/* ── Auto-scroll containers ───────────────────────────────────────────────── */

.scroller {
  overflow-y: scroll;
  scrollbar-width: none;   /* Firefox */
}
.scroller::-webkit-scrollbar { display: none; }  /* Chrome / Safari */

.holdings-section .scroller { max-height: 108px; }
.signals-section  .scroller { max-height: 160px; }
.trades-section   .scroller { max-height: 100px; }
.logs-section     .scroller { max-height: 80px;  }

/* ── Holdings table ───────────────────────────────────────────────────────── */

.holdings-section { border-bottom: 1px solid var(--border); }

.holdings-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}

.holdings-table th {
  text-align: left;
  padding: 1px 4px;
  color: var(--dimgray);
  font-weight: normal;
}

.holdings-table td {
  padding: 1px 4px;
}

.holdings-table tr:hover td { background: var(--bg3); }

.pnl-pos { color: var(--green); }
.pnl-neg { color: var(--red); }

/* ── Signals table ────────────────────────────────────────────────────────── */

.signals-section { border-bottom: 1px solid var(--border); }

.signals-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}

.signals-table th {
  text-align: left;
  padding: 1px 4px;
  color: var(--dimgray);
  font-weight: normal;
}

.signals-table td { padding: 1px 4px; }
.signals-table tr:hover td { background: var(--bg3); }

.exec-ok   { color: var(--green); }
.exec-warn { color: var(--yellow); }
.exec-err  { color: var(--red); }
.exec-dim  { color: var(--dimgray); }

.sig-buy  { color: var(--green); }
.sig-sell { color: var(--red); }
.sig-hold { color: var(--dimgray); }

.sig-top10-row td { background: rgba(0, 204, 102, 0.04); }
.sig-top10-row:hover td { background: rgba(0, 204, 102, 0.10) !important; }
html[data-theme="light"] .sig-top10-row td { background: rgba(0, 122, 61, 0.07); }
html[data-theme="light"] .sig-top10-row:hover td { background: rgba(0, 122, 61, 0.15) !important; }
.sig-top10-star { color: var(--yellow); font-size: 9px; margin-right: 2px; }

/* ── Trades ───────────────────────────────────────────────────────────────── */

.trades-section { border-bottom: 1px solid var(--border); }

.trade-row {
  display: flex;
  gap: 4px;
  padding: 1px 6px;
  font-size: 11px;
  align-items: baseline;
}

.trade-row .trade-time { color: var(--dimgray); min-width: 40px; }
.trade-row .trade-side-buy  { color: var(--green); }
.trade-row .trade-side-sell { color: var(--red); }
.trade-row .trade-sym  { min-width: 80px; }
.trade-row .trade-usdt { margin-left: auto; color: var(--text-dim); }

/* ── Logs ─────────────────────────────────────────────────────────────────── */

.logs-section { padding: 0; }

.log-line {
  padding: 0 6px;
  font-size: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text-dim);
}

.log-line.log-warn  { color: var(--yellow); }
.log-line.log-error { color: var(--red); }

/* ── Control buttons ──────────────────────────────────────────────────────── */

.controls {
  display: flex;
  gap: 4px;
  padding: 4px 6px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

.ctrl-btn {
  padding: 2px 6px;
  font-family: var(--font);
  font-size: 10px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  cursor: pointer;
  letter-spacing: 0.5px;
}

.ctrl-btn:hover  { border-color: var(--yellow); color: var(--yellow); }
.ctrl-btn.danger { border-color: var(--red); color: var(--red); }
.ctrl-btn.danger:hover { background: var(--red); color: #000; }

/* ── Global controls bar ──────────────────────────────────────────────────── */

#global-controls {
  display: flex;
  gap: 4px;
  align-items: center;
  padding: 4px 8px;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
  flex-wrap: wrap;
}

#global-controls .label {
  font-size: 10px;
  color: var(--dimgray);
  margin-right: 4px;
}

.window-btn {
  padding: 1px 5px;
  font-family: var(--font);
  font-size: 10px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--dimgray);
  cursor: pointer;
}

.window-btn.active { border-color: var(--cyan); color: var(--cyan); }
.window-btn:hover  { color: var(--text); }

/* ── Portfolio pnl badge ──────────────────────────────────────────────────── */

.pnl-badge {
  font-size: 12px;
  font-weight: bold;
}

.pnl-badge.pos { color: var(--green); }
.pnl-badge.neg { color: var(--red); }

/* ── Inject credentials panel ────────────────────────────────────────────── */

#inject-panel {
  margin: 4px;
  border: 1px solid var(--border);
  background: var(--bg2);
}

.inject-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 3px 6px;
  border-bottom: 1px solid var(--border);
}

.inject-row label {
  font-size: 10px;
  color: var(--dimgray);
  min-width: 80px;
  white-space: nowrap;
}

.inject-row input {
  flex: 1;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font);
  font-size: 11px;
  padding: 2px 4px;
}

.inject-row input:focus { border-color: var(--cyan); outline: none; }

#inject-panel .controls { border-top: 1px solid var(--border); padding: 4px 6px; }

.ws-status.error { color: var(--red); }

/* ── Fleet Commander panel ────────────────────────────────────────────────── */

#fleet-panel {
  margin: 4px;
  border: 1px solid var(--border);
  background: var(--bg2);
}

#fleet-panel .section-title {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.fleet-regime-badge {
  font-size: 10px;
  font-weight: bold;
  padding: 1px 5px;
  border: 1px solid currentColor;
  letter-spacing: 0.5px;
}

.regime-neutral    { color: var(--dimgray); }
.regime-defensive  { color: var(--cyan); }
.regime-aggressive { color: var(--yellow); }

.fleet-row {
  display: flex;
  gap: 12px;
  padding: 4px 8px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.fleet-stat {
  font-size: 11px;
  color: var(--text);
}

/* Proposal panel */
#proposal-panel {
  border-top: 1px solid var(--border);
}

#proposal-panel .section-title {
  padding: 4px 6px;
  font-size: 11px;
  text-transform: none;
  letter-spacing: 0;
}

.proposal-diagnosis {
  padding: 4px 8px;
  font-size: 11px;
  color: var(--text-dim);
  border-bottom: 1px solid var(--border);
  white-space: pre-wrap;
  max-height: 80px;
  overflow-y: auto;
}

.mutation-list {
  max-height: 140px;
  overflow-y: auto;
  scrollbar-width: none;
}
.mutation-list::-webkit-scrollbar { display: none; }

.mutation-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding: 2px 8px;
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  flex-wrap: wrap;
}

.mut-path   { color: var(--cyan);    min-width: 160px; }
.mut-old    { color: var(--red);     text-decoration: line-through; }
.mut-arrow  { color: var(--dimgray); }
.mut-new    { color: var(--green);   }
.mut-reason { color: var(--dimgray); font-size: 10px; margin-left: auto; font-style: italic; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Mode buttons */
.mode-btn {
  padding: 2px 6px;
  font-family: var(--font);
  font-size: 10px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--dimgray);
  cursor: pointer;
  letter-spacing: 0.5px;
}

.mode-btn:hover         { color: var(--text); border-color: var(--text); }
.mode-btn.active        { border-color: var(--cyan); color: var(--cyan); }

/* Approve button */
.approve-btn { border-color: var(--green) !important; color: var(--green) !important; }
.approve-btn:hover { background: var(--green) !important; color: #000 !important; }

/* ── Console terminal panel ───────────────────────────────────────────────── */

#terminal-wrap {
  margin: 8px 4px 4px;
  border: 1px solid var(--border);
  background: var(--bg);
}

#terminal-wrap .section-title {
  padding: 3px 6px;
  background: var(--bg3);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
}

#terminal-container {
  padding: 4px;
}

/* ── Theme toggle button ──────────────────────────────────────────────────── */

.theme-toggle {
  padding: 1px 7px;
  font-family: var(--font);
  font-size: 10px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  cursor: pointer;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

.theme-toggle:hover { border-color: var(--cyan); color: var(--cyan); }

.theme-auto-label {
  font-size: 10px;
  color: var(--dimgray);
}
