/* ═══════════════════════════════════════════════════════
   ORBITUM — journal.css
   Premium redesign per design audit
   8 stages: color semantics, typography, stat cards,
   CTA, glow reduction, spacing system, animations, polish
   ═══════════════════════════════════════════════════════ */

/* ── STAGE 1: Color Semantics + CSS Variables ── */
:root {
  /* BRAND — ТОЛЬКО лого и 1-2 основных CTA */
  --brand:     #ff7a8a;
  --brand-strong: #ff8fa3;
  --brand-soft: rgba(255,122,138,0.11);
  --brand-border: rgba(255,122,138,0.22);
  --brand-glow: rgba(255,122,138,0.16);
  --brand-dim: var(--brand-soft);
  --brand-bd:  var(--brand-border);

  /* ACCENT — brand only (алиасы для совместимости) */
  --a:  var(--brand);
  --a2: var(--brand-soft);
  --a3: var(--brand-border);

  /* UI STATES — нейтральные, белые, НЕ красные */
  --state-active:        rgba(255,255,255,0.08);
  --state-active-text:   rgba(255,255,255,0.9);
  --state-active-border: rgba(255,255,255,0.15);

  /* DATA COLORS — семантически фиксированные */
  --profit:  #34D399;
  --loss:    #F87171;
  --warning: #FBBF24;
  --info:    #3b82f6;

  /* TYPOGRAPHY SCALE */
  --t-hero:  32px;
  --t-value: 24px;
  --t-body:  15px;
  --t-label: 11px;
  --t-meta:  11px;

  /* SEMANTIC COLORS — fixed */
  --g:  #34D399;   /* green = profit / win / positive */
  --gd: rgba(52,211,153,0.08);
  --r:  #F87171;   /* red = loss / negative */
  --rd: rgba(248,113,113,0.08);
  --y:  #FBBF24;   /* amber = warning */
  --yd: rgba(251,191,36,0.08);

  /* BACKGROUNDS */
  --bg:       #0c0c0e;
  --bg2:      rgba(255,255,255,0.03);
  --bg3:      rgba(255,255,255,0.05);
  --bg-card:  #111114;
  --bg-card2: #161619;
  --bg-input: rgba(255,255,255,0.045);

  /* BORDERS */
  --bd:  rgba(255,255,255,0.07);
  --bd2: rgba(255,255,255,0.12);
  --bd3: rgba(255,255,255,0.2);
  --line: 1px solid var(--bd);

  /* TEXT */
  --t:  rgba(255,255,255,0.9);
  --t2: #ffffff;
  --m:  rgba(255,255,255,0.45);
  --m2: rgba(255,255,255,0.28);

  /* SHADOWS */
  --shadow-card: 0 10px 28px rgba(0,0,0,0.28);

  /* TOPBAR / SIDEBAR */
  --topbar-bg:  rgba(12,12,14,0.96);
  --sidebar-bg: rgba(12,12,14,0.98);

  /* LAYOUT */
  --sb: 220px;

  /* RADIUS */
  --radius:    12px;
  --radius-lg: 14px;

  /* ── STAGE 6: 8px Spacing Tokens ── */
  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;

  /* ── STAGE 2: Typography Scale (6 sizes only) ── */
  --fs-xs:   11px;
  --fs-sm:   12px;
  --fs-base: 13px;
  --fs-md:   15px;
  --fs-lg:   20px;
  --fs-xl:   28px;

  /* FONTS */
  --font-body:    'SF Pro Text', 'SF Pro Display', -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif;
  --font-mono:    'SF Pro Text', 'SF Pro Display', -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif;
  --font-display: 'SF Pro Display', 'SF Pro Text', -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif;
  --apple-nav-h: 48px;

  /* ORB COLORS */
  --orb1: rgba(255,143,163,0.018);
  --orb2: rgba(255,143,163,0.012);
  --orb3: rgba(255,143,163,0.009);
}

/* ── BASE RESET ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  width: 100%;
  max-width: none;
  background: var(--bg);
  color: var(--t);
  font-family: var(--font-body);
  font-size: var(--t-body);   /* 14px — audit Fix 5 */
  line-height: 1.6;
  height: 100%;
  overflow-x: hidden;
}

/* SELECTIVE TEXT SELECT */
.fng-num, .pnl-neg, .pnl-pos, .sbw-lp-price, .sbw-metric-val,
.stat-cell, .stat-value, .tr-pair, .tr-pnl-neg, .tr-pnl-pos,
.trade-row, input, select, textarea {
  -webkit-user-select: text;
  user-select: text;
}
.jnl-topbar, .mob-bar, .mob-bottom-nav, .mob-nav-btn,
.sb-item, .sidebar, .tnav {
  -webkit-user-select: none;
  user-select: none;
}

/* ── STAGE 7: Background Orbs — slow, almost invisible ── */
.bg-orbs-wrap {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.bg-o { position: absolute; border-radius: 50%; pointer-events: none; }
.bg-o-1 {
  width: 800px; height: 800px;
  top: -300px; left: 30%;
  transform: translateX(-50%);
  background: radial-gradient(circle, var(--orb1), transparent 65%);
  filter: blur(80px);
  animation: orbDrift1 30s ease-in-out infinite alternate;
  opacity: 0.5;
}
.bg-o-2 {
  width: 600px; height: 600px;
  bottom: -200px; right: -100px;
  background: radial-gradient(circle, var(--orb2), transparent 65%);
  filter: blur(100px);
  animation: orbDrift2 36s ease-in-out infinite alternate;
  opacity: 0.5;
}
.bg-o-3 {
  width: 500px; height: 500px;
  top: 40%; left: -150px;
  background: radial-gradient(circle, var(--orb3), transparent 65%);
  filter: blur(120px);
  animation: orbDrift3 42s ease-in-out infinite alternate;
  opacity: 0.5;
}
@keyframes orbDrift1 {
  from { transform: translateX(-50%) translateY(0) scale(1); }
  to   { transform: translateX(-50%) translateY(-50px) scale(1.06); }
}
@keyframes orbDrift2 {
  from { transform: translate(0, 0); }
  to   { transform: translate(-30px, -40px); }
}
@keyframes orbDrift3 {
  from { transform: translate(0, 0); }
  to   { transform: translate(25px, -35px); }
}



/* ══════════════════════════════════════════════════
   APPLE-STYLE DESKTOP NAV
   ══════════════════════════════════════════════════ */
.apple-navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--apple-nav-h);
  z-index: 260;
  background: rgba(10,10,12,0.82);
  backdrop-filter: saturate(180%) blur(22px);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  display: none;
}
.apple-nav-inner {
  max-width: 1440px;
  height: 100%;
  margin: 0 auto;
  padding: 0 22px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
}
.apple-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: rgba(255,255,255,0.94);
}
.apple-brand-mark {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--brand);
  box-shadow: 0 0 16px rgba(255,143,163,0.14);
}
.apple-brand-text {
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.apple-nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-width: 0;
}
.apple-menu { position: relative; }
.apple-nav-link,
.apple-menu-item,
.apple-tool-btn {
  font-family: var(--font-body);
}
.apple-nav-link {
  height: 32px;
  padding: 0 12px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: rgba(255,255,255,0.78);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: -0.01em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  transition: background .18s ease, color .18s ease;
}
.apple-nav-link:hover,
.apple-menu.open .apple-nav-link,
.apple-nav-link.active {
  background: rgba(255,255,255,0.06);
  color: #fff;
}
.apple-nav-caret {
  font-size: var(--fs-xs);
  opacity: .65;
  transform: translateY(-1px);
}
.apple-menu-panel {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  width: min(720px, calc(100vw - 40px));
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(18,18,22,0.96);
  box-shadow: 0 28px 80px rgba(0,0,0,0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
.apple-menu.open .apple-menu-panel {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.apple-menu-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.2fr) minmax(200px, .8fr);
  gap: 24px;
}
.apple-menu-column-main {
  padding-right: 8px;
  border-right: 1px solid rgba(255,255,255,0.06);
}
.apple-menu-eyebrow {
  font-size: var(--fs-xs);
  font-weight: 500;
  color: rgba(255,255,255,0.42);
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.apple-menu-item {
  width: 100%;
  display: block;
  text-align: left;
  text-decoration: none;
  padding: 10px 0;
  background: transparent;
  border: 0;
  color: rgba(255,255,255,0.94);
  font-size: 28px;
  line-height: 1.08;
  font-weight: 600;
  letter-spacing: -0.03em;
  cursor: pointer;
  transition: color .18s ease, opacity .18s ease;
}
.apple-menu-item:hover,
.apple-menu-item.active { color: var(--brand); }
.apple-menu-copy {
  color: rgba(255,255,255,0.58);
  font-size: var(--fs-sm);
  line-height: 1.55;
  max-width: 280px;
}
.apple-nav-tools {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}
.apple-current-page {
  min-width: 82px;
  text-align: right;
  color: rgba(255,255,255,0.46);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: -0.01em;
}
.apple-tool-btn {
  height: 30px;
  min-width: 30px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.84);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: var(--fs-xs);
  font-weight: 500;
  transition: background .18s ease, border-color .18s ease, color .18s ease;
}
.apple-tool-btn:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.14);
  color: #fff;
}
.apple-tool-btn-icon svg { display: block; }

body.journal-apple-shell .main {
  position: relative;
  z-index: 1;
  margin-left: 0;
  width: 100%;
  max-width: 1500px;
  padding: calc(var(--apple-nav-h) + 26px) 28px 48px;
  margin-right: auto;
  margin-left: auto;
}
body.journal-apple-shell .stats-row {
  align-items: stretch;
  margin-bottom: 18px;
}
body.journal-apple-shell .stat-cell,
body.journal-apple-shell .dash-card,
body.journal-apple-shell .fcard,
body.journal-apple-shell .tcard,
body.journal-apple-shell .coach-card,
body.journal-apple-shell .settings-card,
body.journal-apple-shell .pm-section-card,
body.journal-apple-shell .mc-card,
body.journal-apple-shell .hm-card {
  border-radius: 20px;
  border-color: rgba(255,255,255,0.08);
  box-shadow: none;
}
body.journal-apple-shell .stat-value {
  font-size: var(--fs-xl);
  line-height: 1;
  letter-spacing: -0.03em;
  font-weight: 600;
}
body.journal-apple-shell .stat-label,
body.journal-apple-shell label,
body.journal-apple-shell .sbw-metric-label,
body.journal-apple-shell .lb-sub {
  letter-spacing: -0.01em;
  text-transform: none;
}
body.journal-apple-shell .btn-add,
body.journal-apple-shell .balance-popup-save,
body.journal-apple-shell .plo-btn {
  border-radius: 999px;
}
body.journal-apple-shell .jnl-topbar { display: none; }

/* ══════════════════════════════════════════════════
   SIDEBAR
   ══════════════════════════════════════════════════ */
 .sidebar {
  box-shadow: inset -1px 0 0 rgba(255,255,255,0.02);
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: 260px;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--bd);
  display: none;
  flex-direction: column;
  z-index: 300;
  overflow: hidden;
}

.sb-logo {
  height: 52px;
  display: flex;
  align-items: center;
  padding: 0 var(--sp-4);
  border-bottom: var(--line);
  flex-shrink: 0;
  gap: var(--sp-2);
  text-decoration: none;
  cursor: pointer;
}
.sb-logo-text {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--a);
  text-transform: uppercase;
  transition: opacity 0.2s;
}
.sb-logo:hover .sb-logo-text { opacity: 0.75; }

.sb-logo-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--a);
  flex-shrink: 0;
}

.sb-scroll-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}
.sb-scroll-body::-webkit-scrollbar { width: 3px; }
.sb-scroll-body::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.1);
  border-radius: 3px;
}

.sb-nav {
  padding: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex-shrink: 0;
}

.sb-section {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--m2);
  padding: var(--sp-4) var(--sp-2) var(--sp-1);
}

.sb-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bd), transparent);
  margin: var(--sp-1) 0;
}

.sb-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  text-decoration: none;
  cursor: pointer;
  color: var(--m);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  width: 100%;
  text-align: left;
  padding: var(--sp-2) var(--sp-2);
  transition: background 0.12s, color 0.12s;
}
.sb-item:hover {
  background: rgba(255,255,255,0.05);
  color: var(--t);
}
.sb-item.active {
  background: var(--state-active);
  color: var(--state-active-text);
  border: 1px solid var(--state-active-border);
  border-left: 2px solid rgba(255,255,255,0.4);
  box-shadow: none;
}

.sb-item-icon {
  font-size: var(--fs-sm);
  width: 16px;
  text-align: center;
  flex-shrink: 0;
}
.sb-item.active .sb-item-icon {
  color: var(--state-active-text);
}

.sb-footer {
  padding: var(--sp-2);
  border-top: var(--line);
  flex-shrink: 0;
}
.sb-user {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-2);
  background: var(--bg2);
  border-radius: 8px;
  margin-bottom: var(--sp-1);
}
.sb-avatar {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--bd2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-sm);
  color: var(--m);
  flex-shrink: 0;
}
.sb-user-info { flex: 1; overflow: hidden; }
.sb-user-name {
  font-size: var(--fs-sm);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sb-user-plan {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--m2);
  margin-top: 1px;
  letter-spacing: 1px;
}
.sb-logout {
  width: 100%;
  padding: var(--sp-1) var(--sp-2);
  background: transparent;
  border: var(--line);
  border-radius: 6px;
  color: var(--m);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  cursor: pointer;
  transition: 0.2s;
  letter-spacing: 1px;
}
.sb-logout:hover { border-color: var(--r); color: var(--r); }

/* MARKET DATA DRAWER — collapsible */
.sb-market-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-2) var(--sp-3);
  margin: var(--sp-1) var(--sp-2) 0;
  border-radius: 7px;
  border: 1px solid var(--bd);
  background: transparent;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.sb-market-toggle:hover {
  background: rgba(255,255,255,0.04);
  border-color: var(--bd2);
}
.sb-market-toggle-label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--m2);
}
.sb-market-toggle-arrow {
  font-size: var(--fs-xs);
  color: var(--m2);
  transition: transform 0.2s;
}
.sb-market-toggle.open .sb-market-toggle-arrow {
  transform: rotate(90deg);
}
.sb-market-collapsed {
  display: none;
}
.sb-market-collapsed.open {
  display: block;
  border-top: 1px solid var(--bd);
  padding: var(--sp-1) var(--sp-2) 0;
}
.sb-section-label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  color: var(--m2);
  text-transform: uppercase;
  margin-bottom: var(--sp-1);
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}
.sb-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--bd);
}
.sbw {
  border-radius: 6px;
  padding: var(--sp-2) var(--sp-3);
  margin-bottom: var(--sp-1);
  background: rgba(255,255,255,0.015);
  border: 1px solid var(--bd);
  transition: border-color 0.2s;
}
.sbw:hover { border-color: var(--bd2); }
.sbw-title {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  color: var(--m2);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-1);
  padding-bottom: var(--sp-1);
  border-bottom: 1px solid var(--bd);
}
.sbw-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--a);
}
.sbw-dot-live { animation: 1.5s dotLive infinite; }
@keyframes dotLive {
  0%,100% { opacity: 1; }
  50%     { opacity: 0.25; }
}
.sbw-fng { display: flex; align-items: center; gap: var(--sp-2); padding: 2px 0; }
.fng-arc { width: 40px; height: 24px; flex-shrink: 0; }
.fng-arc svg { height: 24px; }
.fng-num {
  font-family: var(--font-mono);
  font-size: 20px;
  line-height: 1;
  transition: color 0.4s;
}
.fng-label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--m);
  letter-spacing: 0.3px;
  margin-top: 1px;
}
.sbw-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-1); }
.sbw-metric {
  background: rgba(255,255,255,0.03);
  border-radius: 4px;
  padding: 3px 5px;
}
.sbw-metric-label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1.5px;
  color: var(--m2);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.sbw-metric-val {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--t);
}
.sbw-metric-val.up { color: var(--g); }
.sbw-metric-val.dn { color: var(--r); }
.sbw-metric-val.accent { color: var(--a); }
.mkt-btc-dom {
  height: 2px;
  background: rgba(255,255,255,0.05);
  border-radius: 1px;
  margin-top: 4px;
  overflow: hidden;
  grid-column: 1/-1;
}
.mkt-btc-fill {
  height: 100%;
  background: linear-gradient(90deg, #f7931a, rgba(247,147,26,0.4));
  border-radius: 1px;
  transition: width 0.8s;
}

/* LIVE PRICES */
.sbw-live-prices { display: flex; flex-direction: column; gap: 2px; }
.sbw-lp-row {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 3px var(--sp-2);
  border-radius: 4px;
  transition: background 0.1s;
}
.sbw-lp-row:hover { background: rgba(255,255,255,0.03); }
.sbw-lp-sym { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 0.5px; width: 32px; }
.sbw-lp-price { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 600; color: var(--t); flex: 1; }
.sbw-lp-chg { font-family: var(--font-mono); font-size: var(--fs-xs); text-align: right; flex-shrink: 0; width: 46px; }
.sbw-lp-chg.up { color: var(--g); }
.sbw-lp-chg.dn { color: var(--r); }
@keyframes lpFlash {
  0%   { background: rgba(255,255,255,0.1); }
  100% { background: transparent; }
}
.sbw-lp-flash { animation: 0.25s lpFlash; }

/* TRENDS & MOVERS */
.sbw-trend { display: flex; flex-direction: column; gap: 2px; }
.trend-item { display: flex; align-items: center; gap: var(--sp-1); padding: 2px var(--sp-1); border-radius: 4px; transition: background 0.15s; }
.trend-item:hover { background: rgba(255,255,255,0.04); }
.trend-rank { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m2); width: 8px; flex-shrink: 0; }
.trend-thumb { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; background: rgba(255,255,255,0.06); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.trend-sym { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--t); font-weight: 500; flex: 1; }
.trend-pos { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m2); }
.gl-tabs { display: flex; gap: 3px; margin-bottom: var(--sp-1); }
.gl-tab {
  flex: 1;
  border-radius: 4px;
  border: 1px solid var(--bd);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  cursor: pointer;
  background: transparent;
  color: var(--m);
  padding: 2px var(--sp-2);
  height: 20px;
  transition: 0.15s;
}
.gl-tab.active.gain { background: rgba(52,211,153,0.1); color: var(--g); border-color: rgba(52,211,153,0.2); }
.gl-tab.active.lose { background: rgba(248,113,113,0.1); color: var(--r); border-color: rgba(248,113,113,0.2); }
.sbw-gl { display: flex; flex-direction: column; gap: 2px; }
.gl-item { display: flex; align-items: center; gap: var(--sp-1); padding: 2px var(--sp-1); border-radius: 4px; transition: background 0.15s; }
.gl-item:hover { background: rgba(255,255,255,0.04); }
.gl-sym { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--t); flex: 1; font-weight: 500; letter-spacing: 0.5px; }
.gl-pct { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 600; }
.gl-pct.up { color: var(--g); }
.gl-pct.dn { color: var(--r); }

/* SPECIAL SB BUTTONS */
.sb-fvg  { border-color: rgba(52,211,153,0.2) !important; color: rgba(52,211,153,0.7) !important; }
.sb-fvg.active, .sb-fvg:hover { background: rgba(52,211,153,0.1) !important; border-color: rgba(52,211,153,0.4) !important; color: var(--g) !important; }
.sb-ob   { border-color: rgba(255,143,163,0.18) !important; color: rgba(255,122,138,0.7) !important; }
.sb-ob.active, .sb-ob:hover { background: var(--a2) !important; border-color: var(--a3) !important; color: var(--a) !important; }
.sb-liq  { border-color: rgba(155,89,182,0.25) !important; color: rgba(155,89,182,0.7) !important; }
.sb-liq.active, .sb-liq:hover { background: rgba(155,89,182,0.1) !important; border-color: rgba(155,89,182,0.4) !important; color: #9b59b6 !important; }
.sb-sr   { border-color: rgba(52,152,219,0.25) !important; color: rgba(52,152,219,0.7) !important; }
.sb-sr.active, .sb-sr:hover { background: rgba(52,152,219,0.1) !important; border-color: rgba(52,152,219,0.4) !important; color: #3498db !important; }
.sb-bo   { border-color: rgba(251,191,36,0.25) !important; color: rgba(251,191,36,0.7) !important; }
.sb-bo.active, .sb-bo:hover { background: rgba(251,191,36,0.1) !important; border-color: rgba(251,191,36,0.4) !important; color: var(--y) !important; }
.sb-wy   { border-color: rgba(231,76,60,0.25) !important; color: rgba(231,76,60,0.7) !important; }
.sb-wy.active, .sb-wy:hover { background: rgba(231,76,60,0.1) !important; border-color: rgba(231,76,60,0.4) !important; color: #e74c3c !important; }
.sb-other { border-color: rgba(255,255,255,0.1) !important; color: var(--m) !important; }
.sb-other.active, .sb-other:hover { background: var(--bg3) !important; color: var(--t) !important; }
.sb-badge {
  background: var(--a);
  color: #fff;
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  padding: 1px 6px;
  border-radius: 10px;
}

/* ══════════════════════════════════════════════════
   TOPBAR (desktop)
   ══════════════════════════════════════════════════ */
.jnl-topbar {
  display: none;
  position: sticky;
  top: 0;
  z-index: 150;
  background: var(--topbar-bg);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--bd);
  height: 48px;
  align-items: center;
  padding: 0 var(--sp-5);
  gap: var(--sp-2);
  margin-left: 0;
}
.jtb-logo {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--a);
  text-decoration: none;
  flex-shrink: 0;
  cursor: pointer;
  transition: opacity 0.2s;
}
.jtb-logo:hover { opacity: 0.7; }
/* Stage 5: jtb-dot glow kept — it's a single accent point */
.jtb-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--a);
}
.jtb-badge {
  background: var(--a2);
  border: 1px solid var(--a3);
  border-radius: 5px;
  padding: 3px var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--a);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  white-space: nowrap;
}
.jtb-sep { width: 1px; height: 18px; background: var(--bd); flex-shrink: 0; }
.jtb-sep-v { width: 1px; height: 18px; background: var(--bd); flex-shrink: 0; margin: 0 var(--sp-1); }
.jtb-navs {
  display: flex;
  gap: 2px;
  flex: 1;
  overflow-x: auto;
  scrollbar-width: none;
}
.jtb-navs::-webkit-scrollbar { display: none; }
.jtb-nav {
  padding: var(--sp-1) var(--sp-3);
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--m);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.35px;
  text-transform: none;
  cursor: pointer;
  transition: 0.15s;
  white-space: nowrap;
}
.jtb-nav:hover { color: var(--t); background: rgba(255,255,255,0.04); }
/* Active topbar nav — neutral white, not brand red */
.jtb-nav.active { background: var(--state-active); border: 1px solid var(--state-active-border); color: var(--state-active-text); }
.jtb-right { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
/* Stage 4: profile button — clean, no glow */
.jtb-profile-btn {
  width: 30px; height: 30px;
  border-radius: 50%;
  border: 1.5px solid var(--bd2);
  background: var(--bg2);
  color: var(--m);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: 0.2s;
  flex-shrink: 0;
  text-decoration: none;
}
.jtb-profile-btn:hover { border-color: var(--bd3); color: var(--t); background: var(--bg3); }

/* BALANCE WIDGET */
.jtb-balance {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 3px var(--sp-2);
  background: var(--bg2);
  border: 1px solid var(--bd);
  border-radius: 8px;
  cursor: pointer;
  transition: 0.15s;
}
.jtb-balance:hover { background: var(--bg3); border-color: var(--bd2); }
.jtb-balance-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; color: var(--m2); text-transform: uppercase; line-height: 1; }
.jtb-balance-val { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 600; line-height: 1.2; color: var(--g); }
.jtb-balance-delta { font-family: var(--font-mono); font-size: var(--fs-xs); line-height: 1; }

