/* ======================================================================
   BINANCE MOBILE DARK THEME – FULL STYLE (UPDATED + CLEAN + JS-MATCHED)
   Replace your style.css with this file

   Supports:
   - Home, Markets
   - Spot (BUY/SELL toggle, SL/TP modes, bottom tabs)
   - Futures (margin + leverage toggles, custom leverage input)
   - Signal widgets (spot/futures)
   - Live Spot Orders UI
   - Futures Positions + Open Orders panels
   - Backend flags labels
   ====================================================================== */

/* ======================================================================
   THEME TOKENS
   ====================================================================== */

:root {
  /* LIGHT THEME TOKENS (background white) */

  /* main palette */
  --bg-main: #ffffff;
  --bg-surface: #f5f7fa;
  --bg-surface-soft: #f0f2f5;
  --bg-surface-alt: #eef2f7;
  --bg-card: #ffffff;
  --bg-card-alt: #ffffff;

  --border-soft: #e5e7eb;
  --border-strong: #d1d5db;

  --text-main: #111827;
  --text-sub: #4b5563;
  --text-muted: #6b7280;
  --text-secondary: #4b5563;

  --accent: #f0b90b;
  --accent-yellow: #f0b90b;
  --accent-tab: #f0b90b;

  --green: #0ecb81;
  --red: #f6465d;
  --gray-pill: #e5e7eb;

  --nav-active: #111827;
  --nav-inactive: #6b7280;

  --purple: #a855f7;

  /* unified aliases */
  --bin-bg: var(--bg-main);
  --bin-surface: var(--bg-surface);
  --bin-surface-2: var(--bg-surface-alt);
  --bin-surface-3: var(--bg-surface-soft);

  --bin-border: var(--border-strong);
  --bin-border-soft: var(--border-soft);

  --bin-text: var(--text-main);
  --bin-sub: var(--text-sub);
  --bin-muted: var(--text-muted);

  --bin-yellow: var(--accent-yellow);
  --bin-green: var(--green);
  --bin-red: var(--red);

  --bin-focus-shadow: 0 0 0 2px rgba(240, 185, 11, 0.18);
}


/* ======================================================================
   RESET / BASE
   ====================================================================== */

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

html,
body {
  height: 100%;
}

body {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text",
    Roboto, sans-serif;
  background: #fff;
  color: var(--text-main);
  display: flex;
  justify-content: center;
  align-items: stretch;
  min-height: 100vh;
}

/* login page background */
body.dark {
  background: #fff;
}

/* ======================================================================
   APP SHELL
   ====================================================================== */

.app {
  width: 100%;
  max-width: 430px;
  background: var(--bg-main);
  padding: 12px 14px 4px;
  position: relative;
  min-height: 100vh;
}

/* SCREENS */
.screen {
  display: none;
}
.screen.active {
  display: block;
}

/* ======================================================================
   STATUS BAR (optional)
   ====================================================================== */

.status-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 4px 12px;
  font-size: 14px;
  color: var(--text-main);
}

.status-right {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
}

.status-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
  border: 2px solid #fff;
}

.battery {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: #1f2933;
  padding: 1px 4px;
  border-radius: 10px;
  font-size: 9px;
}

.battery-pill {
  width: 15px;
  height: 7px;
  border-radius: 4px;
  background: #22c55e;
}

/* ======================================================================
   TOP ROW / GENERIC HEADER UI
   ====================================================================== */

.top-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.top-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.icon-btn {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid var(--border-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-main);
  font-size: 16px;
  background: var(--bg-card);
}

.badge {
  min-width: 20px;
  height: 16px;
  border-radius: 999px;
  background: var(--accent-yellow);
  color: #000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 600;
}

/* segmented generic */
.segmented {
  display: inline-flex;
  background: var(--bg-surface);
  padding: 3px;
  border-radius: 999px;
  border: 1px solid var(--border-soft);
  gap: 2px;
}

.segment {
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 12px;
  color: var(--text-sub);
  cursor: pointer;
  white-space: nowrap;
}

.segment.active {
  background: #272a30;
  color: var(--accent-yellow);
  font-weight: 600;
}

.top-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* ======================================================================
   TOTAL VALUE CARD (HOME)
   ====================================================================== */

.total-card {
  background: var(--bg-card);
  border-radius: 22px;
  padding: 14px 14px 12px;
  margin-bottom: 12px;
  border: 1px solid var(--border-soft);
}

.total-card-header {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--text-sub);
  margin-bottom: 6px;
}

.total-card-header span:last-child {
  font-size: 14px;
}

.total-card-value {
  font-size: 32px;
  font-weight: 600;
  letter-spacing: 0.03em;
  margin-bottom: 4px;
}

.total-card-pnl {
  font-size: 12px;
  color: var(--green);
  text-align: left;
  display: flex;
  justify-content: flex-start;
  gap: 8px;
  margin-bottom: 2px;
}

/* ======================================================================
   CARDS ROW (HOME)
   ====================================================================== */

.cards-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}

.card {
  background: var(--bg-card);
  border-radius: 18px;
  padding: 12px;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border-soft);
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
  font-size: 11px;
  color: var(--text-sub);
}

.card-title {
  font-weight: 500;
}

.fiat-tag {
  background: rgba(14, 203, 129, 0.12);
  color: var(--green);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 10px;
}

.pair {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 12px;
}

.token-circle {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: #02c076;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

.pair-text-main {
  font-size: 13px;
  font-weight: 500;
}

.pair-text-sub {
  font-size: 11px;
  color: var(--text-sub);
}

.pair-rate {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.card-balance-label {
  font-size: 11px;
  color: var(--text-sub);
  margin-top: 6px;
}

.card-balance-amount {
  font-size: 13px;
  font-weight: 500;
}

.tiny-chart {
  position: absolute;
  right: 12px;
  bottom: 18px;
  width: 40%;
  height: 40px;
  background: linear-gradient(90deg, rgba(14, 203, 129, 0.2), #0ecb81);
  mask-image: linear-gradient(90deg, transparent, black 20%, black 80%, transparent);
  border-radius: 8px;
}

/* ======================================================================
   TABS ROW (Favorites / Hot / ...)
   ====================================================================== */

.tabs-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  margin: 10px 0 8px;
  font-size: 13px;
}

.tab-pill {
  position: relative;
  padding-bottom: 6px;
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
}

.tab-pill.active {
  color: var(--text-main);
  font-weight: 500;
}

.tab-pill.active::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-tab);
}

.tab-group {
  display: flex;
  gap: 18px;
  font-size: 12px;
  margin-bottom: 4px;
  color: var(--text-muted);
}

.tab-group span {
  cursor: pointer;
}

.tab-group span.active {
  color: var(--text-main);
  font-weight: 500;
}

/* ======================================================================
   CRYPTO LIST (HOME + MARKETS)
   ====================================================================== */

.list-card {
  background: var(--bg-card-alt);
  border-radius: 22px;
  padding: 12px 14px 10px;
  margin-bottom: 14px;
  border: 1px solid var(--border-soft);
}

.list-header {
  display: grid;
  grid-template-columns: 2fr 1.4fr 1.2fr;
  font-size: 11px;
  color: var(--text-sub);
  margin-bottom: 6px;
}

.list-row {
  display: grid;
  grid-template-columns: 2fr 1.4fr 1.2fr;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid #11151f;
  font-size: 13px;
  cursor: pointer;
}

.list-row:first-of-type {
  border-top: none;
}

.coin-name {
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
}

.coin-hot-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #fff, var(--accent));
}

.price-main {
  font-size: 13px;
  text-align: right;
}

.price-sub {
  font-size: 10px;
  color: var(--text-sub);
  text-align: right;
}

.change-pill {
  justify-self: flex-end;
  min-width: 64px;
  text-align: center;
  border-radius: 999px;
  padding: 5px 4px;
  font-size: 11px;
  font-weight: 500;
  color: #fff;
}

.change-up {
  background: var(--green);
}
.change-down {
  background: var(--red);
}
.change-flat {
  background: var(--gray-pill);
}

.view-more {
  margin-top: 10px;
  text-align: center;
  color: var(--text-sub);
  font-size: 12px;
}

/* ======================================================================
   DISCOVER SECTION
   ====================================================================== */

.discover-section-title {
  display: flex;
  gap: 18px;
  align-items: center;
  font-size: 13px;
  margin-bottom: 10px;
  color: var(--text-sub);
}

.discover-section-title .active {
  color: var(--text-main);
  font-weight: 500;
  position: relative;
  padding-bottom: 6px;
}

.discover-section-title .active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-tab);
}

.banner {
  background: #272a30;
  border-radius: 999px;
  padding: 8px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: #f4f4ff;
  margin-bottom: 14px;
}

.banner-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.banner-logo {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: #1e2329;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}

.banner-text-main {
  font-weight: 500;
}

.banner-tag {
  background: rgba(0, 0, 0, 0.25);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 10px;
  margin-left: 4px;
}

.banner-right-pill {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ======================================================================
   PROFILE CARD
   ====================================================================== */

.profile-card {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 65px;
}

.profile-avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: #1d2535;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}

.profile-text-main {
  font-size: 13px;
  font-weight: 500;
}

.profile-text-sub {
  font-size: 11px;
  color: var(--text-sub);
}

.profile-badge {
  margin-left: auto;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--accent-yellow);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #000;
  font-size: 14px;
}

/* ======================================================================
   BOTTOM NAV
   ====================================================================== */

.bottom-nav {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 100%;
  max-width: 430px;
  padding: 6px 18px 10px;
  background: linear-gradient(to top, rgba(255,255,255,0.92), rgba(255,255,255,0.75), transparent);
  backdrop-filter: blur(18px);
  z-index: 50;
}

.bottom-nav-inner {
  background: var(--bg-card);
  border-radius: 22px 22px 0 0;
  padding: 8px 24px 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--border-soft);
}

.nav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: 10px;
  color: var(--nav-inactive);
  cursor: pointer;
  user-select: none;
}

.nav-item span.icon {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  background: transparent;
}

.nav-item.active {
  color: var(--nav-active);
  font-weight: 500;
}

.nav-item.active span.icon {
  background: var(--accent-yellow);
  color: #000;
}

/* responsive cards */
@media (max-width: 360px) {
  .cards-row {
    grid-template-columns: 1fr;
  }
}

/* ======================================================================
   MARKETS SCREEN
   ====================================================================== */

.market-header {
  margin-bottom: 10px;
}

.market-search {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 10px;
  border-radius: 18px;
  background: var(--bg-surface);
  border: 1px solid var(--border-soft);
  font-size: 13px;
  color: var(--text-sub);
  margin-bottom: 12px;
}

.market-search-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.market-search-icon {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid #343842;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
}

.market-search-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
}

.market-top-tabs {
  display: flex;
  gap: 18px;
  font-size: 14px;
  margin-bottom: 8px;
}

.market-top-tab {
  position: relative;
  padding-bottom: 6px;
  color: var(--text-muted);
  cursor: pointer;
}

.market-top-tab.active {
  color: var(--text-main);
  font-weight: 500;
}

.market-top-tab.active::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-tab);
}

.market-subtabs,
.market-chains {
  display: flex;
  gap: 14px;
  font-size: 12px;
  margin-bottom: 8px;
  color: var(--text-muted);
}

.market-subtabs span,
.market-chains span {
  cursor: pointer;
  white-space: nowrap;
}

.market-subtabs span.active,
.market-chains span.active {
  color: #fff;
  font-weight: 500;
}

