@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=JetBrains+Mono:wght@400;500;600&display=swap');
/* Maintenance Mode Animations */
@keyframes maintPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:0.85}}
@keyframes maintBlink{0%,100%{opacity:1}50%{opacity:0.3}}

*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}

/* ── DESIGN TOKENS ─────────────────────────────────────────── */
:root{
  /* Surfaces */
  --bg:       #f5f5f7;
  --bg1:      #ffffff;
  --bg2:      #f5f5f7;
  --bg3:      #e8e8ed;
  --bg4:      #d2d2d7;
  /* Borders */
  --border:   rgba(0,0,0,0.08);
  --border2:  rgba(0,0,0,0.12);
  --border3:  rgba(0,0,0,0.18);
  /* Text */
  --t1:#1d1d1f;
  --t2:#424245;
  --t3:#86868b;
  /* Brand accent — use sparingly */
  --acc:#0071e3;
  --acc2:#00a884;
  --acc3:#f5a623;
  --g:  #34c759;
  --r:  #ff3b30;
  /* Misc */
  --f:'Inter',system-ui,-apple-system,sans-serif;
  --m:'JetBrains Mono',monospace;
  --lock-color:rgba(0,113,227,0.07);
  --lock-color2:rgba(0,113,227,0.04);
  --shadow:0 1px 0 rgba(0,0,0,0.05);
  --card-shadow:0 2px 8px rgba(0,0,0,0.06),0 0 0 0.5px rgba(0,0,0,0.06);
  --radius:14px;
}
body.dark{
  --bg:   #000000;
  --bg1:  #1c1c1e;
  --bg2:  #2c2c2e;
  --bg3:  #3a3a3c;
  --bg4:  #48484a;
  --border:  rgba(255,255,255,0.08);
  --border2: rgba(255,255,255,0.12);
  --border3: rgba(255,255,255,0.18);
  --t1:#f5f5f7;
  --t2:#ebebf0;
  --t3:#8e8e93;
  --acc:#2997ff;
  --g:  #32d74b;
  --r:  #ff453a;
  --lock-color:rgba(41,151,255,0.08);
  --lock-color2:rgba(41,151,255,0.04);
  --card-shadow:0 2px 8px rgba(0,0,0,0.4),0 0 0 0.5px rgba(255,255,255,0.06);
}
body{background:var(--bg);color:var(--t1);font-family:var(--f);overflow-x:hidden;min-height:100vh;transition:background 0.3s,color 0.3s;font-size:16px;line-height:1.5}
body.on-home{}

/* ── LOCK BG ─────────────────────────────────────────────────── */
.lock-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;opacity:0;transition:opacity 0.5s}
body.on-home .lock-bg{opacity:1}
.lock-grid{display:grid;grid-template-columns:repeat(18,1fr);gap:18px;padding:20px;transform:rotate(-8deg) scale(1.15);transform-origin:center;position:absolute;inset:-80px}
.lk{display:flex;align-items:center;justify-content:center}
.lk svg{width:28px;height:28px}
.lock-fade{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,transparent 25%,var(--bg) 65%,var(--bg) 100%)}
.lock-fade-sides{position:absolute;inset:0;background:linear-gradient(90deg,var(--bg) 0%,transparent 15%,transparent 85%,var(--bg) 100%)}

/* ── NAV — Apple-style frosted glass bar ─────────────────────── */
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 22px;height:48px;
  background:rgba(255,255,255,0.72);
  border-bottom:0.5px solid rgba(0,0,0,0.1);
  position:sticky;top:0;z-index:200;
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  transition:background 0.3s;
}
body.dark .nav{background:rgba(28,28,30,0.82);border-bottom:0.5px solid rgba(255,255,255,0.1)}
.nav-logo{
  font-size:18px;font-weight:700;letter-spacing:-0.4px;
  cursor:pointer;color:var(--t1);transition:opacity 0.15s;
  display:flex;align-items:center;gap:0;
}
.nav-logo:hover{opacity:0.7}
.nav-logo span{color:var(--acc)}
.nav-tabs{display:flex;gap:0;align-items:center}
.nav-tab{
  padding:5px 11px;border-radius:8px;
  font-size:13px;font-weight:400;
  color:var(--t3);cursor:pointer;
  transition:color 0.15s,background 0.15s;
  position:relative;user-select:none;letter-spacing:-0.1px;
}
.nav-tab:hover{color:var(--t1)}
.nav-tab.active{color:var(--t1);font-weight:500}
.nav-tab.has-drop{display:flex;align-items:center;gap:3px}
.drop-arrow{font-size:8px;transition:transform 0.2s;opacity:0.5}
.nav-tab.open .drop-arrow{transform:rotate(180deg)}
.dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:rgba(255,255,255,0.92);
  border:0.5px solid rgba(0,0,0,0.1);
  border-radius:14px;padding:5px;
  min-width:180px;
  box-shadow:0 8px 32px rgba(0,0,0,0.12),0 2px 8px rgba(0,0,0,0.08);
  display:none;z-index:300;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
body.dark .dropdown{background:rgba(44,44,46,0.96);border:0.5px solid rgba(255,255,255,0.12)}
.nav-tab.open .dropdown{display:block}
.drop-item{
  padding:8px 12px;border-radius:9px;
  font-size:13px;font-weight:400;color:var(--t1);
  cursor:pointer;transition:background 0.12s;white-space:nowrap;
}
.drop-item:hover{background:rgba(0,0,0,0.05)}
body.dark .drop-item:hover{background:rgba(255,255,255,0.07)}
.nav-right{display:flex;gap:8px;align-items:center}
.btn-ghost{
  padding:5px 14px;border-radius:20px;
  font-size:13px;font-weight:500;
  color:var(--acc);background:transparent;
  border:1.5px solid rgba(0,113,227,0.35);
  cursor:pointer;transition:all 0.15s;letter-spacing:-0.1px;
}
.btn-ghost:hover{background:rgba(0,113,227,0.06)}
body.dark .btn-ghost{border-color:rgba(41,151,255,0.4)}
.btn-primary{
  padding:6px 18px;border-radius:20px;
  font-size:13px;font-weight:500;
  color:#fff;background:var(--acc);border:none;cursor:pointer;
  transition:all 0.15s;letter-spacing:-0.1px;
}
.btn-primary:hover{opacity:0.86}

