/* ── RESET & ROOT ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100%}
.content{overflow-x:hidden}
html,body{height:100%;overflow:hidden}
:root{
  --bg:#0d0f0e;--bg2:#131614;--bg3:#191c1a;--bg4:#1e2220;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
  --text:#e8ede9;--text2:#a0a89f;--text3:#748a74;
  --green:#4ade80;--green-dim:#1a4a2a;--green-mid:#2d7a47;
  --red:#f87171;--red-dim:#4a1a1a;
  --yellow:#fbbf24;--yellow-dim:#3d2e08;
  --orange:#fb923c;--orange-dim:#3d1f08;
  --teal:#2dd4bf;--teal-dim:#0d3330;
  --nav-w:210px;
  --font:'DM Sans',sans-serif;--mono:'DM Mono',monospace;
  --radius:10px;--radius-lg:14px;
  --fs-base:15px;--fs-sm:13px;--fs-xs:11px;--fs-lg:17px;--fs-xl:21px;--fs-xxl:26px;
}
body.light-mode{
  --bg:#f4f6f4;--bg2:#ffffff;--bg3:#eef0ee;--bg4:#e4e8e4;
  --border:rgba(0,0,0,0.08);--border2:rgba(0,0,0,0.14);
  --text:#1a1f1a;--text2:#4a5a4a;--text3:#7a8a7a;
  --green-dim:#d4f4e0;--red-dim:#fde8e8;--yellow-dim:#fef3d0;
  --orange-dim:#feebd4;--teal-dim:#d4f4f0;
}
body.light-mode .cal-cell.profit-lo{background:#e8f5ec;border-color:#b2d9bc}
body.light-mode .cal-cell.profit-mid{background:#d4f0dc;border-color:#8ec9a0}
body.light-mode .cal-cell.profit-hi{background:#bbead0;border-color:#5aad7a}
body.light-mode .cal-cell.loss{background:#fde8e8;border-color:#e8a0a0;border-width:1.5px}
body.font-sm{--fs-base:13px;--fs-sm:11px;--fs-xs:10px;--fs-lg:15px;--fs-xl:18px;--fs-xxl:22px}
body.font-lg{--fs-base:17px;--fs-sm:15px;--fs-xs:13px;--fs-lg:19px;--fs-xl:24px;--fs-xxl:30px}
body.hide-fpo .fpo{display:none!important}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:var(--fs-base);display:flex;height:100vh;overflow:hidden}

/* ── LAYOUT SHELL ── */
.nav{width:var(--nav-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;overflow:hidden}
.main{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;min-width:0}
.topbar{flex-shrink:0;height:48px;padding:0 20px;display:flex;align-items:center;justify-content:space-between;background:var(--bg2);border-bottom:1px solid var(--border);gap:12px}
.content{flex:1;overflow-y:auto;padding:16px 20px;min-height:0}
.panel{display:none}.panel.active{display:block}

/* ── NAV ── */
.brand{padding:16px 12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand-logo{width:130px;height:auto;display:block;transition:all 0.28s cubic-bezier(0.4,0,0.2,1)}
.brand-logo-icon{width:44px;height:auto;display:none}
body.nav-collapsed .brand-logo{display:none}
body.nav-collapsed .brand-logo-icon{display:block}
body.nav-collapsed .brand{justify-content:flex-start;padding-left:14px}
.brand-icon{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,#2d7a47,#1a4a2a);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand-icon svg{width:15px;height:15px;stroke:#4ade80;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.brand-name{font-size:13px;font-weight:500;color:var(--text);letter-spacing:0.08em}
.brand-sub{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em}
.nav-body{padding:10px 8px;flex:1;overflow-y:auto}
.nav-slabel{font-size:9px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;padding:8px 10px 4px}
.nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;margin-bottom:1px;position:relative;color:var(--text2);transition:background 0.1s}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{background:var(--green-dim);color:var(--green)}
.nav-item.active::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:2px;background:var(--green);border-radius:0 2px 2px 0}
.nav-item svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.nav-item .label{font-size:12px;flex:1;text-transform:uppercase;letter-spacing:0.06em}
.nav-badge{font-size:10px;background:var(--red-dim);color:var(--red);border-radius:10px;padding:1px 6px;font-family:var(--mono)}
.nav-footer{padding:10px;border-top:1px solid var(--border);flex-shrink:0}
.import-btn{width:100%;padding:8px;border-radius:8px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-family:var(--font);transition:background 0.12s}
.import-btn:hover{background:var(--green-mid)}
.import-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── TOPBAR ── */
.topbar-left,.topbar-right{display:flex;align-items:center;gap:8px}
.page-title{font-size:13px;font-weight:500;color:var(--text)}
.dr-pills{display:flex;gap:3px}
.pill{font-size:var(--fs-xs);padding:4px 10px;border-radius:20px;cursor:pointer;border:1px solid var(--border2);color:var(--text2);background:transparent;font-family:var(--font);transition:all 0.1s}
.pill:hover{color:var(--text)}
.pill.active{background:var(--green-dim);color:var(--green);border-color:var(--green-mid)}
.toggle-pnl{display:flex;border:1px solid var(--border2);border-radius:8px;overflow:hidden}
.tpill{font-size:var(--fs-xs);padding:4px 10px;cursor:pointer;border:none;background:transparent;color:var(--text2);font-family:var(--font)}
.tpill.active{background:var(--green-dim);color:var(--green)}
.data-badge{font-size:10px;padding:3px 8px;border-radius:20px;font-family:var(--mono)}
.badge-manual{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(251,191,36,0.2)}
.badge-verified{background:var(--green-dim);color:var(--green);border:1px solid rgba(74,222,128,0.2)}
.reset-btn{font-size:9px;padding:2px 7px;border-radius:10px;background:transparent;border:1px solid var(--border);color:var(--text3);cursor:pointer;font-family:var(--font)}

/* ── TOOLTIP ── */
/* Trigger styling only — positioning handled by JS smart tooltip engine */
.has-tip{position:relative;cursor:help;border-bottom:1px dashed var(--text3)}
/* Inline .tip spans are hidden — content is read by JS and shown in #smartTip */
.tip{display:none!important}

/* Smart tooltip overlay — single shared element, JS-positioned */
#smartTip{
  position:fixed;
  z-index:9999;
  max-width:260px;
  padding:9px 12px;
  background:var(--bg4);
  border:1px solid var(--border2);
  border-radius:8px;
  font-size:12px;
  color:var(--text2);
  line-height:1.6;
  font-family:var(--font);
  font-weight:400;
  text-transform:none;
  letter-spacing:0;
  pointer-events:none;
  opacity:0;
  transition:opacity 0.15s;
  white-space:normal;
  word-break:break-word;
}
#smartTip.visible{opacity:1}
#smartTip::after{
  content:'';
  position:absolute;
  border:5px solid transparent;
}
#smartTip.tip-above::after{
  top:100%;left:var(--arrow-x,50%);
  transform:translateX(-50%);
  border-top-color:var(--border2);
}
#smartTip.tip-below::after{
  bottom:100%;left:var(--arrow-x,50%);
  transform:translateX(-50%);
  border-bottom-color:var(--border2);
}


.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}
.card-title{font-size:var(--fs-xs);font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px}
.pos{color:var(--green)!important}.neg{color:var(--red)!important}

/* ── SCOREBOARD ── */
.scoreboard{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.sb-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sb-item{display:flex;flex-direction:column;align-items:center}
.sb-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em}
.sb-val{font-family:var(--mono);font-size:15px;font-weight:500;color:var(--text)}
.sb-val.pos{color:var(--green)}.sb-val.neg{color:var(--red)}.sb-val.warn{color:var(--yellow)}
.sb-divider{width:1px;height:26px;background:var(--border2);flex-shrink:0}
.sb-source{font-size:10px;font-weight:500;padding:3px 8px;border-radius:10px;white-space:nowrap}
.sb-source.manual{background:var(--yellow-dim);color:var(--yellow)}
.sb-source.das{background:var(--green-dim);color:var(--green)}
.sb-reconcile{width:100%;padding-top:8px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:10px}
.sb-reconcile-label{color:var(--text3);white-space:nowrap}
.sb-reconcile-items{display:flex;gap:12px}
.sb-reconcile-item{font-family:var(--mono);color:var(--text3)}
.sb-reconcile-item span{color:var(--text2)}
.sb-delta{font-size:10px;font-family:var(--mono);padding:1px 6px;border-radius:4px}
.sb-delta.match{background:var(--green-dim);color:var(--green)}
.sb-delta.mismatch{background:var(--yellow-dim);color:var(--yellow)}

/* ── MANUAL INPUT ── */
.input-strikes-row{display:flex;gap:8px;margin-bottom:12px}
.manual-input-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;display:flex;align-items:center;gap:10px;flex:1}
.manual-label{font-size:var(--fs-xs);color:var(--text3);text-transform:uppercase;letter-spacing:0.06em;white-space:nowrap}
.pnl-input-group{display:flex;align-items:center;background:var(--bg4);border:1px solid var(--border2);border-radius:6px;overflow:hidden}
.pnl-prefix{font-family:var(--mono);font-size:14px;color:var(--text2);padding:5px 0 5px 10px}
.manual-input{background:transparent;border:none;color:var(--text);font-family:var(--mono);font-size:14px;padding:5px 8px 5px 4px;width:100px;outline:none}
.manual-update-btn{padding:6px 14px;border-radius:6px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:var(--fs-xs);font-family:var(--font);cursor:pointer}
.strikes-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;display:flex;align-items:center;gap:10px}
.strike-label{font-size:var(--fs-xs);color:var(--text3);text-transform:uppercase;letter-spacing:0.06em}
.strike-count{font-family:var(--mono);font-size:20px;font-weight:500;color:var(--text);min-width:28px;text-align:center}
.strike-count.warn{color:var(--red)}
.strike-btn{width:28px;height:28px;border-radius:6px;background:var(--bg4);border:1px solid var(--border2);color:var(--text2);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:var(--font);line-height:1}
.strike-btn:hover{background:var(--bg3);color:var(--text)}

