/* ═══════════════════════════════════════════
   MyLiquidBot — app.css
   Design system unified with dashboard.html
   ═══════════════════════════════════════════ */
:root {
  /* ── Backgrounds (5 levels, matches dashboard) ── */
  --bg:    #07070b;
  --bg2:   #0d0d14;
  --bg3:   #121219;
  --bg4:   #181823;
  --bg5:   #1e1e2e;

  /* Legacy aliases → mapped to new system */
  --bg-primary:   var(--bg);
  --bg-secondary: var(--bg2);
  --bg-card:      var(--bg3);
  --bg-hover:     var(--bg5);

  /* ── Borders ── */
  --border:  rgba(255, 255, 255, 0.06);
  --border2: rgba(255, 255, 255, 0.10);

  /* ── Text ── */
  --text:           rgba(255, 255, 255, 0.88);
  --text-primary:   rgba(255, 255, 255, 0.88);
  --muted:          rgba(255, 255, 255, 0.38);
  --text-secondary: rgba(255, 255, 255, 0.38);
  --dim:            rgba(255, 255, 255, 0.18);

  /* ── Accent colors (premium crypto palette) ── */
  --up:    #3dba85;
  --up-bg: rgba(61, 186, 133, 0.09);
  --up-bd: rgba(61, 186, 133, 0.22);

  --dn:    #d95c6e;
  --dn-bg: rgba(217, 92, 110, 0.09);
  --dn-bd: rgba(217, 92, 110, 0.22);

  --accent:  #6c8dff;
  --acc-bg:  rgba(108, 141, 255, 0.09);
  --acc-bd:  rgba(108, 141, 255, 0.20);

  --warn:    #c9913a;
  --warn-bg: rgba(201, 145, 58, 0.10);
  --warn-bd: rgba(201, 145, 58, 0.25);

  --purple:  #9278e0;
  --pur-bg:  rgba(146, 120, 224, 0.09);

  /* Legacy aliases */
  --accent-green: var(--up);
  --accent-red:   var(--dn);
  --accent-blue:  var(--accent);
  --green: var(--up);
  --red:   var(--dn);

  /* ── Typography (matches dashboard: Syne + DM Sans + DM Mono) ── */
  --ff-display: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --ff-body:    -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --ff-mono:    'SF Mono', ui-monospace, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
  --ff-ibm:     'IBM Plex Mono', monospace;
  --font: var(--ff-body);
  --mono: var(--ff-mono);

  /* ── Radius + shadows ── */
  --r:  9px;
  --r2: 13px;
  --shadow-1: 0 6px 18px rgba(0, 0, 0, 0.45);
  --shadow-2: 0 10px 30px rgba(0, 0, 0, 0.55);
}

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

html {
  scroll-behavior: smooth;
  font-size: 14px
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--ff-body);
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.5;
}

/* ── Layout ── */
.wrap {
  width: 100%;
  padding: 0
}

header {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  background: rgba(7, 7, 11, 0.96);
  border-bottom: 1px solid var(--border);
  padding: 8px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

header h1 {
  font-family: var(--ff-display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .01em
}

.sub {
  color: var(--muted);
  font-size: 11px;
  font-family: var(--ff-mono);
  margin-top: 2px;
}

.right {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap
}

.wallet {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 3px 12px 3px 10px;
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pill-group {
  display: flex;
  gap: 2px;
  padding: 2px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border)
}

.lang-btn {
  border: none;
  background: transparent;
  color: var(--muted);
  font-size: 10px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s
}

.lang-btn.active {
  background: rgba(255, 255, 255, 0.1);
  color: #fff
}

main {
  display: flex;
  flex-direction: column
}

/* ── Tabs (top nav) ── */
.tabs {
  display: flex;
  gap: 1px;
  padding: 0 10px;
  background: rgba(7, 7, 11, 0.96);
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.tabs::-webkit-scrollbar { display: none; }
.tabs[aria-hidden="true"] { display: none !important; }

.tab {
  border: none;
  background: transparent;
  color: var(--muted);
  padding: 11px 14px;
  cursor: pointer;
  font-family: var(--ff-body);
  font-weight: 500;
  font-size: 12.5px;
  border-bottom: 2px solid transparent;
  transition: background .15s, color .15s, border-color .15s, opacity .15s;
  white-space: nowrap;
  flex-shrink: 0;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}

.tab:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.03);
}

.tab.active {
  color: var(--text);
  border-bottom-color: transparent;
  background: rgba(255, 255, 255, 0.04);
  box-shadow: inset 0 0 0 1px var(--border2);
  border-radius: 8px 8px 0 0;
}

/* ── Cards ── */
.card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 13px;
}

.tabpane {
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
}

/* ── Buttons ── */
.btn {
  border: 1px solid var(--border2);
  background: var(--bg3);
  color: var(--text);
  padding: 5px 13px;
  border-radius: var(--r);
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--ff-body);
  transition: background .15s, border-color .15s;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  white-space: nowrap;
}

.btn:hover {
  background: var(--bg4);
}

.btn:active {
  background: var(--bg5);
}

.btn:disabled {
  opacity: .4;
  cursor: not-allowed;
}

.btn.primary {
  border-color: var(--up-bd);
  background: var(--up-bg);
  color: var(--up);
}

.btn.primary:hover {
  background: rgba(61,186,133, 0.14);
}

.btn.sell {
  border-color: var(--dn-bd);
  background: var(--dn-bg);
  color: var(--dn);
}

.btn.sell:hover {
  background: rgba(217,92,110, 0.14);
}

.btn-chip {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
}

.btn-chip.active {
  border-color: var(--border2);
  background: var(--bg5);
  color: var(--text);
}

/* ── Inputs ── */
input,
select {
  padding: 8px 10px;
  border-radius: var(--r);
  border: 1px solid var(--border);
  background: var(--bg3);
  color: var(--text);
  font-size: 12.5px;
  font-family: var(--ff-body);
  transition: border-color .15s;
  -webkit-appearance: none;
  min-height: 36px;
}

input:focus,
select:focus {
  outline: none;
  border-color: var(--up-bd);
  background: var(--bg4);
}

label {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 11px;
  color: var(--muted);
  font-weight: 500
}

/* ── Sliders ── */
input[type=range] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 3px;
  border: 0;
  padding: 0;
  background: rgba(255, 255, 255, 0.08);
  outline: none;
  cursor: pointer;
  min-height: auto;
}

input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--up);
  border: 2px solid #000;
  cursor: pointer;
}

input[type=range]::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--up);
  border: 2px solid #000;
  cursor: pointer;
}

/* ── Grid helpers ── */
.row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 6px;
  flex-wrap: wrap
}

.between {
  justify-content: space-between
}

.grid {
  display: grid;
  gap: 8px;
  margin-top: 8px
}

.grid-7 {
  grid-template-columns: repeat(7, 1fr)
}

.grid-2 {
  grid-template-columns: 1fr 1fr
}

.msg {
  font-size: 11px;
  color: var(--muted)
}

.msg.err {
  color: var(--dn)
}

.hidden {
  display: none
}

h2 {
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .01em;
}

/* ── Preview row (bot creation) ── */
.preview {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-top: 6px
}

.preview .p {
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--bg3);
  padding: 8px 10px;
}

.preview .p span {
  color: var(--muted);
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.preview .p b {
  display: block;
  margin-top: 4px;
  font-family: var(--ff-mono);
  font-size: 12px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* ── Bot cards ── */
.bots {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 6px
}

@media (max-width: 1400px) {
  .bots { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 1100px) {
  .bots { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px) {
  .bots { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════
   BOT CARD — Diseño A+C
   Barra lateral de color · tipografía IBM Plex
   Mono · grid de 4 métricas · barra de ROI
   · botones keycap
   ═══════════════════════════════════════════ */
.bot {
  display: grid;
  grid-template-columns: 3px minmax(0, 1fr);
  min-width: 0;
  border: 1px solid var(--border2);
  border-radius: var(--r2);
  background: var(--bg3);
  overflow: hidden;
  transition: border-color .18s, background .18s, box-shadow .18s;
}
.bot:hover {
  border-color: rgba(255,255,255,.16);
  background: var(--bg4);
  box-shadow: 0 6px 24px rgba(0,0,0,.36);
}

/* ── Barra lateral de color (dirección) ── */
.bot-stripe {
  width: 3px;
  flex-shrink: 0;
}

/* ── Neutrals → sin shade ── */
.bot.bot-neutral .bot-stripe { background: var(--muted); }

/* ── Long → shade verde ── */
.bot.bot-long,
.bot.bot-mg-long {
  border-color: rgba(61,186,133,0.22);
  background: linear-gradient(135deg, rgba(61,186,133,0.08) 0%, var(--bg3) 60%);
}
.bot.bot-long .bot-stripe,
.bot.bot-mg-long .bot-stripe { background: var(--up); }
.bot.bot-long:hover,
.bot.bot-mg-long:hover {
  background: linear-gradient(135deg, rgba(61,186,133,0.13) 0%, var(--bg4) 60%);
}

/* ── Short → shade rojo ── */
.bot.bot-short,
.bot.bot-mg-short {
  border-color: rgba(217,92,110,0.22);
  background: linear-gradient(135deg, rgba(217,92,110,0.08) 0%, var(--bg3) 60%);
}
.bot.bot-short .bot-stripe,
.bot.bot-mg-short .bot-stripe { background: var(--dn); }
.bot.bot-short:hover,
.bot.bot-mg-short:hover {
  background: linear-gradient(135deg, rgba(217,92,110,0.13) 0%, var(--bg4) 60%);
}

/* ── Paused → amarillo ── */
.bot.bot-paused .bot-stripe { background: var(--warn); }

/* ── Inner wrapper ── */
.bot-inner {
  min-width: 0;
  width: 100%;
  padding: 13px 14px 12px;
}

/* ── Top row ── */
.bot .top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}
.bot-asset-block {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
  flex: 1 1 auto;
}
.bot-asset {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 16px; font-weight: 600; letter-spacing: -.01em;
}
.bot-tags { display: flex; gap: 4px; align-items: center; }
.bot-tag {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 9px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 4px;
  background: var(--bg5); color: var(--muted); border: 1px solid var(--border2);
}
.bot-tag.long    { background: var(--up-bg);  color: var(--up);  border-color: var(--up-bd); }
.bot-tag.short   { background: var(--dn-bg);  color: var(--dn);  border-color: var(--dn-bd); }
.bot-tag.neutral { background: rgba(108,141,255,.07); color: var(--accent); border-color: rgba(108,141,255,.2); }
.bot-id {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 9px; color: var(--dim); letter-spacing: .04em;
  margin-top: 2px;
}

/* ── Badge de estado ── */
.badge {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 9px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  padding: 3px 9px; border-radius: 5px;
  display: inline-flex; align-items: center; gap: 5px;
  flex-shrink: 0;
}
.badge::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: currentColor; flex-shrink: 0;
}
.badge.run   { background: var(--up-bg); color: var(--up); border: 1px solid var(--up-bd); animation: badge-glow 2.5s ease infinite; }
.badge.pause { background: var(--warn-bg); color: var(--warn); border: 1px solid var(--warn-bd); }
.badge.stop  { background: rgba(255,255,255,.05); color: var(--muted); border: 1px solid var(--border2); }
@keyframes badge-glow {
  0%,100% { box-shadow: 0 0 0 0 rgba(61,186,133,0); }
  50%      { box-shadow: 0 0 10px rgba(61,186,133,.2); }
}

/* ── Metrics grid (4 celdas) ── */
.bot .meta {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  background: var(--border);
  border-radius: 7px;
  overflow: hidden;
  border: 1px solid var(--border);
  margin-bottom: 10px;
}
.meta-cell {
  background: var(--bg4);
  padding: 8px 10px;
}
.meta-label {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 8px; font-weight: 500; text-transform: uppercase;
  letter-spacing: .1em; color: var(--dim); margin-bottom: 3px;
}
.meta-value {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 13px; font-weight: 600; letter-spacing: -.01em;
  color: var(--text); font-variant-numeric: tabular-nums;
}
.meta-value.good { color: var(--up); }
.meta-value.bad  { color: var(--dn); }

/* ── ROI bar ── */
.bot-roi-row {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 10px;
}
.bot-roi-lbl {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 9px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--dim); flex-shrink: 0; width: 24px;
}
.bot-roi-track {
  flex: 1; height: 3px; background: var(--bg5); border-radius: 2px; overflow: hidden;
}
.bot-roi-fill {
  height: 100%; border-radius: 2px;
  transition: width .5s cubic-bezier(.4,0,.2,1);
}
.bot-roi-fill.good { background: linear-gradient(90deg, var(--up), rgba(61,186,133,.35)); }
.bot-roi-fill.bad  { background: linear-gradient(90deg, var(--dn), rgba(217,92,110,.35)); }
.bot-roi-pct {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 11px; font-weight: 600; flex-shrink: 0;
  width: 58px; text-align: right; letter-spacing: -.01em;
}
.bot-roi-pct.good { color: var(--up); }
.bot-roi-pct.bad  { color: var(--dn); }

/* ── Estimated liquidation row ── */
.bot-liq-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 2px 0 10px;
  padding: 9px 11px;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}
.bot-liq-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  flex: 1;
}
.bot-liq-label {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 8px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--dim);
}
.bot-liq-value {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -.01em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.bot-liq-sep {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 13px;
  color: var(--muted);
  flex-shrink: 0;
}

/* ── Actions ── */
.bot .actions {
  display: flex; gap: 5px;
}

/* ── KPIs ── */
.kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-top: 8px
}

.kpi {
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--bg3);
  padding: 9px 11px;
}

.kpi .k {
  color: var(--muted);
  font-size: 9.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 3px;
}

.kpi .v {
  font-family: var(--ff-mono);
  font-size: 14px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* ── Log ── */
.log {
  color: rgba(200,220,255,0.75);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 9px 11px;
  overflow: auto;
  max-height: 180px;
  font-family: var(--ff-mono);
  font-size: 11px;
  line-height: 1.6;
}

/* ═══════════════════════════════════════════
   TRADING TAB — Pionex-like 3 columns
   ═══════════════════════════════════════════ */
#tab-trading {
  padding: 6px 8px;
  border: none;
  background: transparent
}

#tab-trading h2 {
  font-size: 12px;
  margin: 0
}

.pionex-layout {
  display: grid;
  /* Clamp side columns so the layout never forces horizontal scrolling */
  grid-template-columns: minmax(240px, 1fr) 200px minmax(280px, 320px);
  gap: 1px;
  align-items: stretch;
  width: 100%;
  max-width: 100%;
  height: auto;
  min-height: 300px;
  overflow-x: hidden;
}


/* ── Terminal bottom panel ── */
.terminal-panel {
  background: rgba(10, 10, 10, 0.92);
  border: 1px solid var(--border);
  border-radius: 6px;
  margin-top: 1px;
  height: 218px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.tp-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  overflow-x: auto
}

.tp-tab {
  background: none;
  border: none;
  color: var(--muted);
  padding: 6px 14px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}

.tp-tab:hover {
  color: var(--text)
}

.tp-tab.active {
  color: var(--text);
  border-bottom-color: var(--accent)
}

.tp-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: auto;
  padding: 0;
  -webkit-overflow-scrolling: touch
}

.tp-pane {
  height: 100%;
  overflow-y: auto;
  overflow-x: auto
}

.tp-orders-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: rgba(10, 10, 10, 0.96);
  z-index: 2
}

.tp-orders-toolbar input {
  width: min(320px, 100%);
  height: 28px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  padding: 0 10px;
  font-size: 12px
}

.tp-orders-toolbar input:focus {
  outline: none;
  border-color: rgba(64, 156, 255, 0.7)
}

.tp-orders-count {
  margin-left: auto;
  color: var(--muted);
  font-size: 11px;
  white-space: nowrap
}

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

.tp-table thead {
  position: sticky;
  top: 0;
  background: rgba(10, 10, 10, 0.95);
  z-index: 1
}

.tp-table th {
  text-align: left;
  padding: 4px 8px;
  color: var(--muted);
  font-weight: 600;
  border-bottom: 1px solid var(--border);
  white-space: nowrap
}

.tp-table td {
  padding: 3px 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  white-space: nowrap
}

.tp-table .side-long {
  color: var(--green)
}

.tp-table .side-short {
  color: var(--red)
}

.tp-table .pnl-pos {
  color: var(--green)
}

.tp-table .pnl-neg {
  color: var(--red)
}

.tp-table .btn-cancel {
  background: none;
  border: 1px solid var(--red);
  color: var(--red);
  padding: 4px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 11px;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent
}

.tp-table .btn-cancel:hover {
  background: var(--red);
  color: #fff
}

.tp-empty {
  text-align: center;
  color: var(--muted);
  padding: 30px 0;
  font-size: 12px
}

.p-col {
  background: rgba(10, 10, 10, 0.9);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 3px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* visually fuse columns (chart|ob|sidebar) */
.chart-col {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0
}

.ob-col {
  border-radius: 0;
  border-left: 0;
  border-right: 0
}

.side-col {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0
}

/* Chart column */
.chart-col {
  min-width: 0
}

.chart-col .chart-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 6px;
  font-size: 11px;
  color: var(--muted)
}

#tv_chart {
  flex: 1;
  min-height: 300px
}

#tab-pnl canvas {
  min-height: 110px;
  background: var(--bg3);
}

/* Orderbook column */
.ob-col {
  padding: 0;
  display: flex;
  flex-direction: column
}

.ob-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, .92fr);
  color: var(--muted);
  font-size: 10px;
  font-weight: 600;
  padding: 5px 6px;
  border-bottom: 1px solid var(--border)
}

.ob-asks,
.ob-bids {
  font-size: 11px;
  flex: 1;
  overflow-y: auto;
  font-family: var(--mono);
  font-variant-numeric: tabular-nums
}

.ob-asks {
  display: flex;
  flex-direction: column;
  justify-content: flex-start
}

.ob-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, .92fr);
  gap: 4px;
  padding: 2px 6px;
  font-size: 11px;
  line-height: 1.6
}

.ob-row:hover {
  background: rgba(255, 255, 255, 0.03)
}

.ob-row .px {
  font-weight: 600
}

.ob-row.ask .px {
  color: var(--dn)
}

.ob-row.bid .px {
  color: var(--up)
}

.ob-mid {
  padding: 6px;
  margin: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  font-weight: 800;
  font-size: 14px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

#ob-book {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden
}

/* Sidebar column */
.side-col {
  display: flex;
  flex-direction: column;
  overflow-y: auto
}

.side-tabs {
  display: flex;
  border-bottom: 1px solid var(--border)
}

.side-tab {
  flex: 1;
  border: none;
  background: transparent;
  color: var(--muted);
  padding: 8px 4px;
  cursor: pointer;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: .01em;
  border-bottom: 2px solid transparent;
  transition: background .15s, color .15s, border-color .15s, opacity .15s;
  -webkit-tap-highlight-color: transparent;
}

.side-tab.active {
  color: var(--up);
  border-bottom-color: var(--up)
}

.side-panel {
  padding: 8px;
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch
}

/* Futures Bot sub-tabs */
.fb-tabs {
  display: flex;
  gap: 6px;
  padding: 6px 0 0
}

.fb-tab {
  flex: 1;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
  padding: 8px 8px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  -webkit-tap-highlight-color: transparent;
}

.fb-tab.active {
  color: var(--up);
  border-color: rgba(61,186,133, 0.3);
  background: rgba(61,186,133, 0.10)
}

/* Account balance bar in Manual */
.acct-bar {
  display: flex;
  gap: 12px;
  padding: 6px 8px;
  margin-bottom: 6px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(13, 13, 20, 0.45);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  flex-wrap: wrap;
}

.acct-bar .lbl {
  color: var(--muted);
  font-weight: 500
}

.acct-bar .val {
  color: var(--text);
  font-weight: 700;
  margin-left: 4px
}

/* Slider row */
.slider-row {
  display: flex;
  align-items: center;
  gap: 6px
}

.slider-row input[type=range] {
  flex: 1
}

.slider-row .sv {
  font-size: 11px;
  font-weight: 600;
  min-width: 60px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--text)
}


#mSizeSlider {
  --manual-slider-pct: 0%;
  touch-action: pan-y;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(108,141,255,.95) 0%, rgba(108,141,255,.95) var(--manual-slider-pct), rgba(255,255,255,.08) var(--manual-slider-pct), rgba(255,255,255,.08) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), inset 0 0 0 1px rgba(255,255,255,.04);
}

#mSizeSlider::-webkit-slider-thumb {
  width: 18px;
  height: 18px;
  border: 2px solid #0a1018;
  box-shadow: 0 0 0 4px rgba(108,141,255,.18), 0 3px 10px rgba(0,0,0,.38);
}

#mSizeSlider::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border: 2px solid #0a1018;
  box-shadow: 0 0 0 4px rgba(108,141,255,.18), 0 3px 10px rgba(0,0,0,.38);
}

.trade-slider-scale {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
  margin-top: 8px;
  font-size: 10px;
  line-height: 1;
  color: rgba(255,255,255,.42);
  font-family: var(--ff-mono);
}

.trade-slider-scale span:nth-child(1) { text-align: left; }
.trade-slider-scale span:nth-child(2),
.trade-slider-scale span:nth-child(3),
.trade-slider-scale span:nth-child(4) { text-align: center; }
.trade-slider-scale span:nth-child(5) { text-align: right; }

/* Buy/Sell buttons pro */
.btn-buy {
  flex: 1;
  padding: 10px;
  border-radius: var(--r);
  border: 1px solid var(--up-bd);
  background: var(--up-bg);
  color: var(--up);
  font-family: var(--ff-body);
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  transition: background .15s, box-shadow .15s;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  min-height: 42px;
}

.btn-buy:hover {
  background: rgba(61,186,133,0.16);
  box-shadow: 0 0 0 1px var(--up-bd);
}

.btn-buy:active {
  background: rgba(61,186,133,0.22);
}

.btn-sell {
  flex: 1;
  padding: 10px;
  border-radius: var(--r);
  border: 1px solid var(--dn-bd);
  background: var(--dn-bg);
  color: var(--dn);
  font-family: var(--ff-body);
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  transition: background .15s, box-shadow .15s;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  min-height: 42px;
}

.btn-sell:hover {
  background: rgba(217,92,110,0.16);
  box-shadow: 0 0 0 1px var(--dn-bd);
}

.btn-sell:active {
  background: rgba(217,92,110,0.22);
}

/* ═══════════════════════════════════════
   RESPONSIVE — Tablet
   ═══════════════════════════════════════ */
@media(max-width:1100px) {
  .pionex-layout {
    grid-template-columns: 1fr 190px 260px;
    height: auto;
    min-height: 50vh
  }

  .terminal-panel {
    height: 180px
  }
}

/* ═══════════════════════════════════════
   RESPONSIVE — Mobile (<900px)
   ═══════════════════════════════════════ */
@media(max-width:900px) {
  html {
    font-size: 14px
  }

  header {
    padding: 8px 10px
  }

  header h1 {
    font-size: 14px
  }

  .sub {
    font-size: 10px
  }

  /* Stack 3 columns vertically */
  .pionex-layout {
    grid-template-columns: 1fr;
    height: auto;
    gap: 4px;
  }

  .p-col {
    min-height: auto;
    border-radius: 6px !important
  }

  /* Chart: fixed height, full width */
  .chart-col {
    order: 1
  }

  #tv_chart {
    height: 300px;
    flex: none
  }

  /* Orderbook: horizontal compact, fixed height */
  .ob-col {
    order: 2;
    max-height: 200px
  }

  /* Sidebar: natural flow */
  .side-col {
    order: 3;
    max-height: none;
    overflow-y: visible
  }

  .side-panel {
    padding: 10px
  }

  /* Terminal panel */
  .terminal-panel {
    height: 200px;
    border-radius: 6px
  }

  .tp-table {
    font-size: 10px;
    min-width: 420px
  }

  .tp-table th,
  .tp-table td {
    padding: 3px 6px
  }

  .tp-tab {
    padding: 8px 12px;
    font-size: 11px
  }

  /* Grids: 2 cols max */
  .grid-7 {
    grid-template-columns: repeat(2, 1fr)
  }

  .grid-2 {
    grid-template-columns: 1fr 1fr
  }

  .preview {
    grid-template-columns: repeat(2, 1fr)
  }

  .kpis {
    grid-template-columns: 1fr
  }

  /* Bigger touch targets */
  .btn {
    padding: 8px 14px;
    font-size: 12px;
    min-height: 40px
  }

  .btn-buy,
  .btn-sell {
    min-height: 48px;
    font-size: 14px
  }

  input,
  select {
    min-height: 40px;
    font-size: 14px;
    padding: 8px 10px
  }

  .tab {
    padding: 12px 14px;
    font-size: 12px
  }

  .side-tab {
    padding: 10px 4px;
    font-size: 12px
  }
}

