/* ═══════════════════════════════════════════════════════
   JOYTRADE v3 — Oceanic Design System
   ═══════════════════════════════════════════════════════ */
:root {
  --bg-0:#030b14; --bg-1:#060f1e; --bg-2:#091526; --bg-3:#0d1f35;
  --bg-4:#112540; --bg-5:#162d4d;
  --teal:#00d4aa;   --teal-d:rgba(0,212,170,.10); --teal-g:rgba(0,212,170,.30);
  --cyan:#00b8d4;   --cyan-d:rgba(0,184,212,.10);
  --green:#00d4aa;  --green-d:rgba(0,212,170,.12);
  --red:#ff5c7a;    --red-d:rgba(255,92,122,.12);   --red-g:rgba(255,92,122,.28);
  --gold:#f0b429;   --gold-d:rgba(240,180,41,.12);
  --blue:#4a9eff;   --blue-d:rgba(74,158,255,.12);
  --tx1:#e2eef8; --tx2:#6b9ab8; --tx3:#2e4d66; --tx4:#1a3347;
  --br:rgba(0,212,170,.09); --br2:rgba(255,255,255,.06); --bra:rgba(0,212,170,.22);
  --sans:'Space Grotesk',sans-serif; --mono:'Space Mono',monospace;
  --hdr-h:56px; --flt-h:48px; --ticker-h:30px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--sans); background:var(--bg-0); color:var(--tx1);
  min-height:100vh; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--bg-5); border-radius:2px; }

/* ── BG EFFECTS ──────────────────────────────────────── */
.bg-glow { position:fixed; border-radius:50%; filter:blur(130px); pointer-events:none; z-index:0; }
.bg-g1 { width:800px; height:600px; top:-200px; right:-150px;
  background:radial-gradient(ellipse,rgba(0,212,170,.05),transparent 70%); }
.bg-g2 { width:600px; height:600px; bottom:-100px; left:-180px;
  background:radial-gradient(ellipse,rgba(0,184,212,.04),transparent 70%); }
.bg-grid { position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.32;
  background-image:linear-gradient(rgba(0,212,170,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,212,170,.03) 1px,transparent 1px);
  background-size:48px 48px; }

