/* ═══════════════════════════════════════════════════════
   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:     #F26B3A;
  --brand-dim: rgba(242,107,58,0.08);
  --brand-bd:  rgba(242,107,58,0.2);

  /* ACCENT — brand only (алиасы для совместимости) */
  --a:  #F26B3A;
  --a2: rgba(242,107,58,0.08);
  --a3: rgba(242,107,58,0.2);

  /* 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.025);
  --bg3:      rgba(255,255,255,0.04);
  --bg-card:  #111114;
  --bg-card2: #161619;
  --bg-input: rgba(255,255,255,0.04);

  /* 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 2px 12px rgba(0,0,0,0.35);

  /* 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(242,107,58,0.022);
  --orb2: rgba(242,107,58,0.014);
  --orb3: rgba(242,107,58,0.01);
}

/* ── 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 24px rgba(242,107,58,0.18);
}
.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, box-shadow .18s ease;
}
.apple-tool-btn:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(242,107,58,0.35);
  color: #fff;
  box-shadow: 0 0 10px rgba(242,107,58,0.2), 0 0 20px rgba(242,107,58,0.08);
}
.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 {
  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 {
  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: 2px;
  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: 2px;
  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: 2px;
  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(242,107,58,0.2) !important; color: rgba(242,107,58,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-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  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(242,107,58,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-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  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: 2px; font-weight: 600; color: rgba(242,107,58,0.5); 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 {
  display: grid;
  grid-template-columns: 1fr 1fr 2fr;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  margin-top: var(--sp-6);
}
/* Stage 3: more padding, bigger numbers, no text-shadow */
.stat-cell {
  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 0 16px rgba(52,211,153,0.1); }
.stat-cell.glow-r { box-shadow: 0 0 16px rgba(248,113,113,0.08); }
.stat-cell.glow-a { box-shadow: 0 0 16px rgba(255,255,255,0.06); }