.market-chains {
  align-items: center;
}

.market-chains .right-icon {
  margin-left: auto;
  font-size: 16px;
}

.market-list-card {
  background: transparent;
  border-radius: 0;
  padding: 10px 0 70px;
  border: none;
}

.market-list-card .list-row {
  border-top-color: #1f2933;
}

/* ======================================================================
   COMMON BUTTONS / MSG
   ====================================================================== */

.btn-primary {
  background: var(--green);
  border-radius: 999px;
  border: none;
  color: #041b11;
  font-weight: 600;
  padding: 0.6rem 1.4rem;
  cursor: pointer;
  font-size: 0.9rem;
}

.btn-outline {
  background: transparent;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.7);
  color: #e5e7eb;
  padding: 0.55rem 1.3rem;
  cursor: pointer;
}

.btn-outline.danger {
  border-color: rgba(248, 113, 113, 0.85);
  color: #fecaca;
}

.full-width {
  width: 100%;
}

.msg {
  margin-top: 0.4rem;
  font-size: 0.78rem;
}

.msg.error {
  color: #fb7185;
}
.msg.success {
  color: #22c55e;
}

/* =====================================================================
   FORM CONTROL NORMALIZATION (Spot + Futures + Widgets)
   ===================================================================== */

.screen-spot select,
.screen-futures select,
.screen-spot input[type="number"],
.screen-futures input[type="number"],
.signal-toolbar select,
.signal-toolbar input {
  background: var(--bin-surface-2);
  color: var(--bin-text);
  border: 1px solid var(--bin-border);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 12px;
  outline: none;
  width: 100%;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

/* select arrow */
.screen-spot select,
.screen-futures select,
.signal-toolbar select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--bin-sub) 50%),
    linear-gradient(135deg, var(--bin-sub) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 13px) calc(50% - 3px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 28px;
}

.screen-spot input::placeholder,
.screen-futures input::placeholder {
  color: #6b7280;
}

/* focus glow */
.screen-spot select:focus,
.screen-futures select:focus,
.screen-spot input:focus,
.screen-futures input:focus,
.signal-toolbar select:focus,
.signal-toolbar input:focus {
  border-color: var(--bin-yellow);
  box-shadow: var(--bin-focus-shadow);
  background: #20252b;
}

/* =====================================================================
   SPOT SCREEN (TRADE)
   ===================================================================== */

.screen-spot {
  margin-top: 4px;
}

/* inner phone frame */
.screen-spot .spot-phone {
  width: 100%;
  background: var(--bg-card);
  border-radius: 22px;
  padding: 8px 8px 12px;
  border: 1px solid var(--border-soft);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6);
}

.screen-spot .spot-phone .status-bar {
  font-size: 11px;
  color: #9aa4bf;
  padding: 2px 4px 4px;
}

/* top nav */
.screen-spot .top-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 4px 2px;
  font-size: 14px;
}

.screen-spot .top-nav-left {
  display: flex;
  align-items: baseline;
  gap: 6px;
}

#spot-pair-symbol {
  font-weight: 600;
  letter-spacing: 0.4px;
}

.screen-spot .pair-change {
  font-size: 11px;
  color: var(--green);
}

.screen-spot .top-nav-right {
  display: flex;
  gap: 12px;
  font-size: 13px;
  color: #9aa4bf;
}

.screen-spot .top-nav-right span.active {
  color: #ffffff;
  font-weight: 600;
  position: relative;
}

.screen-spot .top-nav-right span.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -6px;
  height: 2px;
  border-radius: 999px;
  background: var(--green);
}

/* layout */
.screen-spot .trade-layout {
  display: grid;
  grid-template-columns: 1.1fr 1.6fr;
  gap: 10px;
  margin-top: 10px;
}

/* orderbook left */
.screen-spot .orderbook {
  background: var(--bin-surface);
  border-radius: 12px;
  padding: 10px 8px;
  border: 1px solid var(--bin-border-soft);
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 11px;
}

.screen-spot .orderbook-header {
  display: flex;
  justify-content: space-between;
  color: #5f6b85;
  font-size: 10px;
}

.screen-spot .order-row {
  display: flex;
  justify-content: space-between;
  margin: 1px 0;
  font-size: 10px;
}

.screen-spot .order-row span:first-child {
  width: 44%;
}
.screen-spot .order-row span:last-child {
  width: 30%;
  text-align: right;
}

.screen-spot .order-row.sell span:first-child {
  color: var(--red);
}
.screen-spot .order-row.buy span:first-child {
  color: var(--green);
}

.screen-spot .last-price {
  text-align: center;
  padding: 4px 0 1px;
}

.screen-spot .last-price-main {
  color: var(--green);
  font-size: 18px;
  font-weight: 700;
}

.screen-spot .last-price-sub {
  font-size: 11px;
  color: #9aa4bf;
}

.screen-spot .depth-bar {
  margin-top: 6px;
  border-radius: 999px;
  overflow: hidden;
  background: #11151f;
  height: 6px;
  position: relative;
}

.screen-spot .depth-bar-buy {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 68%;
  background: rgba(14, 203, 129, 0.5);
}

.screen-spot .depth-bar-sell {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 32%;
  background: rgba(246, 70, 93, 0.6);
}

.screen-spot .orderbook-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 6px;
  font-size: 10px;
  color: #9aa4bf;
}

.screen-spot .amount-step {
  padding: 4px 6px;
  border-radius: 6px;
  background: #1c2027;
  border: 1px solid var(--border-soft);
  font-size: 10px;
}



/* NEW: Binance-style bid/ask tape under spot market price */
.screen-spot .orderbook-tape{
  flex: 1 1 auto;
  min-height: 0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--bin-border-soft);
  margin-top: 4px;
}

.screen-spot .orderbook-tape .tape-col{
  background: #0f141a;
  display: flex;
  flex-direction: column;
  min-height: 0;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  overflow: hidden;
}

.screen-spot .orderbook-tape .tape-title{
  padding: 6px 8px;
  font-size: 10px;
  color: #8fa3bb;
  border-bottom: 1px solid var(--border-soft);
  display:flex;
  align-items:center;
  justify-content: space-between;
}

.screen-spot .orderbook-tape .tape-rows{
  flex: 1 1 auto;
  min-height: 0;
  padding: 6px 8px 8px;
  display:flex;
  flex-direction:column;
  justify-content: flex-end; /* push rows down until space ends */
  gap: 4px;
}

.screen-spot .orderbook-tape .tape-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 8px;
  padding: 2px 4px;
  border-radius: 6px;
  font-size: 10px;
}

.screen-spot .orderbook-tape .tape-row .price,
.screen-spot .orderbook-tape .tape-row .qty{
  font-variant-numeric: tabular-nums;
}

.screen-spot .orderbook-tape .tape-row .qty{
  color:#9aa4bf;
}

.screen-spot .orderbook-tape .tape-row.ask .price{ color: var(--red); }
.screen-spot .orderbook-tape .tape-row.bid .price{ color: var(--green); }

.screen-spot .orderbook-tape .tape-row.flash-up{ animation: obFlashUp 650ms ease; }
.screen-spot .orderbook-tape .tape-row.flash-down{ animation: obFlashDown 650ms ease; }

@keyframes obFlashUp{
  0%{ background: rgba(14,203,129,0.18); }
  100%{ background: transparent; }
}
@keyframes obFlashDown{
  0%{ background: rgba(246,70,93,0.18); }
  100%{ background: transparent; }
}


/* NEW: Binance-style bid/ask tape under futures market price */
.screen-futures .orderbook-tape{
  flex: 1 1 auto;
  min-height: 0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--bin-border-soft);
  margin-top: 4px;
}

.screen-futures .orderbook-tape .tape-col{
  background: #0f141a;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.screen-futures .orderbook-tape .tape-title{
  padding: 6px 8px;
  font-size: 10px;
  color: #8fa3bb;
  border-bottom: 1px solid var(--border-soft);
  display:flex;
  align-items:center;
  justify-content: space-between;
}

.screen-futures .orderbook-tape .tape-rows{
  flex: 1 1 auto;
  min-height: 0;
  padding: 6px 8px 8px;
  display:flex;
  flex-direction:column;
  justify-content: flex-end; /* push rows down until space ends */
  gap: 4px;
}

.screen-futures .orderbook-tape .tape-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 8px;
  padding: 2px 4px;
  border-radius: 6px;
  font-size: 10px;
}

.screen-futures .orderbook-tape .tape-row .price,
.screen-futures .orderbook-tape .tape-row .qty{
  font-variant-numeric: tabular-nums;
}

.screen-futures .orderbook-tape .tape-row .qty{
  color:#9aa4bf;
}

.screen-futures .orderbook-tape .tape-row.ask .price{ color: var(--red); }
.screen-futures .orderbook-tape .tape-row.bid .price{ color: var(--green); }

.screen-futures .orderbook-tape .tape-row.flash-up{ animation: obFlashUp 650ms ease; }
.screen-futures .orderbook-tape .tape-row.flash-down{ animation: obFlashDown 650ms ease; }

/* Futures leverage typing + available balance placement */
.screen-futures .lev-typed-wrap{
  display:flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  min-width: 92px;
}

.screen-futures .lev-typed-wrap #fut-custom-leverage{
  width: 82px;
  background: #1b2026;
  border: 1px solid var(--bin-border-soft);
  border-radius: 12px;
  padding: 6px 8px;
  text-align: center;
  font-weight: 700;
  color: #e6eef7;
}

.screen-futures .avbl-inline{
  font-size: 10px;
  font-weight: 700;
  color: var(--accent-yellow);
  white-space: nowrap;
}

/* price pulse on main market price */
.screen-spot .last-price-main.pulse-up{ animation: pricePulseUp 650ms ease; }
.screen-spot .last-price-main.pulse-down{ animation: pricePulseDown 650ms ease; }

@keyframes pricePulseUp{
  0%{ color: var(--green); text-shadow: 0 0 0 rgba(14,203,129,0); }
  35%{ color: #bff7df; text-shadow: 0 0 14px rgba(14,203,129,0.25); }
  100%{ color: var(--green); text-shadow: 0 0 0 rgba(14,203,129,0); }
}
@keyframes pricePulseDown{
  0%{ color: var(--red); text-shadow: 0 0 0 rgba(246,70,93,0); }
  35%{ color: #ffc0c9; text-shadow: 0 0 14px rgba(246,70,93,0.20); }
  100%{ color: var(--red); text-shadow: 0 0 0 rgba(246,70,93,0); }
}

/* trade panel right */
.screen-spot .trade-panel {
  background: var(--bin-surface);
  border-radius: 12px;
  padding: 10px;
  border: 1px solid var(--bin-border-soft);
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 11px;
}

/* BUY / SELL toggle */
.screen-spot .buy-sell-toggle {
  display: flex;
  background: #1e2329;
  border-radius: 999px;
  padding: 2px;
  font-size: 12px;
}

.screen-spot .toggle-btn {
  flex: 1;
  text-align: center;
  padding: 6px 0;
  border-radius: 999px;
  cursor: pointer;
  color: #9aa4bf;
  user-select: none;
}

.screen-spot .toggle-btn.active-buy {
  background: var(--green);
  color: #041b11;
  font-weight: 700;
}

.screen-spot .toggle-btn.active-sell {
  background: var(--red);
  color: #2b090c;
  font-weight: 700;
}

/* fields */
.screen-spot .field {
  margin-top: 6px;
}

.screen-spot .field-label {
  font-size: 10px;
  color: #9aa4bf;
  margin-bottom: 2px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.screen-spot .field-input {
  background: var(--bin-surface-2);
  border: 1px solid var(--bin-border);
  border-radius: 12px;
  padding: 8px 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  font-size: 12px;
}

/* Spot inline number inputs (JS uses these IDs) */
#spot-amount-asset,
#spot-stop-loss,
#spot-take-profit {
  background: transparent;
  border: none;
  outline: none;
  color: var(--bin-text);
  padding: 2px 0;
  font-size: 12px;
  width: 100%;
}

#spot-stop-loss,
#spot-take-profit {
  text-align: left;
}

/* suffix */
.screen-spot .suffix {
  font-size: 10px;
  color: #9aa4bf;
  margin-left: 6px;
  white-space: nowrap;
}

/* price emphasis (JS updates these IDs) */
#spot-price-display,
#spot-price-display-copy {
  color: var(--green);
  font-weight: 700;
}

