@import "https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap";@import "https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.css";.flash-toast{z-index:9999;border-radius:.75rem;align-items:center;gap:.5rem;max-width:340px;padding:.8rem 1.2rem;font-size:.875rem;font-weight:500;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 8px 30px #00000026}.flash-success{color:#fff;background:#198754}.flash-error{color:#fff;background:#dc3545}.flash-warning{color:#212529;background:#ffc107}.flash-info{color:#055160;background:#0dcaf0}.flash-enter-active,.flash-leave-active{transition:all .3s}.flash-enter-from,.flash-leave-to{opacity:0;transform:translateY(10px)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#5d3fd3;--primary-d:#4b3684;--primary-l:#f0ebfa;--secondary:#8b5a8c;--accent:#f0ebfa;--surface:#fff;--text:#212529;--text-muted:#6c757d;--border:#e9ecef;--danger:#dc3545;--success:#198754;--warning:#ffc107;--info:#0dcaf0;--radius:.75rem;--shadow:0 2px 12px #00000012;--shadow-lg:0 8px 30px #0000001f;--sidebar-w:240px;--nav-h:60px}html,body{height:100%}body{background:var(--accent);color:var(--text);font-family:Poppins,sans-serif;font-size:14px;line-height:1.6}#app{height:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.card-header{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding:1rem 1.25rem;font-weight:600;display:flex}.card-body{padding:1.25rem}.btn{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:.5rem;align-items:center;gap:.35rem;padding:.45rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.btn-lg{padding:.65rem 1.4rem;font-size:1rem}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-d)}.btn-secondary{color:#fff;background:#6c757d;border-color:#6c757d}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:#157347}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#b02a37}.btn-warning{background:var(--warning);color:#212529;border-color:var(--warning)}.btn-outline-primary{color:var(--primary);border-color:var(--primary);background:0 0}.btn-outline-primary:hover:not(:disabled){background:var(--primary-l)}.btn-outline-secondary{color:#6c757d;background:0 0;border-color:#6c757d}.btn-outline-secondary:hover:not(:disabled){background:#f8f9fa}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--accent);color:var(--primary)}.btn-icon{border-radius:.5rem;padding:.4rem}.form-group{margin-bottom:1rem}.form-label{margin-bottom:.3rem;font-size:.82rem;font-weight:500;display:block}.form-control,.form-select{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:.5rem;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;transition:all .2s}.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #5d3fd31f}textarea.form-control{resize:vertical;min-height:80px}.badge{border-radius:2rem;align-items:center;gap:.25rem;padding:.2rem .55rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-primary{background:var(--primary-l);color:var(--primary)}.badge-success{color:#0a3622;background:#d1e7dd}.badge-danger{color:#58151c;background:#f8d7da}.badge-warning{color:#664d03;background:#fff3cd}.badge-secondary{color:#495057;background:#e9ecef}.badge-info{color:#055160;background:#cff4fc}.table-wrap{border-radius:var(--radius);overflow-x:auto}table{border-collapse:collapse;width:100%}th{background:var(--accent);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);text-align:left;white-space:nowrap;padding:.7rem 1rem;font-size:.78rem;font-weight:600}td{border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.875rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--accent)}.alert{border-radius:var(--radius);align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.alert-success{color:#0a3622;background:#d1e7dd;border:1px solid #badbcc}.alert-error{color:#58151c;background:#f8d7da;border:1px solid #f5c2c7}.alert-warning{color:#664d03;background:#fff3cd;border:1px solid #ffecb5}.alert-info{color:#055160;background:#cff4fc;border:1px solid #b6effb}.text-primary{color:var(--primary)!important}.text-muted{color:var(--text-muted)!important}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}.fw-600{font-weight:600}.fs-sm{font-size:.82rem}.flex{display:flex}.flex-center{align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.w-100{width:100%}.progress-bar-wrap{background:#e9ecef;border-radius:4px;height:8px;overflow:hidden}.progress-bar{background:var(--primary);border-radius:4px;height:100%;transition:width .5s}.modal-overlay{z-index:9000;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:540px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.1rem 1.25rem;display:flex}.modal-header h3{font-size:1rem;font-weight:600}.modal-body{padding:1.25rem}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;display:flex}.stat-card{padding:1.25rem}.stat-card .icon{border-radius:.75rem;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;display:flex}.stat-card .val{margin:.4rem 0 .1rem;font-size:1.5rem;font-weight:700}.stat-card .lbl{color:var(--text-muted);font-size:.78rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.page-title{align-items:center;gap:.5rem;font-size:1.3rem;font-weight:700;display:flex}.grid-2{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}@media (width<=900px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}}.chip{cursor:pointer;border:1px solid;border-radius:2rem;align-items:center;padding:.25rem .75rem;font-size:.78rem;font-weight:500;transition:all .2s;display:inline-flex}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.chip:not(.active){color:var(--text-muted);border-color:var(--border);background:0 0}.chip:not(.active):hover{border-color:var(--primary);color:var(--primary)}.kanban-col{background:var(--accent);border-radius:var(--radius);min-height:300px;padding:1rem}.kanban-card{background:var(--surface);box-shadow:var(--shadow);border-left:3px solid #0000;border-radius:.5rem;margin-bottom:.6rem;padding:.9rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.empty-state i{opacity:.35;margin-bottom:.75rem;font-size:2.5rem;display:block}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{justify-content:center;align-items:center;padding:3rem;display:flex}
