:root{
  --bg:#0b0e14; --panel:#141925; --panel2:#1b2230; --line:#232c3d;
  --text:#e7ecf3; --muted:#8a97ab; --tiny:#5f6b80;
  --green:#21c55d; --green-dim:#143a26; --red:#f0506e; --red-dim:#3a1620;
  --amber:#f6b73c; --amber-dim:#3a2e12; --accent:#4f8cff; --accent-dim:#16243f;
  --radius:14px; --shadow:0 6px 24px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:radial-gradient(1200px 600px at 80% -10%,#16203a 0%,var(--bg) 55%);
  color:var(--text); min-height:100vh; -webkit-font-smoothing:antialiased;
}
.hidden{display:none !important}
.muted{color:var(--muted)} .tiny{font-size:12px}
button{font-family:inherit; cursor:pointer; border:none; border-radius:10px; font-weight:600}
.primary{background:var(--accent); color:#fff; padding:9px 16px}
.primary:hover{background:#3f7bf0}
.ghost{background:transparent; color:var(--muted); border:1px solid var(--line); padding:7px 13px}
.ghost:hover{color:var(--text); border-color:#33405a}

/* LOGIN */
.login{position:fixed; inset:0; display:grid; place-items:center; padding:20px;
  background:radial-gradient(900px 500px at 50% 0%,#16203a 0%,var(--bg) 60%); z-index:50}
.login-card{background:var(--panel); border:1px solid var(--line); border-radius:18px;
  padding:34px 30px; width:100%; max-width:360px; text-align:center; box-shadow:var(--shadow)}
.login-card .logo{font-size:42px}
.login-card h1{margin:8px 0 2px; font-size:22px}
.login-card input{width:100%; margin:18px 0 10px; padding:12px 14px; border-radius:10px;
  border:1px solid var(--line); background:var(--panel2); color:var(--text); font-size:15px}
.login-card button{width:100%; padding:12px; font-size:15px; background:var(--accent); color:#fff}
.err{color:var(--red); font-size:13px; margin-top:10px; min-height:16px}

/* TOPBAR */
.app{max-width:1200px; margin:0 auto; padding:18px 18px 40px}
.topbar{display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:6px 2px 18px}
.brand{font-weight:800; font-size:18px; letter-spacing:.2px}
.logo-sm{margin-right:4px}
.top-actions{display:flex; align-items:center; gap:8px; flex-wrap:wrap}

/* SUMMARY */
.summary{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:14px; margin-bottom:22px}
.kpi{background:linear-gradient(180deg,var(--panel) 0%,var(--panel2) 100%);
  border:1px solid var(--line); border-radius:var(--radius); padding:16px 18px}
.kpi .lbl{color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.6px}
.kpi .val{font-size:26px; font-weight:800; margin-top:6px}
.kpi .sub{font-size:13px; margin-top:3px}

/* LAYOUT */
.layout{display:grid; grid-template-columns:1fr 340px; gap:22px}
@media(max-width:880px){ .layout{grid-template-columns:1fr} }
.section-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:12px}
.section-head h2,.side h2{font-size:16px; margin:0}

/* HOLDINGS */
.holdings{display:flex; flex-direction:column; gap:12px}
.card{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:14px 16px; display:grid; grid-template-columns:1fr auto; gap:10px 16px;
  cursor:pointer; transition:border-color .15s, transform .05s}
.card:hover{border-color:#33405a}
.card:active{transform:scale(.997)}
.card .head{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.tick{font-weight:800; font-size:17px}
.badge{font-size:11px; padding:2px 8px; border-radius:20px; font-weight:700; letter-spacing:.3px}
.badge.stock{background:var(--accent-dim); color:#8fb6ff}
.badge.etf{background:#1d2c22; color:#7fd8a0}
.badge.crypto{background:#2c2440; color:#b79bff}
.cname{color:var(--muted); font-size:13px}
.recpill{font-size:12px; font-weight:800; padding:4px 12px; border-radius:20px; letter-spacing:.4px}
.rec-BUY{background:var(--green-dim); color:var(--green); border:1px solid #1f5c39}
.rec-SELL{background:var(--red-dim); color:var(--red); border:1px solid #6e2435}
.rec-HOLD{background:var(--amber-dim); color:var(--amber); border:1px solid #6a531a}

.card .nums{text-align:right; display:flex; flex-direction:column; gap:2px; min-width:130px}
.price{font-size:18px; font-weight:700}
.chg-pos{color:var(--green)} .chg-neg{color:var(--red)} .chg-zero{color:var(--muted)}
.value{font-size:13px; color:var(--muted)}

.card .meta{grid-column:1 / -1; display:flex; flex-wrap:wrap; gap:8px 18px; align-items:center;
  border-top:1px solid var(--line); padding-top:10px; margin-top:2px}
.chip{font-size:12px; color:var(--muted)}
.chip b{color:var(--text); font-weight:600}
.spark{height:34px}

.reasons{grid-column:1/-1; display:flex; flex-wrap:wrap; gap:6px}
.reason{font-size:11.5px; padding:3px 9px; border-radius:8px; background:var(--panel2); color:var(--muted)}
.reason.pos{color:#8fe3ad} .reason.neg{color:#ff9bae} .reason.neu{color:var(--muted)}
.reason.pos::before{content:"▲ "} .reason.neg::before{content:"▼ "}

.holderr{grid-column:1/-1; color:var(--amber); font-size:12px}

.empty{text-align:center; padding:50px 20px; color:var(--muted);
  border:1px dashed var(--line); border-radius:var(--radius)}

/* NEWS */
.side{position:relative}
.news-tabs{display:flex; flex-wrap:wrap; gap:6px; margin:10px 0 12px}
.news-tab{font-size:12px; padding:5px 11px; border-radius:20px; background:var(--panel2);
  color:var(--muted); border:1px solid transparent; cursor:pointer}
.news-tab.active{background:var(--accent-dim); color:#9cbcff; border-color:#274064}
.news{display:flex; flex-direction:column; gap:10px}
.nitem{background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:11px 13px;
  text-decoration:none; color:var(--text); display:block; transition:border-color .15s}
.nitem:hover{border-color:#33405a}
.nitem .nt{font-size:13.5px; font-weight:500; line-height:1.35}
.nitem .nm{font-size:11px; color:var(--tiny); margin-top:6px}

.foot{text-align:center; margin-top:34px; padding-top:18px; border-top:1px solid var(--line)}

/* MODAL */
.modal{position:fixed; inset:0; background:rgba(4,7,12,.7); display:grid; place-items:center;
  padding:18px; z-index:40; backdrop-filter:blur(3px)}
.modal-card{background:var(--panel); border:1px solid var(--line); border-radius:18px;
  padding:22px; width:100%; max-width:440px; box-shadow:var(--shadow)}
.modal-card h3{margin:0 0 16px}
.modal-card label{display:block; font-size:13px; color:var(--muted); margin-bottom:12px}
.modal-card label small{color:var(--tiny); font-weight:400}
.modal-card input,.modal-card select{width:100%; margin-top:5px; padding:10px 12px; border-radius:9px;
  border:1px solid var(--line); background:var(--panel2); color:var(--text); font-size:14px}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.modal-actions{display:flex; align-items:center; gap:8px; margin-top:8px}
.modal-actions .spacer{flex:1}
#deleteBtn{color:var(--red); border-color:#42202a}

/* CHARTS */
.charts{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:22px}
@media(max-width:760px){ .charts{grid-template-columns:1fr} }
.chart-card{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:14px 16px}
.chart-card .lbl{color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.6px; margin-bottom:10px}
.hist{width:100%; height:130px; display:block}
.hist-foot{display:flex; justify-content:space-between; align-items:center; margin-top:4px; font-weight:600}
.donut-wrap{display:flex; align-items:center; gap:18px; flex-wrap:wrap}
.donut{width:140px; height:140px; flex:0 0 140px}
.legend{display:flex; flex-direction:column; gap:5px; font-size:13px; flex:1; min-width:120px}
.leg{display:flex; align-items:center; gap:7px; color:var(--muted)}
.leg b{color:var(--text); margin-left:auto}
.leg .dot{width:10px; height:10px; border-radius:3px; display:inline-block}

/* ANALYST BAR */
.analyst{grid-column:1/-1; display:flex; align-items:center; gap:10px}
.abar{flex:1; height:7px; border-radius:6px; overflow:hidden; display:flex; background:var(--panel2); max-width:260px}
.abar span{display:block; height:100%}

/* ALERTS */
.card.has-alert{border-color:#5a4316}
.alertb{font-size:11px; font-weight:700; padding:3px 9px; border-radius:20px}
.alertb.hit-t{background:var(--green-dim); color:var(--green)}
.alertb.hit-s{background:var(--red-dim); color:var(--red)}

.head-btns{display:flex; gap:8px}

/* IMPORT */
#importFile{width:100%; padding:10px; border:1px dashed var(--line); border-radius:10px;
  background:var(--panel2); color:var(--text); margin-top:8px}
#importResults{display:flex; flex-direction:column; gap:8px; max-height:46vh; overflow:auto; margin:6px 0}
.imp-row{display:grid; grid-template-columns:1fr 70px 80px 84px 30px; gap:6px; align-items:center}
.imp-row input,.imp-row select{padding:8px; border-radius:8px; border:1px solid var(--line);
  background:var(--panel2); color:var(--text); font-size:13px; width:100%}
.imp-row .x{background:transparent; color:var(--muted); border:1px solid var(--line); padding:7px 0}

/* TOAST */
.toast{position:fixed; bottom:22px; left:50%; transform:translateX(-50%);
  background:var(--panel2); border:1px solid var(--line); color:var(--text);
  padding:11px 18px; border-radius:12px; box-shadow:var(--shadow); z-index:60; font-size:14px}
