@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

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

:root {
  --bg:        #0b0c0f;
  --bg2:       #111318;
  --bg3:       #181b22;
  --bg4:       #1e2230;
  --border:    rgba(255,255,255,0.07);
  --border2:   rgba(255,255,255,0.12);

  --text:      #e2e4ea;
  --text2:     #8b92a5;
  --text3:     #555d72;

  --green:     #00c896;
  --green-dim: rgba(0,200,150,0.12);
  --red:       #f5475c;
  --red-dim:   rgba(245,71,92,0.12);
  --pnl-red:   #d98a93;
  --pnl-red-dim: rgba(217,138,147,0.16);
  --blue:      #4d8cf5;
  --blue-dim:  rgba(77,140,245,0.1);
  --amber:     #f5a623;
  --amber-dim: rgba(245,166,35,0.1);
  --purple:    #a78bfa;

  --radius:  6px;
  --radius2: 10px;
}

html, body { height: 100%; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  display: flex;
  font-size: 13px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* ── Sidebar ─────────────────────────────────────────────────────────────── */
#sidebar {
  width: 200px;
  min-height: 100vh;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  height: 100vh;
}

.sidebar-logo {
  padding: 20px 16px 16px;
  border-bottom: 1px solid var(--border);
}
.logo-mark {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 500;
  color: var(--green);
  letter-spacing: 2px;
  text-transform: uppercase;
}
.logo-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin-top: 2px;
}

nav { padding: 8px 0; flex: 1; }

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  cursor: pointer;
  color: var(--text2);
  font-size: 13px;
  font-weight: 500;
  transition: color 0.15s, background 0.15s;
  border-left: 2px solid transparent;
}
.nav-item:hover { color: var(--text); background: rgba(255,255,255,0.03); }
.nav-item.active {
  color: var(--text);
  background: rgba(0,200,150,0.06);
  border-left-color: var(--green);
}
.nav-icon { font-size: 14px; width: 18px; text-align: center; }

.sidebar-bottom {
  padding: 14px 16px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 11px;
  color: var(--text3);
}
.ws-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--text3);
  flex-shrink: 0;
  transition: background 0.3s;
}
.ws-dot.connected { background: var(--green); box-shadow: 0 0 6px var(--green); }

/* ── Main ────────────────────────────────────────────────────────────────── */
#main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── Top header bar ──────────────────────────────────────────────────────── */
#topbar {
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  height: 48px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-shrink: 0;
}
.tb-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text2);
}
.tb-val {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text);
  font-size: 12px;
  font-weight: 500;
}
.tb-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--text3);
  transition: background 0.3s;
}
.tb-dot.running { background: var(--green); box-shadow: 0 0 8px rgba(0,200,150,0.6); }
.tb-mode-live { color: var(--green) !important; font-weight: 600; }
.tb-mode-dry  { color: var(--amber) !important; font-weight: 600; }
.tb-sep { width: 1px; height: 16px; background: var(--border2); flex-shrink: 0; }

/* ── Pages ───────────────────────────────────────────────────────────────── */
.page { display: none; flex: 1; padding: 24px; overflow-y: auto; height: calc(100vh - 48px); }
.page.active { display: block; }

.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 20px;
}
.page-title { font-size: 18px; font-weight: 700; color: var(--text); }
.page-sub { font-size: 12px; color: var(--text2); margin-top: 2px; }

/* ── Stat grid ───────────────────────────────────────────────────────────── */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}
.stat-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  padding: 16px;
}
.stat-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.stat-value {
  font-family: 'JetBrains Mono', monospace;
  font-size: 20px;
  font-weight: 600;
  color: var(--text);
  margin-top: 8px;
  line-height: 1.2;
}
.stat-sub {
  font-size: 11px;
  color: var(--text2);
  margin-top: 4px;
  font-family: 'JetBrains Mono', monospace;
}
.c-green  { color: var(--green); }
.c-red    { color: var(--red); }
.pnl-negative { color: var(--pnl-red); }
.c-blue   { color: var(--blue); }
.c-amber  { color: var(--amber); }
.c-purple { color: var(--purple); }

/* ── Cards ───────────────────────────────────────────────────────────────── */
.card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  padding: 16px;
  margin-bottom: 14px;
}
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.card-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border2);
  background: transparent;
  color: var(--text);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  white-space: nowrap;
}
.btn:hover { background: rgba(255,255,255,0.06); }
.btn-primary { background: var(--green); border-color: var(--green); color: #000; font-weight: 600; }
.btn-primary:hover { background: #00dcaa; border-color: #00dcaa; }
.btn-danger { border-color: transparent; color: var(--red); }
.btn-danger:hover { background: var(--red-dim); border-color: var(--red); }
.btn-ghost { border-color: transparent; color: var(--text2); }
.btn-ghost:hover { color: var(--text); background: rgba(255,255,255,0.05); }

.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text2);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.15s;
}
.icon-btn:hover { border-color: var(--border2); color: var(--text); background: rgba(255,255,255,0.05); }
.icon-btn.i-danger:hover { border-color: var(--red); color: var(--red); background: var(--red-dim); }
.icon-btn.i-green:hover  { border-color: var(--green); color: var(--green); background: var(--green-dim); }
.icon-btn.i-orange       { border-color: var(--amber); color: var(--amber); background: rgba(245,166,35,0.1); }
.icon-btn.i-orange:hover { border-color: var(--amber); color: var(--amber); background: rgba(245,166,35,0.18); }