/* total field */
#spot-total-usdt {
  color: var(--bin-text);
  font-weight: 700;
}

/* available row */
.screen-spot .avbl-row {
  margin: 4px 0 2px;
  font-size: 10px;
  color: #9aa4bf;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.screen-spot .avbl-row .value {
  color: var(--accent-yellow);
  font-weight: 500;
}

/* =====================================================================
   SL/TP MODE BUTTONS (Spot + Futures)
   ===================================================================== */

.sl-tp-mode {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
}

.sl-tp-mode .mode-btn {
  border: 1px solid var(--bin-border);
  background: #1b2026;
  color: #9aa4bf;
  font-size: 10px;
  padding: 4px 10px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.sl-tp-mode .mode-btn.active {
  background: var(--bin-yellow);
  color: #000;
  border-color: transparent;
  font-weight: 700;
  box-shadow: 0 6px 14px rgba(240, 185, 11, 0.18);
}

.sl-tp-mode .mode-hint {
  margin-left: auto;
  font-size: 10px;
  color: #636b8f;
}

/* =====================================================================
   RANGE SLIDERS (Spot + Futures)
   ===================================================================== */

#spot-amount-slider,
#fut-amount-slider {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: #2b3139;
  border-radius: 999px;
  outline: none;
}

#spot-amount-slider::-webkit-slider-thumb,
#fut-amount-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--bin-yellow);
  border: 2px solid #000;
  box-shadow: 0 0 0 2px rgba(240, 185, 11, 0.2);
  cursor: pointer;
}

#spot-amount-slider::-moz-range-thumb,
#fut-amount-slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--bin-yellow);
  border: 2px solid #000;
  box-shadow: 0 0 0 2px rgba(240, 185, 11, 0.2);
  cursor: pointer;
}

#spot-amount-slider::-webkit-slider-runnable-track,
#fut-amount-slider::-webkit-slider-runnable-track {
  height: 4px;
  background: #2b3139;
  border-radius: 999px;
}

#spot-amount-slider::-moz-range-track,
#fut-amount-slider::-moz-range-track {
  height: 4px;
  background: #2b3139;
  border-radius: 999px;
}

/* =====================================================================
   SLIDER META BLOCKS (JS IDs)
   ===================================================================== */

/* Spot slider meta */
.slider-meta {
  background: #11151f;
  border: 1px solid var(--bin-border-soft);
  border-radius: 12px;
  padding: 8px 10px;
  margin-top: 6px;
}

.slider-meta-top {
  display: flex;
  gap: 6px;
  align-items: center;
  font-size: 10px;
  color: #9aa4bf;
}

.slider-meta-bottom {
  margin-top: 2px;
  font-size: 12px;
  font-weight: 700;
  color: var(--bin-text);
}

/* Futures slider meta */
.fut-slider-meta {
  background: #0f1422;
  border: 1px solid #1c2233;
  border-radius: 12px;
  padding: 8px 10px;
  margin-top: 4px;
}

/* =====================================================================
   SPOT ACTION BUTTON (JS: #spot-action-btn)
   ===================================================================== */

#spot-action-btn {
  background: var(--bin-green);
  color: #041b11;
  border: none;
  border-radius: 16px;
  padding: 11px 0;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  width: 100%;
  box-shadow: 0 12px 24px rgba(14, 203, 129, 0.28);
  transition: transform 0.12s ease, filter 0.12s ease, background 0.12s ease;
}

#spot-action-btn.danger {
  background: var(--bin-red);
  color: #2b090c;
  box-shadow: 0 12px 24px rgba(246, 70, 93, 0.25);
}

#spot-action-btn:active {
  transform: translateY(1px);
  filter: brightness(0.98);
}

/* =====================================================================
   SPOT BOTTOM TABS + PANELS (JS-driven)
   ===================================================================== */

#spot-bottom-tabs,
.screen-spot .bottom-tabs {
  margin-top: 10px;
  padding: 0 2px;
  font-size: 11px;
  color: #5f6b85;
  border-bottom: 1px solid #171b27;
  display: flex;
  gap: 20px;
}

#spot-bottom-tabs span,
.screen-spot .bottom-tabs span {
  padding: 6px 0;
  cursor: pointer;
  user-select: none;
}

#spot-bottom-tabs span.active,
.screen-spot .bottom-tabs span.active {
  color: #ffffff;
  position: relative;
  font-weight: 600;
}

#spot-bottom-tabs span.active::after,
.screen-spot .bottom-tabs span.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -4px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-yellow);
}

/* Panels */
.spot-tab-panels {
  margin-top: 6px;
}

.spot-panel {
  display: none;
}
.spot-panel.active {
  display: block;
}

/* simple card/list for holdings/grid */
.simple-card {
  background: #181a20;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  padding: 10px 10px 8px;
  margin-top: 8px;
}

.simple-card-title {
  font-size: 11px;
  color: #cbd5f5;
  margin-bottom: 8px;
  font-weight: 700;
}

.simple-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 11px;
}

.simple-list.muted {
  color: #636b8f;
}

.simple-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
  padding: 6px 4px;
  border-bottom: 1px solid #161b2a;
}

.simple-row:last-child {
  border-bottom: none;
}

.simple-row .asset {
  color: #fff;
  font-weight: 600;
}

.simple-row .qty {
  text-align: right;
}

.simple-row .muted {
  text-align: right;
  color: #636b8f;
}

/* =====================================================================
   SPOT LIVE ORDERS (JS: #spot-live-orders)
   ===================================================================== */

#spot-live-orders {
  margin-top: 6px;
  font-size: 11px;
  color: #9aa4bf;
}

.live-orders {
  background: #121722;
  border: 1px solid #1c2233;
  border-radius: 12px;
  padding: 10px 10px 8px;
}

.live-order-row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding: 8px 2px 6px;
}

.live-order-row:last-child {
  border-bottom: none;
}

.live-order-main {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
}

.order-side {
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
}

.order-side.buy {
  color: var(--green);
}
.order-side.sell {
  color: var(--red);
}

.live-order-type {
  color: #8b93b8;
}

.live-order-price {
  margin-left: auto;
  font-weight: 600;
  color: #e6eef7;
}


.live-order-time{
  margin-left: 8px;
  font-size: 10px;
  color: #9aa4bf;
  padding: 2px 7px;
  border-radius: 999px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  font-variant-numeric: tabular-nums;
}
.live-order-sub {
  margin-top: 2px;
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: #8b93b8;
}

/* =====================================================================
   FUTURES SCREEN
   ===================================================================== */

.screen-futures {
  margin-top: 4px;
}

.screen-futures .fut-screen {
  width: 100%;
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  padding: 8px 8px 12px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6);
}

/* top bar */
.screen-futures .top-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 8px 8px;
  font-size: 13px;
  color: #8b93b8;
}

.screen-futures .top-bar-left {
  display: flex;
  gap: 10px;
  align-items: center;
}

.screen-futures .top-bar-title span:first-child {
  color: #ffffff;
  font-weight: 700;
}

.screen-futures .top-tabs {
  display: flex;
  gap: 12px;
  font-size: 12px;
}

.screen-futures .top-tabs span {
  opacity: 0.55;
  cursor: pointer;
}

.screen-futures .top-tabs span.active {
  opacity: 1;
  color: #ffffff;
  font-weight: 600;
}

.screen-futures .top-bar-right {
  display: flex;
  gap: 10px;
  align-items: center;
  font-size: 18px;
  color: #8b93b8;
}

/* pair header */
.screen-futures .pair-header {
  padding: 6px 10px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.screen-futures .pair-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.screen-futures .pair-symbol {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 16px;
  font-weight: 700;
}

.screen-futures .pair-symbol .badge {
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  font-size: 11px;
  color: #636b8f;
  min-width: 0;
  height: auto;
}

.screen-futures .pair-change {
  font-size: 13px;
  color: var(--green);
  font-weight: 600;
}

.screen-futures .pair-sub {
  font-size: 11px;
  color: #636b8f;
  display: flex;
  gap: 6px;
  align-items: center;
}

.screen-futures .pair-right {
  display: flex;
  gap: 10px;
  font-size: 18px;
  color: #636b8f;
}

/* layout */
.screen-futures .main-content.fut-main {
  display: grid;
  grid-template-columns: 1.1fr 1.1fr;
  gap: 6px;
  padding: 4px 4px 6px;
}

/* orderbook */
.screen-futures .orderbook {
  background: var(--bin-surface);
  border-radius: 18px;
  padding: 10px 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border: 1px solid var(--bin-border-soft);
}

.screen-futures .orderbook-header {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: #636b8f;
  margin-bottom: 4px;
}

.screen-futures .order-lines {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
  font-size: 12px;
}

.screen-futures .order-row {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  align-items: center;
}

.screen-futures .price-sell {
  color: var(--red);
}
.screen-futures .price-buy {
  color: var(--green);
}

.screen-futures .amount {
  text-align: right;
  color: #8b93b8;
}

.screen-futures .orderbook-mid {
  text-align: center;
  margin: 6px 0;
}

.screen-futures .mid-price-main {
  font-size: 17px;
  font-weight: 700;
  color: var(--green);
}

.screen-futures .mid-price-sub {
  font-size: 11px;
  color: #636b8f;
}

.screen-futures .orderbook-bottom {
  margin-top: auto;
  font-size: 11px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
  color: #8b93b8;
}

.screen-futures .volume-bar {
  flex: 1;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(to right, var(--green) 75%, var(--red) 75%);
}

/* panel form */
.screen-futures .panel {
  background: var(--bin-surface);
  border-radius: 18px;
  padding: 10px 8px 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border: 1px solid var(--bin-border-soft);
}

.screen-futures .panel-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
  font-size: 11px;
}

/* Futures segmented */
.screen-futures .segmented {
  display: inline-flex;
  background: #1e2329;
  border-radius: 999px;
  padding: 2px;
  gap: 2px;
  border: 1px solid var(--bin-border-soft);
}

.screen-futures .segmented button {
  border: none;
  outline: none;
  padding: 3px 8px;
  font-size: 11px;
  border-radius: 999px;
  background: transparent;
  color: #636b8f;
  cursor: pointer;
}

.screen-futures .segmented.small button {
  padding: 3px 6px;
}

.screen-futures .segmented button.active {
  background: #2b3139;
  color: #ffffff;
  font-weight: 600;
}

.screen-futures .panel-label {
  font-size: 11px;
  color: #636b8f;
  margin-bottom: 2px;
}

