:root{
  --bg:#0b0e14; --bg2:#11151f; --card:#151b27; --card2:#1b2231;
  --line:#232c3d; --text:#e6ebf2; --muted:#8b97ac; --muted2:#5e6b80;
  --gold:#f0b429; --green:#2fbf71; --red:#ef5d60; --blue:#4d8bf0;
  --purple:#9b7df0; --cyan:#37c8d8;
  --shadow:0 6px 24px rgba(0,0,0,.35);
  --radius:14px;
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text)}
body{font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
.muted{color:var(--muted)}
.pos{color:var(--green)} .neg{color:var(--red)}

/* ── login ─────────────────────────────────────────── */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:radial-gradient(1200px 600px at 50% -10%,#1a2236 0%,var(--bg) 60%)}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:38px 34px;width:330px;display:flex;flex-direction:column;gap:12px;
  box-shadow:var(--shadow);text-align:center}
.login-logo{font-size:34px;color:var(--gold)}
.login-card h1{margin:4px 0 0;font-size:22px;letter-spacing:.3px}
.login-card .muted{margin:0 0 14px}
.field{background:var(--bg2);border:1px solid var(--line);color:var(--text);
  border-radius:10px;padding:12px 14px;font-size:14px;outline:none}
.field:focus{border-color:var(--blue)}
.btn-primary{background:linear-gradient(180deg,#f0b429,#d99b13);color:#1a1300;border:none;
  border-radius:10px;padding:12px;font-weight:700;cursor:pointer;font-size:14px}
.btn-primary:hover{filter:brightness(1.06)}
.login-err{color:var(--red);font-size:13px;margin:2px 0 0}

/* ── layout ────────────────────────────────────────── */
.app{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.sidebar{background:var(--bg2);border-right:1px solid var(--line);padding:18px 14px;
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:4px}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px;font-weight:800;font-size:16px}
.brand .dot{color:var(--gold);font-size:20px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  color:var(--muted);cursor:pointer;font-weight:600;font-size:13.5px}
.nav-item:hover{background:var(--card);color:var(--text)}
.nav-item.active{background:var(--card2);color:var(--text)}
.nav-item .ic{width:18px;text-align:center}
.sidebar .spacer{flex:1}
.logout{margin-top:6px}

.main{padding:22px 26px 60px;max-width:1500px;width:100%}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;
  flex-wrap:wrap;margin-bottom:18px}
.topbar h2{margin:0;font-size:20px}
.controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.seg{display:inline-flex;background:var(--bg2);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{background:transparent;border:none;color:var(--muted);padding:7px 13px;cursor:pointer;font-weight:600;font-size:13px}
.seg button.active{background:var(--card2);color:var(--text)}
.select{background:var(--bg2);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:7px 10px;font-size:13px}
.btn{background:var(--card2);border:1px solid var(--line);color:var(--text);border-radius:10px;
  padding:7px 12px;cursor:pointer;font-weight:600;font-size:13px}
.btn:hover{border-color:var(--blue)}
.pill{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;border:1px solid var(--line)}
.pill.ok{color:var(--green);border-color:rgba(47,191,113,.4)}
.pill.bad{color:var(--red);border-color:rgba(239,93,96,.4)}
.pill.warn{color:var(--gold);border-color:rgba(240,180,41,.4)}

/* ── cards / grid ──────────────────────────────────── */
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:1050px){.cols-2,.cols-3{grid-template-columns:1fr}}
@media(max-width:760px){.app{grid-template-columns:1fr}.sidebar{display:none;position:fixed;inset:0 auto 0 0;width:230px;z-index:200;overflow-y:auto}.app.sidebar-open .sidebar{display:flex}}
.menu-btn{display:none}
@media(max-width:760px){.menu-btn{display:inline-flex}}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199}
.app.sidebar-open .sidebar-backdrop{display:block}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow)}
.card h3{margin:0 0 12px;font-size:14px;color:var(--muted);font-weight:600;
  display:flex;align-items:center;justify-content:space-between}
.kpi .label{color:var(--muted);font-size:12.5px;font-weight:600;margin-bottom:8px;
  display:flex;align-items:center;gap:6px}
.kpi .value{font-size:26px;font-weight:800;letter-spacing:.3px}
.kpi .sub{font-size:12px;color:var(--muted);margin-top:5px}
.kpi .accent{height:3px;width:40px;border-radius:3px;margin-bottom:12px;background:var(--blue)}
.kpi.gold .accent{background:var(--gold)} .kpi.green .accent{background:var(--green)}
.kpi.red .accent{background:var(--red)} .kpi.blue .accent{background:var(--blue)}
.kpi.purple .accent{background:var(--purple)} .kpi.cyan .accent{background:var(--cyan)}

.chart-wrap{position:relative;height:300px}
.chart-wrap.tall{height:360px}
.chart-wrap.short{height:230px}

/* ── tables (Grid.js overrides) ────────────────────── */
.table-card{padding:16px 18px}
.gridjs-wrapper{box-shadow:none!important;border-radius:10px!important;border:1px solid var(--line)!important}
.gridjs-table{background:var(--card)!important}
table.gridjs-table th,.gridjs-th{background:var(--bg2)!important;color:var(--muted)!important;
  border-color:var(--line)!important;font-size:12px!important}
.gridjs-td{background:var(--card)!important;color:var(--text)!important;border-color:var(--line)!important;font-size:13px!important}
.gridjs-tr:hover .gridjs-td{background:var(--card2)!important}
.gridjs-search-input,.gridjs-input{background:var(--bg2)!important;color:var(--text)!important;border-color:var(--line)!important}
.gridjs-pagination,.gridjs-pagination .gridjs-pages button{color:var(--muted)!important;background:var(--bg2)!important;border-color:var(--line)!important}
.gridjs-footer{background:var(--bg2)!important;border-color:var(--line)!important}

.cell-pos{color:var(--green);font-weight:700}
.cell-neg{color:var(--red);font-weight:700}
.tag{font-size:11px;font-weight:700;padding:2px 7px;border-radius:6px;border:1px solid var(--line);display:inline-block}
.tag.buy{color:var(--green)} .tag.sell{color:var(--red)}
.tag.win{color:var(--green)} .tag.loss{color:var(--red)}

.empty{color:var(--muted);text-align:center;padding:34px 10px;font-style:italic}
.updated{color:var(--muted2);font-size:12px}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--line);
  border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
.hidden{display:none!important}
.page{animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ── expand modal ──────────────────────────────────── */
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:none;
  align-items:center;justify-content:center;z-index:9999;padding:24px}
#modal-overlay.open{display:flex}
#modal-box{background:var(--card2);border:1px solid var(--line);border-radius:14px;
  padding:26px 30px 28px;max-width:680px;width:100%;position:relative;
  box-shadow:0 24px 60px rgba(0,0,0,.55);animation:fade .15s ease}
#modal-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.8px;margin:0 0 10px}
#modal-text{color:var(--text);font-size:14px;line-height:1.65;white-space:pre-wrap;
  word-break:break-word;max-height:60vh;overflow-y:auto;margin:0}
#modal-close{position:absolute;top:12px;right:16px;background:none;border:none;
  color:var(--muted);font-size:22px;cursor:pointer;line-height:1;padding:0}
#modal-close:hover{color:var(--text)}

/* expandable cells */
.xcell{cursor:pointer;color:var(--muted)}
.xcell:hover{color:var(--blue)!important;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}
.xhint{font-size:11px;color:var(--blue);margin-left:4px;opacity:.8}