/* ── THEME TOGGLE ────────────────────────────────────────────── */
.theme-toggle{
  width:40px;height:24px;border-radius:12px;
  background:var(--bg3);border:1px solid var(--border2);
  cursor:pointer;position:relative;transition:all 0.3s;flex-shrink:0;
}
.theme-toggle .knob{
  position:absolute;top:3px;left:3px;
  width:18px;height:18px;border-radius:50%;
  background:var(--acc);
  transition:all 0.3s;display:flex;align-items:center;justify-content:center;font-size:10px;
  box-shadow:0 1px 3px rgba(0,0,0,0.2);
}
body.dark .theme-toggle .knob{transform:translateX(16px);background:#2997ff}
body.dark .theme-toggle{background:var(--bg3)}

/* ── TRIAL PILL ──────────────────────────────────────────────── */
.trial-pill{
  display:flex;align-items:center;gap:5px;
  padding:5px 13px;border-radius:20px;
  font-size:12px;font-weight:600;font-family:var(--f);letter-spacing:-0.1px;
  color:#fff;background:linear-gradient(135deg,#f5a623,#ff3b30);
  cursor:pointer;user-select:none;
  animation:pilsate 2.8s ease-in-out infinite;white-space:nowrap;
}
.trial-fire{font-size:12px}
.cta-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.btn-cta{
  position:relative;z-index:2;
  display:flex;align-items:center;gap:6px;
  padding:6px 18px;border-radius:20px;
  font-size:13px;font-weight:500;color:#fff;
  background:var(--acc);border:none;cursor:pointer;
  transition:opacity 0.15s;letter-spacing:-0.1px;
}
.btn-cta:hover{opacity:0.82}
.cta-arrow{font-size:13px;transition:transform 0.2s}
.btn-cta:hover .cta-arrow{transform:translateX(2px)}
.cta-ring{position:absolute;inset:-5px;border-radius:24px;border:1.5px solid rgba(0,113,227,0.4);animation:ctaring 2s ease-in-out infinite;pointer-events:none}
@keyframes ctaring{0%,100%{opacity:0.5;transform:scale(1)}50%{opacity:0;transform:scale(1.1)}}
@keyframes pilsate{0%,100%{opacity:1}50%{opacity:0.8}}

/* ── PAGES ───────────────────────────────────────────────────── */
.page{display:none;position:relative;z-index:1}
.page.active{display:block}
.page.page-enter{animation:pageIn 0.2s ease forwards}
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ── HERO ────────────────────────────────────────────────────── */
.hero{padding:72px 32px 56px;text-align:center;max-width:860px;margin:0 auto;position:relative}
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 14px;border-radius:20px;
  background:rgba(0,113,227,0.07);border:1px solid rgba(0,113,227,0.15);
  font-size:11px;font-weight:500;color:var(--acc);
  letter-spacing:0.2px;text-transform:none;margin-bottom:20px;font-family:var(--f);
}
.hero h1{
  font-size:clamp(40px,5.5vw,68px);
  font-weight:700;letter-spacing:-2.5px;line-height:1.04;
  color:var(--t1);margin-bottom:16px;
}
.hero h1 span{color:var(--acc)}
.hero p{
  font-size:19px;color:var(--t3);font-weight:400;
  line-height:1.55;max-width:540px;margin:0 auto 32px;letter-spacing:-0.2px;
}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-xl{
  padding:13px 28px;border-radius:980px;
  font-size:17px;font-weight:400;letter-spacing:-0.2px;
  cursor:pointer;transition:opacity 0.15s;
}
.btn-xl.primary{background:var(--acc);color:#fff;border:none}
.btn-xl.primary:hover{opacity:0.82}
.btn-xl.secondary{background:rgba(0,0,0,0.06);color:var(--t1);border:none}
body.dark .btn-xl.secondary{background:rgba(255,255,255,0.1)}
.btn-xl.secondary:hover{background:rgba(0,0,0,0.1)}
.hero-sub{font-size:12px;color:var(--t3);margin-top:14px;letter-spacing:0}

/* ── VAULT ANIMATION ─────────────────────────────────────────── */
.vault-wrap{display:flex;justify-content:center;margin-bottom:28px}
.vault-svg{width:120px;height:120px;filter:drop-shadow(0 0 18px rgba(0,113,227,0.18))}
.vault-spin{transform-origin:60px 60px;animation:vaultSpin 12s linear infinite}
@keyframes vaultSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.vault-handle{transform-origin:60px 60px;animation:handleTurn 3.5s cubic-bezier(0.4,0,0.2,1) 0.8s forwards}
@keyframes handleTurn{0%{transform:rotate(0deg)}30%{transform:rotate(-40deg)}60%{transform:rotate(25deg)}80%{transform:rotate(-10deg)}100%{transform:rotate(0deg)}}
.vault-unlock-ring{animation:unlockRing 1.2s ease-out 1.6s forwards}
@keyframes unlockRing{from{stroke-dashoffset:326;opacity:0}to{stroke-dashoffset:0;opacity:0.6}}
.vault-labels{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:28px}
.vault-label{
  padding:5px 14px;border-radius:20px;font-size:12px;font-weight:400;
  background:rgba(0,0,0,0.04);border:0.5px solid rgba(0,0,0,0.1);color:var(--t2);
  opacity:0;animation:labelFadeIn 0.4s ease forwards;letter-spacing:-0.1px;
}
body.dark .vault-label{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.1)}
.vault-label:nth-child(1){animation-delay:1.8s}.vault-label:nth-child(2){animation-delay:2.0s}
.vault-label:nth-child(3){animation-delay:2.2s}.vault-label:nth-child(4){animation-delay:2.4s}
.vault-label:nth-child(5){animation-delay:2.6s}.vault-label:nth-child(6){animation-delay:2.8s}
@keyframes labelFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ── STATS STRIP ─────────────────────────────────────────────── */
.stats-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0.5px;background:var(--border);
  border-radius:20px;overflow:hidden;margin:0 32px 56px;
  border:0.5px solid var(--border);
}
.stat-cell{background:var(--bg1);padding:28px 24px;transition:background 0.2s}
.stat-num{font-size:36px;font-weight:700;letter-spacing:-2px;line-height:1}
.stat-lbl{font-size:11px;color:var(--t3);letter-spacing:-0.1px;margin-top:5px}
.stat-delta{font-size:11px;font-family:var(--m);margin-top:3px}
.stat-delta.up{color:var(--g)}

/* ── FEATURE GRID ────────────────────────────────────────────── */
.feat-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:0.5px;background:var(--border);
  border-radius:20px;overflow:hidden;margin:0 32px 56px;
  border:0.5px solid var(--border);
}
.feat-card{background:var(--bg1);padding:32px 28px;transition:background 0.2s;cursor:pointer}
.feat-card:hover{background:var(--bg2)}
.feat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.feat-title{font-size:17px;font-weight:600;letter-spacing:-0.4px;margin-bottom:6px;color:var(--t1)}
.feat-desc{font-size:14px;color:var(--t3);line-height:1.55;letter-spacing:-0.1px}
.feat-tag{display:inline-block;margin-top:12px;font-size:12px;color:var(--acc);letter-spacing:-0.1px}

/* ── COMMON CARDS ────────────────────────────────────────────── */
.card,.panel{
  background:var(--bg1);border:0.5px solid var(--border);
  border-radius:var(--radius);padding:20px;
  transition:background 0.2s;box-shadow:var(--card-shadow);
}
.panel-title{font-size:11px;font-weight:600;color:var(--t3);letter-spacing:0;margin-bottom:14px;text-transform:none}
.section-eyebrow{font-size:12px;font-weight:600;color:var(--acc);letter-spacing:0.2px;margin-bottom:8px}
.progress-track{background:var(--bg3);border-radius:6px;height:4px;overflow:hidden}
.progress-fill{height:100%;border-radius:6px;background:var(--acc)}