.screen-futures .input {
  background: var(--bin-surface-3);
  border-radius: 12px;
  border: 1px solid #1f2636;
  padding: 8px 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  gap: 8px;
}

.screen-futures .input span.unit {
  font-size: 11px;
  color: #8b93b8;
}

/* Futures amount / interval inline fields */
#fut-amount,
#fut-stop-loss,
#fut-take-profit,
#fut-interval,
#fut-custom-leverage {
  background: transparent;
  border: none;
  outline: none;
  color: var(--bin-text);
  padding: 2px 0;
  font-size: 12px;
  width: 100%;
}

/* custom leverage input visual emphasis */
#fut-custom-leverage {
  text-align: center;
  font-weight: 700;
  color: #e6eef7;
}

/* =====================================================================
   FUTURES TABS (Positions / Open Orders)
   JS: #fut-pos-tab, #fut-orders-tab
   ===================================================================== */

.screen-futures .tabs {
  display: flex;
  padding: 6px 10px 2px;
  border-top: 1px solid #161b2a;
  font-size: 12px;
  gap: 18px;
  margin-top: 4px;
}

.screen-futures .tab,
#fut-pos-tab,
#fut-orders-tab {
  position: relative;
  padding-bottom: 4px;
  color: #636b8f;
  cursor: pointer;
  user-select: none;
}

.screen-futures .tab.active,
#fut-pos-tab.active,
#fut-orders-tab.active {
  color: #ffffff;
  font-weight: 600;
}

.screen-futures .tab.active::after,
#fut-pos-tab.active::after,
#fut-orders-tab.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-yellow);
}

/* panels container */
.fut-panels {
  margin: 0 6px 8px;
}

.fut-panel {
  display: none;
}
.fut-panel.active {
  display: block;
}

/* ======================================================================
   FUTURES POSITIONS + OPEN ORDERS TABLES
   ====================================================================== */

.fut-pos-header {
  display: grid;
  grid-template-columns: 1.2fr 1fr 0.8fr 1fr 1fr 1fr 1fr 1fr 1fr;
  gap: 6px;
  padding: 8px 10px;
  border-bottom: 1px solid #1f2636;
  font-size: 10px;
  color: var(--text-secondary);
}

.fut-pos-body {
  max-height: 200px;
  overflow: auto;
}

.fut-pos-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr 0.8fr 1fr 1fr 1fr 1fr 1fr 1fr;
  gap: 6px;
  padding: 8px 10px;
  font-size: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.fut-pos-row.empty {
  display: block;
  color: var(--text-secondary);
}

.fut-pos-row .sym {
  color: #fff;
  font-weight: 700;
}

/* futures open orders table */
.fut-ord-header {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.8fr 0.8fr;
  gap: 6px;
  padding: 8px 10px;
  border-bottom: 1px solid #1f2636;
  font-size: 10px;
  color: var(--text-secondary);
}

.fut-ord-body {
  max-height: 200px;
  overflow: auto;
}

.fut-ord-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.8fr 0.8fr;
  gap: 6px;
  padding: 8px 10px;
  font-size: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.fut-ord-row.empty {
  display: block;
  color: var(--text-secondary);
}

.fut-ord-row .buy {
  color: var(--green);
  font-weight: 700;
}

.fut-ord-row .sell {
  color: var(--red);
  font-weight: 700;
}

/* =====================================================================
   REAL / SIM TOGGLES
   ===================================================================== */

.real-sim-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 6px;
  gap: 8px;
}

.real-sim-row .muted {
  font-size: 10px;
  color: #9aa4bf;
}

#spot-mode-toggle,
#fut-mode-toggle {
  display: inline-flex;
  gap: 4px;
  background: #0b0e11;
  border: 1px solid var(--bin-border-soft);
  padding: 3px;
  border-radius: 999px;
}

#spot-mode-toggle button,
#fut-mode-toggle button {
  border: 1px solid transparent;
  background: transparent;
  color: var(--bin-sub);
  padding: 4px 10px;
  font-size: 10px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.15s ease;
}

#spot-mode-toggle button.active,
#fut-mode-toggle button.active {
  background: #272a30;
  color: var(--bin-yellow);
  border-color: #3a414b;
  font-weight: 700;
}

#spot-mode-toggle button[data-mode="REAL"].active,
#fut-mode-toggle button[data-mode="REAL"].active {
  color: #ffffff;
  background: linear-gradient(135deg, rgba(240, 185, 11, 0.2), rgba(240, 185, 11, 0.06));
  border-color: rgba(240, 185, 11, 0.35);
}

#spot-mode-toggle button[data-mode="SIMULATION"].active,
#fut-mode-toggle button[data-mode="SIMULATION"].active {
  color: #cbd5f5;
  background: linear-gradient(135deg, rgba(138, 162, 189, 0.18), rgba(138, 162, 189, 0.06));
  border-color: rgba(138, 162, 189, 0.35);
}

/* Futures Margin + Leverage toggle */
#fut-margin-toggle,
#fut-leverage-toggle {
  background: #1b2026;
  border: 1px solid var(--bin-border-soft);
  padding: 3px;
  border-radius: 999px;
  gap: 4px;
}

#fut-margin-toggle button,
#fut-leverage-toggle button {
  color: #8b93b8;
  padding: 4px 9px;
  font-size: 10px;
}

#fut-margin-toggle button.active,
#fut-leverage-toggle button.active {
  background: #2b3139;
  color: #fff;
  border-color: #3a414b;
  font-weight: 600;
}

/* ======================================================================
   SIGNAL CHART WIDGET
   ====================================================================== */

.signal-widget {
  margin: 8px 0 10px;
  background: linear-gradient(180deg, #14191f, #10151c);
  border: 1px solid #1a2736;
  border-radius: 14px;
  overflow: hidden;
}

.signal-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 8px 10px;
  border-bottom: 1px solid #1a2736;
  background: rgba(11, 15, 20, 0.75);
}

.signal-toolbar .title {
  font-size: 11px;
  color: #e6eef7;
  font-weight: 700;
  letter-spacing: 0.2px;
}

.signal-toolbar .hint {
  font-size: 10px;
  color: #9eb1c7;
}

.signal-toolbar select,
.signal-toolbar input,
.signal-toolbar button {
  background: #0f1621;
  color: #e6eef7;
  border: 1px solid #1a2736;
  border-radius: 10px;
  padding: 5px 8px;
  font-size: 10px;
  outline: none;
}

.signal-toolbar input[list] {
  min-width: 120px;
}

.signal-toolbar .pill {
  font-size: 10px;
  padding: 2px 6px;
  border: 1px solid #1a2736;
  border-radius: 999px;
  color: #9eb1c7;
}

.signal-toolbar .auto-box {
  display: flex;
  align-items: center;
  gap: 6px;
}

.signal-toolbar .auto-box input[type="checkbox"] {
  accent-color: var(--accent-yellow);
  transform: translateY(1px);
}

.signal-toolbar .amt {
  width: 64px;
}

.mode-toggle {
  display: flex;
  gap: 6px;
}

.sig-mode-btn {
  padding: 4px 8px !important;
  font-size: 10px !important;
  opacity: 0.75;
  cursor: pointer;
}
.sig-mode-btn.active {
  opacity: 1;
  border-color: var(--accent-yellow);
  color: #fff;
}

.signal-chart {
  height: 210px;
}

@media (max-width: 360px) {
  .signal-chart {
    height: 190px;
  }
}

/* Signal panel: extra compact on tiny screens */
@media (max-width: 360px) {
  .signal-panel-body{
    max-height: 90px;
  }
}

/* NEW: Scrollable signal panel (under chart) */
.signal-panel{
  border-top: 1px solid #1a2736;
  background: rgba(12, 17, 24, 0.92);
}

.signal-panel-header{
  display:grid;
  grid-template-columns: 1.4fr .9fr 1fr 1fr 1fr .9fr 1.3fr;
  gap: 8px;
  padding: 8px 10px;
  font-size: 10px;
  color: #8fa3bb;
  border-bottom: 1px solid #1a2736;
  position: sticky;
  top: 0;
  background: rgba(12, 17, 24, 0.96);
  z-index: 2;
}

.signal-panel-body{
  max-height: 110px;
  overflow: auto;
}

.signal-row{
  display:grid;
  grid-template-columns: 1.4fr .9fr 1fr 1fr 1fr .9fr 1.3fr;
  gap: 8px;
  padding: 8px 10px;
  font-size: 10px;
  align-items: center;
  border-bottom: 1px solid rgba(26, 39, 54, 0.55);
}

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

.signal-row .sym{
  font-weight: 700;
  color: #e6eef7;
}

.signal-side{
  justify-self: start;
  font-weight: 800;
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.06);
}

.signal-side.buy{
  color: var(--green);
  background: rgba(14,203,129,0.10);
  border-color: rgba(14,203,129,0.22);
}

.signal-side.sell{
  color: var(--red);
  background: rgba(246,70,93,0.10);
  border-color: rgba(246,70,93,0.22);
}

.signal-strength{
  justify-self: start;
  font-weight: 800;
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 999px;
  color: var(--accent-yellow);
  background: rgba(240,185,11,0.10);
  border: 1px solid rgba(240,185,11,0.20);
}

.signal-time{
  color: #9eb1c7;
  font-variant-numeric: tabular-nums;
}

/* status label inside widget */
.sig-status {
  font-size: 10px;
  color: #9eb1c7;
}

/* ======================================================================
   BACKEND FLAGS
   ====================================================================== */

#backend-flags-spot,
#backend-flags-fut {
  font-size: 10px;
  color: #8b93b8;
  margin-top: 4px;
}

/* ======================================================================
   LOGIN LAYOUT
   ====================================================================== */

.login-wrapper {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  padding: 24px 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.login-card {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 20px;
  background: rgba(15, 23, 42, 0.95);
  border-radius: 18px;
  border: 1px solid #1f2937;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.8);
  padding: 16px 18px;
}

.login-card-left {
  padding-right: 8px;
}

.app-title {
  font-size: 1.3rem;
  margin-bottom: 6px;
}

.app-subtitle {
  font-size: 0.82rem;
  color: var(--text-sub);
  margin-bottom: 10px;
}

.features-list {
  list-style: disc;
  padding-left: 18px;
  font-size: 0.8rem;
  color: #cbd5f5;
}

.features-list li + li {
  margin-top: 4px;
}

.login-card-right h2 {
  font-size: 1rem;
  margin-bottom: 4px;
}

.login-caption {
  font-size: 0.78rem;
  color: var(--text-sub);
  margin-bottom: 10px;
}

.login-form .field {
  margin-bottom: 8px;
}

.login-form label {
  font-size: 0.78rem;
  color: var(--text-sub);
  display: block;
  margin-bottom: 3px;
}

.login-form input {
  width: 100%;
  padding: 7px 9px;
  border-radius: 9px;
  border: 1px solid #1f2937;
  background: #020617;
  color: #f9fafb;
  font-size: 0.85rem;
}

@media (max-width: 720px) {
  .login-card {
    grid-template-columns: 1fr;
  }
}

/* ======================================================================
   RESPONSIVE / SMALL TWEAKS
   ====================================================================== */

@media (max-width: 480px) {
  .screen-spot .trade-layout {
    grid-template-columns: 1fr;
  }
  .screen-spot .orderbook {
    order: 2;
  }
  .screen-spot .trade-panel {
    order: 1;
  }

  .signal-toolbar {
    gap: 6px;
  }
  .signal-toolbar .amt {
    width: 58px;
  }

  /* Futures manual controls: mobile layout like top section */
  .screen-futures .main-content.fut-main{
    grid-template-columns: 1fr;
    grid-template-areas:
      "panel"
      "orderbook";
  }
  .screen-futures .main-content.fut-main > .orderbook{ grid-area: orderbook; }
  .screen-futures .main-content.fut-main > .panel{ grid-area: panel; }

  .screen-futures .panel-row{
    flex-wrap: wrap;
    align-items: flex-start;
  }
  #fut-margin-toggle{
    flex: 1 1 auto;
  }
  #fut-leverage-toggle{
    flex: 1 1 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .screen-futures .lev-typed-wrap{
    margin-left: auto;
  }
}

