/* ══ THEME VARIABLES ══ */
:root{
  --bg:#ffffff; --surface:#f9fafb; --surface2:#f3f4f6;
  --border:#e5e7eb; --border2:#f3f4f6;
  --text:#111827; --text2:#374151; --text3:#6b7280; --text4:#9ca3af; --text5:#d1d5db;
  --profit:#00c853; --profit-bg:#edfbf3; --profit-badge:#c6f7de; --profit-badge-t:#00a844;
  --loss:#ff1744;   --loss-bg:#fff0f0;   --loss-badge:#ffd6d6;   --loss-badge-t:#d50000;
  --today:#3b82f6;  --today-bg:#eff6ff;  --today-num:#2563eb;
  --sel:#6366f1;
  --logo-bg:#111827; --logo-fg:#ffffff;
  --btn-inv:#111827; --btn-inv-h:#1f2937;
  --shadow:rgba(0,0,0,.15);
}
[data-theme="dark"]{
  --bg:#111113; --surface:#18181b; --surface2:#1c1c1f;
  --border:#2d2d30; --border2:#242427;
  --text:#fafafa; --text2:#d4d4d8; --text3:#a1a1aa; --text4:#71717a; --text5:#52525b;
  --profit:#07db74; --profit-bg:rgba(0,230,118,.18); --profit-badge:rgba(0,230,118,.32); --profit-badge-t:#00e676;
  --loss:#ff4444;   --loss-bg:rgba(255,68,68,.18);  --loss-badge:rgba(255,68,68,.32);   --loss-badge-t:#ff6b6b;
  --today:#60a5fa;  --today-bg:rgba(96,165,250,.09); --today-num:#93c5fd;
  --sel:#818cf8;
  --logo-bg:#fafafa; --logo-fg:#111113;
  --btn-inv:#fafafa; --btn-inv-h:#e4e4e7;
  --shadow:rgba(0,0,0,.45);
}

/* ══ AUTH MODAL ══ */
.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s}
.auth-overlay.open{opacity:1;pointer-events:all}
.auth-box{background:var(--bg);border:1px solid var(--border);border-radius:14px;width:calc(100% - 32px);max-width:380px;box-shadow:0 32px 80px rgba(0,0,0,.4);transform:translateY(12px) scale(.98);transition:transform .2s,opacity .2s;opacity:0}
.auth-overlay.open .auth-box{transform:translateY(0) scale(1);opacity:1}
/* top bar inside modal */
.auth-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0}
.auth-brand{display:flex;align-items:center;gap:7px}
.auth-brand-sq{width:26px;height:26px;background:var(--btn-inv);border-radius:6px;display:flex;align-items:center;justify-content:center}
.auth-brand-name{font-size:13px;font-weight:700;color:var(--text)}
/* header */
.auth-header{padding:20px 24px 0}
.auth-title{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.4px;margin-bottom:4px}
.auth-sub{font-size:13px;color:var(--text3);line-height:1.5}
/* tabs */
.auth-tabs{display:flex;margin:18px 24px 0;background:var(--surface);border-radius:8px;padding:3px;gap:3px}
.auth-tab{flex:1;padding:7px;text-align:center;font-size:12px;font-weight:600;color:var(--text3);cursor:pointer;border-radius:6px;transition:all .15s}
.auth-tab.active{background:var(--bg);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.12)}
/* body */
.auth-body{padding:18px 24px 24px}
.auth-field{margin-bottom:12px}
.auth-label{font-size:11px;font-weight:600;color:var(--text3);margin-bottom:5px;display:block;letter-spacing:.2px;text-transform:uppercase}
.auth-input{width:100%;padding:10px 13px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}
.auth-input:focus{border-color:var(--text3);box-shadow:0 0 0 3px rgba(113,113,122,.1)}
.auth-input::placeholder{color:var(--text5)}
.auth-btn{width:100%;padding:11px;background:var(--btn-inv);color:var(--logo-fg);border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s;margin-top:4px;letter-spacing:.1px}
.auth-btn:hover{opacity:.88}
.auth-btn:disabled{opacity:.4;cursor:not-allowed}
.auth-divider{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--text5);font-size:11px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-google{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}
.auth-google:hover{background:var(--surface2);border-color:var(--border2)}
.auth-msg{font-size:12px;text-align:center;margin-top:10px;padding:8px 12px;border-radius:7px;display:none}
.auth-msg.error{display:block;background:rgba(255,68,68,.08);color:#ff4444;border:1px solid rgba(255,68,68,.15)}
.auth-msg.success{display:block;background:rgba(0,200,83,.08);color:#00c853;border:1px solid rgba(0,200,83,.15)}
.auth-forget{font-size:11px;color:var(--text4);text-align:right;margin-top:-6px;margin-bottom:12px;cursor:pointer;transition:color .1s}
.auth-forget:hover{color:var(--text2)}
.auth-footer{padding:14px 24px;border-top:1px solid var(--border);text-align:center;font-size:11px;color:var(--text4)}
@keyframes auth-bounce-in{0%{transform:scale(.7);opacity:0}60%{transform:scale(1.08)}80%{transform:scale(.96)}100%{transform:scale(1);opacity:1}}
.auth-confirm{padding:32px 24px 28px;text-align:center;display:none}
.auth-confirm.show{display:block;animation:auth-bounce-in .4s cubic-bezier(.34,1.56,.64,1) both}
.auth-confirm-icon{width:52px;height:52px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--text3)}
.auth-confirm-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:-.3px}
.auth-confirm-sub{font-size:13px;color:var(--text3);line-height:1.6;margin-bottom:24px}
.auth-confirm-email{font-weight:600;color:var(--text);font-size:13px}
/* User chip in topbar */
.user-chip{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 6px;border:1px solid var(--border);border-radius:20px;background:var(--surface);cursor:pointer;transition:background .15s;font-size:12px;color:var(--text2)}
.user-chip:hover{background:var(--surface2)}
.user-avatar{width:24px;height:24px;border-radius:50%;background:var(--btn-inv);color:var(--logo-fg);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.user-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg);border:1px solid var(--border);border-radius:10px;min-width:180px;box-shadow:0 8px 24px var(--shadow);z-index:1700;overflow:hidden;display:none}
.user-menu.open{display:block}
.user-menu-item{padding:10px 14px;font-size:13px;color:var(--text2);cursor:pointer;transition:background .1s}
.user-menu-item:hover{background:var(--surface)}
.user-menu-item.danger{color:#ff4444}
.user-menu-sep{height:1px;background:var(--border)}
.user-menu-email{padding:10px 14px 6px;font-size:11px;color:var(--text4)}
.user-chip-wrap{position:relative}

/* ── Settings dropdown ── */
.btn-icon-only{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:7px;color:var(--text2)}
.settings-wrap{position:relative}
.settings-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg);border:1px solid var(--border);border-radius:10px;min-width:200px;box-shadow:0 8px 24px var(--shadow);z-index:1700;overflow:hidden;display:none}
.settings-menu.open{display:block}
.settings-item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13px;color:var(--text2);cursor:pointer;transition:background .1s}
.settings-item:hover{background:var(--surface)}
.settings-item svg{flex-shrink:0;opacity:.7}
.settings-sep{height:1px;background:var(--border);margin:2px 0}
.settings-section-label{padding:8px 14px 3px;font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.5px}

