:root{--c-bg:#f1f5f9;--c-surface:#fff;--c-border:#e2e8f0;--c-text:#0f172a;--c-muted:#64748b;--c-primary:#2563eb;--c-primary-dark:#1d4ed8;--c-primary-soft:#dbeafe;--c-success:#16a34a;--c-success-soft:#dcfce7;--c-warning:#d97706;--c-warning-soft:#fef3c7;--c-danger:#dc2626;--c-danger-soft:#fee2e2;--c-info:#0891b2;--c-info-soft:#cffafe;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #0f172a14, 0 1px 2px #0f172a0a;--shadow-lg:0 10px 30px #0f172a1f;--sidebar-w:248px;--font:"Inter", "Segoe UI", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}h1,h2,h3,h4{font-weight:650;line-height:1.25}.btn{border-radius:var(--radius-sm);white-space:nowrap;background:var(--c-surface);color:var(--c-text);border:1px solid #0000;border-color:var(--c-border);justify-content:center;align-items:center;gap:8px;padding:9px 16px;font-size:13.5px;font-weight:550;transition:all .15s;display:inline-flex}.btn:hover{background:#f8fafc}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.btn-primary:hover{background:var(--c-primary-dark)}.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}.btn-danger:hover{filter:brightness(.93)}.btn-success{background:var(--c-success);color:#fff;border-color:var(--c-success)}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:#f1f5f9}.btn-sm{padding:6px 11px;font-size:12.5px}.btn-block{width:100%}.field{margin-bottom:16px}.field label{color:#334155;margin-bottom:6px;font-size:13px;font-weight:550;display:block}.field .req{color:var(--c-danger)}.input,.select,.textarea{border:1px solid var(--c-border);border-radius:var(--radius-sm);width:100%;color:var(--c-text);background:#fff;padding:10px 12px;font-family:inherit;font-size:14px;transition:border .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-soft);outline:none}.textarea{resize:vertical;min-height:80px}.field-error{color:var(--c-danger);margin-top:4px;font-size:12px}.form-grid{grid-template-columns:repeat(2,1fr);gap:0 18px;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr}}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:20px}.card-header{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.card-header h3{font-size:15px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.stat{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:6px;padding:18px;display:flex}.stat .stat-label{color:var(--c-muted);text-transform:uppercase;letter-spacing:.03em;font-size:12.5px;font-weight:550}.stat .stat-value{font-size:28px;font-weight:700}.stat .stat-icon{background:var(--c-primary-soft);width:40px;height:40px;color:var(--c-primary);border-radius:10px;place-items:center;margin-bottom:4px;font-size:20px;display:grid}.table-wrap{overflow-x:auto}table.data{border-collapse:collapse;width:100%;font-size:13.5px}table.data th{text-align:left;color:var(--c-muted);border-bottom:1px solid var(--c-border);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;background:#f8fafc;padding:11px 14px;font-size:12px;font-weight:600}table.data td{border-bottom:1px solid var(--c-border);vertical-align:middle;padding:11px 14px}table.data tbody tr:hover{background:#f8fafc}table.data tbody tr:last-child td{border-bottom:none}.table-empty{text-align:center;color:var(--c-muted);padding:40px}.badge{border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge.gray{color:#475569;background:#f1f5f9}.badge.blue{background:var(--c-primary-soft);color:var(--c-primary-dark)}.badge.green{background:var(--c-success-soft);color:var(--c-success)}.badge.amber{background:var(--c-warning-soft);color:var(--c-warning)}.badge.red{background:var(--c-danger-soft);color:var(--c-danger)}.badge.cyan{background:var(--c-info-soft);color:var(--c-info)}.toast-container{z-index:9999;flex-direction:column;gap:10px;display:flex;position:fixed;top:18px;right:18px}.toast{border-radius:var(--radius-sm);color:#fff;min-width:280px;max-width:380px;box-shadow:var(--shadow-lg);align-items:flex-start;gap:10px;padding:13px 16px;font-size:13.5px;animation:.2s slideIn;display:flex}.toast.success{background:var(--c-success)}.toast.error{background:var(--c-danger)}.toast.warning{background:var(--c-warning)}.toast.info{background:var(--c-primary)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.modal-backdrop{z-index:1000;background:#0f172a80;justify-content:center;align-items:flex-start;padding:40px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{border-radius:var(--radius);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:560px;margin:auto 0;animation:.2s slideIn}.modal.lg{max-width:820px}.modal-header{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-body{padding:22px}.modal-footer{border-top:1px solid var(--c-border);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);color:#cbd5e1;z-index:50;background:#0f172a;flex-direction:column;flex-shrink:0;display:flex;position:fixed;inset:0 auto 0 0}.sidebar .brand{color:#fff;border-bottom:1px solid #1e293b;align-items:center;gap:10px;padding:20px 22px;font-size:17px;font-weight:700;display:flex}.sidebar .brand .logo{background:var(--c-primary);border-radius:8px;place-items:center;width:30px;height:30px;font-size:16px;display:grid}.sidebar nav{scrollbar-width:thin;scrollbar-color:#334155 transparent;flex:1;padding:12px;overflow-y:auto}.sidebar nav::-webkit-scrollbar{width:8px}.sidebar nav::-webkit-scrollbar-track{background:0 0}.sidebar nav::-webkit-scrollbar-thumb{background:linear-gradient(#334155,#1e293b) padding-box padding-box;border:2px solid #0f172a;border-radius:999px}.sidebar nav::-webkit-scrollbar-thumb:hover{background:var(--c-primary);background-clip:padding-box;border:2px solid #0f172a}.sidebar .nav-section{text-transform:uppercase;letter-spacing:.05em;color:#64748b;padding:14px 12px 6px;font-size:11px;font-weight:600}.sidebar a.nav-link{border-radius:var(--radius-sm);color:#cbd5e1;align-items:center;gap:11px;margin-bottom:2px;padding:9px 12px;font-size:13.5px;font-weight:500;transition:background .15s,color .15s;display:flex}.sidebar a.nav-link:hover{color:#fff;background:#1e293b}.sidebar a.nav-link.router-link-active{background:var(--c-primary);color:#fff}.sidebar a.nav-link .ico{text-align:center;width:18px}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;display:flex}.topbar{background:var(--c-surface);border-bottom:1px solid var(--c-border);z-index:40;justify-content:space-between;align-items:center;height:62px;padding:0 24px;display:flex;position:sticky;top:0}.topbar .page-title{font-size:17px;font-weight:650}.topbar .user-chip{align-items:center;gap:10px;display:flex}.avatar{background:var(--c-primary);color:#fff;border-radius:50%;place-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:grid}.content{flex:1;padding:24px}.menu-toggle{display:none}@media (width<=900px){.sidebar{transition:transform .2s;transform:translate(-100%)}.sidebar.open{transform:none}.main{margin-left:0}.menu-toggle{display:inline-flex}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.page-header h1{font-size:22px}.page-header p{color:var(--c-muted);margin-top:2px;font-size:13.5px}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.toolbar .spacer{flex:1}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.muted{color:var(--c-muted)}.text-right{text-align:right}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.grid-2{grid-template-columns:1fr 1fr;gap:18px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}@media (width<=800px){.grid-2,.grid-3{grid-template-columns:1fr}}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.actions{gap:6px;display:flex}.search-input{min-width:220px}.pagination{justify-content:flex-end;align-items:center;gap:6px;padding:14px;display:flex}.pagination button{min-width:34px}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.spinner.dark{border-color:var(--c-border);border-top-color:var(--c-primary)}.loading-center{justify-content:center;padding:50px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.login-wrap{background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 50%,#0891b2 100%);place-items:center;min-height:100vh;padding:20px;display:grid}.login-card{width:100%;max-width:410px;box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;padding:36px}.login-card .login-logo{background:var(--c-primary);color:#fff;border-radius:14px;place-items:center;width:54px;height:54px;margin:0 auto 16px;font-size:26px;display:grid}.login-card h1{text-align:center;margin-bottom:4px;font-size:22px}.login-card .sub{text-align:center;color:var(--c-muted);margin-bottom:26px;font-size:13.5px}