@media (max-width: 390px) {
  .app {
    padding: 10px 10px 4px;
  }
  .bottom-nav-inner {
    padding: 8px 14px 6px;
  }
}

@media (max-height: 700px) {
  .screen-futures .fut-screen {
    border-radius: 18px;
  }
  .screen-futures .main-content.fut-main {
    grid-template-columns: 1fr;
    grid-auto-rows: minmax(0, 1fr);
  }
}


/* ======================================================================
   HOME SLIDER + NEWS MARQUEE + COIN LOGOS (ADDED)
   ====================================================================== */

.home-slider {
  margin: 8px 0 14px;
  width: 100%;
  aspect-ratio: 16 / 9;
  max-height: 190px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border-soft);
  background: var(--bg-surface);
  position: relative;
}


.home-slider-track {
  display: flex;
  width: 300%;
  height: 100%;
  transition: transform 650ms cubic-bezier(0.22, 1, 0.36, 1);

}

.home-slide {
  width: 100%;
  height: 100%;
  flex: 0 0 100%;
  object-fit: contain;
  box-sizing: border-box;
  padding: 8px 10px;
  display: block;
}


.home-slider-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 8px;
  display: flex;
  justify-content: center;
  gap: 6px;
  pointer-events: none;
}

.home-slider-dots .dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.35);
}
.home-slider-dots .dot.active {
  background: var(--accent-yellow);
}

.news-strip {
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid var(--border-soft);
  background: #11151a;
}

.news-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #000;
  background: var(--accent-yellow);
  padding: 3px 8px;
  border-radius: 999px;
  flex: 0 0 auto;
}

.news-marquee {
  overflow: hidden;
  white-space: nowrap;
  flex: 1 1 auto;
}

.news-marquee-inner {
  display: inline-block;
  white-space: nowrap;
  padding-left: 100%;
  animation: news-marquee 22s linear infinite;
  font-size: 11px;
  color: var(--text-sub);
}

@keyframes news-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

.coin-logo {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  object-fit: cover;
  background: #0f141a;
  border: 1px solid var(--border-soft);
  flex: 0 0 auto;
}

.coin-name .coin-title {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}


/* =====================================================================
   QUICK ACTIONS (Home icons row)
   ===================================================================== */
.quick-actions{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  padding: 10px 14px 6px;
}
.qa-item{
  text-align:center;
  cursor:pointer;
  user-select:none;
}
.qa-icon{
  width: 58px;
  height: 58px;
  margin: 0 auto 8px;
  border-radius: 18px;
  background: #222831;
  border: 1px solid rgba(255,255,255,0.06);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: 0 8px 18px rgba(0,0,0,0.35);
}
.qa-icon svg{
  width: 30px;
  height: 30px;
  fill: #e9eef6;
}
.qa-icon svg .qa-accent{
  fill: var(--bin-yellow);
}
.qa-label{
  font-size: 12px;
  color: #d7dee8;
  opacity: 0.95;
}

/* =====================================================================
   ASSETS SCREEN (Wallet UI)
   ===================================================================== */
