:root{--bg:#0d0d1a;--sidebar-bg:#090912;--card-bg:#12121f;--border:#1e1e3a;--accent:#e94560;--accent2:#7c3aed;--text:#e2e2f0;--text-muted:#6b7280;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--info:#0ea5e9;--sidebar-width:240px;--header-height:60px}*{box-sizing:border-box;margin:0;padding:0}body{background:#0d0d1a;background:var(--bg);color:#e2e2f0;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.layout{display:flex;min-height:100vh}.sidebar{background:#090912;background:var(--sidebar-bg);border-right:1px solid #1e1e3a;border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;transition:width .2s;width:240px;width:var(--sidebar-width);z-index:100}.sidebar.collapsed{width:60px}.sidebar-logo{align-items:center;border-bottom:1px solid #1e1e3a;border-bottom:1px solid var(--border);display:flex;gap:10px;min-height:60px;min-height:var(--header-height);padding:18px 16px}.sidebar-logo .logo-text{color:#e94560;color:var(--accent);font-size:16px;font-weight:700;overflow:hidden;white-space:nowrap}.sidebar-logo .logo-icon{align-items:center;background:#e94560;background:var(--accent);border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-nav{flex:1 1;overflow-y:auto}.nav-section,.sidebar-nav{padding:8px 0}.nav-section-title{font-size:10px;font-weight:600;letter-spacing:.8px;padding:6px 16px;text-transform:uppercase}.nav-item,.nav-section-title{color:#6b7280;color:var(--text-muted);white-space:nowrap}.nav-item{align-items:center;border-left:3px solid #0000;cursor:pointer;display:flex;gap:10px;padding:9px 16px;text-decoration:none;transition:all .15s}.nav-item:hover{background:#ffffff0a;color:#e2e2f0;color:var(--text)}.nav-item.active{background:#e9456014;border-left-color:#e94560;border-left-color:var(--accent);color:#e94560;color:var(--accent)}.nav-item .nav-icon{flex-shrink:0;font-size:16px;text-align:center;width:20px}.nav-item .nav-label{font-size:13px;font-weight:500}.sidebar-footer{border-top:1px solid #1e1e3a;border-top:1px solid var(--border);padding:12px}.user-card{border-radius:8px;gap:10px;padding:8px}.user-avatar,.user-card{align-items:center;display:flex}.user-avatar{background:#7c3aed;background:var(--accent2);border-radius:50%;color:#fff;flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.user-info,.user-name{overflow:hidden}.user-name{font-size:13px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:11px;text-transform:capitalize}.sidebar-collapse-btn,.user-role{color:#6b7280;color:var(--text-muted)}.sidebar-collapse-btn{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;justify-content:center;margin-top:4px;padding:8px;transition:all .15s;width:100%}.sidebar-collapse-btn:hover{background:#ffffff0f;color:#e2e2f0;color:var(--text)}.main-content{flex:1 1;margin-left:240px;margin-left:var(--sidebar-width);min-width:0;transition:margin-left .2s}.main-content.collapsed{margin-left:60px}.header{align-items:center;background:#090912;background:var(--sidebar-bg);border-bottom:1px solid #1e1e3a;border-bottom:1px solid var(--border);display:flex;gap:16px;height:60px;height:var(--header-height);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header-title{flex:1 1;font-size:18px;font-weight:600}.header-actions{align-items:center;display:flex;gap:12px}.notif-btn{background:none;border:none;border-radius:8px;color:#6b7280;color:var(--text-muted);cursor:pointer;font-size:20px;padding:6px;position:relative;transition:all .15s}.notif-btn:hover{background:#ffffff0f;color:#e2e2f0;color:var(--text)}.notif-badge{align-items:center;background:#e94560;background:var(--accent);border-radius:50%;color:#fff;display:flex;font-size:9px;font-weight:700;height:16px;justify-content:center;position:absolute;right:2px;top:2px;width:16px}.notif-dropdown{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #00000080;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:360px;z-index:200}.notif-header{align-items:center;border-bottom:1px solid #1e1e3a;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 16px}.notif-header h4{font-size:14px;font-weight:600}.notif-list{max-height:380px;overflow-y:auto}.notif-item{border-bottom:1px solid #1e1e3a;border-bottom:1px solid var(--border);cursor:pointer;padding:12px 16px;transition:background .15s}.notif-item:hover{background:#ffffff08}.notif-item.unread{background:#e945600a}.notif-item-title{color:#e2e2f0;color:var(--text);font-size:13px;font-weight:600;margin-bottom:2px}.notif-item-msg{font-size:12px;line-height:1.4}.notif-item-msg,.notif-item-time{color:#6b7280;color:var(--text-muted)}.notif-item-time{font-size:11px;margin-top:4px}.notif-footer{border-top:1px solid #1e1e3a;border-top:1px solid var(--border);padding:10px 16px;text-align:center}.notif-dropdown-wrap{position:relative}.page{padding:24px}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.page-title{font-size:20px;font-weight:700}.page-subtitle{color:#6b7280;color:var(--text-muted);font-size:13px;margin-top:2px}.card{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:12px;padding:20px}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.card-title{font-size:15px;font-weight:600}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-bottom:24px}.stat-card{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:18px;transition:border-color .15s}.stat-card:hover{border-color:#2a2a4a}.stat-label{color:#6b7280;color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.stat-value{font-size:24px;font-weight:700}.stat-sub{color:#6b7280;color:var(--text-muted);font-size:12px}.stat-icon{font-size:24px}.charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:24px}.chart-card{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:12px;padding:20px}.chart-title{color:#6b7280;color:var(--text-muted);font-size:14px;font-weight:600;margin-bottom:16px}.chart-container{height:220px;position:relative}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;text-decoration:none;transition:all .15s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#e94560;background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#d63651}.btn-secondary{background:#7c3aed;background:var(--accent2);color:#fff}.btn-secondary:hover:not(:disabled){background:#6d2fd6}.btn-success{background:#22c55e;background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#1aaf52}.btn-danger{background:#ef4444;background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:#0000;border:1px solid #1e1e3a;border:1px solid var(--border);color:#e2e2f0;color:var(--text)}.btn-ghost:hover:not(:disabled){background:#ffffff0f}.btn-sm{font-size:12px;padding:5px 10px}.btn-icon{padding:8px}.form-group{margin-bottom:16px}.form-label{color:#6b7280;color:var(--text-muted);display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.form-control{background:#0d0d1a;border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:8px;color:#e2e2f0;color:var(--text);font-size:13px;outline:none;padding:9px 12px;transition:border-color .15s;width:100%}.form-control:focus{border-color:#e94560;border-color:var(--accent)}.form-control::placeholder{color:#3a3a5c}select.form-control{cursor:pointer}textarea.form-control{min-height:80px;resize:vertical}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.table-wrap{border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:12px;overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:#0a0a17}th{color:#6b7280;color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.6px;text-align:left;text-transform:uppercase;white-space:nowrap}td,th{padding:12px 16px}td{border-bottom:1px solid #1a1a2e;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:hsla(0,0%,100%,.015)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;padding:2px 8px}.badge-hot{background:#ef444426;color:#ef4444}.hot-dot{animation:pulse 1.5s infinite;background:#ef4444;border-radius:50%;display:inline-block;height:6px;margin-right:4px;width:6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.modal-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:16px;max-height:90vh;max-width:560px;overflow-y:auto;padding:28px;position:relative;width:100%}.modal h2,.modal h3{font-size:18px;margin-bottom:20px}.modal-close{background:none;border:none;border-radius:6px;color:#6b7280;color:var(--text-muted);cursor:pointer;font-size:22px;padding:4px;position:absolute;right:16px;top:16px;transition:all .15s}.modal-close:hover{background:#ffffff14;color:#e2e2f0;color:var(--text)}.modal-actions{border-top:1px solid #1e1e3a;border-top:1px solid var(--border);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px}.confirm-modal{max-width:420px}.confirm-modal h3{margin-bottom:12px}.confirm-modal p{color:#6b7280;color:var(--text-muted);margin-bottom:0}.filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.search-input{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:8px;color:#e2e2f0;color:var(--text);font-size:13px;min-width:220px;outline:none;padding:8px 12px}.search-input:focus{border-color:#e94560;border-color:var(--accent)}.filter-select{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:8px;color:#e2e2f0;color:var(--text);cursor:pointer;font-size:13px;outline:none;padding:8px 12px}.filter-select:focus{border-color:#e94560;border-color:var(--accent)}.empty-state{padding:60px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px}.empty-title{font-size:16px;font-weight:600;margin-bottom:8px}.empty-desc{color:#6b7280;color:var(--text-muted);font-size:13px}.pagination{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-top:20px}.pagination-info{color:#6b7280;color:var(--text-muted);font-size:13px}.pagination-controls{display:flex;gap:4px}.page-btn{background:#12121f;background:var(--card-bg);border:1px solid #1e1e3a;border:1px solid var(--border);border-radius:6px;color:#6b7280;color:var(--text-muted);cursor:pointer;font-size:13px;min-width:32px;padding:6px 10px;text-align:center;transition:all .15s}.page-btn:hover:not(:disabled){border-color:#e94560;border-color:var(--accent);color:#e94560;color:var(--accent)}.page-btn.active{background:#e94560;background:var(--accent);border-color:#e94560;border-color:var(--accent);color:#fff}.page-btn:disabled{cursor:not-allowed;opacity:.3}.page-ellipsis{color:#6b7280;color:var(--text-muted);padding:6px 4px}.overdue-banner{align-items:center;background:#ef44441f;border:1px solid #ef44444d;border-radius:10px;display:flex;gap:10px;margin-bottom:20px;padding:12px 16px}.overdue-banner .overdue-icon{font-size:18px}.overdue-banner a{color:#ef4444;color:var(--danger);font-weight:600}.loading-spinner{align-items:center;display:flex;justify-content:center;padding:60px}.spinner{animation:spin .8s linear infinite;border:3px solid #e9456033;border-radius:50%;border-top:3px solid var(--accent);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.btn-loading{position:relative}.btn-loading:after{animation:spin .7s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:14px;position:absolute;right:10px;top:50%;transform:translateY(-50%);width:14px}@media (max-width:860px){.sidebar{width:60px}.sidebar .logo-text,.sidebar .nav-label,.sidebar .nav-section-title,.sidebar .user-info{display:none}.main-content{margin-left:60px}.charts-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}}@media (max-width:600px){.page{padding:16px}.stats-grid{grid-template-columns:1fr 1fr}.modal{padding:20px}.filters-bar{align-items:stretch;flex-direction:column}.search-input{min-width:0;min-width:auto;width:100%}}
/*# sourceMappingURL=main.aaab534b.css.map*/