/* ── DASHBOARD ───────────────────────────────────────────────── */
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:0 24px;margin-bottom:14px}
.d-stat{
  background:var(--bg1);border:0.5px solid var(--border);
  border-radius:16px;padding:18px;
  transition:all 0.2s;box-shadow:var(--card-shadow);
}
.d-stat-top{height:2px;border-radius:2px;margin-bottom:14px}
.d-num{font-size:28px;font-weight:700;letter-spacing:-1.5px;line-height:1}
.d-label{font-size:11px;color:var(--t3);letter-spacing:-0.1px;margin-bottom:6px}
.dash-main{display:grid;grid-template-columns:2fr 1fr;gap:10px;padding:0 24px;margin-bottom:14px}
.trade-mini{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--border)}
.trade-mini:last-child{border-bottom:none}
.t-sym{background:rgba(0,113,227,0.08);color:var(--acc);padding:2px 7px;border-radius:5px;font-size:11px;font-family:var(--m);font-weight:500}
.dash-lower{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;padding:0 24px;margin-bottom:16px}
.check-item{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:0.5px solid var(--border);cursor:pointer}
.check-item:last-child{border-bottom:none}
.chk{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border3);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
.chk.on{background:var(--g);border-color:var(--g)}
.notif-item{display:flex;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--border)}
.notif-item:last-child{border-bottom:none}
.ndot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px}
.streak-days{display:flex;gap:4px;margin-top:8px}
.sday{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--f);font-weight:500}
.sday.hit{background:rgba(52,199,89,0.12);color:var(--g)}
.sday.now{background:var(--g);color:#fff;font-weight:600}
.sday.off{background:var(--bg3);color:var(--t3)}

/* ── JOURNAL ─────────────────────────────────────────────────── */
.journal-wrap{display:grid;grid-template-columns:1fr 320px;gap:16px;padding:0 24px;margin-bottom:50px}
.form-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:18px;padding:24px;box-shadow:var(--card-shadow)}
.field label{
  font-size:11px;font-weight:500;color:var(--t3);
  letter-spacing:-0.1px;display:block;margin-bottom:5px;
}
.field input,.field select,.field textarea{
  background:rgba(0,0,0,0.03);
  border:0.5px solid rgba(0,0,0,0.12);
  border-radius:10px;padding:10px 14px;
  font-size:14px;color:var(--t1);font-family:var(--f);
  outline:none;width:100%;transition:all 0.15s;
  -webkit-appearance:none;letter-spacing:-0.2px;
}
body.dark .field input,body.dark .field select,body.dark .field textarea{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.1)}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--acc);
  background:var(--bg1);
  box-shadow:0 0 0 3px rgba(0,113,227,0.1);
}
body.dark .field input:focus,body.dark .field select:focus,body.dark .field textarea:focus{box-shadow:0 0 0 3px rgba(41,151,255,0.15)}
.field select option{background:var(--bg1)}
.field textarea{resize:none;height:70px}
.conf-opt{
  padding:5px 11px;border-radius:20px;font-size:12px;
  border:0.5px solid var(--border2);color:var(--t3);
  background:transparent;cursor:pointer;transition:all 0.15s;
  letter-spacing:-0.1px;
}
.conf-opt.sel{
  background:rgba(0,113,227,0.08);
  border-color:rgba(0,113,227,0.3);color:var(--acc);
}
.dir-btn{
  flex:1;padding:9px;border-radius:10px;
  font-size:13px;font-weight:500;font-family:var(--f);
  border:0.5px solid var(--border2);
  background:rgba(0,0,0,0.03);color:var(--t3);
  cursor:pointer;transition:all 0.15s;letter-spacing:-0.1px;
}
body.dark .dir-btn{background:rgba(255,255,255,0.04)}
.dir-btn.long-active{background:rgba(52,199,89,0.1);border-color:rgba(52,199,89,0.4);color:var(--g)}
.dir-btn.short-active{background:rgba(255,59,48,0.1);border-color:rgba(255,59,48,0.4);color:var(--r)}
.star{font-size:22px;cursor:pointer;color:var(--bg3);transition:color 0.1s}
.star.lit{color:var(--acc3)}
.calc-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:18px;padding:22px;box-shadow:var(--card-shadow)}
.rr-big{font-size:48px;font-weight:700;letter-spacing:-2.5px;color:var(--acc2);text-align:center;margin:14px 0 3px}
.rr-sub{font-size:11px;color:var(--t3);text-align:center;letter-spacing:-0.1px}
.calc-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:0.5px solid var(--border);font-size:13px;color:var(--t2);letter-spacing:-0.1px}
.calc-row:last-child{border-bottom:none}
.calc-val{font-family:var(--m);font-weight:600}
.submit-btn{
  width:100%;padding:13px;border-radius:980px;
  background:var(--acc);color:#fff;
  font-size:15px;font-weight:400;border:none;cursor:pointer;
  margin-top:18px;transition:opacity 0.15s;letter-spacing:-0.1px;
}
.submit-btn:hover{opacity:0.82}

/* ── OUTCOME BUTTONS ─────────────────────────────────────────── */
.outcome-btn{
  display:flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:10px;
  font-size:12px;font-weight:500;
  border:0.5px solid var(--border2);
  background:rgba(0,0,0,0.03);
  color:var(--t3);cursor:pointer;transition:all 0.15s;
  letter-spacing:-0.1px;
}
body.dark .outcome-btn{background:rgba(255,255,255,0.04)}
.outcome-win-btn.active-outcome{background:rgba(52,199,89,0.1);border-color:rgba(52,199,89,0.4);color:var(--g)}
.outcome-loss-btn.active-outcome{background:rgba(255,59,48,0.1);border-color:rgba(255,59,48,0.4);color:var(--r)}
.outcome-be-btn.active-outcome{background:rgba(0,113,227,0.08);border-color:rgba(0,113,227,0.3);color:var(--acc)}
.outcome-partial-btn.active-outcome{background:rgba(245,166,35,0.1);border-color:rgba(245,166,35,0.4);color:var(--acc3)}

/* ── TRADE HISTORY ───────────────────────────────────────────── */
.history-filters{display:flex;gap:6px;padding:0 24px;margin-bottom:12px;flex-wrap:wrap}
.filter-chip{
  padding:5px 14px;border-radius:20px;
  font-size:12px;font-weight:400;letter-spacing:-0.1px;
  border:0.5px solid var(--border2);
  color:var(--t3);background:transparent;cursor:pointer;transition:all 0.15s;
}
.filter-chip.on,.filter-chip:hover{background:rgba(0,113,227,0.08);border-color:rgba(0,113,227,0.25);color:var(--acc)}
.trades-table{margin:0 24px;background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--card-shadow)}
.t-th{display:grid;grid-template-columns:32px 90px 70px 50px 1fr 90px 60px 80px 70px;padding:9px 16px;border-bottom:0.5px solid var(--border);background:var(--bg2)}
.t-th span{font-size:10px;font-family:var(--f);color:var(--t3);letter-spacing:-0.1px;font-weight:500;text-transform:none}
.t-row{display:grid;grid-template-columns:32px 90px 70px 50px 1fr 90px 60px 80px 70px;padding:11px 16px;border-bottom:0.5px solid var(--border);align-items:center;cursor:pointer;transition:background 0.12s}
.t-row:last-child{border-bottom:none}
.t-row:hover{background:var(--bg2)}
.t-row.selected{background:rgba(0,113,227,0.05)}
.t-date{font-size:11px;font-family:var(--m);color:var(--t3);white-space:nowrap}
.t-date-group{padding:6px 16px;background:var(--bg2);border-bottom:0.5px solid var(--border);font-size:11px;color:var(--t3);letter-spacing:-0.1px;font-weight:500;display:flex;align-items:center;gap:8px}
.t-date-group::after{content:'';flex:1;height:0.5px;background:var(--border)}
.sym-pill{padding:2px 8px;border-radius:5px;background:rgba(0,113,227,0.08);color:var(--acc);font-family:var(--m);font-size:11px;font-weight:500}
.dir-l{padding:2px 7px;border-radius:4px;font-size:10px;font-family:var(--f);font-weight:500;background:rgba(52,199,89,0.1);color:var(--g)}
.dir-s{padding:2px 7px;border-radius:4px;font-size:10px;font-family:var(--f);font-weight:500;background:rgba(255,59,48,0.1);color:var(--r)}
.trade-checkbox{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.15s}
.trade-checkbox.checked{background:var(--acc);border-color:var(--acc)}
.trade-checkbox.checked::after{content:'✓';font-size:10px;color:white;font-weight:700}
#select-all-cb{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.15s}
#select-all-cb.checked{background:var(--acc);border-color:var(--acc)}
#select-all-cb.checked::after{content:'✓';font-size:10px;color:white;font-weight:700}
#bulk-delete-bar{position:sticky;top:48px;z-index:150;margin:0 24px 0;background:rgba(0,113,227,0.95);backdrop-filter:blur(12px);border-radius:12px;padding:10px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px rgba(0,113,227,0.25)}