/* ══════════════════════════════════════════════════
   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-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  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-mono);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--m);
  display: flex;
  align-items: center;
  gap: 6px;
}
.field input, .field select, .field textarea {
  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(242,107,58,0.25); outline: none; }

.btn-ai {
  width: 100%;
  padding: var(--sp-2);
  background: var(--gd);
  border: 1px solid rgba(52,211,153,0.25);
  border-radius: var(--radius);
  color: var(--g);
  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(52,211,153,0.14); border-color: rgba(52,211,153,0.4); }

/* 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 {
  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); }
.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: 2px; }
.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 {
  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: 2px;
  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: 2px; 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: 2px; 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: 2px; 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: 2px; 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: 2px;
  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: 2px;
  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: 2px; 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: 2px; 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: 2px;
  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(242,107,58,0.08); border: 1px solid var(--a3); display: flex; align-items: center; justify-content: center; font-size: 28px; flex-shrink: 0; }
.coach-name { font-family: var(--font-body); font-size: var(--fs-md); font-weight: 600; color: rgba(255,255,255,0.9); }
.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: 10px; }

/* ── COACH REC: cleaner structure with left accent bar ── */
.coach-rec {
  border-radius: 10px;
  padding: 12px 14px 12px 16px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  transition: 0.18s;
  position: relative;
  overflow: hidden;
}
.coach-rec::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  border-radius: 3px 0 0 3px;
}
.coach-rec.warn {
  background: rgba(251,191,36,0.06);
  border: 1px solid rgba(251,191,36,0.22);
}
.coach-rec.warn::before { background: #FBBF24; }
.coach-rec.crit {
  background: rgba(248,113,113,0.06);
  border: 1px solid rgba(248,113,113,0.22);
}
.coach-rec.crit::before { background: #F87171; }
.coach-rec.good {
  background: rgba(52,211,153,0.05);
  border: 1px solid rgba(52,211,153,0.2);
}
.coach-rec.good::before { background: #34D399; }

.coach-rec-icon { font-size: 15px; flex-shrink: 0; margin-top: 1px; line-height: 1; }

/* Main body: title + desc + action */
.coach-rec-body { flex: 1; min-width: 0; }
.coach-rec-title {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 4px;
}
.coach-rec.warn .coach-rec-title { color: #F5C842; }
.coach-rec.crit .coach-rec-title { color: #F87171; }
.coach-rec.good .coach-rec-title { color: #34D399; }

.coach-rec-desc {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  line-height: 1.55;
  color: rgba(255,255,255,0.5);
  margin-bottom: 6px;
}
.coach-rec-action {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  opacity: 0.85;
}
.coach-rec.warn .coach-rec-action { color: rgba(251,191,36,0.8); }
.coach-rec.crit .coach-rec-action { color: rgba(248,113,113,0.8); }
.coach-rec.good .coach-rec-action  { color: rgba(52,211,153,0.8); }

/* Legacy text support */
.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(248,113,113,0.9); }
.coach-rec.good .coach-rec-text { color: rgba(52,211,153,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: 9px;
  letter-spacing: 1.5px;
  padding: 3px 8px;
  border-radius: 5px;
  text-transform: uppercase;
  font-weight: 600;
  align-self: flex-start;
}
.coach-rec.warn .coach-rec-badge { background: rgba(251,191,36,0.12); color: #FBBF24; border: 1px solid rgba(251,191,36,0.3); }
.coach-rec.crit .coach-rec-badge { background: rgba(248,113,113,0.12); color: #F87171; border: 1px solid rgba(248,113,113,0.3); }
.coach-rec.good .coach-rec-badge { background: rgba(52,211,153,0.1); color: #34D399; border: 1px solid rgba(52,211,153,0.3); }

/* ── COACH PNL TAG ── */
.coach-rec-pnl {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  opacity: 0.7;
}
.coach-rec.crit .coach-rec-pnl { color: #F87171; }
.coach-rec.warn .coach-rec-pnl { color: #FBBF24; }
.coach-rec.good .coach-rec-pnl { color: #34D399; }

.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(242,107,58,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: 2px; 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(--g); 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: 2px; 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(--gd); border: 1px solid rgba(52,211,153,0.3); border-radius: 8px; color: var(--g); font-family: var(--font-body); font-size: var(--fs-base); font-weight: 600; cursor: pointer; transition: 0.15s; }
.ai-check-btn:hover { background: rgba(52,211,153,0.14); }
.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: 2px; 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: 2px; 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: 2px; 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: 2px; 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(242,107,58,0.14); }

/* ══════════════════════════════════════════════════
   PROGRESS BARS
   ══════════════════════════════════════════════════ */
.prog-bar-fill { background: linear-gradient(90deg, var(--a), rgba(242,107,58,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: 2px; 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(242,107,58,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: 2px;
  white-space: nowrap;
  overflow: hidden;
  width: 0;
  border-right: 2px solid rgba(242,107,58,0.7);
  animation: 2.2s steps(40,end) forwards orbTw;
}
@keyframes orbTw {
  0%   { width: 0; }
  99%  { border-right: 2px solid rgba(242,107,58,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: 2px; opacity: 0; transition: opacity 0.3s; color: rgba(242,107,58,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(242,107,58,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: 2px; 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(242,107,58,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(242,107,58,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 { 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 { 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 { 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 { 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 { 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 { margin-bottom: 10px; }
@media (min-width: 861px) {
  .main { max-width: 1600px !important; }
  .stats-row { 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: 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(242,107,58,0.065);
  --orb2:rgba(242,107,58,0.04);
  --orb3:rgba(242,107,58,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(242,107,58,0.16) 0%, transparent 64%),
    radial-gradient(ellipse 58% 58% at 68% 112%, rgba(242,107,58,0.12) 0%, transparent 66%),
    radial-gradient(ellipse 84% 28% at 50% 103%, rgba(242,107,58,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(10,10,13,0.72);
  backdrop-filter:saturate(200%) blur(28px);
  border-bottom:1px solid rgba(255,255,255,0.06);
  box-shadow:0 1px 0 rgba(242,107,58,0.08), 0 4px 24px rgba(0,0,0,0.28);
}
.apple-nav-inner{
  max-width:1280px;
  padding:0 20px;
  gap:16px;
}
.apple-brand-text{
  font-family:var(--font-body);
  font-size:11px;
  font-weight:700;
  letter-spacing:0.06em;
  text-transform:uppercase;
}
.apple-brand-mark{
  width:6px; height:6px;
  box-shadow:0 0 10px rgba(242,107,58,0.9), 0 0 20px rgba(242,107,58,0.4);
}
.apple-nav-links{gap:2px;}
.apple-nav-link{
  height:28px;
  padding:0 10px;
  border:1px solid transparent;
  background:transparent;
  color:rgba(255,255,255,0.65);
  font-size:11px;
  font-weight:500;
  letter-spacing:-0.01em;
  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.07);
  color:rgba(255,255,255,0.9);
}
.apple-nav-link.active{
  color:var(--brand);
  border-color:rgba(242,107,58,0.18);
  background:rgba(242,107,58,0.07);
}
.apple-nav-caret{display:none!important;}
.apple-menu-panel{
  top:calc(100% + 8px);
  width:min(680px, calc(100vw - 32px));
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,0.09);
  background:rgba(16,16,20,0.92);
  backdrop-filter:blur(32px) saturate(160%);
  box-shadow:0 24px 64px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.05), 0 0 0 1px rgba(242,107,58,0.06);
}
.apple-menu-grid{gap:20px;}
.apple-menu-column-main{
  padding-right:10px;
  border-right:1px solid rgba(255,255,255,0.07);
}
.apple-menu-eyebrow{
  color:rgba(255,255,255,0.35);
  font-size:10px;
  letter-spacing:0.04em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.apple-menu-item{
  font-family:var(--font-display);
  font-size:22px;
  line-height:1.1;
  font-weight:600;
  letter-spacing:-0.03em;
  padding:7px 0;
  color:rgba(255,255,255,0.88);
}
.apple-menu-item:hover,
.apple-menu-item.active{color:var(--brand);}
.apple-menu-copy{
  color:rgba(255,255,255,0.5);
  font-size:11px;
  line-height:1.6;
  max-width:260px;
}
.apple-current-page{
  min-width:72px;
  font-size:10px;
  font-weight:500;
  color:rgba(255,255,255,0.38);
}
.apple-tool-btn{
  height:26px;
  min-width:26px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.09);
  background:rgba(255,255,255,0.03);
  backdrop-filter:blur(12px);
  font-size:10px;
}

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(242,107,58,0.12);
  border-color:rgba(242,107,58,0.22);
  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(242,107,58,0.96), rgba(255,92,74,0.9))!important;
  color:#fff!important;
  border:1px solid rgba(242,107,58,0.92)!important;
  box-shadow:0 14px 30px rgba(242,107,58,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(242,107,58,0.12)!important;
  border-color:rgba(242,107,58,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(242,107,58,0.12)!important;
  border-color:rgba(242,107,58,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: #F26B3A;
  --a: #F26B3A;
  --a2: rgba(242,107,58,0.08);
  --a3: rgba(242,107,58,0.20);
  
  /* 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.04);
  
  /* 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(242,107,58,0.018);
  --orb2: rgba(242,107,58,0.012);
  --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(242,107,58,0.2) !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 {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1.5fr !important;
  gap: 14px !important;
  margin-bottom: 24px !important;
}
.stat-cell {
  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), #FF9F6A);
  -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(242,107,58,0.15), 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(242,107,58,0.3);
}

/* ── 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(242,107,58,0.08);
  border: 1px solid rgba(242,107,58,0.15);
  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(242,107,58,0.2) !important;
}
.btn-add:hover {
  opacity: 0.92 !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 20px rgba(242,107,58,0.3) !important;
}
.btn-ai {
  background: rgba(52,211,153,0.06) !important;
  border: 1px solid rgba(52,211,153,0.18) !important;
  border-radius: 14px !important;
  padding: 14px 20px !important;
  color: var(--g) !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(52,211,153,0.10) !important;
  border-color: rgba(52,211,153,0.28) !important;
}

/* ── FORM INPUTS — Softer, warmer ── */
.field input, .field select, .field textarea {
  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(242,107,58,0.3) !important;
  background: rgba(255,255,255,0.05) !important;
  box-shadow: 0 0 0 3px rgba(242,107,58,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(242,107,58,0.10) !important;
  border-color: rgba(242,107,58,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(242,107,58,0.10) !important;
  border-color: rgba(242,107,58,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(242,107,58,0.10) !important;
  border-color: rgba(242,107,58,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(242,107,58,0.3) !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 {
  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(242,107,58,0.10) !important;
  border-color: rgba(242,107,58,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 {
  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(242,107,58,0.2) !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(242,107,58,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(242,107,58,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 {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  .stat-cell {
    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(242,107,58,0.08);
  border: 1px solid rgba(242,107,58,0.15);
  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(242,107,58,0.3) !important;
  box-shadow: 0 0 0 3px rgba(242,107,58,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(242,107,58,0.2) !important;
  margin-top: 14px;
}
.ai-check-btn:hover {
  box-shadow: 0 4px 20px rgba(242,107,58,0.3) !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(242,107,58,0.08) !important;
  border-color: rgba(242,107,58,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(242,107,58,0.06) !important;
    border-left: 3px solid var(--a) !important;
    color: var(--a) !important;
  }
}

/* ══════════════════════════════════════════════════════════
   PHASE 1 — Typography & Mono Cleanup
   Applied: 2026. Safe cascade override at end of file.
   ══════════════════════════════════════════════════════════ */

/* 1.1 Typography scale — 6 sizes only, final values */
:root {
  --fs-xs:   11px;
  --fs-sm:   13px;
  --fs-base: 15px;
  --fs-md:   18px;
  --fs-lg:   22px;
  --fs-xl:   28px;
}

/* 1.2 Kill mono companion styles on label/badge/meta classes.
   High letter-spacing (1-2px) + uppercase = terminal feeling.
   These were designed for mono — with sans-serif they look wrong. */
.stat-label, .field label, .em-label, .em-bar-label,
.pm-limit-label, .pm-mood-label, .pm-section-title,
.pm-side-title, .dash-title, .mc-title, .hm-title,
.dg-label, .di-label, .eq-title, .section-microtitle,
.pkpi-label, .lb-sub, .lb-lbl, .list-title,
.sbw-metric-label, .trade-metric-label,
.settings-card-sub, .my-badges-title,
.ecc, .emc-label, .sim-param-label, .sim-roi-label,
.coach-sub, .ai-sub, .ck-num, .ai-note label,
.goal-popup-head, .goal-popup-lbl, .balance-popup-head,
.balance-popup-lbl, .qnote-label, .qnote-item-type,
.edit-label, .plo-label, .kb-title, .scr-label,
.onb-label, .ticker-divider-label, .mob-pill-label,
.mob-nav-label, .hm-legend, .hm-month-label,
.dh-week, .setup-name, .setup-meta, .ch-desc,
.psych-cond, .psych-trades, .mistake-label,
.pm-streak-label, .pm-ready-text,
.jtb-balance-label, .jtb-goal-label {
  letter-spacing: 0 !important;
  text-transform: none !important;
  font-family: var(--font-body) !important;
}

/* 1.3 Preserve uppercase only where it's structural (tabs/nav) */
.gl-tab,
.mob-nav-label,
.tnav-item {
  text-transform: none !important;
  letter-spacing: -0.01em !important;
}

/* 1.4 tabular-nums on all numeric values — aligns digits, looks professional */
.stat-value, .dg-val, .pkpi-val, .speedo-val,
.tpnl, .fng-num, .sbw-lp-price, .sbw-metric-val,
.streak-num, .sim-roi-val, .sim-param-val,
.ds-level, .setup-wr, .pkpi-val, .psych-result,
.jtb-balance-val, .jtb-goal-val,
.pm-streak-num {
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  font-family: var(--font-body) !important;
}

/* ══════════════════════════════════════════════════════════
   PHASE 1 — Steps 1.3 & 1.4: Kill visual noise
   ══════════════════════════════════════════════════════════ */

/* 1.3a — ORBS: hide completely. Solid bg is calmer. */
.bg-orbs-wrap {
  display: none !important;
}

/* 1.3b — GRADIENT TEXT: kill on stat-cell:nth-child(3).
   Was: linear-gradient on brand value. Now: plain color.
   -webkit-text-fill-color must be explicitly reset. */
.stat-cell:nth-child(3) .stat-value {
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: var(--t) !important;
  color: var(--t) !important;
}

/* 1.3c — GRADIENT TEXT on .sv-g (profit value) — keep color, kill gradient trick */
.sv-g {
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: var(--g) !important;
  color: var(--g) !important;
}

/* 1.4a — KILL decorative ::after gradient lines on cards.
   These were a gimmick. Depth comes from bg difference, not gradients. */
.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 {
  display: none !important;
}

/* 1.4b — KILL brand glow on logo dot (apple-brand-mark).
   A solid dot is already enough. Glow adds noise. */
.apple-brand-mark {
  box-shadow: none !important;
}

/* 1.4c — KILL glow on fcard-dot (section progress dot) */
.fcard-dot.active {
  box-shadow: none !important;
}

/* 1.4d — KILL big CTA glow. Keep shadow subtle: elevation only, no color. */
.btn-add,
.pm-save-btn,
.settings-btn-primary,
.edit-save,
.ai-check-btn {
  box-shadow: 0 2px 8px rgba(0,0,0,0.25) !important;
}
.btn-add:hover,
.pm-save-btn:hover,
.settings-btn-primary:hover,
.edit-save:hover,
.ai-check-btn:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.3) !important;
  transform: none !important;
}

/* 1.4e — KILL hover lift (translateY) on cards.
   Only border-color changes on hover. Clean, calm. */
.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: none !important;
  border-color: rgba(255,255,255,0.12) !important;
  transition: border-color 0.15s ease !important;
}

/* 1.4f — KILL hover gradient background on cards */
.stat-cell:hover,
.fcard:hover,
.dash-card:hover,
.tcard:hover,
.coach-card:hover,
.settings-card:hover,
.pm-section-card:hover {
  background: inherit !important;
}

/* 1.4g — CTA gradient → flat color. Simpler, more confident. */
.btn-add,
.pm-save-btn,
.settings-btn-primary,
.edit-save,
.ai-check-btn {
  background: var(--brand) !important;
}


/* 1.4h — KILL stat-cell dynamic glow classes (added via JS on data change) */
.stat-cell.glow-g,
.stat-cell.glow-r,
.stat-cell.glow-a {
  box-shadow: none !important;
}

/* 1.4i — KILL noise texture body::before (too visible at current opacity) */
body::before {
  opacity: 0.012 !important;
}

/* ══════════════════════════════════════════════════════════
   PHASE 2 — Visual System Cleanup
   2.1 Three radius levels
   2.2 Unified card padding
   2.3 Remove backdrop-filter from cards (solid bg only)
   2.4 Single hover effect (border-color only)
   2.5 Stats row: equal columns
   2.6 Spacing tokens applied
   ══════════════════════════════════════════════════════════ */

/* ── 2.1 THREE RADIUS LEVELS. THAT'S IT. ──────────────────
   --r-sm:   8px  → inputs, small buttons, tags, badges
   --r-md:  16px  → cards, modals, sections
   --r-lg:  24px  → large containers, fcard
   --r-pill: 999px → pills, toggles (already used)
   --------------------------------------------------------- */
:root {
  --r-sm:   8px;
  --r-md:   16px;
  --r-lg:   24px;
  --r-pill: 999px;
}

/* Cards → --r-md */
.stat-cell,
.dash-card, .an-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,
.lb-card,
.score-card,
.dg-card,
.digest-insights {
  border-radius: var(--r-md) !important;
}

/* Form card and modals → --r-lg */
.fcard,
.ai-box,
.edit-box,
.onb-box,
.qnote-popup,
.apple-menu-panel {
  border-radius: var(--r-lg) !important;
}

/* Inputs, small buttons, tags → --r-sm */
input, select, textarea,
.setup-btn, .res-btn, .dbtn,
.fbtn,
.ntag,
.pattern-badge,
.ch-badge,
.ci-badge,
.coach-rec-badge,
.tg-status-badge,
.best-setup-badge,
.worst-setup-badge,
.settings-btn-secondary,
.settings-btn-danger,
.settings-card-icon,
.edit-input,
.goal-popup-input,
.balance-popup-input,
.onb-input,
.sim-toggle,
.psych-btn,
.tilt-btn,
.qnote-type-btn {
  border-radius: var(--r-sm) !important;
}

/* CTA buttons → --r-md for confidence, not pill */
.btn-add,
.pm-save-btn,
.settings-btn-primary,
.edit-save,
.qnote-save,
.ai-check-btn,
.zero-btn,
.es-cta,
.plo-btn,
.onb-btn,
.goal-popup-save,
.balance-popup-save {
  border-radius: var(--r-md) !important;
}

/* Nav items stay pill */
.apple-nav-link,
.gl-tab,
.mob-nav-btn,
.filter-btn {
  border-radius: var(--r-pill) !important;
}

/* ── 2.2 UNIFIED CARD PADDING ─────────────────────────────
   --card-pad:    20px  → standard cards
   --card-pad-sm: 14px  → compact cards (metric, badge)
   --------------------------------------------------------- */
:root {
  --card-pad:    20px;
  --card-pad-sm: 14px;
}

.stat-cell,
.dash-card, .an-card,
.tcard,
.coach-card,
.hm-card,
.equity-card,
.digest-header,
.mc-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.pm-side-card,
.setup-card,
.psych-card,
.pair-card,
.dg-card,
.digest-insights,
.lb-card,
.score-card {
  padding: var(--card-pad) !important;
}

.fcard {
  padding: 24px 28px !important;
}

.pkpi,
.sbw {
  padding: var(--card-pad-sm) !important;
}

/* ── 2.3 REMOVE BACKDROP-FILTER FROM CARDS ────────────────
   Blur on solid-bg cards = muteness, not depth.
   Blur stays ONLY on: navbar, sidebar, mob-bar, overlays, modals.
   --------------------------------------------------------- */
.stat-cell,
.fcard,
.dash-card, .an-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,
.lb-card,
.score-card {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Kill fcard::before decorative gradient line (top accent line) */
.fcard::before {
  display: none !important;
}

/* ── 2.4 SINGLE HOVER EFFECT — border-color only ──────────
   No transform. No shadow animation. No background shift.
   Just the border brightening slightly.
   --------------------------------------------------------- */
.stat-cell,
.fcard,
.dash-card, .an-card,
.tcard,
.coach-card,
.settings-card,
.pm-section-card,
.pm-limits-card,
.pm-moods-card,
.pm-side-card {
  transition: border-color 0.15s ease !important;
}

.stat-cell:hover,
.fcard:hover,
.dash-card:hover, .an-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 {
  border-color: rgba(255,255,255,0.14) !important;
  transform: none !important;
  background: inherit !important;
}

/* ── 2.5 STATS ROW — 3 EQUAL COLUMNS ─────────────────────
   Was: 1fr 1fr 2fr (or 1fr 1fr 1.5fr)
   Now: 1fr 1fr 1fr — symmetry = order
   --------------------------------------------------------- */
.stats-row {
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 12px !important;
}

/* ── 2.6 SPACING TOKENS — 4 values for card gaps ──────────
   --gap-sm:  8px   within a card between elements
   --gap-md: 12px   between cards in a grid
   --gap-lg: 20px   between sections
   --gap-xl: 32px   major section separation
   --------------------------------------------------------- */
:root {
  --gap-sm:  8px;
  --gap-md: 12px;
  --gap-lg: 20px;
  --gap-xl: 32px;
}

/* Apply gap-md between trade cards */
.trade-list,
.list-wrap {
  gap: var(--gap-md) !important;
}

/* Apply gap-md in dashboard grid */
.dash-grid {
  gap: var(--gap-md) !important;
}

/* Section spacing */
.stats-row {
  margin-bottom: var(--gap-lg) !important;
}


/* ══════════════════════════════════════════════════════════════
   PHASE 3 — Complete UI Polish
   ══════════════════════════════════════════════════════════════ */

/* ── 3.1 KILL PARTICLE EFFECTS ─────────────────────────────── */
body > div[style*="border-radius:50%"][style*="pointer-events:none"],
body > div[style*="position:fixed"][style*="border-radius:50%"] {
  display: none !important;
}

/* ── 3.2 P&L COLORS (override webkit-text-fill-color) ──────── */
#s-pnl.sv-g {
  color: var(--g) !important;
  -webkit-text-fill-color: var(--g) !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
}
#s-pnl.sv-r {
  color: var(--r) !important;
  -webkit-text-fill-color: var(--r) !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
}

/* ── 3.3 ACTIVE NAV: underline not rectangle ────────────────── */
.tnav.active {
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid var(--brand) !important;
  border-radius: 0 !important;
  color: var(--t) !important;
}
.tnav:hover:not(.active) {
  border-radius: 0 !important;
  border-bottom: 2px solid rgba(255,255,255,0.08) !important;
}

/* Sidebar active: left line, no fill */
.sb-item.active,
.sb-item.active:hover {
  background: transparent !important;
  border-left: 2px solid var(--brand) !important;
  color: var(--brand) !important;
  box-shadow: none !important;
}

/* ── 3.4 BRIGHTER BORDERS + GLOW ON CARDS ─────────────────── */
:root {
  --bd: rgba(255,255,255,0.11);
  --bd2: rgba(255,255,255,0.16);
}

/* Form card has orange border tint */
.fcard {
  border-color: rgba(242,107,58,0.15) !important;
  box-shadow: 0 0 0 1px rgba(242,107,58,0.05) !important;
}
.fcard:hover {
  border-color: rgba(242,107,58,0.25) !important;
  box-shadow: 0 0 12px rgba(242,107,58,0.07) !important;
}

/* General card glow on hover */
.dash-card:hover,
.stat-cell:hover {
  border-color: rgba(242,107,58,0.18) !important;
  box-shadow: 0 0 10px rgba(242,107,58,0.06) !important;
}

/* ── 3.5 DISCIPLINE SECTION: hide emoji text ────────────────── */
/* JS sets level-icon.textContent = emoji — hide it, keep SVG */
#level-icon {
  font-size: 0 !important;
  color: var(--brand);
}
#level-icon svg {
  display: block !important;
  font-size: initial !important;
}

/* ── 3.6 TRADE HISTORY: thin compact list ──────────────────── */
#trades-list {
  background: var(--bg-card);
  border: 1px solid var(--bd2);
  border-radius: var(--r-md);
  overflow: hidden;
  padding: 0 !important;
  gap: 0 !important;
  display: flex;
  flex-direction: column;
  box-shadow: 0 0 8px rgba(242,107,58,0.04);
}

/* Each trade row: ultra thin */
.tcard {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.055) !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  position: relative;
  transition: background 0.12s;
}
.tcard:last-child {
  border-bottom: none !important;
}
.tcard:hover {
  background: rgba(255,255,255,0.025) !important;
}

/* Left color stripe by result */
.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.18) !important; }

/* Trade header row — single compact line */
.th {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  min-height: 38px !important;
  padding: 0 12px 0 10px !important;
  cursor: pointer;
}

/* Left section of row */
.tl {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex: 1 !important;
  min-width: 0 !important;
}

/* Right section */
.tr {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}

/* Pair name */
.tpair {
  font-size: 12.5px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--t) !important;
  font-variant-numeric: tabular-nums;
}

/* Direction badge */
.tdir {
  font-size: 10px !important;
  font-weight: 500 !important;
  padding: 1px 5px !important;
  border-radius: 3px !important;
  letter-spacing: 0 !important;
}
.tdir.long  { background: rgba(52,211,153,0.1); color: var(--g); }
.tdir.short { background: rgba(248,113,113,0.1); color: var(--r); }

/* PnL value */
.tpnl {
  font-size: 12.5px !important;
  font-weight: 600 !important;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em !important;
}
.tpnl.p { color: var(--g) !important; }
.tpnl.n { color: var(--r) !important; }

/* Date */
.tdate {
  font-size: 11px !important;
  color: var(--m) !important;
  white-space: nowrap;
  letter-spacing: 0 !important;
}

/* Edit/Delete btns: hidden until hover */
.editbtn, .delbtn {
  background: none !important;
  border: none !important;
  font-size: 11px !important;
  cursor: pointer !important;
  padding: 2px 4px !important;
  border-radius: 3px !important;
  opacity: 0;
  transition: opacity 0.15s, color 0.12s !important;
  color: var(--m2) !important;
}
.tcard:hover .editbtn,
.tcard:hover .delbtn { opacity: 1; }
.editbtn:hover { color: var(--brand) !important; }
.delbtn:hover  { color: var(--r) !important; }

/* Chevron for expand */
.tcard-chevron {
  display: inline-flex;
  align-items: center;
  color: var(--m2);
  font-size: 12px;
  transition: transform 0.2s;
  margin-left: 2px;
}
.tcard.expanded .tcard-chevron {
  transform: rotate(180deg);
}

/* Expandable detail panel */
.tcard-detail {
  display: none;
  padding: 8px 12px 10px;
  border-top: 1px solid rgba(255,255,255,0.04);
  background: rgba(0,0,0,0.12);
}
.tcard.expanded .tcard-detail {
  display: block;
}

/* Notes inside detail */
.tnotes {
  font-size: 12px !important;
  color: var(--m) !important;
  line-height: 1.6 !important;
  letter-spacing: 0 !important;
}

/* Screenshot smaller */
.tcard-screenshot {
  margin-top: 6px !important;
  border-radius: 6px !important;
  max-height: 110px !important;
  overflow: hidden !important;
}
.tcard-screenshot img {
  width: 100%;
  object-fit: cover;
}

/* ── 3.7 NEW TRADE FORM: compact step layout ────────────────── */
/* Step wrappers */
.form-section {
  padding: 12px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
}
.form-section:last-of-type {
  border-bottom: none !important;
}

.form-section-label {
  font-size: 10px !important;
  letter-spacing: 1.5px !important;
  color: var(--m2) !important;
  margin-bottom: 10px !important;
  display: flex;
  align-items: center;
  gap: 6px;
}
.form-section-num {
  background: rgba(242,107,58,0.12);
  color: var(--brand);
  border: 1px solid rgba(242,107,58,0.2);
  border-radius: 4px;
  padding: 1px 5px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1px;
}

/* Tighter field inputs */
.field input,
.field select {
  height: 34px !important;
  font-size: 13px !important;
  padding: 0 10px !important;
}
.field textarea {
  min-height: 52px !important;
  font-size: 13px !important;
  padding: 8px 10px !important;
}

/* Section 01: pair + direction grid */
.fg3.mb-12 {
  grid-template-columns: 2fr 1fr 1.2fr !important;
  gap: 8px !important;
}

/* Section 02: position/risk */
.fg3.mb-6 {
  grid-template-columns: 1.4fr 1fr 1fr !important;
  gap: 8px !important;
}

/* Section 03: prices 2x2 */
.fg4.mb-6 {
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}

/* P&L row: tighter */
.fg2.mb-6 {
  max-width: 50% !important;
  gap: 8px !important;
}

/* Trade metrics row */
.trade-metrics {
  gap: 6px !important;
}
.trade-metric {
  padding: 6px 10px !important;
}
.trade-metric-label {
  font-size: 9px !important;
}
.trade-metric-value {
  font-size: 14px !important;
}

/* Emotion options */
.em-opt {
  height: 26px !important;
  padding: 3px 9px !important;
  font-size: 11px !important;
}

/* Notes grid: 3 col */
.fg3.mb-10 {
  gap: 8px !important;
}

/* Form action button */
.btn-add {
  height: 38px !important;
  font-size: 11px !important;
}

/* Setup buttons smaller */
.setup-btn {
  padding: 3px 9px !important;
  font-size: 11px !important;
}

/* Fcard padding tighter */
.fcard {
  padding: 16px 18px !important;
}


/* ══════════════════════════════════════════════════
   PATCH v4 — 4 tasks:
   1) AI Coach response colors & structure
   2) Apple nav — compact + orange glow
   3) Navbar button glow
   4) coach-btn breathe animation, match save-trade size
   ══════════════════════════════════════════════════ */

/* ── TASK 1: AI COACH — richer color structure ─────────── */

/* Card outer container */
.coach-card {
  border-color: rgba(242,107,58,0.12) !important;
}

/* Severity rows — stronger contrast */
.coach-rec {
  padding: 12px 14px !important;
  border-radius: 10px !important;
  gap: 10px !important;
  align-items: flex-start !important;
}

/* CRITICAL — vivid red */
.coach-rec.crit {
  background: rgba(248,113,113,0.07) !important;
  border: 1px solid rgba(248,113,113,0.28) !important;
  border-left: 3px solid #F87171 !important;
}
.coach-rec.crit .coach-rec-icon { color: #F87171; }
.coach-rec.crit .coach-rec-text { color: rgba(255,190,190,0.92) !important; }
.coach-rec.crit .coach-rec-badge {
  background: rgba(248,113,113,0.14) !important;
  color: #F87171 !important;
  border: 1px solid rgba(248,113,113,0.35) !important;
  font-weight: 600 !important;
}

/* WARNING — vivid amber */
.coach-rec.warn {
  background: rgba(251,191,36,0.06) !important;
  border: 1px solid rgba(251,191,36,0.24) !important;
  border-left: 3px solid #FBBF24 !important;
}
.coach-rec.warn .coach-rec-icon { color: #FBBF24; }
.coach-rec.warn .coach-rec-text { color: rgba(255,230,150,0.92) !important; }
.coach-rec.warn .coach-rec-badge {
  background: rgba(251,191,36,0.12) !important;
  color: #FBBF24 !important;
  border: 1px solid rgba(251,191,36,0.32) !important;
  font-weight: 600 !important;
}

/* GOOD / STRENGTH — vivid green */
.coach-rec.good {
  background: rgba(52,211,153,0.06) !important;
  border: 1px solid rgba(52,211,153,0.24) !important;
  border-left: 3px solid #34D399 !important;
}
.coach-rec.good .coach-rec-icon { color: #34D399; }
.coach-rec.good .coach-rec-text { color: rgba(160,245,200,0.92) !important; }
.coach-rec.good .coach-rec-badge {
  background: rgba(52,211,153,0.12) !important;
  color: #34D399 !important;
  border: 1px solid rgba(52,211,153,0.32) !important;
  font-weight: 600 !important;
}

/* Badge — bigger, more visible */
.coach-rec-badge {
  font-size: 10px !important;
  padding: 3px 9px !important;
  border-radius: 6px !important;
  letter-spacing: 1px !important;
  white-space: nowrap !important;
}

/* Icon — larger */
.coach-rec-icon {
  font-size: 18px !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  margin-top: 0 !important;
}

/* Action arrow line — orange, stands out */
.coach-rec-text span[style*="color:var(--a)"] {
  color: #F26B3A !important;
  font-weight: 500 !important;
  font-size: 12px !important;
  display: block !important;
  margin-top: 5px !important;
  padding-top: 5px !important;
  border-top: 1px solid rgba(255,255,255,0.06) !important;
}

/* Pattern title inside rec-text */
.coach-rec-text strong {
  display: block !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  margin-bottom: 3px !important;
  color: rgba(255,255,255,0.96) !important;
}

/* Gap between recs */
.coach-recs {
  gap: 10px !important;
}

/* Coach header name */
.coach-name {
  color: var(--brand) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
}

/* ── TASK 2: APPLE NAV — compact + orange glow ─────────── */

.apple-navbar {
  height: 44px !important;
  background: rgba(10,10,13,0.78) !important;
  backdrop-filter: saturate(200%) blur(28px) !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  /* orange bottom glow line */
  box-shadow: 0 1px 0 rgba(242,107,58,0.18), 0 0 32px rgba(242,107,58,0.06) !important;
}

/* shrink variable used by body.main padding */
:root { --apple-nav-h: 44px; }

.apple-nav-inner {
  max-width: 1380px !important;
  padding: 0 20px !important;
  gap: 20px !important;
}

/* Brand — tighter */
.apple-brand {
  gap: 7px !important;
}
.apple-brand-text {
  font-size: 11.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
}
.apple-brand-mark {
  width: 7px !important;
  height: 7px !important;
  box-shadow: 0 0 10px rgba(242,107,58,0.55), 0 0 20px rgba(242,107,58,0.25) !important;
}

/* Nav links — no dropdown caret, tight */
.apple-nav-link {
  height: 28px !important;
  padding: 0 11px !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.72) !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  letter-spacing: -0.01em !important;
}
.apple-nav-link:hover {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: #fff !important;
  box-shadow: 0 0 0 2px rgba(242,107,58,0.10) !important;
}
.apple-menu.open .apple-nav-link,
.apple-nav-link.active {
  background: rgba(242,107,58,0.10) !important;
  border-color: rgba(242,107,58,0.22) !important;
  color: rgba(255,200,170,0.95) !important;
  box-shadow: 0 0 12px rgba(242,107,58,0.14) !important;
}

/* Caret — hide */
.apple-nav-caret { display: none !important; }

/* Nav gap tighter */
.apple-nav-links { gap: 4px !important; }

/* Menu panel — tighter */
.apple-menu-panel {
  top: calc(100% + 8px) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  border: 1px solid rgba(255,255,255,0.09) !important;
  background: rgba(16,16,20,0.94) !important;
  backdrop-filter: blur(30px) saturate(160%) !important;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5), 0 0 0 0.5px rgba(242,107,58,0.12), inset 0 1px 0 rgba(255,255,255,0.04) !important;
}
.apple-menu-item {
  font-size: 18px !important;
  padding: 7px 0 !important;
  font-weight: 600 !important;
  letter-spacing: -0.025em !important;
}

/* Tool buttons right side */
.apple-tool-btn {
  height: 28px !important;
  min-width: 28px !important;
  padding: 0 10px !important;
  font-size: 11px !important;
  border: 1px solid rgba(255,255,255,0.09) !important;
  background: rgba(255,255,255,0.03) !important;
}
.apple-tool-btn:hover {
  background: rgba(255,255,255,0.07) !important;
  border-color: rgba(242,107,58,0.28) !important;
  box-shadow: 0 0 8px rgba(242,107,58,0.12) !important;
}
.apple-current-page {
  font-size: 11px !important;
  color: rgba(255,255,255,0.40) !important;
}

/* ── TASK 3: MOB NAV BUTTON GLOW ───────────────────────── */

.mob-nav-btn.active {
  background: rgba(242,107,58,0.10) !important;
  border-color: rgba(242,107,58,0.24) !important;
  color: var(--a) !important;
  box-shadow: 0 0 10px rgba(242,107,58,0.18), 0 0 0 1px rgba(242,107,58,0.10) !important;
}

/* ── TASK 4: COACH-BTN — breathe + match btn-add size ───── */

@keyframes btnBreathe {
  0%, 100% {
    box-shadow: 0 0 10px rgba(242,107,58,0.22), 0 6px 20px rgba(242,107,58,0.16);
    transform: scale(1);
  }
  50% {
    box-shadow: 0 0 22px rgba(242,107,58,0.42), 0 8px 28px rgba(242,107,58,0.28);
    transform: scale(1.012);
  }
}

#coach-btn,
.coach-run-btn {
  /* match save-trade / btn-add size */
  height: 36px !important;
  padding: 0 18px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.6px !important;
  border-radius: 999px !important;
  /* orange gradient matching btn-add */
  background: linear-gradient(135deg, rgba(242,107,58,0.95), rgba(255,92,74,0.88)) !important;
  border: 1px solid rgba(242,107,58,0.9) !important;
  color: #fff !important;
  /* breathe */
  animation: btnBreathe 2.4s ease-in-out infinite !important;
  transition: opacity 0.15s !important;
  cursor: pointer !important;
}

#coach-btn:hover,
.coach-run-btn:hover {
  opacity: 0.88 !important;
  animation-play-state: paused !important;
}

#coach-btn:disabled,
.coach-run-btn:disabled {
  animation: none !important;
  opacity: 0.55 !important;
  box-shadow: none !important;
}



/* === NEW TRADE: dense SaaS layout === */
.trade-form-shell{
  display:grid;
  grid-template-columns:minmax(0,1.85fr) minmax(320px,1fr);
  gap:14px;
  align-items:start;
}
.stray-analysis{display:none !important;}
.legacy-analysis-section{display:none !important;}
#add-trade-form{
  display:grid;
  grid-template-columns:minmax(0,1.85fr) minmax(320px,1fr);
  gap:14px;
  align-items:start;
}
#add-trade-form > .fcard-header,
#add-trade-form > .form-actions{
  grid-column:1 / -1;
}
#add-trade-form > .trade-form-shell{
  display:contents;
}
#add-trade-form > .form-section:not(.stray-analysis){
  grid-column:2;
  margin:0 !important;
  background:linear-gradient(180deg, rgba(255,255,255,0.022), rgba(255,255,255,0.012));
  border:1px solid rgba(242,107,58,0.16);
  border-radius:12px;
  padding:10px 12px !important;
  box-shadow:0 0 0 1px rgba(242,107,58,0.07), 0 16px 36px rgba(0,0,0,0.28), 0 0 24px rgba(242,107,58,0.08);
}
.trade-form-left,.trade-form-right{min-width:0;}
.trade-form-left .form-section,
.trade-form-right .form-section-prices{
  background:linear-gradient(180deg, rgba(255,255,255,0.022), rgba(255,255,255,0.012));
  border:1px solid rgba(242,107,58,0.16);
  border-radius:12px;
  padding:10px 12px !important;
  box-shadow:0 0 0 1px rgba(242,107,58,0.07), 0 16px 36px rgba(0,0,0,0.28), 0 0 24px rgba(242,107,58,0.08);
}
.trade-form-left{
  display:grid;
  gap:10px;
}
.trade-form-right{
  display:grid;
  gap:10px;
}
.trade-form-left .form-section{
  margin:0 !important;
}
.trade-form-left .form-section .form-section-label,
.trade-form-right .form-section .form-section-label,
#add-trade-form > .form-section .form-section-label{
  margin-bottom:8px !important;
}
.form-section-num{
  box-shadow:0 0 0 1px rgba(242,107,58,0.14), 0 0 12px rgba(242,107,58,0.16);
}
.form-section-risk .fg3{
  grid-template-columns:minmax(120px,1fr) minmax(120px,1fr) !important;
  gap:8px !important;
  align-items:end;
}
.form-section-risk .fg3 .field:nth-child(2){
  grid-column:1 / -1;
}
.form-section-risk .fg3 .field:nth-child(3){
  grid-column:1 / -1;
}
.lev-slider-wrap{
  display:grid;
  grid-template-columns:52px minmax(150px,220px);
  gap:8px;
  align-items:center;
  width:100%;
}
.lev-range{max-width:220px;}
.lev-display{
  font-size:28px !important;
  letter-spacing:-0.02em;
}
.dtoggle,.res-btns{
  border:1px solid rgba(255,255,255,0.08);
  border-radius:9px;
  padding:2px;
  background:rgba(255,255,255,0.02);
  gap:2px;
}
.dbtn,.res-btn{
  min-height:30px !important;
  padding:0 10px !important;
  border-radius:7px !important;
  font-size:11px !important;
  border:0 !important;
}
.dbtn.active,
.res-btn.active-win,
.res-btn.active-loss,
.res-btn.active-be{
  box-shadow:0 0 0 1px rgba(242,107,58,0.28), 0 0 14px rgba(242,107,58,0.18) inset;
}
.compact-price-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:8px !important;
  margin-bottom:8px !important;
}
.compact-price-grid .field-pnl-usd{grid-column:2;}
.trade-metrics-grid{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:8px !important;
  margin:0 !important;
}
.compact-price-grid .field,
.trade-metric-card{
  min-height:52px;
  padding:8px 9px !important;
  border-radius:10px !important;
  border:1px solid rgba(242,107,58,0.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 0 20px rgba(242,107,58,0.06);
}
.trade-metric-label{font-size:10px !important;}
.trade-metric-value,.rr-display{font-size:12px !important;}
.form-section-prices .field input{max-width:none !important;}
.setup-btns{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:6px;
}
.setup-btn{
  width:100%;
  justify-content:center;
}
.setup-btn.active{
  border-color:rgba(141,255,82,0.55) !important;
  color:#9DFF73 !important;
  box-shadow:0 0 0 1px rgba(141,255,82,0.24), 0 0 12px rgba(141,255,82,0.28);
}
.em-grid{
  grid-template-columns:1fr;
  gap:8px !important;
}
.em-row{
  background:linear-gradient(180deg, rgba(255,255,255,0.024), rgba(255,255,255,0.014));
  border:1px solid rgba(242,107,58,0.14);
  border-radius:10px;
  padding:9px 10px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 0 18px rgba(242,107,58,0.05);
}
.em-opt{
  min-height:24px !important;
  padding:2px 7px !important;
  font-size:10px !important;
}
.notes-compact,
#add-trade-form > .form-section:not(.stray-analysis) .fg3.mb-10{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px !important;
  margin-top:10px !important;
}
#add-trade-form > .form-section:not(.stray-analysis) .field{
  gap:6px;
}
#add-trade-form > .form-section:not(.stray-analysis) .field label{
  font-size:11px !important;
  font-weight:600 !important;
  color:rgba(244,240,236,0.62) !important;
}
#add-trade-form > .form-section:not(.stray-analysis) .field textarea{
  min-height:74px !important;
  padding:10px 12px !important;
  border-radius:12px !important;
  resize:none;
  background:linear-gradient(180deg, rgba(255,255,255,0.038), rgba(255,255,255,0.02)) !important;
  border:1px solid rgba(242,107,58,0.14) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 0 22px rgba(242,107,58,0.05);
}
#add-trade-form > .form-section:not(.stray-analysis) .field textarea:focus{
  border-color:rgba(242,107,58,0.3) !important;
  box-shadow:0 0 0 3px rgba(242,107,58,0.07), 0 0 28px rgba(242,107,58,0.07) !important;
}
#add-trade-form input[type=number]::-webkit-outer-spin-button,
#add-trade-form input[type=number]::-webkit-inner-spin-button{
  -webkit-appearance:none;
  margin:0;
}
#add-trade-form input[type=number]{
  -moz-appearance:textfield;
  appearance:textfield;
}
.form-actions{display:flex;justify-content:flex-end;gap:8px;align-items:center;margin-top:8px;}
.btn-ai{width:auto !important;min-width:158px;min-height:36px !important;}
.btn-add{
  width:auto !important;
  min-width:120px;
  padding:8px 14px !important;
  min-height:34px !important;
  border-radius:9px !important;
  background:rgba(242,107,58,0.10) !important;
  border:1px solid rgba(242,107,58,0.24) !important;
  color:var(--brand) !important;
  font-size:11px !important;
  font-weight:500 !important;
  letter-spacing:0 !important;
  box-shadow:none !important;
}
.btn-add:hover{background:rgba(242,107,58,0.14) !important;border-color:rgba(242,107,58,0.3) !important;transform:none !important;opacity:1 !important;}
.screenshot-zone,#scr-zone,.scr-input,#scr-file-input,label[for="scr-zone"]{display:none !important;}

/* navbar + dropdown polish */
.apple-nav-link{
  border-radius:999px !important;
  border:1px solid transparent !important;
}
.apple-nav-link.active,
.apple-menu.open .apple-nav-link{
  background:linear-gradient(180deg, rgba(242,107,58,0.2), rgba(242,107,58,0.08)) !important;
  border-color:rgba(242,107,58,0.36) !important;
  color:#ffd7c7 !important;
  box-shadow:0 0 0 1px rgba(242,107,58,0.12), 0 0 18px rgba(242,107,58,0.18);
}
.apple-menu-panel{
  border:1px solid rgba(255,255,255,0.1) !important;
  box-shadow:0 20px 60px rgba(0,0,0,0.56), 0 0 0 1px rgba(242,107,58,0.14), inset 0 1px 0 rgba(255,255,255,0.05) !important;
}
.apple-menu-item{
  border-radius:12px !important;
  padding:8px 10px !important;
  transition:background .16s ease,color .16s ease, box-shadow .16s ease !important;
}
.apple-menu-item:hover{
  background:rgba(255,255,255,0.05) !important;
}
.apple-menu-item.active{
  background:linear-gradient(90deg, rgba(242,107,58,0.24) 0%, rgba(242,107,58,0.06) 70%) !important;
  border:1px solid rgba(242,107,58,0.24) !important;
  color:#fff !important;
  box-shadow:inset 2px 0 0 rgba(242,107,58,0.78), 0 0 16px rgba(242,107,58,0.14) !important;
}

@media (max-width: 1080px){
  #add-trade-form{grid-template-columns:1fr;}
  #add-trade-form > .trade-form-shell{display:block;}
  #add-trade-form > .form-section:not(.stray-analysis){grid-column:auto;}
  .trade-form-shell{grid-template-columns:1fr;}
  .trade-form-right .form-section-prices{padding:10px !important;}
  .notes-compact,
  #add-trade-form > .form-section:not(.stray-analysis) .fg3.mb-10{
    grid-template-columns:1fr;
  }
}
@media (max-width: 720px){
  .fg3.mb-12{grid-template-columns:1fr !important;}
  .form-section-risk .fg3{grid-template-columns:1fr 1fr !important;}
  .form-section-risk .field:nth-child(2){grid-column:1 / -1;}
  .form-section-risk .field:nth-child(3){grid-column:1 / -1;}
  .compact-price-grid,.trade-metrics-grid{grid-template-columns:1fr !important;}
  .compact-price-grid .field-pnl-usd{grid-column:auto;}
  .setup-btns{grid-template-columns:repeat(2,minmax(0,1fr));}
  .notes-compact,
  #add-trade-form > .form-section:not(.stray-analysis) .fg3.mb-10{grid-template-columns:1fr;}
  .em-grid{grid-template-columns:1fr;}
  .btn-ai,.btn-add{min-width:0;width:100% !important;}
  .form-actions{flex-direction:column;}
}

/* === TRADE PANEL WORKSPACE === */
#add-trade-form.trade-layout-ready{
  display:block !important;
}
.trade-layout-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:8px 0 12px;
  padding:10px 12px;
  border:1px solid rgba(242,107,58,0.14);
  border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  box-shadow:0 0 0 1px rgba(242,107,58,0.06), 0 0 22px rgba(242,107,58,0.05);
}
.trade-layout-copy{display:flex;flex-direction:column;gap:4px;}
.trade-layout-title{
  font:600 12px/1 var(--font-mono);
  letter-spacing:.14em;
  color:#f6d7c8;
  text-transform:uppercase;
}
.trade-layout-sub{
  font-size:12px;
  color:rgba(232,228,220,0.48);
}
.trade-layout-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.trade-layout-btn,
.trade-panel-icon,
.trade-hidden-chip{
  appearance:none;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.03);
  color:rgba(244,240,236,0.82);
  border-radius:999px;
  min-height:30px;
  padding:0 12px;
  font:600 11px/1 var(--font-mono);
  letter-spacing:.08em;
  cursor:pointer;
  transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease;
}
.trade-layout-btn:hover,
.trade-panel-icon:hover,
.trade-hidden-chip:hover{
  border-color:rgba(242,107,58,0.26);
  color:#fff4ed;
}
.trade-layout-btn.active{
  background:rgba(242,107,58,0.12);
  border-color:rgba(242,107,58,0.26);
  box-shadow:0 0 0 1px rgba(242,107,58,0.1), 0 0 18px rgba(242,107,58,0.08);
}
.trade-panel-workspace{
  --trade-cols:12;
  --trade-row:72px;
  position:relative;
  display:grid;
  grid-template-columns:repeat(var(--trade-cols), minmax(0, 1fr));
  grid-auto-rows:var(--trade-row);
  gap:12px;
  min-height:calc(var(--trade-row) * 6 + 60px);
}
.trade-panel{
  position:relative;
  display:flex;
  flex-direction:column;
  min-width:0;
  min-height:0;
  padding:10px 10px 12px;
  border-radius:14px;
  border:1px solid rgba(242,107,58,0.18);
  background:linear-gradient(180deg, rgba(20,18,18,0.98), rgba(14,13,13,0.96));
  box-shadow:0 0 0 1px rgba(242,107,58,0.08), 0 18px 44px rgba(0,0,0,0.34), 0 0 28px rgba(242,107,58,0.08);
  overflow:hidden;
}
.trade-panel.is-hidden{display:none;}
.trade-panel.is-dragging{
  z-index:8;
  box-shadow:0 0 0 1px rgba(242,107,58,0.22), 0 22px 60px rgba(0,0,0,0.45), 0 0 36px rgba(242,107,58,0.16);
}
.trade-panel-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.trade-panel-heading{
  display:flex;
  align-items:center;
  gap:8px;
  font:600 12px/1 var(--font-body);
  color:#efe4dd;
  min-width:0;
}
.trade-panel-grip{
  appearance:none;
  border:1px solid transparent;
  background:transparent;
  color:rgba(242,107,58,0.82);
  cursor:grab;
  padding:0 2px;
  min-width:20px;
  font:700 14px/1 var(--font-mono);
  letter-spacing:-0.1em;
}
.trade-panel-grip:active{cursor:grabbing;}
.trade-panel-body{
  position:relative;
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
  padding-right:2px;
}
.trade-panel-body::-webkit-scrollbar{width:6px;height:6px;}
.trade-panel-body::-webkit-scrollbar-thumb{
  background:rgba(242,107,58,0.18);
  border-radius:999px;
}
.trade-panel-source,
.trade-panel-source.form-section{
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
.trade-panel-source .form-section-label,
.trade-panel-source .section-microtitle{
  display:none !important;
}
.trade-panel-resize{
  position:absolute;
  right:8px;
  bottom:8px;
  width:18px;
  height:18px;
  border:0;
  border-radius:6px;
  background:
    linear-gradient(135deg, transparent 0 38%, rgba(242,107,58,0.7) 38% 48%, transparent 48% 60%, rgba(242,107,58,0.42) 60% 70%, transparent 70%);
  cursor:nwse-resize;
  opacity:.24;
}
.trade-layout-editing .trade-panel-resize,
.trade-layout-editing .trade-panel-grip{
  opacity:1;
}
.trade-layout-hidden{
  margin-top:12px;
  padding:10px 12px;
  border:1px dashed rgba(242,107,58,0.18);
  border-radius:12px;
  background:rgba(255,255,255,0.015);
}
.trade-hidden-label{
  margin-bottom:8px;
  font:600 11px/1 var(--font-mono);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(242,107,58,0.82);
}
.trade-hidden-list{display:flex;gap:8px;flex-wrap:wrap;}
.trade-panel-workspace .fg3.mb-12{grid-template-columns:2fr 1fr 1.15fr !important;}
.trade-panel-workspace .form-section-risk .fg3{grid-template-columns:1.1fr 1fr 1fr !important;}
.trade-panel-workspace .form-section-risk .field:nth-child(2){grid-column:auto !important;}
.trade-panel-workspace .form-section-risk .field:nth-child(3){grid-column:auto !important;}
.trade-panel-workspace .lev-display{font-size:24px !important;}
.trade-panel-workspace .setup-btns{grid-template-columns:repeat(4,minmax(0,1fr));}
.trade-panel-workspace .em-grid{grid-template-columns:1fr;}
.trade-panel-workspace .fg3.mb-10{grid-template-columns:repeat(3,minmax(0,1fr));}
.trade-panel-workspace .field textarea{min-height:82px !important;}
.trade-layout-editing .trade-panel{
  outline:1px dashed rgba(242,107,58,0.34);
  outline-offset:0;
}
@media (max-width: 1080px){
  .trade-layout-toolbar{padding:10px;}
  .trade-panel-workspace{
    grid-template-columns:1fr;
    grid-auto-rows:auto;
    min-height:0;
  }
  .trade-panel{
    grid-column:auto !important;
    grid-row:auto !important;
    min-height:auto;
  }
  .trade-panel-resize,
  .trade-panel-grip,
  .trade-layout-toolbar{display:none;}
  .trade-panel-workspace .fg3.mb-10,
  .trade-panel-workspace .setup-btns,
  .trade-panel-workspace .fg3.mb-12,
  .trade-panel-workspace .form-section-risk .fg3,
  .trade-panel-workspace .compact-price-grid,
  .trade-panel-workspace .trade-metrics-grid{
    grid-template-columns:1fr !important;
  }
}

/* === PREMIUM LIGHT/DARK + AI SURFACES === */
:root {
  --orb-accent: #b8ff62;
  --orb-accent-strong: #9ae63a;
  --orb-accent-soft: rgba(184,255,98,0.16);
  --orb-accent-border: rgba(184,255,98,0.28);
  --orb-grid-line: rgba(184,255,98,0.07);
  --orb-surface-shadow: 0 20px 60px rgba(7, 12, 8, 0.35);
}

html[data-theme="dark"] {
  --a: var(--orb-accent);
  --a2: var(--orb-accent-soft);
  --a3: var(--orb-accent-border);
  --bg: #090d0a;
  --bg2: #101612;
  --bg3: #141d18;
  --bg4: #19231d;
  --t: #f4f8f1;
  --m: rgba(230, 238, 228, 0.62);
  --m2: rgba(230, 238, 228, 0.34);
  --bd: rgba(216, 232, 217, 0.1);
  --bd2: rgba(216, 232, 217, 0.18);
  --bd3: rgba(184,255,98,0.35);
}

html[data-theme="light"] {
  --a: #7acb2f;
  --a2: rgba(122, 203, 47, 0.1);
  --a3: rgba(122, 203, 47, 0.22);
  --bg: #f5f8f2;
  --bg2: rgba(255, 255, 255, 0.9);
  --bg3: #ffffff;
  --bg4: #eef4ea;
  --t: #172018;
  --m: rgba(23, 32, 24, 0.62);
  --m2: rgba(23, 32, 24, 0.38);
  --bd: rgba(23, 32, 24, 0.08);
  --bd2: rgba(23, 32, 24, 0.14);
  --bd3: rgba(122, 203, 47, 0.28);
  --line: 1px solid rgba(23, 32, 24, 0.08);
  --shadow: 0 18px 60px rgba(140, 161, 135, 0.16);
}

html[data-theme="light"] body,
html[data-theme="light"] .main {
  background: linear-gradient(180deg, #fbfdf8 0%, #f2f7ee 100%);
  color: var(--t);
}

html[data-theme="light"] .stat-cell,
html[data-theme="light"] .dash-card,
html[data-theme="light"] .coach-card,
html[data-theme="light"] .chat-sidebar,
html[data-theme="light"] .chat-main,
html[data-theme="light"] .trade-panel,
html[data-theme="light"] .trade-layout-toolbar,
html[data-theme="light"] .new-trade-card {
  background: rgba(255,255,255,0.86) !important;
  box-shadow: 0 18px 48px rgba(140, 161, 135, 0.14);
  border-color: rgba(23, 32, 24, 0.08) !important;
}

.main {
  position: relative;
  isolation: isolate;
}

.main::before {
  content: '';
  position: fixed;
  inset: 44px 0 0 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    linear-gradient(to right, var(--orb-grid-line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--orb-grid-line) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,0.86), transparent 82%);
  opacity: 0.6;
}

.stats-row,
#page-journal,
#page-aichat,
#page-coach {
  position: relative;
  z-index: 1;
}

.jnl-topbar .jtb-action-btn,
.apple-tool-btn {
  border-color: var(--a3);
  color: var(--a);
}

.jnl-topbar .jtb-action-btn:hover,
.apple-tool-btn:hover {
  background: var(--a2);
  color: var(--a);
  box-shadow: 0 8px 20px rgba(184,255,98,0.12);
}

.chat-layout {
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  gap: 18px;
  min-height: calc(100vh - 190px);
  height: auto;
}

.chat-sidebar,
.chat-main,
.coach-card,
.dash-card,
.mistake-card {
  border-radius: 22px;
  box-shadow: var(--orb-surface-shadow);
}

.chat-sidebar,
.chat-main {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)),
    var(--bg2);
  border: 1px solid var(--bd2);
}

.chat-main {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.chat-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 18px 20px 12px;
  border-bottom: 1px solid var(--bd);
}

.chat-context-rail {
  display: grid;
  grid-template-columns: minmax(220px, 1.1fr) minmax(0, 1.4fr);
  gap: 12px;
  padding: 14px 20px 0;
}

.chat-context-card,
.chat-mini-card,
.coach-summary-card,
.coach-rules-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid var(--bd);
  border-radius: 18px;
}

.chat-context-card {
  padding: 16px 18px;
}

.chat-context-eyebrow,
.coach-summary-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--a);
  margin-bottom: 8px;
}

.chat-context-title {
  font-family: var(--font-display);
  font-size: 20px;
  line-height: 1.1;
  color: var(--t);
  margin-bottom: 8px;
}

.chat-context-copy,
.coach-summary-text {
  font-size: 13px;
  line-height: 1.7;
  color: var(--m);
}

.chat-context-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.chat-mini-card {
  padding: 14px 14px 12px;
}

.chat-mini-card.good { border-color: rgba(52,211,153,0.28); }
.chat-mini-card.bad { border-color: rgba(248,113,113,0.25); }

.chat-mini-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--m2);
  margin-bottom: 7px;
}

.chat-mini-value {
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--t);
}

.chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 18px 20px;
}

.msg-avatar.ai {
  background: var(--a2);
  border: 1px solid var(--a3);
  color: var(--a);
}

.msg-avatar.user {
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--bd2);
  color: var(--t);
}

.msg-bubble {
  max-width: 80%;
  border-radius: 18px;
  padding: 12px 14px;
}

.chat-msg.ai .msg-bubble {
  background: rgba(255,255,255,0.04);
}

.chat-msg.user .msg-bubble {
  background: linear-gradient(135deg, var(--a2), rgba(255,255,255,0.03));
  color: var(--t);
}

.chat-input-area {
  padding: 16px 20px 20px;
  border-top: 1px solid var(--bd);
}

.chat-input-row {
  display: flex;
  align-items: flex-end;
  gap: 12px;
}

.chat-input {
  width: 100%;
  min-height: 56px;
  max-height: 180px;
  resize: none;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--bd2);
  background: rgba(255,255,255,0.04);
  color: var(--t);
  font: 500 14px/1.6 var(--font-body);
  outline: none;
}

.chat-input:focus {
  border-color: var(--a3);
  box-shadow: 0 0 0 4px rgba(184,255,98,0.08);
}

.chat-send {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--a), var(--orb-accent-strong));
  color: #112007;
  font-weight: 800;
  box-shadow: 0 18px 28px rgba(154, 230, 58, 0.2);
}

.coach-summary-card,
.coach-rules-card {
  padding: 16px 18px;
  margin-bottom: 12px;
}

.coach-rec-rich {
  padding: 16px 18px;
  border-radius: 18px;
  margin-bottom: 12px;
  border: 1px solid var(--bd);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015));
}

