*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4f46e5;--primary-dark:#4338ca;--primary-light:#ede9fe;--success:#059669;--success-dark:#047857;--warning:#d97706;--danger:#dc2626;--danger-dark:#b91c1c;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--text:#0f172a;--muted:#64748b;--sidebar-w:240px;--radius:10px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000a;--shadow-md:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);color:#e2e8f0;z-index:100;background:#0f172a;border-right:1px solid #1e293b;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{color:#fff;letter-spacing:-.3px;border-bottom:1px solid #1e293b;padding:18px 20px 16px;font-size:17px;font-weight:800}.sidebar-logo span{color:#818cf8}.sidebar-logo .logo-sub{color:#475569;letter-spacing:.05em;text-transform:uppercase;margin-top:1px;font-size:10px;font-weight:500}.sidebar-section{padding:16px 12px 4px}.sidebar-section-label{color:#475569;text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px;padding:0 8px;font-size:9px;font-weight:700}.nav-item{cursor:pointer;color:#94a3b8;border-radius:8px;align-items:center;gap:9px;margin-bottom:1px;padding:8px 10px;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item:hover{color:#f1f5f9;background:#1e293b}.nav-item.active{background:var(--primary);color:#fff}.nav-item .nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:15px}.sidebar-footer{border-top:1px solid #1e293b;margin-top:auto;padding:14px 12px}.sidebar-user{margin-bottom:8px;padding:8px 10px}.sidebar-user-name{color:#f1f5f9;font-size:13px;font-weight:600}.sidebar-user-role{color:#f59e0b;margin-top:1px;font-size:11px}.sidebar-user-plain{color:#64748b;margin-top:1px;font-size:11px}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;height:56px;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{color:var(--text);font-size:16px;font-weight:700}.content{flex:1;padding:24px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow .15s,transform .15s}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:11px;font-weight:600}.stat-value{letter-spacing:-.5px;font-size:28px;font-weight:800;line-height:1}.stat-sub{color:var(--muted);margin-top:6px;font-size:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-title{border-bottom:1px solid var(--border);padding:16px 20px;font-size:15px;font-weight:700}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:#f8fafc;padding:10px 16px;font-size:11px;font-weight:700}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 16px}tr:hover td{background:#f8fafc}tr:last-child td{border-bottom:none}.badge{letter-spacing:.02em;border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.badge-green{color:#065f46;background:#d1fae5}.badge-blue{color:#1e40af;background:#dbeafe}.badge-orange{color:#9a3412;background:#fed7aa}.badge-red{color:#991b1b;background:#fee2e2}.badge-gray{color:#475569;background:#f1f5f9}.badge-purple{color:#5b21b6;background:#ede9fe}.badge-teal{color:#0f766e;background:#ccfbf1}.btn{cursor:pointer;white-space:nowrap;letter-spacing:.01em;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#4f46e5 100%);box-shadow:0 2px 4px #4f46e54d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#818cf8 0%,#6366f1 100%);transform:translateY(-1px);box-shadow:0 4px 8px #4f46e566}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-success{color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);box-shadow:0 2px 4px #0596694d}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#34d399 0%,#10b981 100%);transform:translateY(-1px);box-shadow:0 4px 8px #05966966}.btn-danger{color:#fff;background:linear-gradient(135deg,#f43f5e 0%,#dc2626 100%);box-shadow:0 2px 4px #dc26264d}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#fb7185 0%,#f43f5e 100%);transform:translateY(-1px);box-shadow:0 4px 8px #dc262666}.btn-warning{color:#fff;background:linear-gradient(135deg,#fbbf24 0%,#d97706 100%);box-shadow:0 2px 4px #d977064d}.btn-warning:hover:not(:disabled){background:linear-gradient(135deg,#fcd34d 0%,#fbbf24 100%);transform:translateY(-1px)}.btn-outline{background:var(--surface);border:1.5px solid var(--border);color:var(--text);box-shadow:var(--shadow-sm)}.btn-outline:hover:not(:disabled){box-shadow:var(--shadow);background:#f8fafc;border-color:#cbd5e1}.btn-ghost{color:var(--muted);background:0 0;border:none}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-sm{border-radius:6px;padding:5px 11px;font-size:12px}.btn-xs{border-radius:5px;padding:3px 8px;font-size:11px}.btn-lg{padding:11px 22px;font-size:14px}.btn-icon{border-radius:8px;padding:7px}.w-full{width:100%}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none!important;transform:none!important}.form-group{margin-bottom:16px}.form-label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-hint{color:var(--muted);margin-top:4px;font-size:11px}.form-input,.form-select{border:1.5px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;width:100%;padding:9px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4f46e51a}.form-input::placeholder{color:#94a3b8}.filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.pagination{justify-content:flex-end;align-items:center;gap:4px;padding:12px 16px;display:flex}.page-btn{border:1.5px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text);border-radius:7px;padding:6px 11px;font-size:13px;font-weight:500;transition:all .12s}.page-btn:hover:not(:disabled):not(.active){background:var(--bg);border-color:#cbd5e1}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:700}.page-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:460px;max-width:94vw;padding:28px;animation:.15s ease-out modal-in;box-shadow:0 25px 50px -12px #00000040}@keyframes modal-in{0%{opacity:0;transform:translateY(-8px)scale(.98)}to{opacity:1;transform:none}}.modal-title{letter-spacing:-.2px;margin-bottom:22px;font-size:17px;font-weight:800}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:22px;padding-top:16px;display:flex}.chart-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}@media (width<=900px){.chart-grid{grid-template-columns:1fr}}.swal-popup{border-radius:14px!important;font-family:inherit!important;font-size:14px!important;box-shadow:0 25px 50px -12px #00000040!important}.swal-btn-confirm{cursor:pointer;letter-spacing:.01em;align-items:center;gap:6px;display:inline-flex;color:#fff!important;background:linear-gradient(135deg,#6366f1 0%,#4f46e5 100%)!important;border:none!important;border-radius:8px!important;padding:9px 20px!important;font-size:13px!important;font-weight:700!important;transition:all .15s!important;box-shadow:0 2px 4px #4f46e559!important}.swal-btn-confirm:hover{transform:translateY(-1px);background:linear-gradient(135deg,#818cf8 0%,#6366f1 100%)!important}.swal-btn-cancel{cursor:pointer;align-items:center;gap:6px;display:inline-flex;background:var(--surface)!important;color:var(--text)!important;border:1.5px solid var(--border)!important;border-radius:8px!important;padding:9px 20px!important;font-size:13px!important;font-weight:600!important;transition:all .15s!important}.swal-btn-cancel:hover{background:var(--bg)!important}.swal-btn-deny{cursor:pointer;color:#fff!important;background:linear-gradient(135deg,#f43f5e 0%,#dc2626 100%)!important;border:none!important;border-radius:8px!important;padding:9px 20px!important;font-size:13px!important;font-weight:700!important}.text-muted{color:var(--muted)}.loading{color:var(--muted);justify-content:center;align-items:center;gap:10px;padding:56px;display:flex}.loading:before{content:"";border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--muted);padding:56px}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.page-title{color:var(--text);letter-spacing:-.3px;font-size:20px;font-weight:800}.page-sub{color:var(--muted);margin-top:3px;font-size:13px}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}
