/* BillingLens — UI (black/white/gray, dense ERP) */
:root{
  --ink:#000;                      /* all text: black only */
  --royal:#2b50b4;                 /* royal blue — chrome (headers/buttons/topbar) */
  --royal-dark:#1e3c8f;
  --bg:#e8eefb;                    /* soft royal-blue tint page background, easy on the eyes */
  --paper:#fff; --gray-1:#f2f5fd; --gray-2:#d9e1f2; --gray-3:#b7c3e0; --gray-4:#5d6b8c; --gray-5:#333;
  --green:#1b8a2a; --amber:#c77d00; --red:#c62828;
  --mono:'JetBrains Mono',monospace; --sans:'IBM Plex Sans',sans-serif;
  --sidebar-w:216px; --topbar-h:44px;
}
*{margin:0;padding:0;box-sizing:border-box;border-radius:0!important}
html{font-size:13px}
body{font-family:var(--sans);color:var(--ink);background:var(--bg)}
a{color:var(--ink)}
.num{font-family:var(--mono);text-align:right;white-space:nowrap}
.neg{color:var(--red)} .pos{color:var(--green)} .amb{color:var(--amber)}

.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:var(--royal);color:#fff;display:flex;align-items:center;gap:10px;padding:0 12px;z-index:50}
.topbar .brand{font-weight:700;letter-spacing:.5px;font-size:14px;color:#fff;text-decoration:none}
.topbar .brand span{font-weight:400;color:#cfdaf5}
.hamburger{background:none;border:1px solid rgba(255,255,255,.5);color:#fff;width:30px;height:30px;font-size:15px;cursor:pointer;display:none}
.co-switch{margin-left:auto;display:flex;align-items:center;gap:8px}
.co-switch select{background:var(--royal-dark);color:#fff;border:1px solid rgba(255,255,255,.5);padding:4px 8px;font-family:var(--sans);font-size:12px;max-width:260px}
.userchip{border:1px solid rgba(255,255,255,.5);padding:3px 10px;font-size:12px;color:#fff;text-decoration:none;white-space:nowrap}
.env-tag{font-family:var(--mono);font-size:10px;border:1px solid rgba(255,255,255,.6);color:#fff;padding:2px 6px}

.sidebar{position:fixed;top:var(--topbar-h);left:0;bottom:0;width:var(--sidebar-w);background:#fff;border-right:1px solid var(--gray-2);overflow-y:auto;z-index:40}
.sidebar .grp{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--gray-4);padding:12px 14px 4px;font-weight:600}
.sidebar a.nav{display:block;padding:6px 14px;font-size:12.5px;text-decoration:none;border-left:3px solid transparent}
.sidebar a.nav:hover{background:var(--gray-1)}
.sidebar a.nav.active{border-left-color:var(--royal);background:var(--gray-1);font-weight:600}

.main{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);padding:14px;min-height:calc(100vh - var(--topbar-h))}
.flash{padding:8px 12px;margin-bottom:10px;border:1px solid;font-weight:600;font-size:12.5px}
.flash.ok{border-color:var(--green);color:var(--green);background:#fff}
.flash.err{border-color:var(--red);color:var(--red);background:#fff}

.pagehead{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.pagehead form{display:contents}
.pagehead h1{font-size:16px;font-weight:700}
.pagehead .crumb{font-size:11px;color:var(--gray-4)}
.pagehead .spacer{flex:1}

.btn{font-family:var(--sans);font-size:12px;font-weight:600;padding:0 14px;height:30px;line-height:28px;cursor:pointer;border:1px solid var(--royal);background:var(--royal);color:#fff;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;box-sizing:border-box}
.btn.sec{background:#fff;color:var(--ink);border-color:var(--royal)}
.btn.danger{background:var(--red);border-color:var(--red);color:#fff}
.btn.sm{height:24px;line-height:22px;padding:0 8px;font-size:11px}
.btn:disabled{opacity:.45;cursor:not-allowed}

.panel{background:#fff;border:1px solid var(--gray-2);margin-bottom:12px}
.panel .ph{padding:8px 12px;border-bottom:1px solid var(--gray-2);font-size:12px;font-weight:700;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.panel .pb{padding:12px}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:12px}
.kpi{background:#fff;border:1px solid var(--gray-2);padding:10px 12px}
.kpi .l{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--gray-4);font-weight:600}
.kpi .v{font-family:var(--mono);font-size:19px;font-weight:700;margin-top:3px}
.kpi .s{font-size:11px;color:var(--gray-5);margin-top:2px}

.fbar{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;background:#fff;border:1px solid var(--gray-2);padding:10px 12px;margin-bottom:10px}
.fld{display:flex;flex-direction:column;gap:3px}
.fld input,.fld select,.fld textarea{margin-top:auto}
.fld label{font-size:10.5px;font-weight:600;color:var(--gray-5);text-transform:uppercase;letter-spacing:.4px}
.fld input,.fld select,.fld textarea{font-family:var(--sans);font-size:12.5px;padding:5px 8px;border:1px solid var(--gray-3);background:#fff;min-width:110px}
.fld input.mono,.fld input[type=date],.fld input[type=time]{font-family:var(--mono)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:2px solid var(--royal);outline-offset:-1px}
.fld input[readonly]{background:var(--gray-1);color:var(--gray-5)}

.twrap{overflow-x:auto;background:#fff;border:1px solid var(--gray-2)}
table.grid{width:100%;border-collapse:collapse;font-size:12.5px}
table.grid th{background:var(--royal);color:#fff;text-align:left;font-weight:600;padding:7px 10px;font-size:11.5px;white-space:nowrap}
table.grid th.r{text-align:right}
table.grid td{padding:6px 10px;border-bottom:1px solid var(--gray-2);vertical-align:middle}
table.grid tbody tr:nth-child(even){background:var(--gray-1)}
table.grid tbody tr:hover{background:var(--gray-2)}
table.grid td.r{font-family:var(--mono);text-align:right;white-space:nowrap}
table.grid td.mono{font-family:var(--mono)}
table.grid tfoot td{font-weight:700;background:var(--gray-2);border-top:2px solid var(--royal);font-family:var(--mono)}
table.grid tfoot td:first-child{font-family:var(--sans)}
.badge{display:inline-block;font-size:10.5px;font-weight:700;padding:1px 7px;border:1px solid;white-space:nowrap}
.badge.g{color:var(--green);border-color:var(--green)}
.badge.a{color:var(--amber);border-color:var(--amber)}
.badge.r{color:var(--red);border-color:var(--red)}
.badge.k{color:var(--gray-5);border-color:var(--gray-3)}
.rowact a{font-size:11px;margin-right:8px;text-decoration:underline;cursor:pointer}
.rowact a.del{color:var(--red)}

.formgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}
.itemgrid td{padding:3px 6px}
.itemgrid input,.itemgrid select{width:100%;font-size:12.5px;padding:4px 6px;border:1px solid var(--gray-3);font-family:var(--sans);background:#fff}
.itemgrid input.num{font-family:var(--mono);text-align:right}
.itemgrid input[readonly]{background:var(--gray-1);color:var(--gray-5)}
.gridfoot{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start}
.totbox{margin-left:auto;width:280px;max-width:100%;font-size:12.5px}
.totbox .tr{display:flex;justify-content:space-between;padding:4px 10px;border-bottom:1px solid var(--gray-2)}
.totbox .tr .v{font-family:var(--mono)}
.totbox .tr.grand{background:var(--royal);color:#fff;font-weight:700;font-size:14px}
.pager{display:flex;gap:6px;align-items:center;justify-content:flex-end;padding:8px 0;font-size:11.5px;color:var(--gray-5)}
.pager a{border:1px solid var(--gray-3);background:#fff;padding:3px 9px;font-family:var(--mono);text-decoration:none}
.help{font-size:11px;color:var(--gray-4);margin-top:4px}

.loginwrap{max-width:360px;margin:60px auto;background:#fff;border:1px solid var(--gray-2)}
.loginwrap .lh{background:var(--royal);color:#fff;padding:14px 16px;font-weight:700;letter-spacing:.5px}
.loginwrap .lb{padding:18px 16px;display:flex;flex-direction:column;gap:12px}

.rpthub{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}
.rptcard{background:#fff;border:1px solid var(--gray-2);padding:12px;text-decoration:none;display:block}
.rptcard:hover{outline:2px solid var(--royal);outline-offset:-2px}
.rptcard .rt{font-weight:700;font-size:13px}
.rptcard .rd{font-size:11.5px;color:var(--gray-5);margin-top:3px}
.rptcard .rg{font-family:var(--mono);font-size:10px;color:var(--gray-4);text-transform:uppercase;margin-bottom:4px}

@media (max-width:820px){
  .hamburger{display:block}
  .sidebar{transform:translateX(-100%);transition:transform .15s;width:240px}
  .sidebar.open{transform:none}
  .main{margin-left:0;padding:10px}
  .totbox{width:100%}
  .env-tag{display:none}
  .userchip{display:none}
  html{font-size:12.5px}
}
.scrim{display:none;position:fixed;inset:44px 0 0 0;background:rgba(0,0,0,.35);z-index:35}
.scrim.on{display:block}

/* uniform inline inputs inside data tables */
table.grid input.cellin,table.grid select.cellin{border:1px solid var(--gray-3);padding:4px 6px;height:26px;box-sizing:border-box;font-family:var(--sans);font-size:12.5px;background:#fff;width:100%}
table.grid input.cellin.num{font-family:var(--mono);text-align:right}
table.grid td.cell-r{text-align:right}