.coach-rec-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.coach-rec-title {
  font: 700 18px/1.2 var(--font-display);
  color: var(--t);
}

.coach-rec-detail {
  font-size: 13px;
  line-height: 1.65;
  color: var(--m);
  margin-bottom: 6px;
}

.coach-rec-detail span {
  color: var(--t);
  font-weight: 600;
}

.coach-rec-foot {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--m2);
}

.coach-positive-card {
  border-color: rgba(52,211,153,0.22);
}

.coach-rules-list {
  display: grid;
  gap: 8px;
}

.coach-rule-item {
  padding: 10px 12px;
  border: 1px solid var(--bd);
  border-radius: 12px;
  font-size: 13px;
  color: var(--t);
  background: rgba(255,255,255,0.03);
}

.psych-card-rich {
  border-radius: 16px;
  padding: 14px;
}

.mistake-card {
  background: linear-gradient(180deg, rgba(248,113,113,0.11), rgba(248,113,113,0.05));
  border-color: rgba(248,113,113,0.22);
}

.trade-layout-toolbar,
.trade-panel {
  border-color: var(--a3) !important;
  box-shadow:
    0 0 0 1px rgba(184,255,98,0.05),
    0 0 26px rgba(184,255,98,0.08),
    0 24px 40px rgba(7, 12, 8, 0.2);
}