/* GOAL WIDGET */
.jtb-goal {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 3px var(--sp-2);
  background: var(--bg2);
  border: 1px solid var(--bd);
  border-radius: 8px;
  cursor: pointer;
  transition: 0.15s;
  position: relative;
  min-width: 100px;
}
.jtb-goal:hover { background: var(--bg3); border-color: var(--bd2); }
.jtb-goal.achieved { background: var(--a2); border-color: var(--a3); }
.jtb-goal-icon { font-size: var(--fs-xs); line-height: 1; flex-shrink: 0; }
.jtb-goal-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; color: var(--m2); text-transform: uppercase; line-height: 1; }
.jtb-goal-val { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--t); line-height: 1.2; font-weight: 500; }
.jtb-goal-progress { position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: rgba(255,255,255,0.05); border-radius: 0 0 8px 8px; overflow: hidden; }
.jtb-goal-fill { height: 100%; border-radius: 0 0 8px 8px; background: var(--a); transition: width 0.5s; }

/* ACTION BUTTONS */
.jtb-action-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  border-radius: 7px;
  padding: var(--sp-1) var(--sp-2);
  border: none;
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  transition: 0.15s;
}
.jtb-action-btn.profile {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--bd);
  color: var(--m);
}
.jtb-action-btn.profile:hover { background: var(--bg3); color: var(--t); border-color: var(--bd2); }
.jtb-action-btn.note {
  background: var(--a2);
  border: 1px solid var(--a3);
  color: var(--a);
}
.jtb-action-btn.note:hover { background: rgba(255,122,138,0.14); }

/* DROPDOWNS */
.jtb-dropdown { position: relative; display: inline-flex; }
.jtb-dd-trigger { display: flex; align-items: center; gap: 4px; }
.dd-arrow { font-size: var(--fs-xs); transition: transform 0.18s; }
.jtb-dropdown.open .dd-arrow { transform: rotate(180deg); }
.jtb-dd-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  background: var(--bg-card);
  border: 1px solid var(--bd2);
  border-radius: var(--radius);
  padding: var(--sp-1);
  min-width: 170px;
  z-index: 900;
  box-shadow: 0 16px 40px rgba(0,0,0,0.6);
  animation: 0.15s ddIn both;
}
@keyframes ddIn {
  from { opacity: 0; transform: translateY(-5px); }
  to   { opacity: 1; transform: none; }
}
.jtb-dropdown.open .jtb-dd-menu { display: block; }
.jtb-dd-item {
  display: block;
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--m);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.35px;
  text-transform: none;
  cursor: pointer;
  transition: 0.12s;
  text-align: left;
  white-space: nowrap;
}
.jtb-dd-item:hover { color: var(--t); background: rgba(255,255,255,0.05); }
.jtb-dd-item.active { color: var(--state-active-text); background: var(--state-active); }
.jtb-dd-sep { height: 1px; background: var(--bd); margin: var(--sp-1) 0; }

/* ══════════════════════════════════════════════════
   MOBILE BAR
   ══════════════════════════════════════════════════ */
.mob-bar {
  display: flex;
  position: sticky;
  top: 0;
  z-index: 90;
  background: var(--topbar-bg);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--bd);
  height: 48px;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--sp-3);
  gap: var(--sp-2);
}
.mob-logo {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--a);
  text-decoration: none;
  flex-shrink: 0;
}
.mob-bar-right { display: flex; align-items: center; gap: var(--sp-1); flex-shrink: 0; }
.mob-stat-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3px var(--sp-2);
  border-radius: 6px;
  cursor: pointer;
  min-width: 56px;
  transition: 0.2s;
}
.mob-stat-pill.balance { background: var(--bg2); border: 1px solid var(--bd); }
.mob-stat-pill.balance:active { background: var(--bg3); }
.mob-stat-pill.goal-pill { background: rgba(255,255,255,0.05); border: 1px solid var(--bd2); }
.mob-pill-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; color: var(--m2); text-transform: uppercase; line-height: 1; margin-bottom: 2px; }
.mob-pill-val { font-family: var(--font-mono); font-size: var(--fs-sm); font-weight: 500; line-height: 1; }
.mob-profile-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 8px;
  text-decoration: none;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--bd2);
  color: var(--m);
  font-size: var(--fs-base);
  flex-shrink: 0;
  transition: 0.15s;
}
.mob-profile-btn:hover { background: var(--bg3); color: var(--t); border-color: var(--bd3); }

/* MOBILE BOTTOM NAV */
.mob-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 400;
  background: var(--sidebar-bg);
  border-top: 1px solid var(--bd);
  backdrop-filter: blur(20px);
  padding: var(--sp-2) var(--sp-3) var(--sp-3);
  overflow-x: auto;
  scrollbar-width: none;
}
.mob-bottom-nav::-webkit-scrollbar { display: none; }
.mob-nav-inner { display: flex; gap: 6px; align-items: center; width: max-content; padding: 0 4px; }
.mob-nav-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 7px var(--sp-3);
  border-radius: 10px;
  border: 1px solid transparent;
  background: rgba(255,255,255,0.03);
  color: var(--m);
  cursor: pointer;
  transition: 0.18s;
  white-space: nowrap;
  flex-shrink: 0;
}
.mob-nav-btn.active { color: var(--state-active-text); background: var(--state-active); border-color: var(--state-active-border); }
.mob-nav-icon { font-size: var(--fs-base); line-height: 1; }
.mob-nav-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.5px; text-transform: uppercase; }

/* OVERLAY */
.sb-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 99; }
.sb-overlay.open { display: block; }

/* ══════════════════════════════════════════════════
   TICKER BAR
   ══════════════════════════════════════════════════ */
.ticker-bar {
  position: fixed;
  top: 0;
  left: var(--sb);
  right: 0;
  z-index: 200;
  height: 26px;
  overflow: hidden;
  background: var(--topbar-bg);
  border-bottom: 1px solid var(--bd);
  display: none;
}
.ticker-bar::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0; width: 60px; z-index: 2;
  background: linear-gradient(90deg, var(--bg-card), transparent);
  pointer-events: none;
}
.ticker-bar::after {
  content: '';
  position: absolute; right: 0; top: 0; bottom: 0; width: 60px; z-index: 2;
  background: linear-gradient(270deg, var(--bg-card), transparent);
  pointer-events: none;
}
.ticker-track {
  display: flex;
  align-items: center;
  height: 100%;
  animation: 110s linear infinite tickerScroll;
  width: max-content;
}
@keyframes tickerScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.ticker-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 var(--sp-4);
  height: 100%;
  cursor: default;
  white-space: nowrap;
  position: relative;
  transition: background 0.15s;
}
.ticker-item:hover { background: var(--bg2); }
.ticker-sym { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 600; letter-spacing: 1px; color: var(--a); }
.ticker-price { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 500; color: var(--t); min-width: 64px; }
.ticker-chg { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 500; padding: 1px 5px; border-radius: 3px; min-width: 46px; text-align: center; }
.ticker-chg.up { color: var(--g); background: var(--gd); }
.ticker-chg.dn { color: var(--r); background: var(--rd); }
.ticker-chg.flat { color: var(--m); background: var(--bg2); }
.ticker-divider { display: inline-flex; align-items: center; gap: 6px; padding: 0 var(--sp-3); height: 100%; flex-shrink: 0; border-left: 1px solid var(--bd); border-right: 1px solid var(--bd); }
.ticker-divider-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; font-weight: 600; color: rgba(255,143,163,0.52); text-transform: uppercase; }
@keyframes priceFlashUp { 0%,100% { color: var(--t); } 50% { color: var(--g); } }
@keyframes priceFlashDn { 0%,100% { color: var(--t); } 50% { color: var(--r); } }
.ticker-price.flash-up { animation: 0.6s priceFlashUp; }
.ticker-price.flash-dn { animation: 0.6s priceFlashDn; }

/* ══════════════════════════════════════════════════
   MAIN LAYOUT
   ══════════════════════════════════════════════════ */
.main {
  margin-left: 0;
  padding: var(--sp-6) var(--sp-5) 100px;
  min-height: 100vh;
  position: relative;
  z-index: 1;
}
.page { display: none; }
.page.active { display: block; animation: 0.25s pgIn both; }
@keyframes pgIn {
  from { opacity: 0; transform: translateY(5px); }
  to   { opacity: 1; transform: none; }
}

/* ── STAGE 3: STAT CARDS ── */
.stats-row {
  align-items: stretch;
  display: grid;
  grid-template-columns: 1fr 1fr 2fr;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  margin-top: var(--sp-5);
}
/* Stage 3: more padding, bigger numbers, no text-shadow */
.stat-cell {
  box-shadow: var(--shadow-card);
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius-lg);
  padding: var(--sp-5) var(--sp-5);
  cursor: default;
  position: relative;
  overflow: hidden;
  /* Stage 7: only interaction transitions */
  transition: background 0.15s, border-color 0.15s;
}
/* Stage 3: subtle hover, no glow */
.stat-cell:hover {
  background: var(--bg-card2);
  border-color: var(--bd2);
}
/* Stage 2: typography — clean labels with proper hierarchy */
.stat-label {
  font-family: var(--font-mono);
  font-size: var(--t-label);      /* 12px — audit label level */
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--m);
  margin-bottom: var(--sp-2);
  display: flex;
  align-items: center;
  gap: 5px;
}
/* Stage 2+3: stat values with audit-prescribed hierarchy */
.stat-value {
  font-family: var(--font-mono);
  font-size: var(--t-value);   /* 22px audit: value level */
  font-weight: 600;
  letter-spacing: -0.5px;
  color: var(--t);
  text-shadow: none;
  line-height: 1;
}
/* P&L card — hero size since it gets 2fr */
.stat-cell:nth-child(3) .stat-value {
  font-size: var(--t-hero);   /* 32px audit: hero level */
  font-weight: 700;
}
.stat-cell:nth-child(3) .stat-label {
  font-size: var(--t-label);  /* 12px */
  margin-bottom: var(--sp-3);
}
/* Stage 1: correct color semantics */
.sv-g { color: var(--g) !important; text-shadow: none !important; }
.sv-r { color: var(--r) !important; text-shadow: none !important; }
.sv-a { color: var(--a) !important; text-shadow: none !important; }
/* Stage 5: no animation on stat values */

/* HOVER INSIGHT */
.hover-insight {
  display: none;
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(10,12,15,0.98);
  border: 1px solid var(--bd2);
  border-radius: 8px;
  padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--t);
  white-space: nowrap;
  z-index: 50;
  line-height: 1.6;
  box-shadow: 0 4px 20px rgba(0,0,0,0.6);
  pointer-events: none;
}
.stat-cell:hover .hover-insight { display: block; }
.stat-cell.glow-g { box-shadow: 0 6px 14px rgba(52,211,153,0.04); }
.stat-cell.glow-r { box-shadow: 0 8px 22px rgba(248,113,113,0.07); }
.stat-cell.glow-a { box-shadow: 0 8px 20px rgba(0,0,0,0.2); }

/* ══════════════════════════════════════════════════
   LEVEL BAR
   ══════════════════════════════════════════════════ */
.level-bar {
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-3);
}
.lb-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.lb-left { display: flex; align-items: center; gap: var(--sp-3); }
.lb-icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-md);
  flex-shrink: 0;
  border: 1px solid var(--bd);
}
/* Stage 2+5: no text-shadow on lb-name */
.lb-name {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  letter-spacing: 1px;
  line-height: 1;
}
.lb-sub { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--m); margin-top: 2px; }
.lb-right { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.streak-pill {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  background: var(--a2);
  border: 1px solid var(--a3);
  border-radius: 6px;
  padding: var(--sp-1) var(--sp-2);
}
/* Stage 5: no text-shadow on streak number */
.streak-num { font-family: var(--font-mono); font-size: 20px; font-weight: 600; color: var(--a); line-height: 1; }
.streak-lbl { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; }
.lb-track { overflow: hidden; margin-bottom: 4px; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.05); }
.lb-fill { height: 100%; transition: width 1s cubic-bezier(0.16,1,0.3,1); border-radius: 2px; }
.lb-labels { display: flex; justify-content: space-between; margin-bottom: var(--sp-2); }
.lb-lbl { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); }
.lb-reward { display: flex; align-items: center; gap: 6px; background: var(--a2); border: 1px solid var(--a3); border-radius: 5px; padding: 6px var(--sp-2); }
.lb-reward-text { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--a); letter-spacing: 0.5px; line-height: 1.4; }
.lb-card { background: var(--bg-card); border: 1px solid var(--bd); border-radius: var(--radius); }

/* ══════════════════════════════════════════════════
   TOP NAV (tabs)
   ══════════════════════════════════════════════════ */
.topnav {
  display: flex;
  align-items: center;
  gap: 3px;
  margin-bottom: var(--sp-4);
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: 9px;
  padding: 3px;
  width: fit-content;
}
.tnav {
  padding: var(--sp-1) var(--sp-3);
  border-radius: 6px;
  border: none;
  color: var(--m);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.35px;
  text-transform: none;
  cursor: pointer;
  transition: 0.15s;
  white-space: nowrap;
  background: transparent;
}
.tnav:hover:not(.active) { color: var(--t); background: rgba(255,255,255,0.04); }
/* Active tab — neutral white, not brand red */
.tnav.active { background: var(--state-active); border: 1px solid var(--state-active-border); color: var(--state-active-text); }

/* ══════════════════════════════════════════════════
   FORM CARD (Add Trade)
   ══════════════════════════════════════════════════ */
.fcard {
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius-lg);
  padding: var(--sp-5) var(--sp-6);
  margin-bottom: var(--sp-3);
  position: relative;
  overflow: hidden;
}
/* Stage 2+5: fcard-title clean — no text-shadow, readable size */
.fcard-title {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: 0;
  color: var(--t);
  margin-bottom: var(--sp-4);
  text-shadow: none;
  text-transform: none;
}

/* FORM GRIDS */
.fg4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.fg3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.fg2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.field { display: flex; flex-direction: column; gap: var(--sp-1); }
.field label {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.35px;
  text-transform: none;
  color: var(--m);
  display: flex;
  align-items: center;
  gap: 6px;
}
.field input, .field select, .field textarea {
  font-family: var(--font-body);
  background: var(--bg-input);
  border: 1px solid var(--bd);
  border-radius: 9px;
  padding: var(--sp-2) var(--sp-3);
  color: var(--t);
  font-family: var(--font-mono);
  font-size: var(--fs-base);
  outline: 0;
  width: 100%;
  transition: 0.15s;
}
.field input::placeholder, .field textarea::placeholder { color: rgba(255,255,255,0.18); }
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--bd3);
  background: rgba(255,255,255,0.04);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.06);
  outline: 0;
}
.field textarea { resize: vertical; min-height: 54px; font-family: var(--font-body); line-height: 1.6; }
/* Key field */
.field-key input {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--t);
  border-color: var(--bd2);
}
.field-key input::placeholder { color: var(--m2); }
/* RR display — no glow */
.rr-display {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 600;
  color: var(--a);
  padding: var(--sp-2) 0;
  letter-spacing: 1px;
  text-shadow: none;
}
/* Field hint */
.field-hint {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--bd);
  color: var(--m);
  font-size: var(--fs-xs);
  cursor: pointer;
  flex-shrink: 0;
  transition: 0.15s;
}
.field-hint:hover { background: var(--a2); border-color: var(--a3); color: var(--a); }

/* DIRECTION TOGGLE */
.dtoggle { display: flex; gap: 2px; }
.dbtn {
  flex: 1;
  padding: var(--sp-2);
  border: var(--line);
  background: var(--bg3);
  color: var(--m);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1.5px;
  cursor: pointer;
  text-align: center;
  border-radius: 8px;
  transition: 0.15s;
}
.dbtn.long.active {
  background: var(--gd);
  border-color: rgba(52,211,153,0.4);
  color: var(--g);
}
.dbtn.short.active {
  background: var(--rd);
  border-color: rgba(248,113,113,0.4);
  color: var(--r);
}

/* RESULT BUTTONS */
.res-btns { display: flex; gap: var(--sp-1); }
.res-btn {
  flex: 1;
  padding: var(--sp-2) var(--sp-1);
  border: var(--line);
  background: var(--bg3);
  color: var(--m);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  text-align: center;
  cursor: pointer;
  border-radius: 8px;
  transition: 0.15s;
}
.res-btn:hover { border-color: var(--bd2); color: var(--t); }
.res-btn.active-win { background: var(--gd); border-color: rgba(52,211,153,0.4); color: var(--g); }
.res-btn.active-loss { background: var(--rd); border-color: rgba(248,113,113,0.4); color: var(--r); }
.res-btn.active-be { background: var(--a2); border-color: var(--a3); color: var(--a); }

/* SETUP BUTTONS */
.setup-btns { display: flex; gap: var(--sp-1); flex-wrap: wrap; margin-bottom: var(--sp-2); }
.setup-btn {
  padding: var(--sp-1) var(--sp-3);
  border: var(--line);
  background: var(--bg3);
  color: var(--m);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  cursor: pointer;
  white-space: nowrap;
  border-radius: 7px;
  transition: 0.15s;
}
.setup-btn:hover { border-color: var(--bd2); color: var(--t); }
.setup-btn.active { background: var(--a2); border-color: var(--a3); color: var(--a); }

/* EMOTION SECTION */
.em-section {
  background: rgba(255,255,255,0.015);
  border: 1px solid var(--bd);
  border-radius: var(--radius);
  margin-bottom: var(--sp-2);
  padding: var(--sp-3);
}
/* Stage 2+5: em-title clean, no text-shadow */
.em-title {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--m);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: var(--sp-2);
  text-shadow: none;
}
.em-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); }
.em-row { display: flex; flex-direction: column; gap: var(--sp-1); }
.em-label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--m);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.em-opts { display: flex; gap: 3px; }
.em-opt {
  flex: 1;
  padding: var(--sp-2) 5px;
  border-radius: 7px;
  border: var(--line);
  background: var(--bg3);
  color: var(--m);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 500;
  cursor: pointer;
  transition: 0.15s;
  text-align: center;
}
.em-opt:hover { border-color: var(--bd2); color: var(--t); }
.em-opt.active { background: var(--a2); border-color: var(--a3); color: var(--a); }

/* ── STAGE 4: CTA BUTTON — clean, flat accent ── */
.btn-add {
  width: 100%;
  padding: 13px;
  background: var(--a);
  border: none;
  border-radius: var(--radius);
  color: #fff;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: 0.3px;
  cursor: pointer;
  margin-top: var(--sp-1);
  /* Stage 4: only opacity + tiny lift on hover, no gradients, no heavy shadows */
  transition: opacity 0.15s, transform 0.1s;
}
.btn-add:hover { opacity: 0.88; transform: translateY(-1px); }
.btn-add:active { transform: none; opacity: 0.96; }
.btn-add:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }
/* Stage 5: focus glow on CTA — kept as accent point */
.btn-add:focus { box-shadow: 0 0 0 3px rgba(255,143,163,0.24); outline: none; }

.btn-ai {
  width: 100%;
  padding: var(--sp-2);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--bd2);
  border-radius: var(--radius);
  color: var(--t);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  letter-spacing: 0.5px;
  cursor: pointer;
  margin-top: 6px;
  transition: 0.15s;
}
.btn-ai:hover { background: rgba(255,255,255,0.05); border-color: var(--a3); color: var(--a); }

/* PAIR PRESETS */
.pair-presets { display: flex; gap: var(--sp-1); margin-top: var(--sp-1); flex-wrap: wrap; }
.pair-presets button {
  padding: 3px var(--sp-2);
  border: 1px solid var(--bd);
  background: var(--bg2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  cursor: pointer;
  border-radius: 6px;
  transition: 0.15s;
  color: var(--m);
}
.pair-presets button:hover { background: var(--bg3); border-color: var(--bd2); }
.pair-presets button.active { border-color: currentColor; background: rgba(255,255,255,0.06); }

/* LEVERAGE SLIDER (replaces 9 buttons) */
.lev-slider-wrap {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-1);
}
.lev-display {
  font-family: var(--font-mono);
  font-size: var(--fs-lg);
  font-weight: 700;
  min-width: 52px;
  color: var(--t);
  line-height: 1;
  flex-shrink: 0;
}
.lev-range {
  flex: 1;
  height: 4px;
  -webkit-appearance: none;
  appearance: none;
  background: var(--bd2);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}
.lev-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--t);
  cursor: pointer;
  border: 2px solid var(--bg-card);
  box-shadow: 0 1px 4px rgba(0,0,0,0.4);
  transition: transform 0.1s;
}
.lev-range::-webkit-slider-thumb:hover { transform: scale(1.2); }
.lev-range::-moz-range-thumb {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--t);
  cursor: pointer;
  border: 2px solid var(--bg-card);
}
.lev-risk-label {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  margin-top: 4px;
  letter-spacing: 0.5px;
}

/* PAIR AUTOCOMPLETE */
.pair-autocomplete-wrap { position: relative; width: 100%; }
.pair-suggestions {
  position: absolute;
  top: calc(100% + 4px);
  left: 0; right: 0;
  background: var(--bg-card);
  border: 1px solid var(--bd2);
  border-radius: var(--radius);
  z-index: 9999;
  overflow: hidden;
  box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
.pair-sug-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--t);
  transition: background 0.1s;
  border-bottom: 1px solid var(--bd);
}
.pair-sug-item:last-child { border-bottom: none; }
.pair-sug-item:hover, .pair-sug-item.highlighted { background: var(--a2); color: var(--a); }
.pair-sug-icon { font-size: var(--fs-base); width: 18px; text-align: center; flex-shrink: 0; }
.pair-sug-name { font-weight: 600; letter-spacing: 0.5px; }
.pair-sug-full { color: var(--m); font-size: var(--fs-xs); }

/* ══════════════════════════════════════════════════
   TRADE LIST
   ══════════════════════════════════════════════════ */
.list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
}
/* Stage 2+5: list-title clean */
.list-title {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: 0;
  color: var(--m);
  text-shadow: none;
}
.filters { display: flex; gap: var(--sp-1); flex-wrap: wrap; }
.fbtn {
  padding: var(--sp-1) var(--sp-2);
  border-radius: 20px;
  border: var(--line);
  background: transparent;
  color: var(--m);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  cursor: pointer;
  transition: 0.15s;
}
.fbtn.active, .fbtn:hover { border-color: var(--bd2); color: var(--t); background: var(--state-active); }

