@import url(https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap);:root[data-theme=light]{--bg:#fff;--bg-secondary:#f7f9fc;--bg-card:#fff;--border:#e8ecf0;--text-primary:#0d1117;--text-secondary:#5a6472;--text-muted:#8b95a1;--accent:#00b4d8;--accent-hover:#0096b7;--accent-soft:#e8f8fc;--danger:#e53935;--success:#00c853;--warning:#ff9800;--shadow:0 1px 3px #00000014,0 4px 16px #0000000a;--shadow-lg:0 8px 32px #0000001a}:root[data-theme=dark]{--bg:#0d1117;--bg-secondary:#161b22;--bg-card:#1c2128;--border:#2d3748;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#6e7681;--accent:#00b4d8;--accent-hover:#33c4e0;--accent-soft:#0d2a33;--danger:#f85149;--success:#3fb950;--warning:#d29922;--shadow:0 1px 3px #0000004d,0 4px 16px #0003;--shadow-lg:0 8px 32px #0006}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text-primary);font-family:DM Sans,sans-serif;transition:background .2s,color .2s}.app{min-height:100vh}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.login-page{align-items:center;background:var(--bg);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-bg{background:radial-gradient(circle,#00b4d814 0,#0000 70%);border-radius:50%;pointer-events:none;position:absolute}.login-card{animation:fadeUp .4s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-lg);max-width:420px;padding:48px;position:relative;width:100%;z-index:1}.login-logo{color:var(--text-primary);font-size:26px;font-weight:600;letter-spacing:-.5px;margin-bottom:4px}.login-logo span{color:var(--accent)}.login-portal-tag{color:var(--text-muted);font-size:12px;margin-bottom:28px}.login-title{font-size:22px;font-weight:600;margin-bottom:6px}.login-desc{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.theme-toggle-float{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);color:var(--text-secondary);cursor:pointer;display:flex;font-size:16px;height:40px;justify-content:center;position:fixed;right:20px;top:20px;width:40px;z-index:1000}.form-group{margin-bottom:14px}.form-label{color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:5px}.form-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-family:DM Sans,sans-serif;font-size:14px;outline:none;padding:11px 14px;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #00b4d81f}.form-input::placeholder{color:var(--text-muted)}.form-select{padding:10px 14px}.form-select,.form-textarea{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-family:DM Sans,sans-serif;font-size:14px;outline:none;width:100%}.form-textarea{min-height:80px;padding:11px 14px;resize:vertical}.btn-primary{background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;margin-top:6px;padding:12px;transition:background .15s;width:100%}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#0000;border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;font-family:DM Sans,sans-serif;font-size:13px;padding:9px 18px}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-sm{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;padding:8px 16px}.btn-sm:hover{background:var(--accent-hover)}.alert-info{background:var(--accent-soft);border:1px solid #00b4d84d;border-radius:8px;color:var(--accent);margin-bottom:14px}.alert-info,.error-msg{font-size:13px;padding:10px 14px}.error-msg{background:#e5393514;border:1px solid #e5393533;border-radius:8px;color:var(--danger);margin-top:10px}.success-msg{background:#00c8531a;border:1px solid #00c85333;border-radius:8px;color:var(--success);font-size:12px;margin-top:10px;padding:8px 12px}.divider{align-items:center;display:flex;gap:10px;margin:14px 0}.divider-line{background:var(--border);flex:1 1;height:1px}.divider-text{color:var(--text-muted);font-size:12px}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dashboard{background:var(--bg-secondary)}.dashboard,.sidebar{display:flex;min-height:100vh}.sidebar{background:var(--bg-card);border-right:1px solid var(--border);bottom:0;flex-direction:column;left:0;padding:24px 0;position:fixed;top:0;width:240px;z-index:100}.sidebar-logo{border-bottom:1px solid var(--border);padding:0 24px 24px}.sidebar-logo-text{color:var(--text-primary);font-size:22px;font-weight:600;letter-spacing:-.5px}.sidebar-logo-text span{color:var(--accent)}.sidebar-logo-sub{color:var(--text-muted);font-size:11px;margin-top:2px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:14px 12px}.sidebar-nav-item{align-items:center;background:#0000;border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;padding:9px 12px;text-align:left;transition:background .15s,color .15s;width:100%}.sidebar-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-soft);color:var(--accent)}.sidebar-bottom{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px;padding:12px}.sidebar-user{background:var(--bg-secondary);border-radius:10px;gap:10px;padding:9px 12px}.sidebar-avatar,.sidebar-user{align-items:center;display:flex}.sidebar-avatar{background:var(--accent);border-radius:8px;color:#fff;flex-shrink:0;font-size:13px;font-weight:600;height:32px;justify-content:center;width:32px}.sidebar-user-name{color:var(--text-primary);font-size:13px;font-weight:500}.sidebar-user-role{color:var(--text-muted);font-size:11px}.sidebar-btn{align-items:center;background:#0000;border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:DM Sans,sans-serif;font-size:13px;gap:8px;padding:8px 12px;transition:border-color .15s,color .15s;width:100%}.sidebar-btn:hover{border-color:var(--accent);color:var(--accent)}.sidebar-btn.danger:hover{border-color:var(--danger);color:var(--danger)}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:240px;min-height:100vh}.topbar{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;height:52px;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50}.topbar-title{color:var(--text-primary);font-size:15px;font-weight:500}.topbar-right{gap:10px}.topbar-btn,.topbar-right{align-items:center;display:flex}.topbar-btn{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:16px;height:34px;justify-content:center;position:relative;width:34px}.topbar-btn:hover{border-color:var(--accent)}.notif-count{align-items:center;background:var(--accent);border:2px solid var(--bg-card);border-radius:50%;color:#fff;display:flex;font-size:9px;font-weight:600;height:17px;justify-content:center;position:absolute;right:-5px;top:-5px;width:17px}.page-body{flex:1 1;padding:28px 32px}.page-header{margin-bottom:24px}.page-title{color:var(--text-primary);font-size:22px;font-weight:600;letter-spacing:-.3px}.page-subtitle{color:var(--text-secondary);font-size:13px;margin-top:3px}.stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:24px}.stat-card{animation:fadeUp .4s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:18px 22px}.stat-label{color:var(--text-muted);font-size:11px;font-weight:500;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.stat-value{color:var(--text-primary);font-family:DM Mono,monospace;font-size:26px;font-weight:600}.stat-accent{color:var(--accent)}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);margin-bottom:24px;padding:20px 24px}.chart-title{color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:16px}.chart-bars{align-items:flex-end;display:flex;gap:8px;height:80px}.chart-bar-wrap{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:4px;height:100%;justify-content:flex-end}.chart-bar{background:var(--accent-soft);border-radius:4px 4px 0 0;min-height:4px;transition:background .15s;width:100%}.chart-bar:hover{background:var(--accent)}.chart-bar-label{color:var(--text-muted);font-size:10px}.chart-bar-val{color:var(--text-secondary);font-size:10px}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}.table-toolbar{border-bottom:1px solid var(--border);gap:12px;justify-content:space-between;padding:16px 20px}.table-toolbar,.table-toolbar-left{align-items:center;display:flex;flex-wrap:wrap}.table-toolbar-left{gap:10px}.table-toolbar-title{color:var(--text-primary);font-size:14px;font-weight:600}.filter-tabs{display:flex;gap:4px}.filter-tab{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-family:DM Sans,sans-serif;font-size:12px;padding:5px 12px;transition:all .15s}.filter-tab.active{background:var(--accent-soft);border-color:#00b4d84d;color:var(--accent)}.search-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-family:DM Sans,sans-serif;font-size:13px;outline:none;padding:7px 12px;width:200px}.search-input:focus{border-color:var(--accent)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead tr{background:var(--bg-secondary);border-bottom:1px solid var(--border)}th{color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.5px;padding:10px 20px;text-align:left;text-transform:uppercase;white-space:nowrap}td{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:13px;padding:12px 20px;vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{cursor:pointer;transition:background .1s}tbody tr:hover{background:var(--bg-secondary)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:500;padding:3px 10px}.badge-success{background:#00c8531a;color:var(--success)}.badge-warning{background:#ff98001a;color:var(--warning)}.badge-info{background:#00b4d81a;color:var(--accent)}.badge-danger{background:#e539351a;color:var(--danger)}.duration-cell{color:var(--text-secondary);font-family:DM Mono,monospace;font-size:12px}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:500}.modal{animation:fadeUp .25s ease;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);max-height:85vh;max-width:560px;overflow-y:auto;width:100%}.modal,.modal-header{background:var(--bg-card)}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:18px 22px;position:sticky;top:0;z-index:1}.modal-title{color:var(--text-primary);font-size:15px;font-weight:600}.modal-close{align-items:center;background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;height:28px;justify-content:center;width:28px}.modal-close:hover{background:var(--bg-secondary)}.modal-body{padding:22px}.modal-section{margin-bottom:18px}.modal-section-label{color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.modal-section-value{color:var(--text-primary);font-size:14px;line-height:1.6}.modal-tabs{border-bottom:1px solid var(--border);display:flex;gap:4px;margin-bottom:18px;padding-bottom:14px}.modal-tab{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-family:DM Sans,sans-serif;font-size:13px;padding:6px 14px;transition:all .15s}.modal-tab.active{background:var(--accent-soft);border-color:#00b4d84d;color:var(--accent)}.notif-dropdown{animation:slideDown .2s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;position:absolute;right:0;top:44px;width:320px;z-index:200}.notif-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:12px 16px}.notif-title{color:var(--text-primary);font-size:13px;font-weight:600}.notif-mark-all{background:none;border:none;color:var(--accent);cursor:pointer;font-size:11px}.notif-list{max-height:300px;overflow-y:auto}.notif-item{align-items:flex-start;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:10px;padding:12px 16px;transition:background .1s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-secondary)}.notif-item.unread{background:var(--accent-soft)}.notif-dot{border-radius:50%;flex-shrink:0;height:7px;margin-top:5px;width:7px}.notif-dot.unread{background:var(--accent)}.notif-dot.read{background:var(--border)}.notif-text{color:var(--text-primary);font-size:12px;line-height:1.5}.notif-time{color:var(--text-muted);font-size:11px;margin-top:2px}.notif-empty{color:var(--text-muted);font-size:13px;padding:24px;text-align:center}.toast{align-items:center;animation:slideDown .3s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;bottom:24px;box-shadow:var(--shadow-lg);color:var(--text-primary);display:flex;font-size:13px;gap:10px;min-width:280px;padding:12px 16px;position:fixed;right:24px;z-index:1000}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;margin-left:auto}.session-warning{align-items:center;background:#ff9800;color:#fff;display:flex;font-size:13px;font-weight:500;gap:12px;justify-content:center;left:0;padding:10px 20px;position:fixed;right:0;top:0;z-index:999}.session-warning button{background:#fff;border:none;border-radius:6px;color:#ff9800;cursor:pointer;font-size:12px;font-weight:600;padding:5px 14px}.admin-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:1fr 1fr}.admin-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:22px}.admin-card-title{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:16px;padding-bottom:12px}.dept-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.dept-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:18px}.dept-name{color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:4px}.dept-tag{color:var(--text-muted);font-size:11px;margin-bottom:12px}.dept-stat,.dept-tag{font-family:DM Mono,monospace}.dept-stat{color:var(--accent);font-size:24px;font-weight:600}.dept-stat-label{color:var(--text-muted);font-size:11px}.code-display{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;margin-top:12px;padding:14px 16px}.code-value{color:var(--text-primary);font-family:DM Mono,monospace;font-size:16px;font-weight:500;letter-spacing:2px;margin-bottom:6px}.code-expires{color:var(--text-muted);font-size:11px}.empty-state{color:var(--text-muted);padding:50px 20px;text-align:center}.empty-text,.loading{font-size:14px}.loading{align-items:center;color:var(--text-muted);display:flex;gap:10px;justify-content:center;padding:50px}.spinner{animation:spin .7s linear infinite;border:2px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:18px;width:18px}.pw-strength{border-radius:2px;height:3px;margin-top:6px;transition:width .3s,background .3s}.note-item{background:var(--bg-secondary);border-radius:8px;margin-bottom:8px;padding:10px 12px}.note-meta{color:var(--text-muted);display:flex;font-size:11px;justify-content:space-between;margin-bottom:4px}.note-text{color:var(--text-primary);font-size:13px}@media (max-width:900px){.admin-grid{grid-template-columns:1fr}.sidebar{width:200px}.main-content{margin-left:200px}.page-body{padding:20px}}
/*# sourceMappingURL=main.14c0bffb.css.map*/