/* ── ANALYTICS ───────────────────────────────────────────────── */
.analytics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 24px;margin-bottom:16px}
.a-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--card-shadow)}
.a-label{font-size:11px;color:var(--t3);letter-spacing:-0.1px;margin-bottom:7px}
.a-val{font-size:32px;font-weight:700;letter-spacing:-2px}
.bar-row{display:flex;align-items:center;gap:9px;margin-bottom:7px}
.bar-label{width:75px;color:var(--t2);font-size:11px;flex-shrink:0;letter-spacing:-0.1px}
.bar-track{flex:1;height:5px;background:var(--bg3);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px}
.bar-val{width:34px;text-align:right;font-family:var(--m);font-size:11px;color:var(--t2)}
.feedback-box{margin:0 24px 32px;background:rgba(0,113,227,0.04);border:0.5px solid rgba(0,113,227,0.15);border-radius:16px;padding:18px 22px}
.fb-head{font-size:12px;color:var(--acc);letter-spacing:-0.1px;margin-bottom:10px;font-weight:500}
.fb-item{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--t2);line-height:1.5;margin-bottom:7px;letter-spacing:-0.1px}
.fb-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px}

/* ── LEARN ───────────────────────────────────────────────────── */
.learn-hero{padding:40px 24px 28px;display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.lesson-list{display:flex;flex-direction:column;gap:6px;padding:0 24px;margin-bottom:36px}
.lesson-row{
  display:flex;align-items:center;gap:13px;
  padding:13px 16px;background:var(--bg1);
  border:0.5px solid var(--border);border-radius:12px;
  cursor:pointer;transition:all 0.15s;box-shadow:var(--card-shadow);
}
.lesson-row:hover{border-color:rgba(0,113,227,0.3);box-shadow:0 2px 12px rgba(0,113,227,0.08)}
.lesson-row.done .l-num{background:rgba(52,199,89,0.12);color:var(--g)}
.lesson-row.active .l-num{background:rgba(0,113,227,0.1);color:var(--acc)}
.l-num{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--m);font-weight:600;background:var(--bg3);color:var(--t3);flex-shrink:0}
.l-title{font-size:14px;font-weight:500;margin-bottom:2px;color:var(--t1);letter-spacing:-0.2px}
.l-sub{font-size:11px;color:var(--t3);letter-spacing:-0.1px}
.l-right{margin-left:auto;display:flex;align-items:center;gap:9px}
.l-time{font-size:11px;font-family:var(--m);color:var(--t3)}
.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px;padding:0 24px;margin-bottom:50px}
.topic-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:18px;overflow:hidden;cursor:pointer;transition:all 0.2s;box-shadow:var(--card-shadow)}
.topic-card:hover{transform:scale(1.01);box-shadow:0 8px 28px rgba(0,0,0,0.1)}
.topic-video{position:relative;aspect-ratio:16/9;overflow:hidden}
.play-ring{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.14);border:1.5px solid rgba(255,255,255,0.32);display:flex;align-items:center;justify-content:center;position:relative;z-index:2;backdrop-filter:blur(8px)}
.vid-dur{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,0.55);color:white;font-size:10px;font-family:var(--m);padding:2px 6px;border-radius:5px;z-index:2}
.topic-body{padding:14px 16px}
.topic-name{font-size:15px;font-weight:600;letter-spacing:-0.4px;margin-bottom:5px;color:var(--t1)}
.topic-desc{font-size:13px;color:var(--t3);line-height:1.55;margin-bottom:10px;letter-spacing:-0.1px}
.tpill{padding:3px 8px;border-radius:5px;font-size:10px;font-weight:500;letter-spacing:-0.1px}

/* ── STRATEGIES ──────────────────────────────────────────────── */
.strat-bar{display:flex;align-items:center;justify-content:space-between;padding:0 24px;margin-bottom:16px}
.create-strat-btn{display:flex;align-items:center;gap:7px;padding:7px 14px;border-radius:20px;background:rgba(0,113,227,0.06);border:0.5px solid rgba(0,113,227,0.2);font-size:12px;font-weight:500;color:var(--acc);cursor:pointer;transition:all 0.15s;letter-spacing:-0.1px}
.create-strat-btn:hover{background:rgba(0,113,227,0.1)}
.strat-grid-new{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px;padding:0 24px;margin-bottom:36px}
.strat-tile{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;padding:20px 18px;cursor:pointer;transition:all 0.2s;position:relative;box-shadow:var(--card-shadow)}
.strat-tile:hover{transform:scale(1.01);box-shadow:0 8px 28px rgba(0,0,0,0.1);border-color:rgba(0,113,227,0.2)}
.strat-num{font-size:10px;font-family:var(--m);color:var(--t3);margin-bottom:9px}
.strat-name{font-size:15px;font-weight:600;letter-spacing:-0.5px;color:var(--t1);margin-bottom:4px;line-height:1.2}
.strat-trader{font-size:11px;color:var(--t3);margin-bottom:12px;letter-spacing:-0.1px}
.strat-pills{display:flex;gap:5px;flex-wrap:wrap}
.sp{padding:3px 7px;border-radius:5px;font-size:10px;font-weight:500}
.strat-win{position:absolute;top:14px;right:14px;font-size:17px;font-weight:700;letter-spacing:-0.5px}
.strat-arrow{position:absolute;bottom:14px;right:14px;color:var(--t3);font-size:13px;transition:all 0.15s}
.strat-tile:hover .strat-arrow{color:var(--acc);transform:translateX(2px)}

/* ── INDICATORS ──────────────────────────────────────────────── */
.ind-how-banner{margin:0 24px 20px;background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;overflow:hidden;display:flex;box-shadow:var(--card-shadow)}
.ind-video-thumb{width:240px;flex-shrink:0;background:#08081a;position:relative;display:flex;align-items:center;justify-content:center;min-height:110px;cursor:pointer}
.ind-banner-body{padding:18px 22px;flex:1}
.ind-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;padding:0 24px;margin-bottom:36px}
.ind-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;overflow:hidden;cursor:pointer;transition:all 0.2s;box-shadow:var(--card-shadow)}
.ind-card:hover{transform:scale(1.01);box-shadow:0 8px 28px rgba(0,0,0,0.1)}
.ind-thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.ind-body{padding:14px 16px}
.ind-name{font-size:14px;font-weight:600;margin-bottom:5px;color:var(--t1);letter-spacing:-0.3px}
.ind-desc{font-size:12px;color:var(--t3);line-height:1.55;margin-bottom:8px;letter-spacing:-0.1px}
.ind-footer{display:flex;justify-content:space-between;align-items:center}
.ind-lang{padding:2px 7px;border-radius:5px;font-size:9px;font-family:var(--m);font-weight:600}