/* ═══════════════════════════════════════
   RESPONSIVE — Small phone (<480px)
   ═══════════════════════════════════════ */
@media(max-width:480px) {
  header {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px
  }

  .right {
    width: 100%;
    justify-content: space-between
  }

  .tabs {
    padding: 0 6px
  }

  .tab {
    padding: 10px 10px;
    font-size: 11px
  }

  #tv_chart {
    height: 240px
  }

  .ob-col {
    max-height: 160px
  }

  .grid-2 {
    grid-template-columns: 1fr
  }

  .preview {
    grid-template-columns: 1fr 1fr
  }

  .terminal-panel {
    height: 180px
  }

  .tp-table {
    min-width: 360px
  }

  .card {
    padding: 8px
  }

  .side-panel {
    padding: 6px
  }

  .bot .top {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .bot-asset-block,
  .bot-asset-block > div,
  .bot-asset-block > div > div {
    min-width: 0;
    max-width: 100%;
  }

  .bot-asset-block > div > div,
  .bot-tags,
  .bot .actions {
    flex-wrap: wrap;
  }

  .bot .meta {
    font-size: 11px;
    gap: 8px
  }

  .bot .actions {
    gap: 4px
  }

  .bot .actions .btn {
    flex: 1 1 calc(50% - 4px);
    min-width: 0;
    text-align: center
  }
}

/* ═══════════════════════════════════════
   SAFE AREA (notch phones)
   ═══════════════════════════════════════ */
@supports(padding: env(safe-area-inset-bottom)) {
  body {
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
    padding-bottom: env(safe-area-inset-bottom);
  }
}

/* ═══════════════════════════════════════════
   BOT SELECTION CARDS (Elegir Bot)
   ═══════════════════════════════════════════ */
.bot-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-top: 16px;
}

.bot-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 20px;
  cursor: pointer;
  transition: border-color .18s, box-shadow .18s;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  overflow: hidden;
}

.bot-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--up) 0%, transparent 70%);
  opacity: 0;
  transition: opacity .2s;
}

.bot-card:hover {
  border-color: var(--up-bd);
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
}

.bot-card:hover::after {
  opacity: .8;
}

.bot-card.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.bot-card.disabled:hover {
  border-color: rgba(255, 255, 255, 0.08);
  transform: none;
  box-shadow: none;
}

.bot-card .bot-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--bg4);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 8px;
  flex-shrink: 0;
}

.bot-card .bot-name {
  font-family: var(--ff-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}

.bot-card .bot-desc {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
  flex: 1;
}

.bot-card .bot-status {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 4px 10px;
  border-radius: 99px;
  display: inline-block;
  width: fit-content;
  margin-top: 8px;
}

.bot-status.disponible {
  background: rgba(61,186,133, 0.15);
  color: #3dba85;
}

.bot-status.soon {
  background: rgba(255, 159, 10, 0.15);
  color: var(--warn);
}

.bot-config-form {
  animation: fadeIn 0.2s ease;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.coming-soon-msg {
  text-align: center;
  padding: 40px 20px;
}

.coming-soon-icon {
  font-size: 48px;
  margin-bottom: 16px;
}

/* ═══════════════════════════════════════════
   BOT DETAIL: Pending orders book (Pionex-ish)
   ═══════════════════════════════════════════ */
.pend-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.03);
  font-size: 12px;
}

.pend-bar {
  display: flex;
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  margin: 10px 2px 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.pend-bar .g {
  flex: 1;
  background: linear-gradient(90deg, rgba(61,186,133, 0.9), rgba(61,186,133, 0.35));
}

.pend-bar .r {
  flex: 1;
  background: linear-gradient(90deg, rgba(255, 69, 58, 0.35), rgba(255, 69, 58, 0.9));
}

.pend-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: start
}

/* (mid column removed; keep layout full-width) */
.pend-col {
  min-width: 0
}

.pend-col-head {
  display: grid;
  grid-template-columns: 1fr 72px 64px;
  gap: 10px;
  color: rgba(255, 255, 255, 0.35);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 0 0 6px
}

.pend-col-head.right {
  text-align: right
}

.pend-col-head.right span {
  text-align: right
}

.pend-row {
  display: grid;
  grid-template-columns: 22px 1fr 72px 64px;
  gap: 10px;
  align-items: center;
  padding: 4px 0;
  font-family: var(--mono);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}

.pend-badge {
  width: 18px;
  height: 18px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 900;
  color: #000;
}

.pend-badge.buy {
  background: rgba(61,186,133, 0.9)
}

.pend-badge.sell {
  background: rgba(255, 69, 58, 0.9);
  color: #fff
}

.pend-buy .pend-px {
  color: #3dba85;
  font-weight: 800
}

.pend-sell .pend-px {
  color: var(--dn);
  font-weight: 800;
  text-align: right
}

.pend-dist {
  color: rgba(255, 255, 255, 0.45);
  text-align: center
}

.pend-sz {
  color: rgba(255, 255, 255, 0.55);
  text-align: right
}

@media (max-width:700px) {
  .pend-cols {
    grid-template-columns: 1fr;
  }
}


/* ── Bot card action buttons (keycap style) ── */
.bot .actions .btn {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  padding: 8px 10px !important;
  border-radius: 7px !important;
  box-shadow: 0 2px 0 rgba(0,0,0,.6) !important;
  transition: all .12s !important;
}
.bot .actions .btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 3px 0 rgba(0,0,0,.6) !important;
}
.bot .actions .btn:active {
  transform: translateY(1px) !important;
  box-shadow: 0 1px 0 rgba(0,0,0,.6) !important;
}

.btn-stop-close {
  background: rgba(255, 69, 58, 0.08) !important;
  border: 1px solid rgba(255, 69, 58, 0.3) !important;
  color: var(--dn) !important;
}
.btn-stop-close:hover { background: rgba(255, 69, 58, 0.16) !important; }

.btn-pause {
  background: rgba(255, 159, 10, 0.08) !important;
  border: 1px solid rgba(255, 159, 10, 0.3) !important;
  color: var(--warn) !important;
}
.btn-pause:hover { background: rgba(255, 159, 10, 0.16) !important; }

.btn-resume {
  background: rgba(61,186,133, 0.08) !important;
  border: 1px solid rgba(61,186,133, 0.3) !important;
  color: var(--up) !important;
  flex: 2 !important;
}
.btn-resume:hover { background: rgba(61,186,133, 0.16) !important; }

.btn-detail {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  flex: 0 0 auto !important;
}

.btn-delete {
  background: transparent !important;
  border: 1px solid rgba(255, 69, 58, 0.2) !important;
  color: rgba(255, 69, 58, 0.7) !important;
  flex: 0 0 auto !important;
  padding: 8px 12px !important;
}
.btn-delete:hover {
  background: rgba(255, 69, 58, 0.1) !important;
  color: var(--dn) !important;
}

/* ═══════════════════════════════════════════
   APP HIDDEN (when landing is visible)
   ═══════════════════════════════════════════ */
.app-hidden {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════
   LANDING PAGE — MyLiquidBot
   Futuristic, clean, professional design for crypto traders
   ═══════════════════════════════════════════════════════════════ */

#landing {
  font-family: var(--ff-body);
  color: var(--text);
  overflow-x: hidden;
}

/* ── Container ── */
.land-container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ═══ NAVBAR ═══ */
.land-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: rgba(0, 0, 0, 0.65);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: background 0.3s;
}

.land-nav-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: calc(60px + env(safe-area-inset-bottom, 0px));
}

.land-logo {
  display: flex;
  align-items: center;
  gap: 9px;
  font-family: var(--ff-display);
  text-decoration: none;
}

.land-logo-icon {
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: var(--bg4);
  border: 1px solid var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.land-logo-text {
  font-family: var(--ff-display);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: .01em;
  background: linear-gradient(135deg, #fff 30%, rgba(61,186,133, 0.8));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.land-nav-links {
  display: flex;
  gap: 28px;
}

.land-nav-links a {
  color: rgba(255, 255, 255, 0.55);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  transition: color 0.2s;
  letter-spacing: 0.01em;
}

.land-nav-links a:hover {
  color: #fff;
}

.land-nav-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

.land-btn-login {
  border: 1px solid rgba(61,186,133, 0.35);
  background: rgba(61,186,133, 0.10);
  color: #3dba85;
  padding: 8px 18px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 650;
  font-family: var(--ff-body);
  transition: all 0.2s;
}

.land-btn-login:hover {
  background: rgba(61,186,133, 0.18);
  border-color: rgba(61,186,133, 0.5);
}

.land-mobile-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
}

.land-mobile-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: rgba(255, 255, 255, 0.7);
  border-radius: 2px;
  transition: all 0.25s;
}

/* ═══ HERO ═══ */
.land-hero {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 100px 24px 60px;
}

.land-hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 40%, rgba(61,186,133,0.07) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 72% 58%, rgba(108,141,255,0.05) 0%, transparent 60%),
    radial-gradient(ellipse 35% 35% at 20% 70%, rgba(146,120,224,0.04) 0%, transparent 50%);
  will-change: opacity;
  animation: heroGlow 10s ease-in-out infinite alternate;
}

@keyframes heroGlow {
  from { opacity: 1; }
  to   { opacity: 0.65; }
}

.land-hero-grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black 20%, transparent 70%);
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) {
  .land-hero-bg { animation: none !important; }
}

.land-hero-content {
  position: relative;
  text-align: center;
  max-width: 720px;
}

.land-hero-badge {
  display: inline-block;
  padding: 6px 16px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 28px;
  letter-spacing: 0.02em;
}

.land-hero-title {
  font-family: var(--ff-display);
  font-size: clamp(36px, 6vw, 64px);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.01em;
  margin: 0 0 20px;
  color: #fff;
}

.land-gradient-text {
  background: linear-gradient(135deg, #3dba85 0%, #6c8dff 60%, #9278e0 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.land-hero-sub {
  font-size: clamp(15px, 2vw, 18px);
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.52);
  margin: 0 auto 36px;
  max-width: 520px;
}

.land-hero-sub strong {
  color: rgba(255, 255, 255, 0.8);
}

.land-hero-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Primary button ── */
.land-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 12px;
  border: none;
  background: linear-gradient(135deg, #3dba85 0%, #2f9a6d 100%);
  color: #000;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--ff-body);
  cursor: pointer;
  transition: all 0.2s;
  box-shadow: 0 4px 20px rgba(61,186,133, 0.25);
}

.land-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(61,186,133, 0.35);
}

.land-btn-primary:active {
  transform: translateY(0);
}

.land-btn-lg {
  padding: 16px 36px;
  font-size: 16px;
  border-radius: 14px;
}

.land-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.85);
  font-size: 15px;
  font-weight: 600;
  font-family: var(--ff-body);
  cursor: pointer;
  transition: all 0.2s;
}

.land-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.2);
}

.land-btn-telegram {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 12px;
  border: 1px solid var(--acc-bd);
  background: var(--acc-bg);
  color: var(--accent);
  font-size: 15px;
  font-weight: 600;
  font-family: var(--ff-body);
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s;
}

.land-btn-telegram:hover {
  background: rgba(108, 141, 255, 0.15);
  border-color: rgba(108, 141, 255, 0.40);
}

/* ── Trust badges ── */
.land-hero-trust {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-top: 40px;
  flex-wrap: wrap;
}

.land-trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.45);
  letter-spacing: 0.02em;
}

.land-trust-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

.land-trust-dot.green {
  background: #3dba85;
  box-shadow: 0 0 8px rgba(61,186,133, 0.5);
}

.land-trust-dot.blue {
  background: var(--accent);
  box-shadow: 0 0 8px rgba(108, 141, 255, 0.5);
}

.land-trust-dot.purple {
  background: var(--purple);
  box-shadow: 0 0 8px rgba(146, 120, 224, 0.5);
}

/* ═══ SECTIONS ═══ */
.land-section {
  padding: 100px 0;
}

.land-section-dark {
  background: rgba(255, 255, 255, 0.015);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.land-section-header {
  text-align: center;
  margin-bottom: 56px;
}

.land-section-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #3dba85;
  padding: 5px 14px;
  border-radius: 99px;
  border: 1px solid rgba(61,186,133, 0.2);
  background: rgba(61,186,133, 0.06);
  margin-bottom: 18px;
}

.land-section-title {
  font-family: var(--ff-display);
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 12px;
  color: #fff;
}

.land-section-sub {
  font-size: 14.5px;
  color: var(--muted);
  max-width: 500px;
  margin: 0 auto;
  line-height: 1.65;
}

/* ═══ FEATURES GRID ═══ */
.land-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.land-feature-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 26px 22px;
  transition: border-color .2s, box-shadow .2s, transform .2s;
}

.land-feature-card:hover {
  border-color: var(--border2);
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(0,0,0,.35);
}

.land-feature-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: var(--bg4);
  border: 1px solid var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  box-shadow: 0 0 18px var(--glow-color, transparent);
  transition: box-shadow .3s;
}

.land-feature-card:hover .land-feature-icon {
  box-shadow: 0 0 28px var(--glow-color, transparent);
}

.land-feature-card h3 {
  font-family: var(--ff-display);
  font-size: 15px;
  font-weight: 600;
  margin: 0 0 8px;
  color: #fff;
}

.land-feature-card p {
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.45);
  margin: 0;
}

/* ═══ HOW IT WORKS (STEPS) ═══ */
.land-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
}

.land-step {
  text-align: center;
  padding: 0 24px;
  position: relative;
}

.land-step-num {
  font-size: 42px;
  font-weight: 900;
  letter-spacing: -0.04em;
  background: linear-gradient(180deg, rgba(61,186,133, 0.4) 0%, rgba(61,186,133, 0.05) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 16px;
}

.land-step-line {
  width: 60%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(61,186,133, 0.3), transparent);
  margin: 0 auto 20px;
}

.land-step h3 {
  font-size: 17px;
  font-weight: 700;
  margin: 0 0 10px;
  color: #fff;
}

.land-step p {
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.45);
  margin: 0;
  max-width: 260px;
  margin-left: auto;
  margin-right: auto;
}

/* ═══ STATS ═══ */
.land-stats-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  align-items: center;
  gap: 0;
  padding: 40px 32px;
  background: linear-gradient(180deg, rgba(20, 20, 22, 0.95) 0%, rgba(12, 12, 14, 0.95) 100%);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 20px;
  backdrop-filter: blur(12px);
}

.land-stat {
  text-align: center;
  padding: 0 16px;
}

.land-stat-value {
  font-family: var(--ff-display);
  font-size: clamp(32px, 4vw, 44px);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #fff;
  line-height: 1;
  margin-bottom: 6px;
}

.land-stat-label {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 4px;
}

.land-stat-sub {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.3);
}

.land-stat-divider {
  width: 1px;
  height: 50px;
  background: rgba(255, 255, 255, 0.06);
}

/* ═══ BOTS SHOWCASE ═══ */
.land-bots-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.land-bot-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 26px 22px;
  position: relative;
  transition: border-color .2s, box-shadow .2s, transform .2s;
  overflow: hidden;
}

.land-bot-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  transition: opacity .3s;
}

.land-bot-active {
  cursor: pointer;
  border-color: var(--up-bd);
}

.land-bot-active::before {
  background: linear-gradient(90deg, transparent, rgba(61,186,133,0.45), transparent);
}

.land-bot-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(0,0,0,.3);
}

.land-bot-active:hover {
  border-color: rgba(61,186,133, 0.35);
  box-shadow: 0 10px 32px rgba(61,186,133, 0.08);
}

.land-bot-badge {
  position: absolute;
  top: 20px;
  right: 20px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 5px 12px;
  border-radius: 99px;
}

.land-bot-badge.available {
  background: rgba(61,186,133, 0.12);
  color: #3dba85;
  border: 1px solid rgba(61,186,133, 0.25);
}

.land-bot-badge.coming {
  background: rgba(255, 159, 10, 0.12);
  color: var(--warn);
  border: 1px solid rgba(255, 159, 10, 0.25);
}

.land-bot-icon {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: var(--bg4);
  border: 1px solid var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
}

.land-bot-card h3 {
  font-family: var(--ff-display);
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 10px;
  color: #fff;
}

.land-bot-card p {
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.42);
  margin: 0 0 16px;
}

.land-bot-features {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
}

.land-bot-features li {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
  padding: 5px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  display: flex;
  align-items: center;
  gap: 8px;
}

.land-bot-features li::before {
  content: '→';
  color: rgba(61,186,133, 0.6);
  font-weight: 700;
  font-size: 11px;
}

.land-bot-cta {
  font-size: 13px;
  font-weight: 700;
  color: #3dba85;
  transition: color 0.2s;
}

.land-bot-active:hover .land-bot-cta {
  color: #4de070;
}

/* ═══ PRICING ═══ */
.land-pricing-card {
  max-width: 440px;
  margin: 0 auto;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(61,186,133,0.08), 0 20px 60px rgba(0,0,0,0.4);
}

.land-pricing-header {
  padding: 30px 26px 22px;
  text-align: center;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(61,186,133,0.04) 0%, transparent 100%);
}

.land-pricing-price {
  font-family: var(--ff-display);
  font-size: 42px;
  font-weight: 700;
  letter-spacing: -0.01em;
  background: linear-gradient(135deg, #3dba85, #6c8dff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.land-pricing-period {
  font-size: 12.5px;
  font-family: var(--ff-mono);
  color: var(--muted);
  margin-top: 6px;
  letter-spacing: .02em;
}

.land-pricing-body {
  padding: 24px 28px;
}

.land-pricing-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 0;
  font-size: 13.5px;
  color: var(--text);
  border-bottom: 1px solid var(--border);
}

.land-pricing-check {
  color: #3dba85;
  font-weight: 700;
  font-size: 15px;
}

.land-pricing-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.06);
  margin: 16px 0;
}

.land-pricing-fee {
  text-align: center;
}

.land-pricing-fee-title {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.52);
  margin-bottom: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.land-pricing-fee-detail {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 14px;
}

.land-pricing-fee-detail span {
  color: rgba(255, 255, 255, 0.5);
}

.land-pricing-fee-detail strong {
  color: #fff;
  font-weight: 700;
}

/* ═══ CTA SECTION ═══ */
.land-cta-section {
  position: relative;
  padding: 100px 0;
  text-align: center;
  overflow: hidden;
}

.land-cta-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%, rgba(61,186,133, 0.06) 0%, transparent 65%),
    radial-gradient(ellipse 40% 50% at 30% 40%, rgba(108, 141, 255, 0.04) 0%, transparent 50%);
}

.land-cta-title {
  font-family: var(--ff-display);
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 14px;
  color: #fff;
  position: relative;
}

.land-cta-sub {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.45);
  margin: 0 0 32px;
  position: relative;
}

.land-cta-actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
}

/* ═══ FOOTER ═══ */
.land-footer {
  border-top: 1px solid var(--border);
  padding: 52px 0 30px;
  background: rgba(7,7,11,0.6);
}

.land-footer-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
}

.land-footer-brand {
  flex-shrink: 0;
  max-width: 220px;
}

.land-footer-desc {
  font-size: 12px;
  color: var(--dim);
  margin: 10px 0 0;
  line-height: 1.6;
}

.land-footer-links {
  display: flex;
  gap: 60px;
}

.land-footer-col {
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.land-footer-col h4 {
  font-family: var(--ff-display);
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin: 0 0 4px;
}

.land-footer-col a {
  color: var(--dim);
  text-decoration: none;
  font-size: 12.5px;
  transition: color 0.15s;
}

.land-footer-col a:hover {
  color: var(--text);
}

.land-footer-bottom {
  margin-top: 32px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  font-size: 11.5px;
  font-family: var(--ff-mono);
  color: var(--dim);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}

/* ═══ SCROLL ANIMATIONS ═══ */
.land-anim {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.55s cubic-bezier(0.22,1,0.36,1), transform 0.55s cubic-bezier(0.22,1,0.36,1);
  will-change: opacity, transform;
}

.land-anim.land-visible {
  opacity: 1;
  transform: translateY(0);
  will-change: auto;
}

@media (prefers-reduced-motion: reduce) {
  .land-anim {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

.land-features-grid .land-anim:nth-child(2) {
  transition-delay: 0.08s;
}

.land-features-grid .land-anim:nth-child(3) {
  transition-delay: 0.16s;
}

.land-features-grid .land-anim:nth-child(4) {
  transition-delay: 0.24s;
}

.land-features-grid .land-anim:nth-child(5) {
  transition-delay: 0.32s;
}

.land-features-grid .land-anim:nth-child(6) {
  transition-delay: 0.40s;
}

.land-steps .land-anim:nth-child(2) {
  transition-delay: 0.12s;
}

.land-steps .land-anim:nth-child(3) {
  transition-delay: 0.24s;
}

.land-bots-grid .land-anim:nth-child(2) {
  transition-delay: 0.10s;
}

.land-bots-grid .land-anim:nth-child(3) {
  transition-delay: 0.20s;
}

/* ═══ LANDING RESPONSIVE — Tablet ═══ */
@media (max-width: 900px) {
  .land-nav-links {
    display: none;
  }

  .land-mobile-toggle {
    display: flex;
  }

  .land-nav.open .land-nav-links {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 60px;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.92);
    backdrop-filter: blur(20px);
    padding: 16px 24px;
    gap: 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  }

  .land-nav.open .land-nav-links a {
    font-size: 15px;
  }

  .land-features-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .land-steps {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .land-stats-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    padding: 32px 24px;
  }

  .land-stat-divider {
    display: none;
  }

  .land-bots-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin: 0 auto;
  }

  .land-footer-top {
    flex-direction: column;
  }
}

/* ═══ LANDING RESPONSIVE — Mobile ═══ */
@media (max-width: 540px) {
  .land-hero {
    padding: 90px 20px 50px;
    min-height: 90vh;
  }

  .land-hero-title {
    font-size: 32px;
  }

  .land-nav-right .pill-group {
    display: none;
  }

  .land-features-grid {
    grid-template-columns: 1fr;
  }

  .land-feature-card {
    padding: 22px 20px;
  }

  .land-stats-row {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 28px 20px;
  }

  .land-section {
    padding: 64px 0;
  }

  .land-hero-actions {
    flex-direction: column;
    align-items: center;
  }

  .land-btn-primary,
  .land-btn-secondary,
  .land-btn-telegram {
    width: 100%;
    justify-content: center;
    max-width: 280px;
  }

  .land-cta-actions {
    flex-direction: column;
    align-items: center;
  }

  .land-footer-links {
    flex-direction: column;
    gap: 24px;
  }

  .land-pricing-card {
    margin: 0 8px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   HOME BUTTON (in app header)
   ═══════════════════════════════════════════════════════════════ */
.btn-home {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  min-height: 36px;
  padding: 0 !important;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
}

.btn-home:hover {
  background: rgba(61,186,133, 0.1);
  border-color: rgba(61,186,133, 0.3);
}

.btn-home:hover svg {
  stroke: #3dba85;
}

.btn-home-sm {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
}

/* ═══════════════════════════════════════════════════════════════
   CUENTA TAB — Professional card-based redesign
   ═══════════════════════════════════════════════════════════════ */
#tab-cuenta {
  border: none;
  background: transparent;
  padding: 0;
}

.cuenta-wrap {
  padding: 16px 12px;
  width: 100%;
  max-width: none;
  margin: 0;
}

/* Header */
.cuenta-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 24px;
  gap: 12px;
  flex-wrap: wrap;
}

.cuenta-header-left {}

.cuenta-title {
  font-size: 20px !important;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 !important;
}

.cuenta-sub {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.52);
  margin: 4px 0 0;
}

.cuenta-header-right {
  display: flex;
  gap: 8px;
  align-items: center;
}

/* Cards Grid */
.cuenta-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.cuenta-profile-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0 0 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(108,141,255,0.08), rgba(108,141,255,0.02));
}