/* ── STATE BANNER ── */
.state-banner{border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:12px;transition:all 0.3s}
.state-banner.s-neutral{background:var(--green-dim);border:1px solid var(--green-mid)}
.state-banner.s-yellow{background:var(--yellow-dim);border:1px solid rgba(251,191,36,0.3)}
.state-banner.s-orange{background:var(--orange-dim);border:1px solid rgba(251,146,60,0.3)}
.state-banner.s-red{background:var(--red-dim);border:1px solid rgba(248,113,113,0.3)}
.state-banner.s-teal{background:var(--teal-dim);border:1px solid rgba(45,212,191,0.3)}
.banner-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.banner-status{font-size:var(--fs-lg);font-weight:700;letter-spacing:0.04em}
.s-neutral .banner-status,.s-teal .banner-status{color:var(--green)}
.s-yellow .banner-status{color:var(--yellow)}
.s-orange .banner-status{color:var(--orange)}
.s-red .banner-status{color:var(--red)}
.banner-pnl{font-family:var(--mono);font-size:var(--fs-xl);font-weight:700;display:inline-flex;align-items:center;gap:6px}
.s-neutral .banner-pnl,.s-teal .banner-pnl{color:var(--green)}
.s-yellow .banner-pnl{color:var(--yellow)}
.s-orange .banner-pnl{color:var(--orange)}
.s-red .banner-pnl{color:var(--red)}
.banner-rules{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:4px}
.banner-rule{font-size:var(--fs-sm);padding:4px 8px;border-radius:5px}
.s-neutral .banner-rule{background:rgba(74,222,128,0.08);color:#86efac}
.s-yellow .banner-rule{background:rgba(251,191,36,0.08);color:#fcd34d}
.s-orange .banner-rule{background:rgba(251,146,60,0.08);color:#fdba74}
.s-red .banner-rule{background:rgba(248,113,113,0.08);color:#fca5a5}
.s-teal .banner-rule{background:rgba(45,212,191,0.08);color:#5eead4}
.strike-warn{margin-top:8px;padding:6px 10px;border-radius:6px;font-size:12px;font-weight:500;letter-spacing:0.05em;text-align:center}
.s-neutral .strike-warn,.s-teal .strike-warn{background:rgba(74,222,128,0.15);color:var(--green)}
.s-yellow .strike-warn{background:rgba(251,191,36,0.15);color:var(--yellow)}
.s-orange .strike-warn{background:rgba(251,146,60,0.15);color:var(--orange)}
.s-red .strike-warn{background:rgba(248,113,113,0.15);color:var(--red)}

/* ── MARKET CLOSED STATE ── */
.state-banner.s-closed{background:var(--bg2);border:1px solid var(--border)}
.s-closed .banner-status{color:var(--text3);font-size:13px;font-weight:400;letter-spacing:0.02em}
.s-closed .banner-pnl{display:none}
.s-closed .banner-rules{display:none}
.s-closed .banner-top{margin-bottom:0}
.s-closed .strike-warn{display:none!important}

/* ── STOP TRADING LOCKOUT (3+ strikes) ── */
.state-banner.s-lockout{background:#2a0808;border:1.5px solid rgba(248,113,113,0.5)}
.s-lockout .banner-status{display:none}
.s-lockout .banner-pnl{display:none}
.s-lockout .banner-rules{display:none}
.banner-lockout-msg{display:none;text-align:center;padding:6px 0 4px}
.s-lockout .banner-lockout-msg{display:block}
.lockout-headline{font-size:20px;font-weight:500;letter-spacing:0.06em;color:var(--red);line-height:1.3}
.lockout-sub{font-size:13px;color:#fca5a5;margin-top:6px;letter-spacing:0.04em}
.lockout-reset-btn{margin-top:14px;padding:7px 18px;border-radius:7px;background:rgba(248,113,113,0.15);border:1px solid rgba(248,113,113,0.35);color:var(--red);font-size:11px;font-family:var(--font);cursor:pointer;letter-spacing:0.04em}
.lockout-reset-btn:hover{background:rgba(248,113,113,0.25)}

/* ── STRIKES CARD RED STATE ── */
.strikes-card.strikes-danger{background:var(--red-dim);border-color:rgba(248,113,113,0.35)}
.strikes-card.strikes-danger .strike-count{color:var(--red)}

/* ── GOAL CARDS ── */
.goal-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.goal-card.g-neutral{background:var(--bg2)}
.goal-card.g-hit{background:var(--green-dim);border-color:var(--green-mid)}
.goal-card.g-unlock{background:#2d1f00;border-color:rgba(251,191,36,0.3)}
.goal-card.g-teal{background:var(--teal-dim);border-color:rgba(45,212,191,0.3)}
.goal-card.g-danger{background:var(--red-dim);border-color:rgba(248,113,113,0.3)}
.gc-label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:6px}
.g-neutral .gc-label{color:var(--text3)}.g-hit .gc-label{color:#4ade80}.g-unlock .gc-label{color:var(--yellow)}.g-teal .gc-label{color:var(--teal)}.g-danger .gc-label{color:var(--red)}
.gc-val{font-size:var(--fs-xxl);font-weight:500;font-family:var(--mono);margin-bottom:2px}
.g-neutral .gc-val{color:var(--text)}.g-hit .gc-val{color:var(--green)}.g-unlock .gc-val{color:var(--yellow)}.g-teal .gc-val{color:var(--teal)}.g-danger .gc-val{color:var(--red)}
.gc-sub{font-size:var(--fs-xs)}
.g-neutral .gc-sub{color:var(--text3)}.g-hit .gc-sub{color:#86efac}.g-unlock .gc-sub{color:#fcd34d}.g-teal .gc-sub{color:#5eead4}.g-danger .gc-sub{color:#fca5a5}

/* ── GOAL PROGRESS ── */
.goal-progress-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px 22px;margin-bottom:12px}
.gp-title{font-size:var(--fs-sm);font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:14px}
.gp-outer{position:relative;height:78px;margin:0 6px}
.gp-rail{position:absolute;left:0;right:0;top:34px;height:7px;border-radius:99px;background:var(--bg4)}
.gp-fill{position:absolute;top:0;height:100%;border-radius:99px;transition:left 0.55s cubic-bezier(0.34,1.56,0.64,1),width 0.55s cubic-bezier(0.34,1.56,0.64,1),background 0.3s ease}
.gp-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;border:2px solid var(--bg2);transition:left 0.55s cubic-bezier(0.34,1.56,0.64,1),background 0.3s ease;pointer-events:none}
.gp-zero-tick{position:absolute;top:-6px;bottom:-6px;width:2px;background:var(--border2);transform:translateX(-50%)}
.gp-tick{position:absolute;top:-4px;bottom:-4px;width:1px;background:var(--border);transform:translateX(-50%)}
.gp-lbl-above{position:absolute;font-size:12px;font-family:var(--mono);font-weight:600;white-space:nowrap;color:var(--text3);line-height:1}
.gp-lbl-below{position:absolute;font-size:13px;font-family:var(--mono);font-weight:700;white-space:nowrap;line-height:1;transition:left 0.55s cubic-bezier(0.34,1.56,0.64,1),color 0.3s ease}
.gp-zone-label{position:absolute;font-size:9px;font-weight:600;letter-spacing:0.1em;color:var(--text3);text-transform:uppercase;white-space:nowrap}

/* ── STREAKS ── */
.streak-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.streak-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;gap:20px;position:relative}
.streak-main{display:flex;flex-direction:column;align-items:center;min-width:68px;padding-right:20px;border-right:1px solid var(--border)}
.streak-num{font-family:var(--mono);font-size:44px;font-weight:300;line-height:1}
.streak-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text3);margin-top:5px;text-align:center}
.streak-1x .streak-num{color:var(--green)}.streak-2x .streak-num{color:var(--teal)}.streak-green .streak-num{color:#86efac}
.streak-body{flex:1;min-width:0}
.streak-info-label{font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text3);margin-bottom:4px}
.streak-info-sub{font-size:var(--fs-sm);color:var(--text2);margin-bottom:8px}
.streak-tip{position:absolute;top:10px;right:10px;width:16px;height:16px;border-radius:50%;border:1px solid var(--border2);background:var(--bg3);font-size:9px;color:var(--text3);display:flex;align-items:center;justify-content:center;cursor:help;font-weight:600}

/* ── METRICS ── */
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(88px,1fr));gap:8px;margin-bottom:12px}
.mc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px}
.mc-label{font-size:var(--fs-xs);color:var(--text3);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.06em}
.mc-val{font-size:var(--fs-xl);font-weight:500;font-family:var(--mono);color:var(--text)}
.mc-val.pos{color:var(--green)}.mc-val.neg{color:var(--red)}

/* ── PULSE CHECKS ── */
.pulse-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.pulse-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;transition:border-color 0.3s}
.pulse-card.pulse-strong{border-color:rgba(74,222,128,0.35)}
.pulse-card.pulse-slow{border-color:rgba(251,191,36,0.35)}
.pulse-card.pulse-caution{border-color:rgba(251,146,60,0.35)}
.pulse-card.pulse-lockin{border-color:rgba(45,212,191,0.35)}
.pulse-card.pulse-protect{border-color:rgba(251,191,36,0.35)}
.pulse-card.pulse-walkaway{border-color:rgba(248,113,113,0.35)}
.pulse-time-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.pulse-time-label{font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text2)}
.pulse-status{font-size:var(--fs-xs);padding:2px 8px;border-radius:10px;font-weight:500}
.ps-good{background:var(--green-dim);color:var(--green)}
.ps-warn{background:var(--red-dim);color:var(--red)}
.ps-neutral{background:var(--yellow-dim);color:var(--yellow)}
.ps-orange{background:var(--orange-dim);color:var(--orange)}
.ps-teal{background:var(--teal-dim);color:var(--teal)}
.ps-pending{background:var(--bg4);color:var(--text3)}
.pulse-pnl{font-family:var(--mono);font-size:20px;font-weight:500;margin-bottom:3px}
.pulse-meta{font-size:var(--fs-sm);color:var(--text2)}
.pulse-drift{margin-top:8px;padding-top:7px;border-top:1px solid var(--border);font-size:var(--fs-xs);font-family:var(--mono);color:var(--text3)}
.pulse-drift .drift-up{color:var(--green)}.pulse-drift .drift-down{color:var(--red)}.pulse-drift .drift-flat{color:var(--text3)}
.pulse-resnap-btn{font-size:10px;padding:1px 5px;border-radius:6px;background:transparent;border:1px solid var(--border2);color:var(--text3);cursor:pointer;font-family:var(--font);line-height:1.4}
.pulse-resnap-btn:hover{background:var(--bg3);color:var(--text)}

/* ── CHARTS ── */
/* ── DASHBOARD HERO EQUITY CARD ── */
.dash-hero-card{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:18px 20px 16px;margin-bottom:10px;position:relative}
.dash-hero-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.dash-hero-title{font-size:10px;font-weight:700;letter-spacing:0.1em;color:var(--text3);text-transform:uppercase;display:flex;align-items:center;gap:10px}
.dash-hero-sub{font-size:9px;font-weight:400;color:var(--text3);letter-spacing:0.04em;text-transform:none;opacity:0.7}
.dash-chart-expand-btn{background:none;border:none;color:var(--text3);font-size:14px;cursor:pointer;padding:2px 4px;border-radius:4px;opacity:0;transition:opacity 0.15s,color 0.15s;line-height:1}
.dash-hero-card:hover .dash-chart-expand-btn,.dash-trio-card:hover .dash-chart-expand-btn{opacity:1}
.dash-chart-expand-btn:hover{color:var(--text)}

/* ── HORIZONTAL STAT BAR ── */
.dash-stat-bar{display:flex;align-items:stretch;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;margin-bottom:10px;overflow:hidden}
.dash-stat-pill{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;gap:5px;min-width:0}
.dash-stat-label{font-size:9px;font-weight:600;letter-spacing:0.07em;color:var(--text3);text-transform:uppercase;text-align:center;white-space:nowrap}
.dash-stat-val{font-family:var(--mono);font-size:14px;font-weight:500;color:var(--text);text-align:center}
.dash-stat-divider{width:1px;background:var(--border);flex-shrink:0;margin:10px 0}

/* ── 3-COLUMN SUPPORTING CHARTS ── */
.dash-charts-trio{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:12px}
.dash-trio-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 16px 14px;position:relative;cursor:pointer;transition:border-color 0.15s}
.dash-trio-card:hover{border-color:var(--border2)}
.dash-trio-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dash-trio-title{font-size:10px;font-weight:700;letter-spacing:0.1em;color:var(--text3);text-transform:uppercase}
/* Hour chart HTML legend */
.dash-hour-legend{display:flex;align-items:center;gap:10px;margin-left:auto;margin-right:6px}
.dhl-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text3)}
.dhl-swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}
.dhl-green{background:rgba(74,222,128,0.7)}
.dhl-amber{background:rgba(251,191,36,0.9);border-radius:50%}

/* ── CHART EXPAND MODAL ── */
.dash-chart-modal{position:fixed;inset:0;background:rgba(0,0,0,0.72);z-index:9000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.dash-chart-modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:24px;width:min(860px,92vw);max-height:90vh;overflow:auto}
.dash-chart-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.dash-chart-modal-title-wrap{display:flex;flex-direction:column;gap:3px}
.dash-chart-modal-title{font-size:13px;font-weight:700;letter-spacing:0.08em;color:var(--text);text-transform:uppercase}
.dash-chart-modal-sub{font-size:11px;color:var(--text3);font-weight:400;letter-spacing:0.02em}
.dash-chart-modal-close{background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;padding:2px 6px;border-radius:4px;transition:color 0.15s}
.dash-chart-modal-close:hover{color:var(--text)}
.dash-modal-camera-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text3);cursor:pointer;padding:5px 8px;display:flex;align-items:center;transition:color 0.15s,border-color 0.15s}
.dash-modal-camera-btn:hover{color:var(--text);border-color:var(--border2)}