.orb-preloader {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background:
    radial-gradient(circle at top, rgba(184,255,98,0.12), transparent 34%),
    linear-gradient(180deg, rgba(8,13,10,0.98), rgba(8,13,10,0.98));
  backdrop-filter: blur(10px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

.orb-preloader.is-ready {
  opacity: 0;
  transform: scale(1.02);
}

.orb-preloader-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: #f6fbf1;
}

.orb-preloader-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--a);
  box-shadow: 0 0 20px rgba(184,255,98,0.55);
}

.orb-preloader-line {
  width: 180px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--a), transparent);
}

.orb-preloader-copy {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(246,251,241,0.58);
}

@media (max-width: 1080px) {
  .chat-layout {
    grid-template-columns: 1fr;
  }

  .chat-context-rail {
    grid-template-columns: 1fr;
  }

  .chat-sidebar {
    order: 2;
  }

  .chat-main {
    order: 1;
  }
}

@media (max-width: 720px) {
  .chat-layout {
    min-height: calc(100dvh - 150px);
  }

  .chat-sidebar {
    display: block !important;
  }

  .chat-shortcuts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .chat-sc-text {
    font-size: 12px;
  }

  .chat-context-grid {
    grid-template-columns: 1fr 1fr;
  }

  .msg-bubble {
    max-width: 88%;
  }

  .psych-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════════
   CALM PRODUCT SYSTEM REFINEMENT (2026-04)
   ─ quiet visuals, 3-level containers, spacing/type/chip unification
   ═══════════════════════════════════════════════════════ */
:root {
  --space-8: 8px;
  --space-12: 12px;
  --space-16: 16px;
  --space-20: 20px;
  --space-24: 24px;
  --space-32: 32px;

  --radius-page: 20px;
  --radius-panel: 14px;
  --radius-component: 10px;

  --border-soft: 1px solid rgba(255,255,255,0.08);
  --panel-bg: rgba(17,17,20,0.9);
  --component-bg: rgba(255,255,255,0.025);

  --shadow-soft: 0 10px 28px rgba(0,0,0,0.22);
  --shadow-focus: 0 0 0 3px rgba(242,107,58,0.2);

  --type-page-title: 28px;
  --type-section-title: 20px;
  --type-card-title: 15px;
  --type-label: 11px;
  --type-helper: 12px;
  --type-kpi: 30px;
  --type-chip: 12px;
  --lh-tight: 1.2;
  --lh-base: 1.45;
  --fw-medium: 500;
  --fw-semibold: 600;
  --text-secondary: 0.62;
}

/* less texture + less glow = more calm */
body::before { opacity: 0.08 !important; }
body::after { opacity: 0.34 !important; }
.bg-o-1, .bg-o-2, .bg-o-3 { opacity: 0.3 !important; filter: blur(120px) !important; }
.apple-brand-mark { box-shadow: 0 0 14px rgba(242,107,58,0.14) !important; }
.stat-cell.glow-g, .stat-cell.glow-r, .stat-cell.glow-a { box-shadow: none !important; }

/* page-level container */
.main,
body.journal-apple-shell .main {
  max-width: 1420px !important;
  padding: calc(var(--apple-nav-h) + var(--space-24)) var(--space-24) var(--space-32) !important;
}

/* section-level panels */
.stats-row,
.level-bar,
.fcard,
.tcard,
.dash-card,
.coach-card,
.settings-card,
.pm-section-card,
.mc-card,
.hm-card {
  border: var(--border-soft) !important;
  border-radius: var(--radius-panel) !important;
  box-shadow: var(--shadow-soft) !important;
}

/* KPI row cleanup */
.stats-row {
  gap: var(--space-16) !important;
  margin-top: var(--space-20) !important;
  margin-bottom: var(--space-24) !important;
}
.stat-cell {
  min-height: 116px;
  padding: var(--space-16) var(--space-20) !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-8);
}
.stat-label {
  margin-bottom: 0 !important;
  font-size: var(--type-label) !important;
  line-height: var(--lh-tight);
  opacity: var(--text-secondary);
}
.stat-value {
  font-size: clamp(24px, 2.1vw, var(--type-kpi)) !important;
  line-height: 1.05;
}
.stat-cell:nth-child(3) .stat-value { font-size: clamp(28px, 2.4vw, 34px) !important; }
.stat-sub {
  font-size: var(--type-helper);
  line-height: var(--lh-tight);
  color: rgba(255,255,255,0.5);
}