/* ── Tables ──────────────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; border-radius: var(--radius2); }
table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
thead th {
  padding: 9px 14px;
  text-align: left;
  font-size: 10.5px;
  font-weight: 600;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  background: var(--bg2);
}
tbody td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: middle;
}
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: rgba(255,255,255,0.02); }
.mono { font-family: 'JetBrains Mono', monospace; font-size: 12px; }

/* ── Badges ──────────────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.3px;
  white-space: nowrap;
}
.badge-green  { background: var(--green-dim);  color: var(--green); }
.badge-red    { background: var(--red-dim);    color: var(--red); }
.badge-blue   { background: var(--blue-dim);   color: var(--blue); }
.badge-amber  { background: var(--amber-dim);  color: var(--amber); }
.badge-dim    { background: rgba(255,255,255,0.06); color: var(--text2); }
.badge-purple { background: rgba(167,139,250,0.12); color: var(--purple); }
.badge-orange { background: rgba(245,166,35,0.15);  color: var(--amber); }

.risk-thresholds {
  font-size: 11px;
  color: var(--text2);
  font-family: 'JetBrains Mono', monospace;
}
.risk-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
}

.dir-buy  { color: var(--green); font-weight: 600; font-size: 11px; }
.dir-sell { color: var(--red);   font-weight: 600; font-size: 11px; }

/* ── Target list ─────────────────────────────────────────────────────────── */
.target-list { display: flex; flex-direction: column; gap: 2px; }
.target-row {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 10px 14px;
  background: var(--bg3);
  border-radius: var(--radius);
  border: 1px solid transparent;
  transition: border-color 0.15s, background 0.15s;
}
.target-row:hover { background: var(--bg4); border-color: var(--border2); }
.target-row.disabled { opacity: 0.45; }

.target-identity { flex: 0 0 160px; min-width: 0; overflow: hidden; }
.target-name {
  font-weight: 600;
  font-size: 13px;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 6px;
}
.target-addr {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--text3);
  margin-top: 2px;
}
.pm-profile-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dashed var(--text3);
  transition: color 0.15s, border-color 0.15s;
}
.pm-profile-link:hover {
  color: var(--blue);
  border-color: var(--blue);
}

.target-metrics {
  display: flex;
  gap: 24px;
  flex: 1;
  flex-wrap: wrap;
  padding: 0 16px;
}
.tm-item { min-width: 72px; }
.tm-label {
  font-size: 10px;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.tm-val {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text);
  margin-top: 1px;
}

.target-actions { display: flex; gap: 4px; flex-shrink: 0; }

/* ── Params grid ─────────────────────────────────────────────────────────── */
.params-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 24px;
}
.param-row { display: flex; flex-direction: column; gap: 5px; }
.param-label { font-size: 11px; color: var(--text2); font-weight: 500; }
.param-input {
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  color: var(--text);
  font-size: 13px;
  font-family: 'JetBrains Mono', monospace;
  padding: 7px 10px;
  width: 100%;
  outline: none;
  transition: border-color 0.15s;
}
.param-input:focus { border-color: var(--green); }
.param-row-inline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
}

/* toggle */
.toggle { position: relative; display: inline-block; width: 36px; height: 20px; cursor: pointer; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-track {
  position: absolute; inset: 0;
  background: var(--bg4);
  border: 1px solid var(--border2);
  border-radius: 20px;
  transition: background 0.2s, border-color 0.2s;
}
.toggle input:checked + .toggle-track { background: var(--green); border-color: var(--green); }
.toggle-thumb {
  position: absolute;
  top: 3px; left: 3px;
  width: 14px; height: 14px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.2s;
  pointer-events: none;
}
.toggle input:checked ~ .toggle-thumb { transform: translateX(16px); }

/* ── Group rows in positions table ───────────────────────────────────────── */
.row-group-hd td {
  background: rgba(255,255,255,0.025);
  color: var(--text2);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
}
.row-group-hd:hover td { background: rgba(255,255,255,0.04); }
.row-child td { padding-left: 28px; }

/* ── Modal ───────────────────────────────────────────────────────────────── */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.65);
  z-index: 100;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(3px);
}
.modal-overlay.open { display: flex; }
.modal {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: var(--radius2);
  padding: 24px;
  width: 420px;
  max-width: 94vw;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5);
}
.modal-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 20px; }
.modal-field { margin-bottom: 14px; }
.modal-field label {
  display: block;
  font-size: 11px;
  color: var(--text2);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  margin-bottom: 5px;
}
.modal-field input {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  color: var(--text);
  font-size: 13px;
  padding: 8px 10px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s;
}
.modal-field input:focus { border-color: var(--green); }
.modal-footer { display: flex; justify-content: flex-end; gap: 8px; margin-top: 20px; }