/* ── DASHBOARD ENTRY ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scaleY(0.92)}to{opacity:1;transform:scaleY(1)}}

/* Hero equity card */
.dash-hero-card{animation:fadeUp 0.4s cubic-bezier(0.4,0,0.2,1) both}
/* Stat bar fades in slightly after */
.dash-stat-bar{animation:fadeUp 0.4s cubic-bezier(0.4,0,0.2,1) 0.07s both}
/* Trio cards staggered */
.dash-charts-trio .dash-trio-card:nth-child(1){animation:fadeUp 0.4s cubic-bezier(0.4,0,0.2,1) 0.12s both}
.dash-charts-trio .dash-trio-card:nth-child(2){animation:fadeUp 0.4s cubic-bezier(0.4,0,0.2,1) 0.18s both}
.dash-charts-trio .dash-trio-card:nth-child(3){animation:fadeUp 0.4s cubic-bezier(0.4,0,0.2,1) 0.24s both}
/* Insight cards staggered */
.dash-insights-grid .dash-insight-card:nth-child(1){animation:fadeUp 0.38s cubic-bezier(0.4,0,0.2,1) 0.28s both}
.dash-insights-grid .dash-insight-card:nth-child(2){animation:fadeUp 0.38s cubic-bezier(0.4,0,0.2,1) 0.34s both}
.dash-insights-grid .dash-insight-card:nth-child(3){animation:fadeUp 0.38s cubic-bezier(0.4,0,0.2,1) 0.40s both}
/* Streak cards */
.streak-section .streak-card:nth-child(1){animation:fadeUp 0.38s cubic-bezier(0.4,0,0.2,1) 0.32s both}
.streak-section .streak-card:nth-child(2){animation:fadeUp 0.38s cubic-bezier(0.4,0,0.2,1) 0.38s both}
.streak-section .streak-card:nth-child(3){animation:fadeUp 0.38s cubic-bezier(0.4,0,0.2,1) 0.44s both}
/* Metric cards */
.metrics-grid .mc:nth-child(1){animation:fadeUp 0.35s cubic-bezier(0.4,0,0.2,1) 0.05s both}
.metrics-grid .mc:nth-child(2){animation:fadeUp 0.35s cubic-bezier(0.4,0,0.2,1) 0.10s both}
.metrics-grid .mc:nth-child(3){animation:fadeUp 0.35s cubic-bezier(0.4,0,0.2,1) 0.15s both}
.metrics-grid .mc:nth-child(4){animation:fadeUp 0.35s cubic-bezier(0.4,0,0.2,1) 0.20s both}
.metrics-grid .mc:nth-child(5){animation:fadeUp 0.35s cubic-bezier(0.4,0,0.2,1) 0.25s both}
.metrics-grid .mc:nth-child(6){animation:fadeUp 0.35s cubic-bezier(0.4,0,0.2,1) 0.30s both}
/* Best/worst cards */
.bw-card{animation:fadeUp 0.38s cubic-bezier(0.4,0,0.2,1) 0.28s both}
/* Risk items */
.risk-item{animation:fadeIn 0.4s ease 0.35s both}
/* Modal entry */
.dash-chart-modal-box{animation:scaleIn 0.22s cubic-bezier(0.4,0,0.2,1) both}
/* ── DEEP STATS ── */
.deep-stats-grid{display:flex;align-items:stretch;margin-bottom:10px}
.deep-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}
.deep-title{font-size:var(--fs-xs);font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px}
.deep-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:var(--fs-sm)}
.deep-row:last-child{border-bottom:none}
.deep-key{color:var(--text2)}.deep-val{font-family:var(--mono);color:var(--text)}

/* ── TABLES ── */
.sym-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:12px;overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.data-table th{text-align:left;padding:5px 8px;color:var(--text3);font-weight:500;border-bottom:1px solid var(--border);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:0.06em}
.data-table td{padding:7px 8px;border-bottom:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:var(--fs-sm)}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg3)}

/* ── BEST/WORST ── */
.bw-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.bw-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
.bw-card.best{border-left:2px solid var(--green-mid)}.bw-card.worst{border-left:2px solid #7a2d2d}
.bw-label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:6px}
.best .bw-label{color:var(--green)}.worst .bw-label{color:var(--red)}
.bw-sym{font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px}
.bw-pnl{font-family:var(--mono);font-size:20px;font-weight:500;margin-bottom:4px}
.bw-meta{font-size:var(--fs-sm);color:var(--text2)}

/* ── RISK ── */
.risk-section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:12px}
.risk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.risk-item{background:var(--bg3);border-radius:8px;padding:10px 12px}
.risk-name{font-size:var(--fs-xs);color:var(--text3);margin-bottom:3px;text-transform:uppercase;letter-spacing:0.05em}
.risk-val{font-family:var(--mono);font-size:14px;color:var(--text)}

/* ── CALENDAR ── */
.cal-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.cal-nav{display:flex;align-items:center;gap:8px}
.cal-nav-btn{width:28px;height:28px;border-radius:6px;background:var(--bg2);border:1px solid var(--border);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px}
.cal-nav-btn:hover{background:var(--bg3)}
.cal-month{font-size:14px;font-weight:600;min-width:150px;text-align:center;text-transform:uppercase;letter-spacing:0.06em;color:var(--yellow)}
.cal-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;margin-bottom:12px}
.cal-sum-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px}
.cal-sum-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:3px}
.cal-sum-val{font-size:20px;font-weight:500;font-family:var(--mono)}
.cal-sum-val.pos{color:var(--green)}.cal-sum-val.neg{color:var(--red)}
.cal-sum-sub{font-size:11px;color:var(--text3);margin-top:2px}
.cal-streak-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.rpt-dd-standalone{margin-bottom:4px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:12px}
.cal-grid-8{display:grid;grid-template-columns:repeat(8,1fr);gap:3px;margin-bottom:0}
.cal-dow-total{color:var(--text2);font-size:12px;letter-spacing:0.06em;border-left:1px solid var(--border);padding-left:6px}
.cal-week-total-cell{background:rgba(56,100,200,0.18);border:1px solid rgba(80,130,255,0.35);border-radius:8px;padding:10px 10px;min-height:96px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;border-left:3px solid rgba(80,130,255,0.6)}
.cal-wk-label{font-size:11px;font-weight:700;color:rgba(140,170,255,0.8);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:8px}
.cal-wk-pnl{font-family:var(--mono);font-size:18px;font-weight:700;margin-bottom:4px}
.cal-wk-pnl.pos{color:var(--green)}.cal-wk-pnl.neg{color:var(--red)}
.cal-wk-trades{font-size:13px;color:var(--text3)}
.cal-wk-sep{display:none}
.cal-dow{font-size:12px;color:var(--text2);text-align:center;padding:4px 0 6px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em}
.cal-dow.weekend{opacity:0.35}
.cal-cell{border:1px solid var(--border);border-radius:8px;padding:8px 6px;min-height:96px;background:var(--bg2);position:relative;transition:all 0.1s;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.cal-cell.empty{background:transparent;border-color:transparent}
.cal-cell.weekend-cell{opacity:0.35}
.cal-cell.has-trades{cursor:pointer}
.cal-cell.has-trades:hover{border-color:var(--border2)}
.cal-cell.profit-lo{background:#0d1a0f;border-color:#1e3d22}
.cal-cell.profit-mid{background:#0f2114;border-color:#2d5a35}
.cal-cell.profit-hi{background:#133020;border-color:#3a7a44}
.cal-cell.loss{background:#1f0f0f;border-color:#5a2d2d;border-width:1.5px}
.cal-cell.today{outline:2px solid var(--green-mid);outline-offset:-1px}
.cal-cell.out-of-range{opacity:0.18;pointer-events:none}
.cal-cell.out-of-range.has-trades{opacity:0.32;pointer-events:auto;cursor:pointer}
.cal-day-num{font-size:13px;color:var(--text3);margin-bottom:4px;font-family:var(--mono);align-self:flex-start}
.cal-cell.profit-lo .cal-day-num,.cal-cell.profit-mid .cal-day-num,.cal-cell.profit-hi .cal-day-num{color:var(--green)}
.cal-cell.loss .cal-day-num{color:var(--red)}
.cal-pnl{font-size:16px;font-weight:400;font-family:var(--mono);text-align:center}
.cal-cell.profit-lo .cal-pnl,.cal-cell.profit-mid .cal-pnl,.cal-cell.profit-hi .cal-pnl{color:var(--green)}
.cal-cell.loss .cal-pnl{color:var(--red)}
.cal-winrate{font-size:13px;color:var(--text2);margin-top:2px;text-align:center}
.cal-trades{font-size:13px;color:var(--text2);margin-top:2px;text-align:center}
.cal-badges{position:absolute;bottom:5px;right:5px;display:flex;gap:2px}
.cal-badge{width:7px;height:7px;border-radius:50%}
.badge-1x{background:var(--green)}.badge-2x{background:var(--teal)}
.cal-cell.loss::after{content:'';position:absolute;top:5px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--red);opacity:0.7}
.cal-legend{display:flex;gap:12px;font-size:var(--fs-sm);color:var(--text3);flex-wrap:wrap;margin-top:8px}
.cal-day-trade-row:hover td{background:var(--bg3);}

/* ── CHART MODAL ── */
#chartModal{display:none}
#chartModal.open{display:flex}
.chart-ind-btn{font-size:10px;padding:3px 8px;border-radius:6px;background:var(--bg4);border:1px solid var(--border2);color:var(--text3);cursor:pointer;font-family:var(--font);font-weight:500;transition:all 0.1s}
.chart-ind-btn.active{background:var(--green-dim);border-color:var(--green-mid);color:var(--green)}
.chart-ind-btn:hover{color:var(--text);border-color:var(--border2)}


.import-slots{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-top:10px}
.import-slot{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;text-align:center;transition:border-color 0.2s}
.import-slot.loaded{border-color:rgba(74,222,128,0.4);background:var(--green-dim)}
.import-slot.loaded .slot-status{color:var(--green)}
.slot-icon{font-size:18px;margin-bottom:4px}
.slot-name{font-size:var(--fs-xs);font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:3px}
.slot-status{font-size:10px;color:var(--text3);font-family:var(--mono)}
.import-reconcile{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:12px}
.recon-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:var(--fs-sm)}
.recon-row:last-child{border-bottom:none;padding-top:8px;margin-top:2px}
.recon-label{color:var(--text2)}.recon-val{font-family:var(--mono);color:var(--text)}
.recon-row.recon-total .recon-label{font-weight:600;color:var(--text);font-size:13px}
.recon-row.recon-total .recon-val{font-size:14px;font-weight:600}
.recon-source{font-size:9px;color:var(--text3);margin-left:8px;font-family:var(--font)}


.drop-zone{border:1.5px dashed var(--border2);border-radius:var(--radius-lg);padding:32px 16px;text-align:center;cursor:pointer;background:var(--bg2);transition:background 0.12s}
.drop-zone:hover,.drop-zone.over{background:var(--green-dim);border-color:var(--green-mid)}
.drop-zone.paste-flash{background:var(--green-dim);border-color:var(--green)}
.dz-icon{margin-bottom:10px}
.dz-icon svg{width:32px;height:32px;stroke:var(--green-mid);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.dz-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:4px}
.dz-sub{font-size:12px;color:var(--text2)}
.dz-sub span{color:var(--green);cursor:pointer}
.import-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:16px}
.import-tab{font-size:12px;padding:8px 16px;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;margin-bottom:-1px}
.import-tab:hover{color:var(--text)}
.import-tab.active{color:var(--green);border-bottom-color:var(--green)}
.log-line{font-size:var(--fs-sm);font-family:var(--mono);padding:5px 0;border-bottom:1px solid var(--border);color:var(--text2)}
.log-line:last-child{border-bottom:none}
.log-t{color:var(--text3);margin-right:10px}
.log-ok{color:var(--green)}.log-warn{color:var(--yellow)}
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(88px,1fr));gap:6px;margin-bottom:14px}
.result-badge{font-size:var(--fs-xs);padding:2px 7px;border-radius:10px;font-weight:500}
.rb-win{background:var(--green-dim);color:var(--green)}.rb-loss{background:var(--red-dim);color:var(--red)}