/* form composition and hierarchy */
.fcard { padding: var(--space-24) !important; }
.fcard-title {
  font-size: var(--type-card-title) !important;
  font-weight: var(--fw-semibold);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-20) !important;
}
.form-section,
.em-section,
.trade-metrics,
.trade-metrics-grid,
.trade-layout-toolbar,
.trade-panel {
  border: var(--border-soft) !important;
  border-radius: var(--radius-component) !important;
  background: var(--component-bg) !important;
  box-shadow: none !important;
}
.form-section { padding: var(--space-16) !important; margin-bottom: var(--space-16) !important; }
.form-section-label,
.pm-section-title {
  font-size: var(--type-section-title) !important;
  line-height: var(--lh-tight);
  letter-spacing: -0.01em;
}

/* spacing normalization to 8/12/16/20/24/32 */
.fg2, .fg3, .fg4 { gap: var(--space-16) !important; margin-bottom: var(--space-16) !important; }
.field { gap: var(--space-8) !important; }
.field label,
.em-label,
.pkpi-label,
.trade-metric-label,
.section-microtitle {
  font-size: var(--type-label) !important;
  line-height: var(--lh-tight);
  opacity: var(--text-secondary);
}
.field input, .field select, .field textarea,
.pm-limit-input {
  min-height: 40px;
  border-radius: var(--radius-component) !important;
  border: var(--border-soft) !important;
  padding: var(--space-8) var(--space-12) !important;
  font-size: 13px !important;
  line-height: var(--lh-base);
}
.field input::placeholder,
.field textarea::placeholder,
.pm-limit-input::placeholder { color: rgba(255,255,255,0.36) !important; }
.field input:focus, .field select:focus, .field textarea:focus,
.pm-limit-input:focus,
.btn-add:focus,
.apple-tool-btn:focus,
.jtb-action-btn:focus,
.res-btn:focus,
.setup-btn:focus,
.dbtn:focus,
.em-opt:focus { box-shadow: var(--shadow-focus) !important; border-color: rgba(242,107,58,0.44) !important; }