.cuenta-profile-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.cuenta-profile-avatar-wrap {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid rgba(108,141,255,.35);
  background: rgba(108,141,255,.12);
  flex-shrink: 0;
}

.cuenta-profile-avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cuenta-profile-meta {
  min-width: 0;
}

.cuenta-profile-title {
  font-size: 11px;
  color: rgba(255,255,255,.45);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.cuenta-profile-nick {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 280px;
}

.cuenta-profile-wallet {
  font-size: 11px;
  color: rgba(255,255,255,.52);
}

.cuenta-profile-avatar-presets {
  margin: 8px 0 10px;
  max-width: 320px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(10,12,18,.72);
}

.cuenta-profile-avatar-presets[aria-hidden="true"] {
  display: none;
}

.cuenta-profile-avatar-presets-title {
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,.92);
  margin-bottom: 4px;
}

.cuenta-profile-avatar-presets-sub {
  font-size: 11px;
  color: rgba(255,255,255,.52);
  margin-bottom: 8px;
}

.cuenta-profile-avatar-presets-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cuenta-profile-avatar-option {
  width: 56px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: 12px;
  padding: 6px;
  cursor: pointer;
  transition: border-color .18s ease, transform .18s ease, background .18s ease;
}

.cuenta-profile-avatar-option:hover {
  border-color: rgba(108,141,255,.45);
  transform: translateY(-1px);
}

.cuenta-profile-avatar-option.selected {
  border-color: rgba(57,208,122,.72);
  background: rgba(57,208,122,.12);
}

.cuenta-profile-avatar-option img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  border-radius: 10px;
  background: rgba(255,255,255,.04);
}

.cuenta-profile-avatar-option-label {
  margin-top: 5px;
  font-size: 10px;
  color: rgba(255,255,255,.78);
  text-align: center;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


.cuenta-profile-nick-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cuenta-profile-nick-edit {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
}

.cuenta-profile-nick-edit.hidden {
  display: none;
}

.cuenta-profile-nick-edit input {
  min-height: 30px;
  padding: 6px 9px;
  font-size: 12px;
  border-radius: 8px;
}

.cuenta-btn-mini {
  min-height: 28px;
  padding: 4px 8px;
  font-size: 11px;
  border-radius: 8px;
}
.cuenta-profile-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.cuenta-profile-balance-inline {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  min-width: 280px;
}

.cuenta-balance-inline-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.cuenta-balance-inline-k {
  font-size: 10px;
  color: rgba(255,255,255,.5);
  letter-spacing: .04em;
  text-transform: uppercase;
}

.cuenta-balance-inline-v {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  font-family: var(--ff-mono);
}

.cuenta-balance-inline-actions {
  margin-top: 2px;
}

.cuenta-balance-inline-status {
  font-size: 11px;
  color: rgba(255,255,255,.52);
  min-height: 14px;
  text-align: right;
}

.cuenta-balance-inline-hint {
  font-size: 11px;
  color: rgba(255,255,255,.4);
  text-align: right;
  max-width: 320px;
  line-height: 1.35;
}

.cuenta-profile-inline-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
}

.cuenta-btn-lang-quick {
  min-height: 34px;
  padding: 7px 10px;
  font-size: 12px;
  border-color: rgba(108,141,255,0.35) !important;
  background: rgba(108,141,255,0.12) !important;
  color: #cfd8ff !important;
}

.cuenta-btn-lang-quick:hover {
  background: rgba(108,141,255,0.2) !important;
}

/* Asset select (match theme) */
.asset-select{
  width: 100%;
  margin-top: 6px;
  text-transform: uppercase;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  color: var(--text);
  border-radius: 10px;
  color-scheme: dark;
}
.asset-select:focus{
  outline: none;
  border-color: rgba(108,141,255,0.55);
  box-shadow: 0 0 0 3px rgba(108,141,255,0.18);
}
.asset-select option{
  background: #121219;
  color: var(--text);
}

.asset-picker-tools{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:6px;
}
.asset-type-toggle{ display:flex; gap:6px; }
.asset-type-btn{
  flex:1;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  border-radius: 9px;
  padding: 6px 8px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.asset-type-btn.active{
  color: var(--up);
  border-color: var(--up-bd);
  background: var(--up-bg);
}
.asset-combo-input{
  width:100%;
  text-transform: uppercase;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  color: var(--text);
  border-radius: 10px;
  padding: 9px 10px;
}
.asset-combo-input:focus{
  outline:none;
  border-color: rgba(108,141,255,0.55);
  box-shadow: 0 0 0 3px rgba(108,141,255,0.18);
}
.asset-picker-tools.is-open .asset-combo-input{
  border-color: rgba(108,141,255,0.55);
  box-shadow: 0 0 0 3px rgba(108,141,255,0.12);
}
.asset-collateral-hint{
  font-size: 11px;
  color: var(--muted);
  line-height: 1.35;
}
.asset-collateral-hint.warn{
  color: #ffb78e;
}
.asset-select{
  display:none;
  margin-top:8px;
}
.asset-select.asset-select-open{
  display:block;
  min-height: 0;
}

/* Individual Card */
.cuenta-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 20px;
  transition: border-color .2s, box-shadow .2s;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 260px;
}

.cuenta-card-main {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 0;
  flex: 1;
}

.cuenta-card .msg {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.52);
  margin-top: 0;
  min-height: 14px;
  white-space: pre-wrap;
}

.cuenta-card a:not(.btn) {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: 600;
}


.cuenta-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 10%, rgba(255,255,255,0.05) 50%, transparent 90%);
}

.cuenta-card:hover {
  border-color: var(--border2);
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.3);
}

/* Card Icon */
.cuenta-card-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--bg4);
  border: 1px solid var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  box-shadow: 0 0 14px var(--card-accent, transparent);
}

/* Card Titles */
.cuenta-card h3 {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 700;
  margin: 0 0 6px;
  color: var(--text);
}

.cuenta-card-desc {
  font-size: 12px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.52);
  margin: 0 0 14px;
}

/* Card Actions */
.cuenta-card-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: 8px;
}

.cuenta-card-actions .btn {
  font-size: 12px;
}

/* Card Input Row */
.cuenta-card-input-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.cuenta-card-input-row input {
  flex: 1;
  font-size: 13px;
  padding: 8px 12px;
  min-height: 38px;
}

.cuenta-card-input-row .btn {
  flex-shrink: 0;
}

/* Card Status */
.cuenta-card-status {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.52);
  margin-top: 8px;
  min-height: 14px;
  white-space: pre-wrap;
}

/* Card Hint */
.cuenta-card-hint {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.3);
  margin-top: 0;
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.04);
  line-height: 1.5;
}


/* Cuenta polish: cleaner balance + fewer inner boxes */
.cuenta-card-balance .kpis {
  grid-template-columns: 1fr;
  gap: 6px;
}

.cuenta-card-balance .kpi {
  border: 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  border-radius: 0;
  background: transparent;
  padding: 6px 0;
}

.cuenta-card-balance .kpi:last-child {
  border-bottom: 0;
}

.cuenta-card-hint {
  background: transparent;
  border: 0;
  padding: 0;
  color: rgba(255,255,255,0.42);
}

.cuenta-fee-item {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.04);
}


/* Hyperliquid button */
.cuenta-btn-hl {
  background: rgba(108,141,255,0.08) !important;
  border-color: rgba(108,141,255,0.25) !important;
  color: var(--accent) !important;
}

.cuenta-btn-hl:hover {
  background: rgba(108,141,255,0.14) !important;
}

/* Telegram button */
.cuenta-btn-tg {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  background: rgba(108,141,255,0.06) !important;
  border-color: rgba(108,141,255,0.2) !important;
  color: var(--accent) !important;
  text-decoration: none;
}

.cuenta-btn-tg:hover {
  background: rgba(108,141,255,0.12) !important;
}

/* Cuenta: unify key links visual style (Terms, Hyperliquid, Telegram) */
.cuenta-link-unified,
a.cuenta-link-unified.btn,
#accTermsLink,
#btnJoinHL,
#btnTgOpen {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 8px;
  border: 1px solid rgba(108,141,255,0.30) !important;
  background: rgba(108,141,255,0.14) !important;
  color: #dce3ff !important;
  text-decoration: none !important;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
  transition: background .2s, border-color .2s, color .2s;
}

.cuenta-link-unified:hover,
a.cuenta-link-unified.btn:hover,
#accTermsLink:hover,
#btnJoinHL:hover,
#btnTgOpen:hover {
  background: rgba(108,141,255,0.24) !important;
  border-color: rgba(108,141,255,0.52) !important;
  color: #ffffff !important;
}

#accTermsLink {
  margin: 0 4px;
  vertical-align: middle;
}

.cuenta-setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid rgba(108, 141, 255, 0.2);
  background: rgba(108, 141, 255, 0.06);
  border-radius: 10px;
  padding: 12px;
}

.cuenta-setting-meta {
  min-width: 0;
}

.cuenta-setting-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.5);
}

.cuenta-setting-value {
  margin-top: 3px;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
}

.cuenta-btn-lang {
  white-space: nowrap;
}

/* Fee Grid */
.cuenta-card-fee-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 12px 0;
}

.cuenta-fee-item {
  background: rgba(13, 13, 20, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 10px;
  padding: 10px;
  text-align: center;
}

.cuenta-fee-item span {
  display: block;
  font-size: 10px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.35);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 4px;
}

.cuenta-fee-item strong {
  font-size: 16px;
  font-weight: 800;
  color: #fff;
}

/* Terms body */
.cuenta-card-terms-body {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.35);
  line-height: 1.6;
  max-height: 120px;
  overflow-y: auto;
  padding: 10px;
  border-radius: 8px;
  background: rgba(13, 13, 20, 0.42);
  border: 1px solid rgba(255, 255, 255, 0.04);
  margin-top: 8px;
  white-space: pre-wrap;
}

/* ═══ CUENTA RESPONSIVE ═══ */
@media (max-width: 1400px) {
  .cuenta-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1050px) {
  .cuenta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .cuenta-grid {
    grid-template-columns: 1fr;
  }

  .cuenta-card {
    padding: 18px 16px;
  }

  .cuenta-card-fee-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .cuenta-header {
    flex-direction: column;
  }

  .cuenta-setting-row {
    flex-direction: column;
    align-items: stretch;
  }

  .cuenta-btn-lang {
    width: 100%;
  }

  .cuenta-profile-strip {
    flex-wrap: wrap;
  }

  .cuenta-profile-balance-inline {
    width: 100%;
    min-width: 0;
    align-items: flex-start;
  }

  .cuenta-balance-inline-status,
  .cuenta-balance-inline-hint {
    text-align: left;
    max-width: none;
  }
}
/* Trading tab: prevent inner horizontal scroll; allow vertical scroll in side panel */
.pionex-layout .p-col{ min-width:0; }
.side-col{ min-width:0; max-width:100%; }
.side-panel{ overflow:visible; }
.side-panel .grid{ min-width:0; }
.side-panel label{ min-width:0; }
.side-panel input, .side-panel select{ max-width:100%; }

@media (max-width: 1100px){
  .pionex-layout{ grid-template-columns: minmax(220px, 1fr) 180px minmax(260px, 300px); }
}

@media (max-width: 920px){
  .pionex-layout{ grid-template-columns: 1fr; height: auto; }
  .terminal-panel{ height: 240px; }
}

/* ═══════════════════════════════════════════════════════════
   NEW BOT CREATOR — Premium 3-column UI
   Prefix: nb-
   ═══════════════════════════════════════════════════════════ */

/* ── Creator hero ── */
.nb-hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(560px, 700px);
  gap: 20px;
  align-items: center;
  margin-bottom: 18px;
  padding: 18px 20px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(80,200,120,.08), transparent 34%),
    linear-gradient(180deg, rgba(13,17,26,.96), rgba(10,13,20,.88));
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}
.nb-topbar {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  flex-wrap: nowrap;
  margin-bottom: 0;
  min-width: 0;
}
.nb-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 40px;
  padding: 0 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  color: rgba(255,255,255,.72);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: color .2s, border-color .2s, background .2s, transform .2s;
}
.nb-back-btn:hover {
  color: var(--text);
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  transform: translateY(-1px);
}
.nb-hero-copy {
  min-width: 0;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.nb-hero-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.42);
  margin-bottom: 8px;
}
.nb-hero-title {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -.03em;
  color: #fff;
}
.nb-hero-sub {
  margin-top: 10px;
  max-width: 620px;
  color: rgba(255,255,255,.58);
  line-height: 1.55;
  font-size: 13px;
}

/* ── Bot type tabs ── */
.nb-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-self: center;
  min-width: 0;
}
.nb-tab {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 4px;
  min-height: 88px;
  width: auto;
  padding: 12px 16px;
  text-align: left;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  color: rgba(255,255,255,.78);
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease, color .18s ease;
}
.nb-tab-kicker {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
}
.nb-tab-main {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.1;
}
.nb-tab-meta {
  font-size: 10px;
  line-height: 1.25;
  color: rgba(255,255,255,.5);
}
.nb-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: .42;
  transition: opacity .2s, transform .2s, box-shadow .2s;
}
.nb-tab:hover {
  transform: translateY(-1px);
  color: rgba(255,255,255,.96);
  border-color: rgba(255,255,255,.16);
  background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.045));
  box-shadow: 0 14px 28px rgba(0,0,0,.18);
}
.nb-tab.active {
  background: linear-gradient(180deg, rgba(77,194,116,.16), rgba(77,194,116,.08));
  color: #d8ffe4;
  border-color: rgba(77,194,116,.28);
  box-shadow: 0 16px 34px rgba(8,20,12,.3), 0 0 0 1px rgba(77,194,116,.16) inset;
}
.nb-tab.active .nb-tab-kicker,
.nb-tab.active .nb-tab-meta { color: inherit; opacity: .82; }
.nb-tab.active .nb-dot {
  opacity: 1;
  transform: scale(1.08);
  box-shadow: 0 0 0 6px rgba(77,194,116,.12);
}
.nb-tab.tab-mart.active {
  background: linear-gradient(180deg, rgba(255,106,96,.16), rgba(255,106,96,.08));
  color: #ffd9d5;
  border-color: rgba(255,106,96,.26);
  box-shadow: 0 16px 34px rgba(30,10,10,.28), 0 0 0 1px rgba(255,106,96,.14) inset;
}
.nb-tab.tab-mart.active .nb-dot { box-shadow: 0 0 0 6px rgba(255,106,96,.12); }
.nb-tab.tab-gmart.active {
  background: linear-gradient(180deg, rgba(146,120,224,.18), rgba(146,120,224,.08));
  color: #ebe2ff;
  border-color: rgba(146,120,224,.28);
  box-shadow: 0 16px 34px rgba(18,12,32,.28), 0 0 0 1px rgba(146,120,224,.14) inset;
}
.nb-tab.tab-gmart.active .nb-dot { box-shadow: 0 0 0 6px rgba(146,120,224,.12); }

/* ── 3-column split ── */
.nb-split {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr) 292px;
  gap: 14px;
  align-items: start;
}

/* ══════════════════════
   COL 1: Market Panel
══════════════════════ */
.nb-market-panel {
  display: flex; flex-direction: column; gap: 12px;
  position: sticky; top: 16px;
}
.nb-mp-card, .nb-ob-card {
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px; overflow: hidden;
  position: relative;
  box-shadow: 0 16px 38px rgba(0,0,0,.18);
}
.nb-mp-card::after {
  content: ''; position: absolute;
  right: 0; top: 20%; bottom: 20%; width: 2px;
  background: var(--up); border-radius: 2px; opacity: .2;
}
.nb-sim-slot-desktop { margin-top: 0; }
.nb-mp-card-simple::after {
  top: 16%;
  bottom: 16%;
}

/* Price header */
.nb-mp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--border);
}
.nb-mp-card-simple .nb-mp-header {
  border-bottom: none;
  padding-bottom: 14px;
}
.nb-asset-row { display: flex; align-items: center; gap: 9px; }
.nb-asset-icon {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, #f7931a, #ff6b00);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800; color: #fff;
  font-family: 'IBM Plex Mono', monospace; flex-shrink: 0;
  transition: background .3s;
}
.nb-asset-name { font-size: 15px; font-weight: 800; letter-spacing: -.01em; }
.nb-asset-pair { font-size: 10px; color: var(--muted); font-family: 'IBM Plex Mono', monospace; }
.nb-price-col { text-align: right; }
.nb-price { font-family: 'IBM Plex Mono', monospace; font-size: 15px; font-weight: 700; color: var(--up); }
.nb-change { font-size: 10px; font-family: 'IBM Plex Mono', monospace; font-weight: 600; color: var(--up); }
.nb-change.neg { color: var(--dn); }

/* Timeframe tabs */
.nb-tf-tabs {
  display: flex; gap: 2px; padding: 7px 12px;
  border-bottom: 1px solid var(--border);
}
.nb-tf {
  padding: 3px 9px; border-radius: 5px; border: none;
  background: transparent; color: var(--muted);
  font-family: 'IBM Plex Mono', monospace; font-size: 10px; font-weight: 600;
  cursor: pointer; transition: all .15s;
}
.nb-tf.active { background: var(--up-bg); color: var(--up); }
.nb-tf:hover:not(.active) { color: var(--text); }

/* Mini chart */
.nb-chart-wrap {
  position: relative; height: 106px;
  background: var(--bg4); overflow: hidden;
}
.nb-chart-wrap canvas { display: block; width: 100%; height: 100%; }
.nb-chart-labels {
  position: absolute; top: 0; right: 0; bottom: 0;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 6px 8px; pointer-events: none;
}
.nb-chart-labels span {
  font-family: 'IBM Plex Mono', monospace; font-size: 9px;
  color: var(--muted); opacity: .6;
}

/* Stats 2x2 */
.nb-stats-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px; background: var(--border);
}
.nb-stat {
  background: var(--bg3); padding: 9px 14px;
  display: flex; flex-direction: column; gap: 2px;
}
.nb-st-lbl {
  font-size: 9px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--muted);
}
.nb-st-val { font-family: 'IBM Plex Mono', monospace; font-size: 12px; font-weight: 600; color: var(--text); }
.nb-st-val.green { color: var(--up); }
.nb-st-val.red   { color: var(--dn); }

/* Order Book */
.nb-ob-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 16px 9px; border-bottom: 1px solid var(--border);
}
.nb-ob-title { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); }
.nb-ob-prec { display: flex; gap: 3px; }
.nb-prec-btn {
  padding: 2px 7px; border-radius: 4px;
  border: 1px solid var(--border2); background: transparent;
  color: var(--muted); font-size: 9px; font-family: 'IBM Plex Mono', monospace;
  cursor: pointer; transition: all .15s;
}
.nb-prec-btn.active { background: var(--bg5); color: var(--text); }
.nb-ob-cols {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  padding: 5px 14px; border-bottom: 1px solid var(--border);
}
.nb-ob-cols span { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); }
.nb-ob-cols span:nth-child(2) { text-align: center; }
.nb-ob-cols span:nth-child(3) { text-align: right; }

.nb-ob-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  padding: 3px 14px; position: relative; cursor: default;
  transition: background .1s;
}
.nb-ob-row:hover { background: rgba(255,255,255,0.03); }
.nb-ob-fill {
  position: absolute; top: 0; bottom: 0; right: 0;
  border-radius: 2px 0 0 2px; pointer-events: none;
}
.nb-ob-asks .nb-ob-fill { background: rgba(217,92,110,0.10); }
.nb-ob-bids .nb-ob-fill { background: rgba(61,186,133,0.10); }
.nb-ob-row span { font-family: 'IBM Plex Mono', monospace; font-size: 11px; position: relative; z-index: 1; }
.nb-ob-asks .nb-ob-price { color: var(--dn); font-weight: 600; }
.nb-ob-bids .nb-ob-price { color: var(--up); font-weight: 600; }
.nb-ob-size  { color: var(--text); text-align: center; }
.nb-ob-total { color: var(--muted); text-align: right; font-size: 10px; }

.nb-ob-spread {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 14px;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  background: var(--bg4);
}
.nb-ob-spread-tag { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); }
.nb-ob-spread-price { font-family: 'IBM Plex Mono', monospace; font-size: 14px; font-weight: 700; color: var(--up); flex: 1; }
.nb-ob-spread-pct { font-family: 'IBM Plex Mono', monospace; font-size: 10px; color: var(--muted); background: var(--bg5); padding: 2px 7px; border-radius: 5px; }

.nb-ob-trades { padding: 8px 14px 12px; border-top: 1px solid var(--border); }
.nb-ob-trades-title { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin-bottom: 7px; }
.nb-trade-row { display: grid; grid-template-columns: 1fr 1fr 1fr; margin-bottom: 3px; }
.nb-trade-row span { font-family: 'IBM Plex Mono', monospace; font-size: 10px; }
.nb-trade-row .nb-t-price { font-weight: 600; }
.nb-trade-row .nb-t-price.buy  { color: var(--up); }
.nb-trade-row .nb-t-price.sell { color: var(--dn); }
.nb-trade-row .nb-t-size  { color: var(--muted); text-align: center; }
.nb-trade-row .nb-t-time  { color: var(--muted); text-align: right; opacity: .6; }

/* ══════════════════════
   COL 2: Form
══════════════════════ */
.nb-form-col { min-width: 0; }

.nb-bot-form {
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: 20px; overflow: hidden;
  position: relative;
}
.nb-bot-form::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--up), rgba(61,186,133,.08));
  border-radius: 2px 2px 0 0;
}

.nb-form-header {
  padding: 26px 30px 20px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
}
.nb-form-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 100px; border: 1px solid;
  margin-bottom: 8px;
}
.nb-badge-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.nb-form-title { font-size: 20px; font-weight: 800; line-height: 1; letter-spacing: -.01em; }
.nb-form-sub   { font-size: 12px; color: var(--muted); margin-top: 5px; font-weight: 400; line-height: 1.4; }
.nb-help-btn {
  flex-shrink: 0;
  background: rgba(255,255,255,0.03); border: 1px solid var(--border2);
  color: var(--muted); font-size: 12px; font-weight: 600;
  padding: 8px 12px; border-radius: 9px;
  cursor: pointer; transition: all .2s; white-space: nowrap;
}
.nb-help-btn:hover { color: var(--up); border-color: var(--up-bd); }

.nb-how-box {
  margin: 0 28px;
  padding: 14px 16px;
  background: rgba(61,186,133,.05); border: 1px solid var(--up-bd); border-radius: 12px;
  font-size: 12px; color: var(--muted); line-height: 1.55;
}
.nb-how-box strong { color: var(--text); }

.nb-form-body { padding: 24px 30px 30px; }

/* Section headers */
.nb-sec-hd {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 12px; margin-top: 2px;
}
.nb-ico {
  width: 20px; height: 20px; border-radius: 5px;
  background: var(--up-bg); border: 1px solid var(--up-bd); color: var(--up);
  font-size: 10px; font-weight: 800; font-family: 'IBM Plex Mono', monospace;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.nb-lbl { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--muted); }
.nb-lbl-note { font-size: 11px; color: var(--muted); opacity: .55; margin-left: auto; font-weight: 400; font-family: 'IBM Plex Mono', monospace; }

.nb-divider { height: 1px; background: linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.03)); margin: 22px 0; }

/* Field grids */
.nb-fg2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.nb-fg3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.nb-fg4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 10px; }

.nb-f { display: flex; flex-direction: column; gap: 5px; }
.nb-f > label {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--muted);
}
.nb-f input, .nb-f select {
  background: var(--bg4); border: 1.5px solid var(--border2);
  border-radius: 10px; padding: 10px 12px;
  color: var(--text); font-family: 'IBM Plex Mono', monospace; font-size: 13px;
  outline: none; width: 100%; transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none;
}
.nb-f input:focus, .nb-f select:focus {
  border-color: var(--up-bd);
  box-shadow: 0 0 0 3px rgba(61,186,133,.08);
}
.nb-fnote { font-size: 10px; color: var(--muted); font-family: 'IBM Plex Mono', monospace; opacity: .7; }

/* Direction cards */
.nb-dir-cards {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 8px; margin-bottom: 20px;
}
.nb-dc {
  padding: 13px 10px 12px; border-radius: 11px;
  border: 1.5px solid var(--border2); background: var(--bg4);
  cursor: pointer; transition: all .2s; text-align: center; user-select: none;
}
.nb-dc-icon { font-size: 18px; margin-bottom: 5px; }
.nb-dc-name { font-size: 13px; font-weight: 700; color: var(--muted); line-height: 1; }
.nb-dc-note { font-size: 10px; color: var(--muted); margin-top: 3px; opacity: .65; }
.nb-dc:hover { border-color: rgba(255,255,255,.2); }