/* TRADE CARDS */
.tcard {
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius);
  padding: var(--sp-4) var(--sp-4);
  margin-bottom: var(--sp-2);
  transition: background 0.15s, border-color 0.15s;
}
.tcard:hover { background: var(--bg-card2); border-color: var(--bd2); }
.tcard.win  { border-left: 2px solid var(--g); }
.tcard.loss { border-left: 2px solid var(--r); }
.tcard.be   { border-left: 2px solid var(--bd2); }
.th { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-2); }
.tl { display: flex; align-items: center; gap: var(--sp-2); }
/* Stage 2+5: tpair — no glow */
.tpair { font-family: var(--font-body); font-size: var(--fs-md); font-weight: 700; letter-spacing: 1px; }
.tdir {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  padding: 2px 7px;
  border-radius: 4px;
  letter-spacing: 1px;
}
.tdir.long { background: var(--gd); color: var(--g); }
.tdir.short { background: var(--rd); color: var(--r); }
.tr { display: flex; align-items: center; gap: var(--sp-2); }
.tpnl { font-family: var(--font-mono); font-size: var(--fs-base); font-weight: 500; }
.tpnl.p { color: var(--g); }
.tpnl.n { color: var(--r); }
.tdate { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); }
.delbtn { background: transparent; border: none; color: var(--m); cursor: pointer; font-size: var(--fs-base); padding: 2px 5px; border-radius: 3px; transition: 0.15s; }
.delbtn:hover { color: var(--r); background: var(--rd); }
.editbtn { background: transparent; border: none; color: var(--m); cursor: pointer; font-size: var(--fs-base); padding: 2px 5px; border-radius: 3px; transition: 0.15s; }
.editbtn:hover { color: var(--a); background: var(--a2); }
.tnotes { font-size: var(--fs-base); color: var(--m); line-height: 1.55; margin-top: 6px; padding-top: var(--sp-2); border-top: var(--line); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.ntag { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; margin-right: var(--sp-1); }

/* EMPTY / LOADING */
.empty { text-align: center; padding: 36px; color: var(--m); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; }
.loading { text-align: center; padding: 28px; color: var(--m); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; }
.empty-state { display: flex; flex-direction: column; align-items: center; gap: var(--sp-3); }
.empty-state-icon { font-size: var(--fs-xl); opacity: 0.3; }
.empty-state-text { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; }

/* ══════════════════════════════════════════════════
   ANALYTICS (DASHBOARD)
   ══════════════════════════════════════════════════ */
.dash-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.dash-card, .an-card {
  box-shadow: 0 8px 22px rgba(0,0,0,0.2);
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
  transition: border-color 0.15s;
}
.dash-card:hover, .an-card:hover { border-color: var(--bd2); }
/* Stage 2+5: dash-title clean */
.dash-title {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--m);
  margin-bottom: var(--sp-3);
  text-shadow: none;
}
.an-card-title, .ai-title {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  color: var(--t);
  margin-bottom: var(--sp-3);
  text-shadow: none;
}

/* Speedo */
.speedo-wrap { display: flex; flex-direction: column; align-items: center; }
.speedo-svg { width: 200px; height: 115px; }
.speedo-val { font-family: var(--font-mono); font-size: var(--fs-xl); font-weight: 600; color: var(--a); text-align: center; line-height: 1; text-shadow: none; }
.speedo-desc { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); text-align: center; margin-top: var(--sp-1); letter-spacing: 1px; }

/* EM bars */
.em-bars { display: flex; flex-direction: column; gap: var(--sp-2); }
.em-bar-row { display: flex; flex-direction: column; gap: var(--sp-1); }
.em-bar-head { display: flex; justify-content: space-between; }
.em-bar-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; text-transform: uppercase; }
.em-bar-val { font-family: var(--font-mono); font-size: var(--fs-base); color: var(--t); }
.em-bar-track { height: 3px; background: rgba(255,255,255,0.05); border-radius: 1.5px; overflow: hidden; }
.em-bar-fill { height: 100%; border-radius: 1.5px; transition: width 0.8s cubic-bezier(0.16,1,0.3,1); }

/* Patterns */
.patterns { display: flex; flex-direction: column; gap: var(--sp-2); }
.pattern-item { background: var(--bg-card); border: 1px solid var(--bd); border-radius: 8px; padding: var(--sp-2) var(--sp-3); display: flex; align-items: center; gap: var(--sp-2); }
.pattern-icon { font-size: var(--fs-md); flex-shrink: 0; }
.pattern-text { flex: 1; }
.pattern-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 500; margin-bottom: 1px; }
.pattern-desc { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); }
.pattern-badge { padding: 2px var(--sp-2); border-radius: 4px; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; white-space: nowrap; }
.badge-ok   { background: var(--gd);  border: 1px solid rgba(52,211,153,0.25);  color: var(--g); }
.badge-bad  { background: var(--rd);  border: 1px solid rgba(248,113,113,0.25);  color: var(--r); }
.badge-warn { background: var(--yd);  border: 1px solid rgba(251,191,36,0.25); color: var(--y); }

/* EMC compare */
.emc-legend { display: flex; gap: var(--sp-3); margin-bottom: var(--sp-3); align-items: center; }
.ecc { display: flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; text-transform: uppercase; }
.ecc-dot { width: 7px; height: 3px; border-radius: 1.5px; }
.emc-row { display: flex; align-items: center; gap: var(--sp-2); }
.emc-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); width: 60px; letter-spacing: 1px; text-transform: uppercase; flex-shrink: 0; }
.emc-bars { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.emc-bar { height: 5px; border-radius: 2.5px; min-width: 2px; transition: width 0.8s; }
.emc-win  { background: var(--g); }
.emc-loss { background: var(--r); }

/* ══════════════════════════════════════════════════
   DIGEST
   ══════════════════════════════════════════════════ */
.digest-header {
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius);
  padding: var(--sp-5) var(--sp-6);
  margin-bottom: var(--sp-3);
}
.dh-week { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--a); letter-spacing: 1px; margin-bottom: var(--sp-1); }
/* Stage 2+5: dh-title clean */
.dh-title { font-family: var(--font-body); font-size: var(--fs-lg); font-weight: 600; letter-spacing: -0.3px; margin-bottom: 3px; text-shadow: none; }
.dh-sub { font-family: var(--font-body); color: var(--m); line-height: 1.5; font-size: var(--fs-base); }
.digest-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); margin-bottom: var(--sp-3); }
.dg-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); }
.dg-card.good { background: var(--gd); border-color: rgba(52,211,153,0.15); }
.dg-card.bad  { background: var(--rd); border-color: rgba(248,113,113,0.15); }
.dg-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; text-transform: uppercase; margin-bottom: var(--sp-1); }
.dg-val { font-family: var(--font-mono); font-size: var(--fs-lg); font-weight: 600; letter-spacing: -0.5px; line-height: 1; margin-bottom: 3px; }
.dg-desc { font-family: var(--font-body); font-size: var(--fs-base); color: var(--m); line-height: 1.4; }
.digest-insights { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-4); margin-bottom: var(--sp-3); }
.di-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--a); letter-spacing: 1px; margin-bottom: var(--sp-3); }
.di-items { display: flex; flex-direction: column; gap: 6px; }
.di-item { display: flex; align-items: flex-start; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); background: var(--bg3); border: var(--line); border-radius: 7px; }
.di-icon { font-size: var(--fs-base); flex-shrink: 0; line-height: 1; margin-top: 1px; }
.di-text { font-family: var(--font-body); font-size: var(--fs-sm); color: var(--m); line-height: 1.55; }
.di-text b { color: var(--t); font-weight: 600; }
.month-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); }
.mc-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-4); }
/* Stage 2: mc-title clean */
.mc-title { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; text-transform: uppercase; color: var(--m); margin-bottom: var(--sp-3); }
.mc-row { display: flex; align-items: center; justify-content: space-between; padding: 6px 0; border-bottom: var(--line); }
.mc-row:last-child { border-bottom: none; }
.mc-key { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; }
.mc-vals { display: flex; gap: var(--sp-2); align-items: center; }
.mc-val { font-family: var(--font-mono); font-size: var(--fs-base); }
.mc-val.prev { color: rgba(255,255,255,0.25); }
.mc-val.curr { color: var(--t); }
.mc-delta { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; }
.mc-delta.up { color: var(--g); }
.mc-delta.down { color: var(--r); }
.mc-delta.same { color: var(--m); }

/* ══════════════════════════════════════════════════
   PRE-MARKET / SESSION
   ══════════════════════════════════════════════════ */
.pm-page-wrap { display: flex; flex-direction: column; gap: var(--sp-3); }
.pm-header-card {
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius);
  padding: var(--sp-5) var(--sp-6);
  position: relative;
  overflow: hidden;
}
/* Stage 2+5: pm-headline — no glow, clean */
.pm-headline {
  font-family: var(--font-body);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: -0.5px;
  color: var(--a);
  margin-bottom: 2px;
  text-shadow: none;
}
.pm-headline-sub { font-family: var(--font-mono); font-size: var(--fs-base); color: var(--m); letter-spacing: 1px; }
.pm-body { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.pm-section-card, .pm-limits-card, .pm-moods-card {
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius);
  padding: var(--sp-4);
  position: relative;
  overflow: hidden;
}
/* Stage 2+5: pm-section-title clean */
.pm-section-title {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--m);
  text-shadow: none;
}
.pm-section-title::before {
  content: '';
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--a);
  flex-shrink: 0;
}
.pm-side-title {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
  color: var(--m);
  display: flex;
  align-items: center;
  gap: 6px;
  text-shadow: none;
}
.pm-checklist { display: flex; flex-direction: column; gap: 6px; }
.pm-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 8px;
  cursor: pointer;
  transition: 0.2s;
}
.pm-item:hover { border-color: var(--a3); background: var(--a2); }
.pm-item.checked { background: var(--a2); border-color: var(--a3); }
.pm-check {
  width: 18px; height: 18px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,0.1);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-sm);
  flex-shrink: 0;
  transition: 0.2s;
  color: transparent;
}
.pm-item.checked .pm-check { background: var(--gd); border-color: rgba(52,211,153,0.4); color: var(--g); }
.pm-item-text { font-family: var(--font-body); font-size: var(--fs-sm); color: rgba(255,255,255,0.45); transition: 0.2s; }
.pm-item.checked .pm-item-text { color: rgba(255,255,255,0.75); }
.pm-limits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); }
.pm-limit-field { display: flex; flex-direction: column; gap: var(--sp-1); }
.pm-limit-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; text-transform: uppercase; color: var(--m); }
.pm-limit-input-wrap { position: relative; }
.pm-limit-prefix { position: absolute; left: var(--sp-3); top: 50%; transform: translateY(-50%); font-family: var(--font-mono); font-size: var(--fs-base); color: var(--m); pointer-events: none; }
.pm-limit-input {
  background: var(--bg-input);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: var(--sp-2) var(--sp-3) var(--sp-2) var(--sp-6);
  color: var(--t);
  font-family: var(--font-mono);
  font-size: var(--fs-base);
  outline: 0;
  transition: 0.2s;
  width: 100%;
}
.pm-limit-input.no-prefix { padding-left: var(--sp-3); }
.pm-limit-input:focus { border-color: var(--bd3); background: var(--a2); }
.pm-limit-input::placeholder { color: rgba(255,255,255,0.15); }
.pm-moods { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-2); }
.pm-mood-btn {
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.025);
  color: var(--m);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: 0.2s;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-3) var(--sp-2);
}
.pm-mood-emoji { font-size: 20px; line-height: 1; }
.pm-mood-label { font-size: var(--fs-xs); letter-spacing: 1px; text-transform: uppercase; }
.pm-mood-btn:hover { border-color: var(--a3); background: var(--a2); color: var(--m); }
.pm-mood-btn.active { background: var(--a2); border-color: var(--a3); color: var(--a); }
.pm-status {
  padding: var(--sp-2) var(--sp-4);
  border-radius: 9px;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.pm-status.ready  { background: var(--gd); border: 1px solid rgba(52,211,153,0.2);  color: var(--g); }
.pm-status.partial{ background: var(--yd); border: 1px solid rgba(251,191,36,0.2); color: var(--y); }
.pm-status.notready{ background: var(--rd); border: 1px solid rgba(248,113,113,0.2); color: var(--r); }

/* Stage 4: pm-save-btn — clean flat */
.pm-save-btn {
  width: 100%;
  padding: 13px;
  background: var(--a);
  border: none;
  border-radius: var(--radius);
  color: #fff;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: 0.3px;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}
.pm-save-btn:hover { opacity: 0.88; transform: translateY(-1px); }

.pm-history-item { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-2) 0; border-bottom: var(--line); }
.pm-history-item:last-child { border-bottom: none; }
.pm-h-date { font-family: var(--font-mono); font-size: var(--fs-base); color: var(--m); }
.pm-h-mood { font-size: var(--fs-base); }
.pm-h-bar { flex: 1; height: 3px; background: rgba(255,255,255,0.05); border-radius: 1.5px; margin: 0 var(--sp-2); overflow: hidden; }
.pm-h-fill { height: 100%; border-radius: 1.5px; }
.pm-streak-box {
  display: flex; align-items: center; gap: var(--sp-3);
  background: var(--yd); border: 1px solid rgba(251,191,36,0.2);
  border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-3);
}
/* Stage 5: streak num — no text-shadow */
.pm-streak-num { font-family: var(--font-mono); font-size: var(--fs-xl); font-weight: 600; color: var(--y); text-shadow: none; }
.pm-streak-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; }
.pm-side-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-4); }
.pm-ready-bar { background: var(--bg-card); border: var(--line); border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); }
.pm-ready-text { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; }
.pm-start-btn {
  width: 100%;
  padding: 12px;
  background: var(--a);
  border: none;
  border-radius: var(--radius);
  color: #fff;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s;
}
.pm-start-btn:hover { opacity: 0.88; }

/* ══════════════════════════════════════════════════
   PROGRESS
   ══════════════════════════════════════════════════ */
.progress-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-5); flex-wrap: wrap; gap: var(--sp-2); }
.progress-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-2); margin-bottom: var(--sp-4); }
.pkpi { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); }
.pkpi-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: var(--sp-1); }
.pkpi-val { font-family: var(--font-mono); font-size: 20px; font-weight: 500; }
.pkpi-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); margin-top: 3px; }
.equity-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-5); margin-bottom: var(--sp-3); }
/* Stage 2+5: eq-title clean */
.eq-title { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; text-transform: uppercase; margin-bottom: var(--sp-3); display: flex; justify-content: space-between; align-items: center; }
#equity-canvas { width: 100%; height: 180px; display: block; border-radius: 4px; }
.pairs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); margin-bottom: var(--sp-3); }
.pair-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-3); }
.pair-name { font-family: var(--font-body); font-size: var(--fs-md); font-weight: 600; letter-spacing: 1px; margin-bottom: 5px; }
.pair-stat { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); margin-right: var(--sp-2); }
.pair-stat span { color: var(--t); }

/* HEATMAP */
.hm-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-5); margin-bottom: var(--sp-3); }
.hm-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-4); }
/* Stage 2+5: hm-title clean */
.hm-title { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; text-transform: uppercase; }
.hm-stats { display: flex; gap: var(--sp-3); }
.hm-stat { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); }
.hm-stat strong { color: var(--t); }
.hm-weeks { display: flex; gap: 3px; }
.hm-week { display: flex; flex-direction: column; gap: 3px; }
.hm-day-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: rgba(255,255,255,0.18); height: 14px; display: flex; align-items: center; justify-content: center; }
.hm-cell {
  width: 14px; height: 14px;
  border-radius: 3px;
  background: rgba(255,255,255,0.04);
  cursor: pointer;
  position: relative;
  transition: transform 0.1s;
  border: 1px solid rgba(255,255,255,0.03);
}
.hm-cell:hover { transform: scale(1.35); z-index: 10; }
.hm-cell:hover .hm-tip { display: block; }
.hm-cell-win { background: rgba(52,211,153,0.35); }
.hm-cell-win.hot { background: rgba(52,211,153,0.65); }
.hm-tip { display: none; position: absolute; bottom: 130%; left: 50%; transform: translateX(-50%); background: rgba(10,12,15,0.97); border: 1px solid var(--bd2); border-radius: 7px; padding: 6px var(--sp-2); font-family: var(--font-mono); font-size: var(--fs-xs); white-space: nowrap; z-index: 30; color: var(--t); pointer-events: none; }
.hm-tip::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 4px solid transparent; border-top-color: var(--bd2); }
.hm-month-labels { display: flex; gap: 3px; margin-bottom: 3px; padding-left: 22px; }
.hm-month-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: rgba(255,255,255,0.2); white-space: nowrap; }
.hm-legend { display: flex; align-items: center; gap: 5px; margin-top: var(--sp-2); font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); }
.hm-legend-item { width: 12px; height: 12px; border-radius: 2px; }

/* SETUP GRID */
.setup-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); margin-top: var(--sp-2); }
.setup-card { background: var(--bg2); border: var(--line); border-radius: 8px; padding: var(--sp-3); }
.setup-name { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; margin-bottom: 5px; }
.setup-wr { font-family: var(--font-mono); font-size: var(--fs-lg); font-weight: 600; letter-spacing: -0.5px; }
.setup-meta { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); margin-top: 3px; }
.setup-bar { height: 2px; background: rgba(255,255,255,0.06); border-radius: 1px; margin-top: var(--sp-2); overflow: hidden; }
.setup-bar-fill { height: 100%; border-radius: 1px; transition: width 0.6s; background: var(--a); }
.setup-bar-fill.neg { background: rgba(200,200,200,0.35); }
.best-setup-badge  { display: inline-flex; align-items: center; gap: 5px; background: var(--gd); border: 1px solid rgba(52,211,153,0.25); border-radius: 20px; padding: 3px var(--sp-2); font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--g); margin-left: var(--sp-2); }
.worst-setup-badge { display: inline-flex; align-items: center; gap: 5px; background: var(--rd); border: 1px solid rgba(248,113,113,0.2); border-radius: 20px; padding: 3px var(--sp-2); font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--r); margin-left: var(--sp-2); }
.psych-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); margin-top: var(--sp-2); }
.psych-card { background: var(--bg2); border: var(--line); border-radius: 8px; padding: var(--sp-3); }
.psych-cond { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; margin-bottom: 3px; }
.psych-result { font-family: var(--font-mono); font-size: var(--fs-md); font-weight: 600; letter-spacing: 0; }
.psych-trades { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); margin-top: 2px; }
.psych-btn { padding: var(--sp-1) var(--sp-2); border-radius: 6px; border: var(--line); background: var(--bg3); color: var(--m); font-family: var(--font-mono); font-size: var(--fs-xs); cursor: pointer; transition: 0.15s; }
.psych-btn:hover { border-color: var(--bd2); color: var(--t); }
.psych-btn.active { background: var(--a2); border-color: var(--a3); color: var(--a); }
.brutal-btn {
  width: 100%;
  padding: var(--sp-3);
  background: var(--rd);
  border: 1px solid rgba(248,113,113,0.2);
  border-radius: var(--radius);
  color: var(--r);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  cursor: pointer;
  text-transform: uppercase;
  transition: 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
}
.brutal-btn:hover { background: rgba(248,113,113,0.12); border-color: rgba(248,113,113,0.4); }
.brutal-result { display: none; margin-top: var(--sp-3); background: rgba(0,0,0,0.3); border: 1px solid rgba(248,113,113,0.15); border-radius: var(--radius); padding: var(--sp-4); }
.brutal-result.show { display: block; animation: 0.3s pgIn; }
.brutal-line { font-family: var(--font-mono); font-size: var(--fs-xs); line-height: 1.8; color: var(--m); }
.brutal-line strong { color: var(--r); }
.brutal-line .bgreen { color: var(--g); }

/* ══════════════════════════════════════════════════
   COACH / AI
   ══════════════════════════════════════════════════ */
.coach-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-5); margin-bottom: var(--sp-3); }
.coach-header { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.coach-avatar { width: 44px; height: 44px; border-radius: 50%; background: rgba(255,143,163,0.08); border: 1px solid var(--a3); display: flex; align-items: center; justify-content: center; font-size: 28px; flex-shrink: 0; }
/* Stage 5: coach name — no glow */
.coach-name { font-family: var(--font-body); font-size: var(--fs-md); font-weight: 600; color: var(--g); }
.coach-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; }
.coach-recs { display: flex; flex-direction: column; gap: var(--sp-2); }
.coach-rec { border-radius: var(--radius); padding: var(--sp-3) var(--sp-3); display: flex; align-items: flex-start; gap: var(--sp-2); transition: 0.15s; }
.coach-rec.warn { background: rgba(251,191,36,0.05); border: 1px solid rgba(251,191,36,0.18); }
.coach-rec.crit { background: rgba(248,113,113,0.04); border: 1px solid rgba(248,113,113,0.18); }
.coach-rec.good { background: rgba(52,211,153,0.03); border: 1px solid rgba(52,211,153,0.16); }
.coach-rec-icon { font-size: var(--fs-md); flex-shrink: 0; margin-top: 1px; line-height: 1; }
.coach-rec-text { font-family: var(--font-body); font-size: var(--fs-sm); line-height: 1.6; flex: 1; }
.coach-rec.warn .coach-rec-text { color: rgba(245,200,90,0.9); }
.coach-rec.crit .coach-rec-text { color: rgba(255,120,110,0.9); }
.coach-rec.good .coach-rec-text { color: rgba(100,230,130,0.9); }
.coach-rec-text strong { font-weight: 600; }
.coach-rec-badge { margin-left: auto; flex-shrink: 0; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; padding: 2px 7px; border-radius: 4px; text-transform: uppercase; }
.coach-rec.warn .coach-rec-badge { background: var(--yd); color: var(--y); border: 1px solid rgba(251,191,36,0.25); }
.coach-rec.crit .coach-rec-badge { background: var(--rd); color: var(--r); border: 1px solid rgba(248,113,113,0.25); }
.coach-rec.good .coach-rec-badge { background: var(--gd); color: var(--g); border: 1px solid rgba(52,211,153,0.25); }
.coach-run-btn { width: 100%; padding: var(--sp-3); background: var(--a2); border: 1px solid var(--a3); border-radius: 8px; color: var(--a); font-family: var(--font-body); font-size: var(--fs-base); font-weight: 500; letter-spacing: 0.3px; cursor: pointer; transition: 0.2s; margin-top: var(--sp-3); }
.coach-run-btn:hover { background: rgba(255,122,138,0.14); border-color: var(--bd2); }
.coach-insight { border-radius: var(--radius); padding: var(--sp-3); border: 1px solid var(--bd); margin-bottom: 6px; }
.coach-insight.good { border-color: rgba(52,211,153,0.2); background: var(--gd); }
.coach-insight.good .ci-icon, .coach-insight.good .ci-title { color: var(--g); }
.ci-badge { padding: 2px var(--sp-1); border-radius: 4px; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; }
.ci-badge.good, .ci-badge.ok { background: var(--gd); color: var(--g); border: 1px solid rgba(52,211,153,0.25); }
.my-badges { margin-top: var(--sp-3); padding-top: var(--sp-3); border-top: var(--line); }
.my-badges-title { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; margin-bottom: var(--sp-2); text-transform: uppercase; }