/* ── NEWS ────────────────────────────────────────────────────── */
.news-layout{display:grid;grid-template-columns:1fr 300px;gap:16px;padding:0 24px;margin-bottom:40px}
.news-item{padding:14px 18px;border-bottom:0.5px solid var(--border);background:var(--bg1);transition:background 0.12s;cursor:pointer;position:relative}
.news-item:first-child{border-radius:16px 16px 0 0}
.news-item:last-child{border-bottom:none;border-radius:0 0 16px 16px}
.news-item:hover{background:var(--bg2)}
.news-item.breaking{border-left:2px solid var(--r)}
.news-item.important{border-left:2px solid var(--acc3)}
.news-item.normal{border-left:2px solid transparent}
.news-time{font-size:11px;color:var(--t3);margin-bottom:5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;letter-spacing:-0.1px}
.news-headline{font-size:13px;font-weight:500;color:var(--t1);line-height:1.45;letter-spacing:-0.2px}
.news-tag{padding:1px 7px;border-radius:5px;font-size:9px;font-weight:600;font-family:var(--f);letter-spacing:0}
.news-wrap{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--card-shadow)}
.news-sidebar{display:flex;flex-direction:column;gap:12px}
.market-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--card-shadow)}
.market-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:0.5px solid var(--border);font-size:13px;letter-spacing:-0.1px}
.market-row:last-child{border-bottom:none}
.mkt-name{font-size:11px;font-family:var(--m);font-weight:600;color:var(--t3);min-width:36px}
.mkt-val{font-size:13px;font-weight:600;font-family:var(--m);letter-spacing:-0.3px}
.mkt-chg{font-size:11px;font-family:var(--m);font-weight:500}
.calendar-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--card-shadow)}
.cal-event{display:flex;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--border);align-items:flex-start}
.cal-event:last-child{border-bottom:none}
.cal-time{font-size:10px;font-family:var(--m);color:var(--t3);min-width:45px;flex-shrink:0}
.cal-name{font-size:12px;font-weight:500;color:var(--t1);letter-spacing:-0.1px}
.cal-impact{padding:2px 6px;border-radius:5px;font-size:9px;font-weight:600}
.high-impact{background:rgba(255,59,48,0.1);color:var(--r)}
.med-impact{background:rgba(245,166,35,0.1);color:var(--acc3)}
.low-impact{background:rgba(52,199,89,0.1);color:var(--g)}
.news-top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.live-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;background:rgba(255,59,48,0.08);border:0.5px solid rgba(255,59,48,0.2);font-size:11px;font-weight:500;color:var(--r)}
.news-filter{display:flex;gap:5px}
.news-live-dot{width:6px;height:6px;border-radius:50%;background:var(--r);animation:demopulse 2s infinite}

/* ── FOREXFACTORY CALENDAR ───────────────────────────────────── */
.ff-th{display:grid;grid-template-columns:90px 70px 60px 1fr 90px 90px 90px;padding:7px 16px;background:var(--bg2);border-bottom:0.5px solid var(--border);gap:4px}
.ff-th span{font-size:10px;font-family:var(--f);color:var(--t3);font-weight:500;letter-spacing:-0.1px}
.ff-row{display:grid;grid-template-columns:90px 70px 60px 1fr 90px 90px 90px;padding:9px 16px;border-bottom:0.5px solid var(--border);align-items:center;gap:4px;transition:background 0.12s}
.ff-row:last-child{border-bottom:none}
.ff-row:hover{background:var(--bg2)}
.ff-row.high-row{border-left:2px solid var(--r)}
.ff-row.med-row{border-left:2px solid var(--acc3)}
.ff-row.low-row{border-left:2px solid transparent}
.ff-time{font-size:12px;font-family:var(--m);color:var(--t2);font-weight:500}
.ff-time.past{color:var(--t3);text-decoration:line-through}
.ff-time.next{color:var(--acc3);font-weight:700}
.ff-currency{font-size:11px;font-family:var(--m);font-weight:600;padding:2px 7px;border-radius:5px;background:rgba(0,0,0,0.05);color:var(--t2);display:inline-block;letter-spacing:0}
body.dark .ff-currency{background:rgba(255,255,255,0.08)}
.ff-currency.usd{background:rgba(52,199,89,0.1);color:var(--g)}
.ff-impact-high{width:9px;height:9px;border-radius:50%;background:var(--r);display:inline-block}
.ff-impact-med{width:9px;height:9px;border-radius:50%;background:var(--acc3);display:inline-block}
.ff-impact-low{width:9px;height:9px;border-radius:50%;background:var(--bg4);display:inline-block}
.ff-event-name{font-size:12px;color:var(--t1);font-weight:500;letter-spacing:-0.1px}
.ff-val{font-size:12px;font-family:var(--m);text-align:right}
.ff-val.actual-beat{color:var(--g);font-weight:700}
.ff-val.actual-miss{color:var(--r);font-weight:700}
.ff-val.actual-inline{color:var(--acc3);font-weight:700}
.ff-val.forecast{color:var(--t2)}
.ff-val.previous{color:var(--t3)}
.ff-day-tab{padding:4px 11px;border-radius:20px;font-size:11px;font-weight:400;color:var(--t3);cursor:pointer;transition:all 0.15s;letter-spacing:-0.1px}
.ff-day-tab:hover{color:var(--t2)}
.ff-day-tab.active{background:rgba(0,113,227,0.08);color:var(--acc)}
.ff-section-header{padding:6px 16px;background:rgba(0,113,227,0.03);border-bottom:0.5px solid var(--border);font-size:10px;color:var(--acc);font-weight:500;letter-spacing:-0.1px}
.ff-next-badge{display:inline-block;font-size:9px;font-weight:600;padding:1px 6px;border-radius:5px;background:rgba(245,166,35,0.12);color:var(--acc3);margin-left:6px;vertical-align:middle}

/* ── EXPENSES / FINANCES ─────────────────────────────────────── */
.exp-layout{display:grid;grid-template-columns:1fr 280px;gap:16px;padding:0 24px;margin-bottom:40px}
.exp-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:0 24px;margin-bottom:16px}
.exp-sum-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--card-shadow)}
.exp-sum-num{font-size:26px;font-weight:700;letter-spacing:-1.5px;margin-top:5px}
.exp-sum-lbl{font-size:11px;color:var(--t3);letter-spacing:-0.1px}
.exp-table{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--card-shadow)}
.exp-th{display:grid;grid-template-columns:140px 1fr 100px 90px 80px;padding:9px 16px;border-bottom:0.5px solid var(--border);background:var(--bg2)}
.exp-th span{font-size:10px;font-family:var(--f);color:var(--t3);font-weight:500;letter-spacing:-0.1px}
.exp-row{display:grid;grid-template-columns:140px 1fr 100px 90px 80px;padding:11px 16px;border-bottom:0.5px solid var(--border);align-items:center;font-size:13px;transition:background 0.12s;cursor:pointer;letter-spacing:-0.1px}
.exp-row:last-child{border-bottom:none}
.exp-row:hover{background:var(--bg2)}
.exp-cat{padding:2px 8px;border-radius:5px;font-size:10px;font-weight:600;display:inline-block;letter-spacing:-0.1px}
.exp-add-form{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--card-shadow)}
.exp-sidebar-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;padding:18px;margin-bottom:12px;box-shadow:var(--card-shadow)}
.prop-account{padding:11px 14px;background:var(--bg2);border-radius:10px;margin-bottom:8px;border:0.5px solid var(--border)}
.prop-account:last-child{margin-bottom:0}
.prop-firm{font-size:13px;font-weight:500;color:var(--t1);letter-spacing:-0.2px}
.prop-detail{font-size:11px;color:var(--t3);margin-top:2px;letter-spacing:-0.1px}
.prop-status{font-size:10px;font-family:var(--f);padding:2px 8px;border-radius:5px;font-weight:500}
.status-active{background:rgba(52,199,89,0.1);color:var(--g)}
.status-failed{background:rgba(255,59,48,0.1);color:var(--r)}
.status-eval{background:rgba(245,166,35,0.1);color:var(--acc3)}
.export-btn{
  width:100%;padding:11px;border-radius:10px;
  font-size:13px;font-weight:500;letter-spacing:-0.1px;
  border:0.5px solid var(--border2);
  background:transparent;color:var(--t2);
  cursor:pointer;transition:all 0.15s;
  margin-top:10px;display:flex;align-items:center;justify-content:center;gap:8px;
}
.export-btn:hover{border-color:rgba(0,113,227,0.3);color:var(--acc);background:rgba(0,113,227,0.04)}
.export-btn.primary{background:var(--acc);color:#fff;border-color:var(--acc)}
.export-btn.primary:hover{opacity:0.82;background:var(--acc)}
.tax-tip{background:rgba(0,113,227,0.04);border:0.5px solid rgba(0,113,227,0.15);border-radius:10px;padding:12px;margin-top:12px;font-size:11px;color:var(--t2);line-height:1.6;letter-spacing:-0.1px}
.tax-tip strong{color:var(--acc);font-weight:600}
.income-table{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--card-shadow)}
.inc-th{display:grid;grid-template-columns:100px 1fr 90px 90px 80px;padding:9px 16px;border-bottom:0.5px solid var(--border);background:var(--bg2)}
.inc-th span{font-size:10px;font-family:var(--f);color:var(--t3);font-weight:500;letter-spacing:-0.1px}
.inc-type{padding:2px 8px;border-radius:5px;font-size:10px;font-weight:600;display:inline-block;letter-spacing:-0.1px}
.inc-prop{background:rgba(0,113,227,0.08);color:var(--acc)}
.inc-ref{background:rgba(0,168,132,0.1);color:var(--acc2)}
.inc-other{background:rgba(245,166,35,0.1);color:var(--acc3)}
.inc-row{display:grid;grid-template-columns:100px 1fr 90px 90px 80px;padding:11px 16px;border-bottom:0.5px solid var(--border);align-items:center;cursor:pointer;transition:background 0.12s;font-size:13px;letter-spacing:-0.1px}
.inc-row:last-child{border-bottom:none}
.inc-row:hover{background:var(--bg2)}
.pnl-net{font-size:32px;font-weight:700;letter-spacing:-2px;margin-top:8px;margin-bottom:2px}
.pnl-bar-wrap{display:flex;height:8px;border-radius:6px;overflow:hidden;margin:12px 0 6px;gap:2px}
.pnl-bar-inc{background:var(--g);border-radius:6px 0 0 6px}
.pnl-bar-exp{background:var(--r);border-radius:0 6px 6px 0}
.export-btn-sm{display:flex;align-items:center;gap:6px;padding:6px 13px;border-radius:20px;font-size:12px;font-weight:500;border:0.5px solid var(--border2);background:transparent;color:var(--t2);cursor:pointer;transition:all 0.15s;letter-spacing:-0.1px}
.export-btn-sm:hover{border-color:rgba(0,113,227,0.3);color:var(--acc)}
.export-btn-sm.excel{border-color:rgba(52,199,89,0.3);color:var(--g)}
.export-btn-sm.excel:hover{background:rgba(52,199,89,0.06)}
.export-btn-sm.pdf{border-color:rgba(255,59,48,0.3);color:var(--r)}
.export-btn-sm.pdf:hover{background:rgba(255,59,48,0.06)}