.nb-dc-neutral.sel { border-color: rgba(108,141,255,.35); background: rgba(108,141,255,.08); }
.nb-dc-neutral.sel .nb-dc-name { color: var(--accent); }
.nb-dc-long.sel    { border-color: var(--up-bd); background: var(--up-bg); }
.nb-dc-long.sel    .nb-dc-name { color: var(--up); }
.nb-dc-short.sel   { border-color: var(--dn-bd); background: var(--dn-bg); }
.nb-dc-short.sel   .nb-dc-name { color: var(--dn); }

/* Toggle */
.nb-toggle-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; background: var(--bg4);
  border-radius: 11px; border: 1px solid var(--border);
  margin-bottom: 8px; cursor: pointer; transition: border-color .2s;
}
.nb-toggle-item:hover { border-color: var(--border2); }
.nb-ti-name { font-size: 13px; font-weight: 600; }
.nb-ti-desc { font-size: 11px; color: var(--muted); margin-top: 2px; line-height: 1.3; }
.nb-sw {
  width: 38px; height: 21px; border-radius: 11px;
  background: var(--bg5); border: 1px solid var(--border2);
  position: relative; cursor: pointer; flex-shrink: 0;
  transition: background .2s, border-color .2s;
}
.nb-sw.on { background: var(--up); border-color: var(--up); box-shadow: 0 0 8px rgba(61,186,133,.3); }
.nb-sw::after {
  content: ''; position: absolute;
  top: 2px; left: 2px; width: 15px; height: 15px;
  background: rgba(255,255,255,.5); border-radius: 50%; transition: left .2s, background .2s;
}
.nb-sw.on::after { left: 19px; background: #fff; }

/* Capital block */
.nb-capital-block {
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px; padding: 16px 18px;
  transition: border-color .2s, box-shadow .2s;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.02);
}
.nb-capital-block:focus-within { border-color: var(--up-bd); box-shadow: 0 0 0 3px rgba(61,186,133,.07); }
.nb-cap-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 9px; }
.nb-cap-lbl { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); }
.nb-cap-bal { font-size: 11px; font-family: 'IBM Plex Mono', monospace; color: var(--up); font-weight: 600; }
.nb-cap-bal span { color: var(--muted); font-weight: 400; }
.nb-cap-amount { display: flex; align-items: center; gap: 8px; margin-bottom: 11px; }
.nb-cap-amount input {
  background: transparent; border: none; color: var(--text);
  font-family: 'IBM Plex Mono', monospace; font-size: 22px; font-weight: 700;
  outline: none; flex: 1; min-width: 0; padding: 0;
}
.nb-cap-amount input::placeholder { color: var(--muted); }
.nb-cap-cur { font-size: 13px; font-weight: 700; color: var(--muted); font-family: 'IBM Plex Mono', monospace; flex-shrink: 0; }

.nb-cap-slider {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 5px; border-radius: 5px;
  background: var(--bg5); outline: none; cursor: pointer;
  border: none; padding: 0; display: block;
}
.nb-cap-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--up); cursor: pointer;
  box-shadow: 0 0 0 3px rgba(61,186,133,.2), 0 2px 6px rgba(0,0,0,.4);
  transition: box-shadow .2s, transform .1s;
}
.nb-cap-slider::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 5px rgba(61,186,133,.25), 0 2px 6px rgba(0,0,0,.4);
  transform: scale(1.1);
}
.nb-cap-slider::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--up); cursor: pointer; border: none;
  box-shadow: 0 0 0 3px rgba(61,186,133,.2);
}
.nb-slider-labels {
  display: flex; justify-content: space-between; margin-top: 6px;
}
.nb-slider-labels span { font-size: 10px; font-family: 'IBM Plex Mono', monospace; color: var(--muted); }
.nb-slider-pct { color: var(--up) !important; font-weight: 600 !important; }
.nb-pct-badges { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.nb-pct-btn {
  padding: 4px 10px; border-radius: 100px;
  border: 1px solid var(--border2); background: var(--bg5);
  font-size: 11px; font-weight: 700; color: var(--muted);
  font-family: 'IBM Plex Mono', monospace; cursor: pointer; transition: all .15s;
}
.nb-pct-btn:hover, .nb-pct-btn.active-pct { border-color: var(--up-bd); color: var(--up); background: var(--up-bg); }

/* Warning */
.nb-pv-warn {
  margin-top: 10px; min-height: 0;
  font-size: 12px; color: var(--dn);
  font-family: 'IBM Plex Mono', monospace;
  line-height: 1.4;
}

/* Create button */
.nb-create-btn {
  width: 100%; margin-top: 20px;
  padding: 15px; border: none; border-radius: 12px;
  background: linear-gradient(105deg, #3dba85 0%, #2fa874 100%);
  color: #fff; font-size: 15px; font-weight: 700;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 10px;
  position: relative; overflow: hidden;
  transition: opacity .2s, transform .1s;
  box-shadow: 0 4px 20px rgba(61,186,133,.22);
  font-family: inherit; letter-spacing: .01em;
}
.nb-create-btn::before {
  content: ''; position: absolute; top: 0; left: -100%; width: 200%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transition: left .55s;
}
.nb-create-btn:hover::before { left: 100%; }
.nb-create-btn:hover { opacity: .88; }
.nb-create-btn:active { transform: scale(.985); }

.nb-support-card {
  margin-top: 14px;
  padding: 15px 16px;
  border-radius: 16px;
  border: 1px solid rgba(42,171,238,.22);
  background:
    radial-gradient(circle at top left, rgba(42,171,238,.16), transparent 38%),
    linear-gradient(135deg, rgba(20,27,42,.96), rgba(14,19,31,.98));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03), 0 12px 30px rgba(6,13,24,.28);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  position: relative;
  overflow: hidden;
}

.nb-support-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(255,255,255,.05), transparent 35%);
  pointer-events: none;
}

.nb-support-copy,
.nb-support-link {
  position: relative;
  z-index: 1;
}

.nb-support-copy {
  min-width: 0;
}

.nb-support-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(42,171,238,.20);
  background: rgba(42,171,238,.10);
  color: #8fd8ff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.nb-support-icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2AABEE, #1f91df);
  color: #fff;
  box-shadow: 0 10px 20px rgba(42,171,238,.28);
  font-size: 12px;
}

.nb-support-title {
  margin-top: 10px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--text);
}

.nb-support-desc {
  margin-top: 4px;
  max-width: 560px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.nb-support-link {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 194px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(42,171,238,.28);
  background: linear-gradient(135deg, rgba(42,171,238,.24), rgba(42,171,238,.12));
  color: #eef8ff;
  text-decoration: none;
  font-size: 13px;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(42,171,238,.14);
  transition: transform .12s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
  white-space: nowrap;
}

.nb-support-link::before {
  content: '↗';
  opacity: .85;
  font-size: 13px;
}

.nb-support-link:hover {
  transform: translateY(-1px);
  border-color: rgba(42,171,238,.45);
  background: linear-gradient(135deg, rgba(42,171,238,.30), rgba(42,171,238,.16));
  box-shadow: 0 14px 30px rgba(42,171,238,.20);
}

/* ══════════════════════
   COL 3: Right panel
══════════════════════ */
.nb-right-panel { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 16px; }

.nb-r-card {
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.018)); border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px; padding: 18px; position: relative; overflow: hidden;
  box-shadow: 0 16px 36px rgba(0,0,0,.16);
}
.nb-r-card::before {
  content: ''; position: absolute;
  left: 0; top: 20%; bottom: 20%; width: 2px;
  background: var(--up); border-radius: 2px; opacity: .25;
}
.nb-r-title {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--muted); margin-bottom: 13px;
}
.nb-stat-list { display: flex; flex-direction: column; gap: 7px; }
.nb-stat-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 11px; background: var(--bg4); border-radius: 8px; border: 1px solid var(--border);
}
.nb-s-lbl { font-size: 11px; color: var(--muted); font-weight: 500; }
.nb-s-val { font-family: 'IBM Plex Mono', monospace; font-size: 13px; font-weight: 600; color: var(--up); }
.nb-s-val.neutral { color: var(--text); }

.nb-r-card-risk {
  padding: 0;
}
.nb-r-card-risk::before {
  display: none;
}
.nb-risk-block {
  padding: 18px;
}
.nb-risk-block .nb-r-title {
  margin-bottom: 12px;
}
.nb-risk-divider {
  height: 1px;
  margin: 0 18px;
  background: linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
}
.nb-risk-block-tips .nb-tip {
  font-size: 11px;
}

/* Grid visualizer */
.nb-grid-viz {
  position: relative; height: 178px; background: var(--bg4);
  border-radius: 10px; overflow: hidden; margin-top: 12px; border: 1px solid var(--border);
}
.nb-gz-line { position: absolute; left: 0; right: 0; height: 1px; background: rgba(255,255,255,.05); }
.nb-gz-cur  { background: rgba(61,186,133,.55) !important; height: 1.5px !important; box-shadow: 0 0 6px rgba(61,186,133,.35); }
.nb-gz-lbl  { position: absolute; right: 8px; font-family: 'IBM Plex Mono', monospace; font-size: 9px; font-weight: 600; padding: 2px 6px; border-radius: 4px; transform: translateY(-50%); }
.nb-gz-up   { color: var(--dn); background: var(--dn-bg); }
.nb-gz-mid  { color: var(--up); background: var(--up-bg); }
.nb-gz-dn   { color: var(--up); background: var(--up-bg); opacity: .7; }
.nb-gz-zone { position: absolute; left: 30px; right: 0; display: flex; align-items: center; padding-left: 6px; }
.nb-z-lbl   { font-size: 8px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; font-family: 'IBM Plex Mono', monospace; }
.nb-gz-sell .nb-z-lbl { color: rgba(217,92,110,.5); }
.nb-gz-buy  .nb-z-lbl { color: rgba(61,186,133,.5); }
.nb-gz-dot  {
  position: absolute; left: 13px; width: 13px; height: 13px;
  border-radius: 50%; background: var(--up);
  box-shadow: 0 0 10px rgba(61,186,133,.7);
  animation: nbPulse 2s ease infinite;
}
@keyframes nbPulse {
  0%,100% { box-shadow: 0 0 8px rgba(61,186,133,.6); }
  50%      { box-shadow: 0 0 18px rgba(61,186,133,.9); }
}

/* Minimum recommended */
.nb-minrec { overflow: hidden; border-radius: 10px; border: 1px solid var(--border2); }
.nb-minrec.st-ok   { border-color: rgba(61,186,133,.28);  background: rgba(61,186,133,.04); }
.nb-minrec.st-warn { border-color: rgba(245,166,35,.35);  background: rgba(245,166,35,.04); }
.nb-minrec.st-err  { border-color: rgba(217,92,110,.35);  background: rgba(217,92,110,.05);
  animation: nbShake .35s ease; }
@keyframes nbShake {
  0%,100% { transform: translateX(0); } 25% { transform: translateX(-3px); } 75% { transform: translateX(3px); }
}
.nb-mr-inner { display: flex; align-items: center; gap: 11px; padding: 12px 14px; }
.nb-mr-icon  { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 15px; flex-shrink: 0; }
.nb-minrec.st-ok   .nb-mr-icon { background: rgba(61,186,133,.14); }
.nb-minrec.st-warn .nb-mr-icon { background: rgba(245,166,35,.14); }
.nb-minrec.st-err  .nb-mr-icon { background: rgba(217,92,110,.14); }
.nb-mr-body { flex: 1; min-width: 0; }
.nb-mr-row  { display: flex; align-items: baseline; gap: 6px; }
.nb-mr-val  { font-family: 'IBM Plex Mono', monospace; font-size: 17px; font-weight: 700; transition: color .3s; }
.nb-mr-cur  { font-size: 11px; font-weight: 700; color: var(--muted); font-family: 'IBM Plex Mono', monospace; }
.nb-minrec.st-ok   .nb-mr-val { color: var(--up); }
.nb-minrec.st-warn .nb-mr-val { color: #f5a623; }
.nb-minrec.st-err  .nb-mr-val { color: var(--dn); }
.nb-mr-msg  { font-size: 11px; color: var(--muted); margin-top: 3px; line-height: 1.35; transition: color .3s; }
.nb-minrec.st-ok   .nb-mr-msg { color: rgba(61,186,133,.75); }
.nb-minrec.st-warn .nb-mr-msg { color: rgba(245,166,35,.85); }
.nb-minrec.st-err  .nb-mr-msg { color: rgba(217,92,110,.85); }
.nb-mr-breakdown { border-top: 1px solid var(--border); padding: 9px 14px; display: grid; grid-template-columns: repeat(3,1fr); gap: 5px; }
.nb-mrd      { display: flex; flex-direction: column; gap: 2px; text-align: center; }
.nb-mrd-lbl  { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); opacity: .7; }
.nb-mrd-val  { font-family: 'IBM Plex Mono', monospace; font-size: 11px; font-weight: 600; color: var(--text); }

/* Tips */
.nb-tips { display: flex; flex-direction: column; gap: 9px; }
.nb-tip  { display: flex; gap: 8px; align-items: flex-start; font-size: 12px; color: var(--muted); line-height: 1.45; }
.nb-tip span:first-child { font-size: 13px; flex-shrink: 0; margin-top: 1px; }

@media (min-width: 981px) {
  #nbGridLiqInlineBox { display: none; }
}

/* ── Responsive ── */
@media (max-width: 980px) {
  .nb-hero-panel {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .nb-topbar {
    flex-wrap: wrap;
  }
  .nb-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .nb-tab {
    min-height: 72px;
    padding: 11px 14px;
  }
  .nb-tab-main { font-size: 14px; }
  .nb-tab-meta { font-size: 11px; }
  .nb-split { grid-template-columns: 300px minmax(0, 1fr); }
  .nb-market-panel { display: flex; flex-direction: column; gap: 12px; }
  .nb-right-panel { display: none; }
  .nb-fg4 { grid-template-columns: 1fr 1fr; }
  .nb-support-card { flex-direction: column; align-items: stretch; }
  .nb-support-link { width: 100%; min-width: 0; }
}
@media (max-width: 720px) {
  #tab-bots.bots-page {
    padding-left: 0;
    padding-right: 0;
  }
  .nb-split { grid-template-columns: 1fr; }
  .nb-market-panel { display: none; }
  #botConfigView {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    padding-bottom: calc(124px + env(safe-area-inset-bottom, 0px));
  }
  .nb-form-col,
  .nb-bot-form {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }
  .nb-bot-form {
    border-left: 0;
    border-right: 0;
    border-radius: 0;
  }
  .nb-hero-panel {
    grid-template-columns: 1fr;
    margin-bottom: 12px;
    padding: 16px 12px;
    border-left: 0;
    border-right: 0;
    border-radius: 0;
  }
  .nb-topbar {
    margin-bottom: 0;
    gap: 12px;
  }
  .nb-back-btn { min-height: 36px; padding: 0 12px; font-size: 12px; }
  .nb-hero-copy { flex-basis: 100%; }
  .nb-hero-title { font-size: 24px; }
  .nb-hero-sub { font-size: 12px; }
  .nb-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    width: 100%;
    gap: 8px;
  }
  .nb-tab {
    min-width: 0;
    min-height: 58px;
    padding: 9px 10px;
    border-radius: 16px;
  }
  .nb-tab-kicker,
  .nb-tab-meta { display: none; }
  .nb-tab-main {
    width: 100%;
    justify-content: center;
    gap: 8px;
    font-size: 12px;
    text-align: center;
  }
  .nb-dot {
    width: 7px;
    height: 7px;
  }
  .nb-fg4, .nb-fg3, .nb-fg2 { grid-template-columns: 1fr 1fr; }
  .nb-form-header { flex-direction: column; align-items: stretch; }
  .nb-help-btn { align-self: flex-start; }
  .nb-form-header,
  .nb-form-body { padding-left: 18px; padding-right: 18px; }
  .nb-support-card { padding: 14px; }
  .nb-support-title { font-size: 14px; }
  .nb-support-desc { font-size: 11px; }
}

@media (max-width: 920px) {
  #tab-bots.bots-page {
    padding-bottom: calc(92px + env(safe-area-inset-bottom, 0px));
  }
}

/* ═══════════════════════════════════════════
   PER-BOT color overrides — Martingala (red) & Gridmart (purple)
   ═══════════════════════════════════════════ */

/* ── Martingala ── */
#martingaleForm .nb-bot-form::before,
#martingaleForm.nb-bot-form::before {
  background: linear-gradient(90deg, var(--dn), rgba(217,92,110,.06));
}
#martingaleForm .nb-ico {
  background: rgba(217,92,110,.1);
  border-color: rgba(217,92,110,.25);
  color: var(--dn);
}
#martingaleForm .nb-how-box {
  background: rgba(217,92,110,.05);
  border-color: rgba(217,92,110,.2);
}
#martingaleForm .nb-capital-block:focus-within {
  border-color: rgba(217,92,110,.35);
  box-shadow: 0 0 0 3px rgba(217,92,110,.06);
}
#martingaleForm .nb-cap-slider::-webkit-slider-thumb {
  background: var(--dn);
  box-shadow: 0 0 0 3px rgba(217,92,110,.2), 0 2px 6px rgba(0,0,0,.4);
}
#martingaleForm .nb-cap-slider::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 5px rgba(217,92,110,.25), 0 2px 6px rgba(0,0,0,.4);
}
#martingaleForm .nb-cap-slider::-moz-range-thumb { background: var(--dn); }
#martingaleForm .nb-slider-pct { color: var(--dn) !important; }
#martingaleForm .nb-pct-btn:hover,
#martingaleForm .nb-pct-btn.active-pct {
  border-color: rgba(217,92,110,.35);
  color: var(--dn);
  background: rgba(217,92,110,.1);
}
#martingaleForm .nb-r-card::before { background: var(--dn); }

/* ── Gridmart ── */
#gridIncForm .nb-bot-form::before,
#gridIncForm.nb-bot-form::before {
  background: linear-gradient(90deg, var(--purple), rgba(146,120,224,.06));
}
#gridIncForm .nb-ico {
  background: rgba(146,120,224,.1);
  border-color: rgba(146,120,224,.25);
  color: var(--purple);
}
#gridIncForm .nb-how-box {
  background: rgba(146,120,224,.05);
  border-color: rgba(146,120,224,.2);
}
#gridIncForm .nb-capital-block:focus-within {
  border-color: rgba(146,120,224,.35);
  box-shadow: 0 0 0 3px rgba(146,120,224,.06);
}
#gridIncForm .nb-cap-slider::-webkit-slider-thumb {
  background: var(--purple);
  box-shadow: 0 0 0 3px rgba(146,120,224,.2), 0 2px 6px rgba(0,0,0,.4);
}
#gridIncForm .nb-cap-slider::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 5px rgba(146,120,224,.25), 0 2px 6px rgba(0,0,0,.4);
}
#gridIncForm .nb-cap-slider::-moz-range-thumb { background: var(--purple); }
#gridIncForm .nb-slider-pct { color: var(--purple) !important; }
#gridIncForm .nb-pct-btn:hover,
#gridIncForm .nb-pct-btn.active-pct {
  border-color: rgba(146,120,224,.35);
  color: var(--purple);
  background: rgba(146,120,224,.1);
}

/* ── Direction cards: Long/Short only (no Neutral) for mart & gridmart ── */
#martingaleForm .nb-dir-side-long.sel,
#gridIncForm    .nb-dir-side-long.sel  {
  border-color: var(--up-bd); background: var(--up-bg);
}
#martingaleForm .nb-dir-side-long.sel .nb-dc-name,
#gridIncForm    .nb-dir-side-long.sel .nb-dc-name  { color: var(--up); }
#martingaleForm .nb-dir-side-short.sel,
#gridIncForm    .nb-dir-side-short.sel {
  border-color: var(--dn-bd); background: var(--dn-bg);
}
#martingaleForm .nb-dir-side-short.sel .nb-dc-name,
#gridIncForm    .nb-dir-side-short.sel .nb-dc-name { color: var(--dn); }

/* Shared internal top-left nav buttons — exact same feel as top tabs */
.btn-topnav {
  border: none;
  background: transparent;
  color: var(--muted);
  padding: 11px 14px;
  cursor: pointer;
  font-family: var(--ff-body);
  font-weight: 500;
  font-size: 12.5px;
  border-bottom: 2px solid transparent;
  transition: background .15s, color .15s, border-color .15s, opacity .15s;
  white-space: nowrap;
  flex-shrink: 0;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.btn-topnav:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.03);
  transform: none;
}
.btn-topnav:active {
  transform: none;
}

/* ═══════════════════════════════════════════════════════════════
   LEADERBOARD TAB
   ═══════════════════════════════════════════════════════════════ */