/* ── ANIMATIONS ──────────────────────────────────────── */
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.65)} }
@keyframes spin  { to{transform:rotate(360deg)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }
@keyframes slideInRight { from{transform:translateX(110%)} to{transform:translateX(0)} }
@keyframes slideInLeft  { from{transform:translateX(-110%)} to{transform:translateX(0)} }
@keyframes ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ═══════════════════════════════════════════════════════
   TOP HEADER
   ═══════════════════════════════════════════════════════ */
header {
  position:sticky; top:0; z-index:300; height:var(--hdr-h);
  background:rgba(3,11,20,.92); backdrop-filter:blur(28px) saturate(1.4);
  border-bottom:1px solid var(--br);
  display:flex; align-items:center; padding:0 16px; gap:12px;
}
.logo { font-family:var(--sans); font-weight:700; font-size:19px; letter-spacing:-.5px;
  display:flex; align-items:center; gap:8px; flex-shrink:0; user-select:none; }
.logo-icon { width:30px; height:30px;
  background:linear-gradient(135deg,var(--teal),var(--cyan));
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-size:15px; box-shadow:0 0 18px var(--teal-g); }
.logo em { color:var(--teal); font-style:normal; }
.hdr-right { display:flex; align-items:center; gap:8px; margin-left:auto; flex-shrink:0; }
.live-pill { display:flex; align-items:center; gap:6px; background:var(--bg-2);
  border:1px solid var(--br); border-radius:20px; padding:4px 11px;
  font-size:11px; font-family:var(--mono); color:var(--tx2); }
.live-dot { width:6px; height:6px; background:var(--teal); border-radius:50%;
  box-shadow:0 0 8px var(--teal-g); animation:pulse 2.2s infinite; }

/* ── NAV TABS in header ────────────────────────────────── */
.hdr-nav { display:flex; align-items:center; gap:2px; }
.nav-tab { font-size:11px; font-weight:700; color:var(--tx2); padding:6px 13px;
  border-radius:6px; cursor:pointer; transition:all .15s; white-space:nowrap;
  text-transform:uppercase; letter-spacing:.05em; }
.nav-tab:hover { color:var(--tx1); background:var(--bg-4); }
.nav-tab.active { color:var(--teal); background:var(--teal-d); }

/* ── BUTTONS ─────────────────────────────────────────── */
.btn { font-family:var(--sans); font-size:13px; font-weight:600; padding:8px 16px;
  border-radius:8px; border:none; cursor:pointer; transition:all .2s; white-space:nowrap; }
.btn-sm  { font-size:11px; padding:5px 12px; border-radius:6px; }
.btn-xs  { font-size:10px; padding:3px 9px;  border-radius:5px; font-weight:700; }
.btn-outline  { background:transparent; border:1px solid var(--bra); color:var(--teal); }
.btn-outline:hover  { background:var(--teal-d); box-shadow:0 0 18px var(--teal-g); }
.btn-primary  { background:linear-gradient(135deg,var(--teal),var(--cyan));
  color:#030b14; font-weight:700; box-shadow:0 4px 20px var(--teal-g); }
.btn-primary:hover  { box-shadow:0 4px 32px var(--teal-g); transform:translateY(-1px); }
.btn-primary:disabled { opacity:.5; cursor:not-allowed; transform:none; }
.btn-danger   { background:linear-gradient(135deg,var(--red),#e83366); color:#fff;
  font-weight:700; box-shadow:0 4px 18px var(--red-g); }
.btn-danger:hover   { box-shadow:0 4px 28px var(--red-g); transform:translateY(-1px); }
.btn-ghost    { background:var(--bg-3); color:var(--tx2); border:1px solid var(--br2); }
.btn-ghost:hover    { color:var(--tx1); background:var(--bg-4); }
.btn-long  { background:var(--green-d); color:var(--teal); border:1px solid rgba(0,212,170,.3);
  font-weight:700; padding:12px; border-radius:10px; font-size:14px; width:100%; }
.btn-long:hover  { background:rgba(0,212,170,.22); box-shadow:0 0 20px var(--teal-g); }
.btn-long:disabled { opacity:.5; cursor:not-allowed; }
.btn-short { background:var(--red-d); color:var(--red); border:1px solid rgba(255,92,122,.3);
  font-weight:700; padding:12px; border-radius:10px; font-size:14px; width:100%; }
.btn-short:hover { background:rgba(255,92,122,.22); box-shadow:0 0 20px var(--red-g); }
.btn-short:disabled { opacity:.5; cursor:not-allowed; }

/* Wallet */
.wallet-pill { display:none; align-items:center; gap:7px; background:var(--teal-d);
  border:1px solid var(--bra); border-radius:20px; padding:5px 13px;
  font-size:12px; font-family:var(--mono); color:var(--teal); cursor:pointer; }
.wallet-pill.show { display:flex; }
.wallet-pill:hover { background:rgba(0,212,170,.18); }
.wc-dot { width:7px; height:7px; background:var(--teal); border-radius:50%; box-shadow:0 0 8px var(--teal); }

/* ═══════════════════════════════════════════════════════
   FILTER BAR (below header)
   ═══════════════════════════════════════════════════════ */
.filter-bar {
  position:sticky; top:var(--hdr-h); z-index:200; height:var(--flt-h);
  background:rgba(6,15,30,.95); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--br);
  display:flex; align-items:center; padding:0 14px; gap:10px;
  overflow-x:auto; flex-wrap:nowrap; flex-shrink:0;
}
.filter-bar::-webkit-scrollbar { height:0; }

.filter-sep { width:1px; height:22px; background:var(--br2); flex-shrink:0; }

/* Search in bar */
.flt-search { display:flex; align-items:center; gap:7px; background:var(--bg-2);
  border:1px solid var(--br); border-radius:7px; padding:5px 10px;
  transition:border-color .2s; flex-shrink:0; min-width:0; }
.flt-search:focus-within { border-color:var(--bra); }
.flt-search svg { color:var(--tx3); flex-shrink:0; }
.flt-search input { background:none; border:none; outline:none; font-family:var(--sans);
  font-size:12px; color:var(--tx1); width:130px; }
.flt-search input::placeholder { color:var(--tx3); }

/* Chips */
.flt-chip { font-size:11px; font-weight:700; padding:4px 12px; border-radius:20px;
  border:1px solid var(--br); background:var(--bg-2); color:var(--tx3);
  cursor:pointer; transition:all .15s; text-transform:uppercase; letter-spacing:.04em;
  white-space:nowrap; flex-shrink:0; }
.flt-chip:hover { color:var(--tx2); border-color:var(--br2); }
.flt-chip.on     { color:var(--teal); border-color:var(--bra); background:var(--teal-d); }
.flt-chip.fav-on { color:var(--gold); border-color:rgba(240,180,41,.3); background:var(--gold-d); }
.flt-chip.cex-on { color:var(--cyan); border-color:rgba(0,184,212,.3); background:var(--cyan-d); }

/* Slider inline */
.flt-slider-wrap { display:flex; align-items:center; gap:7px; flex-shrink:0; }
.flt-slider-lbl  { font-size:10px; color:var(--tx3); white-space:nowrap; text-transform:uppercase; letter-spacing:.08em; }
.flt-slider-val  { font-size:11px; color:var(--teal); font-family:var(--mono); font-weight:700; min-width:40px; }
input[type=range] { width:90px; height:3px; -webkit-appearance:none; appearance:none;
  background:var(--bg-5); border-radius:2px; outline:none; cursor:pointer; }
input[type=range]::-webkit-slider-thumb { -webkit-appearance:none; width:13px; height:13px;
  background:var(--teal); border-radius:50%; box-shadow:0 0 8px var(--teal-g); cursor:pointer; }

/* Dropdown */
.flt-select { background:var(--bg-2); border:1px solid var(--br); border-radius:7px;
  padding:5px 28px 5px 10px; font-family:var(--sans); font-size:12px; color:var(--tx2);
  cursor:pointer; outline:none; flex-shrink:0;
  -webkit-appearance:none; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%236b9ab8' viewBox='0 0 16 16'%3E%3Cpath d='M8 10L3 5h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center; background-size:11px;
  transition:border-color .2s; }
.flt-select:focus { border-color:var(--bra); }

/* Exchange filter dropdown */
.exch-filter-wrap  { position:relative; flex-shrink:0; }
.exch-dropdown { position:absolute; top:calc(100% + 6px); left:0; z-index:500;
  background:var(--bg-2); border:1px solid var(--bra); border-radius:12px;
  width:280px; max-height:400px; overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.7);
  display:none; }
.exch-dropdown.open { display:block; animation:fadeUp .15s ease; }
.exch-group-header { font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.12em; color:var(--tx3); padding:12px 14px 6px; }
.exch-item { display:flex; align-items:center; gap:10px; padding:7px 14px;
  cursor:pointer; transition:background .1s; font-size:12px; }
.exch-item:hover { background:var(--bg-3); }
.exch-item label { cursor:pointer; color:var(--tx1); flex:1; user-select:none; }
.exch-tag-sm { font-size:9px; font-weight:700; padding:2px 6px; border-radius:3px;
  text-transform:uppercase; }
.tag-dex-sm { color:var(--teal); background:var(--teal-d); }
.tag-cex-sm { color:var(--cyan); background:var(--cyan-d); }
input[type=checkbox] { width:14px; height:14px; accent-color:var(--teal); cursor:pointer; flex-shrink:0; }
.exch-dd-footer { display:flex; gap:6px; padding:10px 14px; border-top:1px solid var(--br); }

/* ── TICKER ──────────────────────────────────────────── */
.ticker-bar { height:var(--ticker-h); background:var(--bg-1); border-bottom:1px solid var(--br);
  overflow:hidden; display:flex; align-items:center; position:relative; z-index:10; }
.ticker-track { display:flex; white-space:nowrap; animation:ticker 80s linear infinite; }
.ticker-track:hover { animation-play-state:paused; }
.t-item { display:flex; align-items:center; gap:8px; padding:0 18px; height:var(--ticker-h);
  font-size:11px; font-family:var(--mono); color:var(--tx2); border-right:1px solid var(--br); }
.t-sym  { color:var(--tx1); font-weight:700; }
.t-apy  { color:var(--teal); font-weight:700; }
.t-exch { color:var(--tx3); font-size:10px; }

/* ═══════════════════════════════════════════════════════
   MAIN CONTENT AREA
   ═══════════════════════════════════════════════════════ */
.content { padding:14px 14px 14px;  display:flex; flex-direction:column; gap:12px;
  position:relative; z-index:1; min-width:0; }

/* ── TOP OPPORTUNITY CARD ──────────────────────────────── */
.top-card { background:linear-gradient(135deg,rgba(0,212,170,.07),rgba(0,184,212,.03) 60%,transparent);
  border:1px solid var(--bra); border-radius:16px; padding:18px 22px;
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
  position:relative; overflow:hidden; animation:fadeUp .4s ease; }
.top-card::before { content:'⚡ TOP OPPORTUNITY'; position:absolute; top:10px; right:14px;
  font-size:9px; font-weight:700; letter-spacing:.18em; color:var(--teal); opacity:.4; }
.top-icon { width:42px; height:42px; background:var(--bg-4); border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:21px;
  border:1px solid var(--bra); flex-shrink:0; }
.top-sym  { font-family:var(--sans); font-size:22px; font-weight:700; flex-shrink:0; }
.top-meta { display:flex; flex-direction:column; gap:3px; }
.top-apy  { font-family:var(--mono); font-size:34px; font-weight:700;
  color:var(--teal); line-height:1; text-shadow:0 0 40px var(--teal-g); }
.top-apy-lbl { font-size:10px; color:var(--tx2); text-transform:uppercase; letter-spacing:.08em; }
.top-detail  { font-size:12px; color:var(--tx3); margin-top:2px; }
.top-detail span { color:var(--tx2); }
.top-actions { display:flex; align-items:center; gap:10px; margin-left:auto; flex-wrap:wrap; }
.trade-badge { display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:10px 16px; border-radius:12px; cursor:pointer; transition:all .2s;
  border:1px solid transparent; text-align:center; font-size:13px; font-weight:700; }
.trade-badge small { font-size:10px; font-weight:500; opacity:.65;
  text-transform:uppercase; letter-spacing:.06em; }
.tb-long  { background:var(--green-d); border-color:rgba(0,212,170,.3); color:var(--teal); }
.tb-long:hover  { background:rgba(0,212,170,.22); box-shadow:0 0 24px var(--teal-g); transform:translateY(-2px); }
.tb-short { background:var(--red-d); border-color:rgba(255,92,122,.3); color:var(--red); }
.tb-short:hover { background:rgba(255,92,122,.22); box-shadow:0 0 24px var(--red-g); transform:translateY(-2px); }
.badge-sep { font-size:20px; color:var(--tx4); }

/* ═══════════════════════════════════════════════════════
   TABLE — STICKY HEADERS + FROZEN LEFT COLS
   ═══════════════════════════════════════════════════════ */
.table-card { background:var(--bg-1); border:1px solid var(--br); border-radius:16px;
  overflow:hidden; animation:fadeUp .4s .05s ease both; display:flex; flex-direction:column; }
.table-toolbar { display:flex; align-items:center; justify-content:space-between;
  padding:11px 16px; border-bottom:1px solid var(--br); flex-wrap:wrap; gap:8px; flex-shrink:0; }
.table-title { font-size:14px; font-weight:700; display:flex; align-items:center; gap:10px; }
.pair-count { font-size:11px; color:var(--tx3); background:var(--bg-4);
  padding:3px 10px; border-radius:20px; font-family:var(--mono); }

/* The key: outer div has max-height + overflow for both axes */
.table-scroll-outer {
  overflow:auto;
  /* Height = viewport minus header, filter bar, ticker, toolbar, top card, footer */
  max-height:calc(100vh - var(--hdr-h) - var(--flt-h) - var(--ticker-h) - 48px - 140px - 54px);
  min-height:300px;
  position:relative;
}

table { width:max-content; min-width:100%; border-collapse:separate; border-spacing:0; }

/* STICKY HEADER ROW */
thead th {
  padding:9px 12px; text-align:left;
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  color:var(--tx3); background:var(--bg-2);
  border-bottom:1px solid var(--br);
  cursor:pointer; user-select:none; white-space:nowrap;
  transition:color .15s;
  /* Sticky vertical */
  position:sticky; top:0; z-index:2;
}
thead th:hover  { color:var(--tx2); }
thead th.sorted { color:var(--teal); }
.sort-arrow { font-size:10px; margin-left:2px; }

/* FROZEN COLUMNS — first 3 columns: ★, Symbol, APY */
/* Column indices: 0=fav, 1=symbol, 2=APY */
thead th:nth-child(1),
tbody td:nth-child(1) {
  position:sticky; left:0; z-index:3;
  background:var(--bg-2);
  min-width:34px; max-width:34px; width:34px;
}
thead th:nth-child(2),
tbody td:nth-child(2) {
  position:sticky; left:34px; z-index:3;
  background:var(--bg-2);
  min-width:150px;
  /* Right border to visually separate from scrolling part */
  border-right:1px solid var(--br2);
  box-shadow:2px 0 8px rgba(0,0,0,.3);
}
/* Corner: frozen + sticky = highest z */
thead th:nth-child(1) { z-index:4; }
thead th:nth-child(2) { z-index:4; }

tbody td {
  padding:10px 12px; font-size:12px;
  border-bottom:1px solid rgba(255,255,255,.023);
  vertical-align:middle; white-space:nowrap; transition:background .1s;
  background:var(--bg-1);
}
/* Frozen cols need bg too for opacity on scroll */
tbody td:nth-child(1) { background:var(--bg-1); }
tbody td:nth-child(2) { background:var(--bg-1); }

tbody tr:hover td { background:rgba(0,212,170,.02); }
tbody tr:hover td:nth-child(1),
tbody tr:hover td:nth-child(2) { background:rgba(0,212,170,.02); }
tbody tr:last-child td { border-bottom:none; }
tbody tr { animation:fadeUp .3s ease both; }
tbody tr:nth-child(1){animation-delay:.02s} tbody tr:nth-child(2){animation-delay:.04s}
tbody tr:nth-child(3){animation-delay:.06s} tbody tr:nth-child(4){animation-delay:.08s}
tbody tr:nth-child(5){animation-delay:.10s} tbody tr:nth-child(6){animation-delay:.12s}

/* Fav button */
.fav-btn { background:none; border:none; cursor:pointer; font-size:14px;
  color:var(--tx4); transition:all .15s; padding:2px 4px; display:block; }
.fav-btn:hover  { color:var(--gold); transform:scale(1.2); }
.fav-btn.active { color:var(--gold); }

/* Symbol cell */
.sym-cell { display:flex; align-items:center; gap:8px; }
.sym-icon { width:28px; height:28px; background:var(--bg-4); border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:13px;
  flex-shrink:0; border:1px solid var(--br); }
.sym-name { font-weight:700; font-size:13px; color:var(--tx1); }
.sym-sub  { font-size:10px; color:var(--tx3); font-family:var(--mono); }

/* APY pill */
.apy-pill { display:inline-flex; padding:4px 10px; border-radius:6px;
  font-family:var(--mono); font-weight:700; font-size:12px; }
.apy-fire { background:rgba(0,212,170,.18); color:var(--teal); }
.apy-hot  { background:rgba(240,180,41,.15); color:var(--gold); }
.apy-warm { background:rgba(74,158,255,.15); color:var(--blue); }
.apy-cool { background:rgba(255,92,122,.12); color:var(--red); }

/* Exchange rate cells */
.rate-cell { display:flex; flex-direction:column; align-items:center;
  min-width:74px; padding:5px 7px; border-radius:6px; cursor:pointer;
  transition:all .15s; font-family:var(--mono); font-size:11px; font-weight:700;
  border:1px solid transparent; }
.rate-cell:hover { filter:brightness(1.2); transform:scale(1.04); }
.rate-cell.r-pos-hi { background:rgba(255,92,122,.18); color:var(--red);  border-color:rgba(255,92,122,.3); }
.rate-cell.r-pos    { background:rgba(255,92,122,.07); color:var(--red); }
.rate-cell.r-neg-hi { background:rgba(0,212,170,.18);  color:var(--teal); border-color:rgba(0,212,170,.3); }
.rate-cell.r-neg    { background:rgba(0,212,170,.07);  color:var(--teal); }
.rate-cell.r-zero   { background:var(--bg-3);           color:var(--tx2); }
.rate-cell.best-long  { border-color:var(--teal)!important; box-shadow:0 0 10px rgba(0,212,170,.25); }
.rate-cell.best-short { border-color:var(--red)!important;  box-shadow:0 0 10px rgba(255,92,122,.25); }
.rc-tag { font-size:9px; padding:1px 4px; border-radius:3px; margin-top:2px; opacity:.75; }
.r-pos-hi .rc-tag,.r-pos .rc-tag { background:rgba(255,92,122,.15); color:var(--red); }
.r-neg-hi .rc-tag,.r-neg .rc-tag { background:rgba(0,212,170,.15);  color:var(--teal); }
.rate-empty { color:var(--tx4); font-size:11px; padding:0 8px; }

/* Spread bar */
.spr-cell { display:flex; align-items:center; gap:7px; min-width:80px; }
.spr-bar  { height:3px; background:var(--bg-5); border-radius:2px; flex:1; overflow:hidden; }
.spr-fill { height:100%; border-radius:2px; }
.spr-num  { font-family:var(--mono); font-size:11px; font-weight:700; min-width:44px; text-align:right; }
.rate-pos { color:var(--teal); font-weight:700; font-family:var(--mono); }
.rate-neg { color:var(--red);  font-weight:700; font-family:var(--mono); }

/* Loading */
.state-row td { text-align:center; padding:60px; color:var(--tx3); }
.spinner { display:inline-block; width:20px; height:20px; border:2px solid var(--bg-5);
  border-top-color:var(--teal); border-radius:50%; animation:spin .8s linear infinite;
  vertical-align:middle; margin-right:8px; }

/* ═══════════════════════════════════════════════════════
   DEX TRADING PANEL (slide in from right)
   ═══════════════════════════════════════════════════════ */
.trade-panel-overlay {
  position:fixed; inset:0; z-index:400;
  background:rgba(3,11,20,.6); backdrop-filter:blur(6px);
  opacity:0; pointer-events:none; transition:opacity .25s;
}
.trade-panel-overlay.open { opacity:1; pointer-events:all; }

.trade-panel {
  position:fixed; top:0; right:0; bottom:0; z-index:401;
  width:min(460px, 100vw);
  background:var(--bg-1);
  border-left:1px solid var(--bra);
  display:flex; flex-direction:column;
  transform:translateX(110%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:-20px 0 60px rgba(0,0,0,.5);
}
.trade-panel.open { transform:translateX(0); animation:slideInRight .3s cubic-bezier(.4,0,.2,1); }

.tp-header { display:flex; align-items:center; gap:12px; padding:16px 18px;
  border-bottom:1px solid var(--br); flex-shrink:0; }
.tp-close  { background:var(--bg-3); border:1px solid var(--br); border-radius:7px;
  width:30px; height:30px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:15px; color:var(--tx2); transition:all .15s; flex-shrink:0; }
.tp-close:hover { color:var(--tx1); background:var(--bg-4); }
.tp-title { font-family:var(--sans); font-size:16px; font-weight:700; flex:1; }
.tp-exch-badge { font-size:11px; font-weight:700; padding:4px 10px; border-radius:6px; }
.tp-dex-badge { color:var(--teal); background:var(--teal-d); border:1px solid var(--bra); }
.tp-cex-badge { color:var(--cyan); background:var(--cyan-d); border:1px solid rgba(0,184,212,.2); }

.tp-body { flex:1; overflow-y:auto; padding:18px; display:flex; flex-direction:column; gap:16px; }

/* Wallet connect section */
.tp-wallet { background:var(--bg-2); border:1px solid var(--br); border-radius:12px; padding:16px; }
.tp-wallet-title { font-size:12px; font-weight:700; color:var(--tx2);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:12px; }
.tp-wallet-options { display:flex; flex-direction:column; gap:7px; }
.tp-w-opt { display:flex; align-items:center; gap:11px; padding:11px 13px;
  background:var(--bg-3); border:1px solid var(--br); border-radius:10px;
  cursor:pointer; transition:all .18s; }
.tp-w-opt:hover { border-color:var(--bra); transform:translateX(2px); }
.tp-w-ico { width:30px; height:30px; border-radius:8px;
  display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.tp-w-name { font-weight:700; font-size:13px; color:var(--tx1); }
.tp-w-sub  { font-size:11px; color:var(--tx3); }
.tp-w-arr  { margin-left:auto; color:var(--tx3); }

/* Connected wallet bar */
.tp-wallet-connected { display:none; align-items:center; gap:9px;
  background:var(--teal-d); border:1px solid var(--bra); border-radius:10px; padding:10px 14px; }
.tp-wallet-connected.show { display:flex; }
.tp-wc-addr { font-family:var(--mono); font-size:12px; color:var(--teal); flex:1; }
.tp-wc-disc { cursor:pointer; color:var(--tx3); font-size:11px; transition:color .15s; }
.tp-wc-disc:hover { color:var(--red); }

/* Market info */
.tp-market { background:var(--bg-2); border:1px solid var(--br); border-radius:12px; padding:14px; }
.tp-market-row { display:flex; justify-content:space-between; align-items:center;
  font-size:13px; padding:4px 0; border-bottom:1px solid rgba(255,255,255,.03); }
.tp-market-row:last-child { border-bottom:none; }
.tp-mk { color:var(--tx2); }
.tp-mv { color:var(--tx1); font-weight:700; font-family:var(--mono); }
.tp-mv.up   { color:var(--teal); }
.tp-mv.down { color:var(--red); }

/* Pacifica builder steps */
.pac-steps { display:flex; flex-direction:column; gap:7px; margin-bottom:4px; }
.pac-step  { display:flex; align-items:flex-start; gap:11px; padding:11px 13px;
  background:var(--bg-2); border:1px solid var(--br); border-radius:10px; transition:all .2s; }
.pac-step.active { border-color:var(--bra); background:rgba(0,212,170,.04); }
.pac-step.done   { border-color:rgba(0,212,170,.35); opacity:.7; }
.pac-step-num { width:22px; height:22px; border-radius:50%; background:var(--bg-4);
  border:1px solid var(--br); display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; color:var(--tx2); flex-shrink:0; }
.pac-step.active .pac-step-num { background:var(--teal); color:#030b14; border:none; }
.pac-step.done   .pac-step-num { background:rgba(0,212,170,.3); color:var(--teal); }
.pac-step-title { font-weight:700; font-size:12px; color:var(--tx2); }
.pac-step.active .pac-step-title { color:var(--tx1); }
.pac-step-desc  { font-size:10px; color:var(--tx3); margin-top:2px; }

/* Order form */
.tp-form { background:var(--bg-2); border:1px solid var(--br); border-radius:12px; padding:16px;
  display:flex; flex-direction:column; gap:12px; }
.tp-form-label { font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; color:var(--tx3); margin-bottom:5px; display:block; }
.tp-order-type { display:flex; gap:6px; }
.tp-ot-btn { flex:1; font-family:var(--sans); font-size:12px; font-weight:700;
  padding:7px 12px; border-radius:7px; border:1px solid var(--br);
  background:var(--bg-3); color:var(--tx3); cursor:pointer; transition:all .15s; }
.tp-ot-btn.active { color:var(--teal); border-color:var(--bra); background:var(--teal-d); }
.tp-input-box { background:var(--bg-3); border:1px solid var(--br); border-radius:10px;
  padding:11px 13px; display:flex; align-items:center; justify-content:space-between;
  transition:border-color .2s; }
.tp-input-box:focus-within { border-color:var(--bra); }
.tp-input-box input { background:none; border:none; outline:none; font-family:var(--mono);
  font-size:18px; font-weight:700; color:var(--tx1); width:100%; }
.tp-input-cur { font-size:12px; font-weight:700; color:var(--tx2); flex-shrink:0; }
.lev-row { display:flex; align-items:center; gap:10px; }
.lev-lbl { font-size:11px; color:var(--tx2); flex-shrink:0; }
.lev-val { background:var(--bg-4); border-radius:6px; padding:4px 11px;
  font-family:var(--mono); font-size:13px; font-weight:700; color:var(--teal);
  min-width:46px; text-align:center; flex-shrink:0; }
.tp-ls-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.tp-est { display:flex; flex-direction:column; gap:5px;
  background:var(--bg-3); border-radius:8px; padding:10px 12px; }
.tp-est-row { display:flex; justify-content:space-between; font-size:12px; }
.tp-est-k { color:var(--tx2); }
.tp-est-v { color:var(--tx1); font-weight:700; font-family:var(--mono); }
.tp-est-v.g { color:var(--teal); }

/* Not available panel */
.tp-not-available { background:var(--bg-2); border:1px solid var(--br); border-radius:12px;
  padding:20px; text-align:center; }
.tp-na-ico { font-size:32px; margin-bottom:10px; }
.tp-na-title { font-size:15px; font-weight:700; margin-bottom:6px; }
.tp-na-desc { font-size:12px; color:var(--tx2); line-height:1.6; margin-bottom:14px; }
.tp-na-url  { word-break:break-all; font-family:var(--mono); font-size:11px;
  color:var(--teal); background:var(--teal-d); padding:8px 12px; border-radius:8px;
  display:block; margin-bottom:12px; }

/* ═══════════════════════════════════════════════════════
   MODAL (Wallet select + CEX confirm)
   ═══════════════════════════════════════════════════════ */
.overlay { position:fixed; inset:0; z-index:600; background:rgba(3,11,20,.8);
  backdrop-filter:blur(12px); display:flex; align-items:center; justify-content:center;
  padding:16px; opacity:0; pointer-events:none; transition:opacity .22s; }
.overlay.open { opacity:1; pointer-events:all; }
.modal { background:var(--bg-2); border:1px solid var(--bra); border-radius:18px;
  width:100%; max-width:440px; padding:26px; position:relative; max-height:90vh; overflow-y:auto;
  transform:translateY(16px) scale(.97);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 40px 100px rgba(0,0,0,.7); }
.overlay.open .modal { transform:none; }
.modal-x { position:absolute; top:16px; right:16px; width:30px; height:30px; border-radius:7px;
  background:var(--bg-4); border:1px solid var(--br); display:flex; align-items:center;
  justify-content:center; cursor:pointer; font-size:14px; color:var(--tx2); transition:all .15s; }
.modal-x:hover { color:var(--tx1); background:var(--bg-5); }
.modal-title { font-size:20px; font-weight:700; margin-bottom:5px; }
.modal-sub   { font-size:13px; color:var(--tx2); margin-bottom:20px; line-height:1.5; }
.wallet-sec  { font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.14em; color:var(--tx3); margin:14px 0 8px; }
.wallet-sec:first-of-type { margin-top:0; }
.wallet-list { display:flex; flex-direction:column; gap:7px; }
.wallet-opt  { display:flex; align-items:center; gap:12px; padding:12px 14px;
  background:var(--bg-3); border:1px solid var(--br); border-radius:12px;
  cursor:pointer; transition:all .2s; }
.wallet-opt:hover { border-color:var(--bra); background:var(--bg-4); transform:translateX(2px); }
.w-ico  { width:34px; height:34px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:19px; }
.w-name { font-weight:700; font-size:13px; color:var(--tx1); }
.w-sub  { font-size:11px; color:var(--tx3); margin-top:1px; }
.w-arr  { margin-left:auto; color:var(--tx3); }
.cex-warning { background:rgba(240,180,41,.06); border:1px solid rgba(240,180,41,.2);
  border-radius:8px; padding:11px 13px; font-size:12px; color:var(--gold); line-height:1.6; margin-bottom:14px; }
.modal-actions { display:flex; gap:8px; margin-top:16px; }
.modal-actions .btn { flex:1; text-align:center; }

/* ── TOAST ───────────────────────────────────────────── */
.toast { position:fixed; bottom:20px; right:20px; z-index:700;
  background:var(--bg-2); border:1px solid var(--bra); border-radius:12px;
  padding:12px 16px; display:flex; align-items:flex-start; gap:10px;
  max-width:300px; box-shadow:0 20px 60px rgba(0,0,0,.5);
  transform:translateY(14px) scale(.97); opacity:0;
  transition:all .3s cubic-bezier(.34,1.56,.64,1); pointer-events:none; }
.toast.show { transform:none; opacity:1; pointer-events:all; }
.toast-ico  { font-size:17px; flex-shrink:0; margin-top:1px; }
.toast-text { font-size:13px; font-weight:600; color:var(--tx1); }
.toast-sub  { font-size:11px; color:var(--tx2); margin-top:2px; }

/* ── FOOTER ──────────────────────────────────────────── */
footer { border-top:1px solid var(--br); background:var(--bg-1);
  padding:13px 20px; display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:8px; font-size:11px; color:var(--tx3);
  position:relative; z-index:1; }
.ft-brand { display:flex; align-items:center; gap:7px; font-weight:700; color:var(--tx2); }
.ft-links { display:flex; gap:16px; }
.ft-link  { color:var(--tx3); cursor:pointer; transition:color .15s; text-decoration:none; }
.ft-link:hover { color:var(--tx2); }
.ft-attr a { color:var(--tx2); text-decoration:none; }
.ft-attr a:hover { color:var(--teal); }

/* ═══════════════════════════════════════════════════════
   BACKTESTER SECTION
   ═══════════════════════════════════════════════════════ */
.bt-panel { background:var(--bg-1); border:1px solid var(--br); border-radius:16px; padding:22px; }
.bt-title { font-size:16px; font-weight:700; margin-bottom:16px; display:flex; align-items:center; gap:10px; }
.bt-form  { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:12px; }
.bt-field { display:flex; flex-direction:column; gap:5px; }
.bt-lbl   { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--tx3); }
.bt-input { background:var(--bg-2); border:1px solid var(--br); border-radius:8px;
  padding:8px 11px; font-family:var(--sans); font-size:13px; color:var(--tx1);
  outline:none; width:100%; transition:border-color .2s; }
.bt-input:focus { border-color:var(--bra); }
.bt-stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); gap:10px; margin-top:16px; }
.bt-stat  { background:var(--bg-2); border:1px solid var(--br); border-radius:10px; padding:13px; }
.bt-stat-lbl { font-size:10px; color:var(--tx3); text-transform:uppercase; letter-spacing:.1em; margin-bottom:5px; }
.bt-stat-val { font-size:22px; font-weight:700; font-family:var(--mono); color:var(--teal); }
.bt-stat-val.red  { color:var(--red); }
.bt-stat-val.gold { color:var(--gold); }
.bt-chart-wrap { margin-top:16px; background:var(--bg-2); border:1px solid var(--br);
  border-radius:12px; padding:14px; }
.bt-disclaimer { font-size:11px; color:var(--gold); margin-top:12px;
  background:rgba(240,180,41,.05); border:1px solid rgba(240,180,41,.15);
  border-radius:8px; padding:10px 12px; line-height:1.6; }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — MOBILE
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  :root { --hdr-h:52px; --flt-h:44px; }

  header { padding:0 12px; gap:8px; }
  .logo { font-size:17px; }
  .logo-icon { width:26px; height:26px; font-size:13px; }
  .hdr-nav { display:none; } /* hidden on mobile, use bottom nav */
  .live-pill { display:none; }

  .filter-bar { padding:0 10px; gap:8px; height:auto; min-height:var(--flt-h);
    flex-wrap:wrap; padding-top:8px; padding-bottom:8px; }
  .flt-search input { width:100px; }

  .content { padding:10px; gap:10px; }
  .top-card { padding:14px 16px; }
  .top-apy  { font-size:28px; }
  .top-sym  { font-size:18px; }
  .top-actions { width:100%; }

  .table-scroll-outer { max-height:50vh; }

  /* Trade panel full screen on mobile */
  .trade-panel { width:100%; }

  /* Bottom navigation on mobile */
  .mobile-nav { display:flex; }
  footer { display:none; }
}

@media (min-width: 769px) {
  .mobile-nav { display:none !important; }
}

.mobile-nav {
  position:fixed; bottom:0; left:0; right:0; z-index:350;
  background:rgba(6,15,30,.95); border-top:1px solid var(--br);
  display:none; align-items:center; justify-content:space-around;
  padding:8px 0 max(8px, env(safe-area-inset-bottom));
  backdrop-filter:blur(20px);
}
.mob-nav-item { display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:6px 16px; cursor:pointer; font-size:10px; font-weight:700;
  color:var(--tx3); text-transform:uppercase; letter-spacing:.06em; transition:color .15s; }
.mob-nav-item.active { color:var(--teal); }
.mob-nav-item span:first-child { font-size:18px; }

/* DROPDOWN FIX */
.filter-bar { overflow: visible !important; }
.exch-dropdown { position:fixed !important; z-index:9999 !important; }

/* EXCHANGES DROPDOWN FIX */
.filter-bar { overflow: visible !important; }
.exch-dropdown { position:fixed !important; z-index:9999 !important; }

/* EXCHANGES DROPDOWN FIX */
.filter-bar { overflow: visible !important; }
.exch-dropdown { position:fixed !important; z-index:9999 !important; }