/* ── TAX EXPERTS ─────────────────────────────────────────────── */
.tax-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:16px;padding:20px;transition:all 0.2s;box-shadow:var(--card-shadow)}
.tax-card:hover{transform:scale(1.005);box-shadow:0 6px 24px rgba(0,0,0,0.08)}
.tax-badge{padding:3px 9px;border-radius:20px;font-size:10px;font-weight:500;background:rgba(0,113,227,0.08);color:var(--acc);border:0.5px solid rgba(0,113,227,0.2);white-space:nowrap}
.tax-tag{padding:2px 8px;border-radius:5px;font-size:10px;font-weight:500;background:var(--bg2);color:var(--t3);border:0.5px solid var(--border)}
.tax-btn-primary{padding:7px 14px;border-radius:20px;background:var(--acc);color:white;font-size:12px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;transition:opacity 0.15s;font-family:var(--f);border:none;letter-spacing:-0.1px}
.tax-btn-primary:hover{opacity:0.82}
.tax-btn-ghost{padding:7px 14px;border-radius:20px;background:transparent;color:var(--t2);font-size:12px;font-weight:500;cursor:pointer;border:0.5px solid var(--border2);transition:all 0.15s;letter-spacing:-0.1px}
.tax-btn-ghost:hover{border-color:rgba(0,113,227,0.3);color:var(--acc)}
.tax-chip{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:400;background:transparent;color:var(--t3);border:0.5px solid var(--border2);cursor:pointer;transition:all 0.15s;letter-spacing:-0.1px}
.tax-chip.on{background:rgba(0,113,227,0.08);border-color:rgba(0,113,227,0.25);color:var(--acc)}

/* ── PRICING ─────────────────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:660px;margin:0 auto 50px;padding:0 24px}
.price-card{background:var(--bg1);border:0.5px solid var(--border);border-radius:20px;padding:26px;box-shadow:var(--card-shadow)}
.price-card.featured{border-color:rgba(0,113,227,0.3);background:rgba(0,113,227,0.02)}
.price-tier{font-size:12px;color:var(--t3);letter-spacing:-0.1px;margin-bottom:10px}
.price-big{font-size:44px;font-weight:700;letter-spacing:-2.5px;line-height:1;color:var(--t1)}
.price-big.acc{color:var(--acc)}
.price-big sup{font-size:20px;vertical-align:top;margin-top:7px;font-weight:500}
.price-period{font-size:12px;color:var(--t3);margin-bottom:18px;letter-spacing:-0.1px}
.price-feature{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--t2);padding:6px 0;border-bottom:0.5px solid var(--border);letter-spacing:-0.1px}
.price-feature:last-of-type{border-bottom:none;margin-bottom:14px}
.pf-check{color:var(--g);flex-shrink:0}
.pf-lock{color:var(--t3);flex-shrink:0}

/* ── MODALS ──────────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:500;padding:20px}
.modal-box{background:var(--bg1);border:0.5px solid var(--border);border-radius:20px;padding:26px;width:100%;max-width:520px;max-height:88vh;overflow-y:auto;position:relative;box-shadow:0 24px 64px rgba(0,0,0,0.15)}
.modal-box.wide{max-width:760px}
.modal-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,0.06);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--t2);transition:background 0.15s}
body.dark .modal-close{background:rgba(255,255,255,0.08)}
.modal-close:hover{background:rgba(0,0,0,0.1)}
.modal-title{font-size:20px;font-weight:700;letter-spacing:-0.8px;margin-bottom:4px;color:var(--t1)}
.code-block{background:#1a1a2e;border-radius:12px;padding:16px;font-family:var(--m);font-size:11px;color:#a9b1d6;line-height:1.7;overflow-x:auto;margin-top:11px}
.code-block .kw{color:#bb9af7}.code-block .fn{color:#7aa2f7}.code-block .str{color:#9ece6a}.code-block .cm{color:#565f89;font-style:italic}
.copy-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:20px;background:rgba(0,113,227,0.08);border:0.5px solid rgba(0,113,227,0.2);font-size:11px;font-family:var(--m);color:var(--acc);cursor:pointer;margin-top:9px;font-weight:500}
.rules-ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.rules-ul li{font-size:12px;color:var(--t2);display:flex;gap:8px;line-height:1.5;letter-spacing:-0.1px}
.rules-ul li::before{content:'—';color:var(--border3);flex-shrink:0}

/* ── MONTHLY CALENDAR ────────────────────────────────────────── */
.cal-section{padding:0 24px;margin-bottom:32px}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-month-nav{display:flex;align-items:center;gap:10px}
.cal-month-btn{width:30px;height:30px;border-radius:50%;background:var(--bg2);border:0.5px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:15px;transition:all 0.15s}
.cal-month-btn:hover{border-color:rgba(0,113,227,0.3);color:var(--acc)}
.cal-month-label{font-size:18px;font-weight:700;letter-spacing:-0.7px;color:var(--t1);min-width:150px;text-align:center}
.cal-today-btn{padding:5px 14px;border-radius:20px;font-size:12px;font-weight:400;border:0.5px solid var(--border2);background:transparent;color:var(--t2);cursor:pointer;transition:all 0.15s;letter-spacing:-0.1px}
.cal-today-btn:hover{border-color:rgba(0,113,227,0.3);color:var(--acc)}
.cal-monthly-pnl{font-size:13px;font-family:var(--m);font-weight:600}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr) 110px;gap:0.5px;background:var(--border);border:0.5px solid var(--border);border-radius:16px;overflow:hidden}
.cal-dow{background:var(--bg2);padding:9px 10px;font-size:10px;font-weight:500;letter-spacing:-0.1px;color:var(--t3);text-align:center}
.cal-dow.week-col{background:rgba(0,113,227,0.04);color:var(--acc);border-left:0.5px solid rgba(0,113,227,0.15)}
.cal-day{background:var(--bg1);padding:10px 12px;min-height:84px;cursor:pointer;transition:background 0.12s;position:relative}
.cal-day:hover{background:var(--bg2)}
.cal-day.today{background:rgba(0,113,227,0.05)}
.cal-day.win{background:rgba(52,199,89,0.06)}
.cal-day.big-win{background:rgba(52,199,89,0.12)}
.cal-day.loss{background:rgba(255,59,48,0.06)}
.cal-day.empty{background:var(--bg2);opacity:0.5}
.cal-day-num{font-size:11px;font-weight:500;color:var(--t3);margin-bottom:4px;letter-spacing:-0.1px}
.cal-day.today .cal-day-num{color:var(--acc);font-weight:700}
.cal-pnl{font-size:14px;font-weight:700;letter-spacing:-0.5px;line-height:1}
.cal-pnl.pos{color:var(--g)}
.cal-pnl.neg{color:var(--r)}
.cal-trades{font-size:9px;color:var(--t3);margin-top:3px;letter-spacing:-0.1px}
.cal-summary-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px;font-size:12px;color:var(--t3)}
.cal-week-cell{background:rgba(0,113,227,0.03);padding:10px 12px;min-height:84px;display:flex;flex-direction:column;justify-content:center;border-left:1.5px solid rgba(0,113,227,0.15)}
body.dark .cal-week-cell{background:rgba(0,113,227,0.05)}
.cal-week-label{font-size:9px;font-weight:500;color:var(--t3);margin-bottom:5px}
.cal-week-pnl{font-size:16px;font-weight:700;letter-spacing:-0.8px;line-height:1}
.cal-week-pnl.pos{color:var(--g)}.cal-week-pnl.neg{color:var(--r)}
.cal-week-trades{font-size:10px;color:var(--t3);margin-top:4px;letter-spacing:-0.1px}