.screen-assets{
  padding: 10px 14px 80px;
}
.assets-header{
  margin-top: 4px;
}
.assets-tabs{
  display:flex;
  gap: 16px;
  align-items:center;
  font-size: 14px;
}
.assets-tab{
  opacity: 0.6;
  cursor:pointer;
  user-select:none;
}
.assets-tab.active{
  opacity: 1;
  color: #fff;
  font-weight: 700;
}
.assets-total{
  margin-top: 12px;
  background: #11151f;
  border: 1px solid var(--bin-border-soft);
  border-radius: 18px;
  padding: 14px 14px 12px;
}
.assets-total-head{
  display:flex;
  justify-content: space-between;
  align-items:center;
  font-size: 12px;
  color: #9aa4bf;
}
.assets-total-value{
  margin-top: 6px;
  font-size: 36px;
  font-weight: 800;
  letter-spacing: 0.2px;
  color: #ffffff;
}
.assets-cur{
  font-size: 14px;
  font-weight: 700;
  color: #9aa4bf;
  margin-left: 6px;
}
.assets-total-pnl{
  margin-top: 6px;
  font-size: 12px;
  color: #9aa4bf;
}
.assets-total-pnl span{
  margin-left: 6px;
  font-weight: 700;
  color: var(--bin-green);
}
.assets-actions{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}
.assets-btn{
  border: 1px solid rgba(255,255,255,0.08);
  background: #1b212b;
  color: #e6eef7;
  border-radius: 14px;
  padding: 10px 10px;
  font-size: 13px;
  font-weight: 700;
  cursor:pointer;
}
.assets-btn.primary{
  background: var(--bin-yellow);
  color: #0b0e11;
  border-color: rgba(240, 185, 11, 0.25);
}
.assets-panel{
  margin-top: 12px;
  background: #0f1422;
  border: 1px solid #1c2233;
  border-radius: 18px;
  padding: 12px 12px;
}
.assets-panel-tabs{
  display:flex;
  gap: 14px;
  font-size: 12px;
  color: #9aa4bf;
  margin-bottom: 10px;
}
.assets-panel-tabs span{
  cursor:pointer;
  user-select:none;
}
.assets-panel-tabs span.active{
  color: #ffffff;
  font-weight: 700;
  position: relative;
}
.assets-panel-tabs span.active::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: var(--bin-yellow);
}
.assets-list{
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.assets-row{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 10px 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px;
}
.assets-row-left{
  font-size: 13px;
  font-weight: 700;
  color: #e9eef6;
}
.assets-row-right{
  font-size: 13px;
  font-weight: 800;
  color: #e9eef6;
}


/* ======================================================================
   PATCH: Spot/Futures orderbook columns, Futures close button, Trade panel compact,
   Futures mobile full-height, Spot holdings trades time (ADDED)
   ====================================================================== */

/* asks/bids: show rows from top and tint full columns red/green */
.screen-spot .orderbook-tape .tape-rows,
.screen-futures .orderbook-tape .tape-rows{
  justify-content: flex-start !important;
}

.screen-spot .orderbook-tape .tape-col.tape-asks,
.screen-futures .orderbook-tape .tape-col.tape-asks{
  background: rgba(246,70,93,0.10) !important;
  border-color: rgba(246,70,93,0.22) !important;
}

.screen-spot .orderbook-tape .tape-col.tape-bids,
.screen-futures .orderbook-tape .tape-col.tape-bids{
  background: rgba(14,203,129,0.10) !important;
  border-color: rgba(14,203,129,0.22) !important;
}

/* Futures close position button should be red */
.btn-danger{
  background: var(--red);
  border: none;
  color: #fff;
  font-weight: 700;
  padding: 0.6rem 1.4rem;
  border-radius: 999px;
  cursor: pointer;
}
.btn-danger:hover{ filter: brightness(1.05); }
#fut-close-btn{ background: var(--red); }

/* Spot trade panel: smaller design */
.screen-spot .trade-panel{
  padding: 8px !important;
  gap: 6px !important;
  font-size: 10px !important;
  border-radius: 10px !important;
}
.screen-spot .buy-sell-toggle{ font-size: 11px !important; }
.screen-spot .toggle-btn{ padding: 5px 0 !important; }
.screen-spot .trade-panel select,
.screen-spot .trade-panel input[type="number"]{
  padding: 8px 10px !important;
  font-size: 11px !important;
  border-radius: 10px !important;
}

/* Futures page: ensure it uses full mobile screen and doesn't hide behind bottom nav */
@media (max-width: 520px){
  .screen-futures{ padding-bottom: 88px; }
  .screen-futures .fut-screen{
    min-height: calc(100vh - 160px);
    display: flex;
    flex-direction: column;
  }
}

/* Spot holdings: Recent Trades section styling */
.simple-divider{
  height: 1px;
  background: rgba(148,163,184,0.18);
  margin: 10px 0 8px;
}
.simple-subtitle{
  font-size: 11px;
  font-weight: 700;
  color: #e5e7eb;
  margin-bottom: 6px;
}


/* ======================================================================
   CONTROL PANEL (ADDED)
   ====================================================================== */

.screen-control{
  padding: 10px 10px 80px;
}

.screen-control .control-top{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 8px 4px 10px;
}

.screen-control .control-title{
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 0.2px;
}

.screen-control .control-wrap{
  display:flex;
  flex-direction: column;
  gap: 12px;
}

.screen-control .control-card{
  background: #0f141a;
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  padding: 12px 12px;
}

.screen-control .control-card-title{
  font-size: 13px;
  font-weight: 800;
  margin-bottom: 10px;
  color: #e6eef7;
}

.screen-control .control-row{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.screen-control .control-row:first-of-type{
  border-top: none;
}

.screen-control .control-toggle{
  display:flex;
  align-items:center;
  gap: 10px;
  font-size: 12px;
  color: #cfd6e4;
  user-select:none;
}
.screen-control .control-toggle input{
  width: 16px;
  height: 16px;
}

.screen-control .control-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.screen-control .control-field{
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 8px 10px;
}

.screen-control .control-label{
  font-size: 10px;
  color: #8fa3bb;
  margin-bottom: 4px;
  font-weight: 700;
}

.screen-control .control-field input,
.screen-control .control-field select{
  width: 100%;
  background: transparent;
  border: none;
  outline: none;
  color: #e6eef7;
  font-size: 12px;
  font-weight: 700;
}

.screen-control .control-actions{
  display:flex;
  gap: 10px;
  align-items:center;
  margin-top: 10px;
  flex-wrap: wrap;
}

.screen-control .control-actions .btn-primary,
.screen-control .control-actions .btn-danger{
  padding: 0.55rem 1.05rem;
  font-size: 0.85rem;
}



/* ======================================================================
   THEME + MOBILE FIT OVERRIDES (Added for White/Black toggle + Fullscreen)
   ====================================================================== */

html, body {
  height: 100%;
  min-height: 100%;
}

body {
  background: var(--bg-main) !important;
  color: var(--text-main) !important;
  justify-content: center;
}

.app {
  width: 100%;
  max-width: 100% !important;
  min-height: 100dvh;
  background: var(--bg-main);
  padding-bottom: 98px; /* space for bottom nav */
}

/* keep the "phone" look only on large screens */
@media (min-width: 520px) {
  .app {
    max-width: 430px !important;
  }
}

/* Bottom nav should fit any mobile width */
.bottom-nav{
  left: 0 !important;
  transform: none !important;
  width: 100%;
  max-width: 100% !important;
  padding-left: calc(18px + env(safe-area-inset-left));
  padding-right: calc(18px + env(safe-area-inset-right));
}

body[data-theme="light"] .bottom-nav{
  background: linear-gradient(
    to top,
    rgba(255,255,255,0.92),
    rgba(255,255,255,0.75),
    transparent
  );
}

body[data-theme="dark"] .bottom-nav{
  background: linear-gradient(
    to top,
    rgba(11,14,17,0.92),
    rgba(11,14,17,0.75),
    transparent
  );
}

.bottom-nav-inner{
  background: var(--bg-card) !important;
  border-top: 1px solid var(--border-soft) !important;
}

/* ======================================================================
   HOME MENU (Hamburger dropdown)
   ====================================================================== */

.menu-wrap{
  position: relative;
}

.home-menu{
  position: absolute;
  top: 40px;
  left: 0;
  width: min(340px, 88vw);
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  box-shadow: 0 18px 42px rgba(0,0,0,0.18);
  padding: 12px;
  z-index: 80;

  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

body[data-theme="dark"] .home-menu{
  box-shadow: 0 18px 42px rgba(0,0,0,0.45);
}

.home-menu.open{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.home-menu-divider{
  height: 1px;
  background: var(--border-soft);
  margin: 10px 0;
}

.menu-profile{
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.menu-avatar{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid var(--border-soft);
  object-fit: cover;
  background: var(--bg-surface);
  flex: 0 0 auto;
}


.menu-avatar-icon{
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: var(--text-sub);
}

.menu-profile{
  position: relative;
}

.client-connected-badge{
  position: absolute;
  right: 0;
  top: 2px;
  font-size: 11px;
  color: var(--green);
  background: rgba(14, 203, 129, 0.12);
  border: 1px solid rgba(14, 203, 129, 0.25);
  padding: 2px 8px;
  border-radius: 999px;
}
.menu-profile-title{
  font-size: 12px;
  color: var(--text-sub);
  margin-bottom: 6px;
}

.menu-name-input{
  width: 100%;
  border: 1px solid var(--border-soft);
  background: var(--bg-surface);
  color: var(--text-main);
  border-radius: 12px;
  padding: 8px 10px;
  font-size: 13px;
  outline: none;
}

.menu-name-input:focus{
  box-shadow: var(--bin-focus-shadow);
  border-color: var(--accent-yellow);
}

.menu-upload-btn{
  display: inline-flex;
  margin-top: 8px;
  border: 1px dashed var(--border-soft);
  border-radius: 12px;
  padding: 8px 10px;
  cursor: pointer;
  user-select: none;
  color: var(--text-main);
  background: var(--bg-surface);
  font-size: 12px;
}

.menu-save-btn{
  display: inline-flex;
  margin-top: 8px;
  width: 100%;
  justify-content: center;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: 9px 10px;
  cursor: pointer;
  background: var(--accent-yellow);
  color: #111;
  font-weight: 700;
}

.menu-row{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 10px;
  font-size: 13px;
  color: var(--text-main);
}

.menu-theme-toggle{
  display:flex;
  gap: 8px;
}

.theme-btn{
  border: 1px solid var(--border-soft);
  background: var(--bg-surface);
  color: var(--text-main);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  cursor: pointer;
}

.theme-btn.active{
  background: var(--accent-yellow);
  border-color: var(--accent-yellow);
  color: #111;
  font-weight: 800;
}

/* ======================================================================
   HOME SLIDER + NEWS (Theme-safe)
   ====================================================================== */

.home-slider{
  background: var(--bg-card) !important;
  border: 1px solid var(--border-soft) !important;
}

.home-slide{
  padding: 10px 12px !important; /* keep image not zoomed */
  object-fit: contain !important;
}

.news-strip{
  background: var(--bg-card) !important;
  border: 1px solid var(--border-soft) !important;
}

.coin-logo{
  background: var(--bg-surface) !important;
}

/* Quick Actions row */
.qa-icon{
  background: var(--bg-card) !important;
  border: 1px solid var(--border-soft) !important;
  box-shadow: 0 8px 18px rgba(0,0,0,0.12) !important;
}
body[data-theme="dark"] .qa-icon{
  box-shadow: 0 10px 22px rgba(0,0,0,0.42) !important;
}
.qa-icon svg{
  fill: var(--text-main) !important;
}
.qa-label{
  color: var(--text-sub) !important;
}

/* ======================================================================
   CRYPTO NEWS (replaces Discover)
   ====================================================================== */

.crypto-news-wrap{
  margin-top: 10px;
  border: 1px solid var(--border-soft);
  background: var(--bg-card);
  border-radius: 22px;
  padding: 12px 12px 10px;
}

.crypto-news-list{
  margin-top: 8px;
  max-height: 420px;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 4px;
}

.crypto-news-item{
  display:flex;
  gap: 10px;
  align-items:center;
  padding: 10px 8px;
  border-top: 1px solid var(--border-soft);
  cursor: pointer;
  user-select: none;
}


.crypto-news-item .news-thumb{
  width: 52px;
  height: 52px;
  border-radius: 14px;
  overflow: hidden;
  flex: 0 0 52px;
  border: 1px solid var(--border-soft);
  background: var(--bg-surface);
}
.crypto-news-item .news-thumb.noimg{
  background: linear-gradient(135deg, var(--bg-surface), var(--bg-card));
}
.crypto-news-item .news-thumb img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.crypto-news-item .news-body{
  flex: 1 1 auto;
  min-width: 0;
}


.crypto-news-item:first-child{
  border-top: none;
}

.crypto-news-item .news-title{
  font-size: 13px;
  color: var(--text-main);
  line-height: 1.25;
  font-weight: 600;
}

.crypto-news-item .news-meta{
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-muted);
}

.crypto-news-item.skeleton{
  opacity: 0.75;
  cursor: default;
}

/* ======================================================================
   SPOT / FUTURES theme fixes for removed items + readability
   ====================================================================== */

.list-row{
  border-top: 1px solid var(--border-soft) !important;
}

.screen-spot .last-price-sub,
.screen-spot .orderbook-footer{
  color: var(--text-muted) !important;
}

.screen-spot .depth-bar{
  background: var(--bg-surface-alt) !important;
}

.screen-spot .amount-step{
  background: var(--bg-surface) !important;
  color: var(--text-main) !important;
}

.screen-spot .orderbook-tape .tape-col,
.screen-futures .orderbook-tape .tape-col{
  background: var(--bg-card) !important;
}

.screen-spot .orderbook-tape .tape-title,
.screen-futures .orderbook-tape .tape-title{
  color: var(--text-muted) !important;
}

/* ======================================================================
   ASSETS (Wallet) – theme safe + buttons removed UI spacing
   ====================================================================== */

.screen-assets{
  padding-bottom: 92px !important;
}

.assets-tab.active{
  color: var(--text-main) !important;
}

.assets-total{
  background: var(--bg-card) !important;
  border: 1px solid var(--border-soft) !important;
}

.assets-total-head,
.assets-cur,
.assets-total-pnl{
  color: var(--text-muted) !important;
}

.assets-total-value{
  color: var(--text-main) !important;
}

.assets-btn{
  background: var(--bg-card) !important;
  border: 1px solid var(--border-soft) !important;
  color: var(--text-main) !important;
}



/* ======================================================================
   Mobile-only shell (desktop shows a centered phone-sized app)
   ====================================================================== */
html, body {
  height: 100%;
}

body {
  display: flex;
  justify-content: center;
  align-items: stretch;
}

.app{
  width: min(100vw, 430px);
  height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  position: relative;
}



/* ======================================================================
   Mobile-only frame (desktop shows a mobile-sized UI)
   ====================================================================== */
html, body {
  height: 100%;
}
body {
  margin: 0;
  height: 100dvh;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: stretch;
  background: var(--bg-main, #0b0f14);
}

.app {
  width: 100%;
  max-width: 480px;
  height: 100dvh;
  overflow: hidden;
  position: relative;
  background: var(--bg-main, #0b0f14);
}

/* Keep nav inside the app frame */
.bottom-nav {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  transform: none !important;
  width: 100% !important;
  max-width: none !important;
}

/* Ensure screens don't hide behind bottom nav */
.screen {
  padding-bottom: 92px; /* nav height + safe space */
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* ======================================================================
   Home Slider: smooth, slow, perfectly fit in the existing rectangle
   ====================================================================== */
.home-slider {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
}

.home-slider-track {
  display: flex;
  width: 100%;
  height: 100%;
  will-change: transform;
}

.home-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;  /* fills the rectangle nicely */
  border-radius: 18px;
  user-select: none;
  -webkit-user-drag: none;
}

.home-slider-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 10px;
  display: flex;
  justify-content: center;
  gap: 8px;
  pointer-events: auto;
}

.home-slider-dots .dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.35);
}

body[data-theme="light"] .home-slider-dots .dot {
  background: rgba(0, 0, 0, 0.25);
}

.home-slider-dots .dot.active {
  width: 18px;
  background: rgba(255, 255, 255, 0.75);
}

body[data-theme="light"] .home-slider-dots .dot.active {
  background: rgba(0, 0, 0, 0.55);
}

/* ======================================================================
   Crypto News list: with thumbnails + scroll
   ====================================================================== */
.crypto-news-section .crypto-news-list,
#daily-crypto-news.crypto-news-list,
.crypto-news-list#daily-crypto-news {
  max-height: 240px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-right: 4px;
}

.crypto-news-item {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid var(--border-soft, rgba(255,255,255,0.08));
  background: var(--bg-card, rgba(255,255,255,0.04));
  margin-bottom: 10px;
}

body[data-theme="light"] .crypto-news-item {
  background: var(--bg-card, #ffffff);
}

.crypto-news-item .news-thumb {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  overflow: hidden;
  background: var(--bg-surface, rgba(255,255,255,0.06));
  border: 1px solid var(--border-soft, rgba(255,255,255,0.08));
  flex: 0 0 44px;
}

.crypto-news-item .news-thumb.noimg {
  display: none;
}

.crypto-news-item .news-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.crypto-news-item .news-body {
  flex: 1;
  min-width: 0;
}

.crypto-news-item .news-title {
  font-size: 14px;
  line-height: 1.25;
  color: var(--text-main, #e6eef8);
  font-weight: 600;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.crypto-news-item .news-meta {
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-muted, rgba(230,238,248,0.65));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

body[data-theme="light"] .crypto-news-item .news-title {
  color: var(--text-main, #0b1220);
}
body[data-theme="light"] .crypto-news-item .news-meta {
  color: var(--text-muted, rgba(11,18,32,0.55));
}

/* =====================================================================
   FINAL MOBILE RESPONSIVE FIX (Requested)
   - Keep app full-width on phones
   - Ensure login screen scrolls if content is taller than the viewport
   ===================================================================== */

@media (max-width: 520px) {
  .app {
    width: 100vw;
    max-width: 100% !important;
    border-radius: 0;
  }
}

/* Login page: allow scrolling inside wrapper on small screens */
.login-wrapper {
  min-height: 100dvh;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}


/* =====================================================================
   SCROLL UNLOCK (Requested)
   - Fix scroll lock on Home / Markets / Trade / Futures screens
   - Keep bottom nav pinned inside the app frame
   ===================================================================== */

html, body {
  height: 100% !important;
  overflow: hidden !important;
}

body {
  margin: 0;
}

/* App becomes a fixed-height frame; each visible screen scrolls */
.app {
  height: 100dvh !important;
  max-height: 100dvh !important;
  overflow: hidden !important;
}

.screen {
  height: 100% !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 92px !important; /* nav height + safe space */
}

/* Bottom nav pinned inside app */
.bottom-nav {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  transform: none !important;
  width: 100% !important;
  max-width: none !important;
}

/* ======================================================================
   GLOBAL: HIDE ALL SCROLLBARS (keep scrolling)
   ====================================================================== */
* {
  -ms-overflow-style: none; /* IE/Edge */
  scrollbar-width: none;    /* Firefox */
}
*::-webkit-scrollbar {
  width: 0;
  height: 0;
}



/* ===== Login Page (Black + Yellow/White, mobile-first) ===== */
body.login-dark {
  background: #000 !important;
  color: #fff;
}

.hidden { display: none !important; }

.login-screen{
  min-height: 100vh;
  width: 100%;
  padding: 28px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
}

.login-brand{
  text-align: center;
  padding: 6px 0;
}

.brand-title{
  margin: 0;
  font-size: clamp(34px, 9vw, 56px);
  font-weight: 800;
  letter-spacing: 0.6px;
  color: #f6c400;
  text-shadow: 0 0 10px rgba(246,196,0,0.35), 0 0 24px rgba(246,196,0,0.18);
  animation: brandGlow 1.6s ease-in-out infinite alternate, brandFloat 2.8s ease-in-out infinite;
}

.brand-accent{
  margin: 14px auto 0;
  width: min(240px, 70vw);
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(246,196,0,0), rgba(246,196,0,1), rgba(246,196,0,0));
  filter: drop-shadow(0 0 10px rgba(246,196,0,0.25));
}

@keyframes brandGlow{
  from { text-shadow: 0 0 8px rgba(246,196,0,0.25), 0 0 18px rgba(246,196,0,0.12); }
  to   { text-shadow: 0 0 14px rgba(246,196,0,0.55), 0 0 30px rgba(246,196,0,0.20); }
}

@keyframes brandFloat{
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-4px); }
}

.loading-block, .login-block{
  width: 100%;
  max-width: 420px;
}

.loading-text{
  display: flex;
  justify-content: center;
  gap: 10px;
  align-items: baseline;
  font-weight: 700;
  margin-bottom: 12px;
}

.loading-word{
  color: #fff;
  opacity: 0.92;
}

.loading-percent{
  color: #f6c400;
  font-variant-numeric: tabular-nums;
}

.loading-bar{
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(246,196,0,0.25);
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.4) inset;
}

.loading-fill{
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(246,196,0,0.65), rgba(246,196,0,1));
  box-shadow: 0 0 14px rgba(246,196,0,0.25);
  transition: width 120ms ease-out;
}

.login-heading{
  margin: 0 0 14px;
  text-align: center;
  color: #fff;
  font-size: 18px;
  letter-spacing: 0.4px;
  opacity: 0.95;
}

body.login-dark .login-form{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(246,196,0,0.22);
  border-radius: 16px;
  padding: 18px 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
}

body.login-dark .login-form .field{
  margin-bottom: 12px;
}

body.login-dark .login-form label{
  color: #fff;
  font-weight: 600;
  font-size: 13px;
  display: block;
  margin-bottom: 6px;
  opacity: 0.95;
}

body.login-dark .login-form input{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(246,196,0,0.30);
  background: rgba(0,0,0,0.65);
  color: #fff;
  outline: none;
}

body.login-dark .login-form input::placeholder{
  color: rgba(255,255,255,0.45);
}

body.login-dark .login-form input:focus{
  border-color: rgba(246,196,0,0.9);
  box-shadow: 0 0 0 3px rgba(246,196,0,0.18);
}

body.login-dark .btn-primary{
  background: #f6c400;
  color: #000;
  border: none;
  border-radius: 12px;
  padding: 12px 14px;
  font-weight: 800;
  letter-spacing: 0.4px;
  cursor: pointer;
  transition: transform 120ms ease, filter 120ms ease;
}

body.login-dark .btn-primary:disabled{
  opacity: 0.55;
  cursor: not-allowed;
}

body.login-dark .btn-primary:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
}

