:root{
  --bg:#0f1419; --panel:#1a2129; --panel2:#222c36; --line:#2c3845;
  --txt:#e6edf3; --muted:#8b9aa7; --accent:#3fb950; --accent2:#58a6ff;
  --warn:#e3b341; --bad:#f85149; --good:#3fb950;
  --radius:12px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font:14px/1.45 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:var(--accent2);text-decoration:none}
button{cursor:pointer;font:inherit}

/* ---- top bar ---- */
.topbar{display:flex;align-items:center;gap:24px;padding:0 20px;height:56px;
  background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:baseline;gap:9px;white-space:nowrap}
.brand .wm{font-family:Georgia,"Times New Roman",Times,serif;font-weight:700;
  font-size:21px;letter-spacing:.01em;color:#fff;text-transform:uppercase;line-height:1}
.brand .reg{font-family:Georgia,serif;font-size:9px;color:var(--muted);
  align-self:flex-start;margin-left:-7px}
.brand .dept{color:var(--accent);font-weight:600;font-size:12px;text-transform:uppercase;
  letter-spacing:.14em;padding-left:9px;border-left:1px solid var(--line)}
.brand.big{justify-content:center;gap:7px}
.brand.big .wm{font-size:29px;letter-spacing:.01em}
.brand.big .reg{font-size:11px;margin-left:-7px}
.brand.big .dept{font-size:11px;letter-spacing:.16em;padding-left:7px}
.mainnav{display:flex;gap:6px;flex:1}
.mainnav a{padding:8px 14px;border-radius:8px;color:var(--muted);font-weight:500}
.mainnav a:hover{background:var(--panel2);color:var(--txt)}
.mainnav a.active{background:var(--panel2);color:var(--txt)}
.userbox{display:flex;align-items:center;gap:14px}
.userbox .who{color:var(--muted);font-size:13px}
.userbox .who em{color:var(--accent)}
.userbox .logout{color:var(--muted)}
#refreshBtn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  padding:6px 12px;border-radius:8px}
#refreshBtn:hover{border-color:var(--accent)}
#refreshBtn.spin{opacity:.6;pointer-events:none}

/* ---- filter bar ---- */
.filterbar{display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:12px 20px;background:var(--panel);border-bottom:1px solid var(--line)}
.filterbar label{display:flex;flex-direction:column;font-size:11px;color:var(--muted);gap:3px}
.filterbar input,.filterbar select{background:var(--bg);border:1px solid var(--line);
  color:var(--txt);padding:6px 8px;border-radius:7px;font-size:13px}
.quick{display:flex;gap:4px}
.quick button{background:var(--panel2);border:1px solid var(--line);color:var(--muted);
  padding:6px 10px;border-radius:7px}
.quick button.on{background:var(--accent);color:#08160c;border-color:var(--accent);font-weight:600}
.datanote{margin-left:auto;color:var(--muted);font-size:12px}

/* ---- content ---- */
.content{padding:22px;max-width:1500px;margin:0 auto}
h1{font-size:20px;margin:0 0 4px}
h2{font-size:15px;margin:26px 0 10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.sub{color:var(--muted)}

/* ---- KPI cards ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:14px 0}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.kpi .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.kpi .val{font-size:26px;font-weight:700;margin-top:6px}
.kpi .sub{font-size:12px;margin-top:4px}
.kpi.good .val{color:var(--good)} .kpi.warn .val{color:var(--warn)} .kpi.bad .val{color:var(--bad)}
.delta{display:inline-block;font-size:12px;font-weight:600;margin-left:6px}
.delta.up{color:var(--good)} .delta.down{color:var(--bad)} .delta.flat{color:var(--muted)}
.kpi .cmp{font-size:11px;color:var(--muted);margin-top:3px}
.chartbox.tall{height:340px}
.chartbox.short{height:240px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
@media(max-width:1100px){.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.grid3{grid-template-columns:1fr}}

/* ---- panels & charts ---- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;margin-bottom:18px}
.panel h3{margin:0 0 12px;font-size:14px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.chartbox{position:relative;height:300px}
@media(max-width:900px){.grid2{grid-template-columns:1fr}}

/* ---- tables ---- */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:right;padding:8px 10px;border-bottom:1px solid var(--line);white-space:nowrap}
th:first-child,td:first-child{text-align:left}
th{color:var(--muted);font-weight:600;cursor:pointer;user-select:none;position:sticky;top:0;background:var(--panel)}
tbody tr:hover{background:var(--panel2)}
tr.clickable{cursor:pointer}
.tablewrap{max-height:560px;overflow:auto;border:1px solid var(--line);border-radius:var(--radius)}
.pill{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600}
.pill.Star{background:#1f3a24;color:#7ee787}
.pill.Opportunity{background:#3a331f;color:#e3b341}
.pill.Workhorse,.pill.Plowhorse{background:#1f2d3a;color:#79c0ff}
.pill.Dog,.pill.Puzzle{background:#3a1f23;color:#ff7b72}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.toolbar select,.toolbar input{background:var(--bg);border:1px solid var(--line);color:var(--txt);
  padding:6px 8px;border-radius:7px}
.muted{color:var(--muted)}
.right{text-align:right}
.pos{color:var(--good)} .neg{color:var(--bad)}

/* ---- flash ---- */
.flashwrap{padding:10px 20px}
.flash{padding:10px 14px;border-radius:8px;margin-bottom:8px}
.flash.error{background:#3a1f23;color:#ff7b72;border:1px solid #5a2a30}
.flash.ok{background:#1f3a24;color:#7ee787;border:1px solid #2a5a32}

/* ---- login ---- */
.loginpage{display:flex;align-items:center;justify-content:center;height:100vh}
.loginbox{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  padding:34px;width:340px;display:flex;flex-direction:column;gap:14px}
.loginbox .sub{margin:0 0 8px}
.loginbox label{display:flex;flex-direction:column;font-size:12px;color:var(--muted);gap:5px}
.loginbox input{background:var(--bg);border:1px solid var(--line);color:var(--txt);
  padding:10px;border-radius:8px;font-size:14px}
.loginbox button{background:var(--accent);color:#08160c;border:0;padding:11px;
  border-radius:8px;font-weight:700;font-size:14px}

/* ---- admin ---- */
.formrow{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:16px}
.formrow label{display:flex;flex-direction:column;font-size:12px;color:var(--muted);gap:4px}
.formrow input,.formrow select{background:var(--bg);border:1px solid var(--line);color:var(--txt);
  padding:8px;border-radius:7px}
.btn{background:var(--accent);color:#08160c;border:0;padding:9px 16px;border-radius:8px;font-weight:600}
.btn.danger{background:var(--bad);color:#fff}
.btn.ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
.loading{color:var(--muted);padding:20px;text-align:center}
.crumb{color:var(--muted);margin-bottom:10px}
.crumb a{cursor:pointer}

/* item manager */
#itemsTable input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}
#itemsTable .catinput{background:var(--bg);border:1px solid var(--line);color:var(--txt);padding:5px 7px;border-radius:6px}
tr.nonsales td{opacity:.5}
tr.nonsales td:first-child{text-decoration:line-through}
tr.saved{outline:1px solid var(--accent)}
.unitpill{display:inline-block;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:600;
  background:var(--panel2);color:var(--txt);border:1px solid var(--line)}

/* drill-down affordance + active-filter chips */
canvas{cursor:pointer}
.drillchip{display:inline-flex;align-items:center;gap:6px;background:var(--panel2);
  border:1px solid var(--accent);color:var(--txt);border-radius:99px;padding:3px 10px;font-size:12px;margin-left:8px}
.drillchip button{background:none;border:0;color:var(--muted);cursor:pointer;font-size:13px;line-height:1}

/* customize mode */
#customizeBtn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);padding:6px 12px;border-radius:8px}
#customizeBtn:hover{border-color:var(--accent)}
body.customizing .panel,body.customizing .grid2,body.customizing .grid3,body.customizing .kpis{
  position:relative;outline:1px dashed var(--accent2);outline-offset:3px}
.sectbar{position:absolute;top:6px;right:6px;z-index:40;display:flex;gap:3px;align-items:center;
  background:var(--panel2);border:1px solid var(--line);border-radius:7px;padding:3px 5px}
.sectbar .t{color:var(--muted);font-size:11px;margin-right:4px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sectbar button{background:transparent;border:0;color:var(--muted);padding:2px 6px;border-radius:5px;font-size:12px;cursor:pointer}
.sectbar button:hover{color:var(--txt);background:var(--bg)}
.hidden-section{display:none !important}
.custombar{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:60;
  background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 16px;
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;max-width:92vw;
  box-shadow:0 6px 24px rgba(0,0,0,.45)}
.custombar .chip{background:var(--panel2);border:1px solid var(--line);border-radius:99px;
  padding:4px 10px;cursor:pointer;font-size:12px}
.custombar .chip:hover{border-color:var(--accent)}

/* export buttons */
#exportXlsx,#exportPdf{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  padding:6px 12px;border-radius:8px}
#exportXlsx:hover,#exportPdf:hover{border-color:var(--accent)}

/* print header (screen-hidden) */
#printHeader{display:none}
#printHeader .ph-brand{font-family:Georgia,"Times New Roman",serif;font-weight:700;font-size:22px;text-transform:uppercase}
#printHeader .ph-brand span{color:#2a7d3a;text-transform:uppercase;font-size:13px;letter-spacing:.12em}
#printHeader .ph-title{font-size:18px;font-weight:700;margin-top:2px}
#printHeader .ph-meta{font-size:12px;color:#555;margin:2px 0 8px}

/* ---- print / PDF ---- */
@media print{
  @page{ margin:14mm; }
  body{background:#fff;color:#000}
  .topbar,.filterbar,#customTray,.sectbar,.toolbar{display:none !important}
  #customizeBtn,#refreshBtn,#exportXlsx,#exportPdf,.userbox,.mainnav,.quick{display:none !important}
  #printHeader{display:block;border-bottom:2px solid #2a7d3a;margin-bottom:14px}
  .content{padding:0;max-width:none}
  .panel,.kpi{background:#fff !important;border:1px solid #ccc !important;break-inside:avoid;box-shadow:none}
  .grid2,.grid3{display:grid}
  h1,h2,h3,.sub,.muted,td,th,.kpi .val,.kpi .label,.kpi .cmp{color:#000 !important}
  th{background:#eee !important}
  table,th,td{border-color:#ccc !important}
  .tablewrap{max-height:none !important;overflow:visible !important;border:0}
  .chartbox{height:280px !important}
  a{color:#000 !important;text-decoration:none}
  .hidden-section{display:none !important}
}
