/* ── Bot Tab Layout ──────────────────────────────────────────────────────── */

/* Stats bar */
.bot-statsbar {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 10px;
  background: var(--bg1); border: 1px solid var(--border);
  padding: 10px 16px; margin-bottom: 14px;
}
.bsb-left-block { display: flex; align-items: center; gap: 8px; }
.bsb-title      { font-size: 12px; font-weight: 700; color: var(--green); letter-spacing: .1em; text-transform: uppercase; }
.bsb-admin-badge { font-size: 9px; font-weight: 600; letter-spacing: .12em; background: var(--green-bg); color: var(--green); border: 1px solid var(--green); padding: 1px 6px; text-transform: uppercase; }
.bsb-group      { display: flex; align-items: center; flex-wrap: wrap; }
.bsb-metric     { display: flex; flex-direction: column; align-items: flex-start; padding: 2px 18px 2px 0; min-width: 80px; }
.bsb-val        { font-family: var(--mono); font-size: 16px; font-weight: 700; color: var(--white); line-height: 1.2; }
.bsb-lbl        { font-size: 9px; letter-spacing: .15em; text-transform: uppercase; color: var(--dimmer); margin-top: 1px; }
.bsb-divider    { width: 1px; height: 30px; background: var(--border2); margin: 0 10px 0 0; flex-shrink: 0; }
.bsb-right      { display: flex; align-items: center; gap: 10px; }
.bsb-signal     { display: flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; background: var(--bg); border: 1px solid var(--border); padding: 4px 10px; }
.bsb-score      { font-weight: 700; font-size: 13px; }
.bsb-score.pos  { color: var(--green); }
.bsb-score.neg  { color: var(--red); }
.bsb-act        { color: var(--amber); font-weight: 600; letter-spacing: .05em; animation: pulse 1.5s infinite; }

/* Connect button */
.btn-connect    { background: var(--green); color: #fff; border: none; padding: 7px 16px; font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: .08em; cursor: pointer; white-space: nowrap; transition: background .15s; }
.btn-connect:hover { background: var(--green-lt); }

/* User grid */
.bot-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; margin-bottom: 16px; }
.bot-user-card  { border: 1px solid var(--border); background: var(--surface); display: flex; flex-direction: column; transition: border-color .15s, box-shadow .15s; }
.bot-user-card:hover     { border-color: var(--border2); box-shadow: 0 2px 8px rgba(0,0,0,.06); }
.bot-user-card.has-pos   { border-color: var(--green); }
.bot-user-card.has-error { border-color: var(--red); }
.bot-user-card.is-paused { opacity: .7; }
.bot-user-card.tm-card   { border-style: dashed; }