/* ── Tutorial Modal ── */
.tutorial-box{background:var(--bg);border:1px solid var(--border);border-radius:16px;width:calc(100% - 32px);max-width:620px;max-height:90vh;overflow-y:auto;box-shadow:0 32px 80px rgba(0,0,0,.4);transform:translateY(12px) scale(.98);transition:transform .2s,opacity .2s;opacity:0;padding:28px 24px;position:relative}
.auth-overlay.open .tutorial-box{transform:translateY(0) scale(1);opacity:1}
.tutorial-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.tutorial-grid{grid-template-columns:1fr}}
.tutorial-card{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:12px;overflow:hidden;text-decoration:none;color:var(--text);transition:all .15s;background:var(--surface)}
.tutorial-card:hover{border-color:var(--accent,#6366f1);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.tutorial-thumb{position:relative;aspect-ratio:16/9;background:var(--surface2);overflow:hidden}
.tutorial-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.tutorial-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);opacity:0;transition:opacity .15s}
.tutorial-card:hover .tutorial-play{opacity:1}
.tutorial-play svg{filter:drop-shadow(0 2px 6px rgba(0,0,0,.5))}
.tutorial-info{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.tutorial-title{font-size:12px;font-weight:600;color:var(--text);line-height:1.4;flex:1}
.tutorial-tag{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--surface2);color:var(--text3);flex-shrink:0;letter-spacing:.3px}
.tutorial-tag.pro-tag{background:rgba(99,102,241,.12);color:#818cf8}
.tutorial-tag.free-tag{background:rgba(34,197,94,.1);color:#22c55e}

/* ── Account Settings Modal ── */
.support-box{background:var(--bg);border:1px solid var(--border);border-radius:14px;width:calc(100% - 32px);max-width:360px;box-shadow:0 32px 80px rgba(0,0,0,.4);transform:translateY(12px) scale(.98);transition:transform .2s,opacity .2s;opacity:0;padding:28px 24px;position:relative}
.auth-overlay.open .support-box{transform:translateY(0) scale(1);opacity:1}
.support-close{position:absolute;top:12px;right:12px;width:30px;height:30px;border:none;background:var(--bg2,rgba(0,0,0,.05));border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text3);transition:all .15s}
.support-close:hover{background:rgba(239,68,68,.1);color:#ef4444;transform:scale(1.1)}
.support-links{display:flex;flex-direction:column;gap:10px}
.support-link-btn{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:10px;border:1px solid var(--border);text-decoration:none;color:var(--text1);transition:all .15s;cursor:pointer}
.support-link-btn:hover{border-color:var(--accent);background:rgba(99,102,241,.06);transform:translateY(-1px)}
.support-link-btn svg{flex-shrink:0;color:var(--text3)}
.support-link-btn:hover svg{color:var(--accent)}
.support-link-title{font-size:14px;font-weight:600;line-height:1.3}
.support-link-sub{font-size:12px;color:var(--text4);line-height:1.3}
.acct-box{background:var(--bg);border:1px solid var(--border);border-radius:14px;width:calc(100% - 32px);max-width:420px;box-shadow:0 32px 80px rgba(0,0,0,.4);transform:translateY(12px) scale(.98);transition:transform .2s,opacity .2s;opacity:0;max-height:calc(100vh - 60px);display:flex;flex-direction:column;overflow:hidden}
.auth-overlay.open .acct-box{transform:translateY(0) scale(1);opacity:1}
.acct-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.acct-avatar-row{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.acct-avatar-big{width:46px;height:46px;border-radius:50%;background:var(--btn-inv);color:var(--logo-fg);font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.acct-scroll{overflow-y:auto;flex:1}
.acct-section{padding:18px 20px;border-bottom:1px solid var(--border)}.acct-section:last-child{border-bottom:none}
.acct-section-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
.acct-field{margin-bottom:10px}
.acct-danger-section{background:rgba(239,68,68,.04)}
.acct-danger-btn{background:none;border:1px solid #ef4444;color:#ef4444;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;width:100%;font-family:inherit;transition:background .15s}
.acct-danger-btn:hover{background:rgba(239,68,68,.08)}
/* Upgrade modal */
.upgrade-box{max-width:480px;padding:0;overflow:hidden}
.upgrade-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 0 20px}
.upgrade-lang-btn{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);color:var(--text3);cursor:pointer;font-family:inherit;transition:all .15s}
.upgrade-lang-btn:hover{border-color:var(--text4);color:var(--text)}
.upgrade-hero{padding:16px 28px 0;text-align:center}
.upgrade-icon{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:0 8px 24px rgba(59,130,246,.35)}
.upgrade-title{font-size:20px;font-weight:800;letter-spacing:-.3px;color:var(--text);margin-bottom:4px}
.upgrade-sub{font-size:13px;color:var(--text3);line-height:1.5}
.upgrade-plans{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:20px 20px 0}
.plan-card{border:1.5px solid var(--border);border-radius:14px;padding:18px 16px;position:relative;background:var(--surface)}
.plan-card.recommended{border-color:#3b82f6;background:linear-gradient(160deg,rgba(59,130,246,.07),rgba(139,92,246,.04));box-shadow:0 0 0 1px rgba(59,130,246,.15),0 8px 28px rgba(59,130,246,.1)}
.plan-rec-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg,#3b82f6,#8b5cf6);color:#fff;font-size:9px;font-weight:800;padding:3px 12px;border-radius:999px;white-space:nowrap;letter-spacing:.4px}
.plan-name{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.plan-card.recommended .plan-name{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.plan-price{font-size:26px;font-weight:800;color:var(--text);line-height:1;margin-bottom:12px}
.plan-price span{font-size:12px;font-weight:400;color:var(--text3)}
.plan-card.recommended .plan-price{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.plan-early{display:inline-block;font-size:9px;font-weight:700;padding:2px 8px;border-radius:20px;background:linear-gradient(135deg,#60a5fa,#6366f1,#a78bfa);color:#fff;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}
.plan-countdown{text-align:center;margin-bottom:10px}
.plan-cd-label{font-size:9.5px;color:var(--text3);margin-bottom:6px;font-weight:500;letter-spacing:.3px}
.plan-cd-boxes{display:flex;justify-content:center;gap:4px;align-items:center}
.plan-cd-box{background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.18);border-radius:6px;min-width:32px;padding:4px 2px;text-align:center}
.plan-cd-box .cd-val{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;background:linear-gradient(135deg,#818cf8,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}
.plan-cd-box .cd-unit{font-size:7px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.plan-cd-sep{font-size:13px;font-weight:700;color:rgba(139,92,246,.4);margin:0 -1px}
.plan-cd-after{font-size:8.5px;color:var(--text3);margin-top:5px;opacity:.7}
.plan-divider{height:1px;background:var(--border);margin-bottom:12px}
.plan-features{display:flex;flex-direction:column;gap:6px}
.plan-feat{font-size:11.5px;color:var(--text3);display:flex;align-items:center;gap:6px;line-height:1.3}
.plan-feat.yes{color:var(--text2)}
.plan-feat-dot{width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:8px;font-weight:700}
.plan-feat.yes .plan-feat-dot{background:rgba(34,197,94,.15);color:#16a34a}
.plan-feat:not(.yes) .plan-feat-dot{background:var(--surface2);color:var(--text4)}
.upgrade-footer{padding:16px 20px 22px}
.upgrade-cta{width:100%;padding:13px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;border:none;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 4px 18px rgba(59,130,246,.4);transition:all .15s;letter-spacing:.1px}
.upgrade-cta:hover{box-shadow:0 6px 24px rgba(59,130,246,.55);transform:translateY(-1px)}
.upgrade-note{font-size:11px;color:var(--text4);text-align:center;margin-top:9px}

/* ══ THEME TOGGLE BUTTON ══ */
.theme-toggle{width:34px;height:34px;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:background .15s,border-color .15s;flex-shrink:0}
.theme-toggle:hover{background:var(--surface2);border-color:var(--text4)}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%}
body{height:100%;overflow:hidden;background:var(--surface2);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;font-size:13px;line-height:1.5;transition:background .2s,color .2s}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ── APP SHELL ── */
.app{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg)}

/* TOP BAR */
.topbar{height:48px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px;background:var(--bg);flex-shrink:0}
.topbar-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;letter-spacing:-.2px;color:var(--text)}
.topbar-nav{display:flex;gap:2px;align-items:center}
.topbar-nav-link{padding:5px 12px;border-radius:7px;font-size:13px;font-weight:500;color:var(--text2);text-decoration:none;transition:background .15s,color .15s}
.topbar-nav-link:hover{background:var(--hover);color:var(--text)}
.topbar-nav-link.active{background:var(--hover);color:var(--text);font-weight:600}
.logo-sq{width:24px;height:24px;background:var(--logo-bg);border-radius:5px;display:flex;align-items:center;justify-content:center}
.logo-sq span,.auth-brand-sq span{font-size:15px;font-weight:900;background:linear-gradient(180deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.logo-name-e{background:linear-gradient(90deg,#3b82f6,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-name-motion{font-weight:300;background:linear-gradient(90deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.topbar-right{margin-left:auto;display:flex;gap:6px;align-items:center}

/* ── Account Switcher ── */
.acc-switcher-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface);color:var(--text2);cursor:pointer;font-size:12px;font-weight:500;font-family:inherit;transition:background .1s;max-width:160px;flex-shrink:0}
.acc-switcher-btn:hover{background:var(--hover)}
.acc-switcher-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}
.acc-switcher-arrow{flex-shrink:0;color:var(--text4);transition:transform .15s}
.acc-switcher-wrap{position:relative}
@media(max-width:768px){.acc-switcher-wrap{display:none}.hide-mobile{display:none !important}}
@media(max-width:480px){#user-name-chip{display:none !important}.user-chip{padding:4px 6px !important;border-radius:50% !important;border:none !important}.user-chip svg[width="10"]{display:none !important}}
.mob-only{display:none}
@media(max-width:768px){.mob-only{display:flex}}
.acc-dropdown{position:fixed;background:var(--bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px var(--shadow);z-index:9999;min-width:200px;padding:6px;display:none}
.acc-dropdown.open{display:block}
.acc-dd-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;cursor:pointer;transition:background .12s}
.acc-dd-item:hover{background:var(--surface)}
.acc-dd-item.active{background:var(--surface2)}
.acc-dd-check{width:14px;font-size:11px;color:var(--sel);font-weight:700;flex-shrink:0}
.acc-dd-label{flex:1;font-size:12px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acc-dd-actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .12s}
.acc-dd-item:hover .acc-dd-actions{opacity:1}
.acc-dd-icon{background:none;border:none;cursor:pointer;color:var(--text4);font-size:12px;padding:2px 4px;border-radius:4px;line-height:1;transition:color .12s,background .12s}
.acc-dd-icon:hover{color:var(--text);background:var(--border)}
.acc-dd-icon.danger:hover{color:var(--loss);background:rgba(239,68,68,.1)}
.acc-dd-divider{height:1px;background:var(--border);margin:4px 0}
.acc-dd-add{display:flex;align-items:center;gap:6px;width:100%;padding:8px 10px;border:none;border-radius:7px;background:none;color:var(--text3);cursor:pointer;font-size:12px;font-weight:600;font-family:inherit;transition:all .12s}
.acc-dd-add:hover:not(:disabled){background:var(--surface);color:var(--text)}
.acc-dd-add:disabled{opacity:.4;cursor:not-allowed}
/* Account Name Modal */
.acc-name-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);z-index:2100;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s}
.acc-name-overlay.open{opacity:1;pointer-events:all}
.acc-name-box{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:24px;width:calc(100% - 40px);max-width:340px;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.acc-name-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:14px}
.acc-name-input{width:100%;padding:10px 13px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:14px;font-family:inherit;outline:none;box-sizing:border-box;transition:border-color .15s}
.acc-name-input:focus{border-color:var(--sel)}
.acc-name-hint{font-size:11px;color:var(--text4);margin-top:6px;min-height:16px}
.acc-name-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

/* MAIN SPLIT */
.main-split{flex:1;display:flex;min-height:0;overflow:hidden}

/* ── MOBILE BOTTOM NAV (hidden on desktop) ── */
.mobile-nav{display:none}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CALENDAR SECTION
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cal-section{display:flex;flex-direction:column;border-right:none;overflow:hidden;background:var(--bg);flex-shrink:0}
.journal-panel{display:flex;flex-direction:column;background:var(--bg);overflow:hidden;flex-shrink:0;border-left:1px solid var(--border)}

.cal-topbar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.cal-month-label{font-size:15px;font-weight:700;letter-spacing:-.3px;color:var(--text)}
.cal-pnl.pos{color:var(--profit)}.cal-pnl.neg{color:var(--loss)}
.cal-pnl-badge{padding:1px 8px;border-radius:999px;font-size:12px;font-weight:700;font-family:'SF Mono',Consolas,monospace}
.cal-pnl-badge.pos{background:var(--profit-badge);color:var(--profit-badge-t)}
.cal-pnl-badge.neg{background:var(--loss-badge);color:var(--loss-badge-t)}
.cal-pnl-badge.zero{background:var(--surface2);color:var(--text3)}

.cal-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 16px}

.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr)) 100px;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden;width:100%}
.cal-grid.weekly-mode{display:block;background:none;border:none;border-radius:0;overflow:visible}

.cal-head{background:var(--surface);text-align:center;font-size:10px;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:.5px;padding:6px 0}
.cal-head.wk-head{color:var(--text3);background:var(--surface)}

.cal-cell{background:var(--bg);padding:8px 8px;min-height:130px;cursor:pointer;display:flex;flex-direction:column;gap:0;transition:background .1s;position:relative;overflow:hidden;min-width:0}
.cal-cell:hover{background:var(--surface)}
.cal-cell.other-month{background:var(--surface);opacity:.5;cursor:default;pointer-events:none}
.cal-cell.empty-cell{background:var(--surface);cursor:default;pointer-events:none}
.cal-cell.today-cell{outline:2px solid var(--today);outline-offset:-2px;background:var(--today-bg);z-index:1}
.cal-cell.profit-cell{background:var(--profit-bg)}
.cal-cell.loss-cell{background:var(--loss-bg)}
.cal-cell.selected-cell{outline:2px solid #818cf8;outline-offset:-2px;z-index:1;box-shadow:inset 0 0 0 2px #818cf8,0 0 12px rgba(99,102,241,.55),0 0 28px rgba(139,92,246,.3);background:rgba(99,102,241,.08)}

/* top row: date num + dots */
.c-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.c-num{font-size:13px;font-weight:600;color:var(--text2);line-height:1}
.today-cell .c-num{color:var(--today-num);font-weight:700}
.c-media-dots{display:flex;gap:2px}
.c-dot{width:4px;height:4px;border-radius:50%}
.c-dot-note{background:#6366f1}.c-dot-img{background:#f59e0b}

/* body: left info + right square image */
.c-body{display:flex;gap:0;flex:1;min-height:0}
.c-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.c-pnl{font-size:14px;font-weight:700;font-family:'SF Mono',Consolas,monospace;letter-spacing:-.3px;line-height:1.2}
.c-pnl.pos{color:var(--profit)}.c-pnl.neg{color:var(--loss)}
.c-count{font-size:11px;color:var(--text4)}
.c-symbols{font-size:11px;font-weight:600;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-no-trades{font-size:11px;color:var(--text5);margin-top:auto}
.c-emotion{font-size:15px;line-height:1;margin-top:2px}
.c-sub-vals{display:flex;flex-direction:column;gap:1px;margin-top:2px}
.c-sub-row{font-size:10px;font-family:'SF Mono',Consolas,monospace}
.c-sub-row.up{color:var(--profit)}.c-sub-row.dn{color:var(--loss)}

/* right square image */
.c-right{flex-shrink:0;width:clamp(44px,6vw,88px);height:clamp(44px,6vw,88px);position:relative;border-radius:5px;overflow:hidden}
.c-sq-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;cursor:zoom-in;border-radius:5px;transform:scale(1.1)}
.c-sq-more{position:absolute;bottom:2px;right:2px;background:rgba(0,0,0,.6);border-radius:3px;padding:1px 4px;font-size:8px;font-weight:700;color:#fff}

/* Week total cell */
.cal-week-cell{background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;min-height:130px}
.cw-label{font-size:9px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.4px}
.cw-val{font-size:clamp(9px,1.4vw,12px);font-weight:700;font-family:'Geist Mono','SF Mono',Consolas,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center}
.cw-val.pos{color:var(--profit)}.cw-val.neg{color:var(--loss)}.cw-val.zero{color:var(--text4)}
.cw-days{font-size:9px;color:var(--text5)}

/* ── Stats & Charts below calendar ── */
.below-cal{padding:16px 0;display:grid;grid-template-columns:27% 1fr;gap:14px;align-items:start;min-width:0}
.bottom-row{grid-column:1/-1;display:grid;grid-template-columns:27% 1fr;gap:14px;align-items:stretch}

/* ── Statistics Panel ── */
.stats-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 1px 3px var(--shadow)}
.stats-free-lock{display:flex;align-items:center;gap:6px;padding:8px 14px;background:rgba(99,102,241,.07);border-bottom:1px solid rgba(99,102,241,.15);font-size:11.5px;color:var(--text3);flex-shrink:0}
.stats-free-lock svg{flex-shrink:0;color:var(--accent)}
.stats-panel-hdr{padding:14px 16px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.stats-panel-title{font-size:14px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.stats-panel-sub{font-size:10px;color:var(--text4);font-weight:500;background:var(--bg);padding:2px 8px;border-radius:6px;border:1px solid var(--border)}
.stats-period-select{font-size:10px;color:var(--text3);font-weight:600;font-family:inherit;background:var(--bg);padding:4px 8px;border-radius:6px;border:1px solid var(--border);cursor:pointer;outline:none;appearance:auto}
.stats-2x2{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
.ss{padding:14px 16px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;flex-direction:column;transition:background .15s}
.ss:hover{background:var(--surface2)}
.ss:hover{background:var(--surface2)}
.ss:nth-child(2){border-right:none}
.ss:nth-child(3){border-bottom:none}
.ss:nth-child(4){border-right:none;border-bottom:none}
.ss-title{font-size:9px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.ss-title::before{content:'';width:3px;height:10px;border-radius:2px;flex-shrink:0}
.ss:nth-child(1) .ss-title::before{background:var(--profit)}
.ss:nth-child(2) .ss-title::before{background:#6366f1}
.ss:nth-child(3) .ss-title::before{background:#f59e0b}
.ss:nth-child(4) .ss-title::before{background:#06b6d4}
.ss-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}
.ss-row-lbl{font-size:11px;color:var(--text3);font-weight:500}
.ss-row-val{font-size:13px;font-weight:700;font-family:'Geist Mono','SF Mono',Consolas,monospace;letter-spacing:-.3px}
.ss-row-val.pos{color:var(--profit)}.ss-row-val.neg{color:var(--loss)}.ss-row-val.neu{color:var(--text)}
.ss-divider{height:1px;background:var(--border);margin:6px 0}
.ss-row.bold{margin:4px -8px 0;padding:6px 8px;border-radius:6px;background:var(--surface2)}
.ss-row.bold:has(.pos){background:rgba(34,197,94,.08)}
.ss-row.bold:has(.neg){background:rgba(239,68,68,.08)}
.ss-row.bold .ss-row-lbl{font-weight:600;color:var(--text);font-size:11px}
.ss-row.bold .ss-row-val{font-size:13px;font-weight:800}

/* ── Charts Column ── */
.charts-col{display:flex;flex-direction:column;gap:12px}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;overflow:hidden;box-shadow:0 1px 3px var(--shadow);transition:box-shadow .2s}
.chart-card:hover{box-shadow:0 2px 8px var(--shadow)}
.chart-card canvas{display:block;width:100%;max-width:100%}
.chart-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.chart-title{font-size:13px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.chart-final{font-size:16px;font-weight:800;font-family:'SF Mono',Consolas,monospace;padding:4px 12px;border-radius:6px}
.chart-final.pos{color:var(--profit);background:rgba(22,163,74,.08)}.chart-final.neg{color:var(--loss);background:rgba(220,38,38,.08)}.chart-final.neu{color:var(--text)}
.chart-sub{font-size:10px;color:var(--text4);margin-top:1px}
.daily-bar-tip{position:fixed;display:none;padding:5px 10px;border-radius:7px;font-size:12px;font-weight:700;font-family:'SF Mono',Consolas,monospace;pointer-events:none;z-index:9999;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.daily-bar-tip.pos{background:#16a34a;color:#fff}
.daily-bar-tip.neg{background:#dc2626;color:#fff}
.chart-h-slider{-webkit-appearance:none;appearance:none;width:72px;height:3px;border-radius:2px;background:var(--border);outline:none;cursor:pointer;opacity:.6;transition:opacity .2s}
.chart-h-slider--full{width:100%;margin-top:8px;display:block}
.chart-h-slider:hover{opacity:1}
.chart-h-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer}
.chart-h-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent);border:none;cursor:pointer}
.chart-legend{display:flex;gap:14px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
/* ── Hourly Heatmap (single row) ── */
.hm-grid{display:grid;grid-template-columns:repeat(24,1fr);gap:3px;margin:10px 0 0}
.hm-cell{border-radius:5px;height:48px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:6px 2px 4px;cursor:default;transition:transform .12s,box-shadow .12s;border:1px solid var(--border2)}
.hm-cell:hover{transform:scale(1.15);box-shadow:0 3px 8px rgba(0,0,0,.25);z-index:2}
.hm-cell-hr{font-size:7px;font-weight:700;line-height:1}
.hm-cell-hr.has-data{color:rgba(255,255,255,.9)}
.hm-cell-hr.no-data{color:var(--text4)}
.hm-cell-val{font-size:6px;font-weight:600;line-height:1;text-align:center;max-width:100%;overflow:hidden;white-space:nowrap}
.hm-cell-val.has-data{color:rgba(255,255,255,.75)}
.hm-cell-val.no-data{display:none}
.hm-axis{display:grid;grid-template-columns:repeat(24,1fr);gap:3px;margin-top:4px}
.hm-axis-lbl{font-size:8px;color:var(--text4);text-align:center;line-height:1}
/* ── Instrument Breakdown ── */
.inst-list{display:flex;flex-direction:row;gap:6px;margin-top:10px;flex-wrap:nowrap;justify-content:center}
.inst-chip{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 6px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);cursor:default;transition:transform .12s}
.inst-chip:hover{transform:translateY(-2px)}
.inst-chip.pos{border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.07)}
.inst-chip.neg{border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.07)}
.inst-chip-name{font-size:10px;font-weight:700;color:var(--text);letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center}
.inst-chip-pnl{font-size:11px;font-weight:800;line-height:1}
.inst-chip-pnl.pos{color:var(--profit)}
.inst-chip-pnl.neg{color:var(--loss)}
.inst-chip-cnt{font-size:9px;color:var(--text4)}
.legend-item{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text3);font-weight:500}
.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 2px var(--surface),0 0 0 3px var(--border)}

/* ── News icon pill on calendar cell ── */
.c-top-right{display:flex;align-items:center;gap:3px}
.c-news-btn{display:inline-flex;align-items:center;gap:3px;background:var(--bg);border:1px solid var(--border);border-radius:999px;cursor:pointer;color:var(--text3);padding:2px 6px 2px 5px;line-height:1;transition:all .1s;font-family:inherit;box-shadow:0 1px 2px var(--shadow)}
.c-news-btn:hover{background:var(--surface2);color:var(--text)}
.c-news-count{font-size:10px;font-weight:600}

/* ── News backdrop ── */
#news-backdrop{display:none;position:fixed;inset:0;z-index:299}

/* ── News popup (positioned near cell) ── */
.news-popup{
  position:fixed;z-index:300;display:none;flex-direction:column;
  width:340px;max-height:min(500px,80vh);
  background:var(--bg);border:1px solid var(--border);
  border-radius:14px;box-shadow:0 12px 48px var(--shadow);overflow:hidden
}
.news-popup.open{display:flex}
.news-popup-hdr{padding:14px 16px 12px;border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.news-popup-title{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.2px}
.news-popup-body{flex:1;overflow-y:auto;padding:6px 0}
/* Timeline */
.news-tl-row{display:flex;min-height:28px;align-items:stretch}
.news-tl-row.empty-hour{min-height:22px}
.news-tl-row.empty-hour .news-tl-hour{opacity:.4}
.news-tl-row.empty-hour .news-tl-line{opacity:.4}
.news-tl-row.empty-hour .news-tl-events{opacity:.4}
.news-tl-row.has-events{min-height:36px}
/* Session color bar — left edge, continuous strips side-by-side */
.news-tl-sess{flex-shrink:0;display:flex;flex-direction:row;align-self:stretch;min-width:6px}
.news-tl-sess-strip{flex-shrink:0;align-self:stretch}
/* Hour label */
.news-tl-hour{width:48px;flex-shrink:0;padding:7px 8px 4px 6px;font-size:11px;color:var(--text4);font-variant-numeric:tabular-nums;line-height:1;align-self:flex-start}
.news-tl-row.empty-hour .news-tl-hour{font-size:10px;padding:5px 8px 2px 6px}
/* Vertical divider line */
.news-tl-line{width:1px;background:var(--border2);flex-shrink:0;align-self:stretch;margin:4px 0}
.news-tl-events{flex:1;padding:4px 12px 4px 10px;display:flex;flex-direction:column;gap:6px}
/* Event cards */
.news-ev-card{border-radius:8px;padding:8px 12px;border-left:3px solid;cursor:default}
.news-ev-card-title{font-size:12px;font-weight:700;margin-bottom:4px;line-height:1.4}
.news-ev-card-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text3)}
.news-ev-card-time{display:inline-flex;align-items:center;gap:3px}
/* Legend */
.news-popup-legend{display:flex;gap:14px;padding:10px 14px;border-top:1px solid var(--border2);flex-shrink:0;flex-wrap:nowrap;overflow:hidden}
.news-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text3)}
.news-legend-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}

/* sc-val still used in a few places */
.sc-val{font-size:13px;font-weight:700;font-family:'SF Mono',Consolas,monospace}
.sc-val.pos{color:var(--profit)}.sc-val.neg{color:var(--loss)}.sc-val.neu{color:var(--text)}

.cal-footer{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg)}

/* ── Weekly / Yearly View ── */
.yr-outer{display:flex;flex-direction:column;gap:0;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.yr-grid{display:grid;grid-template-columns:repeat(12,minmax(72px,1fr));grid-auto-rows:1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:10px;overflow:hidden;min-width:864px;width:100%}
.yr-month-hdr{text-align:center;padding:8px 4px 7px;background:var(--surface);border-bottom:1px solid var(--border)}
.yr-month-name{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
.yr-month-pnl{font-size:12px;font-weight:700;font-family:'SF Mono',Consolas,monospace;margin-top:3px}
.yr-month-pnl.pos{color:var(--profit)}.yr-month-pnl.neg{color:var(--loss)}.yr-month-pnl.zero{color:var(--text4)}
.yr-cell{padding:8px 4px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:76px;cursor:pointer;transition:background .1s;background:var(--bg);overflow:hidden}
.yr-cell:hover{background:var(--surface2)}
.yr-cell.empty{background:var(--surface2);cursor:default;pointer-events:none;opacity:.4}
.yr-cell.profit{background:var(--profit-bg)}
.yr-cell.loss{background:var(--loss-bg)}
.yr-cell.cur-week{outline:2px solid var(--today);outline-offset:-2px;z-index:1;position:relative}
.yr-cell.active-week{outline:2px solid #818cf8;outline-offset:-2px;z-index:2;position:relative;box-shadow:inset 0 0 0 2px #818cf8,0 0 12px rgba(99,102,241,.55),0 0 28px rgba(139,92,246,.3);background:rgba(99,102,241,.08)}
.yr-wk-label{font-size:9px;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:.4px}
.yr-wk-pnl{font-size:clamp(9px,1.1vw,13px);font-weight:700;font-family:'Geist Mono','SF Mono',Consolas,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center}
.yr-wk-pnl.pos{color:var(--profit)}.yr-wk-pnl.neg{color:var(--loss)}.yr-wk-pnl.zero{color:var(--text3)}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   JOURNAL PANEL (RIGHT)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.journal-panel{display:flex;flex-direction:column;background:var(--bg);overflow:hidden;transition:width .25s ease}
.journal-panel.collapsed{width:0 !important;min-width:0 !important;border-left:none;overflow:hidden}
.journal-panel.collapsed .jp-header,.journal-panel.collapsed .jp-body{opacity:0;pointer-events:none}
.jp-show-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:200;display:none;flex-direction:column;align-items:center;justify-content:center;width:22px;height:64px;background:var(--surface2);border:1px solid var(--border);border-right:none;border-radius:6px 0 0 6px;cursor:pointer;color:var(--text2);box-shadow:-2px 0 8px var(--shadow);transition:background .15s,color .15s}
.jp-show-tab:hover{background:var(--surface);color:var(--accent,#6366f1)}
.journal-panel.collapsed ~ .jp-show-tab,.app.panel-hidden .jp-show-tab{display:flex}

.jp-header{height:48px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:8px;flex-shrink:0}
.jp-title{font-size:14px;font-weight:700;color:var(--text)}
.jp-info{font-size:12px;color:var(--text4);cursor:help}
.jp-header-right{margin-left:auto;display:flex;gap:4px;align-items:center}

.jp-body{flex:1;display:flex;overflow:hidden}

/* Left date list */
.jp-datelist{width:80px;border-right:1px solid var(--border);flex-shrink:0;overflow-y:auto;padding:8px 0}
.jp-date-item{display:flex;flex-direction:column;align-items:center;padding:10px 4px;cursor:pointer;border-left:2px solid transparent;gap:3px;transition:background .1s}
.jp-date-item:hover{background:var(--surface)}
.jp-date-item.active{border-left-color:var(--text);background:var(--surface)}
.jp-date-dot{width:8px;height:8px;border-radius:50%;border:2px solid var(--text3)}
.jp-date-item.active .jp-date-dot{background:var(--text);border-color:var(--text)}
.jp-date-label{font-size:9px;font-weight:600;color:var(--text3);text-align:center}
.jp-date-item.active .jp-date-label{color:var(--text)}
.jp-date-sub{font-size:8px;color:var(--text4)}

/* Journal main content */
.jp-main{flex:1;overflow-y:auto;padding:14px}
.jp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 0;color:var(--text4);text-align:center}
.jp-empty-icon{font-size:20px}

/* Section */
.jp-section{margin-bottom:16px}
.jp-section-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:8px}

/* Emotion Picker */
.emotion-row{display:flex;align-items:center;gap:6px}
.emotion-emoji{font-size:18px;flex-shrink:0}
.emotion-swatches{display:flex;gap:2px;flex:1}
.em-swatch{width:100%;height:26px;border-radius:3px;cursor:pointer;border:none;transition:transform .12s,box-shadow .12s,background .15s;flex:1;min-width:0;background:var(--border)}
.em-swatch:hover{transform:scaleY(1.18);box-shadow:0 2px 6px rgba(0,0,0,.25)}
.em-swatch.selected{transform:scaleY(1.28);box-shadow:0 2px 8px rgba(0,0,0,.35)}
.emotion-question{font-size:11px;color:var(--text3);margin-top:6px}

/* Session Tags */
.tags-row{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.tag-chip{display:inline-flex;align-items:center;gap:4px;background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:11px;color:var(--text2)}
.tag-chip .tag-del{cursor:pointer;color:var(--text4);font-size:10px;font-weight:700}
.tag-chip .tag-del:hover{color:#ef4444}
.no-trades-chip{font-size:11px;color:var(--text4);font-style:italic}
.btn-add-tag{background:none;border:1px dashed var(--text5);border-radius:999px;padding:2px 10px;font-size:11px;color:var(--text3);cursor:pointer;font-family:inherit}
.btn-add-tag:hover{border-color:var(--text4);color:var(--text2)}
.tag-input{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:2px 10px;font-size:11px;color:var(--text);outline:none;width:110px;font-family:inherit}
.tag-input:focus{border-color:#6366f1}

/* Timeframe & Strategy */
.tf-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
.tf-chip{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text3);transition:all .1s;user-select:none}
.tf-chip:hover{border-color:var(--text4);color:var(--text2)}
.tf-chip.active{background:#6366f1;border-color:#6366f1;color:#fff}
.strat-section{margin-top:6px}
.strat-label{font-size:10px;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.strat-btn-row{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:6px}
.strat-preset-wrap{position:relative;display:inline-block}
.strat-preset-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:3px 10px;font-size:11px;color:var(--text3);cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:4px}
.strat-preset-btn:hover{border-color:var(--text4);color:var(--text2)}
.strat-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px var(--shadow);z-index:200;min-width:170px;padding:4px;display:none;flex-direction:column;gap:1px}
.strat-dropdown.open{display:flex}
.strat-dd-item{padding:6px 10px;font-size:12px;color:var(--text2);border-radius:5px;cursor:pointer;white-space:nowrap}
.strat-dd-item:hover{background:var(--surface2)}
.strat-dd-item.used{color:var(--text4);pointer-events:none}
.inst-dd-sep{padding:4px 10px 2px;font-size:9px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.5px;background:var(--surface2)}
.inst-dd-item{padding:7px 12px;font-size:12px;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}
.inst-dd-item:hover{background:var(--surface2)}
.inst-dd-item b{font-weight:700;color:var(--text)}
.inst-dd-item span{font-size:10px;color:var(--text4)}

/* Analysis Sections */
.an-row{display:flex;gap:6px}
.an-dd-wrap{flex:1;position:relative;display:flex;flex-direction:column;gap:3px}
.an-dd-label{font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.5px}
.an-dd-btn{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:11px;color:var(--text3);gap:4px;user-select:none}
.an-dd-btn:hover{border-color:var(--text4)}
.an-dd-arrow{font-size:9px;flex-shrink:0}
.an-dropdown{position:absolute;top:calc(100% + 3px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px var(--shadow);z-index:300;padding:4px;display:none;flex-direction:column;min-width:120px}
.an-dropdown.open{display:flex}
.an-dd-item{padding:6px 10px;font-size:12px;color:var(--text2);border-radius:5px;cursor:pointer;white-space:nowrap}
.an-dd-item:hover{background:var(--surface2)}
.an-dd-item.checked{color:#6366f1;font-weight:600}
.an-dd-item.checked::before{content:'✓ '}
.an-dd-sep{padding:4px 10px 2px;font-size:9px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.5px}
.an-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.an-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--surface2);border:1px solid var(--border);color:var(--text2)}
.an-tag .an-tag-del{cursor:pointer;color:var(--text4);font-size:10px;margin-left:1px}
.an-tag .an-tag-del:hover{color:#ef4444}

/* RTE */
.rte-wrap{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg)}
.rte-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1px;padding:5px 6px;border-bottom:1px solid var(--border2);background:var(--surface)}
.tb-btn{background:none;border:1px solid transparent;border-radius:4px;padding:3px 5px;cursor:pointer;font-size:11px;font-weight:600;color:var(--text3);font-family:inherit;line-height:1.2;min-width:22px;text-align:center;transition:background .1s,color .1s}
.tb-btn:hover{background:var(--surface2);color:var(--text)}
.tb-btn.active{background:var(--surface2);color:var(--text)}
.tb-sep{width:1px;height:14px;background:var(--border);margin:0 3px}
.rte-editor{min-height:130px;padding:10px 12px;font-size:13px;color:var(--text2);outline:none;line-height:1.6;background:var(--bg)}
.rte-editor:empty::before{content:attr(data-placeholder);color:var(--text5);pointer-events:none}
.rte-editor h1{font-size:20px;font-weight:700;margin-bottom:4px;color:var(--text)}
.rte-editor h2{font-size:17px;font-weight:700;margin-bottom:3px;color:var(--text)}
.rte-editor h3{font-size:14px;font-weight:700;margin-bottom:3px;color:var(--text)}
.rte-editor ul,.rte-editor ol{padding-left:20px;margin:4px 0}
.rte-editor blockquote{border-left:3px solid var(--border);padding-left:10px;color:var(--text3);margin:4px 0}
.rte-editor img{max-width:100%;border-radius:4px;margin:4px 0;display:block}
.rte-editor table{border-collapse:collapse;width:100%;margin:4px 0}
.rte-editor td,.rte-editor th{border:1px solid var(--border);padding:4px 8px;color:var(--text2)}

/* JP Save bar — sticky bottom of scroll area */
/* Journal trades list */
.jp-no-trades{font-size:11px;color:var(--text5);padding:6px 0}
.jp-trade-row{display:flex;align-items:stretch;gap:0;min-height:44px;border-bottom:1px solid var(--border2)}
.jp-trade-row:last-child{border-bottom:none}
.jp-trade-sess{width:3px;flex-shrink:0;border-radius:2px;margin:6px 0}
.jp-trade-time-col{width:44px;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;padding:6px 8px 6px 6px;gap:2px}
.jp-trade-entry-t{font-size:10px;font-weight:600;color:var(--text3);font-variant-numeric:tabular-nums;line-height:1}
.jp-trade-close-t{font-size:9px;color:var(--text5);font-variant-numeric:tabular-nums;line-height:1}
.jp-trade-divider{width:1px;background:var(--border2);flex-shrink:0;margin:6px 0}
.jp-trade-body{flex:1;min-width:0;padding:7px 8px;display:flex;flex-direction:column;justify-content:center;gap:3px}
.jp-trade-top{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.jp-trade-inst{font-size:12px;font-weight:700;color:var(--text)}
.jp-trade-side-chip{font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px}
.jp-trade-qty{font-size:10px;color:var(--text4);background:var(--surface2);padding:1px 5px;border-radius:4px}
.jp-trade-note{font-size:10px;color:var(--text4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jp-trade-pnl{font-size:11px;font-weight:700;font-family:'SF Mono',Consolas,monospace;white-space:nowrap;flex-shrink:0;padding:0 10px 0 4px;display:flex;align-items:center}
.jp-trades-pnl{font-size:12px;font-weight:700;font-family:'SF Mono',Consolas,monospace}
.jp-save-bar{padding:8px 14px;border-top:1px solid var(--border);background:var(--bg);flex-shrink:0}
.jp-save-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:9px;background:var(--btn-inv);color:var(--logo-fg);border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s,transform .1s;letter-spacing:.1px}
.jp-save-btn:hover{opacity:.85}
.jp-save-btn:active{transform:scale(.98)}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   BUTTONS (generic)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border);font-family:inherit;background:var(--bg);color:var(--text2);transition:background .1s}
.btn:hover{background:var(--surface)}
.btn-icon-xs{width:26px;height:26px;border:1px solid var(--border);border-radius:5px;background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text3);transition:background .1s}
.btn-icon-xs:hover{background:var(--surface);color:var(--text)}
.btn-dark{background:var(--btn-inv);color:var(--logo-fg);border-color:var(--btn-inv)}
.btn-dark:hover{background:var(--btn-inv-h);border-color:var(--btn-inv-h)}
.btn-view{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border);font-family:inherit;background:var(--bg);color:var(--text3);transition:all .1s}
.btn-view:hover{background:var(--surface)}
.btn-view.active{background:var(--btn-inv);color:var(--logo-fg);border-color:var(--btn-inv)}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   MODALS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding-top:60px;opacity:0;pointer-events:none;transition:opacity .18s}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg);border:1px solid var(--border);border-radius:12px;width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px var(--shadow);transform:translateY(8px);transition:transform .18s;overflow:hidden}
@media(max-width:600px){
  .overlay{
    padding: 8px;
    align-items: center;
    justify-content: center;
  }
  .modal{
    max-height: 88vh;
    height: auto;
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  .modal-body{
    flex: 1 1 auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    min-height: 0;
  }
  .modal-ftr{
    flex: 0 0 auto;
    position: relative;
    z-index: 10;
  }
}
.overlay.open .modal{transform:translateY(0)}

.modal-hdr{padding:18px 20px 14px;border-bottom:1px solid var(--border2);display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0}
.modal-title{font-size:17px;font-weight:700;color:var(--text)}
.modal-subtitle{font-size:12px;color:var(--text4);margin-top:2px}

.modal-tabs-row{display:flex;gap:0;padding:0 20px;border-bottom:1px solid var(--border2);flex-shrink:0}
.modal-tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--text4);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .1s;background:none;border-left:none;border-right:none;border-top:none;font-family:inherit}
.modal-tab:hover{color:var(--text2)}
.modal-tab.active{color:var(--text);border-bottom-color:var(--text);font-weight:600}

.modal-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:14px;background:var(--bg)}
.modal-tab-panel{display:none;flex-direction:column;gap:14px}
.modal-tab-panel.active{display:flex}