/* ── SETTINGS ── */
.settings-section{margin-bottom:8px}
.settings-section-title{font-size:var(--fs-base);font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.settings-field{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
.field-label{font-size:var(--fs-xs);color:var(--text3);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:6px}
.field-input{background:var(--bg4);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--mono);font-size:13px;padding:6px 10px;width:100%;outline:none}
.field-input:focus{border-color:var(--green-mid)}
/* Collapsible setting groups */
.sg-header{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;cursor:pointer;border-radius:var(--radius);background:var(--bg2);border:1px solid var(--border);margin-bottom:2px;user-select:none}
.sg-header:hover{background:var(--bg3)}
.sg-header.open{border-radius:var(--radius) var(--radius) 0 0;border-bottom-color:transparent;margin-bottom:0}
.sg-title{font-size:14px;font-weight:600;color:var(--yellow);text-transform:uppercase;letter-spacing:0.08em}
.sg-chevron{font-size:10px;color:var(--text3);transition:transform 0.2s}
.sg-header.open .sg-chevron{transform:rotate(180deg)}
.sg-body{display:none;background:var(--bg2);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:4px 0 8px;margin-bottom:8px}
.sg-body.open{display:block}
.sg-body .settings-section{margin-bottom:0;padding:0 14px}
.sg-body .settings-section-title{font-size:12px;color:var(--text3);letter-spacing:0.06em;padding-top:12px}
.sg-body .card{border-left:none;border-right:none;border-radius:0;border-top:none;border-bottom:1px solid var(--border)}
.sg-body>div:last-child .card{border-bottom:none}
.rule-row{display:flex;align-items:center;gap:24px;padding:7px 0;border-bottom:1px solid var(--border)}
.rule-row:last-child{border-bottom:none}
.rule-num{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono);min-width:20px}
.rule-input{background:transparent;border:none;color:var(--text);font-family:var(--font);font-size:12px;flex:1;max-width:560px;outline:none;padding:2px 6px;border-radius:4px}
.rule-input:focus{background:var(--bg4)}
.setting-row-item{display:flex;align-items:center;justify-content:flex-start;gap:24px;padding:9px 0;border-bottom:1px solid var(--border)}
.setting-row-item:last-child{border-bottom:none}
.setting-name{font-size:var(--fs-base);color:var(--text);font-weight:500}
.setting-desc{font-size:var(--fs-sm);color:var(--text3);margin-top:2px}
.setting-row-item>div:first-child{flex:1;min-width:0;max-width:600px}
.tog{width:30px;height:17px;border-radius:9px;position:relative;cursor:pointer;transition:background 0.15s;flex-shrink:0}
.tog.on{background:var(--green-mid)}.tog.off{background:var(--bg4);border:1px solid var(--border2)}
.tog-thumb{width:13px;height:13px;background:#fff;border-radius:50%;position:absolute;top:2px;transition:left 0.15s}
.tog.on .tog-thumb{left:15px}.tog.off .tog-thumb{left:2px}
.theme-font-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.theme-btn,.font-btn{font-size:var(--fs-sm);padding:5px 14px;border-radius:6px;cursor:pointer;border:1px solid var(--border2);background:var(--bg4);color:var(--text2);font-family:var(--font)}
.theme-btn.active,.font-btn.active{background:var(--green-dim);border-color:var(--green-mid);color:var(--green)}
.save-btn{padding:9px 20px;border-radius:8px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:12px;font-family:var(--font);cursor:pointer}
.save-btn:hover{background:var(--green-mid)}
.btn-sm{font-size:var(--fs-sm);padding:6px 12px;border-radius:6px;background:var(--bg2);border:1px solid var(--border2);color:var(--text2);cursor:pointer;font-family:var(--font)}
.btn-sm:hover{background:var(--bg3);color:var(--text)}

/* ── TRADES PANEL ── */
.trades-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.trades-filter-input{background:var(--bg4);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--mono);font-size:11px;padding:5px 9px;outline:none;height:28px}
.trades-filter-input:focus{border-color:var(--green-mid)}
.trades-filter-select{background:var(--bg4);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--font);font-size:11px;padding:4px 8px;outline:none;height:28px;cursor:pointer}
.trades-filter-select:focus{border-color:var(--green-mid)}
.trades-clear-btn{font-size:10px;padding:4px 10px;border-radius:6px;background:transparent;border:1px solid var(--border2);color:var(--text3);cursor:pointer;font-family:var(--font);height:28px}
.trades-clear-btn:hover{color:var(--text);border-color:var(--border)}
.trades-reimport-btn{font-size:10px;padding:4px 10px;border-radius:6px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);cursor:pointer;font-family:var(--font);height:28px;margin-left:auto}
.trades-reimport-btn:hover{background:var(--green-mid)}
.ts-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;flex:1;min-width:90px}
.ts-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:3px}
.ts-val{font-family:var(--mono);font-size:15px;font-weight:500;color:var(--text)}
.ts-val.pos{color:var(--green)}.ts-val.neg{color:var(--red)}
.trades-table-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:12px}
.trades-table{width:100%;border-collapse:collapse;font-size:var(--fs-base)}
.trades-table th{padding:9px 12px;color:var(--text3);font-weight:500;font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:0.06em;border-bottom:1px solid var(--border);background:var(--bg3);cursor:pointer;white-space:nowrap;user-select:none;text-align:left}
.trades-table th:hover{color:var(--text)}
.trades-table th.sort-asc::after{content:' ↑'}.trades-table th.sort-desc::after{content:' ↓'}
.trades-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:var(--fs-base);color:var(--text);white-space:nowrap}
.trades-table tr:last-child td{border-bottom:none}
.trades-table tr:hover td{background:var(--bg3);cursor:pointer}
.trades-table tr.trade-row-highlight td{background:rgba(74,222,128,0.10);border-top:1px solid rgba(74,222,128,0.3);border-bottom:1px solid rgba(74,222,128,0.3);}
.trades-table tr.trade-row-highlight td:first-child{border-left:3px solid var(--green);}
.trade-tag-chip{display:inline-block;font-size:9px;padding:1px 6px;border-radius:10px;background:var(--bg4);color:var(--text2);margin-right:2px;font-family:var(--font);border:1px solid var(--border)}
.trade-side-long{color:var(--green)}.trade-side-short{color:var(--red)}
.trades-empty{text-align:center;padding:48px 16px;color:var(--text3);font-size:var(--fs-sm)}
.trade-sidepanel{position:fixed;top:0;right:-420px;width:400px;height:100vh;background:var(--bg3);border-left:1px solid var(--border2);z-index:200;display:flex;flex-direction:column;transition:right 0.25s ease;overflow:hidden}
.trade-sidepanel.open{right:0}
.tsp-header{padding:16px 18px;border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--bg4)}
.tsp-title{font-size:14px;font-weight:600;color:var(--text)}
.tsp-close{width:26px;height:26px;border-radius:6px;background:var(--bg2);border:1px solid var(--border2);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px}
.tsp-close:hover{color:var(--text)}
.tsp-body{flex:1;overflow-y:auto;padding:16px 18px}
.tsp-row{display:flex;justify-content:space-between;align-items:baseline;padding:9px 0;border-bottom:1px solid var(--border)}
.tsp-key{font-size:12px;color:var(--text2);font-weight:500}.tsp-val{font-family:var(--mono);font-size:13px;color:var(--text);font-weight:500}
.tsp-section{font-size:9px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;margin:16px 0 8px}
.tsp-tags-wrap{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.tsp-tag{font-size:11px;padding:3px 10px;border-radius:10px;background:var(--bg2);color:var(--text2);border:1px solid var(--border2);cursor:pointer;font-family:var(--font);transition:all 0.1s}
.tsp-tag:hover{border-color:var(--border2);color:var(--text)}.tsp-tag.active{background:var(--green-dim);border-color:var(--green-mid);color:var(--green)}
.tsp-tag-input-wrap{display:flex;gap:6px;margin-top:6px}
.tsp-tag-input{flex:1;background:var(--bg2);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--font);font-size:11px;padding:5px 9px;outline:none}
.tsp-tag-input:focus{border-color:var(--green-mid)}
.tsp-tag-add-btn{padding:5px 10px;border-radius:6px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:11px;cursor:pointer;font-family:var(--font)}
.tsp-delete-btn{width:100%;margin-top:16px;padding:8px;border-radius:7px;background:transparent;border:1px solid rgba(248,113,113,0.25);color:var(--red);font-size:11px;cursor:pointer;font-family:var(--font)}
.tsp-delete-btn:hover{background:var(--red-dim)}
.sidepanel-overlay{display:none;position:fixed;inset:0;z-index:199;background:rgba(0,0,0,0.18)}
.sidepanel-overlay.open{display:block}

/* ── CUSTOM DATE PICKER ── */
.custom-range-wrap{display:none;align-items:center;gap:6px;margin-left:4px}
.custom-range-wrap.visible{display:flex}
.custom-date-input{background:var(--bg4);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--mono);font-size:10px;padding:3px 7px;outline:none;cursor:pointer;height:26px;width:120px}
.custom-date-input:focus{border-color:var(--green-mid)}
.custom-date-input::-webkit-calendar-picker-indicator{filter:invert(0.8);cursor:pointer;opacity:0.7}
.custom-date-input::-webkit-calendar-picker-indicator:hover{opacity:1}
input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(0.8);cursor:pointer;opacity:0.7}
input[type="date"]::-webkit-calendar-picker-indicator:hover{opacity:1}
.custom-sep{font-size:10px;color:var(--text3)}
.custom-range-hint{font-size:10px;color:var(--yellow);margin-left:4px;white-space:nowrap}

/* ── MIXED BADGE / TOOLTIP ── */
.badge-mixed{background:var(--teal-dim);color:var(--teal);border:1px solid rgba(45,212,191,0.25);position:relative;cursor:default}
.badge-tooltip{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--bg4);border:1px solid var(--border2);border-radius:8px;padding:8px 10px;font-size:10px;font-family:var(--mono);white-space:nowrap;z-index:100;line-height:1.8;min-width:140px;box-shadow:0 4px 16px rgba(0,0,0,0.4)}
.badge-mixed:hover .badge-tooltip{display:block}
.badge-tooltip-row{display:flex;justify-content:space-between;gap:16px}
.bt-das{color:var(--green)}.bt-manual{color:var(--yellow)}.bt-empty{color:var(--text3)}

/* ── LOCKED BANNER (non-Today) ── */
.state-banner.locked{opacity:0.40;pointer-events:none;position:relative;filter:saturate(0.25) brightness(0.85);padding-bottom:28px}
.banner-lock-pill{display:none;position:absolute;bottom:10px;right:12px;font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:0.1em;padding:2px 8px;border-radius:10px;background:var(--bg);border:1px solid var(--border2);color:var(--text3)}
.state-banner.locked .banner-lock-pill{display:block}

/* ── PERIOD SCOREBOARD (week/month/custom) ── */
.period-sb{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.period-sb-left{display:flex;align-items:baseline;gap:10px}
.period-sb-pnl{font-family:var(--mono);font-size:22px;font-weight:500}
.period-sb-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em}
.period-sb-days{font-size:11px;color:var(--text3);font-family:var(--mono)}
.period-sb-right{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.period-sb-stat{display:flex;flex-direction:column;align-items:center}
.period-sb-stat .sb-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em}
.period-sb-stat .sb-val{font-family:var(--mono);font-size:14px;font-weight:500;color:var(--text)}
.period-sb-divider{width:1px;height:22px;background:var(--border2);flex-shrink:0}
.period-das-note{width:100%;padding-top:8px;border-top:1px solid var(--border);font-size:10px;color:var(--text3);display:flex;align-items:center;gap:6px}
.period-das-note .das-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}

/* ── FPO LABELS ── */
.fpo-dot{font-size:8px;font-weight:500;text-transform:uppercase;letter-spacing:0.06em;color:var(--text3);background:var(--bg4);border:1px solid var(--border);border-radius:3px;padding:1px 4px;vertical-align:middle;margin-left:2px}
.fpo-status-badge{font-size:10px;font-weight:500;padding:3px 9px;border-radius:10px;white-space:nowrap;background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(251,191,36,0.2)}
.fpo-status-badge.cleared{background:var(--green-dim);color:var(--green);border-color:rgba(74,222,128,0.2)}