/* AI MODAL */
.ai-modal { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.75); backdrop-filter: blur(6px); z-index: 500; align-items: center; justify-content: center; padding: var(--sp-4); }
.ai-modal.open { display: flex; }
.ai-box { background: var(--bg-card); border: 1px solid var(--bd2); border-radius: var(--radius-lg); width: 100%; max-width: 520px; max-height: 90vh; overflow-y: auto; padding: var(--sp-6); position: relative; }
.ai-close { position: absolute; top: var(--sp-3); right: var(--sp-3); background: transparent; border: none; color: var(--m); font-size: 20px; cursor: pointer; transition: color 0.15s; }
.ai-close:hover { color: var(--t); }
/* Stage 2+5: ai-title clean */
.ai-title { font-family: var(--font-body); font-size: var(--fs-lg); font-weight: 600; color: var(--t); margin-bottom: 2px; text-shadow: none; }
.ai-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; margin-bottom: var(--sp-4); }
.ck-item { background: var(--bg3); border: var(--line); border-radius: 8px; padding: var(--sp-2) var(--sp-3); margin-bottom: 6px; }
.ck-num { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; margin-bottom: 6px; }
.ck-q { font-family: var(--font-body); font-size: var(--fs-sm); margin-bottom: var(--sp-2); }
.ck-btns { display: flex; gap: 6px; }
.ck-btn { flex: 1; padding: 7px; border-radius: 6px; border: var(--line); background: var(--bg3); color: var(--m); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; cursor: pointer; transition: 0.15s; }
.ck-btn.yes { background: var(--gd); border-color: rgba(52,211,153,0.35); color: var(--g); }
.ck-btn.no  { background: var(--rd); border-color: rgba(248,113,113,0.35); color: var(--r); }
.ai-note { margin-bottom: var(--sp-3); }
.ai-note label { display: block; font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 5px; }
.ai-note textarea { width: 100%; background: var(--bg3); border: var(--line); border-radius: 7px; padding: var(--sp-2) var(--sp-2); color: var(--t); font-family: var(--font-body); font-size: var(--fs-sm); line-height: 1.5; outline: 0; resize: vertical; min-height: 70px; transition: border-color 0.15s; }
.ai-note textarea:focus { border-color: rgba(52,211,153,0.35); }
.ai-check-btn { width: 100%; padding: var(--sp-2); background: var(--a2); border: 1px solid var(--a3); border-radius: 8px; color: var(--a); font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; cursor: pointer; transition: 0.15s; }
.ai-check-btn:hover { background: rgba(255,143,163,0.16); }
.ai-check-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.ai-result { margin-top: var(--sp-3); border-radius: 9px; padding: var(--sp-3); display: none; }
.ai-result.go   { background: var(--gd); border: 1px solid rgba(52,211,153,0.2); }
.ai-result.stop { background: var(--rd); border: 1px solid rgba(248,113,113,0.2); }
.ai-result.wait { background: var(--yd); border: 1px solid rgba(251,191,36,0.2); }
.ai-verdict { font-family: var(--font-body); font-size: var(--fs-xl); font-weight: 700; letter-spacing: -0.5px; margin-bottom: 6px; }
.ai-verdict.go   { color: var(--g); }
.ai-verdict.stop { color: var(--r); }
.ai-verdict.wait { color: var(--y); }
.ai-text { font-family: var(--font-body); font-size: var(--fs-sm); color: var(--m); line-height: 1.6; }

/* ══════════════════════════════════════════════════
   CHAT / AI CHAT
   ══════════════════════════════════════════════════ */
.chat-layout { display: grid; grid-template-columns: 200px 1fr; gap: var(--sp-3); height: calc(100vh - 180px); min-height: 500px; }
.chat-sidebar { background: var(--bg2); border: var(--line); border-radius: var(--radius); display: flex; flex-direction: column; overflow: hidden; }
.chat-sb-title { font-family: var(--font-body); font-size: var(--fs-xs); letter-spacing: 1px; text-transform: uppercase; color: var(--m); padding: var(--sp-3) var(--sp-3); border-bottom: var(--line); font-weight: 600; }
.chat-shortcuts { flex: 1; padding: var(--sp-2); overflow-y: auto; display: flex; flex-direction: column; gap: 3px; }
.chat-sc { padding: var(--sp-2) var(--sp-2); border-radius: 6px; cursor: pointer; border: var(--line); background: var(--bg3); transition: 0.15s; }
.chat-sc:hover { background: var(--a2); border-color: var(--a3); }
.chat-sc-icon { font-size: var(--fs-base); margin-bottom: 3px; }
.chat-sc-text { font-family: var(--font-body); font-size: var(--fs-sm); color: var(--m); line-height: 1.3; }
.chat-header-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; color: var(--t); }
.chat-status { display: flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--g); letter-spacing: 1px; }
.chat-status-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--g); animation: 2s blink ease-in-out infinite; }
@keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }
.chat-msg { display: flex; margin-bottom: var(--sp-2); }
.chat-msg.user { justify-content: flex-end; flex-direction: row-reverse; }
.chat-msg.ai { justify-content: flex-start; }
.msg-avatar { width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0; margin-top: 2px; display: flex; align-items: center; justify-content: center; font-size: var(--fs-sm); }
.msg-avatar.ai { background: var(--gd); border: 1px solid rgba(52,211,153,0.2); }
.msg-avatar.user { background: var(--a2); border: 1px solid var(--a3); }
.msg-bubble { max-width: 72%; padding: var(--sp-2) var(--sp-3); border-radius: var(--radius); font-family: var(--font-body); font-size: var(--fs-sm); line-height: 1.6; }
.chat-msg.ai .msg-bubble { background: var(--bg3); border: var(--line); color: var(--t); border-bottom-left-radius: 3px; }
.chat-msg.user .msg-bubble { background: var(--a2); border: 1px solid var(--a3); color: var(--t); border-bottom-right-radius: 3px; }
.msg-bubble p { margin-bottom: 6px; }
.msg-bubble p:last-child { margin-bottom: 0; }
.msg-bubble strong { color: var(--t); font-weight: 600; }
.msg-bubble .tag { display: inline-block; padding: 1px 6px; border-radius: 3px; font-family: var(--font-mono); font-size: var(--fs-xs); margin: 1px 2px; }
.tag.green  { background: var(--gd); color: var(--g); }
.tag.red    { background: var(--rd); color: var(--r); }
.tag.orange { background: var(--a2); color: var(--a); }
.msg-typing { display: flex; gap: 4px; align-items: center; padding: var(--sp-2) var(--sp-3); }
.msg-typing span { width: 5px; height: 5px; border-radius: 50%; background: var(--m); animation: 1.2s ease-in-out infinite typing; }
.msg-typing span:nth-child(2) { animation-delay: 0.2s; }
.msg-typing span:nth-child(3) { animation-delay: 0.4s; }
@keyframes typing { 0%,100%,80% { transform: scale(0.7); opacity: 0.5; } 40% { transform: scale(1); opacity: 1; } }
.chat-messages::-webkit-scrollbar { width: 3px; }
.chat-messages::-webkit-scrollbar-thumb { background: var(--bd); border-radius: 2px; }
.chat-input-area { padding: var(--sp-3); border-top: var(--line); flex-shrink: 0; }
.chat-input:focus { border-color: var(--a); }
.chat-send { width: 36px; height: 36px; border-radius: 7px; border: none; background: var(--a); color: #fff; font-size: var(--fs-base); cursor: pointer; transition: opacity 0.15s; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.chat-send:hover { opacity: 0.85; }
.chat-send:disabled { opacity: 0.35; cursor: not-allowed; }

/* ══════════════════════════════════════════════════
   POPUPS (Goal, Balance, Qnote)
   ══════════════════════════════════════════════════ */
.goal-popup {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 200;
  width: 260px;
  background: var(--bg-card);
  border: 1px solid var(--bd2);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,0.6);
  display: none;
  animation: 0.18s qnoteIn both;
}
.goal-popup.open { display: block; }
.goal-popup-head { padding: var(--sp-2) var(--sp-3) var(--sp-2); border-bottom: 1px solid rgba(255,255,255,0.06); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; color: var(--a); text-transform: uppercase; }
.goal-popup-body { padding: var(--sp-3) var(--sp-3); }
.goal-popup-row { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.goal-popup-row:last-child { margin-bottom: 0; }
.goal-popup-lbl { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; text-transform: uppercase; flex-shrink: 0; width: 60px; }
.goal-popup-input { flex: 1; background: var(--bg-input); border: 1px solid var(--bd); border-radius: 6px; padding: var(--sp-2) var(--sp-3); color: var(--t); font-family: var(--font-mono); font-size: var(--fs-sm); outline: 0; transition: 0.15s; }
.goal-popup-input:focus { border-color: var(--bd3); }
.goal-popup-unit { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); flex-shrink: 0; }
.goal-popup-today { padding: var(--sp-2) var(--sp-3); background: rgba(255,255,255,0.02); border-top: 1px solid rgba(255,255,255,0.05); font-family: var(--font-mono); font-size: var(--fs-base); color: var(--m); display: flex; justify-content: space-between; align-items: center; }
.goal-popup-save { width: calc(100% - 24px); margin: var(--sp-2) var(--sp-3) var(--sp-3); padding: var(--sp-2); border: none; border-radius: 7px; background: var(--a); color: #fff; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; cursor: pointer; transition: opacity 0.15s; display: block; }
.goal-popup-save:hover { opacity: 0.85; }

.balance-popup {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 200;
  width: 270px;
  background: var(--bg-card);
  border: 1px solid var(--bd2);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,0.6);
  display: none;
  animation: 0.18s qnoteIn both;
}
.balance-popup.open { display: block; }
.balance-popup-head { padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid rgba(255,255,255,0.06); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; color: var(--g); text-transform: uppercase; }
.balance-popup-body { padding: var(--sp-3) var(--sp-3) var(--sp-2); }
.balance-popup-row { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.balance-popup-lbl { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; flex-shrink: 0; width: 68px; }
.balance-popup-input { flex: 1; background: var(--bg-input); border: 1px solid var(--bd); border-radius: 6px; padding: var(--sp-2) var(--sp-3); color: var(--t); font-family: var(--font-mono); font-size: var(--fs-sm); outline: 0; transition: 0.15s; }
.balance-popup-input:focus { border-color: var(--bd3); }
.balance-popup-unit { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); flex-shrink: 0; }
.balance-popup-stats { margin: 0 var(--sp-3) var(--sp-3); background: rgba(255,255,255,0.02); border: 1px solid var(--bd); border-radius: 8px; padding: var(--sp-2) var(--sp-3); display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-2); }
.bps-item { text-align: center; }
.bps-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m2); letter-spacing: 1px; margin-bottom: 3px; }
.bps-val { font-family: var(--font-mono); font-size: var(--fs-sm); }
.balance-popup-save { width: calc(100% - 24px); margin: 0 var(--sp-3) var(--sp-3); padding: var(--sp-2); border: none; border-radius: 7px; background: linear-gradient(135deg, var(--g), #1a9e40); color: #fff; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; cursor: pointer; transition: opacity 0.15s; display: block; }
.balance-popup-save:hover { opacity: 0.85; }

/* QNOTE */
.qnote-overlay { position: fixed; inset: 0; z-index: 999; background: rgba(0,0,0,0.5); backdrop-filter: blur(6px); display: none; align-items: flex-start; justify-content: flex-end; padding: 56px var(--sp-4) 0; }
.qnote-overlay.open { display: flex; }
.qnote-popup { width: 320px; background: var(--bg-card); border: 1px solid var(--bd2); border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 24px 80px rgba(0,0,0,0.7); animation: 0.22s qnoteIn both; }
@keyframes qnoteIn { from { opacity: 0; transform: translateY(-8px) scale(0.97); } to { opacity: 1; transform: none; } }
.qnote-head { padding: var(--sp-3) var(--sp-3) var(--sp-2); border-bottom: 1px solid rgba(255,255,255,0.06); display: flex; align-items: center; justify-content: space-between; }
.qnote-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; color: var(--a); }
.qnote-close { background: transparent; border: none; color: var(--m); font-size: var(--fs-base); cursor: pointer; padding: 0 2px; line-height: 1; }
.qnote-close:hover { color: var(--t); }
.qnote-body { padding: var(--sp-3) var(--sp-3); }
.qnote-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; color: var(--m); text-transform: uppercase; margin-bottom: 6px; }
.qnote-type-row { display: flex; gap: 5px; margin-bottom: var(--sp-2); }
.qnote-type-btn { padding: var(--sp-1) var(--sp-2); border-radius: 5px; border: 1px solid var(--bd); background: var(--bg2); color: var(--m); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; cursor: pointer; transition: 0.12s; }
.qnote-type-btn.active, .qnote-type-btn:hover { background: var(--a2); border-color: var(--a3); color: var(--a); }
.qnote-textarea { width: 100%; background: var(--bg-input); border: 1px solid var(--bd); border-radius: 8px; padding: var(--sp-2) var(--sp-3); color: var(--t); font-family: var(--font-body); font-size: var(--fs-base); outline: 0; resize: vertical; height: 90px; line-height: 1.5; transition: 0.15s; box-sizing: border-box; }
.qnote-textarea::placeholder { color: rgba(255,255,255,0.2); }
.qnote-textarea:focus { border-color: var(--bd2); }
.qnote-footer { padding: 0 var(--sp-3) var(--sp-3); display: flex; gap: 6px; }
/* Stage 4: qnote-save clean */
.qnote-save { flex: 1; padding: var(--sp-2); border: none; cursor: pointer; background: var(--a); color: #fff; font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; border-radius: 7px; transition: opacity 0.15s; }
.qnote-save:hover { opacity: 0.85; }
.qnote-list { border-top: 1px solid rgba(255,255,255,0.05); padding: var(--sp-2) var(--sp-3); max-height: 140px; overflow-y: auto; display: flex; flex-direction: column; gap: 5px; }
.qnote-list::-webkit-scrollbar { width: 3px; }
.qnote-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.qnote-item { background: rgba(255,255,255,0.02); border: 1px solid var(--bd); border-radius: 7px; padding: 6px var(--sp-2); position: relative; }
.qnote-item-type { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; color: var(--a); margin-bottom: 3px; text-transform: uppercase; }
.qnote-item-text { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m2); line-height: 1.5; }
.qnote-item-del { position: absolute; top: 5px; right: 7px; background: transparent; border: none; color: rgba(255,255,255,0.15); font-size: var(--fs-sm); cursor: pointer; }
.qnote-item-del:hover { color: var(--r); }

/* ══════════════════════════════════════════════════
   EDIT MODAL
   ══════════════════════════════════════════════════ */
.edit-modal { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.75); backdrop-filter: blur(6px); z-index: 500; align-items: center; justify-content: center; padding: var(--sp-4); }
.edit-modal.open { display: flex; }
.edit-box { background: var(--bg-card); border: 1px solid var(--bd2); border-radius: var(--radius-lg); padding: var(--sp-6); width: 100%; max-width: 520px; position: relative; max-height: 90vh; overflow-y: auto; }
.edit-box::-webkit-scrollbar { width: 4px; }
.edit-box::-webkit-scrollbar-thumb { background: var(--bd); border-radius: 2px; }
/* Stage 2: edit-title clean */
.edit-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; color: var(--a); margin-bottom: var(--sp-5); }
.edit-close { position: absolute; top: var(--sp-4); right: var(--sp-4); background: transparent; border: none; color: var(--m); font-size: 20px; cursor: pointer; transition: color 0.15s; line-height: 1; }
.edit-close:hover { color: var(--r); }
.edit-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.edit-field { display: flex; flex-direction: column; gap: var(--sp-1); }
.edit-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; text-transform: uppercase; }
.edit-input { background: var(--bg-input); border: 1px solid var(--bd); border-radius: 8px; padding: var(--sp-2) var(--sp-3); color: var(--t); font-family: var(--font-mono); font-size: var(--fs-base); outline: 0; transition: 0.15s; width: 100%; }
.edit-input:focus { border-color: var(--a); background: var(--a2); }
/* Stage 4: edit-save clean */
.edit-save { width: 100%; padding: var(--sp-2); background: var(--a); border: none; color: #fff; font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; cursor: pointer; margin-top: var(--sp-2); border-radius: var(--radius); transition: opacity 0.15s; }
.edit-save:hover { opacity: 0.88; }

/* ══════════════════════════════════════════════════
   NOTIFICATIONS
   ══════════════════════════════════════════════════ */
.notif-tray { position: fixed; top: var(--sp-4); right: var(--sp-4); z-index: 200; display: flex; flex-direction: column; gap: var(--sp-2); pointer-events: none; }
.notif {
  background: var(--bg-card);
  border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-4);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  pointer-events: all;
  min-width: 260px;
  max-width: 320px;
  animation: 0.3s notifIn both;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.notif.notif-warn    { border: 1px solid rgba(251,191,36,0.4); }
.notif.notif-danger  { border: 1px solid rgba(248,113,113,0.45); }
.notif.notif-success { border: 1px solid rgba(52,211,153,0.35); }
.notif.notif-info    { border: 1px solid var(--a3); }
.notif-icon { font-size: 20px; flex-shrink: 0; }
.notif-body { flex: 1; }
/* Stage 2: notif-title clean */
.notif-title { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; margin-bottom: 2px; }
.notif-warn .notif-title    { color: var(--y); }
.notif-danger .notif-title  { color: var(--r); }
.notif-success .notif-title { color: var(--g); }
.notif-info .notif-title    { color: var(--a); }
.notif-msg { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); line-height: 1.5; }
.notif-close { background: transparent; border: none; color: var(--m); cursor: pointer; font-size: var(--fs-base); padding: 0; flex-shrink: 0; }
@keyframes notifIn { from { opacity: 0; transform: translateX(16px); } to { opacity: 1; transform: none; } }
.notif.hiding { animation: 0.25s notifOut forwards; }
@keyframes notifOut { to { opacity: 0; transform: translateX(16px); height: 0; padding: 0; margin: 0; } }

/* JNL NOTIF POPUP */
.jnl-notif-popup { border-left: 3px solid var(--a); }
.balance-popup, .goal-popup, .jnl-notif-popup, .qnote-popup { background: var(--bg-card); border-color: var(--bd2); box-shadow: 0 16px 56px rgba(0,0,0,0.65); }

/* ══════════════════════════════════════════════════
   SIMULATOR
   ══════════════════════════════════════════════════ */
.sim-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-5); margin-bottom: var(--sp-3); }
/* Stage 2+5: sim titles clean */
.sim-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; color: var(--a); margin-bottom: var(--sp-1); }
.sim-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; margin-bottom: var(--sp-4); }
.sim-params { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); margin-bottom: var(--sp-4); }
.sim-param { background: var(--bg3); border: var(--line); border-radius: 8px; padding: var(--sp-3); }
.sim-param-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: var(--sp-1); }
.sim-param-val { font-family: var(--font-mono); font-size: var(--fs-lg); font-weight: 600; color: var(--a); }
.sim-toggles { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.sim-toggle { padding: var(--sp-1) var(--sp-3); border-radius: 20px; border: var(--line); background: transparent; color: var(--m); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; cursor: pointer; transition: 0.15s; }
.sim-toggle.active { background: var(--a2); border-color: var(--a3); color: var(--a); }
.sim-result { background: var(--gd); border: 1px solid rgba(52,211,153,0.2); border-radius: var(--radius); padding: var(--sp-4); display: none; }
.sim-result.show { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); animation: 0.3s pgIn; }
.sim-roi-box { text-align: center; padding: var(--sp-2); background: rgba(52,211,153,0.06); border-radius: 8px; }
.sim-roi-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; margin-bottom: 6px; text-transform: uppercase; }
.sim-roi-val { font-family: var(--font-mono); font-size: var(--fs-xl); font-weight: 600; color: var(--g); }
.sim-roi-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: rgba(52,211,153,0.6); margin-top: 2px; }
.sim-run-btn { width: 100%; padding: var(--sp-3); background: var(--a2); border: 1px solid var(--a3); border-radius: 8px; color: var(--a); font-family: var(--font-body); font-size: var(--fs-base); font-weight: 500; cursor: pointer; transition: 0.2s; margin-bottom: var(--sp-3); }
.sim-run-btn:hover { background: rgba(255,122,138,0.14); }

/* ══════════════════════════════════════════════════
   PROGRESS BARS
   ══════════════════════════════════════════════════ */
.prog-bar-fill { background: linear-gradient(90deg, var(--a), rgba(255,122,138,0.5)); }
.ch-progress-fill { height: 100%; border-radius: 2px; transition: width 0.6s; background: var(--a); }
.prog-card, .prog-section, .challenge-card, .hm-wrap {
  background: var(--bg-card);
  border: 1px solid var(--bd);
  border-radius: var(--radius-lg);
}
.score-card { background: var(--bg-card); border: 1px solid var(--bd); border-radius: var(--radius-lg); }
.score-val, .score-ring-fill { color: var(--a); }
.score-circle { stroke: var(--a); }
.level-badge-icon, .prog-pct { color: var(--a); }
.streak-val { color: var(--a); }
.str-fire { color: var(--a); }
.level-name.active { color: var(--a); }
.level-pct { color: var(--a); }
.needs-more .nm-icon { color: var(--a); }

/* ══════════════════════════════════════════════════
   DS RING / SCORE RING
   ══════════════════════════════════════════════════ */
.ds-card { background: var(--bg-card); border: 1px solid var(--bd); border-radius: var(--radius-lg); padding: var(--sp-5); transition: border-color 0.15s; }
.ds-card:hover { border-color: var(--bd2); }
.ds-ring-wrap { display: flex; align-items: center; gap: var(--sp-6); padding: var(--sp-1) 0 var(--sp-3); }
.ds-ring-svg { flex-shrink: 0; }
.ds-info { flex: 1; }
.ds-level { font-family: var(--font-body); font-size: var(--fs-lg); font-weight: 600; letter-spacing: -0.3px; margin-bottom: 3px; }
.ds-desc { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); line-height: 1.5; }
.ds-val { font-family: var(--font-mono); }
.ds-val.orange { color: var(--a); }
.ds-val.green { color: var(--g); }
.ds-val.red { color: var(--r); }
#ds-roi { color: var(--a); }
.ds-breakdown { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: var(--sp-2); }
.ds-item { background: rgba(255,255,255,0.03); border-radius: 6px; padding: var(--sp-2) var(--sp-2); }
.ds-item-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1px; margin-bottom: var(--sp-1); }
.ds-item-bar { height: 3px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.ds-item-fill { height: 100%; border-radius: 2px; transition: width 0.6s; }
.ds-item-val { font-family: var(--font-mono); font-size: var(--fs-xs); margin-top: 3px; }
#ds-b1, #ds-b2, #ds-b3, #ds-b4 { background: var(--a); }

/* ══════════════════════════════════════════════════
   CHALLENGES
   ══════════════════════════════════════════════════ */
.ch-card { background: rgba(255,255,255,0.025); border: 1px solid var(--bd); border-radius: var(--radius); padding: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-2); transition: border-color 0.2s; }
.ch-card.done { border-color: var(--a3); background: var(--a2); }
.ch-card.active { border-color: var(--a3); }
.ch-head { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: 6px; }
.ch-icon { width: 36px; height: 36px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: var(--a2); border: 1px solid var(--a3); border-radius: 8px; }
.ch-title { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--t); letter-spacing: 0.5px; }
.ch-desc { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); line-height: 1.6; }
.ch-progress-track { height: 4px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.ch-footer { display: flex; align-items: center; justify-content: space-between; }
.ch-pct { font-family: var(--font-mono); font-size: var(--fs-base); color: var(--a); }
.ch-badge { font-family: var(--font-mono); font-size: var(--fs-xs); padding: 2px 7px; border-radius: 4px; letter-spacing: 1px; }
.ch-badge.earned { background: var(--gd); color: var(--g); border: 1px solid rgba(52,211,153,0.3); }
.ch-badge.locked { background: rgba(255,255,255,0.04); color: var(--m); border: 1px solid var(--bd); }

/* ══════════════════════════════════════════════════
   HEATMAP BARS
   ══════════════════════════════════════════════════ */
.hb-col { display: flex; flex-direction: column; align-items: center; flex: 1; cursor: default; position: relative; }
.hb-bar { width: 100%; border-radius: 3px 3px 0 0; min-height: 2px; transition: opacity 0.15s; }
.hb-col:hover .hb-bar { opacity: 0.7; }
.hb-tip { position: absolute; bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%); background: rgba(8,10,16,0.95); border: 1px solid var(--bd2); border-radius: 6px; padding: 6px var(--sp-2); font-family: var(--font-mono); font-size: var(--fs-xs); white-space: nowrap; pointer-events: none; opacity: 0; transition: opacity 0.15s; z-index: 10; color: var(--t); line-height: 1.6; }
.hb-col:hover .hb-tip { opacity: 1; }
.hb-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: rgba(255,255,255,0.25); margin-top: 3px; }

