:root{
  --bg:#eef0f3; --surface:#fff; --surface2:#f5f6f8; --tertiary:#e9ecef;
  --text:#15181d; --muted:#6b7280; --hint:#9aa1ab; --line:rgba(0,0,0,.09);
  --primary:#0f6e56; --primary-soft:#e1f5ee; --green:#0f9d58; --red:#d83a3a;
  --radius:12px;
}
@media (prefers-color-scheme: dark){
  :root{ --bg:#0e1116; --surface:#171b21; --surface2:#1c2128; --tertiary:#232a32;
    --text:#e7eaee; --muted:#9aa3ad; --hint:#6b7480; --line:rgba(255,255,255,.09);
    --primary:#1d9e75; --primary-soft:#0f3b30; --green:#36c77f; --red:#f06a6a; }
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-size:15px}
.hidden{display:none !important}

/* login */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--surface);border:.5px solid var(--line);border-radius:16px;padding:30px 26px;width:100%;max-width:360px;text-align:center}
.login-logo{font-size:22px;font-weight:600;color:var(--primary)}
.login-sub{color:var(--muted);margin:2px 0 20px;font-size:13px}
.login input{width:100%;height:46px;border:1px solid var(--line);background:var(--surface2);color:var(--text);border-radius:10px;padding:0 14px;font-size:16px;margin-bottom:12px}
.login input:focus{outline:none;border-color:var(--primary)}
.login button{width:100%;height:46px;border:none;background:var(--primary);color:#fff;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer}
.login-err{color:var(--red);font-size:13px;min-height:18px;margin:10px 0 0}

/* app */
.topbar{position:sticky;top:0;z-index:5;background:var(--bg);display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:.5px solid var(--line)}
.title{font-size:18px;font-weight:600}
.sub{font-size:12px;color:var(--hint);margin-top:2px}
.actions{display:flex;gap:10px}
.btn-ghost{height:38px;padding:0 14px;border:.5px solid var(--line);background:var(--surface);color:var(--text);border-radius:9px;font-size:14px;cursor:pointer}
.btn-primary{height:38px;padding:0 16px;border:none;background:var(--primary);color:#fff;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}

.wrap{max-width:1080px;margin:0 auto;padding:22px 28px 60px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--surface);border:.5px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.kpi-lbl{font-size:13px;color:var(--muted)}
.kpi-val{font-size:30px;font-weight:700;letter-spacing:-.5px;margin-top:6px}

.card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--radius);overflow:hidden}
.card-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding:16px 18px;border-bottom:.5px solid var(--line);flex-wrap:wrap}
.card-title{font-size:16px;font-weight:600}
.card-sub{font-size:13px;color:var(--hint);margin-top:2px}
.card-tools{display:flex;gap:10px;align-items:center}
.card-tools input{height:38px;width:230px;border:1px solid var(--line);background:var(--surface2);color:var(--text);border-radius:9px;padding:0 12px;font-size:14px}
.card-tools input:focus{outline:none;border-color:var(--primary)}

.tbl-wrap{max-height:60vh;overflow:auto}
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl thead th{position:sticky;top:0;background:var(--surface2);text-align:left;padding:10px 18px;font-weight:600;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.3px;border-bottom:.5px solid var(--line)}
.tbl td{padding:9px 18px;border-bottom:.5px solid var(--line)}
.tbl tbody tr:hover{background:var(--surface2)}
.tbl td.mono{font-variant-numeric:tabular-nums}
.empty{padding:40px;text-align:center;color:var(--hint)}