/* ── NAV COLLAPSE ── */
body.nav-collapsed .nav{width:64px}
.brand-text,.nav-item .label,.nav-badge,.nav-slabel,.import-btn-text,.nav-sep{max-width:200px;overflow:hidden;white-space:nowrap;transition:max-width 0.28s cubic-bezier(0.4,0,0.2,1),opacity 0.2s cubic-bezier(0.4,0,0.2,1)}
body.nav-collapsed .brand-text,body.nav-collapsed .nav-item .label,body.nav-collapsed .nav-badge,body.nav-collapsed .nav-slabel,body.nav-collapsed .import-btn-text,body.nav-collapsed .nav-sep{max-width:0;opacity:0;padding:0;margin:0;height:0;overflow:hidden}
body.nav-collapsed .nav-item{justify-content:flex-start;padding:8px 0 8px 14px}
body.nav-collapsed .nav-item svg{width:20px;height:20px}
body.nav-collapsed .nav-sep-line{display:none}
.nav-toggle{width:100%;padding:9px;border:none;border-top:1px solid var(--border);background:var(--bg2);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color 0.15s,background 0.15s}
.nav-toggle:hover{background:var(--bg3)}
.nav-toggle svg{width:22px;height:22px;stroke:var(--yellow);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;min-width:22px;transition:transform 0.35s cubic-bezier(0.4,0,0.2,1)}
body.nav-collapsed .nav-toggle svg{transform:rotate(180deg)}
/* ── CALENDAR MINIMAL MODE ── */
.cal-mode-btn{display:flex;align-items:center;justify-content:center;width:30px;height:28px;border-radius:7px;border:1px solid var(--border2);background:transparent;color:var(--text2);cursor:pointer;transition:all 0.15s;flex-shrink:0}
.cal-mode-btn:hover{color:var(--text);border-color:var(--border)}
.cal-mode-btn.active{background:var(--bg4);color:var(--text);border-color:var(--border)}
.cal-mode-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
body.cal-minimal .cal-pnl,body.cal-minimal .cal-trades,body.cal-minimal .cal-winrate,body.cal-minimal .cal-badges{display:none}
body.cal-minimal .cal-cell{min-height:48px;justify-content:flex-start}
body.cal-minimal .cal-cell.profit-lo,body.cal-minimal .cal-cell.profit-mid,body.cal-minimal .cal-cell.profit-hi{background:var(--green-dim);border-color:var(--green-mid)}
body.cal-minimal .cal-cell.loss{background:var(--red-dim);border-color:rgba(248,113,113,0.4)}
/* ── GOAL CARDS - ACTIVE ZONE + ARC LAYOUT ── */
.goal-card{border-radius:var(--radius);padding:12px 14px;border:1px solid var(--border);position:relative}
.goal-card.active-zone{border:2px solid var(--yellow)!important;box-shadow:0 0 16px rgba(251,191,36,0.12)}
.gc-body{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px}
.gc-left{flex:1;min-width:0}
/* ── GRAPHIC WIDGETS ── */
.awl-wrap{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.awl-row{display:flex;align-items:center;gap:8px}
.awl-label{font-size:10px;color:var(--text3);width:32px;flex-shrink:0}
.awl-bar-bg{flex:1;height:6px;border-radius:99px;background:var(--bg4);overflow:hidden}
.awl-bar-fill{height:100%;border-radius:99px;transition:width 0.6s cubic-bezier(0.4,0,0.2,1)}
.awl-bar-fill.win{background:var(--green)}.awl-bar-fill.loss{background:var(--red)}
.awl-val{font-family:var(--mono);font-size:11px;font-weight:600;width:48px;text-align:right;flex-shrink:0}
.awl-val.win{color:var(--green)}.awl-val.loss{color:var(--red)}
.streak-badges{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.streak-badge{font-size:10px;font-weight:600;padding:3px 9px;border-radius:99px;white-space:nowrap}
.streak-badge.current{background:var(--green-dim);color:var(--green);border:1px solid var(--green-mid)}
.streak-badge.teal{background:var(--teal-dim);color:var(--teal);border:1px solid rgba(45,212,191,0.3)}
.streak-badge.best{background:var(--bg4);color:var(--text2);border:1px solid var(--border2)}
.streak-badge.zero{background:var(--bg4);color:var(--text3);border:1px solid var(--border)}
/* ── FADE UP ANIMATION ── */
.card,.goal-card,.goal-progress-wrap,.state-banner,.strikes-card{animation:fadeUp 0.35s cubic-bezier(0.4,0,0.2,1) both}
.card:nth-child(1){animation-delay:.03s}.card:nth-child(2){animation-delay:.06s}.card:nth-child(3){animation-delay:.09s}.card:nth-child(4){animation-delay:.12s}.card:nth-child(5){animation-delay:.15s}
/* ── OVERTRADE CIRCUIT-BREAKER BANNER ── */
.overtrade-banner{
  display:flex;align-items:center;gap:12px;
  margin:16px 0 8px;
  padding:12px 16px;
  border-radius:10px;
  background:rgba(251,191,36,0.08);
  border:1px solid rgba(251,191,36,0.25);
  border-left:3px solid var(--yellow,#fbbf24);
}
.overtrade-icon{font-size:18px;flex-shrink:0;line-height:1}
.overtrade-body{display:flex;flex-direction:column;gap:2px}
.overtrade-title{
  font-size:11px;font-weight:700;letter-spacing:0.06em;
  color:var(--yellow,#fbbf24);
  text-transform:uppercase;
}
.overtrade-reason{font-size:11px;color:var(--text2)}
.overtrade-dismiss{
  margin-left:auto;flex-shrink:0;
  background:none;border:none;cursor:pointer;
  color:var(--text3);font-size:14px;line-height:1;
  padding:2px 4px;border-radius:4px;
  transition:color 0.15s;
}
.overtrade-dismiss:hover{color:var(--text)}

/* ══════════════════════════════════════════
   REPORTS PANEL
══════════════════════════════════════════ */
.rpt-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px;flex-wrap:wrap}
.rpt-mode-toggle{display:flex;gap:4px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:3px}
.rpt-mpill{background:none;border:none;color:var(--text3);font-size:11px;font-weight:600;padding:4px 14px;border-radius:6px;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.rpt-mpill.active{background:var(--bg4);color:var(--text)}
.rpt-print-btn{display:flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--border2);color:var(--text2);font-size:11px;font-family:var(--font);font-weight:500;padding:6px 12px;border-radius:7px;cursor:pointer;transition:border-color 0.15s}
.rpt-print-btn:hover{border-color:var(--green-mid);color:var(--text)}
.rpt-expand-btn{display:flex;align-items:center;gap:5px;background:var(--bg2);border:1px solid var(--border2);color:var(--text2);font-size:11px;font-family:var(--font);font-weight:500;padding:6px 12px;border-radius:7px;cursor:pointer;transition:border-color 0.15s,color 0.15s;white-space:nowrap}
.rpt-expand-btn:hover{border-color:var(--green-mid);color:var(--text)}
.rpt-expand-icon{transition:transform 0.25s ease;flex-shrink:0}

.rpt-section-title{font-size:10px;font-weight:700;letter-spacing:0.1em;color:var(--text3);text-transform:uppercase;margin:20px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.rpt-collapsible{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;transition:color 0.15s}
.rpt-collapsible:hover{color:var(--text2)}
.rpt-chevron{color:var(--text3);transition:transform 0.2s ease;flex-shrink:0}
.rpt-collapsed .rpt-chevron{transform:rotate(180deg)}
.rpt-section-body{overflow:hidden;opacity:1}

/* Summary cards */
.rpt-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-bottom:4px}
.rpt-sum-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}
.rpt-sum-label{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:6px}
.rpt-sum-val{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--text)}
.rpt-sum-sub{font-size:12px;color:var(--text3);margin-top:3px}

/* Charts grid */
.rpt-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:4px}
.rpt-chart-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}
.rpt-chart-card-wide{grid-column:1/-1}
.rpt-chart-title{font-size:10px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:10px}
.rpt-chart-wrap{position:relative;height:180px}
.rpt-chart-wrap-tall{height:auto;min-height:180px}