/* EQUITY CANVAS */
#em-cmp-chart { padding: var(--sp-2) 0; }

/* ══════════════════════════════════════════════════
   TILT BANNER
   ══════════════════════════════════════════════════ */
.tilt-banner { display: none; background: rgba(248,113,113,0.06); border: 1px solid rgba(248,113,113,0.3); border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-3); }
.tilt-banner.show { display: flex; align-items: flex-start; gap: var(--sp-3); animation: 0.3s pgIn; }
.tilt-icon { font-size: 28px; flex-shrink: 0; }
.tilt-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; color: var(--r); margin-bottom: 3px; }
.tilt-desc { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); line-height: 1.6; }
.tilt-btn { margin-top: var(--sp-2); background: var(--rd); border: 1px solid rgba(248,113,113,0.3); border-radius: 6px; padding: var(--sp-1) var(--sp-3); color: var(--r); font-family: var(--font-mono); font-size: var(--fs-xs); cursor: pointer; letter-spacing: 1px; }

/* SMART NOTIF BAR */
.smart-notif-bar { display: none; align-items: center; gap: var(--sp-2); background: rgba(248,113,113,0.05); border: 1px solid rgba(248,113,113,0.25); border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-4); }
.smart-notif-bar.show { display: flex; animation: 0.3s pgIn; }
.snb-icon { font-size: var(--fs-lg); flex-shrink: 0; }
.snb-body { flex: 1; }
/* Stage 2+5: snb-title clean */
.snb-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; color: var(--r); }
.snb-msg { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); margin-top: 2px; line-height: 1.5; }
.snb-close { background: transparent; border: none; color: var(--m); cursor: pointer; font-size: var(--fs-base); }

/* MISTAKE CARD */
.mistake-card { background: var(--rd); border: 1px solid rgba(248,113,113,0.2); border-radius: var(--radius); padding: var(--sp-4) var(--sp-5); margin-bottom: var(--sp-3); display: flex; align-items: center; gap: var(--sp-3); }
.mistake-icon { font-size: 28px; flex-shrink: 0; }
.mistake-body { flex: 1; }
.mistake-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: rgba(248,113,113,0.6); letter-spacing: 1px; text-transform: uppercase; margin-bottom: var(--sp-1); }
.mistake-title { font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; color: var(--r); margin-bottom: 2px; }
.mistake-loss { font-family: var(--font-mono); font-size: var(--fs-base); color: var(--m); }
.mistake-loss span { color: var(--r); }

/* DATA HINT */
.data-hint { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-4); border-radius: 8px; background: var(--a2); border: 1px solid var(--a3); }
.dh-icon { font-size: var(--fs-md); flex-shrink: 0; color: var(--a); }
.dh-body { flex: 1; }
.dh-text { font-family: var(--font-body); font-size: var(--fs-sm); color: var(--m2); margin-bottom: 2px; }
.dh-text strong { color: var(--a); }
.dh-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 0.5px; }
.analytics-global-hint { display: flex; align-items: center; gap: var(--sp-2); margin-top: var(--sp-2); padding: var(--sp-2) var(--sp-3); border-radius: 7px; background: var(--bg2); border: var(--line); }
.agh-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--a); opacity: 0.5; flex-shrink: 0; }
.agh-text { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 0.3px; line-height: 1.5; }
.agh-text strong { color: rgba(255,122,138,0.7); }

/* ══════════════════════════════════════════════════
   SETTINGS
   ══════════════════════════════════════════════════ */
.settings-card { background: var(--bg-card); border: 1px solid var(--bd); border-radius: var(--radius); padding: var(--sp-4); }
.settings-card-head { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.settings-card-icon { font-size: var(--fs-md); width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--bg3); border-radius: 8px; flex-shrink: 0; }
.settings-card-title { font-size: var(--fs-base); font-weight: 500; color: var(--t); }
.settings-card-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); margin-top: 2px; letter-spacing: 0.5px; }
.tg-status-badge { margin-left: auto; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; padding: 3px var(--sp-2); border-radius: 10px; background: var(--rd); border: 1px solid rgba(248,113,113,0.25); color: var(--r); }
.tg-status-badge.linked { background: var(--gd); border-color: rgba(52,211,153,0.25); color: var(--g); }
.settings-btn-primary { display: block; width: 100%; padding: var(--sp-2) var(--sp-4); background: var(--a); border: none; border-radius: 9px; color: #fff; font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; cursor: pointer; transition: opacity 0.15s; text-align: center; }
.settings-btn-primary:hover { opacity: 0.85; }
.settings-btn-secondary { padding: var(--sp-2) var(--sp-3); background: var(--bg3); border: var(--line); border-radius: 8px; color: var(--m); font-family: var(--font-mono); font-size: var(--fs-xs); cursor: pointer; transition: 0.15s; letter-spacing: 1px; }
.settings-btn-secondary:hover { background: rgba(255,255,255,0.08); color: var(--t); }
.settings-btn-danger { padding: var(--sp-2) var(--sp-3); background: var(--rd); border: 1px solid rgba(248,113,113,0.2); border-radius: 8px; color: var(--r); font-family: var(--font-mono); font-size: var(--fs-xs); cursor: pointer; transition: 0.15s; }
.settings-btn-danger:hover { background: rgba(248,113,113,0.14); }
.toggle-switch { position: relative; display: inline-block; width: 36px; height: 20px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider { position: absolute; cursor: pointer; inset: 0; background: rgba(255,255,255,0.1); border-radius: 20px; transition: 0.25s; border: 1px solid var(--bd); }
.toggle-slider::before { content: ''; position: absolute; height: 14px; width: 14px; left: 2px; bottom: 2px; background: rgba(255,255,255,0.5); border-radius: 50%; transition: 0.25s; }
.toggle-switch input:checked + .toggle-slider { background: var(--gd); border-color: rgba(52,211,153,0.4); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(16px); background: var(--a); }
.notify-toggles { display: flex; flex-direction: column; gap: 0; }
.notify-row { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-2) 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.notify-row:last-child { border-bottom: none; }
.notify-label { font-size: var(--fs-sm); color: var(--t); font-weight: 500; }
.notify-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m2); margin-top: 1px; }
.alert-item { display: flex; align-items: center; gap: var(--sp-2); padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,0.04); }
.alert-item:last-child { border-bottom: none; }
.alert-sym { font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 600; color: var(--t); min-width: 60px; }
.alert-cond { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); flex: 1; }
.alert-price { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--a); font-weight: 500; }
.alert-del { background: transparent; border: none; color: rgba(248,113,113,0.5); cursor: pointer; font-size: var(--fs-base); padding: 2px var(--sp-1); transition: color 0.15s; }
.alert-del:hover { color: var(--r); }

/* CHART BUTTONS */
.chart-sym-btn, .chart-tf-btn {
  height: 24px; padding: 0 var(--sp-2);
  border-radius: 4px; border: 1px solid transparent;
  cursor: pointer; background: transparent; flex-shrink: 0;
  font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.5px;
  color: var(--m); transition: 0.15s;
}
.chart-sym-btn:hover, .chart-tf-btn:hover { background: var(--bg3); color: var(--t); }
.chart-sym-btn.active, .chart-tf-btn.active { background: var(--a2); color: var(--a); border-color: var(--a3); }

/* ══════════════════════════════════════════════════
   SKELETON LOADERS
   ══════════════════════════════════════════════════ */
@keyframes skPulse { 0%,100% { opacity: 0.45; } 50% { opacity: 0.15; } }
.sk { background: rgba(255,255,255,0.07); border-radius: 6px; animation: 1.4s skPulse ease-in-out infinite; display: block; }
.sk-stat-value { height: 28px; width: 60px; margin: var(--sp-1) auto 2px; border-radius: 5px; }
.sk-stat-label { height: 9px; width: 44px; margin: 0 auto; border-radius: 3px; }
.sk-tcard { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-2); display: flex; flex-direction: column; gap: var(--sp-2); }
.sk-tcard-row { display: flex; justify-content: space-between; align-items: center; gap: var(--sp-3); }
.sk-pair { height: 14px; width: 80px; border-radius: 4px; }
.sk-dir { height: 12px; width: 44px; border-radius: 10px; }
.sk-pnl { height: 16px; width: 60px; border-radius: 4px; }
.sk-date { height: 10px; width: 48px; border-radius: 3px; }
.sk-note { height: 10px; width: 70%; border-radius: 3px; margin-top: 2px; }
.sk-dash-card { background: var(--bg2); border: var(--line); border-radius: var(--radius); padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-3); }
.sk-dash-title { height: 10px; width: 100px; border-radius: 3px; }
.sk-dash-value { height: 36px; width: 120px; border-radius: 6px; }
.sk-dash-sub { height: 9px; width: 80px; border-radius: 3px; }
.sk-chart { height: 160px; width: 100%; border-radius: 8px; }
.sk-equity { height: 220px; width: 100%; border-radius: 8px; }
.sk-pk-row { display: flex; gap: var(--sp-3); margin-top: var(--sp-1); }
.sk-pk-item { flex: 1; height: 56px; border-radius: var(--radius); }

/* ══════════════════════════════════════════════════
   BOOT OVERLAY
   ══════════════════════════════════════════════════ */
.orb-boot-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: var(--bg);
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  font-family: var(--font-mono);
  pointer-events: none;
}
.orb-boot-overlay.active { display: flex; }
.orb-boot-tw {
  color: var(--a);
  font-weight: 700;
  font-size: var(--fs-base);
  letter-spacing: 1px;
  white-space: nowrap;
  overflow: hidden;
  width: 0;
  border-right: 2px solid rgba(255,122,138,0.7);
  animation: 2.2s steps(40,end) forwards orbTw;
}
@keyframes orbTw {
  0%   { width: 0; }
  99%  { border-right: 2px solid rgba(255,122,138,0.7); }
  100% { width: 100%; border-right: none; }
}
.orb-boot-sub  { font-size: var(--fs-xs); letter-spacing: 1.5px; opacity: 0; transition: opacity 0.3s; color: var(--m); }
.orb-boot-sub2 { font-size: var(--fs-xs); letter-spacing: 1px; opacity: 0; transition: opacity 0.3s; color: rgba(255,122,138,0.6); }
.orb-boot-bar { width: 200px; height: 2px; background: rgba(255,255,255,0.06); border-radius: 1px; margin-top: 18px; overflow: hidden; }
.orb-boot-bar-fill { height: 100%; width: 0; background: linear-gradient(90deg, var(--a), rgba(255,122,138,0.4)); border-radius: 1px; transition: width 3.5s; }
.orb-boot-hint { font-size: var(--fs-xs); letter-spacing: 3px; opacity: 0; transition: opacity 0.3s; color: var(--m2); margin-top: var(--sp-2); }

/* ══════════════════════════════════════════════════
   HOTKEYS / KEYBOARD
   ══════════════════════════════════════════════════ */
.hk-hint {
  position: fixed; bottom: 72px; left: 50%; transform: translateX(-50%);
  background: rgba(13,16,23,0.96); border: 1px solid var(--bd); border-radius: 8px;
  padding: var(--sp-2) var(--sp-3); font-size: var(--fs-xs);
  font-family: var(--font-mono); color: var(--m); z-index: 9000;
  white-space: nowrap; pointer-events: none; opacity: 0; transition: opacity 0.2s;
}
.hk-hint.show { opacity: 1; }
.hk-hint kbd { background: var(--bg3); border: 1px solid var(--bd2); border-radius: 3px; padding: 1px 5px; font-size: var(--fs-xs); margin: 0 2px; }
.kb-panel { display: none; position: fixed; inset: 0; z-index: 98000; background: rgba(0,0,0,0.7); backdrop-filter: blur(8px); align-items: center; justify-content: center; }
.kb-panel.open { display: flex; }
.kb-box { background: var(--bg-card); border: 1px solid var(--bd2); border-radius: var(--radius-lg); padding: var(--sp-5); width: 340px; max-width: 95vw; }
.kb-title { font-size: var(--fs-xs); color: var(--a); letter-spacing: 1px; font-family: var(--font-mono); margin-bottom: var(--sp-3); text-align: center; text-transform: uppercase; }
.kb-list { display: flex; flex-direction: column; gap: 5px; }
.kb-row { display: flex; align-items: center; justify-content: space-between; padding: 6px var(--sp-2); border-radius: 6px; background: rgba(255,255,255,0.02); }
.kb-row kbd { background: var(--bg3); border: 1px solid var(--bd2); border-radius: 4px; padding: 2px 7px; font-size: var(--fs-xs); font-family: var(--font-mono); color: var(--t); }
.kb-row span { font-size: var(--fs-xs); color: var(--m); }
.kb-close-row { text-align: center; margin-top: var(--sp-3); }
.kb-close { padding: 6px 18px; border-radius: 7px; border: var(--line); background: transparent; color: var(--m); font-size: var(--fs-xs); font-family: var(--font-mono); cursor: pointer; }

/* ══════════════════════════════════════════════════
   SCREENSHOT
   ══════════════════════════════════════════════════ */
.screenshot-zone { border: 1.5px dashed var(--bd); border-radius: var(--radius); padding: 0; transition: border-color 0.15s, background 0.15s; position: relative; overflow: hidden; background: rgba(255,255,255,0.02); }
.screenshot-zone.drag, .screenshot-zone:hover { border-color: var(--a3); background: var(--a2); }
.screenshot-zone.has-image { border-color: var(--a3); border-style: solid; padding: 0; }
.scr-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 18px var(--sp-3); cursor: pointer; }
.scr-icon { font-size: var(--fs-lg); opacity: 0.45; }
.scr-label { font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; font-family: var(--font-mono); text-align: center; }
.scr-label span { color: rgba(255,122,138,0.7); }
.scr-preview { display: none; width: 100%; position: relative; }
.scr-preview img { width: 100%; max-height: 220px; object-fit: contain; display: block; border-radius: 8px; background: #000; }
.scr-remove { position: absolute; top: 6px; right: 6px; width: 24px; height: 24px; border-radius: 50%; background: rgba(0,0,0,0.75); border: 1px solid rgba(255,255,255,0.15); color: rgba(255,255,255,0.7); font-size: var(--fs-xs); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: 0.12s; z-index: 2; }
.scr-remove:hover { background: rgba(248,113,113,0.7); color: #fff; }
.scr-input { display: none; }
.tcard-screenshot { margin-top: var(--sp-2); border-radius: 7px; overflow: hidden; cursor: pointer; position: relative; }
.tcard-screenshot img { width: 100%; max-height: 160px; object-fit: cover; display: block; transition: opacity 0.15s; }
.tcard-screenshot:hover img { opacity: 0.85; }
.tcard-screenshot::after { content: '🔍'; position: absolute; top: 6px; right: 8px; font-size: var(--fs-base); opacity: 0; transition: opacity 0.15s; }
.tcard-screenshot:hover::after { opacity: 0.7; }
.scr-lightbox { display: none; position: fixed; inset: 0; z-index: 99900; background: rgba(0,0,0,0.92); backdrop-filter: blur(8px); align-items: center; justify-content: center; cursor: zoom-out; }
.scr-lightbox.open { display: flex; }
.scr-lightbox img { max-width: 90vw; max-height: 90vh; object-fit: contain; border-radius: 8px; }
.scr-lb-close { position: fixed; top: 20px; right: 24px; font-size: 28px; color: var(--m); cursor: pointer; z-index: 99901; line-height: 1; }
.scr-lb-close:hover { color: #fff; }
.scr-uploading { position: absolute; inset: 0; background: rgba(0,0,0,0.6); display: flex; align-items: center; justify-content: center; font-size: var(--fs-xs); font-family: var(--font-mono); color: var(--a); letter-spacing: 1px; border-radius: 8px; }

/* ══════════════════════════════════════════════════
   ONBOARDING
   ══════════════════════════════════════════════════ */
.onb-overlay { display: none; position: fixed; inset: 0; z-index: 99000; background: rgba(0,0,0,0.85); backdrop-filter: blur(16px); align-items: center; justify-content: center; padding: var(--sp-5); }
.onb-overlay.open { display: flex; }
.onb-box { background: var(--bg-card); border: 1px solid var(--a3); border-radius: var(--radius-lg); width: 100%; max-width: 440px; padding: var(--sp-6); box-shadow: 0 24px 80px rgba(0,0,0,0.7); position: relative; }
.onb-dots { display: flex; gap: 5px; justify-content: center; margin-bottom: var(--sp-6); }
.onb-dot { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,0.1); transition: 0.25s; }
.onb-dot.active { background: var(--a); width: 18px; border-radius: 3px; }
.onb-dot.done { background: rgba(255,255,255,0.2); }
.onb-step { display: none; }
.onb-step.active { display: block; }
.onb-icon { font-size: var(--fs-xl); text-align: center; margin-bottom: var(--sp-3); line-height: 1; }
.onb-title { font-size: var(--fs-md); font-weight: 700; color: var(--t); text-align: center; font-family: var(--font-mono); letter-spacing: -0.3px; margin-bottom: 6px; }
.onb-sub { font-size: var(--fs-sm); color: var(--m); text-align: center; line-height: 1.65; margin-bottom: var(--sp-5); }
.onb-features { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-5); }
.onb-feat { display: flex; align-items: center; gap: var(--sp-2); background: var(--bg2); border: var(--line); border-radius: 8px; padding: var(--sp-2) var(--sp-3); }
.onb-feat-icon { font-size: var(--fs-base); flex-shrink: 0; }
.onb-feat-text { font-size: var(--fs-xs); color: var(--m); line-height: 1.4; }
.onb-feat-text strong { color: var(--t); display: block; font-size: var(--fs-sm); margin-bottom: 1px; }
.onb-input-wrap { margin-bottom: var(--sp-4); }
.onb-label { font-size: var(--fs-xs); color: var(--m2); letter-spacing: 1.5px; font-family: var(--font-mono); margin-bottom: 5px; display: block; }
.onb-input { width: 100%; height: 40px; background: var(--bg-input); border: 1px solid var(--bd); border-radius: 8px; color: var(--t); font-size: var(--fs-base); padding: 0 var(--sp-3); font-family: var(--font-mono); outline: 0; transition: border-color 0.15s; }
.onb-input:focus { border-color: var(--bd3); }
.onb-input::placeholder { color: rgba(255,255,255,0.2); }
.onb-presets { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 6px; }
.onb-preset { padding: 3px var(--sp-2); border-radius: 4px; border: var(--line); background: transparent; color: var(--m); font-size: var(--fs-xs); font-family: var(--font-mono); cursor: pointer; transition: 0.12s; }
.onb-preset:hover { color: var(--a); border-color: var(--a3); background: var(--a2); }
.onb-preset.active { color: var(--a); border-color: var(--a3); background: var(--a2); }
.onb-hotkeys { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: var(--sp-5); }
.onb-hk { display: flex; align-items: center; gap: var(--sp-2); background: var(--bg2); border-radius: 7px; padding: var(--sp-2) var(--sp-2); }
.onb-hk kbd { background: var(--bg3); border: 1px solid var(--bd2); border-radius: 4px; padding: 2px 6px; font-size: var(--fs-xs); font-family: var(--font-mono); color: var(--t); min-width: 22px; text-align: center; flex-shrink: 0; }
.onb-hk-desc { font-size: var(--fs-xs); color: var(--m); }
.onb-btn-row { display: flex; gap: var(--sp-2); }
.onb-btn { flex: 1; height: 42px; border-radius: 9px; border: none; font-size: var(--fs-sm); font-weight: 700; letter-spacing: 0.5px; font-family: var(--font-mono); cursor: pointer; transition: 0.15s; }
.onb-btn.primary { background: var(--a); color: #fff; }
.onb-btn.primary:hover { opacity: 0.88; }
.onb-btn.secondary { background: transparent; color: var(--m); border: var(--line); }
.onb-btn.secondary:hover { color: var(--t); }
.onb-skip { display: block; text-align: center; margin-top: var(--sp-2); font-size: var(--fs-xs); color: var(--m2); cursor: pointer; letter-spacing: 0.5px; font-family: var(--font-mono); }
.onb-skip:hover { color: var(--m); }

/* ══════════════════════════════════════════════════
   ZERO / EMPTY STATE
   ══════════════════════════════════════════════════ */
.zero-state { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 60px var(--sp-5); text-align: center; }
.zero-icon { width: 64px; height: 64px; border-radius: 50%; background: var(--a2); border: 1px solid var(--a3); display: flex; align-items: center; justify-content: center; margin-bottom: var(--sp-5); }
/* Stage 2: zero-title clean */
.zero-title { font-family: var(--font-body); font-size: var(--fs-lg); font-weight: 600; letter-spacing: -0.3px; color: var(--t); margin-bottom: var(--sp-2); }
.zero-sub { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 0.5px; line-height: 1.7; max-width: 280px; margin-bottom: var(--sp-6); }
.zero-btn { display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2) var(--sp-6); background: var(--a); color: #fff; border: none; border-radius: 8px; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1px; text-transform: uppercase; cursor: pointer; transition: opacity 0.15s; }
.zero-btn:hover { opacity: 0.85; }
.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px var(--sp-5); text-align: center; min-height: 280px; }
.es-icon { font-size: var(--fs-xl); margin-bottom: var(--sp-3); opacity: 0.6; }
.es-title { font-size: var(--fs-base); font-weight: 700; color: var(--t); font-family: var(--font-mono); margin-bottom: 6px; letter-spacing: 0.5px; }
.es-sub { font-size: var(--fs-xs); color: var(--m); line-height: 1.7; margin-bottom: var(--sp-4); max-width: 260px; }
.es-cta { height: 36px; padding: 0 var(--sp-5); border-radius: 8px; border: none; background: var(--a); color: #fff; font-size: var(--fs-xs); font-weight: 700; font-family: var(--font-mono); cursor: pointer; transition: opacity 0.15s; }
.es-cta:hover { opacity: 0.85; }
.es-hint { font-size: var(--fs-xs); color: var(--m2); margin-top: var(--sp-2); font-family: var(--font-mono); letter-spacing: 0.5px; }

/* ══════════════════════════════════════════════════
   GLOBAL INPUTS (not inside .field)
   ══════════════════════════════════════════════════ */
input, select, textarea {
  background: var(--bg-input);
  border: 1px solid var(--bd);
  color: var(--t);
}
input:focus, select:focus, textarea:focus {
  border-color: var(--a);
  background: rgba(255,255,255,0.04);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.06);
  outline: 0;
}
input::placeholder, textarea::placeholder { color: var(--m2); }
.field-label, .form-label, .input-label, label { color: var(--m); }
select option { background: var(--bg-card); color: var(--t); }
.dir-btn { background: var(--bg3); border: var(--line); color: var(--m); }
.dir-btn:hover { border-color: var(--bd2); color: var(--t); }
.dir-btn.active-long  { background: var(--gd); border-color: rgba(52,211,153,0.4); color: var(--g); }
.dir-btn.active-short { background: var(--rd); border-color: rgba(248,113,113,0.4); color: var(--r); }

/* FOCUS RINGS — neutral white for accessibility */
button:focus-visible, a:focus-visible, [tabindex]:focus-visible,
[role=button]:focus-visible, .sb-item:focus-visible, .tnav:focus-visible,
.delbtn:focus-visible, .editbtn:focus-visible, .res-btn:focus-visible,
.qnote-type-btn:focus-visible, .dir-btn:focus-visible {
  outline: 2px solid rgba(255,255,255,0.5);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(255,255,255,0.08);
}

/* PREVIEW LOCK */
.preview-lock-overlay { position: absolute; inset: 0; z-index: 20; background: rgba(5,7,10,0.75); backdrop-filter: blur(7px); border-radius: inherit; display: flex; align-items: center; justify-content: center; border: 1px solid var(--a3); }
.plo-inner { display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); padding: var(--sp-6); text-align: center; }
.plo-lock { font-size: var(--fs-xl); }
.plo-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--m); letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 2px; }
.plo-btn { display: inline-flex; align-items: center; padding: var(--sp-2) var(--sp-5); background: var(--a); border: none; border-radius: 8px; color: #fff; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 1.5px; text-decoration: none; cursor: pointer; transition: opacity 0.15s; }
.plo-btn:hover { opacity: 0.88; }

/* SCROLLBAR */
::-webkit-scrollbar { width: 3px; height: 3px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.2); }
::selection { background: rgba(255,122,138,0.25); color: #fff; }

/* ══════════════════════════════════════════════════
   RESPONSIVE — DESKTOP
   ══════════════════════════════════════════════════ */
@media (min-width: 861px) {
  html, body {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--t);
    font-family: var(--font-body);
    overflow-x: hidden;
  }
  .mob-bar, .mob-bottom-nav, .sb-overlay, .sidebar, .jnl-topbar, .ticker-bar { display: none !important; }
  .apple-navbar { display: block; }
  .topnav { display: none; }
  .main {
    margin-left: auto !important;
    width: 100% !important;
    max-width: 1500px !important;
    min-width: 0 !important;
    padding: calc(var(--apple-nav-h) + 26px) 28px 56px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }
  .page, .page.active, .topnav, .stats-row, .dash-grid,
  .digest-grid, .progress-kpis, .setup-grid, .fg2, .fg3, .fg4 {
    max-width: 100% !important;
  }
}

