:root{
  --navy:#26307a; --navy-d:#1b2360;
  --green:#5bb12f; --green-d:#4a9626;
  --blue:#2b6fdb; --bg:#eaf1fb; --card:#ffffff;
  --ink:#1f2533; --muted:#6f7888; --line:#e4e9f2;
  --ok-bg:#e7f6e3; --ok-fg:#3c7d22;
  --warn-bg:#fdf1d8; --warn-fg:#b07d12;
  --proc-bg:#e2ecfd; --proc-fg:#2459c2;
  --err-bg:#fbe6e2; --err-fg:#c0452f;
  --radius:12px; --shadow:0 1px 3px rgba(30,40,90,.08),0 6px 20px rgba(30,40,90,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.55}
h1,h2,h3,.brand-name{font-family:'Poppins',sans-serif}
button{font-family:inherit;cursor:pointer;border:none}
a{color:inherit;text-decoration:none}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,#eaf1fb 0%,#dfeaf8 100%);padding:24px}
.login-card{background:var(--card);width:100%;max-width:400px;border-radius:16px;box-shadow:var(--shadow);padding:40px 36px;text-align:center}
.login-card img{height:46px;margin-bottom:8px}
.login-sub{color:var(--muted);font-size:13.5px;margin-bottom:28px}
.field{text-align:left;margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:6px}
.field input{width:100%;padding:11px 14px;border:1.5px solid var(--line);border-radius:9px;font-size:14.5px;font-family:inherit;outline:none;transition:.15s}
.field input:focus{border-color:var(--blue)}
.err-msg{background:var(--err-bg);color:var(--err-fg);font-size:13px;padding:9px 12px;border-radius:8px;margin-bottom:16px;text-align:left}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;border-radius:9px;padding:11px 18px;font-size:14.5px;transition:.15s}
.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:var(--green-d)}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line)}.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-block{width:100%}.login-card .btn{margin-top:6px}
.login-foot{margin-top:22px;font-size:12px;color:var(--muted)}

/* App shell */
.app{min-height:100vh;display:grid;grid-template-columns:236px 1fr;grid-template-rows:64px 1fr;grid-template-areas:"side top" "side main"}
.topbar{grid-area:top;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 26px}
.topbar img{height:34px}
.topbar .crumb{color:var(--muted);font-size:13px;margin-left:18px}
.user-chip{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:500}
.user-chip .logout{color:var(--muted);font-size:12.5px;background:none;padding:6px 8px}
.user-chip .logout:hover{color:var(--err-fg)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;font-family:'Poppins'}
.sidebar{grid-area:side;background:var(--navy);color:#fff;padding:20px 14px;display:flex;flex-direction:column}
.sidebar .logo-area{display:flex;align-items:center;gap:9px;padding:4px 10px 22px}
.sidebar .logo-area .dot{width:30px;height:30px;border-radius:8px;background:var(--green);display:flex;align-items:center;justify-content:center;font-family:'Poppins';font-weight:700;color:#fff}
.sidebar .logo-area b{font-family:'Poppins';font-weight:600;font-size:16px;letter-spacing:.3px}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:9px;color:#c7cdf0;font-size:14px;font-weight:500;cursor:pointer;margin-bottom:3px;transition:.15s;border-left:3px solid transparent}
.nav-item svg{width:18px;height:18px;flex:none;stroke:currentColor}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:rgba(91,177,47,.16);color:#fff;border-left-color:var(--green)}
.side-foot{margin-top:auto;padding:12px 14px;font-size:11.5px;color:#8f97cf;line-height:1.5}
.main{grid-area:main;padding:28px 30px;overflow:auto}

.page-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}
.page-head h1{font-size:23px;font-weight:600}.page-head p{color:var(--muted);font-size:13.5px;margin-top:3px}
.toolbar{display:flex;gap:10px;align-items:center}
.search{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);border-radius:9px;padding:8px 12px;font-size:14px;color:var(--muted);min-width:230px}
.search input{border:none;outline:none;font-family:inherit;font-size:14px;width:100%;color:var(--ink)}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.stat{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px}
.stat .lbl{font-size:12.5px;color:var(--muted);font-weight:500}
.stat .val{font-size:27px;font-weight:700;font-family:'Poppins';margin-top:6px}
.stat .val.green{color:var(--green-d)}.stat .val.navy{color:var(--navy)}.stat .val.warn{color:var(--warn-fg)}.stat .val.blue{color:var(--blue)}

table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:600;padding:13px 18px;border-bottom:1px solid var(--line);background:#fafbfe}
tbody td{padding:14px 18px;border-bottom:1px solid var(--line);font-size:14px}
tbody tr:last-child td{border-bottom:none}
tbody tr.click{cursor:pointer;transition:.12s}tbody tr.click:hover{background:#f5f8fe}
.cell-strong{font-weight:600}.cell-sub{font-size:12px;color:var(--muted);margin-top:2px}
.mono{font-variant-numeric:tabular-nums}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:4px 11px;border-radius:20px;white-space:nowrap}
.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.85}
.pill.ok{background:var(--ok-bg);color:var(--ok-fg)}.pill.proc{background:var(--proc-bg);color:var(--proc-fg)}
.pill.warn{background:var(--warn-bg);color:var(--warn-fg)}.pill.err{background:var(--err-bg);color:var(--err-fg)}.pill.idle{background:#eef1f6;color:#6b7280}
.badge-soft{font-size:11.5px;background:#eef1f6;color:#5b6472;padding:2px 8px;border-radius:6px;font-weight:600}
.empty{padding:48px;text-align:center;color:var(--muted);font-size:14px}
@media(max-width:820px){.app{grid-template-columns:1fr;grid-template-areas:"top" "main"}.sidebar{display:none}.stat-row{grid-template-columns:1fr 1fr}}