/* Card header */
.buc-header    { display: flex; justify-content: space-between; align-items: center; padding: 9px 12px; border-bottom: 1px solid var(--border); background: var(--bg1); }
.buc-identity  { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.buc-dot       { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.buc-dot.live  { background: #2da44e; animation: pulse 2s infinite; }
.buc-dot.paused{ background: var(--amber); }
.buc-dot.error { background: var(--red); animation: pulse .8s infinite; }
.buc-alias     { font-weight: 700; font-size: 13px; color: var(--white); }
.buc-exchange-badge { font-family: var(--mono); font-size: 10px; font-weight: 600; padding: 1px 7px; letter-spacing: .05em; text-transform: uppercase; }
.buc-tm-badge  { font-size: 9px; color: var(--dimmer); border: 1px solid var(--border2); padding: 1px 5px; letter-spacing: .08em; }
.buc-controls  { display: flex; align-items: center; gap: 5px; }
.buc-mode-badge { font-family: var(--mono); font-size: 9px; font-weight: 600; padding: 2px 6px; letter-spacing: .1em; cursor: pointer; transition: all .15s; }
.buc-mode-badge.auto   { color: var(--green); background: var(--green-bg); border: 1px solid var(--green); }
.buc-mode-badge.manual { color: var(--amber); background: var(--amber-bg); border: 1px solid var(--amber); }
.buc-btn-pause, .buc-btn-close { background: none; border: 1px solid var(--border2); color: var(--dim); font-size: 11px; padding: 2px 6px; cursor: pointer; transition: all .15s; }
.buc-btn-pause:hover { border-color: var(--green); color: var(--green); }
.buc-btn-close:hover { border-color: var(--red);   color: var(--red); }

/* Account bar */
.buc-account { display: flex; align-items: center; gap: 12px; padding: 8px 12px; border-bottom: 1px solid var(--border); }
.buc-eq      { display: flex; align-items: baseline; gap: 5px; }
.buc-eq-val  { font-family: var(--mono); font-size: 15px; font-weight: 700; color: var(--white); }
.buc-eq-lbl  { font-size: 10px; color: var(--dimmer); }
.buc-margin-bar-wrap  { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.buc-margin-bar-track { height: 4px; background: var(--bg2); position: relative; border-radius: 2px; overflow: hidden; }
.buc-margin-bar-fill  { position: absolute; left: 0; top: 0; height: 100%; background: var(--green-mid); opacity: .6; transition: width .4s; }
.buc-margin-lbl       { font-size: 10px; color: var(--dimmer); white-space: nowrap; }

/* Position block */
.buc-position-wrap { padding: 10px 12px; border-bottom: 1px solid var(--border); min-height: 52px; }
.buc-no-pos        { color: var(--dimmer); font-size: 11px; font-style: italic; padding: 4px 0; }
.buc-pos-header    { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; flex-wrap: wrap; }
.buc-pos-mark      { font-family: var(--mono); font-size: 14px; font-weight: 600; color: var(--white); }
.buc-pnl-badge     { font-family: var(--mono); font-size: 12px; font-weight: 600; margin-left: auto; white-space: nowrap; }
.buc-pnl-badge.pos { color: var(--green); background: var(--green-bg); }
.buc-pnl-badge.neg { color: var(--red);   background: var(--red-bg); }
.buc-pos-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3px 20px; font-family: var(--mono); font-size: 11px; }
.bpg-l        { color: var(--dimmer); }
.bpg-v        { color: var(--white); font-weight: 600; }
.bpg-v.sl     { color: var(--red); }
.bpg-v.tp     { color: var(--green); }
.bpg-v.liq    { color: var(--amber); }
.be-badge     { grid-column: 1/-1; color: var(--amber); font-size: 10px; font-weight: 600; letter-spacing: .1em; }

/* Stats row */
.buc-stats-row { display: flex; align-items: stretch; padding: 8px 12px; border-bottom: 1px solid var(--border); }
.buc-stat      { display: flex; flex-direction: column; align-items: center; flex: 1; gap: 1px; }
.bcs-val       { font-family: var(--mono); font-size: 12px; font-weight: 700; color: var(--white); }
.bcs-lbl       { font-size: 9px; color: var(--dimmer); letter-spacing: .1em; text-transform: uppercase; }
.buc-stat-div  { width: 1px; background: var(--border); margin: 0 4px; }

/* Error / last trade */
.buc-error { padding: 6px 12px; font-size: 11px; color: var(--red); background: var(--red-bg); border-top: 1px solid var(--red); }
.buc-last-trade { padding: 5px 12px; font-size: 11px; font-family: var(--mono); display: flex; justify-content: space-between; border-top: 1px solid var(--border); }
.buc-last-trade.ok   { color: var(--green); background: var(--green-bg); }
.buc-last-trade.fail { color: var(--red);   background: var(--red-bg); }
.blt-ts  { color: var(--dimmer); font-size: 10px; }
.buc-footer { display: flex; justify-content: space-between; padding: 5px 12px; font-size: 10px; color: var(--dimmer); background: var(--bg1); }

/* Security note */
.bot-security-note { font-size: 11px; color: var(--dimmer); padding: 8px 0; border-top: 1px solid var(--border); display: flex; gap: 6px; align-items: center; }

/* ── Empty State (TamperMonkey-first) ────────────────────────────────────── */
.bot-empty-state { max-width: 620px; margin: 20px auto; }
.bes-header      { text-align: center; margin-bottom: 18px; }
.bes-brand       { font-size: 22px; font-weight: 800; color: var(--green); letter-spacing: .08em; margin-bottom: 6px; }
.bes-tagline     { font-size: 13px; color: var(--dim); line-height: 1.6; max-width: 480px; margin: 0 auto; }

.bes-section         { border: 1px solid var(--border); padding: 18px 20px; margin-bottom: 10px; }
.bes-section-alt     { background: var(--bg1); }
.bes-section-header  { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.bes-section-title   { font-size: 14px; font-weight: 700; color: var(--white); }
.bes-badge           { font-size: 9px; font-weight: 700; letter-spacing: .14em; padding: 2px 7px; text-transform: uppercase; flex-shrink: 0; }
.bes-badge-primary   { background: var(--green-bg); color: var(--green); border: 1px solid var(--green); }
.bes-badge-alt       { background: var(--bg2); color: var(--dim); border: 1px solid var(--border2); }
.bes-tm-why          { font-size: 12px; color: var(--dim); line-height: 1.65; margin-bottom: 14px; }
.bes-tm-steps        { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.bes-step            { display: flex; align-items: flex-start; gap: 10px; font-size: 12px; color: var(--white); }
.bes-step-n          { min-width: 20px; height: 20px; border-radius: 50%; background: var(--green); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.bes-tm-downloads    { display: flex; gap: 8px; flex-wrap: wrap; }
.bes-dl-btn          { display: inline-flex; align-items: center; gap: 6px; background: var(--green); color: #fff; border: none; padding: 8px 16px; font-size: 12px; font-weight: 600; letter-spacing: .04em; cursor: pointer; text-decoration: none; transition: background .15s; }
.bes-dl-btn:hover    { background: var(--green-lt); }

/* ── Debug / error states ────────────────────────────────────────────────── */
.bot-loading { padding: 60px 20px; text-align: center; color: var(--dimmer); font-family: var(--mono); font-size: 12px; letter-spacing: .08em; }
.bot-render-error { padding: 24px; border: 1px solid var(--red); background: var(--red-bg); color: var(--red); font-size: 12px; line-height: 1.7; margin: 20px 0; }
.bot-render-error code { font-family: var(--mono); font-size: 11px; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .bot-grid { grid-template-columns: 1fr; }
}

/* ── Connect Wizard (3-step modal) ───────────────────────────────────────── */
.bot-wizard { max-width: 500px; }
.bw-steps   { display: flex; align-items: center; gap: 0; flex: 1; margin-right: 16px; }
.bw-step {
  display: flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600; color: rgba(255,255,255,.35);
  letter-spacing: .04em; transition: color .2s;
}
.bw-step.active { color: #fff; }
.bw-step.done   { color: rgba(255,255,255,.65); }
.bw-sn {
  width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0;
  background: rgba(255,255,255,.15); color: rgba(255,255,255,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; transition: all .2s;
}
.bw-step.active .bw-sn { background: #fff; color: var(--green); }
.bw-step.done   .bw-sn { background: rgba(255,255,255,.4); color: #fff; }
.bw-sl { display: none; }
@media (min-width: 440px) { .bw-sl { display: inline; } }
.bw-sep { color: rgba(255,255,255,.25); margin: 0 8px; font-size: 14px; }

/* Wizard panels */
.bw-panel       { padding: 22px 22px 8px; display: flex; flex-direction: column; gap: 10px; min-height: 220px; }
.bw-panel-title { font-size: 16px; font-weight: 700; color: var(--green); margin-bottom: 2px; }
.bw-info  {
  font-size: 11px; color: var(--dimmer); background: var(--bg1);
  border: 1px solid var(--border); padding: 9px 12px; line-height: 1.7; margin-top: 6px;
}
.bw-guide {
  font-size: 12px; color: var(--dim); background: var(--green-bg);
  border-left: 3px solid var(--green); padding: 10px 14px;
  line-height: 1.8; white-space: pre-line;
}
.bm-input-lg { font-size: 15px; padding: 11px 13px; }

/* Wizard footer */
.bw-footer  { border-top: 1px solid var(--border); padding: 12px 22px; background: var(--bg1); }
.bw-actions { display: flex; justify-content: space-between; align-items: center; }
.bw-nav     { display: flex; align-items: center; gap: 8px; }
.bw-btn-cancel {
  background: none; border: 1px solid var(--border2); color: var(--dim);
  padding: 7px 16px; font-size: 12px; cursor: pointer; transition: all .15s;
}
.bw-btn-cancel:hover { border-color: var(--red); color: var(--red); }
.bw-btn-back {
  background: none; border: 1px solid var(--border2); color: var(--dim);
  padding: 7px 16px; font-size: 12px; cursor: pointer; transition: all .15s;
}
.bw-btn-back:hover { border-color: var(--green); color: var(--green); }
.bw-btn-next {
  background: var(--green); color: #fff; border: none;
  padding: 7px 22px; font-size: 12px; font-weight: 600; letter-spacing: .06em;
  cursor: pointer; transition: background .15s;
}
.bw-btn-next:hover { background: var(--green-lt); }

/* ═══════════════════════════════════════════════════════════════════════
   Phase 4: Replaces remaining inline styles in bot-cards.js / bot.js
   ═══════════════════════════════════════════════════════════════════════ */

/* Credential fields stack (was inline on #bm-cred-fields) */
#bm-cred-fields {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Security note below cred fields (was inline on .bm-security) */
.bm-security { margin-top: 12px; }

/* Auto-trade checkbox label spacing (was inline on .bm-check-label) */
.bm-check-label { margin-top: 14px; }

/* Exchange icon in wizard grid (color stays inline — brand-specific) */
.beo-icon { font-size: 18px; }

/* CSS-class-based state management — replaces JS inline style toggling */

/* Modal overlay: starts hidden; JS adds/removes .is-open */
.bot-modal-overlay { display: none; }
.bot-modal-overlay.is-open { display: flex; }

/* Wizard panels: starts hidden; JS sets active one visible */
.bw-panel { display: none; }
.bw-panel.is-active { display: block; }

/* Back button: starts invisible; JS toggles .is-visible */
#bw-back { visibility: hidden; }
#bw-back.is-visible { visibility: visible; }

/* Next button: starts visible; JS toggles .is-hidden to hide on last step */
#bw-next.is-hidden { display: none; }

/* Connect button: starts hidden; JS toggles .is-visible */
#bw-connect { display: none; }
#bw-connect.is-visible { display: inline-block; }

/* Error message: starts hidden; JS toggles .is-visible */
#bm-error { display: none; }
#bm-error.is-visible { display: block; }