@media (min-width: 1400px) {
  .main { padding: calc(var(--apple-nav-h) + 34px) 44px 64px !important; }
  .stats-row, .fg3, .fg4 { gap: var(--sp-3); }
}

/* ══════════════════════════════════════════════════
   RESPONSIVE — MOBILE
   ══════════════════════════════════════════════════ */
@media (max-width: 860px) {
  html, body { overflow-x: hidden; }
  .apple-navbar, .jnl-topbar { display: none !important; }
  .mob-bar { display: flex !important; }
  .mob-bottom-nav { display: flex !important; }
  .ticker-bar { display: none !important; }
  .sidebar {
    position: fixed !important;
    top: 0; left: 0; bottom: 0;
    z-index: 300;
    width: 260px;
    background: var(--sidebar-bg) !important;
    transform: translateX(-100%);
    transition: transform 0.25s cubic-bezier(0.4,0,0.2,1);
    display: flex !important;
    flex-direction: column;
  }
  .sidebar.open { transform: translateX(0); }
  .sb-overlay.open { display: block; }
  .main {
    margin-left: 0 !important;
    padding: var(--sp-3) var(--sp-3) 100px !important;
    min-height: 100vh;
    overflow-x: hidden;
  }
  .stats-row {
  align-items: stretch; grid-template-columns: 1fr 1fr !important; gap: 6px !important; margin-bottom: var(--sp-3) !important; }
  .stat-cell:nth-child(3) { grid-column: 1/-1; }  /* P&L full width on mobile */
  .stat-cell:nth-child(5) { grid-column: 1/-1; }
  .stat-cell {
  box-shadow: var(--shadow-card); padding: var(--sp-2) var(--sp-3) !important; }
  .stat-value { font-size: var(--fs-md) !important; }
  .stat-label { font-size: var(--fs-xs) !important; }
  .level-bar { padding: var(--sp-3) !important; margin-bottom: var(--sp-3) !important; }
  .lb-row { flex-direction: column !important; align-items: flex-start !important; }
  .topnav {
    position: sticky !important; top: 52px !important; z-index: 80 !important;
    width: calc(100% + 24px) !important; margin: 0 -12px var(--sp-3) !important;
    display: flex !important; overflow-x: auto !important; flex-wrap: nowrap !important;
    background: var(--topbar-bg) !important; backdrop-filter: blur(16px) !important;
    padding: 6px var(--sp-3) !important; border-radius: 0 !important;
    border-bottom: 1px solid var(--bd) !important; scrollbar-width: none !important;
  }
  .topnav::-webkit-scrollbar { display: none; }
  .tnav { padding: var(--sp-2) var(--sp-3) !important; font-size: var(--fs-xs) !important; white-space: nowrap !important; flex-shrink: 0 !important; }
  .fg2, .fg3, .fg4 { grid-template-columns: 1fr 1fr !important; gap: var(--sp-2) !important; }
  .fcard { padding: var(--sp-3) !important; margin-bottom: var(--sp-2) !important; }
  input, select, textarea, input[type=number] { font-size: var(--fs-base) !important; }
  .dtoggle { gap: 6px !important; }
  .dbtn { padding: var(--sp-2) !important; font-size: var(--fs-xs) !important; min-height: 44px !important; }
  .res-btns { gap: 5px !important; }
  .res-btn { padding: var(--sp-2) 6px !important; font-size: var(--fs-xs) !important; min-height: 44px !important; }
  .btn-add { padding: 14px !important; min-height: 52px !important; }
  .dash-grid, .digest-grid, .em-grid, .month-grid { grid-template-columns: 1fr !important; }
  .dash-card { padding: var(--sp-3) !important; }
  .tcard {
  box-shadow: 0 8px 24px rgba(0,0,0,0.2); padding: var(--sp-3) !important; }
  .tpair { font-size: var(--fs-base) !important; }
  .list-head { flex-wrap: wrap !important; gap: var(--sp-2) !important; }
  .filters { flex-wrap: wrap !important; }
  .progress-kpis, .setup-grid { grid-template-columns: 1fr 1fr !important; }
  .pairs-grid { grid-template-columns: 1fr 1fr !important; }
  .pm-body { grid-template-columns: 1fr !important; }
  .pm-limits-grid { grid-template-columns: 1fr 1fr !important; }
  .pm-moods { grid-template-columns: repeat(4, 1fr) !important; }
  .chat-layout { grid-template-columns: 1fr !important; height: calc(100dvh - 160px) !important; }
  .chat-sidebar { display: none !important; }
  .edit-box { padding: var(--sp-4) !important; }
  .edit-row { grid-template-columns: 1fr !important; }
  .ds-ring-wrap { flex-direction: column !important; align-items: center !important; gap: var(--sp-4) !important; }
  .ds-breakdown { grid-template-columns: 1fr 1fr !important; }
  .hm-card { overflow-x: auto !important; }
  .hm-weeks { min-width: max-content !important; }
  .psych-grid { grid-template-columns: 1fr 1fr !important; }
}

@media (max-width: 480px) {
  .main { padding: var(--sp-2) var(--sp-2) 100px !important; }
  .stats-row {
  align-items: stretch; gap: 5px !important; }
  .stat-value { font-size: var(--fs-base) !important; }
  .fg3, .fg4 { grid-template-columns: 1fr !important; }
  .tnav { font-size: var(--fs-xs) !important; padding: 7px var(--sp-2) !important; }
  .setup-grid { grid-template-columns: 1fr !important; }
  .pm-limits-grid { grid-template-columns: 1fr !important; }
  .pm-moods { grid-template-columns: repeat(2, 1fr) !important; }
  .pairs-grid { grid-template-columns: 1fr 1fr !important; }
  .lb-right { flex-direction: column !important; align-items: flex-start !important; }
  .edit-box { padding: var(--sp-3) !important; }
}

@media (max-width: 380px) {
  .main { padding: 6px 6px 100px !important; }
  .stat-cell {
  box-shadow: var(--shadow-card); padding: var(--sp-2) var(--sp-2) !important; }
  .stat-value { font-size: var(--fs-sm) !important; }
  .fcard { padding: var(--sp-2) !important; }
  .dbtn { padding: var(--sp-2) !important; font-size: var(--fs-xs) !important; }
  .res-btn { padding: var(--sp-2) var(--sp-1) !important; font-size: var(--fs-xs) !important; }
}

/* ══════════════════════════════════════════════════
   REDUCED MOTION
   ══════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, ::before, ::after {
    animation-duration: 0s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0s !important;
  }
  .bg-o { display: none !important; }
}

/* ══════════════════════════════════════════════════
   EXPORT / PRINT TABLE (for export pages)
   ══════════════════════════════════════════════════ */
.stat-val.pos { color: var(--g); }
.stat-val.neg { color: var(--r); }
.tr-pnl-pos { color: var(--g); }
.tr-pnl-neg { color: var(--r); }
.pnl-pos { color: var(--g); }
.pnl-neg { color: var(--r); }

/* Trade rows (table view) */
.trade-row { transition: 0.15s; cursor: pointer; }
.trade-row:hover { background: var(--bg-card2); }
.tr-pair { color: var(--t); font-weight: 500; }
.tr-date, .tr-setup, .trade-meta { color: var(--m); }

/* ══════════════════════════════════════════════════
   LAYOUT HOTFIX (preserve already-fixed structure)
   ══════════════════════════════════════════════════ */
html, body {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}
body { overflow-x: hidden; }


/* ══════════════════════════════════════════════════
   FINAL POLISH PASS — clutter reduction / hierarchy
   ══════════════════════════════════════════════════ */
:root {
  --radius-xl: 16px;
}
.bg-o-1, .bg-o-2, .bg-o-3 { opacity: 0.28; }
.sbw-dot-live, .chat-status-dot { animation-duration: 2.4s; }
.ticker-track { animation-duration: 150s; }
.stat-cell, .dash-card, .equity-card, .hm-card, .digest-header, .mc-card, .fcard, .settings-card, .coach-card {
  box-shadow: none;
}
.fcard, .dash-card, .equity-card, .hm-card, .digest-header, .mc-card, .settings-card, .coach-card, .pm-header-card, .pm-section-card, .pm-limits-card, .pm-moods-card {
  border-radius: var(--radius-xl);
}
.sb-section, .dash-title, .dg-label, .mc-title, .hm-title, .pm-section-title, .pkpi-label, .stat-label, .field label, .em-label, .list-title, .lb-sub, .dg-label, .di-label {
  letter-spacing: 1.2px;
}
.sb-item, .tnav, .jtb-nav, .mob-nav-label, .fbtn, .setup-btn, .res-btn, .dbtn, .gl-tab, .sb-market-toggle-label, .sb-section, .dash-title, .pm-section-title, .pkpi-label, .dg-label, .mc-title {
  text-transform: none;
}
.sb-item, .tnav, .jtb-nav, .mob-nav-label, .fbtn, .setup-btn, .res-btn, .dbtn, .gl-tab {
  letter-spacing: 0.3px;
}
.field label, .em-label, .stat-label, .pkpi-label, .dg-label, .mc-title, .hm-title, .dash-title, .pm-section-title, .list-title {
  color: rgba(255,255,255,0.52);
}
.stat-value, .pkpi-val, .dg-val, .speedo-val, .fng-num, .ds-level, .tpair {
  letter-spacing: -0.02em;
}
.field-hint { opacity: 0.75; }
.field-hint:hover { opacity: 1; }
.sbw, .dg-card, .pkpi, .pair-card, .psych-card, .setup-card, .coach-rec, .pm-side-card, .tilt-banner, .smart-notif-bar, .mistake-card {
  background: rgba(255,255,255,0.02);
}
.sbw-title, .sb-section-label {
  color: rgba(255,255,255,0.4);
}
.sbw-metric-label, .sbw-lp-sym, .trend-rank, .trend-pos, .gl-sym, .gl-pct {
  letter-spacing: 0.3px;
}
.chat-sc-text, .di-text, .coach-rec-text, .dh-sub, .notif-msg, .qnote-item-text, .pm-item-text, .agh-text {
  color: rgba(255,255,255,0.6);
}
.notif, .goal-popup, .balance-popup, .qnote-popup, .ai-box, .edit-box {
  border-radius: var(--radius-xl);
}
.btn-add, .pm-save-btn, .settings-btn-primary, .edit-save {
  min-height: 48px;
  border-radius: 12px;
}
.btn-ai, .coach-run-btn, .sim-run-btn, .settings-btn-secondary, .settings-btn-danger, .pm-start-btn {
  min-height: 44px;
  border-radius: 12px;
}
#page-journal .fcard { margin-bottom: 20px; }
#page-journal #trades-list .tcard {
  box-shadow: 0 8px 24px rgba(0,0,0,0.2); margin-bottom: 10px; }
@media (min-width: 861px) {
  .main { max-width: 1600px !important; }
  .stats-row {
  align-items: stretch; margin-top: 18px; margin-bottom: 24px; }
  .fcard { padding: 24px 28px; }
  .dash-card, .equity-card, .hm-card, .digest-header, .mc-card, .coach-card, .settings-card { padding: 22px; }
}
@media (max-width: 860px) {
  .bg-o-1, .bg-o-2, .bg-o-3 { opacity: 0.18; }
  .fcard, .dash-card, .equity-card, .hm-card, .digest-header, .mc-card, .coach-card, .settings-card { border-radius: 14px; }
}


/* ══════════════════════════════════════════════════
   HTML CLEANUP PASS
   ══════════════════════════════════════════════════ */
