:root{--primary:#6d28d9;--primary-l:#7c3aed;--primary-pale:#f5f3ff;--primary-bd:#ddd6fe;--indigo:#4f46e5;--indigo-l:#6366f1;--indigo-pale:#eef2ff;--indigo-bd:#c7d2fe;--teal:#0d9488;--teal-l:#14b8a6;--teal-pale:#f0fdfa;--teal-bd:#99f6e4;--amber:#d97706;--amber-l:#f59e0b;--amber-pale:#fffbeb;--amber-bd:#fde68a;--mkt:#7c3aed;--mkt-pale:#f0f4ff;--mkt-bd:#c4b5fd;--prod:#16a34a;--prod-pale:#f0fdf4;--prod-bd:#bbf7d0;--smgr:#15803d;--smgr-pale:#f0fdf4;--smgr-bd:#bbf7d0;--cskh:#0284c7;--cskh-pale:#f0f9ff;--cskh-bd:#bae6fd;--ketoan:#6d28d9;--ketoan-pale:#f5f3ff;--ketoan-bd:#ddd6fe;--design:#db2777;--design-pale:#fdf2f8;--design-bd:#fbcfe8;--kho:#ea580c;--kho-pale:#fff7ed;--kho-bd:#fed7aa;--admin:#dc2626;--admin-pale:#fef2f2;--admin-bd:#fecaca;--sales:#6d28d9;--sales-pale:#f5f3ff;--sales-bd:#ddd6fe;--bg:#f1f0f8;--white:#fff;--border:#e5e3f0;--border2:#d4d0e8;--text:#1a1033;--text2:#4a4560;--muted:#8b87a8;--green:#059669;--green-pale:#ecfdf5;--green-bd:#a7f3d0;--blue:#2563eb;--blue-pale:#eff6ff;--blue-bd:#bfdbfe;--red:#dc2626;--red-pale:#fef2f2;--radius:10px;--radius-lg:16px;--shadow:0 1px 3px #6d28d90f,0 4px 12px #6d28d90a;--shadow-lg:0 8px 32px #6d28d924;--grad:linear-gradient(135deg,#6d28d9 0%,#7c3aed 50%,#4f46e5 100%);--grad-soft:linear-gradient(135deg,#f5f3ff 0%,#eef2ff 100%)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Be Vietnam Pro,system-ui,sans-serif;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.btn{color:var(--text);cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:700;transition:all .15s;display:inline-flex}.btn:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.btn-primary{background:var(--grad);color:#fff;box-shadow:0 4px 14px #6d28d94d}.btn-primary:hover{box-shadow:0 6px 18px #6d28d966}.btn-outline{border-color:var(--border2)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-ghost{color:var(--text2);background:0 0}.btn-ghost:hover{background:var(--primary-pale);color:var(--primary)}.btn-sm{padding:5px 10px;font-size:11px}.card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);background:#fff}.card-head{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.card-title{color:var(--text);letter-spacing:-.2px;font-size:16px;font-weight:800}.card-body{padding:20px}.form-grid{gap:14px;display:grid}.form-grid.cols-2{grid-template-columns:1fr 1fr}.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}@media (width<=720px){.form-grid.cols-2,.form-grid.cols-3{grid-template-columns:1fr}}.field{flex-direction:column;gap:5px;display:flex}.field label{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.field .req:after{content:" *";color:var(--red)}.input,.select,.textarea{border:1.5px solid var(--border2);color:var(--text);background:#fafaff;border-radius:8px;width:100%;padding:9px 12px;font-size:13px;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-pale);background:#fff;outline:none}.textarea{resize:vertical;min-height:80px}.field .help{color:var(--muted);font-size:11px}.field .err{color:var(--red);font-size:11px;font-weight:600}.tbl-wrap{border-radius:var(--radius);overflow-x:auto}.tbl{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.tbl th,.tbl td{text-align:left;padding:11px 14px}.tbl thead th{background:var(--primary-pale);color:var(--primary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);font-size:11px;font-weight:800}.tbl tbody tr{transition:background .12s}.tbl tbody tr:not(:last-child) td{border-bottom:1px solid var(--border)}.tbl tbody tr:hover{background:var(--primary-pale)}.tbl .actions{justify-content:flex-end;gap:6px;display:flex}.empty{text-align:center;color:var(--muted);padding:40px}.empty-ico{margin-bottom:10px;font-size:36px}.badge{white-space:nowrap;border:1px solid;border-radius:6px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.badge.green{background:var(--green-pale);color:var(--green);border-color:var(--green-bd)}.badge.amber{background:var(--amber-pale);color:var(--amber);border-color:var(--amber-bd)}.badge.blue{background:var(--blue-pale);color:var(--blue);border-color:var(--blue-bd)}.badge.red{background:var(--red-pale);color:var(--red);border-color:#fecaca}.badge.violet{background:var(--primary-pale);color:var(--primary);border-color:var(--primary-bd)}.badge.muted{color:#475569;background:#f3f4f6;border-color:#e5e7eb}.role-badge{border:1px solid;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:700}.role-sales{background:var(--sales-pale);color:var(--sales);border-color:var(--sales-bd)}.role-mkt{background:var(--mkt-pale);color:var(--mkt);border-color:var(--mkt-bd)}.role-cskh{background:var(--cskh-pale);color:var(--cskh);border-color:var(--cskh-bd)}.role-ketoan{background:var(--ketoan-pale);color:var(--ketoan);border-color:var(--ketoan-bd)}.role-design{background:var(--design-pale);color:var(--design);border-color:var(--design-bd)}.role-kho{background:var(--kho-pale);color:var(--kho);border-color:var(--kho-bd)}.role-admin{background:var(--admin-pale);color:var(--admin);border-color:var(--admin-bd)}.role-smgr{background:var(--smgr-pale);color:var(--smgr);border-color:var(--smgr-bd)}.role-prod{background:var(--prod-pale);color:var(--prod);border-color:var(--prod-bd)}.modal-backdrop{z-index:800;background:#00000073;justify-content:center;align-items:flex-start;padding:24px;animation:.18s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-box{background:#fff;border-radius:18px;width:100%;max-width:620px;margin:auto;animation:.25s cubic-bezier(.34,1.2,.64,1) slideUp;box-shadow:0 20px 60px #0000002e}.modal-box.lg{max-width:920px}.modal-head{border-bottom:1px solid var(--border);background:var(--grad-soft);border-radius:18px 18px 0 0;justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-title{color:var(--text);font-size:16px;font-weight:800}.modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:22px;line-height:1}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-body{max-height:calc(100vh - 220px);padding:22px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 22px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.toast-host{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border:1px solid var(--border);border-left:4px solid var(--primary);box-shadow:var(--shadow-lg);background:#fff;border-radius:10px;align-items:center;gap:10px;min-width:260px;padding:12px 18px;font-size:13px;font-weight:600;animation:.25s slideIn;display:flex}.toast.success{border-left-color:var(--green)}.toast.error{border-left-color:var(--red)}.toast.warn{border-left-color:var(--amber)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:none}}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:18px;display:grid}.kpi{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);border-top:3px solid var(--primary);background:#fff;padding:16px 18px}.kpi-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-size:11px;font-weight:700}.kpi-value{color:var(--text);letter-spacing:-.5px;font-size:24px;font-weight:900}.kpi-sub{color:var(--muted);margin-top:4px;font-size:11px}.kpi.green{border-top-color:var(--green)}.kpi.amber{border-top-color:var(--amber)}.kpi.blue{border-top-color:var(--blue)}.kpi.red{border-top-color:var(--red)}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.toolbar .grow{flex:1}.search-input{border:1.5px solid var(--border2);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%238b87a8' width='16'%3E%3Cpath d='M15.5 14h-.79l-.28-.27A6.5 6.5 0 0 0 16 9.5 6.5 6.5 0 1 0 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z'/%3E%3C/svg%3E") 12px no-repeat;border-radius:8px;min-width:240px;padding:9px 12px 9px 36px;font-size:13px}.pager{justify-content:flex-end;align-items:center;gap:8px;padding:14px 20px;display:flex}.pager button{padding:6px 12px;font-size:12px}.pager .info{color:var(--muted);margin-right:auto;font-size:12px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cdc8e0;border-radius:6px}::-webkit-scrollbar-track{background:0 0}