.modal-ftr{padding:12px 20px;border-top:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--bg)}
.modal-ftr-right{display:flex;gap:8px}

/* Add Trade Modal */
.at-modal{max-width:520px}
/* OCR scan button */
/* CSV Import button */
.btn-csv-import{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border:1px solid var(--border);border-radius:8px;background:var(--surface2);color:var(--text2);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;line-height:1}
.btn-csv-import:hover{border-color:var(--primary);color:var(--primary);background:rgba(99,102,241,.06)}
/* CSV Preview modal */
.csv-preview-summary{font-size:13px;color:var(--text2);margin-bottom:12px;padding:10px 12px;background:var(--surface2);border-radius:8px;border:1px solid var(--border)}
.csv-preview-summary .pos{color:var(--profit);font-weight:700}
.csv-preview-summary .neg{color:var(--loss);font-weight:700}
.csv-preview-table-wrap{max-height:260px;overflow-y:auto;border:1px solid var(--border);border-radius:8px}
.csv-preview-tbl{width:100%;border-collapse:collapse;font-size:12px}
.csv-preview-tbl th{padding:8px 12px;background:var(--surface2);color:var(--text3);font-weight:600;text-align:left;position:sticky;top:0}
.csv-preview-tbl td{padding:7px 12px;border-top:1px solid var(--border);color:var(--text2)}
.csv-preview-tbl td.pos{color:var(--profit);font-weight:600}
.csv-preview-tbl td.neg{color:var(--loss);font-weight:600}
.csv-preview-note{font-size:11px;color:var(--text4);margin-top:10px}
.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}
.btn-ghost{padding:8px 14px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text3);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}
.btn-ghost:hover{border-color:var(--text3);color:var(--text2)}
.at-ocr-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text2);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;line-height:1}
.at-ocr-btn:hover{background:var(--surface2);color:var(--text1)}
.at-ocr-btn:active{opacity:.8}
.at-ocr-btn svg{flex-shrink:0}
/* OCR scanning overlay */
.ocr-scan-overlay{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;margin-bottom:10px;border-radius:10px;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.2);color:var(--primary);font-size:13px;font-weight:500}
.at-mode-toggle{display:flex;gap:4px;margin-bottom:14px;background:var(--surface);border-radius:8px;padding:3px}
.at-mode-btn{flex:1;padding:6px 10px;border:none;border-radius:6px;background:none;color:var(--text3);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}
.at-mode-btn.active{background:var(--bg);color:var(--ink);box-shadow:0 1px 3px var(--shadow)}
.at-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.at-more-btn{width:100%;margin-top:4px;padding:7px 12px;background:none;border:1px dashed var(--border);border-radius:8px;color:var(--text4);font-size:12px;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:color .15s,border-color .15s}
.at-more-btn:hover{color:var(--text2);border-color:var(--text3)}
#at-extra-fields{margin-top:8px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:11px;font-weight:600;color:var(--text2)}
.form-req{color:#ef4444}
.form-input,.form-select{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;color:var(--text);font-family:inherit;outline:none;width:100%;transition:border-color .12s}
.form-input:focus,.form-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.1)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%239ca3af' d='M4.5 6l3.5 4 3.5-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:14px;padding-right:28px;cursor:pointer}
input[type="datetime-local"]{color-scheme:light}
[data-theme="dark"] input[type="datetime-local"]{color-scheme:dark}