.mob-logo-link { display:flex; align-items:center; gap:7px; text-decoration:none; }
.mob-pill-val-profit { color: var(--g); }
.mob-pill-val-accent { color: var(--a); }
.sb-logo-link { text-decoration:none; cursor:pointer; }
.sb-item-external { display:flex; justify-content:space-between; align-items:center; }
.external-arrow { font-size:var(--fs-xs); opacity:0.4; margin-left:auto; padding-left:6px; }
.is-hidden { display:none !important; }
.fng-num-loss { color:#e74c3c; }
.widget-loading-text { font-family:var(--font-body); font-size:var(--fs-xs); color:rgba(255,255,255,0.15); text-align:center; padding:4px; }
.flex-fill { flex:1; }
.lang-btn { font-size:var(--fs-xs); min-width:32px; text-align:center; }
.mb-12 { margin-bottom:12px; }
.mb-10 { margin-bottom:10px; }
.mb-6 { margin-bottom:6px; }
.mb-4 { margin-bottom:4px; }
.trade-metrics-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-bottom:10px; }
.trade-metric-card { display:flex; align-items:center; justify-content:space-between; gap:4px; padding:6px 10px; border-radius:7px; background:rgba(255,255,255,0.02); border:1px solid rgba(255,255,255,0.06); }
.trade-metric-label { font-family:var(--font-mono); font-size:var(--fs-xs); color:var(--m); letter-spacing:1px; }
.trade-metric-value { font-family:var(--font-mono); font-size:var(--fs-base); }
.value-loss { color:var(--r); }
.value-profit { color:var(--g); }
.value-accent { color:var(--a); }
.section-microtitle { font-family:var(--font-mono); font-size:var(--fs-xs); color:var(--m); letter-spacing:2px; text-transform:uppercase; margin-bottom:7px; }
.icon-inline { vertical-align:middle; margin-right:5px; }
.inline-actions { display:flex; align-items:center; gap:8px; }
.ghost-danger-btn { padding:4px 10px; border-radius:14px; border:1px solid rgba(255,77,77,0.25); background:transparent; color:rgba(255,77,77,0.55); font-family:var(--font-mono); font-size:var(--fs-xs); letter-spacing:1px; cursor:pointer; transition:all 0.15s; white-space:nowrap; }
.w-50 { width:50%; }
.w-80 { width:80%; }
.inline-baseline-gap { display:flex; align-items:baseline; gap:5px; }
.level-roi-value { font-family:var(--font-display); font-size:var(--fs-base); color:var(--a); }
.micro-meta { font-family:var(--font-mono); font-size:var(--fs-xs); color:var(--m); letter-spacing:1px; }
.level-fill-accent { width:0%; background:linear-gradient(90deg,var(--a),#ff9a5c); }
.lb-reward-inline { border-top:1px solid rgba(255,255,255,0.05); padding-top:8px; margin-top:2px; }
.muted-mini { font-size:var(--fs-xs); opacity:0.5; }
.preset-color-btc { color:#f7931a; }
.preset-color-eth { color:#627eea; }
.preset-color-sol { color:#9945ff; }
.preset-color-bnb { color:#f3ba2f; }
.preset-color-xrp { color:#00aae4; }
.preset-color-doge { color:#c2a633; }

/* stronger visual cleanup */
.sbw {
  background: rgba(255,255,255,0.012);
  border-color: rgba(255,255,255,0.055);
}
.sbw-title,
.sb-section,
.sb-section-label,
.list-title,
.dash-title,
.hm-title,
.mc-title,
.pm-section-title,
.pm-side-title,
.dg-label {
  letter-spacing: 1.3px;
}
.stat-cell,
.dash-card,
.fcard,
.equity-card,
.hm-card,
.coach-card,
.digest-header,
.settings-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.mc-card {
  border-color: rgba(255,255,255,0.06);
}
.stat-cell,
.dash-card,
.fcard,
.equity-card,
.hm-card,
.coach-card,
.digest-header,
.settings-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.mc-card,
.tcard {
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
  box-shadow: none;
}
.field-hint,
.sbw-dot-live,
.chat-status-dot {
  animation: none !important;
}
.fcard,
.dash-card,
.tcard,
.hm-card,
.equity-card,
.coach-card,
.settings-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.mc-card {
  border-radius: 16px;
}
.btn-add,
.pm-save-btn,
.settings-btn-primary,
.edit-save,
.qnote-save {
  border-radius: 12px;
}
.stat-value,
.dg-val,
.pkpi-val,
.setup-wr,
.pm-streak-num,
.speedo-val {
  letter-spacing: -0.03em;
}
@media (max-width: 860px) {
  .trade-metrics-grid {
    grid-template-columns: 1fr 1fr;
  }
}


/* ═══════════════════════════════════════════════════════
   ORBITUM 2026 — apple glass refinement
   quiet hierarchy · pay-style ambient background · hover nav
   ═══════════════════════════════════════════════════════ */
:root{
  --bg:#0d0d0d;
  --bg2:rgba(255,255,255,0.028);
  --bg3:rgba(255,255,255,0.05);
  --bg-card:rgba(20,20,22,0.72);
  --bg-card2:rgba(28,28,31,0.84);
  --bg-input:rgba(255,255,255,0.055);
  --bd:rgba(255,255,255,0.09);
  --bd2:rgba(255,255,255,0.14);
  --bd3:rgba(255,255,255,0.22);
  --t:rgba(244,240,236,0.92);
  --t2:#ffffff;
  --m:rgba(244,240,236,0.58);
  --m2:rgba(244,240,236,0.34);
  --topbar-bg:rgba(10,10,12,0.70);
  --sidebar-bg:rgba(14,14,16,0.76);
  --shadow-card:0 24px 60px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.03), inset 0 -1px 0 rgba(255,255,255,0.05);
  --orb1:rgba(255,122,138,0.065);
  --orb2:rgba(255,122,138,0.04);
  --orb3:rgba(255,122,138,0.028);
}

html,body{
  background:var(--bg);
}

body::before{
  content:'';
  position:fixed;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E");
  background-size:200px;
  pointer-events:none;
  z-index:0;
  opacity:0.34;
}
body::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(ellipse 58% 58% at 35% 112%, rgba(255,122,138,0.16) 0%, transparent 64%),
    radial-gradient(ellipse 58% 58% at 68% 112%, rgba(255,122,138,0.12) 0%, transparent 66%),
    radial-gradient(ellipse 84% 28% at 50% 103%, rgba(255,143,163,0.08) 0%, transparent 72%);
}

.bg-orbs-wrap{opacity:.92;}
.bg-o-1,.bg-o-2,.bg-o-3{opacity:.72;}

.apple-navbar{
  display:block;
  background:rgba(14,14,18,0.62);
  backdrop-filter:saturate(180%) blur(26px);
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.apple-nav-inner{
  max-width:1320px;
  padding:0 28px;
  gap:28px;
}
.apple-brand-text{
  font-family:var(--font-body);
  font-size:var(--fs-sm);
  font-weight:650;
}
.apple-brand-mark{
  box-shadow:0 0 18px rgba(255,122,138,0.28);
}
.apple-nav-links{gap:8px;}
.apple-nav-link{
  height:34px;
  padding:0 14px;
  border:1px solid transparent;
  background:transparent;
  color:rgba(255,255,255,0.76);
  font-size:var(--fs-sm);
  font-weight:520;
  letter-spacing:-0.015em;
  line-height:1;
}
.apple-nav-link:hover,
.apple-menu.open .apple-nav-link,
.apple-nav-link.active{
  background:rgba(255,255,255,0.05);
  border-color:rgba(255,255,255,0.08);
  color:#fff;
}
.apple-nav-caret{display:none!important;}
.apple-menu-panel{
  top:calc(100% + 10px);
  width:min(760px, calc(100vw - 40px));
  padding:20px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(28,28,34,0.72);
  backdrop-filter:blur(28px) saturate(140%);
  box-shadow:0 30px 80px rgba(0,0,0,0.42), inset 0 1px 0 rgba(255,255,255,0.05);
}
.apple-menu-grid{gap:28px;}
.apple-menu-column-main{
  padding-right:12px;
  border-right:1px solid rgba(255,255,255,0.08);
}
.apple-menu-eyebrow{
  color:rgba(255,255,255,0.42);
  font-size:var(--fs-xs);
  letter-spacing:-0.01em;
  margin-bottom:14px;
}
.apple-menu-item{
  font-family:var(--font-display);
  font-size:var(--fs-lg);
  line-height:1.08;
  font-weight:600;
  letter-spacing:-0.03em;
  padding:9px 0;
  color:rgba(255,255,255,0.94);
}
.apple-menu-item:hover,
.apple-menu-item.active{color:var(--brand);}
.apple-menu-copy{
  color:rgba(255,255,255,0.62);
  font-size:var(--fs-sm);
  line-height:1.6;
  max-width:300px;
}
.apple-current-page{
  min-width:96px;
  font-size:var(--fs-xs);
  font-weight:500;
  color:rgba(255,255,255,0.50);
}
.apple-tool-btn{
  height:32px;
  min-width:32px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  backdrop-filter:blur(12px);
}

body.journal-apple-shell .main{
  max-width:1400px;
  padding:calc(var(--apple-nav-h) + 34px) 28px 72px;
}

.sidebar{
  background:rgba(13,13,16,0.82);
  backdrop-filter:blur(24px);
  border-right:1px solid rgba(255,255,255,0.08);
}
.sb-item{color:rgba(255,255,255,0.62);}
.sb-item:hover{background:rgba(255,255,255,0.05);color:#fff;}
.sb-item.active{
  background:rgba(255,122,138,0.12);
  border-color:rgba(255,122,138,0.18);
  border-left-color:var(--a)!important;
  color:var(--a);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03);
}
.sb-section,
.sb-section-label,
.sbw-title,
.sbw-metric-label,
.mob-pill-label,
.lb-sub,
.lb-lbl,
.stat-label,
.field label,
.pm-limit-label,
.em-label,
.section-microtitle{
  color:rgba(244,240,236,0.48)!important;
  text-transform:none!important;
  letter-spacing:0!important;
}

.stats-row{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:0;
  margin-bottom:20px;
}
.stat-cell,
.fcard,
.dash-card,
.level-bar,
.tcard,
.coach-card,
.settings-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.pm-status-bar,
.pm-side-card,
.lb-card,
.score-card,
.setup-card,
.psych-card,
.pair-card,
.settings-card-head,
.settings-card-actions{
  background:linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.024));
  border:1px solid rgba(255,255,255,0.10)!important;
  box-shadow:var(--shadow-card)!important;
  backdrop-filter:blur(18px);
}
.stat-cell,
.fcard,
.dash-card,
.level-bar,
.tcard,
.coach-card,
.settings-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.pm-status-bar,
.pm-side-card,
.lb-card,
.score-card,
.setup-card,
.psych-card,
.pair-card{
  position:relative;
  overflow:hidden;
}
.stat-cell::after,
.fcard::after,
.dash-card::after,
.level-bar::after,
.tcard::after,
.coach-card::after,
.settings-card::after,
.pm-section-card::after,
.pm-limits-card::after,
.pm-moods-card::after,
.pm-status-bar::after,
.pm-side-card::after,
.lb-card::after,
.score-card::after,
.setup-card::after,
.psych-card::after,
.pair-card::after{
  content:'';
  position:absolute;
  left:14px;
  right:14px;
  bottom:0;
  height:44px;
  background:linear-gradient(180deg, transparent, rgba(255,255,255,0.06));
  opacity:.44;
  pointer-events:none;
}
.stat-cell:hover,
.fcard:hover,
.dash-card:hover,
.tcard:hover,
.coach-card:hover,
.settings-card:hover,
.pm-section-card:hover{
  border-color:rgba(255,255,255,0.14)!important;
  background:linear-gradient(180deg, rgba(255,255,255,0.052), rgba(255,255,255,0.03));
}

.fcard-title,
.list-title,
.dash-title,
.mc-title,
.coach-name,
.coach-sub,
.pm-headline,
.pm-headline-sub,
.pm-section-title,
.pm-side-title,
.settings-card-title,
.settings-card-sub,
.stat-value,
.lb-name,
.lb-reward-text{
  color:var(--t2)!important;
  text-shadow:none!important;
}
.pm-headline{letter-spacing:-0.03em;font-size:var(--fs-xl)!important;}
.pm-headline-sub{color:var(--m)!important;}

.stat-label{font-size:var(--fs-xs)!important;font-weight:500;}
.stat-value{font-size:28px!important;font-weight:630;letter-spacing:-0.03em;}
.stat-cell:nth-child(3) .stat-value{font-size:var(--fs-xl)!important;}
.sv-g,.pnl-pos,.tr-pnl-pos,.value-profit,.pm-pos{color:var(--g)!important;}
.sv-r,.pnl-neg,.tr-pnl-neg,.value-loss,.pm-neg{color:var(--r)!important;}
.sv-a,.value-accent,.mob-pill-val-accent,.jtb-goal-val{color:var(--a)!important;}
.mob-pill-val-profit,.jtb-balance-val{color:var(--g)!important;}

.btn-add,
.btn-ai,
.pm-save-btn,
.pm-start-btn,
.tilt-btn,
.coach-run-btn,
.settings-btn-primary,
.zero-btn,
.ghost-danger-btn,
.btn-plan,
.btn-submit,
.onb-btn.primary,
.onb-analyze-btn,
.qnote-save,
.edit-save,
.ai-check-btn{
  border-radius:999px!important;
}
.btn-add,
.btn-ai,
.pm-save-btn,
.pm-start-btn,
.coach-run-btn,
.settings-btn-primary,
.zero-btn,
.onb-btn.primary,
.onb-analyze-btn,
.qnote-save,
.edit-save,
.ai-check-btn{
  background:linear-gradient(135deg, rgba(255,122,138,0.96), rgba(255,92,74,0.9))!important;
  color:#fff!important;
  border:1px solid rgba(255,122,138,0.92)!important;
  box-shadow:0 14px 30px rgba(255,122,138,0.22)!important;
}
.btn-ai{background:linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.04))!important;color:var(--t)!important;border:1px solid rgba(255,255,255,0.12)!important;box-shadow:none!important;}
.btn-ai:hover{background:rgba(255,255,255,0.08)!important;}
.ghost-danger-btn{
  background:rgba(255,255,255,0.04)!important;
  border:1px solid rgba(255,255,255,0.1)!important;
  color:var(--m)!important;
}
.ghost-danger-btn:hover{color:#fff!important;border-color:rgba(255,255,255,0.18)!important;}

.res-btn,
.setup-btn,
.psych-btn,
.tf-btn,
.sym-btn,
.qnote-type-btn,
.pm-mood-btn,
.dir-btn,
.dbtn,
.fbtn,
.gl-tab,
.ck-btn{
  background:rgba(255,255,255,0.045)!important;
  border:1px solid rgba(255,255,255,0.10)!important;
  color:rgba(255,255,255,0.68)!important;
  box-shadow:none!important;
}
.dbtn.active,
.dir-btn.active,
.fbtn.active,
.setup-btn.active,
.psych-btn.active,
.tf-btn.active,
.sym-btn.active,
.qnote-type-btn.active,
.pm-mood-btn.active,
.ck-btn.yes,
.ck-btn.no,
.gl-tab.active,
.apple-menu-item.active{
  background:rgba(255,122,138,0.12)!important;
  border-color:rgba(255,122,138,0.24)!important;
  color:var(--a)!important;
}
.res-btn.active-win{
  background:rgba(52,211,153,0.12)!important;
  border-color:rgba(52,211,153,0.26)!important;
  color:var(--g)!important;
}
.res-btn.active-loss{
  background:rgba(248,113,113,0.12)!important;
  border-color:rgba(248,113,113,0.26)!important;
  color:var(--r)!important;
}
.res-btn.active-be{
  background:rgba(255,122,138,0.12)!important;
  border-color:rgba(255,122,138,0.24)!important;
  color:var(--a)!important;
}

.balance-popup,
.goal-popup,
.ai-modal,
.edit-modal,
.qnote-panel,
#ai-modal .ai-box,
#edit-modal .edit-box,
#qnote-panel,
#balance-popup,
#goal-popup,
.settings-inline-panel,
.modal{
  background:rgba(26,26,30,0.78)!important;
  border:1px solid rgba(255,255,255,0.12)!important;
  box-shadow:0 28px 80px rgba(0,0,0,0.42)!important;
  backdrop-filter:blur(28px) saturate(140%);
}
.ai-modal::before,
.edit-modal::before{background:rgba(0,0,0,0.48)!important;}

.mob-bar{
  background:rgba(12,12,14,0.76)!important;
  backdrop-filter:blur(22px);
  border-bottom:1px solid rgba(255,255,255,0.08)!important;
}
.mob-stat-pill,
.jtb-balance,
.jtb-goal,
.apple-tool-btn,
.jtb-profile-btn,
.mob-profile-btn{
  background:rgba(255,255,255,0.05)!important;
  border:1px solid rgba(255,255,255,0.10)!important;
  backdrop-filter:blur(14px);
}

@media (max-width: 1024px){
  .apple-navbar{display:none;}
  body.journal-apple-shell .main{padding:24px 16px 110px;}
  .stats-row{grid-template-columns:1fr;gap:12px;}
}


/* ══════════════════════════════════════════════════
   2026 SYSTEM PASS — typography / card unity / calmer journal / mobile
   ══════════════════════════════════════════════════ */
:root{
  /* TYPOGRAPHY SCALE — 6 sizes only */
  --fs-xs:   11px;
  --fs-sm:   13px;
  --fs-base: 15px;
  --fs-md:   18px;
  --fs-lg:   24px;
  --fs-xl:   32px;
  --radius:14px;
  --radius-lg:18px;
  --radius-xl:18px;
}
html,body{
  font-size:var(--fs-base);
  line-height:1.55;
}
body::before{opacity:.22;}
body::after{opacity:.72;}
.bg-orbs-wrap,.bg-o-1,.bg-o-2,.bg-o-3{opacity:.56;}

.stat-label,
.field label,
.em-label,
.pm-limit-label,
.pm-mood-label,
.pm-item-text,
.settings-card-sub,
.trade-metric-label,
.sbw-metric-label,
.lb-sub,
.lb-lbl,
.list-title,
.hm-title,
.mc-title,
.dash-title,
.pm-section-title,
.pm-side-title,
.section-microtitle{
  font-size:var(--fs-xs) !important;
  line-height:1.35;
  font-weight:500;
  color:rgba(244,240,236,0.54) !important;
  letter-spacing:0 !important;
}

.fcard-title,
.settings-card-title,
.coach-name,
.pm-headline,
.stat-value,
.dg-val,
.pkpi-val,
.speedo-val,
.ds-level{
  line-height:1.08;
}

.apple-nav-link,
.sb-item,
.mob-nav-label,
.fbtn,
.setup-btn,
.res-btn,
.dbtn,
.gl-tab,
.pm-save-btn,
.btn-add,
.btn-ai,
.coach-run-btn,
.settings-btn-primary,
.settings-btn-secondary,
.settings-btn-danger,
.edit-save,
.qnote-save,
.ck-btn{
  font-size:var(--fs-sm);
  line-height:1.15;
  letter-spacing:-0.01em;
}

.stat-cell,
.fcard,
.dash-card,
.tcard,
.coach-card,
.settings-card,
.hm-card,
.equity-card,
.digest-header,
.mc-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.pm-side-card,
.level-bar,
.pkpi,
.setup-card,
.psych-card,
.pair-card,
.sbw{
  border-radius:18px !important;
  border:1px solid rgba(255,255,255,0.08) !important;
  backdrop-filter:blur(16px);
}

.stat-cell::after,
.fcard::after,
.dash-card::after,
.tcard::after,
.coach-card::after,
.settings-card::after,
.pm-section-card::after,
.pm-limits-card::after,
.pm-moods-card::after,
.pm-side-card::after,
.level-bar::after,
.setup-card::after,
.psych-card::after,
.pair-card::after{
  opacity:.18;
  height:32px;
}

.stat-cell:hover,
.fcard:hover,
.dash-card:hover,
.tcard:hover,
.coach-card:hover,
.settings-card:hover,
.pm-section-card:hover,
.pm-limits-card:hover,
.pm-moods-card:hover,
.pm-side-card:hover{
  transform:translateY(-1px);
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
  border-color:rgba(255,255,255,0.12) !important;
}

.tcard.win{border-left:2px solid var(--g) !important;}
.tcard.loss{border-left:2px solid var(--r) !important;}
.tcard.be{border-left:2px solid rgba(255,255,255,0.16) !important;}

.apple-menu-item.active,
.apple-menu-item:hover,
.btn-add,
.pm-save-btn,
.settings-btn-primary,
.edit-save,
.qnote-save,
.ai-check-btn{color:#fff !important;}

.btn-ai,
.settings-btn-secondary,
.settings-btn-danger,
.ghost-danger-btn{
  box-shadow:none !important;
}

.trade-metric-card,
.sbw,
.pkpi,
.notify-row,
.pm-item,
.em-box,
.setup-btn,
.res-btn,
.fbtn,
.gl-tab,
.ck-btn{
  border-color:rgba(255,255,255,0.07) !important;
  background:rgba(255,255,255,0.03) !important;
}

.field-hint{
  width:16px;
  height:16px;
  font-size:var(--fs-xs);
  line-height:16px;
  opacity:.72;
}

.mob-bar{
  min-height:58px;
}
.mob-stat-pill,
.mob-profile-btn{
  min-height:38px;
  border-radius:999px !important;
}
.mob-pill-label{
  font-size:var(--fs-xs);
  line-height:1.1;
}
.mob-pill-val{
  font-size:var(--fs-sm);
  line-height:1.1;
}

@media (max-width: 860px){
  body.journal-apple-shell .main{padding:20px 14px 108px !important;}
  .stats-row{gap:10px !important;}
  .stat-cell,
  .fcard,
  .dash-card,
  .tcard,
  .coach-card,
  .settings-card,
  .hm-card,
  .mc-card,
  .pm-section-card,
  .pm-limits-card,
  .pm-moods-card,
  .pm-side-card{border-radius:16px !important;}
  .fcard,
  .dash-card,
  .tcard,
  .coach-card,
  .settings-card,
  .hm-card,
  .mc-card,
  .pm-section-card,
  .pm-limits-card,
  .pm-moods-card,
  .pm-side-card{padding:16px !important;}
  .trade-metrics-grid{grid-template-columns:1fr 1fr; gap:8px;}
  .trade-metric-card{padding:8px 10px;}
  .btn-add,
  .btn-ai,
  .pm-save-btn,
  .coach-run-btn,
  .settings-btn-primary,
  .settings-btn-secondary,
  .settings-btn-danger,
  .edit-save,
  .qnote-save{min-height:44px;}
}

@media (max-width: 480px){
  .mob-bottom-nav{padding-bottom:max(env(safe-area-inset-bottom), 8px);}
  .mob-nav-btn{min-width:72px;}
  .stat-value{font-size:var(--fs-lg) !important;}
  .pm-headline{font-size:var(--fs-lg) !important;}
}

/* ══════════════════════════════════════════════════════════
   ORBITUM v2.0 — Premium SaaS Redesign
   Inspired by: NutriSense, FlowAI, Nexus dashboards
   Warm tones, soft cards, clean hierarchy
   ══════════════════════════════════════════════════════════ */

/* ── NEW DESIGN TOKENS ── */
:root {
  /* Warm palette — away from cold admin feel */
  --brand: #ff7a8a;
  --brand-strong: #ff8fa3;
  --brand-soft: rgba(255,122,138,0.11);
  --brand-border: rgba(255,122,138,0.22);
  --brand-glow: rgba(255,122,138,0.16);
  --a: var(--brand);
  --a2: var(--brand-soft);
  --a3: var(--brand-border);
  
  /* Softer backgrounds — warm undertone */
  --bg: #0B0B0D;
  --bg-card: rgba(255,255,255,0.028);
  --bg-card2: rgba(255,255,255,0.045);
  --bg-input: rgba(255,255,255,0.045);
  
  /* Softer borders */
  --bd: rgba(255,255,255,0.06);
  --bd2: rgba(255,255,255,0.10);
  --bd3: rgba(255,255,255,0.18);
  
  /* Warmer text */
  --t: #F4F0EC;
  --t2: #FFFFFF;
  --m: rgba(244,240,236,0.50);
  --m2: rgba(244,240,236,0.28);
  
  /* Refined semantic */
  --g: #34D399;
  --gd: rgba(52,211,153,0.08);
  --r: #F87171;
  --rd: rgba(248,113,113,0.08);
  --y: #FBBF24;
  --yd: rgba(251,191,36,0.08);
  
  /* Better radius */
  --radius: 16px;
  --radius-lg: 20px;
  
  /* Warm card shadow */
  --shadow-card: 0 1px 3px rgba(0,0,0,0.12), 0 4px 16px rgba(0,0,0,0.08);
  
  /* Premium font stack */
  --font-body: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-display: 'Plus Jakarta Sans', -apple-system, sans-serif;
  
  /* Orb colors — warmer, subtler */
  --orb1: rgba(255,143,163,0.015);
  --orb2: rgba(255,143,163,0.01);
  --orb3: rgba(52,211,153,0.008);
}

/* ── GLOBAL REFINEMENTS ── */
html, body {
  background: var(--bg) !important;
  color: var(--t) !important;
  font-family: var(--font-body) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── NAVBAR — warmer, cleaner ── */
.apple-navbar {
  background: rgba(11,11,13,0.86) !important;
  backdrop-filter: saturate(160%) blur(24px) !important;
  border-bottom-color: rgba(255,255,255,0.05) !important;
}
.apple-brand-mark {
  background: var(--brand) !important;
  box-shadow: 0 0 16px rgba(255,143,163,0.18) !important;
}
.apple-brand-text {
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
}

/* ── STATS ROW — Premium KPI cards ── */
.stats-row {
  align-items: stretch;
  display: grid !important;
  grid-template-columns: 1fr 1fr 1.5fr !important;
  gap: 14px !important;
  margin-bottom: 24px !important;
}
.stat-cell {
  box-shadow: var(--shadow-card);
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 20px !important;
  padding: 22px 24px !important;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(12px) !important;
  transition: all 0.2s ease !important;
}
.stat-cell::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
}
.stat-cell:hover {
  background: rgba(255,255,255,0.045) !important;
  border-color: rgba(255,255,255,0.10) !important;
  transform: translateY(-1px);
}
.stat-label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  color: var(--m) !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
  margin-bottom: 8px !important;
}
.stat-value {
  font-family: var(--font-body) !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
}
body.journal-apple-shell .stat-value {
  font-size: 28px !important;
}
.stat-cell:nth-child(3) .stat-value {
  font-size: var(--fs-xl) !important;
  background: linear-gradient(135deg, var(--brand), #FFC1CC);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sv-g { 
  color: var(--g) !important; 
  -webkit-text-fill-color: var(--g) !important;
}

/* ── FORM CARD — Premium trade entry ── */
.fcard {
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 24px !important;
  padding: 28px 32px !important;
  margin-bottom: 16px !important;
  backdrop-filter: blur(16px) !important;
  position: relative;
  overflow: visible !important;
}
.fcard::before {
  content: '';
  position: absolute;
  top: 0; left: 24px; right: 24px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,143,163,0.14), transparent);
}

.fcard-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
}
.fcard-title {
  font-family: var(--font-body) !important;
  font-size: var(--fs-md) !important;
  font-weight: 700 !important;
  color: var(--t) !important;
  letter-spacing: -0.01em !important;
}
.fcard-step-dots {
  display: flex;
  gap: 6px;
  align-items: center;
}
.fcard-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  transition: all 0.3s;
}
.fcard-dot.active {
  background: var(--brand);
  box-shadow: 0 0 8px rgba(255,143,163,0.22);
}

/* ── FORM SECTIONS — clear visual separation ── */
.form-section {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.form-section:last-of-type {
  border-bottom: none;
  margin-bottom: 16px;
  padding-bottom: 0;
}
.form-section-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--m);
  margin-bottom: 16px;
  letter-spacing: 0;
}
.form-section-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: rgba(255,143,163,0.08);
  border: 1px solid rgba(255,143,163,0.14);
  color: var(--brand);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: 600;
  flex-shrink: 0;
}
.form-section-toggle {
  cursor: pointer;
  justify-content: space-between;
  padding: 4px 0;
  border-radius: 8px;
  transition: color 0.15s;
}
.form-section-toggle:hover {
  color: var(--t);
}
.form-section-arrow {
  font-size: var(--fs-base);
  color: var(--m);
  transition: transform 0.25s ease;
}
.form-section-arrow.rotated {
  transform: rotate(-90deg);
}
.form-section-body {
  overflow: hidden;
  max-height: 2000px;
  transition: max-height 0.35s ease, opacity 0.25s ease;
  opacity: 1;
}
.form-section-body.collapsed {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
}

/* ── ACTION BUTTONS ── */
.form-actions {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 10px;
  margin-top: 8px;
}
.btn-add {
  background: var(--brand) !important;
  border: none !important;
  border-radius: 14px !important;
  padding: 14px 20px !important;
  color: #fff !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-base) !important;
  font-weight: 600 !important;
  cursor: pointer;
  transition: all 0.2s ease !important;
  box-shadow: 0 2px 12px rgba(255,143,163,0.18) !important;
}
.btn-add:hover {
  opacity: 0.92 !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 20px rgba(255,143,163,0.22) !important;
}
.btn-ai {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
  border-radius: 14px !important;
  padding: 14px 20px !important;
  color: var(--t) !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-sm) !important;
  font-weight: 500 !important;
  cursor: pointer;
  transition: all 0.2s ease !important;
  margin-top: 0 !important;
}
.btn-ai:hover {
  background: rgba(255,255,255,0.07) !important;
  border-color: rgba(255,143,163,0.24) !important;
  color: var(--a) !important;
}

/* ── FORM INPUTS — Softer, warmer ── */
.field input, .field select, .field textarea {
  font-family: var(--font-body);
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 12px !important;
  padding: 10px 14px !important;
  color: var(--t) !important;
  font-family: var(--font-mono) !important;
  font-size: var(--fs-sm) !important;
  transition: all 0.2s ease !important;
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: rgba(255,143,163,0.22) !important;
  background: rgba(255,255,255,0.05) !important;
  box-shadow: 0 0 0 3px rgba(255,143,163,0.06) !important;
}
.field input::placeholder, .field textarea::placeholder {
  color: rgba(244,240,236,0.2) !important;
}
.field label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}
.field textarea {
  min-height: 60px !important;
  font-family: var(--font-body) !important;
  line-height: 1.55 !important;
}

/* ── DIRECTION TOGGLE — Cleaner ── */
.dtoggle {
  gap: 4px !important;
}
.dbtn {
  padding: 10px !important;
  border-radius: 10px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-sm) !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
  color: var(--m) !important;
}
.dbtn.long.active {
  background: rgba(52,211,153,0.10) !important;
  border-color: rgba(52,211,153,0.25) !important;
  color: var(--g) !important;
}
.dbtn.short.active {
  background: rgba(248,113,113,0.10) !important;
  border-color: rgba(248,113,113,0.25) !important;
  color: var(--r) !important;
}

/* ── RESULT BUTTONS — Cleaner ── */
.res-btn {
  padding: 10px 8px !important;
  border-radius: 10px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
}
.res-btn.active-win {
  background: rgba(52,211,153,0.10) !important;
  border-color: rgba(52,211,153,0.25) !important;
  color: var(--g) !important;
}
.res-btn.active-loss {
  background: rgba(248,113,113,0.10) !important;
  border-color: rgba(248,113,113,0.25) !important;
  color: var(--r) !important;
}
.res-btn.active-be {
  background: rgba(255,122,138,0.10) !important;
  border-color: rgba(255,122,138,0.20) !important;
  color: var(--brand) !important;
}

/* ── SETUP BUTTONS — More refined ── */
.setup-btns {
  gap: 6px !important;
}
.setup-btn {
  padding: 6px 14px !important;
  border-radius: 10px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  color: var(--m) !important;
  transition: all 0.15s ease !important;
}
.setup-btn:hover {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.12) !important;
  color: var(--t) !important;
}
.setup-btn.active {
  background: rgba(255,122,138,0.10) !important;
  border-color: rgba(255,122,138,0.22) !important;
  color: var(--brand) !important;
}

/* ── TRADE METRICS — Clean chips ── */
.trade-metrics-grid {
  display: grid !important;
  grid-template-columns: repeat(4,1fr) !important;
  gap: 8px !important;
  margin-bottom: 12px !important;
  margin-top: 4px !important;
}
.trade-metric-card {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  padding: 12px 14px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(255,255,255,0.05) !important;
  transition: all 0.15s !important;
}
.trade-metric-card:hover {
  background: rgba(255,255,255,0.04) !important;
}
.trade-metric-label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
}
.trade-metric-value {
  font-family: var(--font-mono) !important;
  font-size: var(--fs-base) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em;
}
.rr-display {
  font-size: var(--fs-base) !important;
  padding: 0 !important;
  color: var(--brand) !important;
}
.value-loss { color: var(--r) !important; }
.value-profit { color: var(--g) !important; }
.value-accent { color: var(--brand) !important; }

