:root{
  --bg:#0f1116; --panel:#161a21; --panel2:#1b1f27; --cell:#1b1f27; --line:#262b35;
  --green:#16b877; --greenbg:rgba(22,184,119,.13); --greenbd:rgba(22,184,119,.5);
  --red:#e0524f; --redbg:rgba(224,82,79,.13); --redbd:rgba(224,82,79,.5);
  --ink:#e7ebf2; --muted:#8b93a3; --accent:#7c6cf0; --accentbg:#2a2740;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:'Segoe UI',Arial,sans-serif;background:var(--bg);color:var(--ink);}
a{color:var(--accent);text-decoration:none}
button{font-family:inherit}
.hidden{display:none !important}

/* layout */
.app{max-width:1180px;margin:0 auto;padding:20px}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.brand .logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#7c6cf0,#16b877);
  display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff}
.brand h1{font-size:20px;margin:0}
.brand .tag{color:var(--muted);font-size:13px}

.bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:16px 0}
.spacer{flex:1}
.btn{background:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:9px;
  padding:8px 14px;cursor:pointer;font-size:13px}
.btn:hover{border-color:#3a4150}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent}
.sel{background:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:9px;
  padding:8px 12px;font-size:13px}

.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:18px}
.tab{padding:10px 16px;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;font-size:14px}
.tab.active{color:var(--ink);border-bottom-color:var(--accent)}

/* stat cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:14px 16px}
.card .lbl{color:var(--muted);font-size:12px;margin-bottom:6px}
.card .val{font-size:21px;font-weight:800}
.pos{color:var(--green)} .neg{color:var(--red)} .zero{color:var(--muted)}

/* calendar */
.calbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.nav{display:flex;align-items:center;gap:8px}
.nav button{background:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:8px;
  width:34px;height:34px;font-size:16px;cursor:pointer}
.mlabel{font-size:19px;font-weight:700;min-width:150px;text-align:center}
.badge{border-radius:9px;padding:6px 12px;font-size:14px;font-weight:700}
.badge.lbl{background:var(--panel);color:var(--muted);font-weight:600}
.badge.pos{background:var(--greenbg);color:var(--green)}
.badge.neg{background:var(--redbg);color:var(--red)}
.badge.days{background:var(--accentbg);color:#b3a9e8}
.grid{display:grid;grid-template-columns:repeat(7,1fr) 158px;gap:7px}
.dow{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding:6px 4px;text-align:center}
.cell{background:var(--cell);border:1px solid var(--line);border-radius:9px;min-height:104px;padding:8px 10px;position:relative}
.cell.empty{background:transparent;border-color:transparent}
.cell.pos{background:var(--greenbg);border-color:var(--greenbd)}
.cell.neg{background:var(--redbg);border-color:var(--redbd)}
.cell.clickable{cursor:pointer}
.cell.clickable:hover{filter:brightness(1.12)}
.dnum{position:absolute;top:7px;left:10px;font-size:13px;color:var(--muted)}
.cell.pos .dnum,.cell.neg .dnum{color:var(--ink)}
.pnl{margin-top:20px;font-size:19px;font-weight:800}
.tcount{font-size:12px;color:var(--muted);margin-top:2px}
.sub{font-size:11px;color:var(--muted);margin-top:5px}
.wk{background:var(--panel);border:1px solid var(--line);border-radius:9px;min-height:104px;padding:12px 14px;
  display:flex;flex-direction:column;justify-content:center}
.wk .wlab{font-size:13px;color:var(--muted)}
.wk .wval{font-size:20px;font-weight:800;margin:6px 0 8px}
.wk .wdays{align-self:flex-start;background:var(--accentbg);color:#b3a9e8;border-radius:20px;padding:2px 10px;font-size:11px}

/* equity curve */
.chartbox{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:18px;margin-bottom:20px}
.chartbox h3{margin:0 0 12px;font-size:15px}
svg .axis{stroke:var(--line)}
svg .eqline{fill:none;stroke:var(--accent);stroke-width:2}
svg .eqarea{fill:url(#eqgrad)}

/* tables */
.tablebox{background:var(--panel);border:1px solid var(--line);border-radius:13px;overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{padding:10px 12px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
th{color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.03em;cursor:pointer;user-select:none}
tbody tr:hover{background:var(--panel2)}
tr:last-child td{border-bottom:none}
.pill{display:inline-block;border-radius:20px;padding:2px 9px;font-size:11px}
.pill.long{background:var(--greenbg);color:var(--green)} .pill.short{background:var(--redbg);color:var(--red)}
.pill.opt{background:var(--accentbg);color:#b3a9e8} .pill.stk{background:#22303a;color:#7fc4e0}
.pill.src{background:#2a2a33;color:#aab}

/* forms / modal */
.modal-bg{position:fixed;inset:0;background:rgba(6,8,12,.7);display:flex;align-items:center;justify-content:center;z-index:50}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px;width:min(560px,94vw);max-height:90vh;overflow:auto}
.modal h2{margin:0 0 16px;font-size:18px}
.form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form .full{grid-column:1/3}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;color:var(--muted)}
.field input,.field select,.field textarea{background:var(--bg);color:var(--ink);border:1px solid var(--line);
  border-radius:8px;padding:9px 10px;font-size:13px;font-family:inherit}
.field textarea{resize:vertical;min-height:60px}
.modal-actions{display:flex;justify-content:flex-start;gap:10px;margin-top:18px}
.pnlpreview{font-size:15px;font-weight:700}

/* dropzone */
.drop{border:2px dashed var(--line);border-radius:14px;padding:34px;text-align:center;color:var(--muted);
  background:var(--panel);cursor:pointer;transition:.15s}
.drop.hot{border-color:var(--accent);background:var(--accentbg);color:var(--ink)}
.drop b{color:var(--ink)}

.empty-state{text-align:center;color:var(--muted);padding:60px 20px}
.empty-state .big{font-size:44px;margin-bottom:10px}
.note{color:var(--muted);font-size:12px;line-height:1.6;margin-top:16px}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--panel);
  border:1px solid var(--line);border-radius:10px;padding:12px 18px;font-size:13px;z-index:60;box-shadow:0 6px 24px rgba(0,0,0,.4)}