/* Trades table */
.trades-table-wrap{overflow-x:auto}
.trades-tbl{width:100%;border-collapse:collapse;font-size:12px}
.trades-tbl th{text-align:left;font-size:10px;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:.4px;padding:6px 8px;border-bottom:1px solid var(--border)}
.trades-tbl td{padding:8px 8px;border-bottom:1px solid var(--surface2);color:var(--text2);font-variant-numeric:tabular-nums}
.trades-tbl tr:last-child td{border-bottom:none}
.td-long{color:var(--profit);font-weight:600}.td-short{color:var(--loss);font-weight:600}
.td-pos{color:var(--profit);font-weight:600}.td-neg{color:var(--loss);font-weight:600}
.btn-del-trade{background:none;border:none;cursor:pointer;color:var(--text5);font-size:13px;padding:2px}
.btn-del-trade:hover{color:#ef4444}
.td-note-cell{cursor:pointer;min-width:120px;max-width:200px}
.td-note-text{color:var(--text2);font-size:12px}
.td-note-empty{color:var(--text5);font-size:11px;font-style:italic}
.td-note-cell:hover .td-note-empty{color:var(--text4)}
.td-note-input{background:var(--surface);border:1px solid #6366f1;border-radius:4px;padding:3px 7px;font-size:12px;color:var(--text);font-family:inherit;outline:none;width:100%;min-width:110px}
.no-trades-msg{text-align:center;color:var(--text4);font-size:12px;padding:16px 0}

/* Analysis */
.analysis-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.a-stat{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:10px 12px}
.a-stat-label{font-size:10px;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.an-chart-block{margin-top:12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px}
.an-chart-title{font-size:10px;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.an-chart-scroll{overflow-x:auto;overflow-y:hidden;height:110px;border-radius:4px}
.an-chart-scroll::-webkit-scrollbar{height:3px}
.an-chart-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.an-chart-block canvas{display:block;height:110px;flex-shrink:0}
.a-stat-val{font-size:16px;font-weight:700;font-family:'SF Mono',Consolas,monospace;color:var(--text)}
.a-stat-val.pos{color:var(--profit)}.a-stat-val.neg{color:var(--loss)}
#analysis-chart{width:100%;height:120px;margin-top:4px}

/* Toast */
/* ── News Alert Card ── */
.news-alert-card{position:fixed;top:70px;right:16px;width:300px;background:var(--bg);border:1.5px solid #ef4444;border-radius:12px;box-shadow:0 8px 28px rgba(239,68,68,.25);z-index:1800;padding:12px 14px;animation:newsAlertIn .3s ease}
@keyframes newsAlertIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.news-alert-top{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.news-alert-icon{font-size:15px}
.news-alert-label{flex:1;font-size:11px;font-weight:700;color:#ef4444;text-transform:uppercase;letter-spacing:.4px}
.news-alert-close{background:none;border:none;color:var(--text4);cursor:pointer;font-size:13px;padding:0;line-height:1}
.news-alert-close:hover{color:var(--text)}
.news-alert-body{display:flex;flex-direction:column;gap:4px}
.news-alert-country{font-size:11px;font-weight:600;color:var(--text3);display:flex;align-items:center}
.news-alert-title{font-size:13px;font-weight:700;color:var(--text);line-height:1.3}
.news-alert-time{font-size:11px;color:#ef4444;font-weight:600}
.toast{position:fixed;bottom:20px;right:20px;background:var(--btn-inv);color:var(--logo-fg);border-radius:8px;padding:10px 16px;font-size:13px;font-weight:500;z-index:999;transform:translateY(6px);opacity:0;pointer-events:none;transition:all .2s;max-width:260px}
.toast.show{transform:translateY(0);opacity:1}

/* Fullscreen editor */
.rte-fullscreen-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:300;display:none;align-items:center;justify-content:center;padding:30px}
.rte-fullscreen-overlay.open{display:flex}
.rte-fullscreen-box{background:var(--bg);border:1px solid var(--border);border-radius:10px;width:100%;max-width:800px;height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px var(--shadow);overflow:hidden}
.rte-fullscreen-box .rte-editor{flex:1;overflow-y:auto;min-height:0;font-size:14px}
.rte-fullscreen-bar{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface)}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE — must be LAST to override base styles
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── Tablet / iPad  769–1366px ── */
@media(min-width:769px) and (max-width:1366px){
  /* Auto-proportion: journal panel clamps to viewport, cal fills rest */
  .cal-section{flex:1 !important;min-width:0;width:auto !important}
  .journal-panel{width:clamp(260px,30%,420px) !important;flex:none !important;flex-shrink:0}

  /* Calendar grid: weekly column smaller, equal day cells */
  .cal-grid{grid-template-columns:repeat(7,minmax(0,1fr)) 72px !important}
  .cal-week-cell{min-height:100px;padding:6px 2px}
  .cw-val{font-size:11px}
  .cw-label,.cw-days{font-size:8px}

  /* Calendar cell */
  .cal-cell{min-height:100px;padding:6px}
  .c-pnl{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .c-right{width:clamp(32px,4vw,56px) !important;height:clamp(32px,4vw,56px) !important}
  .c-count,.c-symbols{font-size:10px}

  /* below-cal: single column so charts don't overflow */
  .below-cal{grid-template-columns:1fr !important;min-width:0}
  .stats-panel,.charts-col,.chart-card{max-width:100%;min-width:0}
  .bottom-row{grid-template-columns:1fr !important}

  /* Footer */
  .cal-footer{flex-wrap:wrap;gap:6px;padding:8px 12px}
  .btn-view{padding:5px 10px;font-size:11px}
}

/* ── Mobile ≤768px ── */
@media(max-width:768px){
  html,body{height:100%;overflow:hidden}
  .app{height:100vh;height:100dvh;display:flex;flex-direction:column}

  /* Topbar compact — icon-only */
  .topbar{padding:0 10px;gap:6px;height:44px}
  .topbar .btn{font-size:0;gap:0;padding:5px 8px}
  .topbar .btn svg{width:15px;height:15px}
  .topbar-logo > span{display:none}

  /* Main layout — stack, one panel visible at a time */
  .main-split{flex:1;min-height:0;overflow:hidden;flex-direction:column}
  #split-handle{display:none !important}

  /* Default: Calendar tab */
  .cal-section{flex:1;min-height:0;width:100% !important;overflow:hidden;display:flex;flex-direction:column}
  .journal-panel{display:none !important}

  /* Journal tab */
  .app.mob-journal .cal-section{display:none !important}
  .app.mob-journal .journal-panel{display:flex !important;flex:1;min-height:0;width:100% !important;border-left:none}

  /* Stats tab */
  .app.mob-stats .cal-topbar{display:none !important}
  .app.mob-stats #cal-grid{display:none !important}
  .app.mob-stats .cal-footer{display:none !important}
  .below-cal{grid-template-columns:1fr !important;gap:10px}
  .app.mob-stats .below-cal{display:grid !important;grid-template-columns:1fr !important;gap:12px;padding:12px}

  /* Bottom row: stack on mobile */
  .bottom-row{grid-template-columns:1fr !important}

  /* Stats panel full width */
  .stats-panel{width:100%}
  .charts-col{width:100%}

  /* Instruments: scroll horizontally */
  .inst-list{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .inst-chip{min-width:72px;flex-shrink:0}

  /* Heatmap: horizontal scroll on mobile */
  #heatmap-card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .hm-grid{min-width:600px;gap:2px}
  .hm-axis{min-width:600px;gap:2px;margin-top:2px}

  /* Calendar grid — horizontal scroll via wrapper */
  .cal-body{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;min-height:0}
  .cal-grid-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
  .cal-grid{min-width:580px;grid-template-columns:repeat(7,minmax(60px,1fr)) 56px !important}
  /* Calendar cell */
  .cal-cell{min-height:68px;padding:4px}
  .c-pnl{font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
  .c-right{width:34px;height:34px}
  .c-count,.c-symbols,.c-no-trades{font-size:9px}
  .c-num{font-size:11px}
  .cal-week-cell{min-height:68px;padding:4px 2px}
  .cw-val{font-size:10px}
  .cw-label,.cw-days{font-size:8px}
  /* Footer */
  .cal-footer{flex-wrap:wrap;gap:5px;padding:6px 10px}
  .btn-view{padding:5px 10px;font-size:11px}
  /* Toast above mobile nav */
  .toast{bottom:calc(56px + env(safe-area-inset-bottom,0px) + 10px)}
  /* Bottom nav */
  .mobile-nav{
    display:flex;
    height:calc(56px + env(safe-area-inset-bottom,0px));
    border-top:1px solid var(--border);
    background:var(--bg);
    flex-shrink:0;
    padding-bottom:env(safe-area-inset-bottom,0px)
  }
  .mob-tab{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;background:none;border:none;cursor:pointer;
    color:var(--text4);font-size:10px;font-weight:600;font-family:inherit;
    padding:4px 0;transition:color .12s
  }
  .mob-tab.active{color:var(--text)}
}


/* ══ AI COACH PANEL ══ */
.btn-ai{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;border:none;font-weight:600}
.btn-ai:hover{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}
.btn-missions{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#1a1a1a;border:none;font-weight:600}
.btn-missions:hover{background:linear-gradient(135deg,#d97706,#f59e0b);color:#1a1a1a}
.btn-news{background:var(--card);color:var(--text);border:1px solid var(--border);font-weight:500;gap:5px}
.btn-news:hover{background:var(--hover)}
/* ── Topbar navigation tabs (Calendar / Chart / News) — PC only ── */
.topbar-tabs{display:flex;align-items:center;gap:4px;padding:3px;background:var(--surface);border:1px solid var(--border);border-radius:9px}
.btn-chart-mob,.btn-news-mob{display:none}
@media(max-width:768px){
  .topbar-tabs{display:none !important}
  .btn-chart-mob,.btn-news-mob{display:inline-flex}
}
.topbar-tab{position:relative;display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text3);background:none;border:none;cursor:pointer;font-family:inherit;white-space:nowrap;transition:color .2s ease,transform .15s ease;z-index:1}
.topbar-tab svg{transition:transform .2s ease,opacity .2s ease;opacity:.75}
.topbar-tab:hover{color:var(--text)}
.topbar-tab:hover svg{opacity:1}
.topbar-tab:active{transform:scale(.97)}
.topbar-tab.nav-active{color:#fff;font-weight:600;background:linear-gradient(135deg,#3b82f6,#6366f1);box-shadow:0 2px 8px rgba(59,130,246,.35),0 0 0 1px rgba(99,102,241,.4),inset 0 1px 0 rgba(255,255,255,.15)}
.topbar-tab.nav-active svg{opacity:1}
.topbar-tab.nav-active:hover{color:#fff}
/* account switcher compact */
.acc-switcher-compact{max-width:unset}
/* on mobile, overlays cover full screen (no persistent topbar) */
@media(max-width:768px){#chart-overlay,#market-overlay{top:0 !important}}
#news-panel{transition:transform .32s cubic-bezier(.4,0,.2,1);transform:translateX(100%)}
#news-panel.open{transform:translateX(0)}
/* ══ MISSIONS PANEL ══ */
.msn-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1798;backdrop-filter:blur(3px)}
.msn-panel{position:fixed;top:0;right:-480px;width:480px;max-width:100vw;height:100vh;height:100dvh;background:var(--bg);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:1799;transition:right .32s cubic-bezier(.4,0,.2,1);box-shadow:-12px 0 48px rgba(0,0,0,.18)}
.msn-panel.open{right:0}
.msn-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0;background:linear-gradient(135deg,rgba(245,158,11,.06),rgba(251,191,36,.04))}
.msn-panel-title{display:flex;align-items:center;gap:7px;font-weight:700;font-size:14px;color:var(--text)}
.msn-content{flex:1;overflow-y:auto;padding:16px}
/* Header */
.msn-header{margin-bottom:14px}
.msn-week-nav{display:flex;align-items:center;gap:10px}
.msn-nav-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-radius:6px;width:28px;height:28px;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.msn-nav-btn:disabled{opacity:.3;cursor:default}
.msn-week-label{flex:1;text-align:center}
.msn-week-key{display:block;font-size:11px;color:var(--text3);font-weight:600;letter-spacing:.5px}
.msn-week-range{display:block;font-size:13px;color:var(--text);font-weight:500}
.msn-past-badge{text-align:center;margin-top:4px;font-size:10px;color:var(--text3);background:var(--surface2);border-radius:99px;padding:2px 10px;display:inline-block;margin:4px auto 0;display:block}
/* Level */
.msn-level-row{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;background:var(--surface);border-radius:10px;border:1px solid var(--border)}
.msn-level-badge{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;min-width:90px}
.msn-level-name{color:#f59e0b;font-size:11px}
.msn-xp-bar-wrap{flex:1;height:6px;background:var(--surface2);border-radius:99px;overflow:hidden}
.msn-xp-bar{height:100%;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:99px;transition:width .5s}
.msn-xp-num{font-size:11px;color:var(--text3);white-space:nowrap}
/* Trophy row */
.msn-trophy-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}
.msn-trophy-box,.msn-streak-box,.msn-xp-earn-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}
.msn-trophy-svg{width:64px;height:64px;display:flex;align-items:center;justify-content:center}
.msn-trophy-label{font-size:12px;font-weight:700;color:var(--text)}
.msn-trophy-sub{font-size:10px;color:var(--text3)}
.msn-streak-fire{font-size:22px}
.msn-streak-num{font-size:20px;font-weight:800;color:#ef4444}
.msn-streak-label{font-size:10px;color:var(--text3)}
.msn-xp-earn-num{font-size:20px;font-weight:800;color:#22c55e}
.msn-xp-earn-label{font-size:10px;color:var(--text3)}
/* Category */
.msn-cat-section{margin-bottom:8px;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.msn-cat-header{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;user-select:none;background:var(--surface)}
.msn-cat-header:hover{background:var(--surface2)}
.msn-cat-emoji{font-size:13px}
.msn-cat-label{font-size:12px;font-weight:700;color:var(--text);min-width:80px}
.msn-cat-bar-wrap{flex:1;height:5px;background:var(--surface2);border-radius:99px;overflow:hidden}
.msn-cat-bar{height:100%;border-radius:99px;transition:width .4s}
.msn-cat-count{font-size:11px;color:var(--text3);min-width:28px;text-align:right}
.msn-cat-arrow{color:var(--text3);transition:transform .2s;flex-shrink:0}
/* Quest list */
.msn-quest-list{display:none;border-top:1px solid var(--border)}
.msn-quest-list.open{display:block}
.msn-quest-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--border2);cursor:default;transition:background .15s}
.msn-quest-item:last-child{border-bottom:none}
.msn-quest-item[onclick]{cursor:pointer}
.msn-quest-item[onclick]:hover{background:var(--surface)}
.msn-quest-item.done{background:rgba(34,197,94,.04)}
.msn-quest-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text3);flex-shrink:0;transition:all .2s}
.msn-quest-item.done .msn-quest-check{background:#22c55e;border-color:#22c55e;color:#fff}
.msn-quest-body{flex:1;min-width:0}
.msn-quest-label{font-size:12px;color:var(--text2)}
.msn-quest-item.done .msn-quest-label{color:var(--text3);text-decoration:line-through}
.msn-quest-hint{display:block;font-size:9.5px;color:var(--text4);margin-top:2px;font-style:italic}
.msn-quest-right{display:flex;flex-direction:column;align-items:flex-end;gap:1px;flex-shrink:0}
.msn-quest-stars{font-size:8px}
.msn-quest-xp{font-size:10px;font-weight:700;color:#f59e0b}
.msn-quest-item.done .msn-quest-xp{color:#22c55e}
/* Weekly Summary Popup */
#msn-summary-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
#msn-summary-overlay.show{opacity:1}
.msn-summary-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:32px 28px;text-align:center;width:280px;box-shadow:0 24px 80px rgba(0,0,0,.4);transform:translateY(20px);transition:transform .3s}
#msn-summary-overlay.show .msn-summary-card{transform:translateY(0)}
.msn-summary-week{font-size:11px;color:var(--text4);margin-bottom:16px;letter-spacing:.5px}
.msn-summary-medal{display:flex;justify-content:center;margin-bottom:8px}
.msn-summary-trophy-name{font-size:20px;font-weight:800;margin-bottom:18px}
.msn-summary-stats{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:24px;padding:14px;background:var(--surface);border-radius:12px}
.msn-summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px}
.msn-summary-stat-num{font-size:26px;font-weight:800;color:var(--text);line-height:1}
.msn-summary-stat-label{font-size:10px;color:var(--text4)}
.msn-summary-divider{width:1px;height:36px;background:var(--border)}
.msn-summary-btn{width:100%;padding:12px;background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#1a1a1a;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer}
.msn-summary-btn:hover{opacity:.9}

/* Trophy Cabinet */
.msn-cabinet-section{margin-top:14px;padding:14px;background:var(--surface);border-radius:10px;border:1px solid var(--border)}
.msn-cabinet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.msn-cup-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);transition:all .2s}
.msn-cup-item.unlocked{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.05);box-shadow:0 0 12px rgba(245,158,11,.12)}
.msn-cup-svg{width:64px;height:64px;display:flex;align-items:center;justify-content:center}
.msn-cup-name{font-size:10px;font-weight:700;color:var(--text2);text-align:center;line-height:1.2}
.msn-cup-item.unlocked .msn-cup-name{color:#f59e0b}
.msn-cup-status{font-size:9px;text-align:center}
.unlocked-tag{color:#22c55e;font-weight:700}
.lock-tag{color:var(--text4)}
.msn-cup-progress-wrap{width:100%;height:3px;background:var(--border);border-radius:99px;overflow:hidden;margin-top:2px}
.msn-cup-progress-bar{height:100%;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:99px;transition:width .4s}

/* Hall of Fame */
.msn-hof-section{margin-top:14px;padding:12px;background:var(--surface);border-radius:10px;border:1px solid var(--border)}
.msn-hof-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:10px}
.msn-hof-summary{display:flex;gap:14px;align-items:center;margin-bottom:10px}
.msn-hof-count{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:var(--text2)}
.msn-hof-weeks{display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}
.msn-hof-weeks::-webkit-scrollbar{height:3px}
.msn-hof-weeks::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
.msn-hof-week{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:36px}
.msn-hof-week-svg{width:36px;height:36px;display:flex;align-items:center;justify-content:center}
.msn-hof-week-svg svg{width:36px;height:36px}
.msn-hof-week-label{font-size:9px;color:var(--text4)}
.msn-hof-week.current{opacity:1}
.msn-hof-week.current .msn-hof-week-label{color:#f59e0b;font-weight:700}
.msn-hof-week.current .msn-hof-week-svg{filter:drop-shadow(0 0 4px rgba(245,158,11,.5))}
@media(max-width:1024px){.msn-panel{width:min(480px,100vw)}}
@media(max-width:500px){.msn-panel{width:100vw}}

/* ── Quest complete toast ── */
.msn-quest-toast{position:fixed;top:50px;right:20px;background:var(--bg);border:1px solid rgba(34,197,94,.35);border-radius:8px;padding:10px 16px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text);box-shadow:0 4px 24px rgba(0,0,0,.18);z-index:99999;opacity:0;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease;white-space:nowrap;pointer-events:none}
.msn-quest-toast.show{opacity:1;transform:translateY(0)}

.ai-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1800;backdrop-filter:blur(3px)}
.ai-panel{position:fixed;top:0;right:-440px;width:440px;max-width:100vw;height:100vh;height:100dvh;background:var(--bg);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:1801;transition:right .32s cubic-bezier(.4,0,.2,1);box-shadow:-12px 0 48px rgba(0,0,0,.16)}
.ai-panel.open{right:0}
/* Header */
.ai-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0;background:linear-gradient(135deg,rgba(99,102,241,.06),rgba(139,92,246,.04));backdrop-filter:blur(8px)}
.ai-panel-title{font-size:14px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px;letter-spacing:-.2px}
.ai-model-badge{font-size:9px;font-weight:700;padding:3px 8px;border-radius:6px;background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(139,92,246,.15));color:#7c3aed;letter-spacing:.4px;margin-left:2px;border:1px solid rgba(139,92,246,.15)}
.ai-hdr-btn{background:none;border:none;color:var(--text4);cursor:pointer;padding:6px 7px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.ai-hdr-btn:hover{background:rgba(139,92,246,.1);color:#7c3aed}
.ai-lang-btn{font-size:10px;font-weight:800;letter-spacing:.3px;min-width:28px}
/* Messages */
.ai-messages{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth}
.ai-msg{display:flex;gap:9px;align-items:flex-start}
.ai-msg-user{flex-direction:row-reverse}
.ai-avatar{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;box-shadow:0 2px 8px rgba(99,102,241,.3)}
/* Bot bubble wrapper (for copy btn positioning) */
.ai-bubble-bot-wrap{position:relative;max-width:calc(100% - 42px)}
.ai-bubble{background:var(--surface);border:1px solid var(--border);border-radius:4px 14px 14px 14px;padding:12px 16px;font-size:13px;color:var(--text2);line-height:1.7;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.ai-bubble-user{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:transparent;border-radius:14px 4px 14px 14px;max-width:calc(100% - 42px);box-shadow:0 2px 10px rgba(99,102,241,.25)}
/* Copy button */
.ai-copy-btn{position:absolute;top:-8px;right:-2px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:10px;font-weight:600;color:var(--text4);cursor:pointer;opacity:0;transition:opacity .15s;font-family:inherit;box-shadow:0 2px 6px var(--shadow);white-space:nowrap}
.ai-msg-bot:hover .ai-copy-btn{opacity:1}
.ai-copy-btn:hover{color:var(--text);background:var(--surface)}
/* Typing dots */
.ai-typing{display:inline-flex;gap:4px;align-items:center;height:18px;padding:1px 0}
.ai-typing span{width:6px;height:6px;border-radius:50%;background:var(--text4);animation:aiDot 1.3s ease-in-out infinite}
.ai-typing span:nth-child(2){animation-delay:.22s}
.ai-typing span:nth-child(3){animation-delay:.44s}
@keyframes aiDot{0%,80%,100%{transform:scale(.65);opacity:.35}40%{transform:scale(1);opacity:1}}
/* Markdown in bubbles */
.ai-bubble .ai-md-h2{font-size:13px;font-weight:700;color:var(--text);margin:10px 0 5px;line-height:1.3}
.ai-bubble .ai-md-h3{font-size:12.5px;font-weight:700;color:var(--text2);margin:8px 0 4px;line-height:1.3}
.ai-bubble .ai-md-ul,.ai-bubble .ai-md-ol{margin:5px 0;padding-left:18px}
.ai-bubble .ai-md-ul li,.ai-bubble .ai-md-ol li{margin:4px 0;line-height:1.65}
.ai-bubble .ai-md-spacer{height:6px}
.ai-bubble .ai-md-code{background:var(--surface2);border-radius:4px;padding:1px 6px;font-family:'SF Mono',Consolas,monospace;font-size:11px;color:var(--text);border:1px solid var(--border)}
.ai-bubble-user .ai-md-code{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3);color:#fff}
/* Quick prompts */
.ai-quick-row{display:flex;flex-wrap:wrap;gap:6px;padding:10px 16px;border-top:1px solid var(--border);flex-shrink:0;max-height:30vh;overflow-y:auto;justify-content:center}
.ai-quick-btn{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--bg);font-size:11.5px;color:var(--text3);cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}
.ai-quick-btn:hover{border-color:#8b5cf6;color:#8b5cf6;background:rgba(139,92,246,.07);box-shadow:0 0 0 3px rgba(139,92,246,.06)}
/* Input row */
.ai-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);align-items:flex-end;flex-shrink:0}
.ai-text-input{flex:1;border:1px solid var(--border);border-radius:10px;padding:9px 13px;font-size:16px;font-family:inherit;color:var(--text);background:var(--surface);resize:none;outline:none;line-height:1.55;overflow:hidden;-webkit-appearance:none;-webkit-user-select:text;user-select:text;touch-action:manipulation}
.ai-text-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,.1)}
.ai-send-btn{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;box-shadow:0 2px 8px rgba(99,102,241,.3)}
.ai-send-btn:hover{opacity:.88;box-shadow:0 4px 14px rgba(99,102,241,.4)}
.ai-send-btn:active{transform:scale(.94)}
/* Daily greeting card */
.ai-greeting-card{background:linear-gradient(135deg,rgba(99,102,241,.07),rgba(139,92,246,.05));border:1px solid rgba(139,92,246,.15);border-radius:14px;padding:16px 18px;margin:0 0 6px}
.ai-greeting-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.ai-greeting-icon{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(99,102,241,.3)}
.ai-greeting-title{font-size:14px;font-weight:700;color:var(--text)}
.ai-greeting-time{font-size:11px;color:var(--text4);font-weight:500}
.ai-greeting-body{font-size:12.5px;color:var(--text2);line-height:1.7}
.ai-greeting-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:12px}
.ai-greeting-stat{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center}
.ai-greeting-stat-val{font-size:16px;font-weight:800;font-family:'SF Mono',Consolas,monospace;letter-spacing:-.3px}
.ai-greeting-stat-val.pos{color:#16a34a}
.ai-greeting-stat-val.neg{color:#dc2626}
.ai-greeting-stat-lbl{font-size:10px;color:var(--text4);margin-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
/* Setup screen */
.ai-setup{display:flex;flex-direction:column;align-items:center;text-align:center;padding:36px 24px 28px;gap:14px}
.ai-setup-icon{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(99,102,241,.35),0 0 0 6px rgba(99,102,241,.08)}
.ai-setup-title{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.4px}
.ai-setup-desc{font-size:13px;color:var(--text3);line-height:1.65;max-width:300px}
.ai-provider-tabs{display:flex;gap:8px;width:100%}
.ai-prov-tab{flex:1;padding:11px 12px;border:1.5px solid var(--border);border-radius:12px;background:var(--surface);font-size:13px;font-weight:600;color:var(--text3);cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}
.ai-prov-tab.active{border-color:#8b5cf6;color:#8b5cf6;background:rgba(139,92,246,.07);box-shadow:0 0 0 3px rgba(139,92,246,.1)}
.ai-prov-tab:hover:not(.active){color:var(--text2);background:var(--surface2);border-color:var(--text4)}
.ai-prov-badge{font-size:8px;font-weight:800;padding:2px 5px;border-radius:4px;letter-spacing:.3px}
.ai-prov-badge.free{background:rgba(16,185,129,.15);color:#10b981}
/* Model selector */
.ai-model-select{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;cursor:pointer;transition:border-color .15s}
.ai-model-select:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,.1)}
/* Key input with show/hide toggle */
.ai-key-wrap{position:relative;width:100%}
.ai-key-input{width:100%;padding:11px 42px 11px 14px;border:1px solid var(--border);border-radius:10px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}
.ai-key-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,.1)}
.ai-key-toggle{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text4);cursor:pointer;padding:4px;display:flex;align-items:center;transition:color .15s}
.ai-key-toggle:hover{color:var(--text2)}
.ai-key-save-btn{width:100%;padding:13px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;box-shadow:0 4px 14px rgba(99,102,241,.3)}
.ai-key-save-btn:hover{opacity:.88;box-shadow:0 6px 20px rgba(99,102,241,.4);transform:translateY(-1px)}
.ai-security-note{display:flex;align-items:center;gap:7px;background:rgba(16,185,129,.07);border:1px solid rgba(16,185,129,.2);border-radius:8px;padding:8px 12px;font-size:11.5px;color:#059669;width:100%;text-align:left}
.ai-key-link{font-size:12px;color:#8b5cf6;text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.ai-key-link:hover{text-decoration:underline}
@media(max-width:1024px){.ai-panel{width:min(440px,100vw)}}
@media(max-width:500px){.ai-panel{width:100vw}}
/* iPad/tablet: ensure messages area fills remaining space */
.ai-messages{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth;min-height:0}
.ai-input-row{flex-shrink:0}

/* ── AI Notification Bar (all popups use this) ── */
.ai-notify{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:400;animation:aiNotifyIn .4s cubic-bezier(.4,0,.2,1);width:calc(100% - 32px);max-width:480px}
@keyframes aiNotifyIn{from{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.ai-notify-inner{display:flex;align-items:flex-start;gap:12px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:0 4px 24px rgba(0,0,0,.1)}
.ai-notify-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.ai-notify-dot.purple{background:#8b5cf6}
.ai-notify-dot.amber{background:#f59e0b}
.ai-notify-dot.red{background:#ef4444}
.ai-notify-body{flex:1;min-width:0}
.ai-notify-title{font-size:12.5px;font-weight:700;color:var(--text);margin-bottom:3px}
.ai-notify-msg{font-size:12px;color:var(--text3);line-height:1.55}
.ai-notify-btns{display:flex;gap:6px;margin-top:10px}
.ai-notify-btn{padding:5px 14px;border-radius:7px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;border:none}
.ai-notify-btn.primary{background:var(--text);color:var(--bg)}
.ai-notify-btn.primary:hover{opacity:.85}
.ai-notify-btn.ghost{background:none;border:1px solid var(--border);color:var(--text3)}
.ai-notify-btn.ghost:hover{background:var(--surface);color:var(--text2)}
.ai-notify-close{position:absolute;top:10px;right:12px;background:none;border:none;color:var(--text4);cursor:pointer;font-size:14px;padding:2px 4px;line-height:1;transition:color .15s}
.ai-notify-close:hover{color:var(--text)}
/* Legacy class aliases */
.ai-trade-popup{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:400;animation:aiNotifyIn .4s cubic-bezier(.4,0,.2,1);width:calc(100% - 32px);max-width:480px}
.ai-trade-popup-inner{display:flex;align-items:flex-start;gap:12px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:0 4px 24px rgba(0,0,0,.1)}
.ai-trade-popup-icon{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px;background:#8b5cf6}
.ai-trade-popup-icon svg{display:none}
.ai-trade-popup-msg{font-size:12px;color:var(--text3);line-height:1.55}
.ai-trade-popup-btns{display:flex;gap:6px;margin-top:10px}
.ai-trade-popup-yes{padding:5px 14px;border-radius:7px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;border:none;background:var(--text);color:var(--bg)}
.ai-trade-popup-yes:hover{opacity:.85}
.ai-trade-popup-no{padding:5px 14px;border-radius:7px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;background:none;border:1px solid var(--border);color:var(--text3)}
.ai-trade-popup-no:hover{background:var(--surface);color:var(--text2)}
.ai-revenge-popup{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:500;animation:aiNotifyIn .4s cubic-bezier(.4,0,.2,1);width:calc(100% - 32px);max-width:480px}
.ai-revenge-inner{display:flex;align-items:flex-start;gap:12px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:0 4px 24px rgba(0,0,0,.1)}
.ai-revenge-icon{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px;background:#ef4444;font-size:0;overflow:hidden}
.ai-revenge-title{font-size:12.5px;font-weight:700;color:var(--text);margin-bottom:3px}
.ai-revenge-msg{font-size:12px;color:var(--text3);line-height:1.55;margin-bottom:0}
.ai-revenge-btns{display:flex;gap:6px;margin-top:10px}
.ai-revenge-coach{padding:5px 14px;border-radius:7px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;border:none;background:var(--text);color:var(--bg);box-shadow:none}
.ai-revenge-coach:hover{opacity:.85}
.ai-revenge-dismiss{padding:5px 14px;border-radius:7px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;background:none;border:1px solid var(--border);color:var(--text3);box-shadow:none}
.ai-revenge-dismiss:hover{background:var(--surface);color:var(--text2)}

/* AI Rules Panel */
.ai-rules-panel{padding:24px 20px;display:flex;flex-direction:column;gap:14px}
.ai-rules-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.ai-rules-title{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.ai-rules-desc{font-size:11.5px;color:var(--text4)}
.ai-rule-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px}
.ai-rule-label{font-size:12.5px;font-weight:600;color:var(--text2)}
.ai-rule-input-wrap{display:flex;align-items:center;gap:8px}
.ai-rule-input{width:60px;padding:6px 8px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:'SF Mono',Consolas,monospace;text-align:center;color:var(--text);background:var(--bg);outline:none}
.ai-rule-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,.1)}
.ai-rule-toggle{width:36px;height:20px;border-radius:10px;background:var(--border);cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.ai-rule-toggle::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.ai-rule-toggle.on{background:#8b5cf6}
.ai-rule-toggle.on::after{transform:translateX(16px)}
.ai-rules-save{padding:12px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;box-shadow:0 2px 8px rgba(99,102,241,.3);margin-top:4px}
.ai-rules-save:hover{opacity:.88}
.ai-rules-back{padding:10px;border-radius:10px;background:none;border:1px solid var(--border);color:var(--text3);font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}
.ai-rules-back:hover{background:var(--surface);color:var(--text2)}
/* Rules banner (shown when no rules set) */
.ai-rules-banner{display:flex;align-items:center;gap:10px;padding:12px 14px;background:linear-gradient(135deg,rgba(99,102,241,.06),rgba(139,92,246,.04));border:1px solid rgba(139,92,246,.18);border-radius:12px;cursor:pointer;transition:all .2s;margin:0 0 4px}
.ai-rules-banner:hover{background:rgba(139,92,246,.1);border-color:rgba(139,92,246,.3)}
.ai-rules-banner-icon{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-rules-banner-body{flex:1}
.ai-rules-banner-title{font-size:12.5px;font-weight:700;color:var(--text)}
.ai-rules-banner-desc{font-size:11px;color:var(--text4);line-height:1.5;margin-top:1px}
.ai-rules-banner-arrow{font-size:20px;color:var(--text4);font-weight:300}
/* Rules active status */
.ai-rules-status{display:flex;align-items:center;gap:6px;padding:8px 12px;background:rgba(139,92,246,.05);border:1px solid rgba(139,92,246,.12);border-radius:10px;cursor:pointer;transition:all .15s;font-size:11.5px;color:var(--text3);margin:0 0 4px}
.ai-rules-status:hover{background:rgba(139,92,246,.1)}
.ai-rules-status-edit{margin-left:auto;color:#8b5cf6;font-weight:600;font-size:11px}
/* Journal Prompt — same bottom bar style */
.ai-journal-popup .ai-trade-popup-icon{background:#f59e0b}
.ai-journal-popup .ai-trade-popup-icon svg{display:none}

/* ══ EDITOR IMAGE ══ */
.editor-img-wrap{position:relative;display:block;margin:4px 0;line-height:normal}
.editor-img-del{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.65);color:#fff;border:none;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;line-height:1}
.editor-img-wrap:hover .editor-img-del{opacity:1}
.editor-img-draw{position:absolute;top:6px;right:34px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.65);color:#fff;border:none;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;line-height:1}
.editor-img-wrap:hover .editor-img-draw{opacity:1}
.draw-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9999;display:none;align-items:center;justify-content:center;flex-direction:column}
.draw-overlay.open{display:flex}
.draw-toolbar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:rgba(30,30,40,.95);border-radius:10px;margin-bottom:10px;flex-wrap:wrap;justify-content:center}
.draw-canvas{border-radius:8px;cursor:crosshair;touch-action:none;max-width:95vw;max-height:75vh}
.draw-color{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s}
.draw-color.active{border-color:#fff}
.draw-size{width:70px;accent-color:#6366f1}
.draw-btn{padding:6px 14px;border-radius:7px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-size:12px;cursor:pointer;transition:all .15s}
.draw-btn:hover{background:rgba(255,255,255,.2)}
.draw-btn.save{background:#6366f1;border-color:#6366f1}
.draw-btn.save:hover{background:#4f46e5}
