:root{
  --bg:#f4f6f9; --panel:#ffffff; --ink:#1f2937; --muted:#6b7280;
  --line:#e5e7eb; --brand:#1d4ed8; --brand-d:#1e40af;
  --green:#067647; --green-bg:#ecfdf3; --amber:#b45309; --amber-bg:#fffaeb;
  --red:#b42318; --red-bg:#fef3f2; --blue:#175cd3; --blue-bg:#eff8ff;
  --grey:#475467; --grey-bg:#f2f4f7;
  --radius:10px; --shadow:0 1px 2px rgba(16,24,40,.06),0 1px 3px rgba(16,24,40,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}

/* top bar */
.topbar{display:flex;align-items:center;gap:18px;background:#0f172a;color:#fff;
  padding:0 20px;height:54px;position:sticky;top:0;z-index:20}
.brand{color:#fff;font-weight:700;font-size:15px;white-space:nowrap}
.brand:hover{text-decoration:none}
.mainnav{display:flex;gap:2px;flex:1;flex-wrap:wrap;overflow:auto}
.mainnav a{color:#cbd5e1;padding:6px 10px;border-radius:7px;font-size:13px;white-space:nowrap}
.mainnav a:hover{background:#1e293b;color:#fff;text-decoration:none}
.mainnav a.active{background:var(--brand);color:#fff}
.userbox{display:flex;align-items:center;gap:12px;white-space:nowrap}
.who{font-size:12px;color:#cbd5e1}
.who em{color:#94a3b8;font-style:normal}

/* layout */
.wrap{max-width:1180px;margin:22px auto;padding:0 20px}
.foot{max-width:1180px;margin:30px auto;padding:14px 20px;color:var(--muted);font-size:12px;border-top:1px solid var(--line)}
h1{font-size:22px;margin:0 0 4px}
h2{font-size:16px;margin:0 0 12px}
.pagehead{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.subtle{color:var(--muted);font-size:13px}

/* panels & grid */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px;margin-bottom:18px}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* stat cards */
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}
.stat .n{font-size:26px;font-weight:700}
.stat .l{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}

/* tables */
table.tbl{width:100%;border-collapse:collapse;background:var(--panel)}
.tbl th,.tbl td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#fafbfc}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:#fcfdff}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}
.scroll{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}

/* pills */
.pill{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}
.pill-green{background:var(--green-bg);color:var(--green)}
.pill-amber{background:var(--amber-bg);color:var(--amber)}
.pill-red{background:var(--red-bg);color:var(--red)}
.pill-blue{background:var(--blue-bg);color:var(--blue)}
.pill-grey{background:var(--grey-bg);color:var(--grey)}

/* buttons */
.btn,.btn-ghost,.btn-danger,.btn-sm{display:inline-block;font-size:13px;font-weight:600;
  padding:8px 14px;border-radius:8px;border:1px solid transparent;cursor:pointer;line-height:1}
.btn{background:var(--brand);color:#fff}
.btn:hover{background:var(--brand-d);text-decoration:none}
.btn-ghost{background:transparent;border-color:#475569;color:#e2e8f0}
.btn-ghost:hover{background:#1e293b;text-decoration:none}
.btn-danger{background:var(--red);color:#fff}
.btn-sm{padding:5px 10px;font-size:12px;background:#fff;border-color:var(--line);color:var(--ink)}
.btn-sm:hover{background:#f8fafc;text-decoration:none}
.actions{display:flex;gap:8px;flex-wrap:wrap}

/* forms */
form .row{margin-bottom:14px}
label{display:block;font-weight:600;font-size:13px;margin-bottom:5px}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=url],select,textarea{
  width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(29,78,216,.12)}
textarea{min-height:90px;resize:vertical;font-family:inherit}
.hint{color:var(--muted);font-size:12px;margin-top:4px}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
@media(max-width:680px){.formgrid{grid-template-columns:1fr}}
.checkline{display:flex;align-items:center;gap:8px}
.checkline input{width:auto}

/* flash */
.flash{padding:11px 14px;border-radius:8px;margin-bottom:16px;font-weight:500;border:1px solid}
.flash-ok{background:var(--green-bg);color:var(--green);border-color:#abefc6}
.flash-err{background:var(--red-bg);color:var(--red);border-color:#fecdca}
.flash-warn{background:var(--amber-bg);color:var(--amber);border-color:#fedf89}

/* login */
.login-wrap{max-width:380px;margin:8vh auto;padding:0 20px}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:28px}
.login-card h1{font-size:20px;text-align:center;margin-bottom:18px}

/* misc */
.kv{display:grid;grid-template-columns:160px 1fr;gap:6px 14px;font-size:14px}
.kv dt{color:var(--muted)}
.kv dd{margin:0}
.tag{font-size:11px;color:var(--muted);border:1px solid var(--line);border-radius:6px;padding:1px 6px}
.section-title{display:flex;justify-content:space-between;align-items:center;margin:0 0 12px}
.empty{padding:24px;text-align:center;color:var(--muted)}