/* Compare section */
.rpt-compare-section{margin-bottom:4px}
.rpt-cmp-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.rpt-cmp-header{display:grid;grid-template-columns:1fr 1fr 1fr;background:rgba(255,255,255,0.03);border-bottom:1px solid var(--border);padding:10px 16px}
.rpt-cmp-col-label{font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--text3);text-align:center}
.rpt-cmp-col-label:first-child{text-align:left}
.rpt-cmp-win{color:#4ade80}
.rpt-cmp-loss{color:#f87171}
.rpt-cmp-row{display:grid;grid-template-columns:1fr 1fr 1fr;padding:8px 16px;border-bottom:1px solid rgba(255,255,255,0.04);align-items:center}
.rpt-cmp-row:last-child{border-bottom:none}
.rpt-cmp-row:nth-child(odd){background:rgba(255,255,255,0.01)}
.rpt-cmp-metric{font-size:12px;color:var(--text2)}
.rpt-cmp-val{font-family:var(--mono);font-size:13px;font-weight:600;text-align:center;color:var(--text)}
.rpt-cmp-val.pos{color:#4ade80}
.rpt-cmp-val.neg{color:#f87171}
/* Comparison two-column layout */
.rpt-cmp3-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.rpt-cmp3-header{display:grid;grid-template-columns:1.4fr 1fr 1fr;background:rgba(255,255,255,0.03);border-bottom:1px solid var(--border);padding:12px 16px}
.rpt-cmp3-hcell{font-size:11px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;color:var(--text3);text-align:center}
.rpt-cmp3-hcell:first-child{text-align:left}
.rpt-cmp3-win{color:#4ade80}
.rpt-cmp3-loss{color:#f87171}
.rpt-cmp3-body{display:flex;flex-direction:column}
.rpt-cmp3-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,0.04);align-items:center}
.rpt-cmp3-row:last-child{border-bottom:none}
.rpt-cmp3-row:nth-child(even){background:rgba(255,255,255,0.015)}
.rpt-cmp3-metric{font-size:12px;color:var(--text2);font-weight:500}
.rpt-cmp3-val{font-family:var(--mono);font-size:14px;font-weight:600;text-align:center;color:var(--text)}
.rpt-cmp3-val.pos{color:#4ade80}
.rpt-cmp3-val.neg{color:#f87171}

/* Drawdown ranked list */
.rpt-dd-wrap{padding:4px 0 8px}
.rpt-dd-empty-msg{font-size:12px;color:var(--text3);padding:16px 0}
.rpt-dd-list{display:flex;flex-direction:column;gap:0}
.rpt-dd-hdr{display:grid;grid-template-columns:130px 1fr 100px;gap:12px;padding:6px 10px;font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border)}
.rpt-dd-hdr-bar{text-align:left}
.rpt-dd-hdr-net{text-align:right}
.rpt-dd-row{display:grid;grid-template-columns:130px 1fr 100px;gap:12px;align-items:center;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.04);cursor:default;transition:background 0.12s}
.rpt-dd-row:hover{background:rgba(255,255,255,0.03)}
.rpt-dd-row:last-child{border-bottom:none}
.rpt-dd-row-worst{background:rgba(248,113,113,0.05)}
.rpt-dd-row-worst:hover{background:rgba(248,113,113,0.09)}
.rpt-dd-date{font-size:11px;color:var(--text2);display:flex;align-items:center;gap:6px;white-space:nowrap}
.rpt-dd-tag{font-size:9px;font-weight:600;background:rgba(74,222,128,0.12);color:#4ade80;border-radius:3px;padding:1px 5px;letter-spacing:0.04em;flex-shrink:0}
.rpt-dd-bar-wrap{display:flex;align-items:center;gap:8px;min-width:0}
.rpt-dd-track{flex:1;min-width:0;height:10px;background:rgba(255,255,255,0.05);border-radius:3px;overflow:hidden;display:flex;align-items:stretch}
.rpt-dd-bar{height:10px;border-radius:3px;min-width:2px;transition:width 0.3s ease;flex-shrink:0}
.rpt-dd-bar-val{font-family:var(--mono);font-size:11px;color:#f87171;white-space:nowrap;flex-shrink:0;min-width:84px}
.rpt-dd-net{font-family:var(--mono);font-size:12px;font-weight:600;text-align:right;white-space:nowrap}
.rpt-dd-net.pos{color:#4ade80}
.rpt-dd-net.neg{color:#f87171}
.rpt-dd-footer{font-size:10px;color:var(--text3);margin-top:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,0.05)}
.tip-rich{min-width:210px;line-height:1.7}

/* Insights */
.rpt-insights-section{border:1px solid var(--border2);border-radius:12px;padding:16px;background:rgba(255,255,255,0.01);margin-bottom:4px}
.rpt-insights-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rpt-insight{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;border-radius:var(--radius-lg);border:1px solid var(--border)}
.rpt-insight-strength{background:rgba(74,222,128,0.06);border-color:rgba(74,222,128,0.2)}
.rpt-insight-warning{background:rgba(251,191,36,0.06);border-color:rgba(251,191,36,0.2)}
.rpt-insight-note{background:rgba(96,165,250,0.06);border-color:rgba(96,165,250,0.2)}
.rpt-insight-neutral{background:var(--bg2)}
.rpt-insight-icon{font-size:26px;flex-shrink:0;line-height:1;margin-top:2px}
.rpt-insight-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:5px}
.rpt-insight-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:5px}
.rpt-insight-title-row .rpt-insight-title{margin-bottom:0;flex:1;min-width:0}
.rpt-insight-text{font-size:14px;color:var(--text2);line-height:1.65}

/* Table */
.rpt-table-tabs{display:flex;gap:4px;background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:2px}
.rpt-ttab{background:none;border:none;color:var(--text3);font-size:10px;font-weight:600;padding:3px 12px;border-radius:5px;cursor:pointer;font-family:var(--font)}
.rpt-ttab.active{background:var(--bg4);color:var(--text)}
.rpt-table-wrap{overflow-x:auto;margin-bottom:24px}
.rpt-table{width:100%}
.rpt-empty{text-align:center;padding:24px;color:var(--text3);font-size:12px}
.rpt-day-row{cursor:pointer}
.rpt-day-row:hover td{background:rgba(255,255,255,0.02)}
.rpt-day-expand-btn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;padding:2px 6px;border-radius:4px;transition:color 0.15s}
.rpt-day-expand-btn:hover{color:var(--text)}
.rpt-drill-cell{padding:0!important;background:var(--bg3)}
.rpt-drill-inner{padding:8px 16px}

/* Print */
/* ── REPORTS RANGE PILLS (base) ── */
.rpt-range-pills{display:flex;gap:4px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:3px}
.rpt-rpill{background:none;border:none;color:var(--text3);font-size:11px;font-weight:400;padding:4px 12px;border-radius:6px;cursor:pointer;font-family:var(--font);transition:all 0.15s;white-space:nowrap}
.rpt-rpill.active{background:var(--green-dim);color:var(--green)}
.rpt-custom-row{display:flex;align-items:center;gap:8px;width:100%}
.rpt-go-btn{background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:11px;font-weight:600;padding:5px 14px;border-radius:6px;cursor:pointer;font-family:var(--font)}
.rpt-right-controls{display:flex;align-items:center;gap:8px;margin-left:auto}

/* ── TRADES PANEL RANGE PILLS (base) ── */
.trades-range-row{display:flex;gap:4px;margin-bottom:10px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:3px;width:fit-content}
.trades-rpill{background:none;border:none;color:var(--text3);font-size:11px;font-weight:400;padding:4px 14px;border-radius:6px;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.trades-rpill.active{background:var(--green-dim);color:var(--green);font-weight:400}

/* ── BANNER PULSE CHIPS ── */
.banner-pulse-chips{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.banner-chip{display:flex;align-items:center;gap:7px;padding:5px 16px;border-radius:20px;font-size:var(--fs-lg);font-weight:700;border:1px solid transparent;letter-spacing:0.02em}
.banner-chip-pulse-strong{background:rgba(74,222,128,0.1);border-color:rgba(74,222,128,0.3);color:var(--green)}
.banner-chip-pulse-slow{background:rgba(251,191,36,0.1);border-color:rgba(251,191,36,0.3);color:var(--yellow,#fbbf24)}
.banner-chip-pulse-caution{background:rgba(251,146,60,0.1);border-color:rgba(251,146,60,0.3);color:#fb923c}
.banner-chip-pulse-lockin{background:rgba(45,212,191,0.1);border-color:rgba(45,212,191,0.3);color:#2dd4bf}
.banner-chip-pulse-protect{background:rgba(251,191,36,0.1);border-color:rgba(251,191,36,0.3);color:var(--yellow,#fbbf24)}
.banner-chip-pulse-walkaway{background:rgba(248,113,113,0.1);border-color:rgba(248,113,113,0.3);color:var(--red)}
.chip-sep{opacity:0.4;margin:0 2px}
.chip-pnl{font-family:var(--mono)}
.chip-stat{opacity:0.8}

/* ── BANNER P&L DIRECTION ARROW ── */

.pnl-arrow{font-size:1.4em;font-weight:900;line-height:1;display:inline-block}
.pnl-arrow.arrow-up{color:var(--green);animation:arrowPop 0.5s cubic-bezier(0.34,1.56,0.64,1) forwards}
.pnl-arrow.arrow-down{color:var(--red);animation:arrowPop 0.5s cubic-bezier(0.34,1.56,0.64,1) forwards}
@keyframes arrowPop{
  0%{opacity:0;transform:scale(0.4) translateY(4px)}
  60%{opacity:1;transform:scale(1.4) translateY(-3px)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}

/* ── OVERTRADE CIRCUIT-BREAKER BANNER ── */
.overtrade-banner{display:flex;align-items:center;gap:12px;margin:16px 0 8px;padding:12px 16px;border-radius:10px;background:rgba(251,191,36,0.08);border:1px solid rgba(251,191,36,0.25);border-left:3px solid var(--yellow,#fbbf24)}
.overtrade-icon{font-size:18px;flex-shrink:0;line-height:1}
.overtrade-body{display:flex;flex-direction:column;gap:2px}
.overtrade-title{font-size:11px;font-weight:700;letter-spacing:0.06em;color:var(--yellow,#fbbf24);text-transform:uppercase}
.overtrade-reason{font-size:11px;color:var(--text2)}
.overtrade-dismiss{margin-left:auto;flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;line-height:1;padding:2px 4px;border-radius:4px;transition:color 0.15s}
.overtrade-dismiss:hover{color:var(--text)}

/* ── IMPORT DATE PICKER ── */
.import-date-row{margin-bottom:16px;padding:14px 16px;background:rgba(251,191,36,0.07);border:2px solid rgba(251,191,36,0.5);border-radius:var(--radius-lg)}
.import-date-inner{display:flex;flex-direction:column;gap:6px}
.import-date-label{font-size:13px;font-weight:400;color:var(--yellow,#fbbf24);letter-spacing:0.02em;display:flex;align-items:center;gap:8px}
.import-date-required{font-size:9px;font-weight:400;letter-spacing:0.06em;color:var(--yellow,#fbbf24);background:rgba(251,191,36,0.15);border:1px solid rgba(251,191,36,0.4);border-radius:4px;padding:1px 6px}
.import-date-input{width:200px;font-size:14px;font-weight:400;padding:8px 12px;border:1px solid rgba(251,191,36,0.4);background:rgba(251,191,36,0.06);color:var(--text)}
.import-date-input:focus{border-color:var(--yellow,#fbbf24);outline:none;box-shadow:0 0 0 2px rgba(251,191,36,0.15)}
.import-date-input.input-error{border-color:var(--red)!important;box-shadow:0 0 0 2px rgba(248,113,113,0.2)!important}
.import-date-hint{font-size:11px;color:var(--text3)}

/* ── PULSE LABEL TOOLTIP POSITIONING ── */
.pulse-time-label .tip{left:0;transform:none}

/* ── REPORTS CARD TOOLTIPS ── */
.rpt-sum-card.has-tip{position:relative}
.rpt-sum-card.has-tip .rpt-sum-label{cursor:help}
.rpt-sum-card{position:relative}
.rpt-sum-card .tip{width:240px;top:calc(100% + 6px);bottom:auto;right:0;left:auto;transform:none;z-index:300}


/* ── INTRADAY GROUP ── */
.intraday-label{font-size:9px;font-weight:700;letter-spacing:0.12em;color:var(--green);text-transform:uppercase;margin-bottom:8px;opacity:0.6}
#intradayGroup{border:1px solid rgba(74,222,128,0.12);border-radius:10px;padding:12px;margin-bottom:12px;background:rgba(74,222,128,0.02)}
#intradayGroup.intraday-hidden{display:none}


/* ── SEARCH PANEL ── */
.search-wrap{max-width:720px;margin:0 auto;padding:8px 0}
.search-input-row{display:flex;align-items:center;gap:10px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;margin-bottom:12px;transition:border-color 0.15s}
.search-input-row:focus-within{border-color:var(--green-mid)}
.search-icon{width:18px;height:18px;color:var(--text3);flex-shrink:0}
.search-input{flex:1;background:none;border:none;outline:none;font-family:var(--font);font-size:var(--fs-lg);color:var(--text);caret-color:var(--green)}
.search-input::placeholder{color:var(--text3)}
.search-clear{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:0 2px;line-height:1;font-family:var(--font)}
.search-clear:hover{color:var(--text)}
.search-meta{font-size:var(--fs-xs);color:var(--text3);margin-bottom:10px;min-height:16px;letter-spacing:0.03em}
.search-results{display:flex;flex-direction:column;gap:4px}
.search-section-label{font-size:9px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text3);padding:8px 2px 4px;margin-top:4px}
.search-result{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color 0.12s,background 0.12s;text-decoration:none}
.search-result:hover{border-color:var(--green-mid);background:var(--bg3)}
.search-result-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.search-result-icon.win{background:rgba(74,222,128,0.12)}
.search-result-icon.loss{background:rgba(248,113,113,0.12)}
.search-result-icon.setting{background:rgba(96,165,250,0.12)}
.search-result-main{flex:1;min-width:0}
.search-result-title{font-size:var(--fs-base);font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-result-sub{font-size:var(--fs-sm);color:var(--text3);margin-top:1px}
.search-result-meta{text-align:right;flex-shrink:0}
.search-result-pnl{font-family:var(--mono);font-size:var(--fs-base);font-weight:500}
.search-result-date{font-size:var(--fs-xs);color:var(--text3);margin-top:2px}
.search-empty{text-align:center;padding:48px 20px;color:var(--text3);font-size:var(--fs-base)}
.search-empty svg{margin-bottom:12px;opacity:0.3}
mark.search-hl{background:rgba(74,222,128,0.25);color:var(--green);border-radius:2px;padding:0 1px}

@media print{
  .nav,.rpt-controls,.rpt-print-btn{display:none!important}
  body.print-mode .nav,.print-mode .rpt-controls{display:none!important}
  .rpt-insights-grid,.rpt-charts-grid{break-inside:avoid}
  .rpt-chart-wrap{height:140px}
  .rpt-cmp-card{break-inside:avoid}
}

/* ══════════════════════════════════════════
   TABLET (768–1024px)
══════════════════════════════════════════ */
@media(max-width:1024px){
  .nav{width:180px;min-width:180px}
  .brand-sub{display:none}
  .goal-grid{grid-template-columns:1fr 1fr!important}
  .banner-rules{grid-template-columns:repeat(3,1fr)!important}
  .rpt-charts-grid{grid-template-columns:1fr 1fr}
  .rpt-summary-grid{grid-template-columns:repeat(3,1fr)}
  .rpt-insights-grid{grid-template-columns:1fr}
  .risk-grid{grid-template-columns:1fr 1fr 1fr!important}
}

/* ══════════════════════════════════════════
   MOBILE TOPBAR (always fixed, hidden on desktop)
══════════════════════════════════════════ */
.mobile-topbar{
  display:none;
  position:fixed;top:0;left:0;right:0;
  height:52px;z-index:500;
  background:var(--bg2);border-bottom:1px solid var(--border);
  align-items:center;padding:0 14px;gap:10px;
}
.mobile-brand{font-size:14px;font-weight:700;color:var(--green);letter-spacing:0.06em;flex:1;text-align:center}
.mobile-pnl{font-family:var(--mono);font-size:13px;font-weight:700;min-width:70px;text-align:right}

/* Mobile range bar — controlled by body classes, never by JS inline style */
.mobile-range-bar{
  position:fixed;top:52px;left:0;right:0;z-index:490;
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:6px 12px;gap:8px;align-items:center;
  display:none; /* hidden by default on desktop */
}
.mobile-custom-row{
  position:fixed;top:98px;left:0;right:0;z-index:489;
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:6px 12px;gap:6px;align-items:center;
  display:none; /* shown only on mobile when custom active */
}
.mobile-custom-sep{font-size:11px;color:var(--text3)}
.mobile-custom-date{
  background:var(--bg3);border:1px solid var(--border2);border-radius:6px;
  color:var(--text);font-family:var(--font);font-size:11px;padding:4px 6px;
  flex:1;min-width:0;outline:none;
}
.mobile-pills{display:flex;gap:3px;flex:1}
.mpill{font-size:11px;padding:5px 10px;border-radius:20px;cursor:pointer;border:1px solid var(--border2);color:var(--text2);background:transparent;font-family:var(--font);white-space:nowrap;transition:all 0.1s}
.mpill:active{opacity:0.7}
.mpill.active{background:var(--green-dim);color:var(--green);border-color:var(--green-mid)}
.mobile-mode-toggle{display:flex;border:1px solid var(--border2);border-radius:8px;overflow:hidden;flex-shrink:0}
.mtpill{font-size:11px;padding:5px 9px;cursor:pointer;border:none;background:transparent;color:var(--text2);font-family:var(--font);white-space:nowrap}
.mtpill.active{background:var(--green-dim);color:var(--green)}

/* Hamburger */
.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px;width:36px;height:36px;flex-shrink:0}
.hamburger span{display:block;height:2px;background:var(--text2);border-radius:2px;transition:all 0.25s ease;transform-origin:center}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Nav overlay */
.nav-overlay{display:none;position:fixed;inset:0;z-index:450;background:rgba(0,0,0,0.6);opacity:0;transition:opacity 0.25s;pointer-events:none}
.nav-overlay.visible{opacity:1;pointer-events:auto}

/* ══════════════════════════════════════════
   MOBILE (<768px)
══════════════════════════════════════════ */
@media(max-width:767px){
  /* Show mobile topbar always */
  .mobile-topbar{display:flex}

  /* Range bar: shown on dashboard/calendar panels via body class */
  body.mobile-show-range .mobile-range-bar{display:flex}

  /* Custom date row: shown when custom range active on mobile */
  body.mobile-show-range.mobile-custom-open .mobile-custom-row{display:flex}

  /* Hide desktop nav collapse carat — not needed on mobile */
  .nav-toggle{display:none!important}

  /* Nav: fixed drawer, always position:fixed, slides in */
  .nav{
    position:fixed!important;
    top:0;left:0;bottom:0;
    width:240px!important;min-width:240px!important;
    height:100vh;z-index:500;
    transform:translateX(-100%);
    transition:transform 0.28s cubic-bezier(0.4,0,0.2,1);
    box-shadow:4px 0 24px rgba(0,0,0,0.5);
  }
  .nav.nav-open{transform:translateX(0)}

  /* Body: nav is fixed so main fills full width; allow scroll on main */
  body{overflow:visible}

  /* Main: base offset = 52px topbar only */
  .main{
    width:100vw!important;
    padding-top:52px;
    height:100vh;
    overflow-y:auto;
    overflow-x:hidden;
  }
  /* When range bar is visible: push content down another 46px */
  body.mobile-show-range .main{padding-top:98px}
  /* When custom row also visible: push down another 40px */
  body.mobile-show-range.mobile-custom-open .main{padding-top:138px}

  /* Hide desktop topbar (pills, mode toggle) */
  .topbar{display:none!important}

  /* Content padding */
  .content{padding:12px!important;height:auto;overflow:visible}

  /* Section spacing */
  .card{margin-bottom:10px}

  /* Banner */
  .banner-top{flex-wrap:wrap;gap:8px}
  .banner-rules{grid-template-columns:1fr 1fr!important;font-size:10px!important}
  .banner-pulse-chips{flex-wrap:wrap}
  .state-banner{padding:12px 14px!important}

  /* Goal grid */
  .goal-grid{grid-template-columns:1fr!important}

  /* Metric cards — 2×2 grid, no orphans */
  .metrics-grid{grid-template-columns:1fr 1fr!important}
  .mc{padding:10px 10px!important}
  .mc-label{font-size:9px!important}

  /* Deep stats */
  .deep-stats-grid{flex-wrap:wrap}
  .dash-stat-pill{min-width:33%}

  /* Risk grid */
  .risk-grid{grid-template-columns:1fr 1fr!important}

  /* Pulse cards — single column */
  .pulse-grid{grid-template-columns:1fr!important}

  /* Streak cards — keep 3-col on tablet */
  .streak-num{font-size:32px!important}
  .streak-card{padding:12px 14px!important;gap:12px!important}
  .streak-main{min-width:52px!important}

  /* Deep stats — wrap on tablet */
  .dash-stat-pill{min-width:25%}

  /* Scoreboard */
  #sbRow{flex-wrap:wrap;gap:6px}
  .sb-divider{display:none}

  /* Supporting charts — 2-col on tablet */
  .dash-charts-trio{grid-template-columns:1fr 1fr!important}
  .rpt-charts-grid,[class*="chart-grid"],[class*="charts-grid"]{grid-template-columns:1fr!important}
  .rpt-chart-card{margin-bottom:8px}

  /* Calendar */
  .cal-cell{min-height:50px!important;font-size:10px}
  .cal-controls{flex-wrap:wrap;gap:6px}

  /* Trades range pills — full width on mobile */
  .trades-range-row{width:100%;flex-wrap:nowrap}
  .trades-rpill{flex:1;text-align:center}

  /* Trades table — horizontal scroll only when trades present */
  .trades-table-wrap{overflow-x:hidden}
  .trades-table-wrap.has-data{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .trades-table-wrap.has-data .trades-table{min-width:600px}
  .trades-table-wrap:not(.has-data) .trades-table thead{display:none}
  .trades-toolbar{flex-wrap:wrap;gap:6px}
  .trades-filter-input,.trades-filter-select{min-width:100px;flex:1}
  .trades-table{font-size:11px}
  .trades-table th,.trades-table td{padding:5px 6px}
  .col-entry,.col-exit,.col-comm{display:none}

  /* Reports */
  .rpt-controls{flex-direction:column;align-items:flex-start;gap:8px}
  .rpt-right-controls{width:100%;justify-content:space-between}
  .rpt-range-pills{width:100%;flex-wrap:nowrap}
  .rpt-rpill{flex:1;text-align:center;padding:4px 6px}
  .rpt-charts-grid{grid-template-columns:1fr}
  .rpt-chart-card-wide{grid-column:auto}
  .rpt-summary-grid{grid-template-columns:1fr 1fr}
  .rpt-insights-grid{grid-template-columns:1fr}
  .rpt-table-wrap{overflow-x:auto}
  .rpt-cmp-header,.rpt-cmp-row{grid-template-columns:1.4fr 1fr 1fr;padding:7px 10px}
  .rpt-cmp-metric{font-size:11px}
  .rpt-cmp-val{font-size:12px}
  .rpt-cmp3-header,.rpt-cmp3-row{padding:8px 12px}
  .rpt-cmp3-metric{font-size:11px}
  .rpt-cmp3-val{font-size:13px}

  /* Import */
  .import-date-input{width:100%!important}

  /* Nav items */
  .nav-item{min-height:44px;padding:10px 12px!important}

  /* Pills */
  .pill,.tpill{padding:6px 12px}
}

/* ── CUSTOM SCROLLBARS (Chrome/Safari) ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(74,222,128,0.3);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:rgba(74,222,128,0.6)}
::-webkit-scrollbar-corner{background:transparent}

/* ── REPORTS DRILL ROW CLICKABLE ── */
.rpt-drill-trade-row:hover td{background:rgba(74,222,128,0.06)}

/* ── DASHBOARD INSIGHTS ── */
#dashInsightsWrap{margin:0 0 18px}
.dash-insights-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.dash-insights-title{font-size:10px;font-weight:700;letter-spacing:0.1em;color:var(--text3);text-transform:uppercase}
.dash-insights-link{background:none;border:none;color:var(--green-mid);font-size:11px;font-family:var(--font);cursor:pointer;padding:0;transition:color 0.15s}
.dash-insights-link:hover{color:var(--green)}
.dash-insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dash-insight-card{display:flex;gap:12px;align-items:flex-start;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;border-left:3px solid transparent}
.dash-insight-strength{border-left-color:rgba(74,222,128,0.5);background:rgba(74,222,128,0.04)}
.dash-insight-warning{border-left-color:rgba(248,113,113,0.5);background:rgba(248,113,113,0.04)}
.dash-insight-note{border-left-color:rgba(99,147,200,0.4);background:rgba(99,147,200,0.03)}
.dash-insight-neutral{border-left-color:rgba(255,255,255,0.1)}
.dash-insight-icon{font-size:18px;line-height:1;flex-shrink:0;margin-top:1px}
.dash-insight-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:5px}
.dash-insight-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:5px}
.dash-insight-title-row .dash-insight-title{margin-bottom:0;flex:1;min-width:0}
.dash-insight-text{font-size:14px;color:var(--text2);line-height:1.6}
/* ── Confidence badge (shared: dashboard + reports) ── */
.ins-conf-badge{flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:0.04em;padding:2px 7px;border-radius:20px;white-space:nowrap;cursor:default;margin-top:2px}
.ins-conf-high{background:rgba(74,222,128,0.15);color:rgba(74,222,128,0.95);border:1px solid rgba(74,222,128,0.25)}
.ins-conf-mid{background:rgba(251,191,36,0.13);color:rgba(251,191,36,0.9);border:1px solid rgba(251,191,36,0.25)}
.ins-conf-low{background:rgba(148,163,184,0.1);color:rgba(148,163,184,0.7);border:1px solid rgba(148,163,184,0.15)}
@media(max-width:1024px){.dash-insights-grid{grid-template-columns:1fr 1fr}}
@media(max-width:767px){.dash-insights-grid{grid-template-columns:1fr}}
@media(max-width:767px){
  .dash-charts-trio{grid-template-columns:1fr!important}
  .dash-stat-bar{flex-wrap:wrap}
  .dash-stat-pill{min-width:50%;border-bottom:1px solid var(--border)}
  .dash-stat-divider{display:none}
}

/* ── PILL TOUR ── */
@keyframes pillSpotlightPulse{
  0%,100%{box-shadow:0 0 0 2px #f5c518,0 0 10px 3px rgba(245,197,24,0.35);transform:scale(1.05);}
  50%{box-shadow:0 0 0 2px #f5c518,0 0 18px 7px rgba(245,197,24,0.55);transform:scale(1.08);}
}
.pill-spotlight{
  animation:pillSpotlightPulse 5s ease-in-out infinite;
  border-radius:4px;
  position:relative;
  z-index:2;
  transition:box-shadow 0.3s ease,transform 0.3s ease;
}

/* ═══════════════════════════════════════════
   JOURNAL PANEL
═══════════════════════════════════════════ */

/* ── Header ── */
.jrn-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.jrn-header-left{display:flex;flex-direction:column;gap:3px}
.jrn-date-display{font-size:var(--fs-lg);font-weight:500;color:var(--text);letter-spacing:0.01em}
.jrn-push-status{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono)}
.jrn-header-right{display:flex;align-items:center;gap:8px}

/* ── Buttons ── */
.jrn-push-btn{display:flex;align-items:center;gap:7px;padding:8px 18px;border-radius:8px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:var(--fs-sm);font-weight:500;font-family:var(--font);cursor:pointer;transition:background 0.12s;white-space:nowrap}
.jrn-push-btn:hover{background:var(--green-mid)}
.jrn-push-btn svg{width:14px;height:14px;stroke:currentColor;flex-shrink:0}
.jrn-download-btn{display:flex;align-items:center;gap:7px;padding:8px 14px;border-radius:8px;background:transparent;border:1px solid var(--border2);color:var(--text2);font-size:var(--fs-sm);font-weight:400;font-family:var(--font);cursor:pointer;transition:all 0.12s;white-space:nowrap}
.jrn-download-btn:hover{border-color:var(--text3);color:var(--text)}
.jrn-download-btn svg{width:14px;height:14px;stroke:currentColor;flex-shrink:0}

/* ── Sections ── */
.jrn-section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:12px}
.jrn-section-label{font-size:var(--fs-xs);font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.09em;margin-bottom:14px}

/* ── No-data notice ── */
.jrn-no-data-notice{display:flex;align-items:center;gap:8px;font-size:var(--fs-sm);color:var(--text3);background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin-bottom:14px}
.jrn-no-data-notice svg{flex-shrink:0;stroke:var(--text3)}

/* ── Stats row ── */
.jrn-stats-row{display:flex;align-items:center;gap:0;margin-bottom:14px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.jrn-stat{flex:1;padding:10px 14px;display:flex;flex-direction:column;gap:3px;min-width:0}
.jrn-stat-label{font-size:var(--fs-xs);color:var(--text3);text-transform:uppercase;letter-spacing:0.07em;white-space:nowrap}
.jrn-stat-val{font-family:var(--mono);font-size:var(--fs-lg);font-weight:500;color:var(--text);white-space:nowrap}
.jrn-stat-divider{width:1px;height:40px;background:var(--border);flex-shrink:0}

/* ── Best / Worst row ── */
.jrn-bw-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.jrn-bw-card{border-radius:var(--radius);padding:12px 14px;border:1px solid}
.jrn-bw-best{background:rgba(74,222,128,0.06);border-color:rgba(74,222,128,0.18)}
.jrn-bw-worst{background:rgba(248,113,113,0.06);border-color:rgba(248,113,113,0.18)}
.jrn-bw-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:5px}
.jrn-bw-best .jrn-bw-label{color:#86efac}
.jrn-bw-worst .jrn-bw-label{color:#fca5a5}
.jrn-bw-sym{font-size:var(--fs-sm);font-weight:500;color:var(--text);font-family:var(--mono);margin-bottom:2px}
.jrn-bw-val{font-family:var(--mono);font-size:var(--fs-xl);font-weight:500}

/* ── Field groups ── */
.jrn-field-group{margin-bottom:18px}
.jrn-field-group:last-child{margin-bottom:0}
.jrn-field-label{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);font-weight:500;color:var(--text2);margin-bottom:7px}
.jrn-field-label svg{stroke:var(--text3)}
.jrn-required-badge{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:0.07em;background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(251,191,36,0.2);border-radius:4px;padding:1px 6px;margin-left:2px}
.jrn-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:var(--fs-base);padding:10px 12px;resize:vertical;outline:none;transition:border-color 0.15s;line-height:1.6}
.jrn-textarea:focus{border-color:var(--border2)}
.jrn-textarea::placeholder{color:var(--text3)}

/* ── Mental state pills ── */
.jrn-mental-pills{display:flex;gap:6px;flex-wrap:wrap}
.jrn-mpill{padding:6px 16px;border-radius:20px;border:1px solid var(--border2);background:transparent;color:var(--text2);font-size:var(--fs-sm);font-family:var(--font);cursor:pointer;transition:all 0.12s}
.jrn-mpill:hover{border-color:var(--text3);color:var(--text)}
.jrn-mpill[data-val="poor"].active{background:var(--red-dim);border-color:rgba(248,113,113,0.4);color:var(--red)}
.jrn-mpill[data-val="fair"].active{background:var(--orange-dim);border-color:rgba(251,146,60,0.4);color:var(--orange)}
.jrn-mpill[data-val="good"].active{background:var(--yellow-dim);border-color:rgba(251,191,36,0.4);color:var(--yellow)}
.jrn-mpill[data-val="great"].active{background:var(--green-dim);border-color:var(--green-mid);color:var(--green)}
.jrn-mpill[data-val="peak"].active{background:var(--teal-dim);border-color:rgba(45,212,191,0.4);color:var(--teal)}

/* ── Tag input ── */
.jrn-tag-wrap{display:flex;flex-wrap:wrap;gap:6px;align-items:center;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;min-height:40px;cursor:text;transition:border-color 0.15s}
.jrn-tag-wrap:focus-within{border-color:var(--border2)}
.jrn-tag-chips{display:flex;flex-wrap:wrap;gap:5px}
.jrn-tag-chip{display:inline-flex;align-items:center;gap:5px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:var(--fs-xs);font-family:var(--mono);padding:3px 8px 3px 9px;border-radius:20px}
.jrn-tag-chip-remove{background:none;border:none;color:inherit;cursor:pointer;font-size:12px;line-height:1;padding:0;opacity:0.7;font-family:var(--font)}
.jrn-tag-chip-remove:hover{opacity:1}
.jrn-tag-input{background:transparent;border:none;outline:none;color:var(--text);font-family:var(--font);font-size:var(--fs-sm);min-width:160px;flex:1}
.jrn-tag-input::placeholder{color:var(--text3)}
.jrn-tag-suggestions{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);margin-top:4px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,0.3)}
.jrn-tag-sug-item{padding:8px 12px;font-size:var(--fs-sm);color:var(--text2);cursor:pointer;font-family:var(--mono)}
.jrn-tag-sug-item:hover{background:var(--bg3);color:var(--text)}

/* ── Tomorrow field (elevated) ── */
.jrn-tomorrow-group{display:flex;gap:0;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(45,212,191,0.25);background:var(--teal-dim);margin-bottom:0}
.jrn-tomorrow-accent{width:3px;background:var(--teal);flex-shrink:0}
.jrn-tomorrow-inner{flex:1;padding:14px 16px}
.jrn-tomorrow-label{color:var(--teal);font-size:var(--fs-sm);font-weight:500}
.jrn-tomorrow-label svg{stroke:var(--teal)}
.jrn-tomorrow-textarea{background:rgba(13,51,48,0.5);border-color:rgba(45,212,191,0.2)}
.jrn-tomorrow-textarea:focus{border-color:rgba(45,212,191,0.45)}
body.light-mode .jrn-tomorrow-textarea{background:rgba(45,212,191,0.06)}

/* ── Footer CTA ── */
.jrn-footer-cta{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.jrn-required-notice{display:flex;align-items:center;gap:6px;font-size:var(--fs-xs);color:var(--yellow);margin-right:auto}
.jrn-required-notice svg{stroke:var(--yellow);flex-shrink:0}

/* ── Connect modal ── */
.jrn-connect-modal{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,0.7);display:flex;align-items:center;justify-content:center}
.jrn-connect-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:32px 28px;max-width:380px;width:90%;text-align:center}
.jrn-connect-icon{width:48px;height:48px;border-radius:12px;background:var(--green-dim);border:1px solid var(--green-mid);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.jrn-connect-icon svg{width:22px;height:22px;stroke:var(--green)}
.jrn-connect-title{font-size:var(--fs-lg);font-weight:500;color:var(--text);margin-bottom:8px}
.jrn-connect-sub{font-size:var(--fs-sm);color:var(--text2);line-height:1.7;margin-bottom:22px}
.jrn-connect-actions{display:flex;flex-direction:column;gap:8px}
.jrn-connect-primary{padding:10px 18px;border-radius:8px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green);font-size:var(--fs-sm);font-weight:500;font-family:var(--font);cursor:pointer;transition:background 0.12s}
.jrn-connect-primary:hover{background:var(--green-mid)}
.jrn-connect-secondary{padding:10px 18px;border-radius:8px;background:transparent;border:1px solid var(--border2);color:var(--text2);font-size:var(--fs-sm);font-family:var(--font);cursor:pointer;transition:all 0.12s}
.jrn-connect-secondary:hover{color:var(--text);border-color:var(--text3)}
.jrn-connect-cancel{background:none;border:none;color:var(--text3);font-size:var(--fs-xs);font-family:var(--font);cursor:pointer;padding:4px}
.jrn-connect-cancel:hover{color:var(--text2)}

/* ── Journal settings format/naming pills ── */
.jrn-fmt-pill{padding:4px 10px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--text3);font-size:var(--fs-xs);font-family:var(--mono);cursor:pointer;transition:all 0.12s}
.jrn-fmt-pill.active{background:var(--teal-dim);border-color:rgba(94,234,212,0.35);color:var(--teal)}
.jrn-fmt-pill:not(.active):not(.disabled):hover{color:var(--text2);border-color:var(--border2)}
.jrn-fmt-pill.disabled{opacity:0.35;cursor:not-allowed}

/* ═══════════════════════════════════════════
   RANGE DATE BAR
═══════════════════════════════════════════ */
.range-date-bar{
  display:flex;align-items:center;
  padding:5px 14px;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  font-size:12px;color:var(--text2);
  font-family:var(--mono);
  gap:8px;
  min-height:30px;
}
.range-date-bar-label{
  color:var(--text);
  font-weight:500;
  letter-spacing:0.01em;
}

/* ═══════════════════════════════════════════
   CUSTOM CALENDAR TRIGGER BUTTON
═══════════════════════════════════════════ */
.custom-cal-trigger{
  display:flex;align-items:center;gap:6px;
  padding:5px 12px;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:var(--radius);
  color:var(--text);
  font-size:12px;font-family:var(--font);
  cursor:pointer;
  transition:border-color 0.15s,background 0.15s;
  white-space:nowrap;
}
.custom-cal-trigger:hover{border-color:var(--green);background:var(--bg3);}
.custom-cal-trigger svg{opacity:0.6;flex-shrink:0;}

/* ═══════════════════════════════════════════
   TRADERVUE-STYLE CALENDAR PICKER MODAL
═══════════════════════════════════════════ */
.cal-picker-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,0.55);
  z-index:9000;
  display:flex;align-items:center;justify-content:center;
}
.cal-picker-modal{
  display:flex;flex-direction:row;
  background:var(--bg);
  border:1px solid var(--border2);
  border-radius:var(--radius-lg);
  box-shadow:0 24px 64px rgba(0,0,0,0.6);
  overflow:hidden;
  width:min(820px,95vw);
  max-height:90vh;
  animation:scaleIn 0.18s cubic-bezier(0.4,0,0.2,1) both;
}

/* ── Left preset list ── */
.cal-picker-left{
  width:156px;flex-shrink:0;
  border-right:1px solid var(--border);
  padding:16px 0;
  background:var(--bg2);
  overflow-y:auto;
}
.cal-preset{
  padding:9px 18px;
  font-size:13px;color:var(--text2);
  cursor:pointer;white-space:nowrap;
  transition:background 0.12s,color 0.12s;
  user-select:none;
}
.cal-preset:hover{background:var(--bg3);color:var(--text);}
.cal-preset.active{color:var(--green);font-weight:600;background:var(--green-dim);}

/* ── Right calendar area ── */
.cal-picker-right{
  flex:1;min-width:0;
  display:flex;flex-direction:column;
  padding:20px 22px 16px;
  overflow:hidden;
}
.cal-picker-months{flex:1;min-width:0;}

/* Single nav row: ‹  [May 2026]  [June 2026]  › */
.cal-nav-row{
  display:grid;
  grid-template-columns:30px 1fr 1px 1fr 30px;
  align-items:center;
  gap:0;
  margin-bottom:14px;
}
.cal-nav-row .cal-month-title{padding:0 20px;}
.cal-nav-row .cal-month-title:first-of-type{padding-left:8px;}
.cal-nav-row .cal-nav-spacer{width:1px;}
.cal-nav-btn{
  width:30px;height:30px;
  background:none;border:1px solid var(--border2);border-radius:6px;
  color:var(--text2);font-size:20px;line-height:1;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:border-color 0.12s,color 0.12s;
}
.cal-nav-btn:hover{border-color:var(--green);color:var(--text);}
.cal-month-title{
  font-size:14px;font-weight:700;color:var(--text);
  text-align:center;
}

/* Two equal month columns */
.cal-grids{
  display:grid;
  grid-template-columns:1fr 1px 1fr;
  gap:0;
}
.cal-month-col{min-width:0;padding:0 20px;}
.cal-month-col:first-child{padding-left:0;}
.cal-month-col:last-child{padding-right:0;}
.cal-month-divider{
  background:var(--border);
  align-self:stretch;
}

/* Day-of-week header */
.cal-picker-modal .cp-grid-header{
  display:grid;grid-template-columns:repeat(7,1fr);
  margin-bottom:4px;
}
.cal-picker-modal .cp-grid-header span{
  text-align:center;font-size:11px;
  color:var(--text3);font-weight:600;padding:3px 0;
}

/* Day cells */
.cal-picker-modal .cp-grid-days{
  display:grid;grid-template-columns:repeat(7,1fr);
  gap:2px;
}
.cal-picker-modal .cp-day{
  aspect-ratio:1/1;min-height:0;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;color:var(--text);
  border-radius:5px;
  cursor:pointer;user-select:none;
  transition:background 0.1s,color 0.1s;
}
.cal-picker-modal .cp-day:hover:not(.cp-day-empty){background:var(--bg3);}
.cal-picker-modal .cp-day-empty{color:transparent;cursor:default;pointer-events:none;}
.cal-picker-modal .cp-day-today{font-weight:700;color:var(--green);}
.cal-picker-modal .cp-day-selected{background:var(--green)!important;color:#000!important;font-weight:700;border-radius:5px;}
.cal-picker-modal .cp-day-in-range{background:var(--green-dim);border-radius:0;}
.cal-picker-modal .cp-day-range-start{background:var(--green)!important;color:#000!important;border-radius:5px 0 0 5px;}
.cal-picker-modal .cp-day-range-end{background:var(--green)!important;color:#000!important;border-radius:0 5px 5px 0;}
.cal-picker-modal .cp-day-range-start.cp-day-range-end{border-radius:5px;}

.cal-picker-footer{
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--border);
  padding-top:14px;margin-top:14px;
}
.cal-selected-label{
  font-size:13px;color:var(--text2);
  font-family:var(--mono);
}
.cal-footer-btns{display:flex;gap:10px;}
.cal-cancel-btn{
  padding:7px 18px;border-radius:8px;
  background:var(--bg2);border:1px solid var(--border2);
  color:var(--text2);font-size:13px;cursor:pointer;
  transition:border-color 0.12s;
}
.cal-cancel-btn:hover{border-color:var(--border);color:var(--text);}
.cal-apply-btn{
  padding:7px 20px;border-radius:8px;
  background:var(--green);border:none;
  color:#000;font-size:13px;font-weight:600;
  cursor:pointer;
  transition:opacity 0.12s;
}
.cal-apply-btn:hover{opacity:0.85;}

/* ── Panel date bars (Reports + Trades) ── */
.panel-date-bar{
  display:flex;align-items:center;
  padding:7px 24px;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  font-size:12px;font-family:var(--mono);
  color:var(--text2);
  min-height:32px;
}
.panel-date-bar span{
  color:var(--text);font-weight:500;letter-spacing:0.01em;
}