body.login-dark .msg{
  margin-top: 10px;
  text-align: center;
  font-size: 13px;
  color: rgba(255,255,255,0.88);
}

body.login-dark .msg.error{
  color: #ff6b6b;
}


/* ======================================================================
   SYMBOL PICKER (Spot/Futures)
   ====================================================================== */

.field-input.field-input-col{
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
}

.symbol-search{
  width: 100%;
  background: var(--bin-surface-1);
  border: 1px solid var(--bin-border);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--bin-text);
  outline: none;
}

.symbol-search:focus{
  border-color: rgba(255, 204, 0, 0.55);
  box-shadow: 0 0 0 3px rgba(255, 204, 0, 0.12);
}

.field-input select{
  width: 100%;
  min-height: 42px;
  background: var(--bin-surface-1);
  border: 1px solid var(--bin-border);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--bin-text);
}

.field-input select:focus{
  border-color: rgba(255, 204, 0, 0.55);
  box-shadow: 0 0 0 3px rgba(255, 204, 0, 0.12);
  outline: none;
}

.symbol-hint{
  font-size: 11px;
  color: var(--bin-sub);
  padding-left: 2px;
  line-height: 1.2;
}

/* ======================================================================
   B PLUS GAIN – AUTH + ADMIN PAGES (YELLOW / WHITE / BLACK)
   Added for email/password auth flow + admin control panel
   ====================================================================== */

:root {
  --bp-yellow: var(--accent-yellow);
  --bp-black: #0b0f14;
  --bp-white: #ffffff;
  --bp-card: #ffffff;
  --bp-border: rgba(17, 24, 39, 0.12);
  --bp-shadow: 0 12px 30px rgba(0, 0, 0, 0.10);
}

/* Full-page layout helpers (use on auth.html / admin.html) */
body.auth-body,
body.admin-body {
  background: linear-gradient(180deg, #ffffff 0%, #f7f7f7 100%);
  color: #111827;
  display: block;
}

.bp-page {
  min-height: 100vh;
  padding: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bp-card {
  width: 100%;
  max-width: 430px;
  background: var(--bp-card);
  border: 1px solid var(--bp-border);
  border-radius: 18px;
  box-shadow: var(--bp-shadow);
  overflow: hidden;
}

.bp-card-header {
  padding: 16px 16px 12px;
  border-bottom: 1px solid var(--bp-border);
  background:
    radial-gradient(1200px 600px at 0% 0%, rgba(240, 185, 11, 0.18), transparent 55%),
    radial-gradient(1200px 600px at 100% 0%, rgba(0, 0, 0, 0.05), transparent 60%),
    #ffffff;
}

.bp-brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.bp-brand-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.bp-logo {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: var(--bp-black);
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
}

.bp-logo::after {
  content: "";
  position: absolute;
  inset: -40%;
  background: conic-gradient(from 210deg, transparent 0 35%, rgba(240, 185, 11, 0.95) 35% 55%, transparent 55% 100%);
  animation: bpSpin 1.8s linear infinite;
}

.bp-logo span {
  width: 30px;
  height: 30px;
  border-radius: 12px;
  background: #ffffff;
  position: relative;
  z-index: 1;
}

@keyframes bpSpin {
  to { transform: rotate(360deg); }
}

.bp-title {
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 0.2px;
}

.bp-subtitle {
  font-size: 12px;
  color: #6b7280;
  margin-top: 2px;
}

.bp-card-body {
  padding: 16px;
}

/* Loader (0% -> 100%) */
.bp-loader {
  padding: 14px 16px 16px;
}

.bp-loader-title {
  font-size: 14px;
  font-weight: 700;
  color: #111827;
  margin-bottom: 10px;
}

.bp-progress {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: rgba(17, 24, 39, 0.08);
  overflow: hidden;
  border: 1px solid rgba(17, 24, 39, 0.08);
}

.bp-progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, rgba(240, 185, 11, 0.35), rgba(240, 185, 11, 1));
  border-radius: 999px;
  transition: width 120ms linear;
}

.bp-loader-row {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.bp-percent {
  font-size: 12px;
  color: #111827;
  font-weight: 700;
}

.bp-loader-hint {
  font-size: 12px;
  color: #6b7280;
}

/* Tabs */
.bp-tabs {
  display: flex;
  gap: 8px;
  margin-top: 14px;
  margin-bottom: 12px;
}

.bp-tab-btn {
  flex: 1;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--bp-border);
  background: #ffffff;
  color: #111827;
  font-weight: 800;
  cursor: pointer;
}

.bp-tab-btn.active {
  background: var(--bp-black);
  color: #ffffff;
  border-color: rgba(0, 0, 0, 0.35);
}

/* Form */
.bp-form {
  display: grid;
  gap: 10px;
}

.bp-field label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: #111827;
  margin-bottom: 6px;
}

.bp-input {
  width: 100%;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--bp-border);
  padding: 10px 12px;
  font-size: 14px;
  outline: none;
  background: #ffffff;
  color: #111827;
}

.bp-input:focus {
  border-color: rgba(240, 185, 11, 0.8);
  box-shadow: 0 0 0 3px rgba(240, 185, 11, 0.18);
}

.bp-actions {
  display: grid;
  gap: 10px;
  margin-top: 6px;
}

.bp-btn {
  width: 100%;
  height: 46px;
  border-radius: 14px;
  border: none;
  font-weight: 900;
  cursor: pointer;
  letter-spacing: 0.15px;
}

.bp-btn.primary {
  background: var(--bp-yellow);
  color: #111827;
}

.bp-btn.primary:active {
  transform: translateY(1px);
}

.bp-btn.secondary {
  background: #111827;
  color: #ffffff;
}

.bp-btn.secondary:active {
  transform: translateY(1px);
}

.bp-note {
  font-size: 12px;
  color: #6b7280;
  line-height: 1.35;
}

.bp-error {
  font-size: 12px;
  color: #b91c1c;
  background: rgba(185, 28, 28, 0.08);
  border: 1px solid rgba(185, 28, 28, 0.16);
  padding: 10px 12px;
  border-radius: 12px;
}

.bp-success {
  font-size: 12px;
  color: #065f46;
  background: rgba(6, 95, 70, 0.08);
  border: 1px solid rgba(6, 95, 70, 0.16);
  padding: 10px 12px;
  border-radius: 12px;
}

/* Center message after register confirm */
.bp-center-message {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(11, 15, 20, 0.55);
  z-index: 9999;
}

.bp-center-message.active {
  display: flex;
}

.bp-center-message .box {
  width: min(520px, 100%);
  background: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 18px;
  box-shadow: 0 16px 45px rgba(0, 0, 0, 0.25);
  overflow: hidden;
}

.bp-center-message .box-header {
  padding: 14px 16px;
  background: #111827;
  color: #ffffff;
  font-weight: 900;
}

.bp-center-message .box-body {
  padding: 16px;
  color: #111827;
  line-height: 1.45;
  font-size: 14px;
}

.bp-center-message .box-body strong {
  color: #111827;
}

.bp-center-message .box-actions {
  padding: 12px 16px 16px;
}

/* Account status overlay (restricted/suspended/blocked/expired) */
.bp-account-overlay {
  position: fixed;
  inset: 0;
  background: rgba(11, 15, 20, 0.55);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9999;
}

.bp-account-overlay.active {
  display: flex;
}

.bp-account-overlay .panel {
  width: min(520px, 100%);
  background: #ffffff;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 16px 45px rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.bp-account-overlay .panel-title {
  padding: 14px 16px;
  background: var(--bp-yellow);
  color: #111827;
  font-weight: 900;
}

.bp-account-overlay .panel-body {
  padding: 16px;
  color: #111827;
  font-size: 14px;
  line-height: 1.45;
}

