/* BureauLens — dense ERP UI. Black/white/gray only; status colors fixed. */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  --ink: #111;
  --bg: #fff;
  --gray-1: #f4f4f4;
  --gray-2: #e6e6e6;
  --gray-3: #bdbdbd;
  --gray-4: #6b6b6b;
  --head: #1a1a1a;
  --green: #1b8a2a;
  --amber: #c77d00;
  --red: #c62828;
}
* { box-sizing: border-box; margin: 0; padding: 0; border-radius: 0 !important; }
html, body { height: 100%; }
body {
  font-family: 'IBM Plex Sans', Arial, sans-serif;
  font-size: 13px; color: var(--ink); background: var(--bg);
}
.num, .mono { font-family: 'JetBrains Mono', Consolas, monospace; font-size: 12.5px; }
.neg { color: var(--red); }

/* ---- topbar / nav ---- */
.topbar {
  background: var(--head); color: #fff; display: flex; align-items: center;
  height: 44px; padding: 0 14px; gap: 18px;
}
.topbar .brand { font-weight: 700; letter-spacing: .5px; font-size: 15px; }
.topbar .brand span { color: var(--gray-3); font-weight: 400; }
.topbar nav { display: flex; gap: 2px; flex: 1; }
.topbar nav a {
  color: #ddd; text-decoration: none; padding: 6px 11px; font-size: 12.5px;
  border-bottom: 2px solid transparent;
}
.topbar nav a:hover { background: #2c2c2c; color: #fff; }
.topbar nav a.active { color: #fff; border-bottom-color: #fff; background: #2c2c2c; }
.topbar .who { color: var(--gray-3); font-size: 12px; }
.topbar .who b { color: #fff; }
.topbar .who a { color: #fff; margin-left: 10px; text-decoration: underline; }

.wrap { padding: 14px 16px 60px; max-width: 1500px; margin: 0 auto; }

h1 { font-size: 17px; font-weight: 700; margin-bottom: 4px; }
h2 { font-size: 14px; font-weight: 600; margin: 16px 0 6px; }
.sub { color: var(--gray-4); font-size: 12px; margin-bottom: 12px; }

/* ---- flash ---- */
.flash { padding: 7px 12px; margin-bottom: 10px; border-left: 4px solid; font-size: 12.5px; }
.flash.ok   { border-color: var(--green); background: #eef7ef; color: #14541c; }
.flash.warn { border-color: var(--amber); background: #fbf3e4; color: #7a4d00; }
.flash.err  { border-color: var(--red);   background: #fbecec; color: #7c1a1a; }

/* ---- KPI strip ---- */
.kpis { display: flex; gap: 1px; background: var(--gray-2); border: 1px solid var(--gray-2); margin-bottom: 14px; flex-wrap: wrap; }
.kpi { background: #fff; padding: 10px 16px; flex: 1; min-width: 170px; }
.kpi .k { font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--gray-4); }
.kpi .v { font-family: 'JetBrains Mono', monospace; font-size: 18px; font-weight: 700; margin-top: 2px; }
.kpi .v.green { color: var(--green); } .kpi .v.amber { color: var(--amber); } .kpi .v.red { color: var(--red); }
.kpi .s { font-size: 11px; color: var(--gray-4); margin-top: 2px; }

/* ---- tables ---- */
table.grid { width: 100%; border-collapse: collapse; background: #fff; margin-bottom: 14px; }
table.grid th {
  background: var(--head); color: #fff; text-align: left; font-weight: 600;
  font-size: 11.5px; padding: 7px 9px; white-space: nowrap; border: 1px solid #000;
}
table.grid th.r, table.grid td.r { text-align: right; }
table.grid td {
  padding: 5px 9px; border: 1px solid var(--gray-2); vertical-align: middle; font-size: 12.5px;
}
table.grid tbody tr:nth-child(even) { background: var(--gray-1); }
table.grid tbody tr:hover { background: #eee; }
table.grid td.r .num, table.grid td.r { font-family: 'JetBrains Mono', monospace; }
table.grid tfoot td { font-weight: 700; background: var(--gray-2); border-top: 2px solid var(--head); }
table.grid a { color: #000; }
.grid-scroll { overflow-x: auto; }

/* ---- status badges ---- */
.badge { display: inline-block; padding: 1px 7px; font-size: 11px; font-weight: 600; border: 1px solid; }
.badge.green { color: var(--green); border-color: var(--green); }
.badge.amber { color: var(--amber); border-color: var(--amber); }
.badge.red   { color: var(--red);   border-color: var(--red); }
.badge.gray  { color: var(--gray-4); border-color: var(--gray-3); }

/* ---- buttons ---- */
.btn {
  display: inline-block; font-family: 'IBM Plex Sans', sans-serif; font-size: 12.5px; font-weight: 600;
  padding: 6px 14px; cursor: pointer; text-decoration: none; border: 1px solid #000; line-height: 1.3;
}
.btn.primary { background: #000; color: #fff; }
.btn.primary:hover { background: #2a2a2a; }
.btn.secondary { background: #fff; color: #000; }
.btn.secondary:hover { background: var(--gray-1); }
.btn.danger { background: var(--red); border-color: var(--red); color: #fff; }
.btn.danger:hover { background: #a82121; }
.btn.sm { padding: 3px 9px; font-size: 11.5px; }

/* ---- forms ---- */
form.inline { display: inline; }
.filterbar { display: flex; gap: 8px; align-items: flex-end; flex-wrap: wrap; margin-bottom: 12px; }
.filterbar .fld { display: flex; flex-direction: column; gap: 2px; }
label { font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--gray-4); font-weight: 600; }
input[type=text], input[type=email], input[type=password], input[type=date], input[type=number], select, textarea {
  font-family: 'IBM Plex Sans', sans-serif; font-size: 13px; padding: 6px 8px;
  border: 1px solid var(--gray-3); background: #fff; min-width: 130px;
}
input.num-in { font-family: 'JetBrains Mono', monospace; text-align: right; }
input:focus, select:focus, textarea:focus { outline: 2px solid #000; outline-offset: -1px; }
.formgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px 14px; max-width: 1000px; margin-bottom: 14px; }
.formgrid .fld { display: flex; flex-direction: column; gap: 3px; }
.panel { border: 1px solid var(--gray-2); padding: 14px; background: #fff; margin-bottom: 16px; }
.panel h2 { margin-top: 0; }

.actions { display: flex; gap: 8px; margin-top: 6px; }
.right { text-align: right; }
.muted { color: var(--gray-4); }
.small { font-size: 11.5px; }
hr.sep { border: 0; border-top: 1px solid var(--gray-2); margin: 14px 0; }

/* ---- login ---- */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--gray-1); }
.login-box { background: #fff; border: 1px solid var(--head); width: 360px; padding: 26px; }
.login-box h1 { font-size: 20px; }
.login-box .tag { color: var(--gray-4); font-size: 12px; margin-bottom: 18px; }
.login-box .fld { margin-bottom: 12px; display: flex; flex-direction: column; gap: 4px; }
.login-box input { width: 100%; }
.login-box .btn { width: 100%; text-align: center; }

@media print {
  .topbar, .filterbar, .btn, .actions { display: none !important; }
}


/* dense single-line rows */
.grid th, .grid td { white-space: nowrap; }
.grid td.trunc { max-width: 320px; overflow: hidden; text-overflow: ellipsis; }

/* topbar denomination selector */
.denom-sel { background:#1a1a1a; color:#fff; border:1px solid #555; padding:3px 6px;
  font-family:"JetBrains Mono",Consolas,monospace; font-size:12px; margin-right:14px; }
.denom-sel:hover { border-color:#fff; }