/* ── TOAST ───────────────────────────────────────────────────── */
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(10px)}}

/* ── DEMO BADGE ──────────────────────────────────────────────── */
.demo-badge{
  position:fixed;bottom:24px;right:24px;z-index:400;
  display:flex;align-items:center;gap:8px;
  padding:8px 15px 8px 11px;border-radius:20px;
  background:rgba(255,255,255,0.88);
  border:0.5px solid rgba(0,0,0,0.1);
  box-shadow:0 4px 20px rgba(0,0,0,0.1);
  cursor:pointer;transition:all 0.2s;user-select:none;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
body.dark .demo-badge{background:rgba(44,44,46,0.9);border-color:rgba(255,255,255,0.1);box-shadow:0 4px 20px rgba(0,0,0,0.4)}
.demo-badge:hover{box-shadow:0 6px 24px rgba(0,113,227,0.15);border-color:rgba(0,113,227,0.25);transform:translateY(-1px)}
.demo-dot{width:7px;height:7px;border-radius:50%;background:var(--acc3);flex-shrink:0;animation:demopulse 2.4s ease-in-out infinite}
@keyframes demopulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.45;transform:scale(0.75)}}
.demo-label{display:flex;flex-direction:column;gap:1px}
.demo-label b{font-size:11px;font-weight:600;color:var(--t2);letter-spacing:-0.1px}
.demo-label small{font-size:9px;color:var(--t3)}
.demo-x{width:16px;height:16px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--t3);margin-left:2px;flex-shrink:0;transition:all 0.15s}
.demo-badge:hover .demo-x{background:rgba(0,113,227,0.1);color:var(--acc)}

/* ── DEMO CONFIRM ────────────────────────────────────────────── */
#demo-confirm{position:fixed;inset:0;background:rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center;z-index:600;padding:20px;backdrop-filter:blur(8px);animation:fadeInBg 0.18s ease}
@keyframes fadeInBg{from{opacity:0}to{opacity:1}}
.demo-box{background:var(--bg1);border:0.5px solid var(--border);border-radius:20px;padding:28px;max-width:370px;width:100%;box-shadow:0 24px 64px rgba(0,0,0,0.15);animation:slideUpBox 0.2s ease}
@keyframes slideUpBox{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── SPOTLIGHT TOUR ──────────────────────────────────────────── */
.tour-spotlight-ring{position:fixed;border-radius:12px;box-shadow:0 0 0 9999px rgba(0,0,0,0.65);transition:all 0.45s cubic-bezier(0.4,0,0.2,1);z-index:802;pointer-events:none;border:1.5px solid rgba(0,113,227,0.6);opacity:0}
.tour-spotlight-ring.visible{opacity:1}
.tour-card{
  position:fixed;z-index:803;width:360px;
  background:rgba(255,255,255,0.92);
  border:0.5px solid rgba(0,0,0,0.1);border-radius:18px;
  box-shadow:0 24px 60px rgba(0,0,0,0.18);
  padding:0 0 16px;
  transition:all 0.4s cubic-bezier(0.4,0,0.2,1);
  pointer-events:all;overflow:hidden;
  opacity:0;transform:translateY(8px);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
body.dark .tour-card{background:rgba(44,44,46,0.96);border-color:rgba(255,255,255,0.1)}
.tour-card.visible{opacity:1;transform:translateY(0)}
.tour-card-progress{height:3px;background:var(--bg3)}
.tour-card-progress-fill{height:100%;background:var(--acc);transition:width 0.4s ease}
.tour-card-body{padding:0 18px}
.tour-card-eyebrow{font-size:10px;color:var(--acc);font-weight:500;margin-bottom:5px;margin-top:14px;letter-spacing:-0.1px}
.tour-card-title{font-size:16px;font-weight:600;letter-spacing:-0.5px;color:var(--t1);margin-bottom:10px;line-height:1.2}
.tour-checklist{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.tour-check-item{display:flex;align-items:flex-start;gap:9px;padding:9px 11px;border-radius:10px;background:rgba(0,0,0,0.03);border:0.5px solid rgba(0,0,0,0.06)}
body.dark .tour-check-item{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.06)}
.tour-check-num{width:18px;height:18px;border-radius:5px;background:rgba(0,113,227,0.1);border:0.5px solid rgba(0,113,227,0.2);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--acc);flex-shrink:0;font-family:var(--m);margin-top:1px}
.tour-check-text{font-size:12px;color:var(--t2);line-height:1.5;letter-spacing:-0.1px}
.tour-check-text strong{color:var(--t1);font-weight:600}
.tour-tip{background:rgba(0,113,227,0.04);border:0.5px solid rgba(0,113,227,0.12);border-radius:9px;padding:9px 12px;font-size:11px;color:var(--t3);line-height:1.5;margin-bottom:12px;letter-spacing:-0.1px}
.tour-footer{display:flex;align-items:center;justify-content:space-between;padding:0 18px}
.tour-step-dot{width:6px;height:6px;border-radius:50%;background:var(--bg3);transition:all 0.2s;cursor:pointer}
.tour-step-dot.active{background:var(--acc);transform:scale(1.4)}
.tour-step-dot.done{background:rgba(0,113,227,0.3)}

/* ── MISC COMPONENTS ─────────────────────────────────────────── */
.live-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;background:rgba(255,59,48,0.08);border:0.5px solid rgba(255,59,48,0.2);font-size:11px;font-weight:500;color:var(--r)}
.export-group{display:flex;gap:7px;margin-left:auto}
.onboarding-tour{position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:700;padding:20px}
.play-ring{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.14);border:1.5px solid rgba(255,255,255,0.32);display:flex;align-items:center;justify-content:center;position:relative;z-index:2;backdrop-filter:blur(8px)}