.lb-shell { padding: 14px 14px 24px; max-width: 1400px; margin: 0 auto; }
.lb-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:16px; flex-wrap:wrap; }
.lb-header-left { display:flex; flex-direction:column; gap:3px; }
.lb-title { font-family:var(--ff-display); font-size:17px; font-weight:700; letter-spacing:-.01em; display:flex; align-items:center; gap:8px; }
.lb-sub { font-size:10.5px; color:var(--muted); font-family:var(--ff-mono); letter-spacing:.02em; }
.lb-refresh-btn { align-self:flex-start; }
.lb-controls { display:flex; align-items:flex-end; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.lb-ctrl-group { display:flex; align-items:center; gap:8px; }
.lb-ctrl-group-select {
  gap:4px;
  flex-direction:column;
  align-items:flex-start;
}
.lb-ctrl-label {
  font-size:8.5px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--muted);
  font-family:var(--ff-mono);
  white-space:nowrap;
  padding-left:2px;
}
.lb-select {
  min-width: 156px;
  height: 30px;
  padding: 0 30px 0 10px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(9,11,16,.72);
  color: var(--text);
  font-size: 11px;
  font-weight: 600;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position: calc(100% - 15px) calc(50% - 2px), calc(100% - 10px) calc(50% - 2px);
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
}
.lb-select:hover { border-color: rgba(255,255,255,.12); background-color: rgba(15,18,26,.84); }
.lb-select:focus { border-color: rgba(108,141,255,.55); box-shadow: 0 0 0 2px rgba(108,141,255,.10); }
.lb-select option { background: #14161b; color: var(--text); }
.lb-live-badge { display:inline-flex; align-items:center; gap:6px; background:var(--up-bg); border:1px solid var(--up-bd); border-radius:20px; padding:3px 10px 3px 8px; font-family:var(--ff-mono); font-size:10px; color:var(--up); font-weight:600; }
.lb-live-dot { width:6px; height:6px; border-radius:50%; background:var(--up); animation:badge-glow 2.5s ease infinite; flex-shrink:0; }
.lb-kpi-row { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:14px; }
@media (max-width:700px){ .lb-kpi-row { grid-template-columns:repeat(2,1fr); } .lb-ctrl-group-select { width:100%; } .lb-select { min-width: 0; width: 100%; } }
.lb-kpi { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:10px 12px; }
.lb-kpi-lbl { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:9px; font-weight:500; text-transform:uppercase; letter-spacing:.1em; color:var(--dim); margin-bottom:4px; }
.lb-kpi-val { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:18px; font-weight:600; letter-spacing:-.02em; color:var(--text); font-variant-numeric:tabular-nums; }
.lb-kpi-val.good { color:var(--up); } .lb-kpi-val.bad { color:var(--dn); }
.lb-table-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r2); overflow:hidden; }
.lb-thead, .lb-row { display:grid; grid-template-columns:46px 1.15fr 1fr 96px 112px 112px 104px 102px 94px; padding:0 12px; }
.lb-thead { background:var(--bg4); border-bottom:1px solid var(--border2); }
.lb-th { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:8.5px; font-weight:600; text-transform:uppercase; letter-spacing:.1em; color:var(--dim); padding:8px 8px; display:flex; align-items:center; }
.lb-row { border-bottom:1px solid var(--border); align-items:center; transition:background .14s; min-height:52px; }
.lb-row:last-child { border-bottom:none; } .lb-row:hover { background:var(--bg4); }
.lb-cell-rank { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:11px; font-weight:700; color:var(--dim); padding:6px; }
.lb-cell-rank.top3 { color:var(--warn); } .lb-cell-rank.top1 { color:#f5c842; }
.lb-cell-bot { padding:6px; display:flex; flex-direction:column; gap:4px; }
.lb-bot-top { display:flex; align-items:center; gap:6px; }
.lb-asset { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:13px; font-weight:700; letter-spacing:-.01em; color:var(--text); }
.lb-bot-type { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:8.5px; font-weight:500; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-top:1px; }
.lb-dir { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:8px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; padding:2px 6px; border-radius:4px; flex-shrink:0; }
.lb-dir.long { background:var(--up-bg); color:var(--up); border:1px solid var(--up-bd); }
.lb-dir.short { background:var(--dn-bg); color:var(--dn); border:1px solid var(--dn-bd); }
.lb-dir.neutral { background:var(--acc-bg); color:var(--accent); border:1px solid var(--acc-bd); }
.lb-cell-cfg { padding:6px; display:flex; flex-wrap:wrap; gap:3px; }
.lb-cfg-chip { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:8px; color:var(--muted); background:var(--bg5); border:1px solid var(--border); border-radius:4px; padding:2px 6px; white-space:nowrap; }
.lb-cfg-chip span { color:var(--text); }
.lb-cell-num { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:12px; font-weight:600; font-variant-numeric:tabular-nums; padding:6px 8px; color:var(--text); white-space:nowrap; }
.lb-cell-num.good { color:var(--up); } .lb-cell-num.bad { color:var(--dn); } .lb-cell-num.muted { color:var(--muted); font-weight:400; }
.lb-substat { font-size:10px; line-height:1.2; opacity:.9; margin-top:2px; font-weight:500; }
.lb-roi-wrap { display:flex; flex-direction:column; gap:3px; padding:6px 8px; min-width:0; }
.lb-roi-val { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:12px; font-weight:600; font-variant-numeric:tabular-nums; }
.lb-roi-val.good { color:var(--up); } .lb-roi-val.bad { color:var(--dn); }
.lb-roi-bar-track { height:3px; background:var(--bg5); border-radius:2px; overflow:hidden; width:100%; }
.lb-roi-bar-fill { height:100%; border-radius:2px; transition:width .6s cubic-bezier(.4,0,.2,1); }
.lb-roi-bar-fill.good { background:linear-gradient(90deg,var(--up), rgba(61,186,133,.3)); }
.lb-roi-bar-fill.bad { background:linear-gradient(90deg,var(--dn), rgba(217,92,110,.3)); }
.lb-cell-uptime { font-family:var(--ff-ibm,'IBM Plex Mono',monospace); font-size:10px; color:var(--muted); padding:6px 18px 6px 18px; white-space:nowrap; text-align:left; }
.lb-mobile-meta { display:none; margin-top:6px; gap:6px; flex-wrap:wrap; }
.lb-mobile-chip { display:inline-flex; align-items:center; gap:4px; padding:3px 7px; border-radius:999px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06); color:var(--muted); font-size:10px; line-height:1.2; }
.lb-mobile-chip b { color:var(--text); font-weight:700; }
.lb-empty { display:flex; flex-direction:column; align-items:center; gap:10px; padding:48px 24px; color:var(--dim); font-size:12px; font-family:var(--ff-mono); }
.lb-loading { padding:12px 10px; display:flex; flex-direction:column; gap:6px; }
.lb-skel-row { height:50px; border-radius:6px; background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%); background-size:400px 100%; animation:shimmer 1.4s infinite; }
.lb-th-copy { width:94px; } .lb-cell-copy { padding:5px; display:flex; align-items:center; }
.lb-copy-btn { display:inline-flex; align-items:center; gap:5px; font-family:var(--ff-ibm); font-size:9px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; padding:5px 10px; border-radius:6px; cursor:pointer; border:1px solid var(--acc-bd); background:var(--acc-bg); color:var(--accent); transition:all .16s; white-space:nowrap; }
.lb-copy-btn:hover { background:rgba(108,141,255,.18); border-color:rgba(108,141,255,.4); box-shadow:0 0 12px rgba(108,141,255,.12); transform:translateY(-1px); }
.lb-copy-btn:active { transform:scale(.95); }
@media (max-width:900px){ .lb-thead, .lb-row { grid-template-columns:38px 1.15fr 98px 92px 100px 92px; } .lb-th-cfg,.lb-cell-cfg,.lb-th-aum,.lb-cell-aum,.lb-th-uptime,.lb-cell-uptime { display:none; } .lb-mobile-meta { display:flex; } }
@media (max-width:600px){ .lb-thead, .lb-row { grid-template-columns:32px 1fr 76px 88px; } .lb-th-cfg,.lb-cell-cfg,.lb-th-aum,.lb-cell-aum,.lb-th-pnl,.lb-cell-ppnl,.lb-th-apr,.lb-cell-apr,.lb-th-uptime,.lb-cell-uptime { display:none; } .lb-mobile-meta { display:flex; } }
@media (max-width:760px){
  .lb-shell { padding: 12px 10px 22px; }
  .lb-header { gap: 10px; margin-bottom: 12px; }
  .lb-refresh-btn { width: 100%; justify-content: center; }
  .lb-controls { gap: 8px; }
  .lb-ctrl-group { width: 100%; }
  .lb-ctrl-group .pill-group { width: 100%; flex-wrap: wrap; }
  .lb-ctrl-group .pill-group .lang-btn { flex: 1 1 auto; min-width: 0; }
  .lb-live-badge { width: 100%; justify-content: center; }
  .lb-kpi-row { gap: 6px; }
  .lb-kpi { padding: 9px 10px; }
  .lb-kpi-val { font-size: 16px; }

  .lb-table-wrap { background: transparent; border: 0; overflow: visible; }
  .lb-thead { display: none; }
  #lbRows { display: flex; flex-direction: column; gap: 10px; }
  .lb-row {
    display: flex;
    flex-direction: column;
    grid-template-columns: none;
    min-height: 0;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--bg2);
    position: relative;
  }
  .lb-row:hover { background: var(--bg2); }
  .lb-cell-rank {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 0;
    font-size: 10px;
    line-height: 1;
  }
  .lb-cell-bot { padding: 0 54px 0 0; gap: 7px; }
  .lb-bot-top { flex-wrap: wrap; gap: 7px; }
  .lb-asset { font-size: 15px; }
  .lb-bot-type { font-size: 9.5px; }
  .lb-mobile-meta { display: flex; gap: 6px; }
  .lb-mobile-chip { font-size: 9.5px; }

  .lb-cell-cfg, .lb-cell-aum, .lb-cell-apr, .lb-cell-uptime { display: none !important; }

  .lb-cell-ppnl, .lb-roi-wrap {
    width: 100%;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }
  .lb-cell-ppnl::before, .lb-roi-wrap::before {
    font-family: var(--ff-ibm,'IBM Plex Mono',monospace);
    font-size: 9px;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--dim);
    flex-shrink: 0;
  }
  .lb-cell-ppnl::before { content: 'PnL'; }
  .lb-roi-wrap::before { content: 'ROI'; }
  .lb-roi-wrap .lb-roi-val { margin-left: auto; text-align: right; }
  .lb-roi-wrap .lb-roi-bar-track { width: 42%; min-width: 84px; }

  .lb-cell-copy { padding: 0; width: 100%; }
  .lb-copy-btn {
    width: 100%;
    justify-content: center;
    min-height: 40px;
    padding: 10px 12px;
    font-size: 10.5px;
    border-radius: 9px;
  }
}
.modal-overlay { position:fixed; inset:0; z-index:400; background:rgba(0,0,0,.72); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .2s; padding:16px; overflow-y:auto; -webkit-overflow-scrolling:touch; }
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal-box { background:var(--bg3); border:1px solid var(--acc-bd); border-radius:var(--r2); padding:24px 22px 20px; width:min(390px,94vw); max-height:calc(100vh - 40px); max-height:calc(100dvh - 40px); overflow:auto; -webkit-overflow-scrolling:touch; box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 0 1px rgba(108,141,255,.06); transform:translateY(12px) scale(.97); transition:transform .22s cubic-bezier(.34,1.56,.64,1); }
.modal-overlay.open .modal-box { transform:translateY(0) scale(1); }
.modal-icon { width:38px; height:38px; border-radius:10px; background:var(--acc-bg); border:1px solid var(--acc-bd); display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.modal-title { font-family:var(--ff-display); font-size:15px; font-weight:700; margin-bottom:5px; }
.modal-sub { font-size:11px; color:var(--muted); margin-bottom:16px; line-height:1.55; }
.modal-params { background:var(--bg4); border:1px solid var(--border); border-radius:var(--r); padding:11px 13px; margin-bottom:14px; display:flex; flex-direction:column; gap:7px; }
.modal-param-row { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.modal-param-key { font-family:var(--ff-ibm); font-size:9.5px; text-transform:uppercase; letter-spacing:.08em; color:var(--dim); }
.modal-param-val { font-family:var(--ff-ibm); font-size:11px; font-weight:600; color:var(--text); }
.modal-param-val.good { color:var(--up); } .modal-param-val.bad { color:var(--dn); } .modal-param-val.acc { color:var(--accent); }
.modal-note { display:flex; gap:8px; align-items:flex-start; background:var(--warn-bg); border:1px solid var(--warn-bd); border-radius:var(--r); padding:9px 11px; margin-bottom:16px; font-size:10.5px; color:rgba(255,255,255,.65); line-height:1.5; }
.modal-actions { display:flex; gap:8px; }
.btn-modal-go { flex:1; border:none; cursor:pointer; background:linear-gradient(105deg,#5a7bef,var(--accent)); color:#fff; font-family:var(--ff-ibm); font-size:11px; font-weight:600; letter-spacing:.04em; padding:9px 16px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; gap:6px; transition:opacity .15s,transform .15s; }
.btn-modal-go:hover { opacity:.88; transform:translateY(-1px); } .btn-modal-go:active { transform:scale(.97); }
.btn-modal-cancel { border:1px solid var(--border2); background:var(--bg5); color:var(--muted); font-family:var(--ff-ibm); font-size:11px; padding:9px 16px; border-radius:var(--r); cursor:pointer; transition:all .15s; }
.btn-modal-cancel:hover { color:var(--text); border-color:rgba(255,255,255,.2); }
@media (max-width:560px){
  .modal-overlay { align-items:flex-start; padding:12px 10px max(12px, env(safe-area-inset-bottom, 0px)); }
  .modal-box { width:100%; max-height:calc(100vh - 24px); max-height:calc(100dvh - 24px); padding:18px 14px 14px; }
  .modal-actions { flex-direction:column-reverse; }
  .btn-modal-go, .btn-modal-cancel { width:100%; justify-content:center; }
}

/* ════════════════════════════════════════════════════════
   BOT DETAIL MODAL — Mobile hardening
   ════════════════════════════════════════════════════════ */
#mlbBotModal > .bot-detail-modal-card {
  box-sizing: border-box;
}

@media (max-width:560px){
  #mlbBotModal {
    align-items: stretch !important;
    justify-content: stretch !important;
    padding: 0 !important;
  }

  #mlbBotModal > .bot-detail-modal-card {
    width: 100vw !important;
    max-width: none !important;
    height: 100dvh;
    max-height: 100dvh !important;
    border-radius: 0 !important;
    border-left: 0 !important;
    border-right: 0 !important;
    padding: 14px 12px calc(18px + env(safe-area-inset-bottom, 0px)) !important;
    overflow-x: hidden !important;
  }

  #mlbBotModal .bot-detail-head {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  #mlbBotModal .bot-detail-head-actions {
    width: 100%;
    justify-content: flex-start !important;
  }

  #mlbBotModal .bot-detail-head-actions .btn {
    flex: 1 1 calc(50% - 4px);
    min-width: 0;
    justify-content: center;
  }

  #mlbBotModal .bot-detail-head-actions #btnBotDetailClose {
    flex: 0 0 46px;
    width: 46px !important;
    min-width: 46px !important;
    margin-left: auto;
  }

  #mlbBotModal .bot-detail-summary-grid,
  #mlbBotModal .bot-detail-main-grid,
  #mlbBotModal .bot-detail-config-grid,
  #mlbBotModal .pend-cols {
    grid-template-columns: 1fr !important;
  }

  #mlbBotModal .bot-detail-config-grid > div {
    flex-wrap: wrap;
    gap: 6px !important;
  }

  #mlbBotModal .bot-detail-config-grid > div b {
    width: 100%;
    text-align: left;
  }

  #mlbBotModal .bot-detail-risk-head,
  #mlbBotModal .pend-head {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 8px;
  }

  #mlbBotModal .bot-detail-risk-chips {
    width: 100%;
    justify-content: flex-start !important;
  }

  #mlbBotModal .bot-detail-risk-inputs {
    grid-template-columns: 1fr !important;
  }

  #mlbBotModal .bot-detail-save-risk-row,
  #mlbBotModal .bot-detail-margin-row,
  #mlbBotModal .bot-detail-invest-row {
    flex-direction: column;
    align-items: stretch;
  }

  #mlbBotModal .bot-detail-save-risk-row .btn,
  #mlbBotModal .bot-detail-margin-row .btn,
  #mlbBotModal .bot-detail-invest-row .btn,
  #mlbBotModal .bot-detail-save-risk-row .msg,
  #mlbBotModal .bot-detail-margin-row .msg,
  #mlbBotModal .bot-detail-invest-row .msg,
  #mlbBotModal #botAddMargin,
  #mlbBotModal #botAddCapital {
    width: 100%;
    max-width: none !important;
  }

  #mlbBotModal .pend-col-head {
    grid-template-columns: 1fr 64px 56px;
  }

  #mlbBotModal .pend-row {
    grid-template-columns: 20px 1fr 64px 56px;
  }

  #mlbBotModal .bot-detail-trades-wrap {
    max-width: 100%;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  #mlbBotModal .tp-table {
    min-width: 640px !important;
  }
}

/* ════════════════════════════════════════════════════════
   TOPBAR + BOTTOM NAV — Unified nav styles (nav-component.js)
   Single source of truth — DO NOT duplicate in page <style> blocks
   ════════════════════════════════════════════════════════ */

/* ── Topbar ── */
.topbar {
  height: 50px;
  background: rgba(7,7,11,0.96);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 200;
}

/* ── Logo ── */
.tb-logo {
  flex-shrink: 0;
  padding: 0 18px;
  border-right: 1px solid var(--border);
  height: 100%;
  display: flex;
  align-items: center;
  gap: 9px;
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .01em;
  text-decoration: none;
  color: var(--text);
}
.tb-logo-mark {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(--bg4);
  border: 1px solid var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}
.tb-logo-icon {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  display: block;
  object-fit: cover;
}

/* ── Nav items ── */
.tb-nav {
  display: flex;
  align-items: center;
  gap: 1px;
  padding: 0 10px;
  flex: 1;
  overflow: hidden;
}
.tb-nav-item {
  padding: 6px 13px;
  border-radius: 7px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--muted);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s, opacity .15s;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
  font-family: var(--ff-body);
}
.tb-nav-item:hover { color: var(--text); background: rgba(255,255,255,0.04); }
.tb-nav-item.active { color: var(--text); background: var(--bg4); }
.tb-nav-item svg { opacity: .5; flex-shrink: 0; }
.tb-nav-item.active svg { opacity: .85; }

/* ── Right side ── */
.tb-right {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  margin-left: auto;
  flex-shrink: 0;
}

/* ── Buttons ── */
.tb-btn {
  padding: 5px 13px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 600;
  border: 1px solid var(--border2);
  background: var(--bg3);
  color: var(--text);
  cursor: pointer;
  font-family: var(--ff-body);
  transition: background .15s, color .15s, border-color .15s, opacity .15s;
  white-space: nowrap;
}
.tb-btn:hover { background: var(--bg4); }
.tb-btn.active { background: var(--bg5); }
.tb-btn-login {
  padding: 5px 13px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 600;
  border: 1px solid var(--up-bd);
  background: var(--up-bg);
  color: var(--up);
  cursor: pointer;
  font-family: var(--ff-body);
  transition: background .15s, color .15s, border-color .15s, opacity .15s;
  white-space: nowrap;
}
.tb-btn-login:hover { background: rgba(61,186,133,0.16); }
.tb-btn-lang-nav { min-width: 40px; padding: 5px 10px; font-weight: 700; }
.tb-btn-menu { display:none; min-width:36px; padding:5px 10px; font-size:16px; line-height:1; }
.tb-mobile-menu { display:none; position:relative; }
.tb-mobile-menu summary { list-style:none; }
.tb-mobile-menu summary::-webkit-details-marker { display:none; }
.tb-mobile-menu-panel { position:absolute; top:calc(100% + 8px); right:0; min-width:190px; display:flex; flex-direction:column; gap:6px; padding:10px; background:rgba(7,7,11,.98); border:1px solid var(--border); border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,.28); }
.tb-mobile-link { display:flex; align-items:center; min-height:38px; padding:8px 10px; border-radius:9px; color:var(--text); text-decoration:none; background:rgba(255,255,255,.02); }
.tb-mobile-link:hover { background:rgba(255,255,255,.05); }

/* ── Lang toggle ── */
.tb-lang {
  display: flex;
  gap: 0;
  border: 1px solid var(--border2);
  border-radius: 10px;
  overflow: hidden;
}
.tb-lang .tb-btn {
  border: none;
  border-radius: 0;
  padding: 4px 10px;
  font-size: 11.5px;
}

/* ── Wallet tag ── */
.wallet-tag {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 4px 12px 4px 10px;
  font-family: var(--ff-mono);
  font-size: 11.5px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 7px;
}
.w-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--up);
  box-shadow: 0 0 6px var(--up);
}

/* ── Bottom nav (mobile) ── */
.bottom-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: calc(60px + env(safe-area-inset-bottom, 0px));
  background: rgba(7,7,11,0.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--border);
  z-index: 1000;
  padding-bottom: max(6px, env(safe-area-inset-bottom, 0px));
}
.bn-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 6px 2px 4px;
  cursor: pointer;
  color: var(--muted);
  transition: color .15s;
  border: none;
  background: transparent;
  font-family: var(--ff-body);
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  position: relative;
}
.bn-item::after {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 2px;
  background: var(--up);
  border-radius: 0 0 3px 3px;
  transition: width .2s ease;
}
.bn-item.active::after { width: 28px; }
.bn-item:hover { color: var(--text); }
.bn-item.active { color: var(--up); }
.bn-icon { width: 20px; height: 20px; opacity: .55; transition: opacity .15s; }
.bn-item.active .bn-icon { opacity: 1; }
.bn-label { font-size: 9px; font-weight: 500; letter-spacing: .01em; }

/* ── Responsive ── */
@media (max-width: 920px) {
  .topbar { padding: 0 12px; }
  .topbar .tb-nav { display: none !important; }
  .tb-logo { border-right: 1px solid var(--border); padding: 0 14px 0 0; }
  .tb-right { gap: 6px; padding: 0 0 0 10px; }
  .tb-btn-menu, .tb-mobile-menu { display: block; }
  #btnRefreshNav { display: none !important; }
  .bottom-nav { display: flex; justify-content: space-around; align-items: center; }
  /* Ensure page content doesn't hide behind bottom nav */
  body { padding-bottom: calc(66px + env(safe-area-inset-bottom, 0px)); }
}

@media (max-width: 700px) {
  .cuenta-card-input-row { flex-direction: column; align-items: stretch; }
  .cuenta-card-input-row > * { width: 100%; }
}

@media (max-width: 560px) {
  .wallet-tag { max-width: 31vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; padding: 4px 9px 4px 8px; }
  .tb-btn, .tb-btn-login { padding: 5px 8px; font-size: 11px; }
  .bn-label { font-size: 8px; }
}

/* ── Topbar button variants ── */
.tb-btn-danger { color: var(--dn) !important; border-color: var(--dn-bd) !important; }
.tb-btn-danger:hover { background: var(--dn-bg) !important; }
.tb-btn-icon { min-width: 32px; padding: 5px 8px; font-size: 14px; }

/* ── Login button in app topbar (primary CTA, consistent en todas las páginas) ── */
.tb-btn-login-nav {
  background: var(--up-bg);
  border-color: var(--up-bd);
  color: var(--up);
  font-weight: 600;
}
.tb-btn-login-nav:hover {
  background: rgba(61, 186, 133, 0.16);
  border-color: var(--up);
}

.lb-th-rpnl, .lb-cell-rpnl { display:none !important; }

.lb-th-uptime { justify-content:flex-start; padding-left:18px !important; }


