:root{--primary:#0b86d8;--primary-2:#0a78c7;--bg:#f4f7fb;--surface:#fff;--text:#1f2937;--muted:#6b7280;--border:#e5e7eb;--danger:#dc2626;--ok:#16a34a;--warn:#d97706;--shadow:0 10px 24px rgba(17,24,39,.08);--radius:14px;--sidebar-w:270px;--font:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px}a{text-decoration:none;color:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);height:100vh;position:sticky;top:0;overflow:auto;z-index:20}.main{flex:1;min-width:0}.sb-top{padding:12px}.profile-card{background:linear-gradient(90deg,var(--primary),var(--primary-2));border-radius:14px;padding:12px;color:#fff;display:flex;gap:10px;align-items:center}.avatar{width:36px;height:36px;border-radius:999px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-weight:800}.p-title{font-weight:800}.p-sub{font-size:12px;opacity:.9}.nav{padding:6px 10px 16px}.group-label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding:12px 10px 6px}.nav a{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:12px;border:1px solid transparent;margin:3px 0;font-size:13px}.nav a:hover{background:#f2f7ff;border-color:#dbeafe}.nav a.active{background:#eaf4ff;border-color:#cfe8ff;color:#0a5ea7;font-weight:800}.mi{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center}.topbar{height:58px;background:linear-gradient(90deg,var(--primary),var(--primary-2));color:#fff;display:flex;align-items:center;gap:12px;padding:0 16px;position:sticky;top:0;z-index:10;box-shadow:0 6px 14px rgba(11,134,216,.18)}.topbar small{display:block;color:rgba(255,255,255,.8);font-size:12px}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.hamb{display:none;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:10px;padding:8px 10px}.content{padding:18px}.page-title{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:16px}.page-title h1{margin:0;font-size:22px}.muted{color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}.metric .label{font-size:12px;color:var(--muted);margin-bottom:8px}.metric .value{font-size:22px;font-weight:850}.metric .sub{font-size:12px;color:var(--muted);margin-top:4px}.table-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:auto}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;font-size:13px;vertical-align:top}th{font-size:12px;color:#475569;background:#f8fafc;position:sticky;top:0}.badge{display:inline-flex;padding:4px 8px;border-radius:999px;font-size:12px;border:1px solid var(--border);background:#f8fafc}.badge.ok{color:var(--ok);background:#ecfdf5;border-color:#bbf7d0}.badge.warn{color:var(--warn);background:#fffbeb;border-color:#fde68a}.badge.danger{color:var(--danger);background:#fef2f2;border-color:#fecaca}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:10px;padding:8px 11px;background:#fff;cursor:pointer;font-size:13px;gap:6px}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.ghost{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.24);color:#fff}.btn.full{width:100%}label{font-size:12px;color:#475569;display:block;margin:10px 0 5px}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:10px;padding:9px 10px;font:inherit;background:#fff}.alert{border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:12px;padding:10px;margin:10px 0}.alert.danger{border-color:#fecaca;background:#fef2f2;color:#b91c1c}.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:min(460px,100%);background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px;padding:20px}.brand-mark{width:44px;height:44px;border-radius:14px;background:linear-gradient(90deg,var(--primary),var(--primary-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:24px}.section{margin-top:16px}.filters{display:flex;gap:8px;flex-wrap:wrap;align-items:end;margin-bottom:12px}.filters>*{max-width:220px}@media(max-width:960px){body{font-size:15px}.sidebar{position:fixed;left:-285px;transition:left .18s ease}.sidebar.open{left:0}.hamb{display:inline-flex}.content{padding:14px}.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar-right span{display:none}.page-title{align-items:flex-start;flex-direction:column}.btn,input,select,textarea{min-height:42px;font-size:15px}th,td{font-size:14px;padding:11px}.filters>*{max-width:none;flex:1 1 100%}}@media(max-width:620px){.grid,.grid-2{grid-template-columns:1fr}.metric .value{font-size:24px}.card{padding:13px}.page-title h1{font-size:20px}.table-wrap table{min-width:680px}}