/* ── NOTES ───────────────────────────────────────────────── */
.notes-shell{display:grid;grid-template-columns:260px 1fr;height:calc(100vh - 48px);overflow:hidden;background:var(--bg)}
.notes-sidebar{border-right:0.5px solid var(--border);display:flex;flex-direction:column;background:var(--bg1);overflow:hidden}
.notes-sidebar-top{padding:14px 14px 10px;border-bottom:0.5px solid var(--border)}
.notes-search{width:100%;padding:8px 12px;border-radius:10px;border:0.5px solid var(--border2);background:rgba(0,0,0,0.04);font-size:13px;color:var(--t1);font-family:var(--f);outline:none;transition:all 0.15s}
body.dark .notes-search{background:rgba(255,255,255,0.05)}
.notes-search:focus{border-color:var(--acc);background:var(--bg1);box-shadow:0 0 0 3px rgba(0,113,227,0.1)}
.notes-tag-filters{display:flex;gap:5px;flex-wrap:wrap;padding:8px 14px 10px;border-bottom:0.5px solid var(--border)}
.notes-tag-filter{padding:3px 10px;border-radius:20px;font-size:11px;border:0.5px solid var(--border2);color:var(--t3);background:transparent;cursor:pointer;transition:all 0.15s;white-space:nowrap}
.notes-tag-filter.on{background:rgba(0,113,227,0.08);border-color:rgba(0,113,227,0.25);color:var(--acc)}
.notes-list{flex:1;overflow-y:auto;padding:6px 0}
.notes-list::-webkit-scrollbar{width:4px}.notes-list::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}
.note-list-item{padding:10px 14px;cursor:pointer;border-bottom:0.5px solid var(--border);transition:background 0.12s;position:relative}
.note-list-item:hover{background:var(--bg2)}
.note-list-item.active{background:rgba(0,113,227,0.06)}
.note-list-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2.5px;background:var(--acc);border-radius:0 2px 2px 0}
.nli-title{font-size:13px;font-weight:500;color:var(--t1);letter-spacing:-0.2px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nli-preview{font-size:11px;color:var(--t3);letter-spacing:-0.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px}
.nli-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.nli-date{font-size:10px;color:var(--t3);letter-spacing:-0.1px}
.nli-tag{padding:1px 6px;border-radius:4px;font-size:10px;font-weight:500;letter-spacing:-0.1px}
.nli-trade-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--acc2);background:rgba(0,168,132,0.08);border:0.5px solid rgba(0,168,132,0.2);border-radius:4px;padding:1px 5px}
.notes-empty{padding:40px 20px;text-align:center;color:var(--t3)}
.notes-empty svg{margin:0 auto 12px;display:block;opacity:0.3}
.notes-empty p{font-size:13px;line-height:1.6}
.notes-editor{display:flex;flex-direction:column;overflow:hidden;background:var(--bg1)}
.notes-editor-toolbar{padding:12px 20px 11px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}
.notes-editor-actions{display:flex;gap:7px;align-items:center}
.note-action-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:400;letter-spacing:-0.1px;border:0.5px solid var(--border2);background:transparent;color:var(--t2);cursor:pointer;transition:all 0.15s;font-family:var(--f)}
.note-action-btn:hover{border-color:var(--acc);color:var(--acc);background:rgba(0,113,227,0.04)}
.note-action-btn.primary{background:var(--acc);color:#fff;border-color:var(--acc)}
.note-action-btn.primary:hover{opacity:0.82}
.note-action-btn.danger{border-color:rgba(255,59,48,0.3);color:var(--r)}
.note-action-btn.danger:hover{background:rgba(255,59,48,0.06);border-color:var(--r)}
.note-save-status{font-size:11px;color:var(--t3);letter-spacing:-0.1px}
.notes-editor-body{flex:1;overflow-y:auto;padding:24px 28px 20px;display:flex;flex-direction:column;gap:14px}
.notes-editor-body::-webkit-scrollbar{width:4px}.notes-editor-body::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}
.note-title-input{width:100%;font-size:22px;font-weight:700;letter-spacing:-0.8px;color:var(--t1);background:transparent;border:none;outline:none;font-family:var(--f);padding:0;line-height:1.2}
.note-title-input::placeholder{color:var(--t3)}
.note-meta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.note-source-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:400;background:rgba(0,168,132,0.08);border:0.5px solid rgba(0,168,132,0.2);color:var(--acc2)}
.note-date-badge{font-size:11px;color:var(--t3);letter-spacing:-0.1px}
.notes-tag-input-wrap{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:8px 12px;border-radius:10px;border:0.5px solid var(--border2);background:rgba(0,0,0,0.03);cursor:text;min-height:38px}
body.dark .notes-tag-input-wrap{background:rgba(255,255,255,0.04)}
.note-tag-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500;cursor:pointer;transition:opacity 0.15s}
.note-tag-pill:hover{opacity:0.7}
.note-tag-pill .tag-x{font-size:10px;opacity:0.6;margin-left:1px}
.note-tag-raw-input{border:none;outline:none;background:transparent;font-size:12px;color:var(--t2);font-family:var(--f);flex:1;min-width:80px;padding:2px 0}
.note-tag-raw-input::placeholder{color:var(--t3)}
.note-content-area{flex:1;min-height:260px;width:100%;background:transparent;border:none;outline:none;font-size:14px;color:var(--t1);font-family:var(--f);line-height:1.7;letter-spacing:-0.1px;resize:none;padding:0}
.note-content-area::placeholder{color:var(--t3)}
.note-linked-section{margin-top:4px}
.note-linked-header{font-size:11px;font-weight:500;color:var(--t3);letter-spacing:-0.1px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.note-linked-header span{flex:1;height:0.5px;background:var(--border);display:block}
.linked-trades-row{display:flex;gap:7px;flex-wrap:wrap}
.linked-trade-pill{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:10px;border:0.5px solid var(--border2);background:var(--bg2);font-size:12px;cursor:pointer;transition:all 0.15s}
.linked-trade-pill:hover{border-color:var(--r);background:rgba(255,59,48,0.04)}
.linked-trade-pill .lt-sym{font-size:11px;font-family:var(--m);font-weight:600;padding:1px 6px;border-radius:4px;background:rgba(0,113,227,0.08);color:var(--acc)}
.linked-trade-pill .lt-dir{font-size:10px;font-weight:500;color:var(--t3)}
.linked-trade-pill .lt-pnl{font-size:12px;font-weight:600;font-family:var(--m)}
.linked-trade-pill .lt-remove{font-size:10px;color:var(--t3);opacity:0.6;margin-left:2px;transition:opacity 0.15s}
.linked-trade-pill:hover .lt-remove{opacity:1;color:var(--r)}
.notes-new-btn{margin:10px 14px 4px;padding:8px 14px;border-radius:10px;font-size:13px;font-weight:500;background:var(--acc);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:opacity 0.15s;font-family:var(--f);letter-spacing:-0.1px}
.notes-new-btn:hover{opacity:0.82}
.link-trade-modal{max-width:480px}
.lt-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;border:0.5px solid var(--border);cursor:pointer;transition:all 0.15s;margin-bottom:7px}
.lt-row:hover{border-color:var(--acc);background:rgba(0,113,227,0.03)}
.lt-row.selected{border-color:var(--acc);background:rgba(0,113,227,0.06)}
.lt-row-check{width:17px;height:17px;border-radius:50%;border:1.5px solid var(--border3);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
.lt-row.selected .lt-row-check{background:var(--acc);border-color:var(--acc)}
.lt-row.selected .lt-row-check::after{content:'✓';font-size:10px;color:#fff;font-weight:700}
.notes-no-select{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--t3);gap:12px}
.notes-no-select svg{opacity:0.2}
.notes-no-select p{font-size:13px;line-height:1.6;text-align:center;max-width:220px}