@media (max-width: 920px) {
  .topbar {
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
}

@media (hover: none) {
  .tb-nav-item:hover,
  .tab:hover,
  .bn-item:hover,
  .btn-topnav:hover {
    background: transparent;
  }
}

@media (max-width: 980px) {
  .cuenta-profile-strip {
    flex-direction: column;
    align-items: stretch;
    position: relative;
    padding-top: 42px;
  }
  .cuenta-profile-actions {
    justify-content: flex-start;
  }
}
/* Grid recommendation assistant (novice opt-in) */
.nb-reco-inline { margin: 8px 0 10px; }
.nb-reco-btn {
  border:1px solid var(--acc-bd); background:var(--acc-bg); color:var(--accent);}
.nb-reco-btn {
  border:1px solid var(--acc-bd); background:var(--acc-bg); color:var(--accent);
  border-radius:8px; padding:6px 10px; font-size:12px; font-weight:600; cursor:pointer;
}
.nb-reco-panel { border:none; background:transparent; border-radius:0; padding:0; margin: 4px 0 12px; }
.nb-reco-head { display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px; }
.nb-reco-title { font-size:12px; font-weight:700; }
.nb-reco-tf { display:flex; gap:6px; }
.nb-reco-tf-btn { border:1px solid var(--border2); background:var(--bg5); color:var(--muted); border-radius:6px; padding:3px 8px; font-size:11px; cursor:pointer; }
.nb-reco-tf-btn.active { border-color: var(--acc-bd); color: var(--accent); background: var(--acc-bg); }
.nb-reco-meta { font-size:11px; color:var(--muted); margin-bottom:8px; }
.nb-reco-cards { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:8px; }
.nb-reco-card { border:1px solid var(--border2); background:var(--bg5); border-radius:8px; padding:8px; display:flex; flex-direction:column; }
.nb-reco-card h4 { margin:0 0 4px; font-size:12px; }
.nb-reco-row { font-size:11px; color:var(--muted); margin:2px 0; }
.nb-reco-apply { margin-top:auto; width:100%; border:1px solid var(--acc-bd); background:var(--acc-bg); color:var(--accent); border-radius:6px; padding:5px 8px; font-size:11px; font-weight:700; cursor:pointer; }
.nb-reco-warnings { margin-top:8px; font-size:11px; color:#ffb84d; line-height:1.4; }

.nb-sim-slot { display:flex; flex-direction:column; gap:12px; }
.nb-sim-slot:empty { display:none; }
.nb-sim-slot-mobile { margin-top:14px; }

.nb-sim-panel { position:relative; overflow:hidden; border:1px solid var(--acc-bd); background:linear-gradient(180deg, rgba(77,159,255,.10), rgba(255,255,255,.02) 28%, rgba(255,255,255,.01)); border-radius:14px; padding:14px; margin: 0 0 16px; box-shadow:0 14px 34px rgba(0,0,0,.22); }
.nb-sim-panel::before { content:''; position:absolute; inset:0 0 auto 0; height:2px; background:linear-gradient(90deg, var(--accent), rgba(77,159,255,0)); opacity:.95; }
.nb-sim-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:12px; }
.nb-sim-copy { min-width:0; }
.nb-sim-topline { display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; margin-bottom:7px; }
.nb-sim-badge { display:inline-flex; align-items:center; gap:6px; border:1px solid var(--acc-bd); background:var(--acc-bg); color:var(--accent); border-radius:999px; padding:5px 10px; font-size:10px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; }
.nb-sim-doc-link { display:inline-flex; align-items:center; gap:6px; color:var(--text); text-decoration:none; font-size:11px; font-weight:700; border:1px solid var(--border2); background:rgba(255,255,255,.03); border-radius:999px; padding:5px 10px; }
.nb-sim-doc-link:hover { border-color:var(--acc-bd); color:var(--accent); background:var(--acc-bg); }
.nb-sim-title { font-size:15px; font-weight:800; color:var(--text); }
.nb-sim-sub { margin-top:5px; font-size:12px; color:var(--text); line-height:1.45; max-width:62ch; }
.nb-sim-tf { display:flex; gap:6px; flex-wrap:wrap; }
.nb-sim-tf-btn { border:1px solid var(--border2); background:var(--bg5); color:var(--muted); border-radius:7px; padding:4px 8px; font-size:11px; cursor:pointer; }
.nb-sim-tf-btn.active { border-color: var(--acc-bd); color: var(--accent); background: var(--acc-bg); }
.nb-sim-meta { font-size:11px; color:var(--muted); line-height:1.45; margin-bottom:10px; }
.nb-sim-summary { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:8px; margin-bottom:10px; }
.nb-sim-kpi { border:1px solid var(--border2); background:var(--bg5); border-radius:10px; padding:9px 10px; min-width:0; }
.nb-sim-k { font-size:9px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
.nb-sim-v { font-family: var(--ff-ibm, 'IBM Plex Mono', monospace); font-size:14px; font-weight:700; color:var(--text); overflow-wrap:anywhere; }
.nb-sim-v.good { color: var(--up); }
.nb-sim-v.bad { color: var(--dn); }
.nb-sim-v.warn { color: #ffb84d; }
.nb-sim-diag { border:1px solid var(--border2); background:var(--bg5); border-radius:10px; padding:10px; margin-bottom:10px; }
.nb-sim-diag-tag { display:inline-flex; align-items:center; gap:6px; border-radius:999px; padding:4px 10px; font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-bottom:6px; }
.nb-sim-diag-tag.healthy { background:var(--up-bg); color:var(--up); border:1px solid var(--up-bd); }
.nb-sim-diag-tag.weak { background:rgba(245,166,35,.12); color:#ffb84d; border:1px solid rgba(245,166,35,.24); }
.nb-sim-diag-tag.aggressive,
.nb-sim-diag-tag.liquidated { background:var(--dn-bg); color:var(--dn); border:1px solid var(--dn-bd); }
.nb-sim-diag-tag.incomplete { background:rgba(255,255,255,.05); color:var(--muted); border:1px solid var(--border2); }
.nb-sim-diag-copy { font-size:12px; color:var(--text); line-height:1.45; }
.nb-sim-warnings { font-size:11px; color:#ffb84d; line-height:1.45; display:flex; flex-direction:column; gap:4px; }

.nb-sim-panel.is-compact { margin:0; padding:12px; box-shadow:0 10px 24px rgba(0,0,0,.18); }
.nb-sim-panel.is-compact .nb-sim-head { flex-direction:column; align-items:stretch; gap:10px; }
.nb-sim-panel.is-compact .nb-sim-topline { align-items:flex-start; }
.nb-sim-panel.is-compact .nb-sim-title { font-size:14px; }
.nb-sim-panel.is-compact .nb-sim-sub { font-size:11px; max-width:none; }
.nb-sim-panel.is-compact .nb-sim-summary { grid-template-columns: 1fr 1fr; }
.nb-sim-panel.is-compact .nb-sim-kpi { padding:8px 9px; }
.nb-sim-panel.is-compact .nb-sim-v { font-size:13px; }
.nb-sim-panel.is-compact .nb-sim-diag-copy { font-size:11px; }

@media (max-width: 780px){
  .nb-reco-cards { grid-template-columns: 1fr; }
  .nb-sim-panel { padding:13px; }
  .nb-sim-head { flex-direction:column; align-items:stretch; }
  .nb-sim-topline { align-items:flex-start; }
  .nb-sim-tf { justify-content:flex-start; }
  .nb-sim-summary { grid-template-columns: 1fr 1fr; }
  .nb-sim-kpi { padding:8px 9px; }
  .nb-sim-v { font-size:13px; }
  .nb-sim-diag-copy { font-size:11px; }
}

@media (max-width: 420px){
  .nb-reco-tf,
  .nb-sim-tf { flex-wrap:wrap; }
  .nb-sim-summary,
  .nb-sim-panel.is-compact .nb-sim-summary { grid-template-columns: 1fr; }
  .nb-sim-warnings > div,
  .nb-reco-warnings > div { overflow-wrap:anywhere; }
}


#nbGridLiqCard .nb-liq-est {
  border: 0;
  background: transparent;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}
#nbGridLiqCard .nb-liq-main { font:700 20px var(--ff-mono); color:var(--text); letter-spacing:0.2px; }
#nbGridLiqCard .nb-liq-sub { margin-top:6px; font-size:12px; color:var(--muted); line-height:1.35; }
#nbGridLiqCard .nb-liq-warn { margin-top:8px; font-size:12px; color:#ff7d7d; line-height:1.35; font-weight:600; }
#nbGridLiqCard .nb-liq-main.warn { color:#ff7d7d; }

#nbMinRecCard .nb-minrec {
  overflow: visible;
  border: 0;
  background: transparent;
  border-radius: 0;
  box-shadow: none;
}
#nbMinRecCard .nb-minrec.st-ok,
#nbMinRecCard .nb-minrec.st-warn,
#nbMinRecCard .nb-minrec.st-err {
  border-color: transparent;
  background: transparent;
}
#nbMinRecCard .nb-mr-inner { display:flex; align-items:center; gap:11px; padding:0 0 12px; }
#nbMinRecCard .nb-mr-breakdown { border-top:1px solid var(--border); padding:12px 0 0; display:grid; grid-template-columns:repeat(3,1fr); gap:5px; }

.nb-grid-liq-inline { margin: -2px 0 10px; border:1px solid var(--border2); background:var(--bg5); border-radius:10px; padding:8px 10px; }
.nb-grid-liq-inline-top { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.nb-grid-liq-inline-label { font-size:12px; color:var(--text); font-weight:600; }
.nb-grid-liq-inline-val { font:700 16px var(--ff-mono); color:var(--text); }
.nb-grid-liq-inline-val.warn { color:#ff7d7d; }
.nb-grid-liq-inline-sub { margin-top:5px; font-size:11px; color:var(--muted); line-height:1.35; }
.nb-grid-liq-inline-warn { margin-top:6px; font-size:11px; color:#ff7d7d; font-weight:600; }


/* Account balance privacy card hotfix */
.cuenta-profile-strip .cuenta-profile-actions.cuenta-balance-privacy-card {
  margin-left: auto;
  min-width: 380px;
  max-width: 520px;
  width: min(100%, 520px);
  align-items: stretch;
  gap: 10px;
  padding: 2px 0 2px 18px;
  border: 0;
  border-left: 1px solid rgba(255,255,255,.08);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.cuenta-balance-card-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.cuenta-balance-card-title {
  display:none;
}
.cuenta-balance-card-tools {
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:auto;
}
.cuenta-balance-eye-btn {
  width: 30px;
  height: 30px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.035);
  color: rgba(255,255,255,.68);
  cursor:pointer;
  transition: all .16s ease;
}
.cuenta-balance-eye-btn:hover {
  color:#fff;
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
}
.cuenta-balance-eye-btn.is-hidden {
  color: #f4cf6a;
  border-color: rgba(244,207,106,.22);
  background: rgba(244,207,106,.08);
}
.cuenta-balance-eye-btn svg {
  width: 15px;
  height: 15px;
}
.cuenta-balance-refresh-btn {
  min-height: 30px;
  padding: 5px 10px;
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.cuenta-balance-metrics-grid {
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 18px;
  align-items:end;
}
.cuenta-balance-metric {
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
  padding:0;
  background: transparent;
  border: 0;
  position: relative;
}
.cuenta-balance-metric + .cuenta-balance-metric {
  padding-left: 18px;
}
.cuenta-balance-metric + .cuenta-balance-metric::before {
  content:'';
  position:absolute;
  left:0;
  top:4px;
  bottom:4px;
  width:1px;
  background: rgba(255,255,255,.08);
}
.cuenta-balance-privacy-card .cuenta-balance-inline-k {
  font-size: 10px;
  color: rgba(255,255,255,.48);
  letter-spacing: .07em;
  text-transform: uppercase;
}
.cuenta-balance-privacy-card .cuenta-balance-inline-v {
  font-size: 18px;
  font-weight: 800;
  line-height: 1.1;
  color: #fff;
  font-family: var(--ff-display);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cuenta-balance-privacy-card .cuenta-balance-inline-status {
  min-height: 0;
  text-align: left;
  color: rgba(255,255,255,.52);
}
.cuenta-balance-privacy-card .cuenta-balance-inline-hint {
  max-width: none;
  text-align: left;
  color: rgba(255,255,255,.34);
  line-height: 1.35;
  font-size: 10.5px;
}
@media (max-width: 980px) {
  .cuenta-profile-strip .cuenta-profile-actions.cuenta-balance-privacy-card {
    margin-left: 0;
    min-width: 0;
    max-width: none;
    width: 100%;
    padding: 12px 0 0;
    border-left: 0;
    border-top: 1px solid rgba(255,255,255,.08);
  }
}
@media (max-width: 640px) {
  .cuenta-balance-metrics-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .cuenta-balance-metric + .cuenta-balance-metric {
    padding-left: 0;
    padding-top: 10px;
  }
  .cuenta-balance-metric + .cuenta-balance-metric::before {
    left: 0;
    right: 0;
    top: 0;
    bottom: auto;
    width: auto;
    height: 1px;
  }
}


/* Account premium hierarchy refresh */
.cuenta-shell {
  display:flex;
  flex-direction:column;
  gap:22px;
}
.cuenta-hero-panel {
  padding: 18px 20px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(13,17,26,.94), rgba(10,13,20,.86));
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}
.cuenta-hero-panel .cuenta-profile-strip {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}
.cuenta-profile-wallet-row {
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:8px;
}
.cuenta-profile-pill-row {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.cuenta-inline-pill {
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.68);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0;
}
.cuenta-inline-pill::before {
  content:'';
  width:7px;
  height:7px;
  border-radius:50%;
  background: rgba(255,255,255,.28);
}
.cuenta-inline-pill.ok::before { background: #39d07a; box-shadow: 0 0 0 3px rgba(57,208,122,.14); }
.cuenta-inline-pill.pending::before { background: #f4cf6a; box-shadow: 0 0 0 3px rgba(244,207,106,.12); }
.cuenta-inline-pill.off::before { background: rgba(255,255,255,.24); }
.cuenta-readiness-hero {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.07);
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
}
.cuenta-readiness-copy {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cuenta-support-card-mini {
  margin-top: 0;
  padding: 12px 14px;
  border-radius: 14px;
  gap: 12px;
  max-width: 560px;
  align-self: flex-start;
}
.cuenta-support-card-mini .nb-support-kicker {
  gap: 7px;
  padding: 4px 9px;
  font-size: 9px;
  letter-spacing: .1em;
}
.cuenta-support-card-mini .nb-support-icon {
  width: 20px;
  height: 20px;
  font-size: 11px;
}
.cuenta-support-card-mini .nb-support-title {
  margin-top: 8px;
  font-size: 13px;
}
.cuenta-support-card-mini .nb-support-desc {
  margin-top: 3px;
  max-width: none;
  font-size: 11px;
  line-height: 1.4;
}
.cuenta-support-card-mini .nb-support-link {
  min-width: 132px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 12px;
  box-shadow: 0 8px 20px rgba(42,171,238,.12);
}
.cuenta-section-eyebrow {
  font-size: 11px;
  letter-spacing: .02em;
  text-transform: none;
  color: rgba(255,255,255,.46);
  margin-bottom: 6px;
  font-weight: 600;
}
.cuenta-readiness-headline {
  font-family: var(--ff-body);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.01em;
  color: #fff;
}
.cuenta-readiness-sub {
  margin-top: 6px;
  max-width: 680px;
  color: rgba(255,255,255,.54);
  line-height: 1.45;
  font-size: 13px;
}
.cuenta-readiness-strip {
  display:grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap:10px;
  min-width: min(100%, 420px);
}
.cuenta-readiness-chip {
  display:flex;
  flex-direction:column;
  gap:6px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.06);
}
.cuenta-readiness-chip > span {
  font-size: 10.5px;
  text-transform: none;
  letter-spacing: 0;
  color: rgba(255,255,255,.46);
  font-weight: 500;
}
.cuenta-readiness-chip > strong {
  font-size: 13px;
  color: #fff;
  font-weight: 700;
}
.cuenta-readiness-chip.ok {
  border-color: rgba(57,208,122,.24);
  background: rgba(57,208,122,.08);
}
.cuenta-readiness-chip.pending {
  border-color: rgba(244,207,106,.18);
}
.cuenta-readiness-chip.optional {
  background: rgba(108,141,255,.06);
}
.cuenta-section {
  padding: 4px 0 0;
}
.cuenta-section-head {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom: 14px;
}
.cuenta-section-title {
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  line-height: 1.18;
  letter-spacing: -.01em;
}
.cuenta-section-sub {
  margin-top: 4px;
  color: rgba(255,255,255,.52);
  line-height: 1.42;
  font-size: 13px;
}
.cuenta-grid-primary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.cuenta-grid-secondary {
  grid-template-columns: 1fr;
  gap: 14px;
}
.cuenta-card {
  min-height: 0;
  padding: 0;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.07);
  background: linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.018));
  box-shadow: none;
}
.cuenta-card:hover {
  border-color: rgba(255,255,255,.11);
  box-shadow: 0 10px 26px rgba(0,0,0,.14);
}
.cuenta-card::before,
.cuenta-card::after,
.cuenta-card-icon {
  display:none !important;
}
.cuenta-card-main {
  padding: 18px 18px 17px;
}
.cuenta-card-topline {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom: 12px;
}
.cuenta-card-title-group {
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.cuenta-card-title-group h3 {
  margin:0;
  font-size: 15px;
  font-weight: 700;
  color:#fff;
  letter-spacing: -.01em;
}
.cuenta-card-icon-inline {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.05);
}
.cuenta-card-icon-inline.warm { color:#f0c86b; background: rgba(240,200,107,.08); }
.cuenta-card-icon-inline.success { color:#39d07a; background: rgba(57,208,122,.08); }
.cuenta-card-icon-inline.blue { color:#86a1ff; background: rgba(108,141,255,.08); }
.cuenta-state-badge {
  display:inline-flex;
  align-items:center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.70);
  background: rgba(255,255,255,.04);
  font-size: 10.5px;
  font-weight: 600;
  white-space: nowrap;
}
.cuenta-state-badge.ok {
  color:#dff8ea;
  border-color: rgba(57,208,122,.24);
  background: rgba(57,208,122,.10);
}
.cuenta-state-badge.pending {
  color:#f4cf6a;
  border-color: rgba(244,207,106,.22);
  background: rgba(244,207,106,.08);
}
.cuenta-state-badge.optional,
.cuenta-state-badge.muted {
  color: rgba(255,255,255,.60);
}
.cuenta-card-desc {
  color: rgba(255,255,255,.74);
  line-height: 1.5;
  font-size: 13px;
}
.cuenta-card-hint {
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  background: rgba(255,255,255,.025);
  color: rgba(255,255,255,.54);
}
.cuenta-card-actions {
  margin-top: 16px;
}
.cuenta-card-input-row {
  margin-top: 14px;
}
.cuenta-card-fee-grid {
  margin-top: 14px;
  background: transparent;
  border: 0;
  padding: 0;
}
.cuenta-fee-item {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.cuenta-profile-strip .cuenta-profile-actions.cuenta-balance-privacy-card {
  min-width: 360px;
  max-width: 470px;
  width: min(100%, 470px);
  padding: 0 0 0 24px;
  gap: 10px;
  border-left: 1px solid rgba(255,255,255,.08);
}
.cuenta-balance-main-wrap {
  display:flex;
  flex-direction:column;
  gap:4px;
}
.cuenta-balance-main-label {
  font-size: 11px;
  text-transform: none;
  letter-spacing: 0;
  color: rgba(255,255,255,.48);
  font-weight: 500;
}
.cuenta-balance-main-value {
  font-family: var(--ff-body);
  font-size: 30px;
  line-height: 1.02;
  font-weight: 700;
  color:#fff;
  letter-spacing: -.02em;
}
.cuenta-balance-secondary-wrap {
  display:flex;
  align-items:baseline;
  gap:10px;
  flex-wrap:wrap;
}
.cuenta-balance-privacy-card .cuenta-balance-inline-v {
  font-size: 15px;
  font-weight: 700;
}
.cuenta-balance-note {
  margin-top: 2px;
}
.cuenta-balance-note summary {
  cursor:pointer;
  list-style:none;
  color: rgba(255,255,255,.46);
  font-size: 11px;
}
.cuenta-balance-note summary::-webkit-details-marker { display:none; }
.cuenta-balance-note[open] summary { color: rgba(255,255,255,.66); }
.cuenta-balance-privacy-card .cuenta-balance-inline-hint {
  margin-top: 8px;
}
@media (max-width: 1100px) {
  .cuenta-readiness-hero {
    flex-direction:column;
  }
  .cuenta-readiness-strip {
    width:100%;
    min-width:0;
  }
}
@media (max-width: 980px) {
  .cuenta-grid-primary {
    grid-template-columns: 1fr;
  }
  .cuenta-profile-strip .cuenta-profile-actions.cuenta-balance-privacy-card {
    width:100%;
    max-width:none;
    min-width:0;
    padding: 16px 0 0;
    border-left:0;
    border-top: 1px solid rgba(255,255,255,.08);
  }
}
@media (max-width: 720px) {
  .cuenta-hero-panel {
    padding: 16px;
    border-radius: 18px;
  }
  .cuenta-support-card-mini {
    max-width: none;
    align-self: stretch;
    flex-direction: column;
    align-items: stretch;
  }
  .cuenta-support-card-mini .nb-support-link {
    width: 100%;
    min-width: 0;
  }
  .cuenta-readiness-headline {
    font-size: 20px;
  }
  .cuenta-readiness-strip {
    grid-template-columns: 1fr;
  }
  .cuenta-card-topline {
    align-items:flex-start;
    flex-direction:column;
  }
  .cuenta-balance-main-value {
    font-size: 26px;
  }
}

/* ════════════════════════════════════════════════════════
   BOTS TAB — Premium refresh aligned with dashboard/account
   ════════════════════════════════════════════════════════ */
#tab-bots.bots-page {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 4px 0 10px;
}

.bots-section-eyebrow {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.42);
  margin-bottom: 10px;
}

.bots-hero-panel,
.bots-live-panel,
.bots-history-head,
.bots-history-note {
  border: 1px solid rgba(255,255,255,.07);
  background:
    radial-gradient(circle at top right, rgba(61,186,133,.10), transparent 34%),
    radial-gradient(circle at bottom left, rgba(108,141,255,.08), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  box-shadow: 0 18px 50px rgba(0,0,0,.20);
}

.bots-hero-panel {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding: 22px 24px;
  border-radius: 26px;
}
.bots-hero-copy h2,
.bots-live-copy h2 {
  margin:0;
  font-size: clamp(24px, 3.2vw, 36px);
  line-height:1;
}
.bots-hero-sub,
.bots-live-sub {
  margin-top: 12px;
  color: rgba(255,255,255,.66);
  max-width: 720px;
  line-height: 1.65;
  font-size: 14px;
}
.bots-hero-pills,
.bots-live-stats,
.bots-history-right {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.bots-hero-pill,
.bots-mini-stat {
  min-width: 112px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.03);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.bots-hero-pill span,
.bots-mini-stat span {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.42);
}
.bots-hero-pill strong,
.bots-mini-stat strong {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
}

.bots-page .bot-cards {
  margin-top: 18px;
  gap: 18px;
}
.bots-page .bot-card {
  min-height: 220px;
  padding: 20px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.07);
  background:
    radial-gradient(circle at top right, rgba(61,186,133,.10), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.018));
  box-shadow: 0 14px 40px rgba(0,0,0,.18);
  gap: 14px;
}
.bots-page .bot-card::after {
  height: 3px;
  opacity: .35;
  background: linear-gradient(90deg, rgba(61,186,133,.9), rgba(108,141,255,.3));
}
.bots-page .bot-card:hover {
  transform: translateY(-3px);
  border-color: rgba(61,186,133,.24);
  box-shadow: 0 20px 42px rgba(0,0,0,.25);
}
.bots-page .bot-card:hover::after { opacity: .92; }
.bots-page .bot-card-top,
.bots-page .bot-card-foot {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.bots-page .bot-card-copy {
  display:flex;
  flex-direction:column;
  gap:10px;
  min-width:0;
  flex:1 1 auto;
}
.bots-page .bot-card .bot-icon {
  width: 52px;
  height: 52px;
  border-radius: 15px;
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
  margin: 0;
}
.bots-page .bot-card .bot-name {
  font-size: 18px;
  line-height: 1.08;
}
.bots-page .bot-card .bot-desc {
  font-size: 13px;
  line-height: 1.65;
  color: rgba(255,255,255,.65);
}
.bots-page .bot-card .bot-status {
  margin: 0;
  border: 1px solid rgba(61,186,133,.18);
}
.bots-page .bot-card-foot {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.bots-page .bot-card-signal {
  width: 82px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(61,186,133,.22), rgba(108,141,255,.65));
  box-shadow: 0 0 24px rgba(61,186,133,.18);
}
.bots-page .bot-card-arrow {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.84);
  font-size: 16px;
}

.bots-live-panel {
  margin-top: 24px;
  padding: 22px 24px 24px;
  border-radius: 26px;
}
.bots-live-head,
.bots-history-head {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 18px;
}
.bots-live-right,
.bots-history-right {
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap: 12px;
}
.bots-live-actions {
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
}
.bots-history-chip {
  font-size: 13px !important;
}
.bots-premium-grid {
  margin-top: 18px;
  gap: 14px;
}

.bot {
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.07);
  background:
    radial-gradient(circle at top right, rgba(61,186,133,.08), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.018));
  box-shadow: 0 12px 38px rgba(0,0,0,.16);
}
.bot:hover {
  border-color: rgba(255,255,255,.11);
  box-shadow: 0 18px 42px rgba(0,0,0,.24);
}
.bot.bot-paused {
  border-color: rgba(244,207,106,.20);
  background: linear-gradient(180deg, rgba(244,207,106,.06), rgba(255,255,255,.018));
}
.bot.bot-error-state {
  border-color: rgba(217,92,110,.22);
  background: linear-gradient(180deg, rgba(217,92,110,.08), rgba(255,255,255,.018));
}
.bot-inner {
  padding: 16px;
}
.bot-head {
  align-items:flex-start !important;
  gap: 14px !important;
  margin-bottom: 14px !important;
}
.bot-head-main {
  gap: 12px;
  align-items:flex-start;
}
.bot-asset-avatar {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.09);
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .08em;
  color: rgba(255,255,255,.86);
  flex-shrink:0;
}
.bot-head-copy {
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}
.bot-kicker {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
}
.bot-title-row {
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.bot-id-row {
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.bot-id-sep {
  color: rgba(255,255,255,.22);
  font-size: 10px;
}
.bot-head-side {
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
  flex-shrink:0;
}
.bot-pnl-stack {
  padding: 10px 12px;
  min-width: 128px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  display:flex;
  flex-direction:column;
  gap:5px;
}
.bot-pnl-label {
  font-family: var(--ff-ibm, 'IBM Plex Mono', monospace);
  font-size: 9px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
}
.bot-pnl-value {
  font-size: 22px;
  line-height: 1;
  font-weight: 700;
}
.bot-pnl-value.good { color: var(--up); }
.bot-pnl-value.bad  { color: var(--dn); }
.bot-premium-meta {
  gap: 0;
  border-radius: 16px;
  border-color: rgba(255,255,255,.07);
  background: rgba(255,255,255,.02);
  margin-bottom: 12px;
}
.bot-premium-meta .meta-cell {
  padding: 11px 12px;
  background: transparent;
  border-right: 1px solid rgba(255,255,255,.05);
}
.bot-premium-meta .meta-cell:last-child { border-right: 0; }
.bot-risk-band {
  padding: 12px 13px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.02);
  margin-bottom: 12px;
}
.bot-roi-row {
  margin-bottom: 12px;
}
.bot-liq-row {
  margin: 0;
  border-radius: 12px;
  border-color: rgba(255,255,255,.05);
  background: rgba(255,255,255,.02);
}
.bot .actions {
  gap: 8px;
  flex-wrap: wrap;
}
.bot .actions .btn {
  flex: 1 1 150px;
}
.bot .actions .btn-detail,
.bot .actions .btn-share {
  flex: 1 1 120px;
}
.bc-err {
  margin-bottom: 12px;
  padding: 12px 13px;
  border-radius: 14px;
  border: 1px solid rgba(255,209,102,.18);
  background: rgba(255,209,102,.06);
  color: #ffd166;
  line-height: 1.5;
}

.bots-history-view {
  display:flex;
  flex-direction:column;
  gap:16px;
}
.bots-history-note {
  display:flex;
  align-items:flex-start;
  gap:14px;
  border-radius: 22px;
  padding: 18px 20px;
}
.bots-history-note-icon {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.78);
  flex-shrink: 0;
}
.bots-history-note-title {
  font-weight: 700;
  margin-bottom: 8px;
}
.bots-history-note-body {
  display:flex;
  flex-direction:column;
  gap:6px;
  color: rgba(255,255,255,.68);
  line-height: 1.6;
}
.bots-history-info {
  grid-column: 1 / -1;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.025);
  color: rgba(255,255,255,.62);
  font-size: 13px;
}
.bots-history-more {
  grid-column: 1 / -1;
  margin-top: 4px;
}