/* one component system for chips / pills / selectable controls */
.res-btn,
.setup-btn,
.dbtn,
.em-opt,
.preset-color-btc,
.preset-color-eth,
.preset-color-sol,
.preset-color-bnb,
.preset-color-xrp,
.preset-color-doge,
.jtb-action-btn,
.apple-tool-btn {
  height: 34px;
  border-radius: 999px !important;
  border: var(--border-soft) !important;
  padding: 0 var(--space-12) !important;
  font-size: var(--type-chip) !important;
  font-weight: var(--fw-medium);
  line-height: 1;
  transition: background .16s ease, border-color .16s ease, color .16s ease;
}
.res-btn:hover,
.setup-btn:hover,
.dbtn:hover,
.em-opt:hover,
.jtb-action-btn:hover,
.apple-tool-btn:hover { border-color: rgba(255,255,255,0.16) !important; box-shadow: none !important; }

/* calmer active states */
.res-btn.active-win,
.dbtn.long.active { background: rgba(52,211,153,0.14) !important; }
.res-btn.active-loss,
.dbtn.short.active { background: rgba(248,113,113,0.14) !important; }
.res-btn.active-be,
.setup-btn.active,
.em-opt.active,
.tnav.active,
.jtb-nav.active,
.apple-nav-link.active,
.apple-menu.open .apple-nav-link { background: rgba(242,107,58,0.14) !important; border-color: rgba(242,107,58,0.36) !important; color: #fff !important; }

/* product-like desktop header alignment */
.apple-nav-inner {
  grid-template-columns: minmax(160px,auto) 1fr minmax(220px,auto) !important;
  gap: var(--space-20) !important;
  padding: 0 var(--space-24) !important;
}
.apple-nav-links { gap: var(--space-8) !important; }
.apple-nav-tools { gap: var(--space-8) !important; }
.apple-current-page {
  font-size: var(--type-helper) !important;
  opacity: 0.64;
  min-width: 94px;
}
.jtb-right { gap: var(--space-8) !important; }
.jtb-profile-btn {
  width: 34px !important;
  height: 34px !important;
  border-radius: 999px !important;
  border: var(--border-soft) !important;
}

/* maintain readable layout on tablet/mobile */
@media (max-width: 1080px) {
  .main, body.journal-apple-shell .main { padding: var(--space-20) var(--space-16) 110px !important; }
  .stats-row { gap: var(--space-12) !important; }
  .fcard { padding: var(--space-16) !important; }
}

/* final task alignment pass:
   remove remaining loud overrides, normalize New Trade spacing,
   and keep one calm component language across the page */
.trade-form-shell,
#add-trade-form {
  gap: var(--space-16) !important;
}