/* ── Toast ───────────────────────────────────────────────────────────────── */
#toast {
  display: none;
  position: fixed;
  bottom: 24px;
  right: 24px;
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  padding: 10px 16px;
  font-size: 13px;
  color: var(--text);
  z-index: 200;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  max-width: 320px;
}
#toast.error { border-color: var(--red); color: var(--red); }
#toast.ok    { border-color: var(--green); }

/* ── Account page — portfolio banner ─────────────────────────────────────── */
.acct-banner {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  padding: 24px 28px;
  margin-bottom: 20px;
  display: flex;
  align-items: flex-end;
  gap: 48px;
  flex-wrap: wrap;
}
.acct-main-val {
  font-family: 'JetBrains Mono', monospace;
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.acct-main-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}
.acct-stat { display: flex; flex-direction: column; }
.acct-stat-val {
  font-family: 'JetBrains Mono', monospace;
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
}
.acct-stat-label { font-size: 11px; color: var(--text2); margin-top: 3px; }

/* ── Account page — position rows ────────────────────────────────────────── */
.pos-market-row {
  display: grid;
  grid-template-columns: 1fr 90px 110px 90px 120px 100px 80px;
  align-items: center;
  padding: 13px 16px;
  border-bottom: 1px solid var(--border);
  transition: background 0.12s;
  cursor: pointer;
}
.pos-market-row:last-child { border-bottom: none; }
.pos-market-row:hover { background: rgba(255,255,255,0.025); }
.pos-market-row.expanded { background: rgba(255,255,255,0.015); }

.pmr-header {
  display: grid;
  grid-template-columns: 1fr 90px 110px 90px 120px 100px 80px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
}
.pmr-hcell {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.pmr-hcell.r { text-align: right; }

.pmr-market { min-width: 0; }
.pmr-market-slug {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pmr-market-token {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--text3);
  margin-top: 2px;
}

.pmr-outcome {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3px;
  width: fit-content;
}
.pmr-outcome.yes {
  background: var(--green-dim);
  color: var(--green);
  border: 1px solid rgba(0,200,150,0.25);
}
.pmr-outcome.no {
  background: var(--red-dim);
  color: var(--red);
  border: 1px solid rgba(245,71,92,0.2);
}

.pmr-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  color: var(--text);
  text-align: right;
}
.pmr-dim { color: var(--text2); }
.pmr-expand-icon { color: var(--text3); font-size: 10px; transition: transform 0.15s; }
.pmr-expand-icon.open { transform: rotate(90deg); }

/* ── Sleeve sub-rows ──────────────────────────────────────────────────────── */
.pos-sleeve-rows {
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.pos-sleeve-row {
  display: grid;
  grid-template-columns: 1fr 90px 110px 90px 120px 100px 80px;
  padding: 9px 16px 9px 36px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 12px;
  color: var(--text2);
}
.pos-sleeve-row:last-child { border-bottom: none; }
.psr-label { font-size: 12px; color: var(--text); font-weight: 500; }
.psr-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  text-align: right;
  color: var(--text2);
}

/* ── PnL attribution table ───────────────────────────────────────────────── */
.pnl-bar-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pnl-bar-track {
  flex: 1;
  height: 4px;
  background: var(--bg4);
  border-radius: 2px;
  overflow: hidden;
}
.pnl-bar-fill {
  height: 100%;
  border-radius: 2px;
  background: var(--green);
  transition: width 0.4s;
}
.pnl-bar-fill.neg { background: var(--pnl-red); opacity: 0.72; }

/* ── Divider ─────────────────────────────────────────────────────────────── */
.divider { height: 1px; background: var(--border); margin: 16px 0; }

/* ── Scrollbar ───────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px; }

/* ── Login overlay ───────────────────────────────────────────────────────── */
#login-overlay {
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
}
#login-overlay.hidden { display: none; }
.login-box {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: var(--radius2);
  padding: 36px;
  width: 340px;
  max-width: 94vw;
  box-shadow: 0 32px 80px rgba(0,0,0,0.6);
}
.login-logo {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 500;
  color: var(--green);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.login-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}
.login-sub {
  font-size: 12px;
  color: var(--text2);
  margin-bottom: 28px;
}
.login-field {
  margin-bottom: 16px;
}
.login-field label {
  display: block;
  font-size: 11px;
  color: var(--text2);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  margin-bottom: 5px;
}
.login-field input {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  color: var(--text);
  font-size: 13px;
  padding: 8px 10px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s;
}
.login-field input:focus { border-color: var(--green); }
#login-error {
  font-size: 12px;
  color: var(--red);
  min-height: 18px;
  margin-bottom: 10px;
}