.bots-empty {
  grid-column: 1 / -1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height: 220px;
  padding: 26px 20px;
  text-align:center;
  border-radius: 22px;
  border: 1px dashed rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.012));
}
.bots-empty-icon {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.82);
  font-size: 18px;
}
.bots-empty-title {
  font-size: 18px;
  font-weight: 700;
}
.bots-empty-body {
  max-width: 560px;
  line-height: 1.65;
  color: rgba(255,255,255,.62);
}

@media (max-width: 1100px) {
  .bots-hero-panel,
  .bots-live-head,
  .bots-history-head {
    flex-direction:column;
  }
  .bots-live-right,
  .bots-history-right {
    width:100%;
    align-items:stretch;
  }
  .bots-live-actions {
    justify-content:flex-start;
  }
}

@media (max-width: 760px) {
  .bots-hero-panel,
  .bots-live-panel,
  .bots-history-head,
  .bots-history-note {
    border-radius: 20px;
  }
  .bots-hero-panel,
  .bots-live-panel,
  .bots-history-head {
    padding: 18px 16px;
  }
  .bots-page .bot-card {
    min-height: 0;
    border-radius: 18px;
    padding: 16px;
  }
  .bots-hero-pill,
  .bots-mini-stat {
    flex: 1 1 calc(50% - 5px);
    min-width: 0;
  }
  .bot-head {
    flex-direction: column;
  }
  .bot-head-side {
    width:100%;
    align-items:flex-start;
  }
  .bot-pnl-stack {
    width:100%;
    min-width:0;
  }
  .bot .meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .bot-premium-meta .meta-cell:nth-child(2n) {
    border-right: 0;
  }
}

@media (max-width: 560px) {
  .bots-page .bot-card-top,
  .bots-page .bot-card-foot,
  .bots-live-actions,
  .bot-title-row,
  .bot-id-row {
    align-items:flex-start;
    flex-wrap:wrap;
  }
  .bots-hero-pill,
  .bots-mini-stat,
  .bot .actions .btn,
  .bot .actions .btn-detail,
  .bot .actions .btn-share {
    flex-basis: 100%;
  }
  .bot .meta {
    grid-template-columns: 1fr;
  }
  .bot-premium-meta .meta-cell {
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.05);
  }
  .bot-premium-meta .meta-cell:last-child {
    border-bottom: 0;
  }
  .bots-history-note {
    flex-direction:column;
  }
}


/* ── Bots / dashboard alignment hotfix (20260411botsdashboard2) ── */
.bots-hero-panel,
.bots-live-panel,
.bots-history-head {
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.022), rgba(255,255,255,.012));
  box-shadow: 0 12px 30px rgba(0,0,0,.16);
  border-radius: 22px;
}
.bots-history-note { display: none !important; }
.bots-hero-panel {
  padding: 20px 22px;
  gap: 16px;
}
.bots-live-panel,
.bots-history-head {
  padding: 20px 22px;
}
.bots-hero-sub,
.bots-live-sub {
  margin-top: 10px;
  color: var(--muted);
  max-width: 680px;
  line-height: 1.55;
}
.bots-hero-pills:empty,
.bots-live-stats:empty,
#botsHistoryStats:empty {
  display: none !important;
}
.bots-live-right,
.bots-history-right {
  gap: 10px;
}
.bots-history-chip {
  font-size: 12px !important;
  padding-inline: 14px !important;
}
.bots-premium-grid {
  margin-top: 16px;
  gap: 12px;
}

.bots-page .bot-card {
  min-height: 204px;
  padding: 18px;
  border-radius: 20px;
  border-color: var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.022), rgba(255,255,255,.012));
  box-shadow: 0 10px 28px rgba(0,0,0,.14);
  gap: 12px;
}
.bots-page .bot-card::after {
  background: linear-gradient(90deg, rgba(255,255,255,.26), transparent 72%);
  opacity: .55;
}
.bots-page .bot-card:hover {
  transform: translateY(-2px);
  border-color: var(--border2);
  box-shadow: 0 14px 32px rgba(0,0,0,.18);
}
.bots-page .bot-card .bot-icon {
  background: var(--bg3);
  border-color: var(--border);
}
.bots-page .bot-card .bot-status {
  border-color: var(--border);
}
.bots-page .bot-card-foot {
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.05);
}
.bots-page .bot-card-signal {
  box-shadow: none;
  background: linear-gradient(90deg, rgba(255,255,255,.16), rgba(255,255,255,.42));
}
.bots-page .bot-card-arrow {
  background: var(--bg3);
  border-color: var(--border);
}

.bot {
  border-radius: 20px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.022), rgba(255,255,255,.012));
  box-shadow: 0 10px 28px rgba(0,0,0,.14);
}
.bot:hover {
  border-color: var(--border2);
  box-shadow: 0 14px 32px rgba(0,0,0,.18);
}
.bot.bot-paused {
  border-color: rgba(244,207,106,.18);
  background: linear-gradient(180deg, rgba(244,207,106,.05), rgba(255,255,255,.012));
}
.bot.bot-error-state {
  border-color: rgba(217,92,110,.18);
  background: linear-gradient(180deg, rgba(217,92,110,.06), rgba(255,255,255,.012));
}
.bot-inner {
  padding: 14px;
}
.bot-head {
  gap: 12px !important;
  margin-bottom: 12px !important;
}
.bot-asset-avatar {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--bg3);
  border-color: var(--border);
  font-size: 12px;
}
.bot-kicker {
  font-size: 8px;
  letter-spacing: .12em;
  color: rgba(255,255,255,.36);
}
.bot-head-side {
  gap: 8px;
}
.bot-pnl-stack {
  min-width: 110px;
  padding: 8px 10px;
  border-radius: 14px;
  border-color: var(--border);
  background: var(--bg3);
}
.bot-pnl-value {
  font-size: 18px;
}
.bot .meta.bot-premium-meta {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin-bottom: 10px;
  border-radius: 14px;
  border-color: var(--border);
  background: var(--bg3);
}
.bot-premium-meta .meta-cell {
  padding: 9px 10px;
}
.bot-risk-band {
  padding: 0;
  margin-bottom: 10px;
  border: 0;
  background: transparent;
}
.bot-roi-row {
  display: none;
}
.bot-liq-row {
  padding: 9px 10px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--bg3);
  gap: 10px;
}
.bot .actions {
  gap: 6px;
}
.bot .actions .btn,
.bot .actions .btn-detail,
.bot .actions .btn-share {
  flex: 1 1 calc(50% - 3px);
  min-width: 0;
  padding: 8px 10px !important;
}
.bc-err {
  margin-bottom: 10px;
  padding: 10px 12px;
  border-radius: 13px;
}

@media (max-width: 760px) {
  .bots-hero-panel,
  .bots-live-panel,
  .bots-history-head {
    padding: 16px 14px;
    border-radius: 18px;
  }
  .bots-page .bot-card {
    min-height: 0;
    padding: 16px;
    border-radius: 18px;
  }
  .bot {
    border-radius: 18px;
  }
  .bot-inner {
    padding: 13px;
  }
  .bot .meta.bot-premium-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .bot .meta.bot-premium-meta {
    grid-template-columns: 1fr;
  }
}


/* ── Bots tightening hotfix (20260411botsdashboard3) ── */
#botsActiveSection .bots-live-right,
#btnRefresh,
#btnGoToHistory,
#viewBotsHistory {
  display: none !important;
}

#botsActiveSection .bots-live-head {
  display: block;
}

#botsActive {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 352px));
  justify-content: start;
  align-items: start;
  gap: 10px;
}

#botsActive > .bot,
#botsActive > .bots-empty {
  width: 100%;
  max-width: 352px;
  justify-self: start;
}

.bot {
  max-width: 352px;
}

.bot-inner {
  padding: 12px;
}

.bot-head {
  gap: 10px !important;
  margin-bottom: 10px !important;
}

.bot-pnl-stack {
  min-width: 102px;
  padding: 7px 9px;
}

.bot-pnl-value {
  font-size: 17px;
}

.bot .meta.bot-premium-meta {
  margin-bottom: 8px;
}

.bot-premium-meta .meta-cell {
  padding: 8px 9px;
}

.bot-liq-row {
  padding: 8px 9px;
  margin-bottom: 8px;
}

.bot .actions {
  gap: 5px;
}

.bot .actions .btn,
.bot .actions .btn-detail,
.bot .actions .btn-share {
  padding: 7px 9px !important;
  font-size: 12px;
}

@media (max-width: 760px) {
  #botsActive {
    grid-template-columns: 1fr;
    gap: 9px;
  }

  #botsActive > .bot,
  #botsActive > .bots-empty,
  .bot {
    max-width: none;
  }

  .bot-inner {
    padding: 11px;
  }
}


/* ── Bots visual harmonization hotfix (20260411botsdashboard4) ── */
#tab-bots.bots-page {
  padding-top: 0;
}

.bots-section-eyebrow {
  margin-bottom: 6px;
  color: rgba(255,255,255,.40);
}

.bots-hero-panel {
  background: radial-gradient(circle at top left, rgba(108,141,255,.11), transparent 40%), linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.018));
  box-shadow: 0 18px 46px rgba(0,0,0,.25);
  padding: 16px 18px;
  gap: 12px;
}

.bots-live-panel,
.bots-history-head {
  background: linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.016));
  box-shadow: 0 18px 46px rgba(0,0,0,.25);
  padding: 16px 18px;
}

.bots-hero-copy h2,
.bots-live-copy h2 {
  font-size: clamp(22px, 2.25vw, 28px);
  line-height: 1.02;
}

.bots-hero-sub,
.bots-live-sub {
  margin-top: 7px;
  max-width: 620px;
  line-height: 1.5;
  font-size: 13px;
  color: var(--muted);
}

.bots-page .bot-cards {
  margin-top: 12px;
  gap: 12px;
}

.bots-page .bot-card {
  min-height: 186px;
  padding: 16px 17px;
  border: 1px solid rgba(255,255,255,.05);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  box-shadow: 0 18px 36px rgba(0,0,0,.22);
  gap: 11px;
}

.bots-page .bot-card::after {
  background: linear-gradient(90deg, rgba(108,141,255,.74), rgba(108,141,255,.16));
  opacity: .78;
}

.bots-page .bot-card:hover {
  border-color: var(--border2);
  box-shadow: 0 20px 40px rgba(0,0,0,.24);
}

.bots-page .bot-card-top,
.bots-page .bot-card-foot {
  gap: 10px;
}

.bots-page .bot-card-copy {
  gap: 8px;
}

.bots-page .bot-card .bot-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
}

.bots-page .bot-card .bot-name {
  font-size: 17px;
}

.bots-page .bot-card .bot-desc {
  font-size: 12.5px;
  line-height: 1.55;
}

.bots-page .bot-card-foot {
  padding-top: 11px;
}

.bots-page .bot-card-signal {
  width: 64px;
  height: 6px;
  background: linear-gradient(90deg, rgba(108,141,255,.24), rgba(108,141,255,.72));
  box-shadow: none;
}

.bot {
  border: 1px solid rgba(255,255,255,.05);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  box-shadow: 0 18px 36px rgba(0,0,0,.22);
}

.bot:hover {
  box-shadow: 0 20px 40px rgba(0,0,0,.24);
}

.bot-inner {
  padding: 11px;
}

.bot-head {
  gap: 9px !important;
  margin-bottom: 8px !important;
}

.bot-head-main {
  gap: 10px;
}

.bot-head-copy {
  gap: 4px;
}

.bot-asset-avatar {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  font-size: 12px;
}

.bot-title-row {
  gap: 6px;
}

.bot-id-row {
  gap: 4px;
}

.bot-head-side {
  gap: 7px;
}

.bot-pnl-stack {
  min-width: 96px;
  padding: 6px 8px;
  border-radius: 13px;
}

.bot-pnl-value {
  font-size: 16px;
}

.bot .meta.bot-premium-meta {
  margin-bottom: 6px;
  border-radius: 13px;
}

.bot-premium-meta .meta-cell {
  padding: 7px 8px;
}

.bot-liq-row {
  padding: 7px 8px;
  gap: 8px;
  margin-bottom: 6px;
  border-radius: 13px;
}

.bot .actions {
  gap: 4px;
}

.bot .actions .btn,
.bot .actions .btn-detail,
.bot .actions .btn-share {
  padding: 6px 8px !important;
  font-size: 11px;
}

@media (max-width: 760px) {
  .bots-hero-panel,
  .bots-live-panel,
  .bots-history-head {
    padding: 14px;
  }

  .bots-page .bot-card {
    min-height: 0;
    padding: 14px;
  }

  .bot-inner {
    padding: 10px;
  }
}


/* ── Bots/account visual parity hotfix (20260411botsdashboard5) ── */
.bots-section-eyebrow {
  font-size: 11px;
  letter-spacing: .02em;
  text-transform: none;
  color: rgba(255,255,255,.46);
  margin-bottom: 6px;
  font-weight: 600;
}

.bots-hero-panel,
.bots-live-panel,
.bots-history-head {
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(13,17,26,.94), rgba(10,13,20,.86));
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}

.bots-hero-panel {
  padding: 14px 18px;
  gap: 10px;
}

.bots-live-panel,
.bots-history-head {
  padding: 15px 18px;
}

.bots-hero-copy h2,
.bots-live-copy h2 {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.01em;
}

.bots-hero-sub,
.bots-live-sub {
  margin-top: 6px;
  max-width: 680px;
  color: rgba(255,255,255,.54);
  line-height: 1.45;
  font-size: 13px;
}

#botsActive {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  justify-content: stretch;
  align-items: start;
  gap: 12px;
}

#botsActive > .bot,
#botsActive > .bots-empty,
.bot {
  width: 100%;
  max-width: none;
  min-width: 0;
  justify-self: stretch;
}

.bot-inner {
  padding: 10px;
}

.bot-head {
  gap: 8px !important;
  margin-bottom: 7px !important;
}

.bot-head-main {
  gap: 9px;
}

.bot-head-copy {
  gap: 3px;
}

.bot-asset-avatar {
  width: 36px;
  height: 36px;
  border-radius: 11px;
  font-size: 11px;
}

.bot-kicker,
.bot-id,
.bot-duration-inline,
.bot-pnl-label,
.meta-label,
.bot-liq-label {
  font-size: 10px;
}

.bot-asset {
  font-size: 17px;
}

.badge {
  min-height: 24px;
  padding: 0 9px;
  font-size: 10px;
}

.bot-tag {
  min-height: 20px;
  padding: 0 7px;
  font-size: 10px;
}

.bot-pnl-stack {
  min-width: 90px;
  padding: 6px 7px;
}

.bot-pnl-value {
  font-size: 15px;
}

.bot .meta.bot-premium-meta {
  margin-bottom: 5px;
}

.bot-premium-meta .meta-cell {
  padding: 7px;
}

.bot-liq-row {
  padding: 7px;
  gap: 7px;
  margin-bottom: 5px;
}

.bot .actions {
  gap: 4px;
}

.bot .actions .btn,
.bot .actions .btn-detail,
.bot .actions .btn-share {
  min-width: 0;
  padding: 6px 7px !important;
  font-size: 10.5px;
}

@media (max-width: 1279px) {
  #botsActive {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  #botsActive {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .bots-hero-panel,
  .bots-live-panel,
  .bots-history-head {
    padding: 14px;
    border-radius: 18px;
  }

  .bots-hero-copy h2,
  .bots-live-copy h2 {
    font-size: 20px;
  }

  #botsActive {
    grid-template-columns: 1fr;
    gap: 9px;
  }

  .bot-inner {
    padding: 10px;
  }
}


/* ── Bots/dashboard/account unified visual language hotfix (20260411botsdashboard6) ── */
.bots-section-eyebrow {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
}

.bots-hero-panel,
.bots-live-panel,
.bots-history-head,
.bots-page .bot-card,
.bot {
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 22px;
  background:
    radial-gradient(circle at 0% 0%, rgba(108,141,255,.10), rgba(0,0,0,0) 42%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: 0 18px 46px rgba(0,0,0,.25);
}

.bots-hero-panel {
  padding: 16px 18px;
  gap: 10px;
}

.bots-live-panel,
.bots-history-head {
  padding: 16px 18px;
}

.bots-hero-copy h2,
.bots-live-copy h2 {
  font-family: var(--ff-body);
  font-size: 22px;
  line-height: 25.3px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: #fff;
}

.bots-hero-sub,
.bots-live-sub,
.bots-page .bot-card .bot-desc {
  font-size: 13px;
  line-height: 18.85px;
  color: rgba(255,255,255,.54);
}

.bots-page .bot-cards {
  gap: 14px;
}

.bots-page .bot-card {
  min-height: 198px;
  padding: 18px;
  gap: 12px;
}

.bots-page .bot-card::after {
  height: 3px;
  opacity: .7;
  background: linear-gradient(90deg, rgba(108,141,255,.78), rgba(108,141,255,.20));
}

.bots-page .bot-card:hover,
.bot:hover {
  border-color: rgba(108,141,255,.20);
  box-shadow: 0 20px 48px rgba(0,0,0,.27);
}

.bots-page .bot-card-top,
.bots-page .bot-card-foot {
  gap: 12px;
}

.bots-page .bot-card-copy {
  gap: 8px;
}

.bots-page .bot-card .bot-icon,
.bot-asset-avatar {
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(108,141,255,.10);
}

.bots-page .bot-card .bot-icon {
  width: 44px;
  height: 44px;
}

.bots-page .bot-card .bot-name,
.bot-asset {
  font-family: var(--ff-body);
  font-size: 16px;
  line-height: 18.4px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -.01em;
}

.bots-page .bot-card .bot-status,
.badge,
.bot-tag,
.bot-kicker,
.bot-id,
.bot-duration-inline,
.bot-pnl-label,
.meta-label,
.bot-liq-label {
  font-size: 10px;
  letter-spacing: .05em;
}

.badge,
.bot-tag {
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}

.bot {
  max-width: none;
}

.bot-inner {
  padding: 11px;
}

.bot-head {
  gap: 8px !important;
  margin-bottom: 8px !important;
}

.bot-head-main,
.bot-head-side,
.bot-title-row,
.bot-id-row {
  gap: 6px;
}

.bot-head-copy {
  gap: 3px;
}

.bot-asset-avatar {
  width: 36px;
  height: 36px;
  font-size: 11px;
}

.bot-pnl-stack,
.bot-premium-meta,
.bot-liq-row {
  border-color: rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}

.bot-pnl-stack {
  min-width: 92px;
  padding: 6px 7px;
  border-radius: 13px;
}

.bot-pnl-value,
.meta-value,
.bot-liq-value {
  color: rgba(255,255,255,.92);
}

.bot-pnl-value {
  font-size: 15px;
}

.bot-premium-meta .meta-cell {
  padding: 7px 8px;
}

.bot-liq-row {
  padding: 7px 8px;
  gap: 8px;
}

.bot .actions .btn,
.bot .actions .btn-detail,
.bot .actions .btn-share {
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.88);
}

@media (max-width: 760px) {
  .bots-hero-panel,
  .bots-live-panel,
  .bots-history-head,
  .bots-page .bot-card,
  .bot {
    border-radius: 18px;
  }

  .bots-hero-copy h2,
  .bots-live-copy h2 {
    font-size: 20px;
    line-height: 23px;
  }

  .bots-page .bot-card {
    min-height: 0;
    padding: 14px;
  }
}


/* ── Bots copy-strip cleanup hotfix (20260411botsdashboard7) ── */
#tab-bots .bots-hero-panel {
  justify-content: flex-start;
  align-items: center;
  padding: 14px 18px;
  min-height: 0;
}

#tab-bots .bots-hero-copy {
  gap: 0;
}

#tab-bots .bots-hero-pills,
#tab-bots .bots-hero-sub,
#tab-bots .bots-section-eyebrow,
#botsActiveSection .bots-live-head {
  display: none !important;
}

#botsActiveSection {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}


/* ── Bots asset avatar removal hotfix (20260411botsdashboard10) ── */
.bot-asset-avatar {
  display: none !important;
}
.bot-head-main {
  gap: 0 !important;
}

/* ── Bots choose hero removal hotfix (20260411botsdashboard12) ── */
#botSelectionView > .bots-hero-panel {
  display: none !important;
}