#add-trade-form > .form-section:not(.stray-analysis),
.trade-form-left .form-section,
.trade-form-right .form-section-prices {
  background: var(--component-bg) !important;
  border: var(--border-soft) !important;
  border-radius: var(--radius-component) !important;
  padding: var(--space-16) !important;
  box-shadow: none !important;
}

.trade-form-left,
.trade-form-right {
  gap: var(--space-16) !important;
}

.trade-form-left .form-section .form-section-label,
.trade-form-right .form-section .form-section-label,
#add-trade-form > .form-section .form-section-label {
  margin-bottom: var(--space-12) !important;
}

.form-section-num {
  box-shadow: none !important;
}

.form-section-risk .fg3 {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: var(--space-12) !important;
}

.lev-slider-wrap {
  gap: var(--space-12) !important;
}

.dtoggle,
.res-btns {
  border: var(--border-soft) !important;
  border-radius: 999px !important;
  padding: 2px !important;
  background: rgba(255,255,255,0.02) !important;
  gap: 2px !important;
}

.dbtn,
.res-btn {
  min-height: 34px !important;
  padding: 0 var(--space-12) !important;
  border-radius: 999px !important;
  border: 0 !important;
  box-shadow: none !important;
}

.dbtn.active,
.res-btn.active-win,
.res-btn.active-loss,
.res-btn.active-be {
  box-shadow: none !important;
}