.bp-account-overlay .panel-actions {
  padding: 12px 16px 16px;
}

/* Admin panel */
.bp-admin-toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 12px;
  margin-bottom: 10px;
}

.bp-admin-toolbar input {
  flex: 1;
}

.bp-admin-grid {
  display: grid;
  gap: 10px;
}

.bp-admin-list {
  border: 1px solid var(--bp-border);
  border-radius: 14px;
  overflow: hidden;
}

.bp-admin-row {
  padding: 12px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: #ffffff;
  border-bottom: 1px solid rgba(17, 24, 39, 0.08);
  cursor: pointer;
}

.bp-admin-row:last-child {
  border-bottom: none;
}

.bp-admin-row:hover {
  background: rgba(240, 185, 11, 0.06);
}

.bp-admin-row .left {
  display: grid;
  gap: 2px;
}

.bp-admin-row .name {
  font-weight: 900;
  font-size: 13px;
}

.bp-admin-row .meta {
  font-size: 12px;
  color: #6b7280;
}

.bp-badge {
  font-size: 11px;
  font-weight: 900;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, 0.10);
  background: rgba(17, 24, 39, 0.04);
  color: #111827;
}

.bp-badge.good {
  background: rgba(6, 95, 70, 0.08);
  border-color: rgba(6, 95, 70, 0.18);
  color: #065f46;
}

.bp-badge.bad {
  background: rgba(185, 28, 28, 0.08);
  border-color: rgba(185, 28, 28, 0.18);
  color: #b91c1c;
}

.bp-badge.warn {
  background: rgba(161, 98, 7, 0.10);
  border-color: rgba(161, 98, 7, 0.20);
  color: #92400e;
}

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

.bp-check {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid rgba(17, 24, 39, 0.10);
  background: rgba(17, 24, 39, 0.02);
}

.bp-check .label {
  font-weight: 800;
  font-size: 13px;
}

.bp-switch {
  appearance: none;
  width: 46px;
  height: 26px;
  border-radius: 999px;
  background: rgba(17, 24, 39, 0.18);
  border: 1px solid rgba(17, 24, 39, 0.12);
  position: relative;
  cursor: pointer;
  outline: none;
}

.bp-switch::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: #ffffff;
  box-shadow: 0 6px 14px rgba(0,0,0,0.12);
  transition: transform 140ms ease;
}

.bp-switch:checked {
  background: rgba(240, 185, 11, 1);
  border-color: rgba(240, 185, 11, 0.55);
}

.bp-switch:checked::after {
  transform: translateX(20px);
}

/* Make sure buttons do not inherit mobile app shell constraints */
body.auth-body .app,
body.admin-body .app {
  max-width: none;
  padding: 0;
  background: transparent;
}

/* ======================================================================
   B PLUS GAING – AUTH PAGES (CLEAR YELLOW/BLACK/WHITE DESIGN)
   Scoped to body.auth-body so it won't break dashboard/other screens.
   ====================================================================== */

body.auth-body {
  background: radial-gradient(900px 500px at 20% 10%, rgba(240, 185, 11, 0.20), transparent 55%),
              radial-gradient(900px 500px at 80% 0%, rgba(255, 255, 255, 0.06), transparent 60%),
              linear-gradient(180deg, #0a0a0a 0%, #111111 100%);
  color: #ffffff;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

.auth-body .bp-page {
  padding: 22px;
}

.auth-body .bp-card {
  max-width: 480px;
  border-radius: 22px;
  border: 1px solid rgba(240, 185, 11, 0.35);
  background: rgba(12, 12, 12, 0.82);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.55);
}

.auth-body .bp-card-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background:
    radial-gradient(1200px 600px at 0% 0%, rgba(240, 185, 11, 0.22), transparent 55%),
    radial-gradient(1200px 600px at 100% 0%, rgba(255, 255, 255, 0.08), transparent 60%),
    rgba(8, 8, 8, 0.6);
}

.auth-body .bp-header-wrap {
  padding: 20px 18px 16px;
  text-align: center;
}

.auth-body .bp-logo {
  font-size: 30px;
  font-weight: 850;
  letter-spacing: 0.4px;
  color: #ffffff;
  line-height: 1.15;
}

.auth-body .bp-subtitle {
  margin-top: 6px;
  font-size: 13px;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.70);
}

.auth-body .bp-card-body {
  padding: 18px;
}

.auth-body .bp-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  background: rgba(255, 255, 255, 0.06);
  padding: 8px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.10);
}

.auth-body .bp-tab-btn {
  border: 0;
  border-radius: 12px;
  padding: 12px 10px;
  font-size: 14px;
  font-weight: 750;
  letter-spacing: 0.02em;
  background: transparent;
  color: rgba(255, 255, 255, 0.78);
  cursor: pointer;
}

.auth-body .bp-tab-btn.active {
  background: rgba(240, 185, 11, 0.16);
  color: #ffffff;
  box-shadow: inset 0 0 0 1px rgba(240, 185, 11, 0.35);
}

.auth-body .bp-alerts {
  margin-top: 12px;
}

.auth-body .bp-form {
  margin-top: 14px;
}

.auth-body .bp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 420px) {
  .auth-body .bp-grid { grid-template-columns: 1fr; }
}

.auth-body .bp-field label {
  display: block;
  margin: 0 0 6px;
  font-size: 13px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.82);
  letter-spacing: 0.02em;
}

.auth-body .bp-input {
  width: 100%;
  height: 48px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  color: #ffffff;
  padding: 0 14px;
  font-size: 16px;        /* Clear letters/numbers */
  font-weight: 650;
  letter-spacing: 0.01em;
  outline: none;
}

.auth-body .bp-input::placeholder {
  color: rgba(255, 255, 255, 0.42);
  font-weight: 600;
}

.auth-body .bp-input:focus {
  border-color: rgba(240, 185, 11, 0.70);
  box-shadow: 0 0 0 4px rgba(240, 185, 11, 0.18);
}

.auth-body .bp-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
}

@media (max-width: 420px) {
  .auth-body .bp-actions { grid-template-columns: 1fr; }
}

.auth-body .bp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 46px;
  border-radius: 14px;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-decoration: none;
  cursor: pointer;
  user-select: none;
}

.auth-body .bp-btn.primary {
  background: #f0b90b;
  color: #0a0a0a;
  border: 1px solid rgba(240, 185, 11, 0.55);
  box-shadow: 0 10px 24px rgba(240, 185, 11, 0.16);
}

.auth-body .bp-btn.primary:hover {
  filter: brightness(1.03);
}

.auth-body .bp-btn.secondary {
  background: transparent;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.auth-body .bp-btn.secondary:hover {
  border-color: rgba(240, 185, 11, 0.60);
}

.auth-body .bp-note {
  margin-top: 12px;
  padding: 12px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.10);
  color: rgba(255, 255, 255, 0.72);
  font-size: 13px;
  line-height: 1.45;
}

/* Loader */
.auth-body .bp-loader {
  padding: 18px;
}

.auth-body .bp-loader-title {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.90);
}

.auth-body .bp-progress {
  height: 12px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.12);
  margin-top: 12px;
}

.auth-body .bp-progress-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #f0b90b 0%, #ffe08a 100%);
  box-shadow: 0 10px 28px rgba(240, 185, 11, 0.20);
}

.auth-body .bp-loader-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-top: 12px;
}

.auth-body .bp-percent {
  font-size: 22px;
  font-weight: 900;   /* Clear numbers */
  letter-spacing: 0.02em;
  color: #ffffff;
}

.auth-body .bp-loader-hint {
  font-size: 13px;
  font-weight: 650;
  color: rgba(255, 255, 255, 0.65);
}

/* Success page */
.auth-body .bp-success {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(240, 185, 11, 0.22);
  background: rgba(240, 185, 11, 0.10);
}

.auth-body .bp-success-badge {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #f0b90b;
  color: #0a0a0a;
  font-weight: 950;
  font-size: 18px;
}

.auth-body .bp-success-title {
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.01em;
}

.auth-body .bp-success-sub {
  margin-top: 2px;
  font-size: 13px;
  font-weight: 650;
  color: rgba(255, 255, 255, 0.72);
}

.auth-body .bp-message-card {
  margin-top: 14px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.92);
}

.auth-body .bp-message-text {
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.78);
}

.auth-body .bp-footnote {
  margin-top: 14px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.60);
  text-align: center;
}

/* =========================
   DEMO MODE WATERMARK
   ========================= */
.demo-watermark{
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 10000;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(0,0,0,0.72);
  border: 1px solid var(--accent-yellow);
  color: var(--accent-yellow);
  font-weight: 900;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  box-shadow: 0 14px 40px rgba(0,0,0,0.35);
  pointer-events: none;
}
/* ============================================================
   PATCH (2025-12-25)
   - Rolling digits support for new JS markup (.digit-roll/.digit-strip)
   - Futures positions (trades) panel: fit on mobile, prevent sideways drag
   - Safer overflow handling for list cards on touch devices
   ============================================================ */

/* Rolling digits (used by balances + trade amounts) */
.digit-roll{
  display:inline-block;
  height:1em;
  overflow:hidden;
  vertical-align:-0.08em;
  line-height:1em;
  font-variant-numeric: tabular-nums;
}
.digit-strip{
  display:block;
  transition: transform 650ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}
.digit-strip > span{
  display:block;
  height:1em;
  line-height:1em;
  font-variant-numeric: tabular-nums;
}

/* Keep punctuation static */
.bal-dot,
.bal-comma,
.bal-sign,
.bal-prefix,
.bal-int-static,
.bal-frac-static{
  display:inline-block;
  font-variant-numeric: tabular-nums;
}

/* Ensure rolling number blocks don't overflow in tight spaces */
#total-balance-usdt,
#spot-total-usdt,
#futures-balance-usdt,
#assets-total-balance-usdt,
#assets-futures-usdt,
#spot-total-usdt,
#spot-avbl-usdt{
  font-variant-numeric: tabular-nums;
}

/* Futures positions panel: prevent horizontal drag/scroll and keep content clipped */
#fut-positions-panel,
#fut-positions-body{
  overflow-x:hidden;
  touch-action: pan-y;
  overscroll-behavior-x: none;
}

/* Make grid cells shrink properly (prevents sideways overflow) */
.fut-pos-header,
.fut-pos-row{
  min-width:0;
}
.fut-pos-header > div,
.fut-pos-row > div{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* Mobile: show only core columns to keep panel fitting screen */
@media (max-width: 520px){
  .fut-pos-header,
  .fut-pos-row{
    grid-template-columns: 1.4fr 1fr 0.9fr 1fr 1fr; /* Symbol, PNL, ROI, Size, Margin */
    gap: 6px;
  }
  .fut-pos-header > div:nth-child(n+6),
  .fut-pos-row > div:nth-child(n+6){
    display:none !important; /* hide M.Ratio, Entry, Mark, Liq */
  }
}

/* General touch safety for list cards (prevents accidental sideways pan) */
.simple-card,
.simple-list,
.list-card{
  touch-action: pan-y;
  overscroll-behavior-x: none;
}
/* Home balance currency prefix ($) */
.currency-prefix{
  display:inline-block;
  margin-right: 6px;
  font-weight: 700;
  opacity: 0.95;
  line-height: 1;
  vertical-align: -0.06em;
  font-variant-numeric: tabular-nums;
}
/* Reduce accidental sideways movement on touch for the whole page */
body, main, .container, .page, .content{
  touch-action: pan-y;
  overscroll-behavior-x: none;
}