/* ── Leaderboard visual parity refresh (20260411leaderboard1) ── */
#tab-leaderboard .lb-shell {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 14px 14px 24px;
}
#tab-leaderboard .lb-hero-panel {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 18px 20px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(13,17,26,.94), rgba(10,13,20,.86));
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}
#tab-leaderboard .lb-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 0;
  flex-wrap: wrap;
}
#tab-leaderboard .lb-header-left {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
#tab-leaderboard .lb-title {
  margin: 0;
  font-family: var(--ff-body);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.01em;
  color: #fff;
}
#tab-leaderboard .lb-sub {
  margin: 0;
  max-width: 680px;
  font-family: var(--ff-body);
  font-size: 13px;
  line-height: 1.45;
  letter-spacing: 0;
  color: rgba(255,255,255,.54);
}
#tab-leaderboard .lb-header-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
#tab-leaderboard .lb-refresh-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  box-shadow: none;
}
#tab-leaderboard .lb-refresh-btn:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.14);
}
#tab-leaderboard .lb-live-badge {
  min-height: 36px;
  padding: 0 12px 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(61,186,133,.22);
  background: rgba(61,186,133,.08);
  font-family: var(--ff-body);
  font-size: 10.5px;
  font-weight: 600;
  color: var(--up);
}
#tab-leaderboard .lb-live-dot {
  width: 7px;
  height: 7px;
}
#tab-leaderboard .lb-controls {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
  margin-bottom: 0;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.07);
}
#tab-leaderboard .lb-ctrl-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  min-width: 0;
}
#tab-leaderboard .lb-ctrl-group-select {
  gap: 8px;
}
#tab-leaderboard .lb-ctrl-label {
  padding-left: 0;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(255,255,255,.46);
  font-family: var(--ff-body);
}
#tab-leaderboard .lb-controls .pill-group {
  width: 100%;
  gap: 3px;
  padding: 3px;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
}
#tab-leaderboard .lb-controls .lang-btn {
  flex: 1 1 0;
  min-height: 34px;
  padding: 0 10px;
  border-radius: 9px;
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,.62);
}
#tab-leaderboard .lb-controls .lang-btn.active {
  background: rgba(255,255,255,.10);
  color: #fff;
}
#tab-leaderboard .lb-select {
  width: 100%;
  min-width: 0;
  height: 40px;
  padding: 0 34px 0 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.04);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  background-position: calc(100% - 16px) calc(50% - 2px), calc(100% - 11px) calc(50% - 2px);
}
#tab-leaderboard .lb-select:hover {
  border-color: rgba(255,255,255,.14);
  background-color: rgba(255,255,255,.06);
}
#tab-leaderboard .lb-select:focus {
  border-color: rgba(108,141,255,.55);
  box-shadow: 0 0 0 2px rgba(108,141,255,.10);
}
#tab-leaderboard .lb-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin-bottom: 0;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(108,141,255,.08), rgba(108,141,255,.02));
  box-shadow: 0 18px 46px rgba(0,0,0,.14);
}
#tab-leaderboard .lb-kpi {
  padding: 16px 18px;
  border-right: 1px solid rgba(255,255,255,.07);
  background: transparent;
  border-radius: 0;
}
#tab-leaderboard .lb-kpi:last-child {
  border-right: 0;
}
#tab-leaderboard .lb-kpi-lbl {
  margin-bottom: 8px;
  font-family: var(--ff-body);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: rgba(255,255,255,.46);
}
#tab-leaderboard .lb-kpi-val {
  font-family: var(--ff-display);
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -.02em;
  color: #fff;
}
#tab-leaderboard .lb-table-wrap {
  background: linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.016));
  border: 1px solid var(--border);
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 18px 46px rgba(0,0,0,.25);
}
#tab-leaderboard .lb-thead {
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid rgba(255,255,255,.07);
}
#tab-leaderboard .lb-thead,
#tab-leaderboard .lb-row {
  padding: 0 14px;
}
#tab-leaderboard .lb-th {
  font-family: var(--ff-body);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .05em;
  color: rgba(255,255,255,.42);
  padding: 10px 8px;
}
#tab-leaderboard .lb-row {
  min-height: 62px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: background .14s ease;
}
#tab-leaderboard .lb-row:hover {
  background: rgba(255,255,255,.025);
}
#tab-leaderboard .lb-cell-rank {
  font-size: 12px;
  color: rgba(255,255,255,.52);
}
#tab-leaderboard .lb-cell-bot,
#tab-leaderboard .lb-cell-cfg,
#tab-leaderboard .lb-cell-num,
#tab-leaderboard .lb-roi-wrap,
#tab-leaderboard .lb-cell-uptime,
#tab-leaderboard .lb-cell-copy {
  padding-top: 10px;
  padding-bottom: 10px;
}
#tab-leaderboard .lb-asset {
  font-family: var(--ff-body);
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
#tab-leaderboard .lb-bot-type {
  font-family: var(--ff-body);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(255,255,255,.54);
}
#tab-leaderboard .lb-dir {
  padding: 3px 8px;
  border-radius: 999px;
  font-family: var(--ff-body);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .04em;
}
#tab-leaderboard .lb-cfg-chip {
  font-family: var(--ff-body);
  font-size: 10px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  color: rgba(255,255,255,.54);
}
#tab-leaderboard .lb-cfg-chip span {
  color: #fff;
}
#tab-leaderboard .lb-cell-num,
#tab-leaderboard .lb-roi-val,
#tab-leaderboard .lb-cell-uptime {
  font-family: var(--ff-body);
  font-size: 12.5px;
  font-weight: 700;
}
#tab-leaderboard .lb-cell-uptime {
  color: rgba(255,255,255,.54);
}
#tab-leaderboard .lb-substat,
#tab-leaderboard .lb-mobile-chip {
  font-family: var(--ff-body);
}
#tab-leaderboard .lb-mobile-chip {
  min-height: 28px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
  color: rgba(255,255,255,.58);
  font-size: 10px;
}
#tab-leaderboard .lb-mobile-chip b {
  color: #fff;
}
#tab-leaderboard .lb-copy-btn {
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(108,141,255,.26);
  background: rgba(108,141,255,.10);
  color: #dce6ff;
  font-family: var(--ff-body);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: none;
}
#tab-leaderboard .lb-copy-btn:hover {
  background: rgba(108,141,255,.16);
  border-color: rgba(108,141,255,.4);
  box-shadow: 0 0 12px rgba(108,141,255,.12);
  transform: translateY(-1px);
}
#tab-leaderboard .lb-empty {
  padding: 56px 24px;
  font-family: var(--ff-body);
  font-size: 13px;
  color: rgba(255,255,255,.48);
}
#tab-leaderboard .lb-loading {
  padding: 14px 12px;
  gap: 8px;
}
#tab-leaderboard .lb-skel-row {
  height: 58px;
  border-radius: 12px;
}
@media (max-width: 1120px) {
  #tab-leaderboard .lb-controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  #tab-leaderboard .lb-shell {
    padding: 12px 10px 22px;
    gap: 14px;
  }
  #tab-leaderboard .lb-hero-panel {
    padding: 16px 14px;
    gap: 14px;
  }
  #tab-leaderboard .lb-header {
    align-items: flex-start;
    gap: 12px;
  }
  #tab-leaderboard .lb-title {
    font-size: 20px;
  }
  #tab-leaderboard .lb-sub {
    font-size: 13px;
  }
  #tab-leaderboard .lb-header-actions {
    margin-left: 0;
    width: 100%;
    justify-content: space-between;
  }
  #tab-leaderboard .lb-refresh-btn {
    flex: 1 1 0;
    min-width: 0;
  }
  #tab-leaderboard .lb-controls {
    grid-template-columns: 1fr;
    gap: 10px;
    padding-top: 14px;
  }
  #tab-leaderboard .lb-kpi-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  #tab-leaderboard .lb-kpi {
    padding: 14px 14px 13px;
    border-right: 1px solid rgba(255,255,255,.07);
    border-bottom: 1px solid rgba(255,255,255,.07);
  }
  #tab-leaderboard .lb-kpi:nth-child(2n) {
    border-right: 0;
  }
  #tab-leaderboard .lb-kpi:nth-last-child(-n+2) {
    border-bottom: 0;
  }
  #tab-leaderboard .lb-kpi-val {
    font-size: 20px;
  }
  #tab-leaderboard .lb-table-wrap {
    background: transparent;
    border: 0;
    overflow: visible;
    box-shadow: none;
  }
  #tab-leaderboard #lbRows {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  #tab-leaderboard .lb-row {
    gap: 10px;
    padding: 14px;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.016));
    box-shadow: 0 18px 46px rgba(0,0,0,.20);
  }
  #tab-leaderboard .lb-cell-bot {
    padding-right: 54px;
  }
  #tab-leaderboard .lb-asset {
    font-size: 15px;
  }
  #tab-leaderboard .lb-bot-type {
    font-size: 10.5px;
  }
  #tab-leaderboard .lb-mobile-meta {
    display: flex;
    gap: 6px;
  }
  #tab-leaderboard .lb-copy-btn {
    width: 100%;
    min-height: 40px;
  }
}


/* ═══════════════════════════════════════
   Trading premium redesign
   ═══════════════════════════════════════ */
#tab-trading{padding:8px 0 92px;}
.pionex-layout{display:flex;flex-direction:column;gap:10px;overflow:visible;}
.trade-premium-shell,.trade-ticket-col,.trade-orderbook-col,.trade-terminal-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2) !important;box-shadow:var(--shadow-1);}
.trade-premium-shell{order:0;overflow:hidden;}
.trade-market-head{padding:12px 14px 0;align-items:flex-start !important;}
.trade-market-title{display:flex;flex-direction:column;gap:4px;min-width:0;}
.trade-market-kicker,.trade-ticket-kicker,.trade-orderbook-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.48);font-weight:700;}
.trade-market-pair-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.trade-market-pair{font-size:22px;font-weight:800;color:#fff;letter-spacing:-.03em;}
.trade-market-badge,.trade-ticket-badge,.trade-orderbook-badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid rgba(108,141,255,.26);background:rgba(108,141,255,.12);color:#d8e1ff;font-size:11px;font-weight:700;}
.trade-market-sub{font-size:12px;color:rgba(255,255,255,.52);}
.trade-market-live{display:flex;flex-direction:column;align-items:flex-end;gap:3px;padding-top:2px;}
.trade-market-live-k{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.46);}
.trade-market-live-v{font-size:30px;line-height:1;font-weight:800;color:#fff;font-family:var(--ff-mono);}
.trading-lower{order:1;display:grid;grid-template-columns:minmax(0,1.18fr) minmax(220px,.82fr);gap:10px;align-items:start;}
.trade-ticket-col,.trade-orderbook-col{min-width:0;max-height:none;}
.trade-ticket-col{order:0;overflow:visible;align-self:start;}
.trade-orderbook-col{order:1;padding:0;overflow:visible;display:flex;flex-direction:column;align-self:start;gap:8px;}
.trading-ticket{padding:12px;display:flex;flex-direction:column;gap:8px;min-height:0;}
.trade-ticket-head,.trade-orderbook-top{display:flex;justify-content:space-between;align-items:center;gap:8px;}
.trade-ticket-head h3,.trade-orderbook-title{margin:0;font-size:17px;font-weight:800;letter-spacing:-.02em;color:#fff;}
.trade-ticket-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
.trade-ticket-top-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;}
.trade-ticket-top-grid > label:first-child{grid-column:1 / -1;}
.trade-ticket-top-grid > label:not(.trade-field-span){display:grid;grid-template-rows:auto minmax(32px,auto);align-content:start;}
.trade-ticket-top-grid > label select{width:100%;}
.trade-ticket-top-grid,.trade-ticket-middle-grid,.trade-ticket-meta-grid{background:linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.016));border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:10px;}
.trade-ticket-middle-grid{gap:10px 8px;}
.trade-ticket-meta-grid{padding-top:9px;padding-bottom:9px;}
.trade-lev-inline{display:flex;flex-direction:column;gap:2px;min-width:0;}
.trade-field-span{grid-column:1 / -1;}
.trade-field-help{font-size:12px;color:rgba(255,255,255,.50);line-height:1.32;margin-top:4px;}
.trade-ticket-col label{gap:2px;font-size:11px;}
.trade-ticket-col input,.trade-ticket-col select{min-height:30px;padding:5px 8px;font-size:12.5px;}
.trade-slip-card,.trade-slider-card{border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:10px 11px;background:linear-gradient(180deg, rgba(20,28,40,.92), rgba(14,19,28,.98));box-shadow:inset 0 1px 0 rgba(255,255,255,.04);}
.trade-slider-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:7px;font-size:11px;color:rgba(255,255,255,.72);font-weight:700;}
.trade-balance-strip{background:rgba(108,141,255,.08);border-color:rgba(108,141,255,.16);margin-top:5px !important;gap:8px;padding:7px 9px;border-radius:12px;}
.trade-inline-warn{margin-top:5px;font-size:11px;color:#ffb84d;line-height:1.3;}
.trade-inline-summary{margin-top:5px;padding:9px 10px;border:1px solid rgba(255,255,255,.06);border-radius:12px;background:rgba(255,255,255,.025);font-size:11px;color:rgba(255,255,255,.72);line-height:1.35;}
.trade-actions{display:flex;flex-wrap:nowrap;align-items:stretch;gap:6px;}
.trade-actions .btn-buy,.trade-actions .btn-sell{flex:1 1 0;min-width:0;width:0;min-height:40px;font-size:13px;border-radius:11px;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1;white-space:nowrap;text-align:center;}
.trade-estimate-card{min-height:auto;padding:11px 12px 14px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:linear-gradient(180deg, rgba(17,23,34,.96), rgba(13,18,27,.98));box-shadow:none;}
.trade-estimate-title{font-weight:700;font-size:13px;margin-bottom:7px;color:#fff;}
.trade-estimate-grid{margin-top:0;gap:8px 10px;font-size:12px;grid-template-columns:1fr;}
.trade-estimate-card .lbl{display:block;font-size:10px;color:rgba(255,255,255,.46);margin-bottom:3px;}
.trade-estimate-card .val{display:block;font-size:14px;font-weight:800;color:#fff;font-family:var(--ff-mono);}
.trade-orderbook-book{display:flex;flex-direction:column;min-height:0;height:auto;width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;box-shadow:none;}
.trade-orderbook-top{padding:10px 12px 7px;border-bottom:1px solid var(--border);}
.trade-terminal-panel{margin-top:10px;min-height:246px;height:auto;overflow:hidden;}
.trade-terminal-panel .tp-tabs{padding:0 12px;gap:14px;border-bottom:1px solid var(--border);background:linear-gradient(180deg, rgba(108,141,255,.06), rgba(108,141,255,0));overflow-x:auto;}
.trade-terminal-panel .tp-tab{padding:11px 0 10px;font-size:12px;font-weight:700;color:rgba(255,255,255,.56);border-bottom:2px solid transparent;}
.trade-terminal-panel .tp-tab.active{color:#fff;border-bottom-color:var(--accent);}
.trade-terminal-panel .tp-body{flex:1;max-height:340px;overflow:auto;}
.trade-terminal-panel .tp-pane{height:auto;min-height:212px;overflow:auto;}
.trade-terminal-panel .tp-orders-toolbar{padding:8px 12px;border-bottom:1px solid var(--border);background:rgba(17,22,34,.96);}
.trade-terminal-panel .tp-table thead{background:rgba(17,22,34,.96);}
.trade-terminal-panel .tp-table th{padding:8px 10px;font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.44);}
.trade-terminal-panel .tp-table td{padding:8px 10px;}
.trade-terminal-panel .tp-empty{padding:34px 12px;color:rgba(255,255,255,.52);}
.ob-head{padding:4px 12px 3px;font-size:9px;letter-spacing:.04em;grid-template-columns:minmax(0,1fr) minmax(0,.92fr);color:rgba(255,255,255,.42);}
.ob-asks,.ob-bids{padding:0 8px 4px;flex:0 0 auto;}
.ob-row{position:relative;grid-template-columns:minmax(0,1fr) minmax(0,.92fr);padding:3px 6px;border-radius:8px;overflow:hidden;line-height:1.35;}
.ob-row::before{content:"";position:absolute;inset:0;opacity:.65;pointer-events:none;}
.ob-row.ask::before{background:linear-gradient(90deg, rgba(234,57,67,0), rgba(234,57,67,.10));}
.ob-row.bid::before{background:linear-gradient(90deg, rgba(22,199,132,0), rgba(22,199,132,.10));}
.ob-row > *{position:relative;z-index:1;}
.ob-mid-wrap{padding:10px 14px;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg, rgba(108,141,255,.08), rgba(108,141,255,.02));}
.ob-mid{padding:0;margin:0;border:none;font-size:24px;color:#fff;text-align:left;}
.ob-mid-sub{font-size:11px;color:rgba(255,255,255,.52);margin-top:4px;font-family:var(--ff-mono);}
@media (min-width: 1100px){#tab-trading .pionex-layout{display:grid;grid-template-columns:minmax(0,1fr) 228px 402px;gap:0;align-items:stretch;background:var(--bg2);border:1px solid var(--border);border-bottom:0;border-radius:var(--r2) var(--r2) 0 0;box-shadow:var(--shadow-1);overflow:hidden;}#tab-trading .trade-premium-shell,#tab-trading .trade-orderbook-col,#tab-trading .trade-ticket-col{background:transparent;border:0;box-shadow:none;border-radius:0 !important;padding:0;min-width:0;min-height:100%;}#tab-trading .trade-premium-shell{grid-column:1;grid-row:1;display:flex;flex-direction:column;border-right:1px solid var(--border);overflow:hidden;}#tab-trading .trading-lower{display:contents;}#tab-trading .trade-orderbook-col{grid-column:2;grid-row:1;display:flex;flex-direction:column;gap:0;min-width:228px;max-width:none;width:100%;border-right:1px solid var(--border);align-self:stretch;}#tab-trading .trade-ticket-col{grid-column:3;grid-row:1;min-width:402px;max-width:none;width:100%;align-self:stretch;overflow:visible;background:linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,0));}#tab-trading .trading-ticket{padding:10px 12px 12px 10px;background:transparent;border:0;box-shadow:none;border-radius:0;overflow:visible;}#tab-trading .trade-ticket-top-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}#tab-trading .trade-ticket-top-grid > label:first-child{grid-column:1 / -1;}#tab-trading .trade-lev-inline{grid-column:auto;}#tab-trading .trade-ticket-middle-grid,#tab-trading .trade-ticket-meta-grid{grid-template-columns:1fr;}#tab-trading .trade-ticket-col label{font-size:10.5px;}#tab-trading .trade-ticket-col input,#tab-trading .trade-ticket-col select{min-height:30px;padding:5px 8px;font-size:12px;}#tab-trading .trade-premium-shell .chart-head{padding:12px 14px 0;}#tab-trading .trade-premium-shell #tv_chart{display:flex;flex:1 1 auto;min-height:0 !important;height:100%;}#tab-trading .trade-premium-shell .hl-chart-shell{display:flex;flex-direction:column;gap:8px;height:100%;min-height:0 !important;}#tab-trading .trade-premium-shell .hl-chart-root{flex:1 1 auto;height:100% !important;min-height:520px !important;border:0 !important;border-radius:0 !important;box-shadow:none !important;}#tab-trading .trade-orderbook-book{display:grid;grid-template-rows:auto auto minmax(0,1fr) auto minmax(0,1fr);flex:1 1 auto;height:100%;min-height:0;background:transparent;border:0;border-radius:0;box-shadow:none;}#tab-trading .trade-orderbook-top{padding:12px 12px 8px;border-bottom:1px solid var(--border);}#tab-trading .ob-head{padding:4px 12px 3px;}#tab-trading .ob-asks,#tab-trading .ob-bids{padding:0 6px 2px;max-height:148px;overflow:hidden;}#tab-trading .ob-row{padding:2px 4px;font-size:10px;line-height:1.28;border-radius:6px;}#tab-trading .ob-mid-wrap{padding:8px 12px;}#tab-trading .ob-mid{font-size:22px;}#tab-trading .trade-orderbook-estimate{margin:0;padding:12px 12px 16px;border:0;border-top:1px solid var(--border);border-radius:0;background:transparent;min-height:88px;display:flex;flex-direction:column;justify-content:center;}#tab-trading .trade-terminal-panel{margin-top:0;border-top:1px solid var(--border);border-radius:0 0 var(--r2) var(--r2) !important;box-shadow:var(--shadow-1);}}
@media (max-width: 900px){.trade-market-pair{font-size:20px;}.trade-market-live-v{font-size:26px;}.trading-lower{grid-template-columns:minmax(0,1.08fr) minmax(132px,.92fr);gap:8px;}.trade-ticket-col,.trade-orderbook-col{max-height:none;}.trade-orderbook-col{gap:7px;}.trading-ticket{padding:10px;gap:6px;}.trade-ticket-grid{gap:6px;}.trade-ticket-top-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.trade-ticket-top-grid > label:first-child{grid-column:1 / -1;}.trade-ticket-middle-grid,.trade-ticket-meta-grid{grid-template-columns:1fr;}.trade-ticket-col input,.trade-ticket-col select{min-height:29px;padding:5px 7px;font-size:12px;}.trade-field-help{font-size:11px;line-height:1.25;margin-top:2px;}.trade-slip-card,.trade-slider-card,.trade-estimate-card{padding:8px 9px;}.trade-slider-head{margin-bottom:4px;font-size:11px;}.trade-actions{flex-direction:row;gap:6px;}.trade-actions .btn-buy,.trade-actions .btn-sell{width:auto;min-height:38px;font-size:12px;}.trade-ticket-head h3,.trade-orderbook-title{font-size:15px;}.trade-orderbook-badge{min-height:22px;padding:0 6px;font-size:9px;}.trade-orderbook-top{padding:8px 9px 5px;}.trade-terminal-panel{margin-top:8px;min-height:228px;}.trade-terminal-panel .tp-tabs{padding:0 10px;gap:12px;}.trade-terminal-panel .tp-tab{padding:10px 0 9px;font-size:12px;}.trade-terminal-panel .tp-body{max-height:304px;}.trade-terminal-panel .tp-table th,.trade-terminal-panel .tp-table td{padding:7px 8px;}.ob-head{padding:3px 9px 2px;}.ob-asks,.ob-bids{padding:0 5px 3px;max-height:154px;}.ob-mid-wrap{padding:5px 7px;}.ob-mid{font-size:18px;}.ob-mid-sub{font-size:10px;margin-top:2px;}.trade-estimate-title{font-size:12px;}.trade-estimate-grid{gap:5px;font-size:11px;}.trade-estimate-card .val{font-size:13px;}}
@media (max-width: 480px){#tab-trading{padding-top:6px;padding-bottom:102px;}.trade-market-head{padding:10px 10px 0;gap:8px;}.trade-market-live{align-items:flex-start;}.trade-market-live-v{font-size:24px;}.trading-lower{grid-template-columns:1fr;gap:7px;}.trade-ticket-col,.trade-orderbook-col{max-height:none;max-width:none;width:100%;}.trade-orderbook-col{gap:6px;}.trading-ticket{padding:8px;gap:5px;}.trade-ticket-grid{gap:5px;}.trade-ticket-top-grid,.trade-ticket-middle-grid,.trade-ticket-meta-grid{padding:6px;border-radius:10px;}.trade-ticket-head h3,.trade-orderbook-title{font-size:14px;}.trade-market-sub{font-size:11px;}.trade-orderbook-badge,.trade-market-badge,.trade-ticket-badge{padding:0 6px;font-size:9px;min-height:22px;}.trade-ticket-col input,.trade-ticket-col select{min-height:28px;padding:4px 7px;font-size:11.5px;}.trade-field-help{font-size:10px;line-height:1.22;}.trade-orderbook-top{padding:7px 8px 4px;}.trade-terminal-panel{margin-top:7px;min-height:212px;}.trade-terminal-panel .tp-tabs{padding:0 8px;gap:10px;}.trade-terminal-panel .tp-tab{padding:9px 0 8px;font-size:11px;}.trade-terminal-panel .tp-body{max-height:280px;}.trade-terminal-panel .tp-table th,.trade-terminal-panel .tp-table td{padding:6px 7px;}.trade-terminal-panel .tp-empty{padding:26px 10px;font-size:11px;}.ob-head{padding:2px 8px 1px;}.ob-asks,.ob-bids{padding:0 4px 2px;max-height:132px;}.ob-row{font-size:9px;gap:2px;padding:2px 4px;}.ob-mid-wrap{padding:4px 6px;}.ob-mid{font-size:16px;}.ob-mid-sub{font-size:9px;margin-top:1px;}.trade-actions{gap:5px;}.trade-actions .btn-buy,.trade-actions .btn-sell{min-height:36px;font-size:11px;}.trade-estimate-card{padding:8px;}.trade-estimate-title{font-size:11px;margin-bottom:5px;}.trade-estimate-grid{gap:5px;font-size:10px;}.trade-estimate-card .lbl{font-size:10px;}.trade-estimate-card .val{font-size:13px;}}
@media (min-width: 1100px){#tab-trading .ob-asks,#tab-trading .ob-bids{height:100%;max-height:none;}#tab-trading .ob-asks{justify-content:flex-end;padding-bottom:0;align-self:stretch;background:linear-gradient(180deg, rgba(234,57,67,.02), rgba(234,57,67,.08));}}

/* ── Creator desktop rebalance hotfix (20260413creator04) ── */
@media (min-width: 981px) {
  .nb-split {
    grid-template-columns: minmax(316px, 336px) minmax(0, 1fr) minmax(268px, 284px);
    gap: 16px;
  }
}

.nb-bot-form,
.nb-mp-card,
.nb-ob-card,
.nb-r-card {
  background: radial-gradient(circle at top left, rgba(108,141,255,.09), transparent 42%), linear-gradient(180deg, rgba(255,255,255,.038), rgba(255,255,255,.018));
  border-color: rgba(255,255,255,.07);
  box-shadow: 0 18px 46px rgba(0,0,0,.23);
}

.nb-market-shell {
  overflow: hidden;
}

.nb-market-overview {
  padding: 0 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.nb-market-kpis {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.nb-market-kpi {
  padding: 10px 11px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.014));
  min-width: 0;
}

.nb-market-kpi-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 5px;
}

.nb-market-kpi-value {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  overflow-wrap: anywhere;
}

.nb-market-kpi #nbDayChange.green,
#nbDayChange.green {
  color: var(--up);
}

.nb-market-kpi #nbDayChange.red,
#nbDayChange.red {
  color: var(--dn);
}

.nb-right-panel {
  gap: 12px;
}

.nb-stat-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.nb-stat-item {
  min-height: 72px;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 7px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.014));
}

.nb-s-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.nb-s-val {
  font-size: 14px;
  line-height: 1.2;
}

.nb-risk-block {
  padding: 16px;
}

.nb-risk-divider {
  margin: 0 16px;
}

.nb-tip {
  padding: 10px 11px;
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 12px;
  background: rgba(255,255,255,.018);
}

@media (min-width: 981px) and (max-width: 1180px) {
  .nb-split {
    grid-template-columns: minmax(292px, 308px) minmax(0, 1fr) minmax(244px, 258px);
  }
  .nb-stat-list {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 721px) and (max-width: 980px) {
  .nb-split {
    grid-template-columns: 300px minmax(0, 1fr);
  }
  .nb-market-overview {
    padding: 0 12px 12px;
  }
}