.compact-price-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: var(--space-12) !important;
  margin-bottom: var(--space-16) !important;
}

.trade-metrics-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: var(--space-12) !important;
  margin: 0 !important;
}

.compact-price-grid .field,
.trade-metric-card {
  min-height: 52px;
  padding: var(--space-12) !important;
  border-radius: var(--radius-component) !important;
  border: var(--border-soft) !important;
  background: var(--component-bg) !important;
  box-shadow: none !important;
}

.trade-metric-label {
  font-size: var(--type-label) !important;
}

.trade-metric-value,
.rr-display {
  font-size: 13px !important;
}

.setup-btns {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-12) !important;
}

.setup-btn {
  width: 100%;
  justify-content: center;
}

.setup-btn.active {
  border-color: rgba(242,107,58,0.36) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.em-grid {
  grid-template-columns: 1fr !important;
  gap: var(--space-12) !important;
}

.em-row {
  background: var(--component-bg) !important;
  border: var(--border-soft) !important;
  border-radius: var(--radius-component) !important;
  padding: var(--space-12) !important;
  box-shadow: none !important;
}

.em-opt {
  min-height: 34px !important;
  padding: 0 var(--space-12) !important;
  font-size: var(--type-chip) !important;
}

.notes-compact,
#add-trade-form > .form-section:not(.stray-analysis) .fg3.mb-10 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-16) !important;
  margin-top: var(--space-16) !important;
}

#add-trade-form > .form-section:not(.stray-analysis) .field {
  gap: var(--space-8) !important;
}

#add-trade-form > .form-section:not(.stray-analysis) .field label {
  font-size: var(--type-label) !important;
  font-weight: var(--fw-medium) !important;
  color: rgba(244,240,236,0.62) !important;
}

#add-trade-form > .form-section:not(.stray-analysis) .field textarea {
  min-height: 88px !important;
  padding: var(--space-12) !important;
  border-radius: var(--radius-component) !important;
  resize: vertical;
  background: rgba(255,255,255,0.03) !important;
  border: var(--border-soft) !important;
  box-shadow: none !important;
}

#add-trade-form > .form-section:not(.stray-analysis) .field textarea:focus {
  border-color: rgba(242,107,58,0.44) !important;
  box-shadow: var(--shadow-focus) !important;
}

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-12) !important;
  align-items: center;
  margin-top: var(--space-16) !important;
}

.btn-ai,
.btn-add {
  min-height: 34px !important;
  border-radius: 999px !important;
  padding: 0 var(--space-16) !important;
  box-shadow: none !important;
}

.btn-ai {
  width: auto !important;
  min-width: 158px;
}

.btn-add {
  width: auto !important;
  min-width: 132px;
  background: rgba(242,107,58,0.14) !important;
  border: 1px solid rgba(242,107,58,0.24) !important;
  color: #fff !important;
  font-size: var(--type-chip) !important;
  font-weight: var(--fw-medium) !important;
  letter-spacing: 0 !important;
}

.btn-add:hover {
  background: rgba(242,107,58,0.2) !important;
  border-color: rgba(242,107,58,0.34) !important;
  transform: none !important;
  opacity: 1 !important;
}

.apple-nav-link.active,
.apple-menu.open .apple-nav-link {
  background: rgba(242,107,58,0.14) !important;
  border-color: rgba(242,107,58,0.24) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.apple-menu-panel {
  border: 1px solid rgba(255,255,255,0.09) !important;
  box-shadow: 0 20px 48px rgba(0,0,0,0.34) !important;
}

.apple-menu-item {
  border-radius: 12px !important;
  padding: var(--space-8) var(--space-12) !important;
  transition: background .16s ease, color .16s ease !important;
}

.apple-menu-item:hover {
  background: rgba(255,255,255,0.04) !important;
}

.apple-menu-item.active {
  background: rgba(242,107,58,0.12) !important;
  border: 1px solid rgba(242,107,58,0.18) !important;
  color: #fff !important;
  box-shadow: none !important;
}

@media (max-width: 1080px) {
  #add-trade-form {
    grid-template-columns: 1fr;
  }

  #add-trade-form > .trade-form-shell {
    display: block;
  }

  #add-trade-form > .form-section:not(.stray-analysis) {
    grid-column: auto;
  }

  .trade-form-shell {
    grid-template-columns: 1fr;
  }

  .notes-compact,
  #add-trade-form > .form-section:not(.stray-analysis) .fg3.mb-10 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .fg3.mb-12 {
    grid-template-columns: 1fr !important;
  }

  .form-section-risk .fg3 {
    grid-template-columns: 1fr 1fr !important;
  }

  .form-section-risk .field:nth-child(2),
  .form-section-risk .field:nth-child(3) {
    grid-column: 1 / -1;
  }

  .compact-price-grid,
  .trade-metrics-grid {
    grid-template-columns: 1fr !important;
  }

  .compact-price-grid .field-pnl-usd {
    grid-column: auto;
  }

  .setup-btns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .notes-compact,
  #add-trade-form > .form-section:not(.stray-analysis) .fg3.mb-10 {
    grid-template-columns: 1fr;
  }

  .btn-ai,
  .btn-add {
    min-width: 0;
    width: 100% !important;
  }

  .form-actions {
    flex-direction: column;
  }
}

/* final visual ergonomics pass */
.main,
body.journal-apple-shell .main {
  padding-top: calc(var(--apple-nav-h) + var(--space-32)) !important;
}

.stats-row {
  margin-top: var(--space-24) !important;
  margin-bottom: var(--space-32) !important;
}

.stat-cell {
  min-height: 128px !important;
  padding: var(--space-20) !important;
}

.stat-label,
.field label,
.em-label,
.trade-metric-label,
.section-microtitle,
.list-title {
  opacity: 0.72 !important;
}

.stat-value {
  font-size: clamp(26px, 2.2vw, 32px) !important;
}

.stat-sub {
  color: rgba(255,255,255,0.56) !important;
}

.form-section-num {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.7) !important;
  box-shadow: none !important;
}

.fcard-title {
  font-size: 16px !important;
}

.field input,
.field select,
.field textarea,
.pm-limit-input {
  min-height: 44px !important;
}

.trade-layout-toolbar {
  margin: 0 0 var(--space-12) !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  justify-content: flex-end !important;
}

.trade-layout-copy {
  display: none !important;
}

.trade-layout-title {
  font: 600 11px/1 var(--font-mono) !important;
  letter-spacing: 0.08em !important;
  color: rgba(244,240,236,0.72) !important;
}

.trade-layout-sub {
  color: rgba(255,255,255,0.42) !important;
}

.trade-layout-actions {
  gap: var(--space-8) !important;
}

.trade-layout-btn,
.trade-panel-icon,
.trade-hidden-chip {
  min-height: 34px !important;
  padding: 0 var(--space-12) !important;
  border: var(--border-soft) !important;
  background: rgba(255,255,255,0.03) !important;
  color: rgba(244,240,236,0.82) !important;
  box-shadow: none !important;
}

.trade-layout-btn.active {
  background: rgba(255,255,255,0.08) !important;
  border-color: rgba(255,255,255,0.16) !important;
}

.trade-panel-workspace {
  --trade-row: 84px;
  gap: var(--space-16) !important;
}

.trade-panel {
  padding: var(--space-16) !important;
  border-radius: var(--radius-panel) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  background: rgba(18,18,20,0.84) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18) !important;
}

.trade-panel-header {
  margin-bottom: var(--space-12) !important;
}

.trade-panel-actions {
  display: none !important;
}

.trade-panel-heading {
  gap: var(--space-8) !important;
  font: 600 12px/1.2 var(--font-body) !important;
  color: rgba(255,255,255,0.88) !important;
}

.trade-panel-icon,
.trade-panel-grip,
.trade-panel-resize {
  opacity: 0 !important;
  pointer-events: none !important;
}

.trade-layout-editing .trade-panel-icon,
.trade-layout-editing .trade-panel-grip,
.trade-layout-editing .trade-panel-resize {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.trade-hidden-label {
  color: rgba(255,255,255,0.56) !important;
}

.trade-hidden-chip:hover,
.trade-layout-btn:hover,
.trade-panel-icon:hover {
  border-color: rgba(255,255,255,0.16) !important;
  color: #fff !important;
}

.form-actions {
  margin-top: var(--space-20) !important;
}

.btn-ai,
.btn-add {
  min-height: 38px !important;
}

.btn-ai {
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.88) !important;
}

.btn-ai:hover {
  background: rgba(255,255,255,0.08) !important;
  border-color: rgba(255,255,255,0.12) !important;
  color: #fff !important;
  transform: none !important;
}

.btn-add {
  background: rgba(242,107,58,0.18) !important;
}

.apple-nav-link,
.apple-tool-btn {
  height: 32px !important;
  font-size: 12px !important;
}

.apple-current-page {
  font-size: 12px !important;
}

.list-head {
  margin-top: var(--space-24) !important;
  margin-bottom: var(--space-12) !important;
}

.fbtn {
  min-height: 32px !important;
  padding: 0 var(--space-12) !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  background: rgba(255,255,255,0.02) !important;
  color: rgba(255,255,255,0.62) !important;
}

.fbtn.active,
.fbtn:hover {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.12) !important;
  color: rgba(255,255,255,0.9) !important;
}
