:root{--primary-color:#2b5fe1;--primary-light:#eef2ff;--bg-color:#f7f9fc;--sidebar-bg:#fff;--text-main:#1e293b;--text-muted:#64748b;--border-color:#e2e8f0;--success-color:#10b981;--success-light:#d1fae5;--warning-color:#f59e0b;--warning-light:#fef3c7;--danger-color:#ef4444;--danger-light:#fee2e2;--info-color:#3b82f6;--info-light:#dbeafe}*{box-sizing:border-box;margin:0;padding:0}html{min-height:100%}body{background-color:var(--bg-color);min-height:100vh;color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Segoe UI Variable Text,Segoe UI,Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}ul{list-style:none}input,select,textarea{font:inherit}img{max-width:100%;display:block}.lg\:p-10{padding:1rem 2rem!important}.ar-page{background-color:#f8fafc;min-height:100vh;padding:24px;font-family:Inter,system-ui,-apple-system,sans-serif}.ar-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.ar-title{color:#1e293b;margin:0 0 8px;font-size:1.5rem;font-weight:700}.ar-subtitle{color:#64748b;margin:0;font-size:.875rem}.ar-header-actions{gap:12px;display:flex}.ar-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;height:40px;padding:0 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.ar-btn-primary{color:#fff;background-color:#2563eb}.ar-btn-primary:hover{background-color:#1d4ed8}.ar-btn-outline{color:#1e293b;background-color:#fff;border:1px solid #e2e8f0}.ar-btn-outline:hover{background-color:#f8fafc}.ar-stats-row{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px;display:grid}.ar-add-form{background-color:#fff;border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:24px;padding:20px;display:flex;box-shadow:0 1px 3px #0000000d}.ar-form-group{flex-direction:column;flex:1;gap:6px;min-width:150px;display:flex}.ar-form-group label{color:#64748b;font-size:.875rem;font-weight:500}.ar-select-wrapper{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;height:42px;padding:0 12px;display:flex;position:relative}.ar-select-content{color:#1e293b;align-items:center;gap:8px;font-size:.875rem;font-weight:500;display:flex}.ar-select-icon{border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;display:flex}.ar-select-chevron{color:#94a3b8;font-size:.75rem}.ar-dropdown-menu{z-index:50;background:#fff;border:1px solid #e2e8f0;border-radius:8px;width:100%;max-height:250px;margin-top:4px;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 4px 6px -1px #0000001a}.ar-dropdown-item{cursor:pointer;color:#1e293b;align-items:center;gap:8px;padding:8px 12px;font-size:.875rem;font-weight:500;display:flex}.ar-dropdown-item:hover{background:#f8fafc}.ar-avatar-small{object-fit:cover;border-radius:50%;width:24px;height:24px}.ar-dot{border-radius:50%;width:8px;height:8px}.ar-dot-high{background-color:#ef4444}.ar-dot-medium{background-color:#f59e0b}.ar-dot-low{background-color:#22c55e}.ar-table-panel{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.ar-table-header{border-bottom:1px solid #f1f5f9;padding:20px}.ar-table-header h3{color:#1e293b;margin:0;font-size:1.125rem;font-weight:600}.ar-table-container{overflow-x:auto}.ar-table{border-collapse:collapse;text-align:left;width:100%}.ar-table th{color:#64748b;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;padding:12px 20px;font-size:.75rem;font-weight:600}.ar-table td{color:#1e293b;vertical-align:middle;border-bottom:1px solid #e2e8f0;padding:16px 20px;font-size:.875rem}.ar-table tr:last-child td{border-bottom:none}.ar-cat-cell{align-items:center;gap:12px;font-weight:600;display:flex}.ar-assignee-cell{align-items:center;gap:12px;display:flex}.ar-assignee-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.ar-assignee-info{flex-direction:column;display:flex}.ar-assignee-name{color:#1e293b;font-weight:600}.ar-assignee-role{color:#64748b;font-size:.75rem}.ar-priority-cell{align-items:center;gap:8px;font-weight:500;display:flex}.ar-status-pill{border-radius:999px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.ar-status-active{color:#166534;background-color:#dcfce7}.ar-status-inactive{color:#991b1b;background-color:#fee2e2}.ar-actions-cell{align-items:center;gap:8px;display:flex}.ar-action-btn{cursor:pointer;color:#64748b;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.ar-action-btn:hover{background-color:#f8fafc}.ar-action-btn.delete{color:#ef4444;background-color:#fef2f2;border-color:#fee2e2}.ar-action-btn.delete:hover{background-color:#fee2e2}.ar-pagination-container{border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.ar-page-info{color:#64748b;font-size:.875rem}.ar-page-controls{align-items:center;gap:4px;display:flex}.ar-page-btn{color:#334155;cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;font-size:.875rem;font-weight:500;display:flex}.ar-page-btn.active{color:#fff;background-color:#2563eb;border-color:#2563eb}.ar-page-btn.ellipsis{cursor:default;background:0 0;border:none}.bg-blue-light{color:#3b82f6;background-color:#eff6ff}.bg-green-light{color:#22c55e;background-color:#f0fdf4}.bg-purple-light{color:#a855f7;background-color:#faf5ff}.bg-amber-light{color:#f59e0b;background-color:#fffbeb}.bg-red-light{color:#ef4444;background-color:#fef2f2}.bg-slate-light{color:#64748b;background-color:#f8fafc}@media (width<=1200px){.ar-stats-row{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.ar-header{flex-direction:column;gap:16px}.ar-stats-row{grid-template-columns:1fr}.ar-add-form{flex-direction:column;align-items:stretch}}.dashboard-stat-card{background:#fff;border:1px solid #edf2f8;border-radius:16px;align-items:center;gap:16px;min-height:110px;padding:20px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 10px 30px #0f172a0d}.dashboard-stat-card:hover{transform:translateY(-4px);box-shadow:0 15px 35px #0f172a14}.stat-card-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;font-size:1.25rem;display:flex}.stat-card-icon.tone-blue{color:#2563eb;background:#eef4ff}.stat-card-icon.tone-green{color:#16a34a;background:#ecfdf5}.stat-card-icon.tone-orange{color:#f97316;background:#fff4e8}.stat-card-icon.tone-red{color:#ef4444;background:#fef2f2}.stat-card-icon.tone-purple{color:#7c3aed;background:#f5f3ff}.stat-card-icon.tone-indigo{color:#4f46e5;background:#eef2ff}.stat-card-icon.tone-amber{color:#d97706;background:#fffbeb}.stat-card-content{flex:1;min-width:0}.stat-card-head{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.stat-card-main h3{color:#64748b;margin:0 0 4px;font-size:.85rem;font-weight:700;line-height:1.2}.stat-card-main strong{color:#0f172a;font-size:1.6rem;font-weight:800;line-height:1;display:block}.stat-card-trend{white-space:nowrap;border-radius:999px;padding:4px 8px;font-size:.72rem;font-weight:700}.stat-card-trend.positive{color:#16a34a;background:#ecfdf5}.stat-card-trend.negative{color:#ef4444;background:#fef2f2}.stat-card-trend.neutral{color:#64748b;background:#f1f5f9}.stat-card-subtitle{color:#94a3b8;margin:6px 0 0;font-size:.75rem;font-weight:600}@media (width<=640px){.dashboard-stat-card{padding:16px}.stat-card-icon{width:44px;height:44px;font-size:1.1rem}.stat-card-main strong{font-size:1.4rem}}.cm-page{color:#0f172a;background-color:#f8fafc;width:100%;min-height:100vh;padding:24px;font-family:Inter,system-ui,-apple-system,sans-serif}.cm-hero{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.cm-title{color:#1e293b;margin:0;font-size:1.5rem;font-weight:600}.cm-subtitle{color:#64748b;margin:4px 0 0;font-size:.875rem}.cm-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;height:40px;padding:0 16px;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.cm-btn-primary{color:#fff;background-color:#1d4ed8}.cm-btn-primary:hover{background-color:#1e40af}.cm-btn-outline{color:#1d4ed8;background-color:#fff;border:1px solid #1d4ed8}.cm-btn-outline:hover{background-color:#eff6ff}.cm-btn-full{width:100%;margin-top:16px}.cm-grid{grid-template-columns:280px 1fr;align-items:start;gap:24px;display:grid}.cm-sidebar-panel,.cm-main-panel{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.cm-panel-title{color:#1e293b;margin:0 0 16px;font-size:1.125rem;font-weight:600}.cm-text-blue{color:#1d4ed8}.cm-search-box{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;height:40px;padding:0 12px;display:flex}.cm-search-box i{color:#94a3b8;font-size:.875rem}.cm-search-box input{color:#334155;background:0 0;border:none;outline:none;width:100%;font-size:.875rem}.cm-search-box input::placeholder{color:#94a3b8}.cm-sidebar-panel .cm-search-box{margin-bottom:16px}.cm-category-list{flex-direction:column;gap:8px;display:flex}.cm-category-item{cursor:pointer;background-color:#0000;border-radius:12px;align-items:center;padding:12px;transition:all .2s;display:flex}.cm-category-item:hover{background-color:#f8fafc}.cm-category-item.active{background-color:#eff6ff;border-left:4px solid #3b82f6}.cm-cat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;margin-right:12px;font-size:1.125rem;display:flex}.cm-cat-info{flex-direction:column;flex:1;display:flex;overflow:hidden}.cm-cat-name{color:#1e293b;margin-bottom:2px;font-size:.875rem;font-weight:600}.cm-category-item.active .cm-cat-name{color:#1d4ed8}.cm-cat-count{color:#64748b;font-size:.75rem}.cm-cat-menu-btn{color:#94a3b8;cursor:pointer;opacity:0;background:0 0;border:none;padding:4px;transition:opacity .2s}.cm-category-item:hover .cm-cat-menu-btn,.cm-category-item.active .cm-cat-menu-btn,.cm-cat-menu-container.dropdown-open .cm-cat-menu-btn{opacity:1}.cm-cat-menu-container{position:relative}.cm-dropdown-menu{z-index:10;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;min-width:120px;margin-top:4px;padding:4px;display:flex;position:absolute;top:100%;right:0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.cm-dropdown-item{color:#475569;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:4px;align-items:center;gap:8px;padding:8px 12px;font-size:.875rem;transition:all .2s;display:flex}.cm-dropdown-item:hover{color:#1e293b;background-color:#f1f5f9}.cm-dropdown-item.delete{color:#ef4444}.cm-dropdown-item.delete:hover{color:#dc2626;background-color:#fef2f2}.tone-blue{color:#3b82f6;background-color:#eff6ff}.tone-green{color:#22c55e;background-color:#f0fdf4}.tone-purple{color:#a855f7;background-color:#faf5ff}.tone-amber{color:#f59e0b;background-color:#fffbeb}.tone-red{color:#ef4444;background-color:#fef2f2}.tone-slate{color:#64748b;background-color:#f8fafc}.cm-main-toolbar{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.cm-main-toolbar .cm-search-box{width:300px}.cm-table-container{border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;overflow-x:auto}.cm-table{border-collapse:collapse;text-align:left;width:100%}.cm-table th{color:#64748b;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;padding:12px 16px;font-size:.75rem;font-weight:600}.cm-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #e2e8f0;padding:16px;font-size:.875rem}.cm-table tr:last-child td{border-bottom:none}.cm-subcat-name-cell{color:#1e293b;align-items:center;gap:12px;font-weight:500;display:flex}.cm-subcat-icon{border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;display:flex}.cm-td-desc{color:#64748b;max-width:300px}.cm-status-pill{border-radius:999px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.cm-status-pill.active{color:#166534;background-color:#dcfce7}.cm-status-pill.inactive{color:#475569;background-color:#f1f5f9}.cm-actions-group{align-items:center;gap:8px;display:flex}.cm-action-btn{cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.cm-action-btn:hover{background-color:#f8fafc}.cm-action-btn.edit-btn{color:#64748b}.cm-action-btn.delete-btn{color:#ef4444;background-color:#fff;border-color:#fee2e2}.cm-action-btn.delete-btn:hover{background-color:#fef2f2}.cm-empty-state{text-align:center;color:#64748b;padding:32px!important}.cm-pagination{justify-content:space-between;align-items:center;display:flex}.cm-page-info{color:#64748b;font-size:.875rem}.cm-page-controls{align-items:center;gap:4px;display:flex}.cm-page-btn{color:#334155;cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.cm-page-btn:disabled{opacity:.5;cursor:not-allowed}.cm-page-btn:not(:disabled):hover{background-color:#f8fafc}.cm-page-btn.active{color:#fff;background-color:#1d4ed8;border-color:#1d4ed8}@media (width<=1024px){.cm-grid{grid-template-columns:1fr}}@media (width<=768px){.cm-main-toolbar{flex-direction:column;align-items:flex-start;gap:16px}.cm-main-toolbar .cm-search-box{width:100%}.cm-pagination{flex-direction:column;align-items:flex-start;gap:16px}}.cm-modal-overlay{z-index:1000;background-color:#0f172a66;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.cm-modal{background-color:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:500px;max-height:90vh;display:flex;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.cm-modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:flex-start;padding:24px;display:flex}.cm-modal-title{color:#1e293b;margin:0;font-size:1.25rem;font-weight:600}.cm-modal-subtitle{color:#64748b;margin:4px 0 0;font-size:.875rem}.cm-modal-close{color:#64748b;cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.25rem;transition:color .2s}.cm-modal-close:hover{color:#0f172a}.cm-modal-body{flex-direction:column;gap:20px;padding:24px;display:flex;overflow-y:auto}.cm-form-group{flex-direction:column;gap:8px;display:flex}.cm-form-group label{color:#1e293b;font-size:.875rem;font-weight:600}.cm-required{color:#ef4444}.cm-form-group input,.cm-form-group textarea,.cm-form-group select{color:#1e293b;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;padding:10px 12px;font-size:.875rem;transition:border-color .2s}.cm-form-group input::placeholder,.cm-form-group textarea::placeholder{color:#94a3b8}.cm-form-group input:focus,.cm-form-group textarea:focus,.cm-form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.cm-form-group textarea{resize:vertical;min-height:80px}.cm-icon-picker{flex-wrap:wrap;gap:12px;display:flex}.cm-icon-option{color:#64748b;cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;transition:all .2s;display:flex}.cm-icon-option:hover{background-color:#f8fafc;border-color:#cbd5e1}.cm-icon-option.active{color:#3b82f6;background-color:#eff6ff;border-color:#3b82f6}.cm-color-picker{align-items:center;gap:16px;padding:4px;display:flex}.cm-color-option{cursor:pointer;border:none;border-radius:50%;width:28px;height:28px;transition:transform .2s}.cm-color-option:hover{transform:scale(1.1)}.cm-color-option.active{box-shadow:0 0 0 2px #fff,0 0 0 4px #3b82f6}.bg-color-blue{background-color:#3b82f6}.bg-color-green{background-color:#22c55e}.bg-color-purple{background-color:#a855f7}.bg-color-amber{background-color:#f59e0b}.bg-color-red{background-color:#ef4444}.bg-color-teal{background-color:#06b6d4}.bg-color-slate{background-color:#64748b}.cm-modal-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.cm-btn-cancel{color:#475569;background-color:#fff;border-color:#e2e8f0}.cm-btn-cancel:hover{background-color:#f8fafc;border-color:#cbd5e1}@media (width<=768px){.hod-dashboard{padding:10px}}.admin-dashboard{width:100%}.stat-card.purple .stat-icon{color:#7c3aed;background:#f5f3ff}.stat-card.green .stat-icon{color:#16a34a;background:#f0fdf4}.admin-overview-page{color:#0f172a;flex-direction:column;gap:18px;width:100%;padding:18px;display:flex}.admin-overview-hero{justify-content:space-between;align-items:center;gap:16px;min-height:42px;display:flex}.admin-overview-copy h1{color:#0f172a;margin:0;font-size:1.1rem;font-weight:700;line-height:1.2}.admin-overview-copy p{display:none}.admin-date-chip,.admin-ghost-select{color:#fff;background:linear-gradient(#3b82f6 0%,#2563eb 100%);border:1px solid #edf2f8;border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 16px;font-size:.84rem;font-weight:600;display:inline-flex;box-shadow:0 8px 20px #2563eb2e}.admin-date-chip svg,.admin-ghost-select svg{color:#fff}.admin-date-chip,.admin-ghost-select,.admin-link-btn,.admin-action-card{cursor:pointer}.admin-kpi-grid{grid-template-columns:repeat(5,1fr);gap:18px;margin-bottom:12px;display:grid}.admin-overview-grid{grid-template-columns:minmax(0,1.65fr) minmax(320px,1fr);gap:18px;display:grid}.admin-overview-grid-bottom{align-items:stretch}.admin-panel{padding:22px}.admin-panel-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}.admin-panel-head h2{color:#0f172a;margin:0;font-size:1.1rem;font-weight:700;line-height:1.2}.admin-link-btn{color:#3b82f6;background:0 0;border:none;padding:0;font-size:.65rem;font-weight:700;line-height:1.2}.admin-chart-legend{flex-wrap:wrap;align-items:center;gap:12px 18px;margin-bottom:12px;display:flex}.admin-legend-item{color:#475569;align-items:center;gap:8px;font-size:.92rem;font-weight:600;display:inline-flex}.admin-legend-dot{border-radius:999px;width:10px;height:10px}.admin-chart-wrap{grid-template-columns:32px minmax(0,1fr);align-items:end;gap:12px;padding-bottom:4px;display:grid;overflow-x:auto}.admin-chart-ylabels{flex-direction:column;justify-content:space-between;height:250px;padding:24px 0 34px;display:flex}.admin-chart-ylabels span,.admin-chart-xlabels span{color:#64748b;font-size:.83rem;font-weight:600}.admin-chart-stage{min-width:620px;position:relative}.admin-chart-grid{pointer-events:none;grid-template-rows:repeat(5,1fr);display:grid;position:absolute;inset:24px 0 34px}.admin-chart-grid span{border-top:1px dashed #e6edf5}.admin-line-chart{width:100%;height:250px;display:block}.admin-chart-xlabels{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin-top:4px;display:grid}.admin-alert-list{flex-direction:column;display:flex}.admin-alert-item{border-top:1px solid #edf2f7;grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:14px;padding:16px 0;display:grid}.admin-alert-item:first-child{border-top:none;padding-top:4px}.admin-alert-copy strong{color:#334155;margin-bottom:5px;font-size:.8rem;font-weight:600;line-height:1.55;display:block}.admin-alert-copy p{color:#64748b;margin:0;font-size:.72rem;line-height:1.25}.admin-alert-time{color:#64748b;white-space:nowrap;justify-self:end;font-size:.72rem}.admin-pill{white-space:nowrap;border-radius:8px;align-items:center;min-width:auto;height:auto;padding:6px 12px;font-size:.75rem;font-weight:700;line-height:1;display:inline-flex}.admin-pill.subtle{min-width:92px}.admin-action-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.admin-action-card{text-align:left;border:1px solid #e2e8f08c;border-radius:12px;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:14px;min-height:78px;padding:16px;transition:transform .2s,box-shadow .2s,border-color .2s;display:grid;box-shadow:inset 0 1px #ffffffbf}.admin-action-card:hover{border-color:#d5e3f5;transform:translateY(-2px);box-shadow:0 8px 18px #2563eb2e}.admin-action-card span{color:#2563eb;font-size:.75rem;font-weight:700;line-height:1}.admin-action-card.tone-blue{background:linear-gradient(#eef4ff 0%,#f6f9ff 100%)}.admin-action-card.tone-green{background:linear-gradient(#edf9f2 0%,#f5fcf8 100%)}.admin-action-card.tone-purple{background:linear-gradient(#f3efff 0%,#f8f5ff 100%)}.admin-action-card.tone-amber{background:linear-gradient(#fff4e8 0%,#fffbf5 100%)}.admin-action-card.tone-cyan{background:linear-gradient(#e0faff 0%,#f5fdff 100%)}.admin-action-icon{color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex;box-shadow:0 8px 18px #2563eb2e}.admin-action-card.tone-blue .admin-action-icon{background:linear-gradient(#3b82f6 0%,#2563eb 100%)}.admin-action-card.tone-green .admin-action-icon{background:linear-gradient(#22c55e 0%,#16a34a 100%)}.admin-action-card.tone-purple .admin-action-icon{background:linear-gradient(#8b5cf6 0%,#7c3aed 100%)}.admin-action-card.tone-amber .admin-action-icon{background:linear-gradient(#f59e0b 0%,#d97706 100%)}.admin-action-card.tone-cyan .admin-action-icon{background:linear-gradient(#06b6d4 0%,#0891b2 100%)}.tone-blue{color:#2563eb;background:#eff6ff}.tone-amber{color:#f59e0b;background:#fff7e8}.tone-green{color:#22c55e;background:#ecfdf3}.tone-red{color:#ef4444;background:#fff1f2}.tone-purple{color:#8b5cf6;background:#f5f3ff}.tone-cyan{color:#06b6d4;background:#ecfeff}.admin-kpi-trend.tone-blue,.admin-kpi-trend.tone-amber,.admin-kpi-trend.tone-green,.admin-kpi-trend.tone-red,.admin-pill.tone-blue,.admin-pill.tone-amber,.admin-pill.tone-green,.admin-pill.tone-red{background:0 0}.admin-pill.tone-red{color:#ef4444;background:#fff1f2}.admin-pill.tone-amber{color:#f59e0b;background:#fff7e8}.admin-pill.tone-green{color:#16a34a;background:#ecfdf3}.admin-pill.tone-blue{color:#2563eb;background:#eff6ff}@media (width<=1400px){.admin-overview-copy p{max-width:34rem}}@media (width<=1120px){.admin-overview-grid,.admin-overview-grid-bottom{grid-template-columns:1fr}.admin-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=820px){.admin-overview-page{gap:14px;padding:10px}.admin-overview-hero{flex-direction:column;align-items:flex-start}.admin-overview-copy h1{font-size:1.6rem}.admin-date-chip{justify-content:space-between;width:100%}.admin-chart-wrap{grid-template-columns:1fr}.admin-chart-ylabels{display:none}.admin-chart-stage{min-width:520px}.admin-panel,.admin-kpi-card{border-radius:16px}}@media (width<=560px){.admin-kpi-grid,.admin-action-grid{grid-template-columns:1fr}.admin-overview-page{padding:4px}.admin-panel,.admin-kpi-card{padding:18px}.admin-panel-head{flex-direction:column;align-items:flex-start}.admin-alert-item{grid-template-columns:auto 1fr;gap:12px}.admin-alert-time{grid-column:2;justify-self:start}.admin-chart-stage{min-width:460px}.admin-action-card span{max-width:none}}.dashboard-table-wrap{width:100%;overflow-x:auto}.dashboard-table th{text-transform:uppercase;color:#8c98ab;letter-spacing:.05em;text-align:left;padding:12px 16px;font-size:.6rem;font-weight:700}.category-icon.blue{color:#2563eb;background:#eef4ff}.category-icon.orange{color:#f97316;background:#fff4e8}.category-icon.indigo{color:#315efb;background:#eef2ff}.category-icon.green{color:#16a34a;background:#ecfdf5}.category-icon.purple{color:#7c3aed;background:#f3efff}.category-icon.red{color:#ef4444;background:#fef2f2}.table-status.under-review,.table-status.pending{color:#f97316;background:#fff7ed}.table-status.resolved,.table-status.completed{color:#22c55e;background:#f0fdf4}.table-status.critical,.table-status.escalated,.table-status.rejected{color:#ef4444;background:#fef2f2}.table-link-btn{color:#3b82f6;cursor:pointer;background:0 0;border:none;padding:0;font-size:.65rem;font-weight:700;line-height:1.2;transition:color .2s}.table-link-btn:hover{color:#2563eb}.table-empty{text-align:center;color:#94a3b8;padding:32px;font-style:italic}.student-cell-info{align-items:center;gap:10px;font-weight:600;display:flex}.avatar-mini{color:#475569;background:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.65rem;display:flex}.mg-page{color:#0f172a;width:100%;padding:18px}.mg-hero{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.mg-title{color:#0f172a;margin:0;font-size:1.7rem;font-weight:700;line-height:1.2}.mg-subtitle{color:#64748b;margin:6px 0 0;font-size:.98rem}.mg-hero-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.mg-btn{color:#0f172a;background:#fff;border:1px solid #dfe8f3;border-radius:12px;align-items:center;gap:10px;height:40px;padding:0 14px;font-size:.92rem;font-weight:700;display:inline-flex}.mg-btn i{font-size:.95rem}.mg-btn-primary{color:#fff;background:#2563eb;border-color:#2563eb;box-shadow:0 12px 32px -24px #2563ebb3}.mg-btn-ghost{color:#0f172a;background:#fff}.mg-panel{background:#fff;border:1px solid #dfe8f3;border-radius:18px;overflow:hidden;box-shadow:0 16px 48px -38px #0f172a57}.mg-filterbar{border-bottom:1px solid #eef2f7;padding:16px 16px 10px}.mg-filter-grid{grid-template-columns:repeat(6,minmax(0,1fr));align-items:end;gap:12px;display:grid}.mg-filter{flex-direction:column;gap:6px;display:flex}.mg-filter span{color:#64748b;font-size:.78rem;font-weight:700}.mg-filter select,.mg-filter-control,.mg-filter input[type=text]{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:12px;height:42px;font-size:.9rem;font-weight:600}.mg-filter select{padding:0 12px}.mg-filter-control{align-items:center;gap:10px;padding:0 12px;display:flex}.mg-filter-control i{color:#64748b}.mg-filter-control input{color:#0f172a;background:0 0;border:none;outline:none;width:100%;font-size:.9rem;font-weight:600}.mg-link{color:#2563eb;background:0 0;border:none;justify-content:flex-end;align-items:center;gap:8px;height:42px;padding:0 4px;font-size:.9rem;font-weight:700;display:inline-flex}.mg-tabs{border-bottom:1px solid #eef2f7;align-items:center;gap:12px;padding:0 16px;display:flex;overflow-x:auto}.mg-tab{color:#64748b;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:14px 6px;font-size:.9rem;font-weight:700}.mg-tab.active{color:#2563eb;border-bottom-color:#2563eb}.mg-tab-count{font-weight:700}.mg-footer{justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.mg-results{color:#64748b;font-size:.86rem;font-weight:700}.mg-pagination{align-items:center;gap:8px;display:inline-flex}.mg-page-btn{color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.mg-page-active{color:#fff;background:#2563eb;border-color:#2563eb}.mg-rows{color:#64748b;white-space:nowrap;align-items:center;gap:10px;font-size:.86rem;font-weight:700;display:inline-flex}.mg-rows select{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:10px;height:34px;padding:0 10px;font-weight:700}@media (width<=1120px){.mg-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.mg-link{justify-content:flex-start;padding:0}}@media (width<=820px){.mg-page{padding:10px}.mg-hero{flex-direction:column;align-items:flex-start}.mg-hero-actions{width:100%}.mg-filter-grid{grid-template-columns:1fr}.mg-footer{flex-direction:column;align-items:flex-start}.mg-pagination{width:100%}.mg-rows{justify-content:space-between;width:100%}}.mu-page{background-color:#f8fafc;min-height:100vh;padding:24px;font-family:Inter,system-ui,-apple-system,sans-serif}.mu-hero{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.mu-title{color:#0f172a;letter-spacing:-.02em;margin:0 0 6px;font-size:1.75rem;font-weight:800}.mu-subtitle{color:#64748b;margin:0;font-size:.875rem;font-weight:500}.mu-actions{gap:12px;display:flex}.mu-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;height:40px;padding:0 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.mu-btn-primary{color:#fff;background-color:#2563eb}.mu-btn-primary:hover{background-color:#1d4ed8}.mu-btn-outline{color:#1e293b;background-color:#fff;border:1px solid #e2e8f0}.mu-btn-outline:hover{background-color:#f8fafc}.mu-kpis{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px;display:grid}.mu-panel{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.mu-filters{flex-wrap:wrap;align-items:flex-end;gap:16px;padding:16px 20px;display:flex}.mu-filter{flex-direction:column;flex:1;gap:6px;min-width:160px;display:flex}.mu-filter label{color:#94a3b8;font-size:.7rem;font-weight:700}.mu-filter select{color:#334155;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;height:42px;padding:0 12px;font-size:.8125rem;font-weight:600}.mu-search{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:2;align-items:center;gap:8px;min-width:200px;height:42px;padding:0 12px;display:flex}.mu-search i{color:#94a3b8;font-size:.875rem}.mu-search input{color:#1e293b;background:0 0;border:none;outline:none;width:100%;font-size:.8125rem;font-weight:500}.mu-filter-btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;height:40px;padding:0 16px;font-size:.875rem;font-weight:600;display:flex}.mu-clear{color:#2563eb;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;height:40px;padding:0 12px;font-size:.875rem;font-weight:600;display:flex}.mu-tabs{border-bottom:1px solid #e2e8f0;gap:24px;padding:0 20px;display:flex}.mu-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:16px 4px;font-size:.8125rem;font-weight:600}.mu-tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:700}.mu-table-container{overflow-x:auto}.mu-table{border-collapse:collapse;text-align:left;width:100%}.mu-table th{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9;padding:16px 20px;font-size:.65rem;font-weight:700}.mu-table td{color:#475569;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:16px 20px;font-size:.8125rem;font-weight:500}.mu-td-id{font-size:.8125rem;color:#0f172a!important;font-weight:700!important}.mu-td-name{font-size:.875rem;color:#0f172a!important;font-weight:700!important}.mu-td-email,.mu-td-dept,.mu-td-date{font-size:.8125rem;font-weight:500;color:#64748b!important}.mu-table tr:last-child td{border-bottom:none}.mu-user{align-items:center;gap:12px;font-weight:600;display:flex}.mu-avatar{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex}.mu-avatar-blue{color:#3b82f6;background:#eff6ff}.mu-avatar-green{color:#22c55e;background:#f0fdf4}.mu-avatar-purple{color:#a855f7;background:#faf5ff}.mu-avatar-amber{color:#f59e0b;background:#fffbeb}.mu-pill{text-align:center;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-block}.mu-pill-student{color:#3b82f6;background:#eff6ff}.mu-pill-hod{color:#a855f7;background:#faf5ff}.mu-pill-staff{color:#f59e0b;background:#fffbeb}.mu-pill-active{color:#166534;background:#dcfce7}.mu-pill-inactive{color:#ef4444;background:#fef2f2}.mu-actions-col{gap:8px;display:flex}.mu-icon-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.mu-icon-btn:hover{background:#f8fafc}.mu-footer{border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.mu-results{color:#64748b;font-size:.875rem}.mu-pagination{align-items:center;gap:4px;display:flex}.mu-page-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;font-size:.875rem;font-weight:500;display:flex}.mu-page-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.mu-rows{color:#64748b;align-items:center;gap:8px;font-size:.875rem;display:flex}.mu-rows select{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:6px;outline:none;height:32px;padding:0 8px}@media (width<=1200px){.mu-kpis{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.mu-hero{flex-direction:column;gap:16px}.mu-kpis{grid-template-columns:1fr}.mu-footer{flex-direction:column;gap:16px}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#0f172a66;justify-content:center;align-items:center;padding:20px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-container{background:#fff;border:1px solid #edf2f7;border-radius:24px;flex-direction:column;width:100%;max-height:90vh;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:flex-start;gap:16px;padding:24px 28px;display:flex}.modal-title-wrap h2{color:#0f172a;margin:0;font-size:1.25rem;font-weight:800;line-height:1.2}.modal-title-wrap p{color:#64748b;margin:6px 0 0;font-size:.88rem;font-weight:600}.modal-close-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .2s;display:flex}.modal-close-btn:hover{color:#0f172a;background:#f8fafc;transform:rotate(90deg)}.modal-body{flex:1;padding:24px 28px;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:#f8fafc}.modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}.modal-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (width<=640px){.modal-container{border-radius:20px}.modal-header,.modal-body{padding:20px}}.student-page{flex-direction:column;gap:24px;display:flex}.dashboard-page{gap:14px}.dashboard-card{background:#fff;border:1px solid #edf2f8;border-radius:14px;box-shadow:0 10px 30px #0f172a0d}.dashboard-topbar{justify-content:space-between;align-items:center;min-height:42px;display:flex}.dashboard-primary-btn{color:#fff;background:linear-gradient(#3b82f6 0%,#2563eb 100%);border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 16px;font-size:.84rem;font-weight:600;line-height:1;display:inline-flex;box-shadow:0 8px 20px #2563eb2e}.dashboard-primary-btn.full-width{justify-content:center;width:100%}.dashboard-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.dashboard-main-grid{grid-template-columns:minmax(0,1fr) 284px;align-items:stretch;gap:14px;display:grid}.dashboard-bottom-grid{grid-template-columns:minmax(0,1fr) 286px;align-items:stretch;gap:14px;display:grid}.quick-actions-card,.activity-card,.overview-card,.help-card{padding:18px 16px}.quick-actions-card{min-width:0}.grievances-card,.category-card,.combined-stats-card{padding:16px 0 10px}.combined-stats-grid{grid-template-columns:1fr 1.2fr;gap:0;height:100%;display:grid}.stats-col{padding:0}.stats-col:first-child{border-right:1px solid #f1f5f9}.dashboard-section-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;padding:0 16px;display:flex}.quick-actions-card .dashboard-section-head,.activity-card .dashboard-section-head,.overview-card .dashboard-section-head,.help-card .dashboard-section-head{padding:0}.dashboard-section-head h2{color:#0f172a;font-size:1.1rem;font-weight:700;line-height:1.2}.text-link-btn,.table-link-btn,.view-all-link{color:#3b82f6;font-size:.65rem;font-weight:700;line-height:1.2;transition:color .2s}.text-link-btn:hover,.table-link-btn:hover,.view-all-link:hover{color:#2563eb}.quick-actions-list{flex-direction:column;gap:12px;display:flex}.quick-action-item{text-align:left;border:1px solid #e2e8f08c;border-radius:12px;grid-template-columns:36px minmax(0,1fr) 14px;align-items:center;gap:14px;width:100%;min-height:78px;padding:16px;display:grid;box-shadow:inset 0 1px #ffffffbf}.quick-action-item.blue{background:linear-gradient(#eef4ff 0%,#f6f9ff 100%)}.quick-action-item.green{background:linear-gradient(#edf9f2 0%,#f5fcf8 100%)}.quick-action-item.purple{background:linear-gradient(#f3efff 0%,#f8f5ff 100%)}.quick-action-icon{color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex;box-shadow:0 8px 18px #2563eb2e}.quick-action-copy{min-width:0}.quick-action-item.blue .quick-action-icon{background:linear-gradient(#3b82f6 0%,#2563eb 100%)}.quick-action-item.green .quick-action-icon{background:linear-gradient(#22c55e 0%,#16a34a 100%)}.quick-action-item.purple .quick-action-icon{background:linear-gradient(#8b5cf6 0%,#7c3aed 100%)}.quick-action-copy strong{color:#2563eb;white-space:normal;max-width:100%;margin-bottom:6px;font-size:.75rem;font-weight:700;line-height:1;display:block}.quick-action-item.green .quick-action-copy strong{color:#15803d}.quick-action-item.purple .quick-action-copy strong{color:#6d28d9}.quick-action-copy small{color:#718198;max-width:150px;font-size:.72rem;line-height:1.25;display:block}.quick-action-arrow{color:#64748b;flex-shrink:0;justify-self:end;font-size:.95rem}.dashboard-table-wrap{overflow-x:auto}.dashboard-table{border-collapse:collapse;width:100%}.dashboard-table th{text-transform:uppercase;color:#8c98ab;letter-spacing:.05em;padding:12px 16px;font-size:.6rem;font-weight:700}.dashboard-table td{vertical-align:middle;color:#334155;border-bottom:1px solid #f1f5f9;padding:16px;font-size:.7rem}.ticket-id-cell{color:#0f172a;white-space:nowrap;font-weight:700}.category-cell{align-items:center;gap:12px;display:flex}.category-icon{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;display:flex}.subject-cell{color:#1e293b;max-width:240px;font-weight:700;line-height:1.4}.table-status{white-space:nowrap;border-radius:8px;align-items:center;padding:6px 12px;font-size:.75rem;font-weight:700;line-height:1;display:inline-flex}.table-status.under-review{color:#f97316;background:#fff7ed}.table-status.in-progress{color:#3b82f6;background:#eff6ff}.table-status.resolved{color:#22c55e;background:#f0fdf4}.dashboard-card-footer{padding:14px 16px 2px}.dashboard-card-footer.center{justify-content:center;display:flex}.view-all-link{align-items:center;gap:8px;display:inline-flex}.activity-list{flex-direction:column;gap:16px;display:flex}.activity-item{grid-template-columns:40px 1fr 9px;align-items:flex-start;gap:12px;display:grid}.activity-icon{border-radius:50%;width:40px;height:40px;font-size:1rem}.activity-copy p{color:#334155;margin-bottom:5px;font-size:.8rem;font-weight:600;line-height:1.55}.activity-copy small{color:#64748b;font-size:.72rem;line-height:1.25}.activity-dot{background:#d5dbe5;border-radius:50%;width:6px;height:6px;margin-top:15px}.activity-item:first-child .activity-dot{background:#2563eb}.overview-body{grid-template-columns:144px 1fr;align-items:center;gap:24px;padding:8px 16px 16px;display:grid}.donut-chart{background:conic-gradient(#4cb782 0deg 210deg,#3b82f6 210deg 270deg,#f59e0b 270deg 360deg,#8b5cf6 360deg 360deg);border-radius:50%;justify-content:center;align-items:center;width:122px;height:122px;display:flex}.overview-legend{flex-direction:column;gap:12px;display:flex}.legend-row{grid-template-columns:120px 1fr;align-items:center;gap:24px;display:grid}.legend-label{color:#050505;align-items:center;gap:10px;font-size:.8rem;font-weight:600;display:inline-flex}.legend-dot{border-radius:50%;width:9px;height:9px}.legend-dot.green{background:#4cb782}.legend-dot.blue{background:#3b82f6}.legend-dot.orange{background:#f59e0b}.legend-dot.purple{background:#8b5cf6}.legend-row strong{color:#0f172a;font-size:.8rem}.legend-value{align-items:center;gap:6px;display:flex}.legend-value strong{color:#0f172a;font-size:.8rem;font-weight:700}.legend-value span{color:#94a3b8;font-size:.75rem;font-weight:500}.category-chart{padding:0 16px 8px}.category-row{grid-template-columns:102px 1fr 18px;align-items:center;gap:10px;margin-bottom:13px;display:grid}.category-name{color:#64748b;font-size:.64rem;font-weight:600;line-height:1.2}.category-bar-track{background:#f1f5f9;border-radius:999px;height:8px;overflow:hidden}.category-bar-fill{border-radius:inherit;background:linear-gradient(90deg,#2f73f6 0%,#60a5fa 100%);height:100%;display:block}.category-value{color:#334155;font-size:.78rem}.category-axis{color:#94a3b8;border-top:1px solid #f1f5f9;grid-template-columns:repeat(7,1fr);margin-left:112px;padding-top:10px;font-size:.75rem;display:grid;position:relative}.category-axis span{justify-content:center;display:flex;position:relative}.category-axis span:before{content:"";background:#e2e8f0;width:1px;height:6px;position:absolute;top:-10px;left:50%}.help-card{flex-direction:column;justify-content:center;gap:16px;min-height:100%;display:flex}.help-icon-wrap{color:#2563eb;background:#eef4ff;border-radius:50%;width:68px;height:68px;font-size:1.6rem}.help-copy h2{margin-bottom:8px}.help-copy p{color:#64748b;font-size:.76rem;line-height:1.5}.hero-panel,.panel{background:#fff;border:1px solid #e2e8f0;border-radius:20px;box-shadow:0 18px 40px #0f172a0d}.hero-panel{grid-template-columns:1.3fr 1fr;align-items:center;gap:24px;padding:28px;display:grid}.hero-panel h1,.panel h1,.panel h2{color:#0f172a}.hero-panel p,.panel p{color:#64748b;line-height:1.6}.section-tag{color:#2563eb;background:#eff6ff;border-radius:999px;align-items:center;margin-bottom:12px;padding:7px 12px;font-size:.8rem;font-weight:600;display:inline-flex}.hero-stats,.content-grid,.contact-grid,.detail-grid{gap:16px;display:grid}.hero-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card,.info-card,.contact-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:20px}.stat-card strong{color:#0f172a;font-size:1.8rem;display:block}.stat-card span,.contact-card span{color:#64748b}.content-grid{grid-template-columns:minmax(0,1.5fr) minmax(300px,.9fr)}.panel{padding:24px}.panel.stack{flex-direction:column;gap:16px;display:flex}.panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.data-table{overflow-x:auto}.data-table table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:14px 12px;font-size:.92rem}.data-table th{color:#475569;background:#f8fafc;font-weight:700}.table-empty{text-align:center;color:#64748b}.status-pill{border-radius:999px;align-items:center;padding:6px 10px;font-size:.78rem;font-weight:700;display:inline-flex}.status-pill.in-review,.status-pill.student-access{color:#1d4ed8;background:#dbeafe}.status-pill.awaiting-documents{color:#b45309;background:#fef3c7}.status-pill.resolved{color:#15803d;background:#dcfce7}.status-pill.escalated{color:#b91c1c;background:#fee2e2}.simple-list{color:#475569;padding-left:18px;line-height:1.8}.form-panel{max-width:960px}.grievance-form,.faq-list,.timeline-list{flex-direction:column;gap:18px;display:flex}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.grievance-form label{color:#334155;flex-direction:column;gap:8px;font-weight:600;display:flex}.grievance-form input,.grievance-form select,.grievance-form textarea{width:100%;font:inherit;color:#0f172a;background:#fff;border:1px solid #dbe4f0;border-radius:14px;padding:13px 14px}.form-actions,.pill-row,.unauthorized-actions{flex-wrap:wrap;gap:12px;display:flex}.primary-btn,.secondary-btn{border-radius:12px;min-height:46px;padding:11px 16px;font-weight:600}.primary-btn{color:#fff;background:#2563eb}.secondary-btn{color:#0f172a;background:#e2e8f0}.filter-pill{color:#475569;background:#f1f5f9;border-radius:999px;align-items:center;padding:8px 12px;font-size:.82rem;font-weight:600;display:inline-flex}.filter-pill.active{color:#2563eb;background:#eff6ff}.timeline-item,.faq-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:18px 20px}.timeline-item{grid-template-columns:18px 1fr;align-items:start;gap:14px;display:grid}.timeline-dot{background:#2563eb;border-radius:50%;width:12px;height:12px;margin-top:6px}.timeline-meta{justify-content:space-between;gap:16px;margin-bottom:6px;display:flex}.timeline-meta span{color:#64748b;white-space:nowrap;font-size:.82rem}.profile-grid{grid-template-columns:minmax(280px,.8fr) minmax(0,1.2fr)}.profile-card{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.profile-avatar{color:#fff;background:#2563eb;border-radius:28px;justify-content:center;align-items:center;width:84px;height:84px;font-size:2rem;font-weight:700;display:flex}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-grid div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:18px}.detail-grid span{color:#64748b;margin-bottom:8px;font-size:.84rem;display:block}.contact-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.contact-card h3{margin-bottom:8px}.contact-card p{color:#2563eb;margin-bottom:12px;font-weight:600}@media (width<=1024px){.dashboard-main-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.grievances-card,.activity-card{grid-column:1/-1}.dashboard-bottom-grid,.combined-stats-grid{grid-template-columns:1fr}.stats-col:first-child{border-bottom:1px solid #f1f5f9;border-right:none;margin-bottom:16px;padding-bottom:16px}.help-card{grid-column:1/-1}.dashboard-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-stats,.detail-grid,.field-grid{grid-template-columns:1fr}}@media (width<=768px){.dashboard-topbar{justify-content:stretch}.dashboard-primary-btn{justify-content:center;width:100%;min-height:42px;font-size:.82rem}.dashboard-summary-grid,.dashboard-main-grid,.dashboard-bottom-grid{grid-template-columns:1fr}.grievances-card,.activity-card,.help-card{grid-column:auto}.summary-card{grid-template-columns:48px 1fr;gap:12px;min-height:auto;padding:16px 14px}.summary-icon{width:48px;height:48px;font-size:1.25rem}.summary-head strong{font-size:1.75rem}.summary-content p,.quick-action-copy small,.help-copy p,.activity-copy small{font-size:.73rem}.quick-action-copy strong,.activity-copy p,.legend-label,.category-name,.category-value{font-size:.77rem}.quick-action-item{grid-template-columns:34px minmax(0,1fr) 14px;gap:12px;min-height:72px;padding:14px}.quick-action-copy strong{font-size:.82rem}.quick-action-copy small{max-width:none;font-size:.7rem}.dashboard-table th,.dashboard-table td{padding:12px 10px;font-size:.74rem}.table-status{padding:5px 8px;font-size:.66rem}.text-link-btn,.table-link-btn,.view-all-link{font-size:.78rem}.overview-body,.category-row{grid-template-columns:1fr}.overview-body{text-align:center;justify-items:center}.category-axis{margin-left:0}.dashboard-card{border-radius:12px}.quick-actions-card,.activity-card,.overview-card,.help-card{padding:16px 14px}.grievances-card,.category-card{padding-top:14px}.dashboard-section-head,.panel,.hero-panel{border-radius:12px;padding:16px 14px}.panel-header,.timeline-meta{flex-direction:column}}@media (width<=560px){.dashboard-page{gap:12px}.dashboard-section-head{flex-direction:row;align-items:center;margin-bottom:12px}.dashboard-section-head h2{font-size:.9rem}.summary-head{flex-direction:column;gap:8px}.category-cell{max-width:none}.dashboard-table{min-width:640px}.activity-item{grid-template-columns:36px 1fr 8px}.activity-icon{width:36px;height:36px;font-size:.9rem}}.notifications-header{margin-bottom:24px}.notifications-header h1{color:#0f172a;margin-bottom:6px;font-size:1.25rem;font-weight:700}.notifications-header p{color:#64748b;font-size:.8rem}.notifications-container{background:#fff;border-radius:12px;overflow:hidden}.notifications-tabs{border-bottom:1px solid #f1f5f9;gap:24px;padding:16px 24px;display:flex}.tab-btn{color:#334155;background:0 0;border-radius:10px;align-items:center;gap:8px;padding:8px 16px;font-size:.78rem;font-weight:700;transition:all .2s;display:flex}.tab-btn.active{color:#2563eb;background:#eff6ff}.tab-btn .badge{color:#fff;background:#3b82f6;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:2px 6px;font-size:.7rem;font-weight:700;display:inline-flex}.notification-item{cursor:pointer;border-bottom:1px solid #f8fafc;gap:16px;padding:18px 24px;transition:background .2s;display:flex}.notification-item:hover{background:#fcfdfe}.notification-item:last-child{border-bottom:none}.notification-icon-wrap{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;display:flex}.notification-icon-wrap.blue{color:#2563eb;background:#eff6ff}.notification-icon-wrap.green{color:#16a34a;background:#ecfdf5}.notification-icon-wrap.orange{color:#f97316;background:#fff7ed}.notification-icon-wrap.purple{color:#7c3aed;background:#f5f3ff}.notification-content{justify-content:space-between;gap:20px;width:100%;display:flex}.notification-main{flex:1}.notification-main h3{color:#0f172a;margin-bottom:4px;font-size:.85rem;font-weight:700}.notification-main p{color:#64748b;font-size:.75rem;line-height:1.5}.notification-meta{white-space:nowrap;flex-shrink:0;align-items:center;gap:12px;display:flex}.notification-meta .time{color:#94a3b8;font-size:.72rem;font-weight:500}.status-dot{background:#e2e8f0;border-radius:50%;width:8px;height:8px}.status-dot.active{background:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}@media (width<=768px){.notification-item{gap:12px;padding:16px}.notification-icon-wrap{width:40px;height:40px;font-size:1rem}.notification-content{flex-direction:column;gap:8px}.notification-meta{justify-content:space-between;width:100%}}.profile-page{width:100%}.profile-header{margin-bottom:24px}.profile-header h1{color:#0f172a;margin-bottom:6px;font-size:1.25rem;font-weight:700}.profile-header p{color:#64748b;font-size:.8rem}.profile-hero-card{background:#fff;justify-content:space-between;align-items:center;margin-bottom:24px;padding:32px;display:flex}.profile-hero-content{align-items:center;gap:28px;display:flex}.profile-avatar-wrapper{position:relative}.profile-hero-avatar{color:#fff;background:#2563eb;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;font-size:2.5rem;font-weight:700;display:flex}.avatar-edit-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;display:flex;position:absolute;bottom:0;right:0;box-shadow:0 4px 12px #0000001a}.name-row{align-items:center;gap:12px;margin-bottom:8px;display:flex}.name-row h2{color:#0f172a;font-size:1.25rem;font-weight:700}.role-badge{color:#3b82f6;background:#eff6ff;border-radius:999px;padding:2px 10px;font-size:.75rem;font-weight:600}.dept-text{color:#1e293b;margin-bottom:4px;font-size:.85rem;font-weight:600}.univ-text{color:#64748b;margin-bottom:16px;font-size:.85rem}.contact-row{gap:24px;display:flex}.contact-row span{color:#475569;align-items:center;gap:8px;font-size:.8rem;display:flex}.contact-row i{color:#94a3b8}.edit-profile-btn{color:#3b82f6;cursor:pointer;background:0 0;border:1px solid #3b82f6;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.edit-profile-btn:hover{background:#eff6ff}.profile-main-grid{grid-template-columns:1.3fr 1fr;gap:24px;display:grid}.card-head{border-bottom:1px solid #f1f5f9;padding:20px 24px}.info-list{padding:12px 24px}.info-item{border-bottom:1px solid #f8fafc;justify-content:space-between;padding:13px 0;display:flex}.info-item:last-child{border-bottom:none}.info-label{color:#64748b;font-size:.8rem;font-weight:500}.info-value{color:#1e293b;font-size:.8rem;font-weight:600}.profile-side-col{flex-direction:column;gap:24px;display:flex}.settings-list,.sessions-list{flex-direction:column;gap:20px;padding:24px;display:flex}.setting-item{justify-content:space-between;align-items:center;display:flex}.setting-label span{color:#64748b;margin-bottom:4px;font-size:.75rem;display:block}.setting-label strong{color:#1e293b;font-size:.85rem}.outline-btn{color:#3b82f6;cursor:pointer;background:0 0;border:1px solid #3b82f6;border-radius:8px;padding:8px 16px;font-size:.8rem;font-weight:600}.select-wrapper select{color:#475569;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E") right 8px center/16px no-repeat;border:1px solid #e2e8f0;border-radius:8px;min-width:120px;padding:8px 32px 8px 12px;font-size:.8rem}.session-item{background:#f0fdf4;border-radius:12px;gap:16px;padding:16px;display:flex}.session-icon{color:#16a34a;background:#dcfce7;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.session-info{flex:1}.session-head{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.session-head strong{color:#1e293b;font-size:.85rem}.active-badge{color:#16a34a;text-transform:uppercase;font-size:.7rem;font-weight:700}.session-info p{color:#64748b;font-size:.75rem}.logout-all-btn{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #fee2e2;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.logout-all-btn:hover{background:#fef2f2;border-color:#fca5a5}@media (width<=1024px){.profile-main-grid{grid-template-columns:1fr}}@media (width<=768px){.profile-hero-card{flex-direction:column;align-items:flex-start;gap:20px;padding:24px}.contact-row{flex-direction:column;gap:10px}}@media (width<=576px){.profile-hero-card{text-align:center;align-items:center;padding:24px 16px}.profile-hero-content{flex-direction:column;gap:16px;width:100%}.name-row{flex-direction:column;gap:8px}.contact-row{align-items:center;width:100%}.edit-profile-btn{justify-content:center;width:100%}.setting-item{flex-direction:column;align-items:flex-start;gap:12px}.setting-label,.outline-btn,.select-wrapper select{width:100%}.session-item{text-align:center;flex-direction:column;align-items:center}.session-head{flex-direction:column;gap:4px}}.al-page{background-color:#f8fafc;min-height:100vh;padding:24px;font-family:Inter,system-ui,-apple-system,sans-serif}.al-header{margin-bottom:24px}.al-title{color:#0f172a;letter-spacing:-.02em;margin:0 0 6px;font-size:1.75rem;font-weight:800}.al-subtitle{color:#64748b;margin:0;font-size:.875rem;font-weight:500}.al-filter-panel{background:#fff;border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:24px;padding:16px 20px;display:flex;box-shadow:0 1px 3px #0000000d}.al-filter-group{flex-direction:column;flex:1;gap:6px;min-width:180px;display:flex}.al-filter-group label{color:#94a3b8;font-size:.75rem;font-weight:700}.al-select-wrapper{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;height:42px;padding:0 12px;display:flex;position:relative}.al-select-content{color:#1e293b;align-items:center;gap:10px;font-size:.7rem;font-weight:600;display:flex}.al-select-icon{color:#94a3b8;font-size:.875rem}.al-select-chevron{color:#94a3b8;font-size:.75rem}.al-filter-btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;height:42px;padding:0 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.al-filter-btn:hover{background:#f8fafc}.al-reset-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;height:42px;padding:0 12px;font-size:.875rem;font-weight:600;display:flex}.al-table-panel{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.al-table-container{overflow-x:auto}.al-table{border-collapse:collapse;text-align:left;width:100%}.al-table th{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9;padding:16px 20px;font-size:.65rem;font-weight:700}.al-table td{color:#475569;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:16px 20px;font-size:.8125rem;font-weight:500}.al-table tr:last-child td{border-bottom:none}.al-id-cell{color:#1e293b;font-weight:700}.al-actor-cell{align-items:center;gap:12px;display:flex}.al-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex}.al-actor-info{flex-direction:column;display:flex}.al-actor-name{color:#0f172a;font-weight:700}.al-actor-email{color:#94a3b8;font-size:.75rem}.al-action-badge{text-transform:uppercase;border-radius:6px;padding:4px 10px;font-size:.65rem;font-weight:800;display:inline-block}.al-action-create{color:#15803d;background:#dcfce7}.al-action-update{color:#1d4ed8;background:#eff6ff}.al-action-delete{color:#b91c1c;background:#fee2e2}.al-entity-id{color:#2563eb;font-weight:700;text-decoration:none}.al-metadata{white-space:nowrap;text-overflow:ellipsis;color:#64748b;max-width:300px;overflow:hidden}.al-view-btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.al-view-btn:hover{background:#f8fafc}.al-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.al-results-info{color:#64748b;font-size:.8125rem;font-weight:500}.al-pagination{align-items:center;gap:6px;display:flex}.al-page-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;font-size:.8125rem;font-weight:600;display:flex}.al-page-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.al-page-btn.disabled{opacity:.5;cursor:not-allowed}.al-page-ellipsis{color:#94a3b8;font-size:.8125rem}.al-rows-selector{color:#64748b;align-items:center;gap:8px;font-size:.8125rem;font-weight:500;display:flex}.al-rows-selector select{color:#1e293b;appearance:none;cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E") right 6px center/12px no-repeat;border:1px solid #e2e8f0;border-radius:6px;height:32px;padding:0 24px 0 8px;font-size:.8125rem;font-weight:600}.bg-blue{background-color:#3b82f6}.bg-purple{background-color:#a855f7}.bg-orange{background-color:#f97316}.bg-teal{background-color:#14b8a6}.bg-rose{background-color:#f43f5e}.hostel-management-page{box-sizing:border-box;width:100%;animation:.4s fadeIn}@keyframes scaleIn{to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.hostel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:32px;display:flex}.hostel-header h1{color:#1e1b4b;letter-spacing:-.5px;margin:0;font-family:Outfit,Inter,sans-serif;font-size:28px;font-weight:700}.hostel-actions{align-items:center;gap:16px;display:flex}.search-wrapper{align-items:center;display:flex;position:relative}.search-input{color:#0f172a;background-color:#fff;border:1px solid #e2e8f0;border-radius:10px;outline:none;width:260px;padding:10px 40px 10px 16px;font-family:inherit;font-size:14px;transition:all .25s;box-shadow:0 1px 3px #00000005}.search-input::placeholder{color:#94a3b8}.search-input:focus{border-color:#2563eb;width:320px;box-shadow:0 0 0 3px #2563eb1f}.search-icon{color:#64748b;pointer-events:none;font-size:16px;transition:color .25s;position:absolute;right:14px}.search-input:focus+.search-icon{color:#2563eb}.add-hostel-btn{color:#fff;cursor:pointer;background-color:#1d4ed8;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .25s;display:flex;box-shadow:0 4px 12px #1d4ed82e}.add-hostel-btn:hover{background-color:#1e40af;transform:translateY(-1px);box-shadow:0 6px 16px #1d4ed840}.add-hostel-btn:active{transform:translateY(0)}.add-hostel-btn i{font-size:14px}.hostels-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px;margin-bottom:40px;display:grid}.hostel-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -1px #00000003}.hostel-card:hover{transform:translateY(-6px);box-shadow:0 12px 25px -5px #0000000d,0 8px 10px -6px #00000008}.hostel-card-header{justify-content:center;align-items:center;height:110px;display:flex;position:relative}.hostel-card-bg-graphic{pointer-events:none;background-image:url(/assets/hostel-card-bg-CMol4vaU.png);background-position:bottom;background-repeat:no-repeat;background-size:cover;position:absolute;inset:0}.hostel-badge-circle{z-index:2;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;transition:transform .3s;display:flex;position:relative;box-shadow:0 4px 10px #00000014}.hostel-card:hover .hostel-badge-circle{transform:scale(1.1)}.hostel-card-body{text-align:center;flex-direction:column;flex-grow:1;align-items:center;padding:24px 20px;display:flex}.hostel-card h3{color:#0f172a;margin:0;font-size:16px;font-weight:700;line-height:1.3}.hostel-card-divider{opacity:.5;border-radius:1px;width:48px;height:2px;margin:12px 0 20px}.hostel-card-stats-row{gap:12px;width:100%;margin-bottom:24px;display:flex}.hostel-stat-box{background-color:#fff;border:1px solid #f1f5f9;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 0;transition:border-color .2s;display:flex}.hostel-stat-box:hover{border-color:#e2e8f0}.hostel-stat-box strong{color:#0f172a;font-size:18px;font-weight:700;line-height:1}.hostel-stat-box span{font-size:13px;font-weight:500}.view-details-link{cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-top:auto;padding:0;font-size:14px;font-weight:600;transition:all .2s;display:flex}.view-details-link i,.view-details-link svg{font-size:16px;transition:transform .2s}.view-details-link:hover i,.view-details-link:hover svg{transform:translate(4px)}.empty-search-state{text-align:center;background:#fff;border:1px dashed #cbd5e1;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;margin-bottom:40px;padding:60px 20px;display:flex}.empty-search-state i{color:#94a3b8;margin-bottom:16px;font-size:40px}.empty-search-state p{color:#64748b;margin:0;font-size:15px}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;background-color:#0f172a59;justify-content:center;align-items:center;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.modal-content-card{box-sizing:border-box;background:#fff;border-radius:12px;width:600px;max-width:90%;max-height:92vh;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleIn;position:relative;overflow:hidden;box-shadow:0 10px 25px #0000001a}.modal-header{border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;margin:0;padding:16px 24px;display:flex}.modal-header-badge{color:#2563eb;background-color:#eff6ff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.modal-header h2{color:#0f172a;flex-grow:1;margin:0;font-family:inherit;font-size:18px;font-weight:600}.modal-close-btn-alt{cursor:pointer;color:#64748b;background:0 0;border:none;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:20px;transition:color .2s;display:flex}.modal-close-btn-alt:hover{color:#0f172a}.hostel-form{flex-direction:column;gap:24px;margin:0;padding:24px;display:flex}.form-group-label{color:#1e293b;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.form-group-label span{color:#ef4444;margin-left:2px}.form-input-group{align-items:center;gap:12px;width:100%;display:flex}.form-badge-icon{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;display:flex}.form-badge-icon.badge-blue{background-color:#2563eb}.form-badge-icon.badge-green{background-color:#22c55e}.form-badge-icon.badge-purple{background-color:#8b5cf6}.form-badge-icon.badge-orange{background-color:#f97316}.form-input-themed{box-sizing:border-box;color:#1e293b;background-color:#fff;border-radius:6px;outline:none;flex-grow:1;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.form-input-themed::placeholder{color:#94a3b8}.form-input-themed.border-blue{border:1px solid #93c5fd}.form-input-themed.border-blue:focus{border-color:#3b82f6}.form-input-themed.border-green{border:1px solid #86efac}.form-input-themed.border-green:focus{border-color:#22c55e}.form-input-themed.border-orange{border:1px solid #fdba74}.form-input-themed.border-orange:focus{border-color:#f97316}.form-grid-row{grid-template-columns:1fr 1fr;gap:24px;display:grid}.dropdown-wrapper{flex-grow:1;align-items:center;display:flex;position:relative}.dropdown-select{appearance:none;cursor:pointer;padding-right:36px!important}.dropdown-chevron{color:#0f172a;pointer-events:none;font-size:14px;position:absolute;right:14px}.toggle-switch-wrapper{align-items:center;gap:12px;display:flex}.toggle-switch-pill{cursor:pointer;background-color:#cbd5e1;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background-color .2s;display:inline-block;position:relative}.toggle-switch-pill.active{background-color:#8b5cf6}.toggle-switch-knob{background-color:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000001a}.toggle-switch-pill.active .toggle-switch-knob{transform:translate(20px)}.toggle-switch-label{color:#1e293b;-webkit-user-select:none;user-select:none;font-size:14px;font-weight:500}.modal-footer{background-color:#fff;border-top:1px solid #f1f5f9;justify-content:flex-end;gap:12px;margin:0;padding:16px 24px;display:flex}.btn-cancel{color:#64748b;cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:9px 18px;font-size:14px;font-weight:500;transition:all .2s}.btn-cancel:hover{color:#334155;background-color:#f8fafc}.btn-submit{color:#fff;cursor:pointer;background-color:#2563eb;border:none;border-radius:6px;align-items:center;gap:8px;padding:9px 18px;font-size:14px;font-weight:500;transition:background-color .2s;display:flex}.btn-submit:hover{background-color:#1d4ed8}.drilldown-page-container{background:#fff;border-radius:12px;margin-top:10px;padding:10px;box-shadow:0 4px 6px -1px #00000005}.fade-in{animation:.3s fadeIn}.drilldown-header-bar{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:24px;display:flex}.drilldown-header-left{align-items:center;gap:16px;display:flex}.drilldown-header-left h2,.drilldown-header-left h3{color:#0f172a;margin:0;font-size:22px;font-weight:700}.back-arrow-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:22px;transition:transform .2s;display:flex}.back-arrow-btn:hover{transform:translate(-3px)}.blocks-card-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.block-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;padding:12px 16px;transition:transform .2s,box-shadow .2s,background-color .2s;display:flex}.block-card.active{outline-offset:-1px;outline:2px solid}.block-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0000000d}.block-card-content{align-items:center;gap:12px;margin-bottom:16px;display:flex}.block-card-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.block-card-info{flex:1;min-width:0}.block-card-info h3{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;margin:0 0 2px;font-size:14px;font-weight:700;overflow:hidden}.block-card-info p{color:#64748b;margin:0;font-size:12px;font-weight:500}.block-card-link{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;gap:4px;margin-top:auto;padding:0;font-size:12px;font-weight:600;transition:transform .2s;display:flex}.block-card-link:hover{transform:translate(4px)}.drilldown-super-header{background:#f8fafc;border-radius:12px;align-items:center;gap:16px;margin-bottom:32px;padding:20px;display:flex}.super-header-text h2{color:#0f172a;margin:0 0 4px;font-size:20px;font-weight:700}.super-header-text p{color:#64748b;margin:0;font-size:14px;font-weight:500}.rooms-section-wrapper{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;margin-top:32px;padding:24px 28px}.rooms-header-bar{border-bottom:1px dashed #cbd5e1;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.rooms-pill-grid{flex-wrap:wrap;gap:16px;display:flex}.room-pill{color:#334155;cursor:pointer;-webkit-user-select:none;user-select:none;background-color:#fff;border:1px solid #cbd5e1;border-radius:10px;justify-content:center;align-items:center;padding:12px 28px;font-size:15px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 4px #00000005}.room-pill:before{content:"";opacity:0;background-color:#2563eb;width:4px;transition:opacity .2s;position:absolute;top:0;bottom:0;left:0}.room-pill:hover{color:#1d4ed8;background-color:#fff;border-color:#93c5fd;transform:translateY(-4px);box-shadow:0 10px 20px -5px #2563eb26}.room-pill:hover:before{opacity:1}.empty-state-box{text-align:center;color:#94a3b8;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;grid-column:1/-1;padding:40px;font-size:14px}@media (width<=768px){.hostel-header,.hostel-actions{flex-direction:column;align-items:stretch}.search-input,.search-input:focus{width:100%}}.sidebar{border-right:1px solid var(--border-color);z-index:100;background:linear-gradient(#fff 0%,#f8fbff 100%);flex-direction:column;width:260px;height:100vh;transition:width .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;overflow:hidden;box-shadow:18px 0 42px -38px #0f172a61}.sidebar.collapsed{width:80px}.sidebar-logo{align-items:center;gap:12px;padding:22px 20px 18px;transition:padding .4s;display:flex}.sidebar.collapsed .sidebar-logo{justify-content:center;gap:0;padding:20px 0}.logo-icon{background-color:var(--primary-color);color:#fff;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:transform .4s;display:flex}.logo-text{opacity:1;visibility:visible;transition:opacity .3s,transform .3s,visibility .3s;overflow:hidden}.sidebar.collapsed .logo-text{opacity:0;visibility:hidden;width:0;transform:translate(-10px)}.logo-text h2{color:var(--text-main);white-space:nowrap;margin-bottom:3px;font-size:1.02rem;font-weight:800}.logo-text p{color:var(--primary-color);white-space:nowrap;font-size:.78rem;font-weight:700}.sidebar-nav{flex-grow:1;padding:10px 16px 0;transition:padding .4s}.sidebar.collapsed .sidebar-nav{padding:0 10px}.sidebar-nav ul{flex-direction:column;gap:4px;display:flex}.sidebar-nav li a{min-height:48px;color:var(--text-muted);border-radius:14px;align-items:center;gap:14px;padding:10px 16px;font-size:.9rem;font-weight:600;transition:all .3s;display:flex;position:relative}.sidebar-nav li a.active,.sidebar-nav li a:hover{color:var(--primary-color);background:linear-gradient(#fbfdff 0%,#f1f6ff 100%)}.sidebar-nav li a.active{box-shadow:inset 0 0 0 1px #2b5fe124,0 18px 36px -34px #2563ebb3}.sidebar.collapsed .sidebar-nav li a{justify-content:center;gap:0;padding:12px 0}.sidebar-nav li a span{white-space:nowrap;text-overflow:ellipsis;opacity:1;visibility:visible;transition:opacity .3s,transform .3s,visibility .3s;overflow:hidden}.sidebar.collapsed .sidebar-nav li a span{opacity:0;visibility:hidden;width:0;transform:translate(-10px)}.sidebar-nav li a i{text-align:center;flex-shrink:0;width:20px;font-size:1.1rem;transition:color .3s,transform .3s}.sidebar.collapsed .sidebar-nav li a.active{background-color:var(--primary-light);color:var(--primary-color);border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;margin:0 auto;display:flex}.sidebar.collapsed .sidebar-nav li a.active i{width:auto;font-size:1.2rem}.icon-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.badge{background-color:var(--primary-color);color:#fff;border-radius:12px;margin-left:auto;padding:2px 8px;font-size:.7rem;font-weight:600;transition:opacity .3s}.badge.mini{opacity:0;visibility:hidden;border:1.5px solid #fff;justify-content:center;align-items:center;width:8px;height:8px;margin:0;padding:0;transition:all .3s;display:flex;position:absolute;top:-2px;right:-2px;transform:scale(0)}.sidebar.collapsed .badge.mini{opacity:1;visibility:visible;transform:scale(1)}.sidebar.collapsed .badge:not(.mini){opacity:0;visibility:hidden;width:0;margin:0;padding:0}.sidebar-illustration{justify-content:center;padding:8px 20px 16px;transition:opacity .3s,transform .3s,height .4s;display:flex;overflow:hidden}.sidebar.collapsed .sidebar-illustration{opacity:0;height:0;padding:0;transform:scale(.8)}.illustration-img{object-fit:contain;width:100%;height:auto;max-height:215px;display:block}.sidebar-logout{z-index:2;padding:8px 20px 18px;transition:padding .4s;position:relative}.sidebar.collapsed .sidebar-logout{justify-content:center;padding:16px 0;display:flex}.logout-btn{background-color:var(--primary-light);width:100%;min-height:48px;color:var(--primary-color);cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;padding:12px 16px;font-size:.95rem;font-weight:700;transition:all .3s;display:flex}.logout-btn span{white-space:nowrap;opacity:1;visibility:visible;transition:opacity .3s,transform .3s,visibility .3s}.sidebar.collapsed .logout-btn span{opacity:0;visibility:hidden;width:0;margin:0}.sidebar.collapsed .logout-btn{border-radius:12px;gap:0;width:44px;height:44px;padding:0}.logout-btn i{font-size:1.1rem;transition:transform .3s}.logout-btn:hover{background-color:var(--primary-color);color:#fff}.sidebar-waves{z-index:1;width:100%;margin-top:auto}.wave-img{object-fit:cover;object-position:bottom;width:100%;height:auto;max-height:100px;display:block}@media (width<=768px){.sidebar{box-shadow:none;transition:left .4s cubic-bezier(.4,0,.2,1),width;left:-280px;overflow-y:auto;width:280px!important}.mobile-menu-open .sidebar{left:0;box-shadow:8px 0 30px #00000026}}@media (width<=1024px) and (width>=769px){.sidebar{width:80px}.sidebar .logo-text,.sidebar .sidebar-nav li a span,.sidebar .sidebar-illustration,.sidebar .logout-btn span{opacity:0;visibility:hidden;width:0}.sidebar .sidebar-nav li a{justify-content:center;gap:0;padding:12px 0}.sidebar .sidebar-logo{justify-content:center;padding:20px 0}}.header{z-index:90;-webkit-backdrop-filter:blur(14px);background-color:#fffffff5;border-bottom:1px solid #e8ecf0;justify-content:space-between;align-items:center;gap:20px;min-height:60px;padding:8px 28px;display:flex;position:sticky;top:0;box-shadow:0 14px 35px -34px #0f172a73}.header-left{flex:1;align-items:center;gap:18px;min-width:0;display:flex}.menu-toggle{color:#475569;cursor:pointer;background:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.25rem;transition:background-color .2s,border-color .2s,box-shadow .2s;display:flex}.menu-toggle:hover{color:#1e293b;background-color:#f1f5f9;border-color:#d5dfeb;box-shadow:0 10px 26px -24px #2563eb99}.header-divider{background-color:#e2e8f0;flex-shrink:0;width:1px;height:38px}.greeting{min-width:0}.greeting h2{color:#1e293b;white-space:nowrap;align-items:center;gap:6px;margin-bottom:4px;font-size:clamp(1.05rem,.65vw + .95rem,1.45rem);font-weight:800;line-height:1.2;display:flex}.greeting-wave{color:#2563eb;font-size:.95rem}.greeting-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.greeting p{color:#64748b;white-space:normal;max-width:44rem;font-size:.9rem;font-weight:500;line-height:1.45}.header-right{flex-shrink:0;align-items:center;gap:14px;min-width:0;margin-left:auto;display:flex}.search-bar{background:linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #e2e8f0;border-radius:16px;align-items:center;width:min(100%,360px);min-width:240px;height:54px;padding:0 16px;transition:border-color .2s,box-shadow .2s;display:flex}.search-bar:focus-within{border-color:#2563eb;box-shadow:0 16px 38px -30px #2563eb73}.search-icon{color:#94a3b8;flex-shrink:0;font-size:.9rem}.search-bar input{color:#334155;background:0 0;border:none;outline:none;width:100%;padding:0 10px;font-family:inherit;font-size:.9rem}.search-bar input::placeholder{color:#94a3b8}.shortcut-badge{color:#64748b;background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;align-items:center;gap:2px;padding:4px 7px;font-size:.72rem;font-weight:700;display:flex}.header-actions{align-items:center;gap:8px;display:flex}.vertical-line{background-color:#e2e8f0;width:1px;height:24px}.icon-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.15rem;transition:all .2s;display:flex;position:relative}.icon-btn:hover{color:#1e293b;background-color:#f1f5f9;border-color:#d5dfeb}.icon-btn.active,.user-profile.active{color:#2563eb;background-color:#eff6ff}.notification-btn{position:relative}.notif-badge{color:#fff;background-color:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:17px;height:17px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.user-profile{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:14px;flex-shrink:0;align-items:center;gap:10px;padding:6px 10px;transition:background-color .2s,border-color .2s;display:flex}.user-profile:hover{background-color:#f8fafc;border-color:#e2e8f0}.avatar{color:#fff;background-color:#2563eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;font-weight:700;display:flex}.user-info{text-align:left;flex-direction:column;align-items:flex-start;display:flex}.user-info h4{color:#1e293b;white-space:nowrap;text-align:left;margin-bottom:2px;font-size:.92rem;font-weight:800}.user-info p{color:#64748b;white-space:nowrap;font-size:.76rem;font-weight:600}.dropdown-icon{color:#94a3b8;font-size:.75rem}.header-popover-wrap{position:relative}.header-popover{z-index:120;background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:280px;padding:14px;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 20px 45px -28px #0f172a59}.popover-head{border-bottom:1px solid #eef2f7;flex-direction:column;gap:4px;margin-bottom:12px;padding-bottom:12px;display:flex}.popover-head strong{color:#0f172a;font-size:.92rem;font-weight:700}.popover-head span{color:#64748b;font-size:.78rem;font-weight:500}.calendar-input{color:#334155;border:1px solid #dbe5f1;border-radius:10px;width:100%;height:42px;margin-bottom:12px;padding:0 12px;font-size:.9rem}.calendar-shortcuts{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.calendar-shortcuts button{color:#334155;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;height:38px;font-size:.85rem;font-weight:600;transition:all .2s}.calendar-shortcuts button:hover{background:#f8fafc;border-color:#cbd5e1}.profile-popover{width:240px}.profile-popover-actions{flex-direction:column;gap:4px;display:flex}.profile-popover-actions button{color:#334155;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;height:42px;padding:0 14px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.profile-popover-actions button:hover{color:#1e293b;background:#f1f5f9}.profile-popover-actions button.danger{color:#dc2626}.profile-popover-actions button.danger:hover{background:#fef2f2}@media (width<=1180px){.header{padding:14px 20px}.search-bar{width:280px;min-width:180px}.greeting p{max-width:30rem}}@media (width<=768px){.header{border-bottom:1px solid #e8ecf0;gap:0;min-height:72px;padding:12px 14px}.header-left{flex:1;gap:10px}.menu-toggle{width:40px;height:40px;font-size:1.15rem}.header-divider{display:none}.greeting h2{gap:4px;margin-bottom:1px;font-size:.98rem}.greeting p{display:none}.header-right{gap:8px}.search-mobile-btn{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;width:40px;height:40px}.notification-btn{width:36px;height:36px}.notif-badge{width:16px;height:16px;font-size:.58rem;top:3px;right:3px}.avatar{width:36px;height:36px;font-size:.95rem}.user-profile{border:none;gap:4px;padding:2px}.dropdown-icon{font-size:.7rem}.header-popover{width:240px;right:-8px}}@media (width<=1024px) and (width>=769px){.search-bar{width:240px;min-width:180px}.header{padding:14px 20px}}.footer{color:#fff;background:linear-gradient(135deg,#1d4ed8 0%,#2563eb 50%,#3b82f6 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;margin-top:auto;padding:12px 32px;display:flex;position:relative;overflow:hidden}.footer-left{align-items:center;display:flex}.footer-logo{align-items:center;gap:14px;display:flex}.footer-logo-icon{border:2px solid #ffffffb3;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:1.3rem;display:flex}.footer-logo-text h3{margin-bottom:3px;font-size:1rem;font-weight:700}.footer-logo-text p{color:#ffffffc7;font-size:.75rem}.footer-links{align-items:center;gap:16px;font-size:.85rem;font-weight:500;display:flex}.footer-links a{color:#ffffffe6;white-space:nowrap;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#fff}.divider{background-color:#ffffff59;flex-shrink:0;width:1px;height:14px}.footer-social{align-items:center;gap:14px;font-size:.85rem;font-weight:500;display:flex}.footer-social>span{white-space:nowrap;color:#ffffffe6}.social-icons{align-items:center;gap:10px;display:flex}.social-icon{color:#fff;border:1.5px solid #ffffff80;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.95rem;text-decoration:none;transition:all .2s;display:flex}.social-icon:hover{background-color:#fff3;border-color:#fff}@media (width<=768px){.footer{background:linear-gradient(#2563eb 0%,#1a4fd6 100%);flex-direction:column;align-items:flex-start;gap:24px;padding:32px 20px 40px}.footer-left{width:100%}.footer-logo{flex-direction:row;align-items:center;gap:14px}.footer-logo-icon{border:2px solid #ffffffb3;border-radius:12px;flex-shrink:0;width:48px;height:48px;font-size:1.3rem}.footer-logo-text h3{margin-bottom:3px;font-size:1rem;font-weight:700}.footer-logo-text p{color:#ffffffbf;font-size:.75rem}.footer-links{border-top:1px solid #ffffff26;justify-content:center;gap:12px;width:100%;padding-top:20px;font-size:.85rem}.footer-social{flex-direction:column;align-items:center;gap:14px;width:100%}.footer-social>span{color:#ffffffd9;font-size:.85rem;font-weight:500}.social-icons{gap:12px}.social-icon{border:1.5px solid #ffffff80;width:40px;height:40px;font-size:1rem}}@media (width<=1024px) and (width>=769px){.footer{gap:16px;padding:24px 28px}.footer-links{gap:12px;font-size:.82rem}}.main-layout{background:#edf3f9;width:100%;min-height:100vh;display:flex}.main-wrapper{flex-direction:column;flex-grow:1;min-width:0;min-height:100vh;margin-left:260px;transition:margin-left .4s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-collapsed .main-wrapper{margin-left:80px}.main-content{background:radial-gradient(circle at 0 0,#ffffffeb,#0000 28%),linear-gradient(#f5f8fc 0%,#edf3f9 100%);flex-grow:1;padding:14px}@media (width<=768px){.main-wrapper{margin-left:0!important}.main-content{padding:10px}.sidebar-overlay{z-index:95;-webkit-backdrop-filter:blur(2px);background-color:#00000073;animation:.3s forwards overlayFadeIn;position:fixed;inset:0}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@media (width<=1024px) and (width>=769px){.main-wrapper{margin-left:80px}.main-content{padding:12px}}@media (width<=768px){.hod-dashboard{padding:10px}}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:24px;padding:0 10px;display:flex}.header-greeting h1{color:#0f172a;margin-bottom:6px;font-size:1.25rem;font-weight:700}.header-greeting p{color:#64748b;font-size:.8rem;font-weight:500}.export-btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.charts-main-grid{grid-template-columns:1.6fr 1fr;gap:20px;margin-bottom:24px;display:grid}.chart-placeholder{min-height:240px;padding:24px}.flex-center{flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex}.id-cell{color:#0f172a;font-weight:700}.student-info{align-items:center;gap:12px;font-weight:600;display:flex}.avatar-small{background:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;display:flex}.cat-pill{border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.cat-pill.blue{color:#2563eb;background:#eff6ff}.cat-pill.orange{color:#f97316;background:#fff7ed}.cat-pill.red{color:#ef4444;background:#fef2f2}.status-badge{border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700}.status-badge.under-review{color:#f97316;background:#fff7ed}.status-badge.critical{color:#ef4444;background:#fef2f2}.action-btn{cursor:pointer;border:1px solid #e2e8f0;border-radius:8px;padding:6px 12px;font-size:.75rem;font-weight:700}@media (width<=1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-main-grid{grid-template-columns:1fr}}@media (width<=768px){.stats-grid{grid-template-columns:1fr}.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}}.line-chart-viz{grid-template-rows:1fr 24px;grid-template-columns:30px 1fr;gap:12px;height:180px;display:grid}.y-axis{color:#94a3b8;text-align:right;flex-direction:column;justify-content:space-between;font-size:.65rem;display:flex}.chart-body{border-bottom:1px solid #f1f5f9;border-left:1px solid #f1f5f9;position:relative}.chart-line{opacity:.15;background:linear-gradient(90deg,#3b82f6 0%,#2563eb 100%);height:2px;position:absolute;top:40%;left:0;right:0}.chart-points{justify-content:space-around;align-items:flex-end;width:100%;height:100%;display:flex;position:absolute}.point{background:#3b82f6;border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:relative;box-shadow:0 0 0 4px #3b82f61a}.point.active{background:#2563eb;transform:scale(1.2);box-shadow:0 0 0 6px #2563eb26}.x-axis{color:#94a3b8;grid-column:2;justify-content:space-around;font-size:.65rem;display:flex}.donut-viz-large{background:conic-gradient(#3b82f6 45%,#8b5cf6 45% 70%,#f59e0b 70% 90%,#22c55e 90%);border-radius:50%;justify-content:center;align-items:center;width:130px;height:130px;display:flex}.donut-inner{background:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:90px;height:90px;display:flex}.donut-inner strong{color:#0f172a;font-size:1.5rem;line-height:1}.donut-inner span{color:#64748b;font-size:.72rem;font-weight:600}.donut-legend{grid-template-columns:repeat(2,1fr);gap:12px;width:100%;display:grid}.legend-item{color:#475569;align-items:center;gap:8px;font-size:.75rem;font-weight:600;display:flex}.dot{border-radius:50%;width:8px;height:8px}.dot.blue{background:#3b82f6}.dot.purple{background:#8b5cf6}.dot.orange{background:#f59e0b}.dot.green{background:#22c55e}@media (width<=768px){.hod-dashboard{padding:10px}}.back-btn-alt{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;margin-bottom:24px;padding:8px 16px;font-size:.78rem;font-weight:700;display:flex}.detail-content-grid{grid-template-columns:1fr 340px;align-items:flex-start;gap:24px;display:grid}.ticket-main-card{margin-bottom:24px;padding:24px}.ticket-title-wrap{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.ticket-title-wrap h1{color:#0f172a;font-size:1.15rem;font-weight:800}.priority-tag{border-radius:6px;padding:6px 12px;font-size:.65rem;font-weight:800}.priority-tag.high{color:#ef4444;background:#fef2f2}.ticket-desc{color:#475569;margin-bottom:24px;font-size:.85rem;line-height:1.6}.ticket-meta-row{border-top:1px solid #f1f5f9;gap:32px;padding-top:20px;display:flex}.meta-item{align-items:center;gap:12px;display:flex}.meta-item i{color:#94a3b8;font-size:1.2rem}.meta-item strong{color:#1e293b;font-size:.8rem;display:block}.meta-item span{color:#94a3b8;font-size:.7rem}.status-val-alt{border-radius:6px;margin-bottom:2px;padding:4px 10px;font-size:.75rem;font-weight:700;display:block}.status-val-alt.orange{color:#f97316;background:#fff7ed}.attachments-section{margin-top:32px}.attachments-section h3{color:#0f172a;margin-bottom:16px;font-size:.85rem;font-weight:700}.doc-card-alt{border:1px solid #f1f5f9;border-radius:12px;align-items:center;gap:16px;width:fit-content;padding:12px 16px;display:flex}.doc-icon{border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex}.doc-icon.pdf{color:#ef4444;background:#fef2f2}.doc-info strong{color:#1e293b;font-size:.8rem;display:block}.doc-info span{color:#94a3b8;font-size:.72rem}.doc-download-btn{color:#64748b;cursor:pointer;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.conversation-list{flex-direction:column;gap:40px;padding:24px;display:flex}.message-row{gap:16px;display:flex}.avatar-circle{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.8rem;font-weight:700;display:flex}.avatar-circle.student{color:#2563eb;background:#eff6ff}.avatar-circle.officer{color:#7c3aed;background:#f5f3ff}.message-head{justify-content:space-between;margin-bottom:6px;display:flex}.message-head strong{color:#1e293b;font-size:.85rem}.message-head span{color:#94a3b8;font-size:.72rem}.message-text{color:#475569;font-size:.85rem;line-height:1.5}.reply-box-wrap{border-top:1px solid #f1f5f9;padding:20px}.reply-box-wrap textarea{resize:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;width:100%;min-height:100px;margin-bottom:12px;padding:12px 16px;font-size:.85rem}.reply-actions{justify-content:space-between;align-items:center;display:flex}.left-tools{gap:12px;display:flex}.left-tools button{color:#94a3b8;cursor:pointer;font-size:1rem}.send-reply-btn{color:#fff;cursor:pointer;background:#2563eb;border-radius:8px;padding:10px 24px;font-size:.85rem;font-weight:700}.sidebar-form{flex-direction:column;gap:20px;padding:20px;display:flex}.form-group-side{flex-direction:column;gap:8px;display:flex}.form-group-side label{color:#475569;font-size:.78rem;font-weight:700}.form-group-side select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px;font-size:.8rem}.upload-zone-mini{text-align:center;color:#3b82f6;cursor:pointer;border:2px dashed #e2e8f0;border-radius:12px;padding:5px}.upload-zone-mini i{margin-bottom:8px;font-size:1.2rem;display:block}.upload-zone-mini span{font-size:.8rem;font-weight:700}.upload-zone-mini p{color:#94a3b8;margin-top:4px;font-size:.65rem}.primary-update-btn{color:#fff;cursor:pointer;background:#3b82f6;border-radius:8px;padding:12px;font-size:.85rem;font-weight:700}.student-side-profile{padding:20px}.student-profile-head{align-items:center;gap:16px;margin-bottom:14px;display:flex}.avatar-large{color:#2563eb;background:#eff6ff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1rem;font-weight:700;display:flex}.profile-titles strong{color:#0f172a;font-size:.9rem;display:block}.profile-titles span{color:#94a3b8;font-size:.72rem}.info-grid-side{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.info-node label{color:#94a3b8;font-size:.72rem;display:block}.info-node span{color:#1e293b;font-size:.78rem;font-weight:600}.text-right{text-align:right}.quick-actions-list{flex-direction:column;gap:12px;padding:0;display:flex}.q-action-btn{border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px;font-size:.8rem;font-weight:700;display:flex}.q-action-btn.blue{color:#2563eb;background:#eff6ff}.q-action-btn.red{color:#ef4444;background:#fef2f2}@media (width<=1024px){.detail-content-grid{grid-template-columns:1fr}}@media (width<=768px){.hod-dashboard{padding:10px}}.page-header-alt h1{color:#0f172a;margin-bottom:4px;font-size:1.25rem;font-weight:700}.page-header-alt p{color:#64748b;font-size:.8rem}.stats-mini-grid{grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px;display:grid}.table-actions-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.table-tabs{gap:20px;display:flex}.tab-item{color:#64748b;cursor:pointer;background:0 0;padding:12px 0;font-size:.8rem;font-weight:600;position:relative}.table-btn-group{gap:10px;display:flex}.secondary-btn{color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.78rem;font-weight:700;display:flex}.advanced-filter-bar{background:#fff;border-bottom:1px solid #f1f5f9;gap:16px;padding:16px 20px;display:flex}.search-box-wrap{flex:1;align-items:center;display:flex;position:relative}.search-box-wrap i{color:#94a3b8;font-size:.85rem;position:absolute;left:12px}.search-box-wrap input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:8px 12px 8px 36px;font-size:.8rem}.filter-selects{gap:10px;display:flex}.filter-selects select{color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:8px;min-width:130px;padding:8px 12px;font-size:.8rem}.id-cell-link{color:#2563eb;cursor:pointer;font-weight:700}.student-cell-alt .student-name{color:#0f172a;font-weight:700}.student-cell-alt .student-id{color:#94a3b8;margin-top:2px;font-size:.7rem}.priority-pill{border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700}.priority-pill.high{color:#ef4444;background:#fef2f2}.priority-pill.medium{color:#f97316;background:#fff7ed}.priority-pill.low{color:#16a34a;background:#f0fdf4}.status-pill-alt{border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700}.status-pill-alt.under-review{color:#f97316;background:#fff7ed}.status-pill-alt.new-request{color:#3b82f6;background:#eff6ff}.status-pill-alt.pending-info{color:#7c3aed;background:#f5f3ff}.status-pill-alt.in-progress{color:#0d9488;background:#f0fdfa}.date-cell .time-sub{color:#94a3b8;margin-top:2px;font-size:.7rem}.overdue-check .due-date{color:#ef4444;font-weight:600}.action-cell{align-items:center;gap:12px;display:flex}.manage-btn{color:#2563eb;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:6px 16px;font-size:.75rem;font-weight:700}.more-btn{color:#94a3b8;cursor:pointer}@media (width<=1024px){.stats-mini-grid{grid-template-columns:repeat(2,1fr)}.advanced-filter-bar{flex-direction:column}}@media (width<=768px){.hod-dashboard{padding:10px}}.hod-dashboard{width:100%}.page-header-alt{margin-bottom:24px;padding:0 10px}.dashboard-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #00000005}.card-head{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-head h3{color:#0f172a;font-size:.95rem;font-weight:700}@media (width<=768px){.hod-dashboard{padding:10px}}.notifications-page{width:100%}.notifications-card{margin-top:24px}.mark-read-btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.78rem;font-weight:700;transition:all .2s;display:flex}.mark-read-btn:hover{background:#f8fafc;border-color:#cbd5e1}.notifications-list{flex-direction:column;display:flex}.notif-item{cursor:pointer;border-bottom:1px solid #f1f5f9;align-items:center;padding:16px 20px;transition:background .2s;display:flex}.notif-item:hover{background:#f8fafc}.notif-indicator{justify-content:center;width:24px;display:flex}.unread-dot{background:#3b82f6;border-radius:50%;width:8px;height:8px}.notif-icon-wrap{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;margin:0 16px;font-size:1.1rem;display:flex}.notif-icon-wrap.blue{color:#3b82f6;background:#eff6ff}.notif-icon-wrap.orange{color:#f97316;background:#fff7ed}.notif-icon-wrap.purple{color:#7c3aed;background:#f5f3ff}.notif-icon-wrap.green{color:#16a34a;background:#f0fdf4}.notif-icon-wrap.red{color:#ef4444;background:#fef2f2}.notif-content{flex:1}.notif-content strong{color:#1e293b;margin-bottom:4px;font-size:.85rem;display:block}.notif-content p{color:#64748b;font-size:.78rem;line-height:1.4}.notif-meta{text-align:right;padding:0 24px}.notif-time{color:#1e293b;margin-bottom:4px;font-size:.78rem;font-weight:700;display:block}.notif-date{color:#94a3b8;font-size:.72rem}.notif-arrow{color:#cbd5e1;font-size:.8rem}.table-footer-pagination{justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.results-count{color:#64748b;font-size:.75rem}.pagination-controls{gap:6px;display:flex}.page-num,.page-nav{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.78rem;font-weight:600;display:flex}.page-num.active{color:#fff;background:#2563eb;border-color:#2563eb}.per-page-select select{color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:6px 12px;font-size:.78rem}@media (width<=768px){.notif-meta{display:none}.notif-item{padding:16px 12px}.notif-icon-wrap{margin:0 12px}}.ng-panel{background:#fff;border:1px solid #eef2f7;border-radius:14px;margin:20px;overflow:hidden;box-shadow:0 10px 32px #1018280f}.ng-header{justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex}.ng-title{color:#0f172a;margin:0;font-size:20px;font-weight:700}.ng-subtitle{color:#64748b;margin:6px 0 0;font-size:14px}.ng-export-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #e5eaf3;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .12s;display:inline-flex}.ng-export-btn:hover{background:#f8fafc}.ng-filters{flex-wrap:wrap;align-items:center;gap:12px;padding:0 24px 20px;display:flex}.ng-search{flex:1;min-width:200px;max-width:320px;position:relative}.ng-search-icon{color:#94a3b8;pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.ng-search input{color:#0f172a;background:#fff;border:1px solid #e5eaf3;border-radius:8px;outline:none;width:100%;height:40px;padding:0 12px 0 36px;font-size:13px}.ng-search input::placeholder{color:#94a3b8}.ng-search input:focus{border-color:#bfd3ff;box-shadow:0 0 0 3px #3b82f626}.ng-filter-group select{color:#334155;cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='m6 9 6 6 6-6' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 10px center no-repeat;border:1px solid #e5eaf3;border-radius:8px;outline:none;height:40px;padding:0 32px 0 12px;font-size:13px}.ng-filter-group select:focus{border-color:#bfd3ff;box-shadow:0 0 0 3px #3b82f626}.ng-clear-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e5eaf3;border-radius:8px;align-items:center;gap:6px;height:40px;padding:0 12px;font-size:13px;font-weight:600;transition:all .12s;display:inline-flex}.ng-clear-btn:hover{color:#334155;background:#f8fafc}.ng-table-container{overflow-x:auto}.ng-table{border-collapse:collapse;width:100%;font-size:13px}.ng-table thead{background:#f8fafc}.ng-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e5eaf3;padding:12px 16px;font-size:11px;font-weight:600}.ng-table th:last-child{text-align:right}.ng-table td{vertical-align:middle;border-bottom:1px solid #f1f4f9;padding:16px}.ng-table tbody tr:hover{background:#fafbfc}.ng-ticket-id{color:#334155;font-weight:600}.ng-category{align-items:center;gap:8px;display:flex}.ng-category-icon{border-radius:6px;place-items:center;width:28px;height:28px;display:grid}.ng-category-academic{color:#3b82f6;background:#eff6ff}.ng-category-hostel{color:#22c55e;background:#f0fdf4}.ng-category-examination{color:#ef4444;background:#fef2f2}.ng-category-financial{color:#f59e0b;background:#fffbeb}.ng-subject{color:#334155;max-width:280px;font-weight:500;line-height:1.4}.ng-status{border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.ng-status-orange{color:#f97316;background:#fff7ed}.ng-status-blue{color:#3b82f6;background:#eff6ff}.ng-status-green{color:#22c55e;background:#f0fdf4}.ng-date{color:#64748b;font-size:12px;line-height:1.5}.ng-view-link{color:#2563eb;align-items:center;gap:4px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.ng-view-link:hover{text-decoration:underline}.ng-pagination{border-top:1px solid #f1f4f9;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.ng-results{color:#64748b;font-size:13px}.ng-page-controls{align-items:center;gap:4px;display:flex}.ng-page-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e5eaf3;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;transition:all .12s;display:inline-flex}.ng-page-btn:hover:not(:disabled){background:#f8fafc;border-color:#d1d5db}.ng-page-btn:disabled{opacity:.5;cursor:not-allowed}.ng-page-active{color:#fff;background:#2563eb;border-color:#2563eb}.ng-page-active:hover{background:#1d4ed8}@media (width<=768px){.ng-header{flex-direction:column;align-items:flex-start;gap:12px}.ng-filters{flex-direction:column;align-items:stretch}.ng-search{max-width:none}.ng-table th,.ng-table td{padding:12px 8px}.ng-subject{max-width:150px}.ng-pagination{flex-direction:column;gap:12px}}.ng-overlay{z-index:100;background:#0f172a73;justify-content:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.ng-drawer{background:#fff;flex-direction:column;width:min(480px,100%);max-width:480px;height:100%;animation:.3s cubic-bezier(.16,1,.3,1) slideIn;display:flex;box-shadow:-10px 0 40px #0000001a}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.ng-drawer-header{border-bottom:1px solid #f1f4f9;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.ng-drawer-back,.ng-drawer-close{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;place-items:center;width:36px;height:36px;transition:all .12s;display:grid}.ng-drawer-back:hover,.ng-drawer-close:hover{color:#334155;background:#f8fafc}.ng-drawer-title{color:#0f172a;margin:0;font-size:16px;font-weight:700}.ng-drawer-content{flex:1;padding:20px;overflow-y:auto}.ng-ticket-header{margin-bottom:20px}.ng-ticket-info{align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.ng-ticket-id-large{color:#0f172a;flex:1;margin:0;font-size:16px;font-weight:700;line-height:1.4}.ng-ticket-meta{color:#64748b;align-items:center;gap:16px;font-size:13px;display:flex}.ng-meta-item{align-items:center;gap:6px;display:flex}.ng-ticket-description{color:#334155;margin-bottom:20px;font-size:14px;line-height:1.6}.ng-attachment{cursor:pointer;background:#f8fafc;border:1px solid #e5eaf3;border-radius:8px;align-items:center;gap:12px;margin-bottom:24px;padding:12px;transition:all .12s;display:flex}.ng-attachment:hover{background:#f1f4f9;border-color:#d1d5db}.ng-attachment-icon{color:#3b82f6;background:#eff6ff;border-radius:8px;place-items:center;width:36px;height:36px;display:grid}.ng-attachment-info{flex-direction:column;gap:2px;display:flex}.ng-attachment-name{color:#334155;font-size:13px;font-weight:600}.ng-attachment-size{color:#94a3b8;font-size:12px}.ng-section-title{color:#0f172a;margin:0 0 16px;font-size:14px;font-weight:700}.ng-status-tracker{margin-bottom:24px}.ng-timeline{padding-left:24px;position:relative}.ng-timeline:before{content:"";background:#e5eaf3;width:2px;position:absolute;top:8px;bottom:24px;left:7px}.ng-timeline-item{padding-bottom:20px;position:relative}.ng-timeline-item:last-child{padding-bottom:0}.ng-timeline-dot{background:#e5eaf3;border:2px solid #fff;border-radius:50%;width:12px;height:12px;position:absolute;top:4px;left:-20px;box-shadow:0 0 0 2px #e5eaf3}.ng-timeline-completed .ng-timeline-dot{background:#22c55e;box-shadow:0 0 0 2px #22c55e}.ng-timeline-active .ng-timeline-dot{background:#3b82f6;animation:2s infinite pulse;box-shadow:0 0 0 2px #3b82f6}@keyframes pulse{0%{box-shadow:0 0 #10b98166}70%{box-shadow:0 0 0 16px #10b98100}to{box-shadow:0 0 #10b98100}}.ng-timeline-content{padding-left:8px}.ng-timeline-title{color:#334155;margin-bottom:4px;font-size:14px;font-weight:600}.ng-timeline-date{color:#64748b;margin-bottom:4px;font-size:12px}.ng-timeline-sub{color:#94a3b8;margin-bottom:2px;font-size:12px}.ng-timeline-pending{color:#f59e0b;font-size:12px;font-weight:500}.ng-conversation{margin-bottom:20px}.ng-messages{flex-direction:column;gap:16px;display:flex}.ng-message{gap:12px;display:flex}.ng-message-avatar{border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:grid}.ng-message-student .ng-message-avatar{color:#3b82f6;background:#eff6ff}.ng-message-officer .ng-message-avatar{color:#f59e0b;background:#fef3c7}.ng-message-content{background:#f8fafc;border-radius:4px 12px 12px;flex:1;padding:12px}.ng-message-officer .ng-message-content{background:#fff;border:1px solid #e5eaf3;border-top-left-radius:12px;border-top-right-radius:4px}.ng-message-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.ng-message-author{color:#334155;font-size:13px;font-weight:700}.ng-message-time{color:#94a3b8;font-size:12px}.ng-message-text{color:#475569;margin:0;font-size:13px;line-height:1.5}.ng-reply-box{background:#fff;border-top:1px solid #f1f4f9;padding:16px 20px}.ng-reply-input-wrap{background:#f8fafc;border:1px solid #e5eaf3;border-radius:10px;align-items:center;gap:12px;margin-bottom:12px;padding:12px;display:flex}.ng-attach-icon{color:#94a3b8;cursor:pointer;flex-shrink:0}.ng-attach-icon:hover{color:#64748b}.ng-reply-input{color:#334155;background:0 0;border:none;outline:none;flex:1;font-size:14px}.ng-reply-input::placeholder{color:#94a3b8}.ng-post-btn{color:#fff;cursor:pointer;background:linear-gradient(#2563eb,#1d4ed8);border:none;border-radius:8px;width:100%;height:40px;font-size:14px;font-weight:700;transition:filter .12s}.ng-post-btn:hover{filter:brightness(1.05)}@media (width<=768px){.ng-drawer{width:100%;max-width:none}}.student-detail-page{background-color:#f8fafc;min-height:calc(100vh - 80px);padding:0 20px 40px}.detail-header-nav{padding:16px 0}.back-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:12px;font-weight:600;display:flex}.back-btn:hover{text-decoration:underline}.ticket-main-header-card{background:#fff;border:1px solid #eef2f7;border-radius:12px;margin-bottom:24px;padding:20px;box-shadow:0 1px 3px #0000000d}.ticket-id-status-row{align-items:center;gap:12px;margin-bottom:8px;display:flex}.ticket-detail-title-small{color:#0f172a;margin:0;font-size:18px;font-weight:700}.ticket-status-pill{color:#16a34a;background:#f0fdf4;border-radius:99px;padding:2px 10px;font-size:11px;font-weight:600}.ticket-subject-text{color:#64748b;margin:0 0 20px;font-size:13px}.meta-info-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.meta-info-item{background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;align-items:center;gap:12px;padding:12px;display:flex}.meta-icon-wrap{color:#3b82f6;background:#eff6ff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.meta-label-value{flex-direction:column;display:flex}.meta-label{color:#94a3b8;font-size:11px;font-weight:500}.meta-value{color:#1e293b;font-size:12px;font-weight:600}.detail-layout{grid-template-columns:1fr 300px;align-items:flex-start;gap:24px;display:grid}.detail-tabs{background:#fff;border-bottom:1px solid #eef2f7;border-top-left-radius:12px;border-top-right-radius:12px;gap:32px;margin-bottom:0;padding:0 20px;display:flex}.tab-item{color:#64748b;cursor:pointer;padding:14px 0;font-size:12px;font-weight:600;position:relative}.tab-item.active{color:#2563eb}.tab-item.active:after{content:"";background:#2563eb;height:2px;position:absolute;bottom:-1px;left:0;right:0}.conversation-panel{background:#fff;border:1px solid #eef2f7;border-top:none;border-bottom-right-radius:12px;border-bottom-left-radius:12px;padding:32px 24px;box-shadow:0 1px 3px #0000000d}.chat-messages-container{flex-direction:column;gap:28px;margin-bottom:32px;display:flex}.date-divider{justify-content:center;margin:12px 0;display:flex}.date-tag{color:#64748b;background:#f1f5f9;border-radius:99px;padding:4px 14px;font-size:11px;font-weight:600}.message-wrap{gap:14px;max-width:90%;display:flex}.message-wrap.user{flex-direction:column;align-self:flex-end;align-items:flex-end}.message-avatar-small{border-radius:50%;flex-shrink:0;width:36px;height:36px}.message-body-small{flex-direction:column;gap:6px;max-width:100%;display:flex}.message-sender-name{color:#0f172a;font-size:12px;font-weight:700}.message-bubble-small{border-radius:12px;min-width:80px;padding:12px 16px 28px;font-size:12px;line-height:1.5;position:relative}.message-wrap.other .message-bubble-small{color:#334155;background:#f1f5f9;border:1px solid #e2e8f0;border-top-left-radius:2px}.message-wrap.user .message-bubble-small{color:#1e40af;background:#eff6ff;border:1px solid #dbeafe;border-top-right-radius:2px}.message-time-wrap{align-items:center;gap:4px;display:flex;position:absolute;bottom:8px;right:12px}.message-time-small{color:#94a3b8;white-space:nowrap;font-size:10px;font-weight:500}.message-wrap.user .message-time-small{color:#7189b6}.reply-area-wrap{align-items:center;gap:12px;margin-top:24px;display:flex}.attach-box-square{color:#64748b;cursor:pointer;background:#f8fafc;border:1px solid #eef2f7;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.reply-input-small{color:#1e293b;background:#fff;border:1px solid #eef2f7;border-radius:8px;outline:none;flex:1;height:40px;padding:0 16px;font-size:12px}.reply-input-small::placeholder{color:#cbd5e1}.send-btn-blue{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;height:40px;padding:0 24px;font-size:12px;font-weight:600;transition:background .2s}.send-btn-blue:hover{background:#1d4ed8}.reply-hint{color:#94a3b8;margin-top:12px;padding-left:2px;font-size:11px}.sidebar-card-small{background:#fff;border:1px solid #eef2f7;border-radius:12px;margin-bottom:20px;padding:16px;box-shadow:0 1px 3px #0000000d}.sidebar-title-small{color:#0f172a;margin:0 0 16px;font-size:13px;font-weight:700}.status-resolved-box{align-items:center;gap:8px;margin-bottom:12px;display:flex}.check-icon-green{color:#16a34a;background:#f0fdf4;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;display:flex}.status-text-bold{color:#1e293b;font-size:12px;font-weight:700}.resolution-info{margin-bottom:16px}.info-label-small{color:#94a3b8;margin-bottom:2px;font-size:11px;display:block}.info-value-small{color:#1e293b;font-size:12px;font-weight:600}.resolved-by-item{align-items:center;gap:10px;margin-top:10px;display:flex}.role-badge-blue{color:#2563eb;background:#eff6ff;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:700}.view-btn-outline{color:#2563eb;cursor:pointer;background:#fff;border:1px solid #dbeafe;border-radius:6px;width:100%;padding:8px;font-size:12px;font-weight:600}.reopen-card{text-align:center}.reopen-icon{color:#f43f5e;background:#fff1f2;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;margin:0 auto 12px;font-size:14px;display:flex}.reopen-text{color:#64748b;margin-bottom:16px;font-size:11px;line-height:1.4}.reopen-btn-red{color:#fff;cursor:pointer;background:#f43f5e;border:none;border-radius:8px;width:100%;padding:10px;font-size:12px;font-weight:700}.info-list-small{flex-direction:column;gap:12px;display:flex}.info-row-small{justify-content:space-between;align-items:center;display:flex}.priority-tag-small{color:#f97316;background:#fff7ed;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.timeline-panel-alt{background:#fff;border:1px solid #eef2f7;border-top:none;border-bottom-right-radius:12px;border-bottom-left-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000d}.timeline-header-actions{justify-content:flex-end;margin-bottom:24px;display:flex}.filter-btn-small{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;padding:6px 14px;font-size:12px;font-weight:600;display:flex}.timeline-list-alt{flex-direction:column;display:flex}.timeline-item-alt{gap:20px;padding-bottom:32px;display:flex;position:relative}.timeline-item-alt.last{padding-bottom:0}.timeline-left{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.timeline-icon-box{color:#fff;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;display:flex;box-shadow:0 4px 10px #0000001a}.timeline-icon-box.blue{background:#3b82f6}.timeline-icon-box.orange{background:#f97316}.timeline-icon-box.purple{background:#a855f7}.timeline-icon-box.green{background:#22c55e}.timeline-icon-box.red{background:#f43f5e}.timeline-line{background:#e2e8f0;flex:1;width:2px;margin-top:4px;position:absolute;top:36px;bottom:0;left:17px}.timeline-content-alt{flex:1;justify-content:space-between;align-items:flex-start;padding-top:6px;display:flex}.timeline-main-info{flex:1}.timeline-event-title{color:#0f172a;margin:0 0 4px;font-size:13px;font-weight:700}.timeline-event-desc{color:#64748b;margin:0;font-size:12px}.timeline-reason-box{color:#1e40af;background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;margin-top:12px;padding:10px 14px;font-size:12px}.timeline-meta-info{flex-direction:column;align-items:flex-end;gap:4px;min-width:150px;display:flex}.timeline-event-date{color:#94a3b8;font-size:11px;font-weight:500}.timeline-user-tag{border-radius:4px;padding:2px 10px;font-size:10px;font-weight:700}.timeline-user-tag.blue{color:#2563eb;background:#eff6ff}.timeline-user-tag.orange{color:#f97316;background:#fff7ed}.timeline-user-tag.purple{color:#7c3aed;background:#f5f3ff}.timeline-user-tag.green{color:#16a34a;background:#f0fdf4}.timeline-user-tag.red{color:#f43f5e;background:#fff1f2}@media (width<=1024px){.detail-layout{grid-template-columns:1fr}}@media (width<=768px){.timeline-content-alt{flex-direction:column;gap:12px}.timeline-meta-info{align-items:flex-start;min-width:auto}}.submit-grievance-container{background-color:#f8fafc;grid-template-columns:1fr 320px;gap:24px;min-height:calc(100vh - 80px);padding:24px;display:grid}.sg-main-card{background:#fff;border:1px solid #eef2f7;border-radius:16px;flex-direction:column;display:flex;box-shadow:0 4px 20px #00000008}.sg-header-alt{padding:32px 32px 24px}.sg-title-alt{color:#0f172a;margin:0;font-size:24px;font-weight:800}.sg-subtitle-alt{color:#64748b;margin-top:8px;font-size:14px}.sg-form-alt{flex:1;padding:0 32px 32px}.sg-form-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}.sg-field-group{flex-direction:column;gap:8px;display:flex}.sg-label-alt{color:#334155;font-size:12px;font-weight:700}.sg-label-alt .required{color:#ef4444;margin-left:2px}.sg-input-wrapper{align-items:center;display:flex;position:relative}.sg-input-icon{color:#2563eb;background:#eff6ff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex;position:absolute;left:12px}.sg-select-alt,.sg-input-alt,.sg-textarea-alt{color:#1e293b;background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;padding:12px 16px;font-size:13px;transition:all .2s}.sg-select-alt{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;background-size:16px;padding-left:52px}.sg-select-alt:focus,.sg-input-alt:focus,.sg-textarea-alt:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f614}.sg-textarea-wrapper{position:relative}.sg-textarea-alt{resize:none;min-height:180px}.sg-char-count{color:#94a3b8;font-size:11px;position:absolute;bottom:12px;right:12px}.sg-upload-section{margin-top:24px}.sg-upload-label{color:#334155;margin-bottom:12px;font-size:13px;font-weight:700}.sg-dropzone-alt{text-align:center;cursor:pointer;background:#fbfdff;border:1px dashed #cbd5e1;border-radius:12px;padding:32px;transition:all .2s}.sg-dropzone-alt:hover{background:#f0f7ff;border-color:#3b82f6}.sg-cloud-icon{color:#2563eb;background:#eff6ff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 16px;font-size:20px;display:flex}.sg-upload-text{color:#475569;font-size:13px}.sg-upload-text span{color:#2563eb;font-weight:700}.sg-upload-hint{color:#94a3b8;margin-top:8px;font-size:11px}.sg-footer-alt{border-top:1px solid #eef2f7;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.btn-cancel{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px 24px;font-size:13px;font-weight:700;transition:all .2s}.btn-cancel:hover{background:#f8fafc;border-color:#cbd5e1}.btn-submit{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:10px;align-items:center;gap:12px;padding:10px 28px;font-size:13px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #2563eb33}.btn-submit:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 6px 16px #2563eb40}.sg-sidebar{flex-direction:column;gap:24px;display:flex}.sg-sidebar-card{background:#fff;border:1px solid #eef2f7;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000005}.sg-sidebar-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.sg-sidebar-icon{color:#2563eb;background:#eff6ff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.sg-sidebar-title{color:#1e293b;font-size:14px;font-weight:700}.sg-sidebar-list{flex-direction:column;gap:24px;display:flex;position:relative}.sg-sidebar-list:before{content:"";background:#e2e8f0;border-style:dashed;width:1px;position:absolute;top:32px;bottom:0;left:15px}.sg-sidebar-item{z-index:1;gap:16px;display:flex;position:relative}.sg-item-bullet{color:#2563eb;background:#eff6ff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.sg-item-content{flex-direction:column;gap:4px;display:flex}.sg-item-title{color:#334155;font-size:13px;font-weight:700}.sg-item-desc{color:#64748b;font-size:11px;line-height:1.5}.privacy-banner{background:#f0f7ff;border:1px solid #dbeafe;border-radius:12px;align-items:flex-start;gap:12px;padding:16px;display:flex}.privacy-icon{color:#2563eb;margin-top:2px;font-size:20px}.privacy-content h4{color:#1e40af;margin:0 0 4px;font-size:13px;font-weight:700}.privacy-content p{color:#60a5fa;margin:0;font-size:11px;line-height:1.4}@media (width<=1024px){.submit-grievance-container{grid-template-columns:1fr}.sg-sidebar{order:2}}@media (width<=640px){.sg-form-grid{grid-template-columns:1fr}.sg-header-alt,.sg-form-alt,.sg-footer-alt{padding-left:20px;padding-right:20px}}@media (width<=576px){.submit-grievance-container{padding:0}.sg-main-card{border-left:none;border-right:none;border-radius:0}}.sg-input-disabled input{color:#64748b;cursor:not-allowed;background-color:#f1f5f9;border-color:#cbd5e1}.sg-alert-banner{border-radius:12px;align-items:center;gap:12px;margin-bottom:24px;padding:16px 20px;font-size:13px;font-weight:500;animation:.3s ease-out slideDown;display:flex}.sg-alert-banner.error{color:#991b1b;background:#fef2f2;border:1px solid #fee2e2}.sg-alert-banner.success{color:#166534;background:#f0fdf4;border:1px solid #dcfce7}.sg-hostel-info-banner{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:10px;margin-bottom:24px;padding:18px;display:flex}.sg-hostel-info-header{color:#1e293b;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;font-size:12px;font-weight:700;display:flex}.sg-hostel-info-header i{color:#2563eb}.sg-hostel-info-grid{color:#475569;grid-template-columns:repeat(3,1fr);gap:16px;font-size:13px;display:grid}.sg-hostel-info-grid strong{color:#1e293b}.sg-uploaded-file-details{text-align:left;align-items:center;gap:16px;width:100%;display:flex}.sg-file-info-text{flex-direction:column;flex:1;gap:4px;display:flex}.sg-file-name{color:#334155;word-break:break-all;font-size:13px;font-weight:700}.sg-file-size{color:#64748b;font-size:11px}.sg-remove-file-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.sg-remove-file-btn:hover{color:#ef4444;background:#fee2e2}.sg-dropzone-has-file{background:#f0fdf4;border-color:#10b981}.sg-dropzone-has-file:hover{background:#f0fdf4;border-color:#059669}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sg-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999;background:#0f172a73;justify-content:center;align-items:center;animation:.3s ease-out forwards fadeIn;display:flex;position:fixed;inset:0}.sg-modal-card{text-align:center;opacity:0;background:#fff;border-radius:24px;width:90%;max-width:480px;padding:40px 32px;animation:.35s cubic-bezier(.34,1.56,.64,1) forwards scaleIn;transform:scale(.9);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.sg-modal-icon-wrap{color:#10b981;background:#d1fae5;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 24px;font-size:36px;animation:2s infinite pulse;display:flex;position:relative;box-shadow:0 0 #10b98166}.sg-modal-title{color:#0f172a;margin-bottom:12px;font-size:20px;font-weight:800}.sg-modal-desc{color:#64748b;margin-bottom:24px;font-size:14px;line-height:1.6}.sg-ticket-info-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:28px;padding:16px}.sg-ticket-label{color:#64748b;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-size:11px;font-weight:700}.sg-ticket-badge{color:#2563eb;letter-spacing:.5px;font-size:16px;font-weight:800}.sg-modal-redirect-text{color:#94a3b8;justify-content:center;align-items:center;gap:8px;margin-top:20px;font-size:12px;display:flex}.sg-modal-redirect-text i{color:#3b82f6}
