:root{--bg:#15213f;--sidebar:#101a33;--card:#1d2c4f;--card-2:#243763;--border:#2f4477;--text:#f3f6fc;--muted:#a6b6d6;--primary:#e11d48;--primary-2:#f43f5e;--green:#22c55e;--amber:#f59e0b;--red:#ef4444;--blue:#60a5fa;--cyan:#38bdf8;--radius:14px;--shadow:0 1px 2px rgba(0,0,0,.25),0 10px 30px rgba(0,0,0,.35);--grad:linear-gradient(160deg,#16233f,#1d2c52 55%,#233a73)}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select{font-family:inherit}.shell{display:flex;min-height:100vh}.sidebar{width:248px;background:var(--grad);border-right:1px solid rgba(225,29,72,.25);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:20}.brand{padding:22px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid hsla(0,0%,100%,.18)}.brand .logo{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:hsla(0,0%,100%,.22);font-size:20px}.brand .name{font-weight:700;font-size:18px;letter-spacing:.3px;color:#fff}.brand .sub{font-size:11px;color:hsla(0,0%,100%,.75)}.nav{padding:12px;overflow-y:auto;flex:1 1}.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:hsla(0,0%,100%,.6);padding:14px 12px 6px}.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:hsla(0,0%,100%,.85);font-size:14px;font-weight:500;margin-bottom:2px;transition:.15s}.nav a:hover{background:hsla(0,0%,100%,.14);color:#fff}.nav a.active{background:var(--primary);color:#fff;font-weight:700;box-shadow:0 6px 16px rgba(225,29,72,.4)}.nav a .ic{width:20px;text-align:center;font-size:16px}.main{margin-left:248px;flex:1 1;min-width:0}.topbar{height:64px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;background:rgba(21,33,63,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.topbar h1{font-size:19px;font-weight:650}.topbar .who{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted)}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:grid;place-items:center;font-weight:700;color:#fff}.content{padding:26px 28px 60px}.grid{display:grid;grid-gap:16px;gap:16px}.cols-5{grid-template-columns:repeat(5,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}@media (max-width:1100px){.cols-4,.cols-5{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:1fr}}@media (max-width:760px){.cols-2,.cols-3,.cols-4,.cols-5{grid-template-columns:1fr}.sidebar{display:none}.main{margin-left:0}}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.card h3{font-size:14px;font-weight:650;margin-bottom:14px}.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden;box-shadow:var(--shadow)}.stat:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad)}.stat .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:20px;margin-bottom:14px}.stat .label{font-size:13px;color:var(--muted)}.stat .value{font-size:27px;font-weight:720;margin-top:2px;letter-spacing:.3px}.stat .sub{font-size:12px;color:var(--muted);margin-top:6px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;padding:12px 14px;white-space:nowrap}td,th{border-bottom:1px solid var(--border)}td{padding:13px 14px;vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--card-2)}.cell-main{font-weight:600}.cell-sub{font-size:12px;color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.b-green{background:rgba(34,197,94,.18);color:#6ee7a0}.b-amber{background:rgba(245,158,11,.18);color:#fcd34d}.b-red{background:rgba(239,68,68,.2);color:#fca5a5}.b-blue{background:rgba(96,165,250,.18);color:#93c5fd}.b-gray{background:rgba(148,163,184,.2);color:#cbd5e1}.b-cyan{background:rgba(56,189,248,.18);color:#7dd3fc}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:9px;border:1px solid var(--border);background:var(--card-2);color:var(--text);font-size:13px;font-weight:600;transition:.15s}.btn-primary,.btn:hover{border-color:var(--primary)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-2)}.btn-sm{padding:5px 10px;font-size:12px}.btn-green{background:rgba(34,197,94,.16);border-color:rgba(34,197,94,.4);color:#6ee7a0}.btn-red{background:rgba(239,68,68,.16);border-color:rgba(239,68,68,.4);color:#fca5a5}.btn-amber{background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.4);color:#fcd34d}.btn-blue{background:rgba(96,165,250,.16);border-color:rgba(96,165,250,.4);color:#93c5fd}.btn-ghost{background:transparent}.btn:disabled{opacity:.5;cursor:default}.actions{gap:6px}.actions,.tabs{display:flex;flex-wrap:wrap}.tabs{gap:4px;background:var(--card);border:1px solid var(--border);padding:4px;border-radius:11px;width:-moz-fit-content;width:fit-content;margin-bottom:18px}.tab{padding:7px 15px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);background:transparent;border:none}.tab.active{background:var(--primary);color:#fff}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-head .ttl{font-size:20px;font-weight:700}.page-head .desc{font-size:13px;color:var(--muted);margin-top:2px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12.5px;color:var(--muted);font-weight:600}.input,.select{width:100%;padding:10px 12px;border-radius:9px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px;outline:none}.input:focus,.select:focus{border-color:var(--primary)}.row{display:flex;gap:12px}.row>*{flex:1 1}.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:grid;place-items:center;z-index:50;padding:20px}.modal{background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:460px;padding:24px}.modal h2{font-size:18px;margin-bottom:4px}.modal .msub{font-size:13px;color:var(--muted);margin-bottom:18px}.modal-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.bars{display:flex;align-items:flex-end;gap:8px;height:150px;padding-top:10px}.bar-col{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}.bar{width:100%;max-width:34px;background:linear-gradient(180deg,var(--primary-2),var(--primary));border-radius:6px 6px 0 0;min-height:4px;transition:.2s}.bar-col:hover .bar{background:linear-gradient(180deg,var(--cyan),var(--primary))}.bar-x{font-size:10.5px;white-space:nowrap}.bar-x,.empty{color:var(--muted)}.empty{text-align:center;padding:40px;font-size:14px}.spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:60px auto}@keyframes spin{to{transform:rotate(1turn)}}.flex{display:flex;align-items:center}.between{justify-content:space-between}.gap{gap:10px}.mt{margin-top:16px}.muted{color:var(--muted)}.right{text-align:right}.pill-cat{display:inline-flex;align-items:center;gap:7px}.legend{display:flex;flex-direction:column;gap:10px}.legend-row{display:flex;align-items:center;justify-content:space-between;font-size:13px}.progress{height:7px;background:var(--card-2);border-radius:6px;overflow:hidden;margin-top:5px}.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--cyan))}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(900px 500px at 20% 10%,rgba(99,102,241,.18),transparent),radial-gradient(700px 500px at 90% 90%,rgba(6,182,212,.12),transparent),var(--bg)}.login-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:18px;padding:34px}.login-card .logo-big{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:28px;background:linear-gradient(135deg,var(--primary),var(--cyan));margin-bottom:18px}.login-card h1{font-size:23px}.login-card p.sub{color:var(--muted);font-size:13.5px;margin:4px 0 22px}.login-card .hint{margin-top:16px;font-size:12px;color:var(--muted);background:var(--card-2);border:1px dashed var(--border);border-radius:10px;padding:11px 13px}.err{color:#f87171;font-size:13px;margin-bottom:12px}