/* ── EMOTION SECTION — Softer ── */
.em-section {
  background: rgba(255,255,255,0.02) !important;
  border: 1px solid rgba(255,255,255,0.05) !important;
  border-radius: 16px !important;
  padding: 16px !important;
  margin-bottom: 14px !important;
}
.em-title {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 600 !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}
.em-opt {
  padding: 9px 6px !important;
  border-radius: 10px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  color: var(--m) !important;
}
.em-opt:hover {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.12) !important;
  color: var(--t) !important;
}
.em-opt.active {
  background: rgba(255,122,138,0.10) !important;
  border-color: rgba(255,122,138,0.22) !important;
  color: var(--brand) !important;
}
.em-label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

/* ── LEVERAGE SLIDER — Premium ── */
.lev-display {
  font-family: var(--font-body) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--t) !important;
}
.lev-range {
  background: rgba(255,255,255,0.08) !important;
  border-radius: 3px !important;
  height: 4px !important;
}
.lev-range::-webkit-slider-thumb {
  background: var(--brand) !important;
  border: 2px solid var(--bg) !important;
  width: 18px !important;
  height: 18px !important;
  box-shadow: 0 0 8px rgba(255,143,163,0.22) !important;
}
.lev-range::-moz-range-thumb {
  background: var(--brand) !important;
  border: 2px solid var(--bg) !important;
  width: 18px !important;
  height: 18px !important;
}
.lev-risk-label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
}

/* ── PAIR PRESETS — Softer chips ── */
.pair-presets button {
  padding: 4px 10px !important;
  border-radius: 8px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 600 !important;
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  color: var(--m) !important;
}
.pair-presets button:hover {
  background: rgba(255,255,255,0.06) !important;
  color: var(--t) !important;
}

/* ── TRADE CARDS (History) — NutriSense style ── */
.tcard {
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 16px !important;
  padding: 16px 18px !important;
  transition: all 0.2s ease !important;
}
.tcard:hover {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.10) !important;
  transform: translateY(-1px) !important;
}
.tcard.win { border-left: 3px solid var(--g) !important; }
.tcard.loss { border-left: 3px solid var(--r) !important; }
.tcard.be { border-left: 3px solid rgba(255,255,255,0.15) !important; }
.tpair {
  font-family: var(--font-body) !important;
  font-size: var(--fs-base) !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}
.tdir {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 600 !important;
  padding: 3px 8px !important;
  border-radius: 6px !important;
  letter-spacing: 0.02em !important;
}
.tpnl {
  font-family: var(--font-mono) !important;
  font-size: var(--fs-base) !important;
  font-weight: 600 !important;
}
.tdate {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  color: var(--m) !important;
}

/* ── FILTER BUTTONS — Pill shape ── */
.fbtn {
  padding: 5px 14px !important;
  border-radius: 999px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  color: var(--m) !important;
}
.fbtn.active, .fbtn:hover {
  background: rgba(255,122,138,0.10) !important;
  border-color: rgba(255,122,138,0.20) !important;
  color: var(--brand) !important;
}
.list-title {
  font-family: var(--font-body) !important;
  font-size: var(--fs-base) !important;
  font-weight: 700 !important;
  color: var(--t) !important;
}

/* ── DASHBOARD CARDS — Unified ── */
.dash-card, .an-card {
  box-shadow: 0 8px 22px rgba(0,0,0,0.2);
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 20px !important;
  padding: 22px !important;
  backdrop-filter: blur(12px) !important;
  transition: all 0.2s ease !important;
}
.dash-card:hover, .an-card:hover {
  border-color: rgba(255,255,255,0.10) !important;
  transform: translateY(-1px) !important;
}
.dash-title {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 600 !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

/* ── LEVEL BAR — Premium ── */
.level-bar {
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 20px !important;
  padding: 16px 20px !important;
}
.lb-name {
  font-family: var(--font-body) !important;
  font-size: var(--fs-md) !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
}

/* ── SCREENSHOT ZONE ── */
.screenshot-zone {
  border-radius: 14px !important;
  border: 1px dashed rgba(255,255,255,0.08) !important;
  background: rgba(255,255,255,0.015) !important;
  padding: 24px !important;
  transition: all 0.2s !important;
}
.screenshot-zone:hover {
  border-color: rgba(255,143,163,0.18) !important;
  background: rgba(255,255,255,0.025) !important;
}
.scr-label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  color: var(--m) !important;
}

/* ── MOBILE TWEAKS ── */
.mob-bar {
  background: rgba(11,11,13,0.82) !important;
  backdrop-filter: saturate(160%) blur(22px) !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
}
.mob-logo {
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  color: var(--brand) !important;
  letter-spacing: 0.06em !important;
}

/* ── SECTION TITLES — uniform ── */
.section-microtitle {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
  margin-bottom: 8px !important;
}

/* ── GHOST DANGER BUTTON — subtle ── */
.ghost-danger-btn {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  border-radius: 999px !important;
  padding: 4px 12px !important;
}

/* ── BACKGROUND ORBS — warmer ── */
.bg-o-1 {
  background: radial-gradient(circle, rgba(255,122,138,0.015), transparent 65%) !important;
}
.bg-o-2 {
  background: radial-gradient(circle, rgba(52,211,153,0.008), transparent 65%) !important;
}
.bg-o-3 {
  background: radial-gradient(circle, rgba(255,122,138,0.010), transparent 65%) !important;
}

/* ── SCROLLBAR — subtle ── */
::-webkit-scrollbar {
  width: 5px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.08);
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.14);
}

/* ── RESPONSIVE — Mobile ── */
@media (max-width: 860px) {
  .stats-row {
  align-items: stretch;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  .stat-cell {
  box-shadow: var(--shadow-card);
    padding: 16px 18px !important;
  }
  .fcard {
    padding: 20px 18px !important;
    border-radius: 20px !important;
  }
  .fg3 {
    grid-template-columns: 1fr !important;
  }
  .fg4 {
    grid-template-columns: 1fr 1fr !important;
  }
  .em-grid {
    grid-template-columns: 1fr !important;
  }
  .trade-metrics-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .form-actions {
    grid-template-columns: 1fr !important;
  }
  .form-section-label {
    font-size: var(--fs-xs) !important;
  }
  .fg2 {
    max-width: 100% !important;
  }
  .fg2[style*="max-width"] {
    max-width: 100% !important;
  }
}

@media (max-width: 480px) {
  .stat-value {
    font-size: var(--fs-lg) !important;
  }
  .stat-cell:nth-child(3) .stat-value {
    font-size: var(--fs-lg) !important;
  }
}

/* ══════════════════════════════════════════════════════════
   AI TRADE ANALYZER v2.0 — Smart contextual modal
   ══════════════════════════════════════════════════════════ */

/* Modal overlay */
.ai-modal {
  background: rgba(0,0,0,0.65) !important;
  backdrop-filter: blur(8px) !important;
}
.ai-box {
  background: rgba(15,15,18,0.96) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 24px !important;
  max-width: 580px !important;
  padding: 28px 30px !important;
  box-shadow: 0 32px 96px rgba(0,0,0,0.5) !important;
  backdrop-filter: blur(24px) !important;
}
.ai-close {
  width: 32px !important;
  height: 32px !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-base) !important;
  transition: all 0.15s !important;
}
.ai-close:hover {
  background: rgba(248,113,113,0.08) !important;
  border-color: rgba(248,113,113,0.2) !important;
  color: var(--r) !important;
}

/* AI Header */
.ai-header-new {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}
.ai-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: rgba(255,143,163,0.08);
  border: 1px solid rgba(255,143,163,0.14);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--a);
  flex-shrink: 0;
}
.ai-title-new {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 700;
  color: var(--t);
  letter-spacing: -0.01em;
}
.ai-sub-new {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--m);
  margin-top: 2px;
}

/* Context card — shows current form data */
.ai-context {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  padding: 14px 16px;
  margin-bottom: 18px;
}
.ai-ctx-label {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--m);
  margin-bottom: 10px;
}
.ai-ctx-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.ai-ctx-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ai-ctx-key {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--m2);
}
.ai-ctx-val {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--t);
}

/* Checklist groups */
.ai-checklist-new {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ai-ck-group {
  background: rgba(255,255,255,0.015);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 14px;
  padding: 14px;
}
.ai-ck-group-label {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--a);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.ai-ck-group-label::before {
  content: '';
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--a);
  flex-shrink: 0;
}
.ai-checklist-new .ck-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  margin-bottom: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
}
.ai-checklist-new .ck-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.ai-checklist-new .ck-q {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  color: rgba(244,240,236,0.72);
  line-height: 1.4;
  flex: 1;
  margin-bottom: 0 !important;
}
.ai-checklist-new .ck-btns {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.ai-checklist-new .ck-btn {
  padding: 6px 14px !important;
  border-radius: 8px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  background: rgba(255,255,255,0.03) !important;
  color: var(--m) !important;
  transition: all 0.15s !important;
}
.ai-checklist-new .ck-btn:hover {
  background: rgba(255,255,255,0.06) !important;
  color: var(--t) !important;
}
.ai-checklist-new .ck-btn.yes {
  background: rgba(52,211,153,0.10) !important;
  border-color: rgba(52,211,153,0.25) !important;
  color: var(--g) !important;
}
.ai-checklist-new .ck-btn.no {
  background: rgba(248,113,113,0.10) !important;
  border-color: rgba(248,113,113,0.25) !important;
  color: var(--r) !important;
}

/* AI Note */
.ai-note label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  color: var(--m) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}
.ai-note textarea {
  background: rgba(255,255,255,0.035) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 12px !important;
  padding: 10px 14px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-sm) !important;
  min-height: 60px !important;
}
.ai-note textarea:focus {
  border-color: rgba(255,143,163,0.22) !important;
  box-shadow: 0 0 0 3px rgba(255,143,163,0.06) !important;
}

/* Analyze button */
.ai-check-btn {
  width: 100% !important;
  padding: 14px !important;
  background: var(--a) !important;
  border: none !important;
  border-radius: 14px !important;
  color: #fff !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-base) !important;
  font-weight: 600 !important;
  cursor: pointer;
  transition: all 0.2s !important;
  box-shadow: 0 2px 12px rgba(255,143,163,0.18) !important;
  margin-top: 14px;
}
.ai-check-btn:hover {
  box-shadow: 0 4px 20px rgba(255,143,163,0.22) !important;
  transform: translateY(-1px);
}

/* Result with score ring */
.ai-result {
  margin-top: 16px !important;
  border-radius: 18px !important;
  padding: 20px !important;
  text-align: center;
}
.ai-result.go {
  background: rgba(52,211,153,0.06) !important;
  border: 1px solid rgba(52,211,153,0.15) !important;
}
.ai-result.stop {
  background: rgba(248,113,113,0.06) !important;
  border: 1px solid rgba(248,113,113,0.15) !important;
}
.ai-result.wait {
  background: rgba(251,191,36,0.06) !important;
  border: 1px solid rgba(251,191,36,0.15) !important;
}
.ai-score-ring {
  margin: 0 auto 12px;
  width: 60px;
  height: 60px;
}
.ai-verdict {
  font-family: var(--font-body) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 8px !important;
}
.ai-text {
  font-family: var(--font-body) !important;
  font-size: var(--fs-sm) !important;
  color: var(--m) !important;
  line-height: 1.65 !important;
}
.ai-recommendations {
  margin-top: 14px;
  text-align: left;
}
.ai-rec-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  margin-bottom: 4px;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--m);
  line-height: 1.5;
}
.ai-rec-item.warn {
  background: rgba(251,191,36,0.04);
  border: 1px solid rgba(251,191,36,0.10);
}
.ai-rec-item.good {
  background: rgba(52,211,153,0.04);
  border: 1px solid rgba(52,211,153,0.10);
}
.ai-rec-item.bad {
  background: rgba(248,113,113,0.04);
  border: 1px solid rgba(248,113,113,0.10);
}
.ai-rec-icon {
  font-size: var(--fs-base);
  flex-shrink: 0;
  line-height: 1;
}

/* ══════════════════════════════════════════════════════════
   MOBILE v2.0 — Touch-friendly, clean
   ══════════════════════════════════════════════════════════ */

/* Mobile bottom nav — rounder, cleaner */
.mob-bottom-nav {
  background: rgba(11,11,13,0.92) !important;
  backdrop-filter: blur(24px) !important;
  border-top: 1px solid rgba(255,255,255,0.05) !important;
  padding: 8px 12px max(env(safe-area-inset-bottom), 10px) !important;
}
.mob-nav-btn {
  border-radius: 14px !important;
  padding: 8px 14px !important;
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(255,255,255,0.04) !important;
  color: var(--m) !important;
  min-width: 68px !important;
}
.mob-nav-btn.active {
  background: rgba(255,143,163,0.08) !important;
  border-color: rgba(255,122,138,0.18) !important;
  color: var(--a) !important;
}

/* Mobile bar — refined */
.mob-bar {
  height: 54px !important;
  background: rgba(11,11,13,0.88) !important;
  backdrop-filter: saturate(160%) blur(22px) !important;
  border-bottom: 1px solid rgba(255,255,255,0.04) !important;
}
.mob-logo {
  font-family: var(--font-body) !important;
  font-size: var(--fs-sm) !important;
  font-weight: 800 !important;
  letter-spacing: 0.06em !important;
  color: var(--a) !important;
}
.mob-stat-pill {
  border-radius: 12px !important;
  padding: 4px 12px !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
}
.mob-pill-label {
  font-family: var(--font-body) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 500 !important;
  color: var(--m2) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}
.mob-pill-val {
  font-family: var(--font-mono) !important;
  font-size: var(--fs-xs) !important;
  font-weight: 600 !important;
}
.mob-profile-btn {
  border-radius: 12px !important;
  width: 36px !important;
  height: 36px !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
}

/* Mobile form adjustments */
@media (max-width: 860px) {
  .form-section {
    margin-bottom: 16px !important;
    padding-bottom: 16px !important;
  }
  .form-section-num {
    width: 22px !important;
    height: 22px !important;
    font-size: var(--fs-xs) !important;
    border-radius: 7px !important;
  }
  .ai-ctx-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .ai-checklist-new .ck-item {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }
  .ai-checklist-new .ck-btns {
    width: 100% !important;
  }
  .ai-checklist-new .ck-btn {
    flex: 1 !important;
    text-align: center !important;
  }
  .ai-box {
    max-width: 100% !important;
    padding: 22px 18px !important;
    border-radius: 20px !important;
    max-height: 85vh !important;
  }
}

@media (max-width: 480px) {
  .mob-bar {
    padding: 0 10px !important;
  }
  .mob-stat-pill {
    padding: 3px 8px !important;
    min-width: 48px !important;
  }
  .form-section-label {
    font-size: var(--fs-xs) !important;
  }
  .ai-ctx-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
  }
}

/* ══════════════════════════════════════════════════════════
   SIDEBAR — Mobile slide-in refinement
   ══════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .sidebar {
    background: rgba(11,11,13,0.96) !important;
    backdrop-filter: blur(24px) !important;
  }
  .sb-item {
    font-family: var(--font-body) !important;
    font-size: var(--fs-sm) !important;
    font-weight: 500 !important;
    padding: 12px 16px !important;
    border-radius: 0 12px 12px 0 !important;
    margin-right: 8px !important;
  }
  .sb-item.active {
    background: rgba(255,143,163,0.06) !important;
    border-left: 3px solid var(--a) !important;
    color: var(--a) !important;
  }
}

/* Legacy PHASE 1/2 override stack removed in Stage 1.5 deduplication.
   Canonical component styling remains in earlier journal.css sections. */

/* Journal v2 base duplicate removed; scoped refinement block kept below. */

/* ===== Journal v2 premium direction refinement (scoped) ===== */
.journal-v2{
  --accent:#ff9a8b;
  --accent-strong:#ff7f8f;
  --accent-soft:rgba(255,154,139,0.14);
  --accent-border:rgba(255,154,139,0.38);
  --accent-glow:rgba(255,127,143,0.24);
  --jv2-bg:#0b0d12;
  --jv2-bg2:#10131b;
  --jv2-surface:rgba(15,18,26,0.92);
  --jv2-surface-soft:rgba(255,255,255,0.02);
  --jv2-line:rgba(255,255,255,0.09);
  --jv2-line-soft:rgba(255,255,255,0.06);
  --jv2-text:rgba(255,255,255,0.93);
  --jv2-muted:rgba(198,206,221,0.65);
  background:radial-gradient(900px 500px at 6% -6%, rgba(255,154,139,0.08), transparent 62%),radial-gradient(700px 420px at 94% 0%, rgba(255,127,143,0.06), transparent 65%),linear-gradient(180deg,var(--jv2-bg),var(--jv2-bg2));
  border-radius:18px;
  padding:18px 20px 24px;
}
.journal-v2-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px;padding:14px;border:1px solid var(--jv2-line);border-radius:16px;background:linear-gradient(130deg,rgba(255,255,255,0.04),rgba(255,154,139,0.08));}
.journal-v2 .jv2-brand{display:flex;align-items:center;gap:12px;min-width:0;}
.journal-v2 .jv2-logo-dot{width:10px;height:10px;border-radius:50%;background:var(--accent-strong);}
.journal-v2 .jv2-brand h1{font-size:22px;letter-spacing:-.01em;color:var(--jv2-text);line-height:1.1;}
.journal-v2 .jv2-brand p{font-size:13px;color:var(--jv2-muted);}
.journal-v2 .jv2-top-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.journal-v2 .jv2-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(255,255,255,0.03);border:1px solid var(--jv2-line-soft);border-radius:11px;white-space:nowrap;}
.journal-v2 .jv2-chip span{font-size:11px;color:var(--jv2-muted);}
.journal-v2 .jv2-chip strong{font-size:12px;color:var(--jv2-text);}
.journal-v2 .jv2-new{width:auto;min-width:170px;margin-top:0;}

.journal-v2-layout{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,0.85fr);gap:18px;align-items:start;}
.journal-v2-main,.journal-v2-side{min-width:0;}
.journal-v2 .jv2-side-card.sticky{position:sticky;top:72px;}

.journal-v2 .fcard{border:1px solid var(--jv2-line);border-radius:16px;background:linear-gradient(180deg,var(--jv2-surface),rgba(16,19,27,0.88));box-shadow:0 12px 36px rgba(2,5,12,0.42), inset 0 1px 0 rgba(255,255,255,0.04);}
.journal-v2 .field label,.journal-v2 .jv2-step-title,.journal-v2 .fcard-title{letter-spacing:.02em;}
.journal-v2 .fcard-title{font-size:19px;font-weight:600;color:var(--jv2-text);margin-bottom:16px;}
.journal-v2 .jv2-step{margin-bottom:14px;padding:16px;border-radius:14px;border-color:var(--jv2-line);background:var(--jv2-surface-soft);}
.journal-v2 .jv2-step-title{font-size:10px;color:#ffc0b6;}
.journal-v2 input,.journal-v2 textarea,.journal-v2 select{min-height:44px;border-radius:10px;border-color:var(--jv2-line-soft);background:rgba(255,255,255,0.025);color:var(--jv2-text);}
.journal-v2 textarea{min-height:118px;}
.journal-v2 input:focus,.journal-v2 textarea:focus,.journal-v2 select:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px rgba(255,154,139,0.1);}
.journal-v2 .dbtn,.journal-v2 .res-btn,.journal-v2 .setup-btn,.journal-v2 .em-opt,.journal-v2 .fbtn{border-radius:10px;border-color:var(--jv2-line-soft);background:rgba(255,255,255,0.02);color:rgba(255,255,255,0.88);}
.journal-v2 .res-btn.active-be,.journal-v2 .setup-btn.active,.journal-v2 .em-opt.active,.journal-v2 .fbtn.active{color:var(--accent);border-color:var(--accent-border);background:var(--accent-soft);}

.journal-v2 .btn-add,.journal-v2 .btn-ai,.journal-v2 .jv2-reset{min-height:42px;border-radius:10px;font-size:13px;width:100%;}
.journal-v2 .btn-add{background:linear-gradient(135deg,var(--accent),var(--accent-strong));box-shadow:0 10px 22px -14px var(--accent-glow);color:#2a1619;font-weight:600;}
.journal-v2 .btn-ai{background:rgba(255,255,255,0.04);border:1px solid var(--jv2-line-soft);color:rgba(255,255,255,.88);}
.journal-v2 .jv2-reset{border:1px solid var(--jv2-line-soft);background:transparent;color:var(--jv2-muted);cursor:pointer;}
.journal-v2 .jv2-reset:hover{border-color:var(--accent-border);color:var(--jv2-text);background:rgba(255,255,255,0.03);}
.journal-v2 .jv2-form-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;}

.journal-v2 .jv2-side-card{padding:14px;border:1px solid var(--jv2-line);border-radius:16px;background:linear-gradient(180deg,rgba(16,19,27,0.94),rgba(12,15,22,0.92));box-shadow:0 10px 24px rgba(3,8,18,0.3), inset 0 1px 0 rgba(255,255,255,0.04);}
.journal-v2 .jv2-side-title{font-size:12px;letter-spacing:.06em;color:var(--jv2-text);margin-bottom:10px;}
.journal-v2 .jv2-metric{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--jv2-line-soft);}
.journal-v2 .jv2-metric:last-of-type{border-bottom:none;}
.journal-v2 .jv2-metric span{font-size:12px;color:var(--jv2-muted);}
.journal-v2 .jv2-metric strong{font-size:15px;color:var(--jv2-text);}
.journal-v2 .jv2-verdict{margin-top:12px;padding:10px;border-radius:10px;color:#ffe4ea;background:linear-gradient(135deg,rgba(255,154,139,0.12),rgba(255,127,143,0.08));border:1px solid rgba(255,154,139,0.32);font-size:12px;}
.journal-v2 .jv2-checklist{margin-top:10px;padding-left:16px;color:var(--jv2-muted);font-size:12px;display:grid;gap:6px;}

.journal-v2 .list-head{margin-top:16px;padding-top:6px;}
.journal-v2 #trades-list .tcard,.journal-v2 #trades-list .trade-row{border-radius:12px;border-color:var(--jv2-line);background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.015));}

.trade-row,.tr-note,.tr-meta,.trade-meta,.tr-pair,.tr-setup,.tr-date{min-width:0;overflow-wrap:anywhere;word-break:break-word;}
.tr-note,.trade-meta{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}

#orb-theme-ctrl,#orb-sp-ov{display:none;}

@media (max-width:1024px){
  .journal-v2{padding:14px 14px 20px;}
  .journal-v2-topbar{gap:12px;}
  .journal-v2-layout{grid-template-columns:1fr;gap:12px;}
  .journal-v2 .jv2-side-card.sticky{position:static;top:auto;}
}
@media (max-width:720px){
  .journal-v2{border-radius:14px;}
  .journal-v2-topbar{padding:14px;flex-direction:column;align-items:flex-start;}
  .journal-v2 .jv2-top-stats{width:100%;}
  .journal-v2 .jv2-chip{flex:1;justify-content:space-between;min-width:0;}
  .journal-v2 .jv2-form-actions{grid-template-columns:1fr;}
}
