*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{background-color:#f5f5f5;min-height:100vh}.page-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.page-container h1{color:#1976d2;font-size:2.5rem;margin-bottom:20px}.page-container p{color:#666;font-size:1.1rem;margin-bottom:10px;max-width:600px;text-align:center}.card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:20px;max-width:800px;padding:30px;width:100%}.button{background-color:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;margin:10px;padding:12px 24px;transition:background-color .3s}.button:hover{background-color:#1565c0}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:20px}.stat-card{border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.stat-card h3{color:#666;font-size:.9rem;font-weight:500;margin-bottom:10px;text-transform:uppercase}.stat-card p{color:#1976d2;font-size:2rem;font-weight:700;margin:0}.toast-container{display:flex;flex-direction:column;gap:10px;max-width:400px;position:fixed;right:20px;top:20px;z-index:10000}.toast{align-items:center;animation:slideIn .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;min-width:280px;padding:14px 16px}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;width:24px}.toast-success .toast-icon{background:#e8f5e9;color:#2e7d32}.toast-error .toast-icon{background:#ffebee;color:#c62828}.toast-warning .toast-icon{background:#fff3e0;color:#ef6c00}.toast-info .toast-icon{background:#e3f2fd;color:#1976d2}.toast-message{color:#333;flex:1 1;font-size:14px;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;padding:0;transition:background .2s,color .2s;width:24px}.toast-close:hover{background:#f5f5f5;color:#666}.toast-success{border-left:4px solid #2e7d32}.toast-error{border-left:4px solid #c62828}.toast-warning{border-left:4px solid #ef6c00}.toast-info{border-left:4px solid #1976d2}.confirm-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.confirm-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:420px;overflow:hidden;width:90%}.confirm-header{align-items:center;border-bottom:1px solid #eee;display:flex;gap:12px;padding:20px 24px}.confirm-header.confirm-danger{background:linear-gradient(135deg,#fee2e2,#fecaca)}.confirm-header.confirm-warning{background:linear-gradient(135deg,#fef3c7,#fde68a)}.confirm-header.confirm-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.confirm-icon{font-size:24px}.confirm-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.confirm-body{padding:24px}.confirm-body p{color:#4b5563;font-size:15px;line-height:1.6;margin:0}.confirm-footer{background:#f9fafb;border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.confirm-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.confirm-btn-cancel{background:#fff;border:1px solid #d1d5db;color:#374151}.confirm-btn-cancel:hover{background:#f3f4f6;border-color:#9ca3af}.confirm-btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.confirm-btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.confirm-btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.confirm-btn-warning:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #f59e0b66;transform:translateY(-1px)}.confirm-btn-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.confirm-btn-info:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:450px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;padding:40px 30px;text-align:center}.login-header h1{font-size:2rem;font-weight:600;margin:0 0 10px}.login-header p{font-size:.95rem;margin:0;opacity:.9}.login-form{padding:40px 30px}.form-group{margin-bottom:24px}.form-group label{color:#333;font-size:.95rem}.form-group input{border:2px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .3s;width:100%}.form-group input:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.password-toggle{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px;transition:color .2s}.password-toggle:hover{color:#1976d2}.forgot-password-link{margin-top:8px;text-align:right}.forgot-password-link a{color:#1976d2;font-size:.9rem;text-decoration:none;transition:color .2s}.forgot-password-link a:hover{color:#1565c0;text-decoration:underline}.forgot-password-text{color:#666;font-size:.95rem;line-height:1.5;margin-bottom:24px}.success-message{background-color:#e8f5e9;border-left:4px solid #4caf50;border-radius:6px;color:#2e7d32;margin-bottom:20px;padding:20px;text-align:center}.success-message h3{font-size:1.1rem;margin:0 0 8px}.success-message p{font-size:.9rem;margin:0}.back-to-login{margin-top:20px;text-align:center}.back-to-login a{color:#1976d2;font-size:.95rem;text-decoration:none}.back-to-login a:hover{text-decoration:underline}.error-message{background-color:#ffebee;border-left:4px solid #c62828;border-radius:6px;color:#c62828;font-size:.9rem;margin-bottom:20px;padding:12px 16px}.login-button{background:linear-gradient(135deg,#1976d2,#1565c0);border:none;border-radius:6px;box-shadow:0 4px 12px #1976d24d;color:#fff;cursor:pointer;font-size:1.05rem;font-weight:600;padding:14px;transition:all .3s;width:100%}.login-button:hover:not(:disabled){box-shadow:0 6px 20px #1976d266;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.demo-credentials{background-color:#f5f5f5;border-radius:6px;margin-top:24px;padding:16px;text-align:center}.demo-credentials p{color:#666;font-size:.9rem;margin:4px 0}.demo-credentials p:first-child{color:#333;font-weight:600;margin-bottom:8px}.backend-status{background-color:#f9f9f9;border-top:1px solid #e0e0e0;padding:20px 30px;text-align:center}.backend-status p{color:#666;font-size:.85rem;margin:0}.status-indicator{animation:pulse 2s infinite;color:#4caf50;font-size:1.2rem;margin-right:4px;vertical-align:middle}.sidebar{background:linear-gradient(180deg,#1e3c72,#2a5298);box-shadow:2px 0 10px #0000001a;color:#fff;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:260px}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:25px 20px;text-align:center}.sidebar-header h2{color:#fff;font-size:24px;font-weight:700;margin:0}.sidebar-header p{color:#b8d4ff;font-size:12px;margin:5px 0 0;opacity:.8}.sidebar-nav{flex:1 1;overflow-y:auto;padding:20px 0}.nav-item{margin-bottom:5px}.nav-link{align-items:center;border-left:3px solid #0000;color:#ffffffe6;cursor:pointer;display:flex;padding:12px 20px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#ffffff1a;border-left-color:#64b5f6}.nav-link.active{background:#ffffff26;border-left-color:#fff;font-weight:600}.nav-link-parent{justify-content:space-between}.nav-icon{font-size:18px;margin-right:12px;min-width:24px}.nav-title{flex:1 1;font-size:14px}.nav-arrow{font-size:10px;opacity:.7;transition:transform .3s ease}.submenu{animation:slideDown .3s ease;background:#0000001a;margin:5px 0}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:500px;opacity:1}}.submenu-link{font-size:13px;padding:10px 20px 10px 56px}.submenu-title{color:#ffffffd9}.sidebar-footer{background:#00000026;border-top:1px solid #ffffff26;padding:16px}.user-info{gap:14px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;flex-shrink:0;font-size:18px;font-weight:700;height:42px;justify-content:center;width:42px}.user-details{flex:1 1;min-width:0}.user-role{color:#fff;font-size:14px;font-weight:600;margin:0 0 6px}.user-email{color:#ffffffb3;font-size:12px;line-height:1.3;margin:0;word-break:break-all}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#0000001a}.sidebar::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff80}.layout{background:#f5f7fa;display:flex;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:260px}.top-header{align-items:center;background:#fff;box-shadow:0 2px 4px #0000000d;display:flex;height:65px;justify-content:space-between;padding:0 30px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-left h1{color:#2c3e50;font-size:20px;font-weight:600;margin:0}.header-right{align-items:center;display:flex;gap:15px}.notification-btn,.profile-btn{background:#f0f2f5;border:none;border-radius:50%;cursor:pointer;font-size:18px;height:40px;position:relative;transition:all .3s ease;width:40px}.notification-btn:hover,.profile-btn:hover{background:#e4e6eb;transform:scale(1.05)}.notification-btn .badge{align-items:center;background:#e74c3c;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:10px;font-weight:700;height:18px;justify-content:center;position:absolute;right:-2px;top:-2px;width:18px}.logout-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.logout-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.header-dropdown{position:relative}.dropdown-menu{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;margin-top:8px;min-width:220px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.dropdown-header{border-bottom:1px solid #f0f2f5;color:#333;font-size:14px;padding:12px 16px}.dropdown-header strong{display:block;font-size:15px}.dropdown-header .user-email{color:#666;display:block;font-size:12px;margin-top:2px}.dropdown-content{padding:12px 16px}.dropdown-content .empty-message{color:#666;font-size:13px;margin:0;text-align:center}.dropdown-items{padding:8px 0}.dropdown-items button{background:none;border:none;color:#333;cursor:pointer;font-size:14px;padding:10px 16px;text-align:left;transition:background .2s ease;width:100%}.dropdown-items button:hover{background:#f0f2f5}.notification-menu{max-height:450px;min-width:350px}.notification-menu .dropdown-header{align-items:center;display:flex;justify-content:space-between}.mark-all-read-btn{background:none;border:none;border-radius:4px;color:#06c;cursor:pointer;font-size:12px;padding:4px 8px}.mark-all-read-btn:hover{background:#e6f0ff}.mark-all-read-btn:disabled{cursor:not-allowed;opacity:.5}.notification-list{max-height:350px;overflow-y:auto;padding:0!important}.notification-item{align-items:flex-start;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;padding:12px 15px;position:relative;transition:background .2s ease}.notification-item:hover{background:#f8f9fa}.notification-item.unread{background:#f0f7ff}.notification-item.unread:hover{background:#e6f0ff}.notification-icon{flex-shrink:0;font-size:20px;margin-right:12px}.notification-content{flex:1 1;min-width:0}.notification-title{color:#333;font-size:13px;font-weight:600;margin-bottom:4px}.notification-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:12px;line-height:1.4;margin-bottom:4px;overflow:hidden}.notification-time{color:#999;font-size:11px}.unread-dot{background:#06c;border-radius:50%;flex-shrink:0;height:8px;margin-left:8px;margin-top:6px;width:8px}.profile-menu{min-width:200px}.page-content{flex:1 1;padding:30px}@media (max-width:768px){.main-content{margin-left:0}.top-header{padding:0 15px}.header-left h1{font-size:16px}.page-content{padding:15px}}.dashboard-content,.dashboard-page{width:100%}.error-banner{background-color:#ffebee;border-left:4px solid #c62828;border-radius:8px;color:#c62828;margin-bottom:24px;padding:16px 20px}.info-section,.quick-actions,.stats-section,.status-section{margin-bottom:40px}.info-section h2,.quick-actions h2,.stats-section h2,.status-section h2{color:#333;font-size:1.4rem;font-weight:600;margin:0 0 20px}.stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.stat-card{display:flex;gap:16px;transition:transform .3s,box-shadow .3s}.stat-card:hover{box-shadow:0 8px 16px #0000001f;transform:translateY(-4px)}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:28px;height:60px;justify-content:center;width:60px}.stat-content h3{color:#666;font-size:.9rem;font-weight:500;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.stat-number{color:#1976d2;font-size:2rem;font-weight:700;margin:0 0 4px}.stat-label{color:#999;font-size:.85rem}.status-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(6,1fr)}@media (max-width:1200px){.status-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.status-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.status-grid{grid-template-columns:1fr}}.status-item{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;flex-direction:column;gap:12px;justify-content:center;min-height:100px;padding:20px;text-align:center}.status-badge{flex-shrink:0;font-size:.75rem;letter-spacing:.3px;padding:6px 10px;white-space:nowrap}.status-badge.approved{background:#e3f2fd;color:#1976d2}.status-badge.in-progress{background:#e8f5e9;color:#388e3c}.status-badge.resolved{background:#e8f5e9;color:#2e7d32}.status-badge.rejected{background:#ffebee;color:#c62828}.status-badge.assigned{background:#e0f7fa;color:#00838f}.status-count{color:#333;font-size:2rem;line-height:1}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;padding:20px;text-align:center}.info-card h4{color:#666;font-size:.9rem;font-weight:500;margin:0 0 8px}.info-card p{color:#1976d2;font-size:1.3rem;font-weight:600;margin:0}.action-buttons{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-btn{background:#fff;border:2px solid #1976d2;border-radius:8px;color:#1976d2;cursor:pointer;font-size:1rem;font-weight:600;padding:16px 24px;transition:all .3s}.action-btn:hover{background:#1976d2;box-shadow:0 4px 12px #1976d24d;color:#fff;transform:translateY(-2px)}.charts-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:40px}@media (max-width:1024px){.charts-section{grid-template-columns:1fr}}.chart-header{align-items:center;display:flex;justify-content:space-between}.chart-header h3{color:#333;font-size:1.1rem}.view-all-btn{background:none;border:none;border-radius:4px;color:#1976d2;cursor:pointer;font-size:.9rem;font-weight:500;padding:4px 8px;transition:background .3s}.view-all-btn:hover{background:#e3f2fd}.bottom-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:40px}@media (max-width:1024px){.bottom-section{grid-template-columns:1fr}}.recent-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.recent-list{display:flex;flex-direction:column;gap:12px}.recent-item{align-items:center;background:#f8f9fa;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:background .3s,transform .2s}.recent-item:hover{background:#e9ecef;transform:translateX(4px)}.recent-info{display:flex;flex-direction:column;gap:4px}.recent-number{color:#1976d2;font-size:.85rem;font-weight:600}.recent-title{color:#666;font-size:.9rem}.no-data{color:#999;font-style:italic;padding:40px 20px;text-align:center}.stat-card{cursor:pointer}.stat-card.highlight{animation:pulse 2s infinite;border:2px solid #e91e63}@keyframes pulse{0%,to{box-shadow:0 2px 8px #00000014}50%{box-shadow:0 4px 16px #e91e6333}}.status-item{cursor:pointer;transition:transform .2s,box-shadow .2s}.status-item:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.pagination-container{align-items:center;border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-top:20px;padding:16px 0}.pagination-info{color:#666;font-size:14px}.pagination-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.items-per-page{align-items:center;color:#666;display:flex;font-size:14px;gap:8px}.items-per-page select{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 10px}.items-per-page select:hover{border-color:#1976d2}.pagination-buttons{align-items:center;display:flex;gap:4px}.pagination-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;display:flex;font-size:14px;height:36px;justify-content:center;min-width:36px;padding:0 8px;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f5f5f5;border-color:#1976d2;color:#1976d2}.pagination-btn.active{background:#1976d2;border-color:#1976d2;color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-ellipsis{color:#999;padding:0 8px}@media (max-width:768px){.pagination-container{align-items:flex-start;flex-direction:column}.pagination-controls{justify-content:space-between;width:100%}}.categories-page{width:100%}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.page-header h1{color:#2c3e50;font-size:28px;font-weight:700;margin:0 0 5px}.page-header p{color:#7f8c8d;font-size:14px;margin:0}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:#f8f9fa}.data-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #e9ecef;color:#495057;padding:16px}.data-table tbody tr:hover{background:#f8f9fa}.icon-cell{font-size:24px;text-align:center;width:60px}.category-icon-img{border-radius:8px;height:40px;object-fit:contain;width:40px}.icon-upload-container{background:#f8f9fa;border:2px dashed #ced4da;border-radius:8px;padding:16px}.icon-preview{align-items:center;display:inline-flex;justify-content:center;margin-bottom:12px;position:relative}.icon-preview img{object-fit:contain}.icon-preview .emoji-preview,.icon-preview img{background:#fff;border:1px solid #e9ecef;border-radius:8px;height:80px;width:80px}.icon-preview .emoji-preview{font-size:48px}.icon-preview .emoji-preview,.remove-icon-btn{align-items:center;display:flex;justify-content:center}.remove-icon-btn{background:#c62828;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:16px;height:24px;line-height:1;position:absolute;right:-8px;top:-8px;width:24px}.icon-upload-options{align-items:center;display:flex;gap:12px}.upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.upload-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.or-divider{color:#999;font-size:14px}.emoji-input{flex:1 1;max-width:200px}.status-badge{text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.action-buttons{gap:8px}.btn-delete,.btn-edit{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .3s ease}.btn-edit{background:#e3f2fd;color:#1976d2}.btn-edit:hover{background:#1976d2;color:#fff}.btn-delete{background:#ffebee;color:#c62828}.btn-delete:hover{background:#c62828;color:#fff}.modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#2c3e50;font-size:22px;font-weight:700;margin:0}.close-btn{background:none;border:none;color:#999;cursor:pointer;font-size:32px;height:32px;line-height:1;padding:0;width:32px}.close-btn:hover{color:#333}.modal-content form{padding:24px}.form-section{margin-bottom:24px}.form-section h3{border-bottom:2px solid #e9ecef;color:#495057;font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.form-group{margin-bottom:16px}.form-group label{color:#495057;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group textarea{border:1px solid #ced4da;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:8px;padding-top:28px}.checkbox-label input[type=checkbox]{cursor:pointer;width:auto}.checkbox-label span{color:#495057;font-size:14px;font-weight:500}.modal-footer{border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.btn-secondary{background:#e9ecef;border:none;border-radius:6px;color:#495057;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-secondary:hover{background:#ced4da}.loading{color:#666;display:flex;font-size:1.2rem;justify-content:center;min-height:60vh}.filters-grid,.loading{align-items:center}.filter-input,.filter-select{background:#fff}.filter-select{cursor:pointer}.password-toggle-btn{padding:5px;transition:opacity .2s ease}.password-toggle-btn:focus{outline:none}.input-error,.input-error:focus{border-color:#dc3545!important}.input-error:focus{box-shadow:0 0 0 2px #dc354533}.error-text{color:#dc3545;display:block;font-size:12px;margin-top:4px}.complaints-page{width:100%}.filters-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:20px}.filters-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-input,.filter-select{border:1px solid #ced4da;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .3s ease}.filter-input:focus,.filter-select:focus{border-color:#667eea;outline:none}.stealth-badge{background:#333;border-radius:12px;color:#fff;font-size:11px;margin-left:8px;padding:2px 8px}.status-badge,.stealth-badge{display:inline-block;font-weight:600}.status-badge{border-radius:20px;font-size:12px;padding:6px 12px;text-transform:capitalize}.status-pending{background:#fff3e0;color:#f57c00}.status-approved{background:#e3f2fd;color:#1976d2}.status-assigned,.status-notified{background:#f3e5f5;color:#7b1fa2}.status-in-progress{background:#e8f5e9;color:#388e3c}.status-resolved{background:#e8f5e9;color:#2e7d32}.status-closed{background:#e0e0e0;color:#616161}.status-rejected{background:#ffebee;color:#c62828}.btn-view{background:#e3f2fd;border:none;border-radius:4px;color:#1976d2;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.btn-view:hover{background:#1976d2;color:#fff}.btn-approve{background:#e8f5e9;border:none;border-radius:4px;color:#2e7d32;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.btn-approve:hover{background:#2e7d32;color:#fff}.btn-reject{background:#ffebee;border:none;border-radius:4px;color:#c62828;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.btn-reject:hover{background:#c62828;color:#fff}.btn-assign{background:#f3e5f5;border:none;border-radius:4px;color:#7b1fa2;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.btn-assign:hover{background:#7b1fa2;color:#fff}.btn-danger{background:#c62828;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-danger:hover{background:#b71c1c}.modal-large{max-width:800px}.modal-body{max-height:60vh;overflow-y:auto;padding:24px}.detail-grid{grid-gap:20px;gap:20px;grid-template-columns:1fr 1fr}.detail-item.full-width{grid-column:1/-1}.detail-item label{font-size:12px}.detail-item p,.detail-item span{color:#333;font-size:14px;margin:0}.detail-item p{line-height:1.6;white-space:pre-wrap}.action-buttons{display:flex;flex-wrap:wrap;gap:6px}.media-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:8px}.media-item{align-items:center;aspect-ratio:1;background:#f5f5f5;border-radius:8px;display:flex;justify-content:center;overflow:hidden;position:relative}.media-thumbnail{cursor:pointer;height:100%;object-fit:cover;transition:transform .2s ease;width:100%}.media-thumbnail:hover{transform:scale(1.05)}.media-audio,.media-video{max-height:150px;width:100%}.video-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;flex-direction:column;height:100%;justify-content:center;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease;width:100%}.video-placeholder:hover{box-shadow:0 4px 12px #667eea66;transform:scale(1.02)}.video-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;font-size:24px;height:50px;justify-content:center;margin-bottom:8px;width:50px}.video-placeholder span{font-size:12px;font-weight:500;opacity:.9}.media-type-badge{background:#000000b3;border-radius:4px;bottom:8px;color:#fff;font-size:10px;font-weight:600;padding:2px 8px;position:absolute;right:8px;text-transform:uppercase}.status-history{display:flex;flex-direction:column;gap:12px;margin-top:8px}.status-history-item{background:#f8f9fa;border-left:3px solid #667eea;border-radius:8px;padding:12px}.status-history-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.status-history-date{color:#666;font-size:12px}.status-history-remarks{background:#fff;border:1px solid #e0e0e0;border-radius:4px;color:#333;font-size:13px;margin:8px 0;padding:8px 12px}.status-history-by{color:#888;font-size:11px;font-style:italic}.users-page{width:100%}.search-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:12px;margin-bottom:20px;padding:20px}.search-input{border:1px solid #ced4da;border-radius:6px;flex:1 1;font-size:14px;padding:10px 12px;transition:border-color .3s ease}.search-input:focus{border-color:#667eea;outline:none}.tabs-section{background:#fff;border-radius:12px 12px 0 0;box-shadow:0 2px 8px #00000014;display:flex;gap:0;margin-bottom:0;overflow:hidden;padding:0}.tab-btn{background:#fff;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:16px 24px;transition:all .3s ease}.tab-btn.active,.tab-btn:hover{background:#f8f9fa}.tab-btn.active{border-bottom-color:#667eea;color:#667eea}.tabs-section+.table-container{border-radius:0 0 12px 12px;margin-top:0}.btn-activate{background:#e8f5e9;border:none;border-radius:4px;color:#2e7d32;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.btn-activate:hover{background:#2e7d32;color:#fff}.btn-deactivate{background:#ffebee;border:none;border-radius:4px;color:#c62828;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.btn-deactivate:hover{background:#c62828;color:#fff}.status-badge.pending{background:#fff3e0;color:#f57c00}.roles-page{width:100%}.permission-tags{display:flex;flex-wrap:wrap;gap:6px}.permission-tag{background:#e3f2fd;border-radius:12px;color:#1976d2;display:inline-block;font-size:11px;font-weight:600;padding:4px 10px}.permissions-matrix{background:#f8f9fa;border-radius:8px;overflow-x:auto;padding:16px}.permissions-table{background:#fff;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.permissions-table th{background:#667eea;color:#fff;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px;text-align:left;text-transform:uppercase}.permissions-table th:first-child{width:40%}.permissions-table td{border-bottom:1px solid #e9ecef;padding:12px;text-align:center}.permissions-table td:first-child{text-align:left}.permissions-table tbody tr:hover{background:#f8f9fa}.permissions-table input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.modal-large .modal-body{max-height:70vh;overflow-y:auto}.profile-page{width:100%}.message-banner{align-items:center;animation:slideDown .3s ease;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:24px;padding:16px 20px}.message-banner.success{background:#d4edda;border-left:4px solid #28a745;color:#155724}.message-banner.error{background:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.close-message{background:none;border:none;color:inherit;cursor:pointer;font-size:24px;line-height:1;opacity:.7;padding:0}.close-message:hover{opacity:1}.profile-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 350px}.profile-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.profile-header-section{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;gap:24px;padding:40px}.profile-avatar{align-items:center;background:#fff;border-radius:50%;box-shadow:0 4px 12px #0003;color:#667eea;display:flex;font-size:36px;font-weight:700;height:80px;justify-content:center;width:80px}.profile-info h2{color:#fff;font-size:28px;font-weight:700;margin:0 0 8px}.role-badge{background:#fff3;border:1px solid #ffffff4d;border-radius:20px;color:#fff;display:inline-block;font-size:14px;font-weight:600;margin:0;padding:6px 16px}.profile-divider{background:#e9ecef;height:1px}.profile-details,.profile-form{padding:32px 40px}.detail-section,.security-section{margin-bottom:32px}.detail-section:last-child{margin-bottom:0}.detail-section h3,.security-section h3{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.detail-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr)}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-item label{color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-item span{color:#333;font-size:15px;font-weight:500}.security-section{background:#f8f9fa;border-radius:8px;padding:20px}.security-item{align-items:center;display:flex;justify-content:space-between}.security-item h4{color:#2c3e50;font-size:16px;font-weight:600;margin:0 0 4px}.security-item p{color:#666;font-size:13px;margin:0}.profile-form .form-section{margin-bottom:24px}.profile-form .form-section h3{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.form-actions{border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;padding-top:24px}.profile-sidebar{display:flex;flex-direction:column;gap:20px}.sidebar-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.sidebar-card h3{color:#2c3e50;font-size:16px;font-weight:600;margin:0 0 16px}.stats-list{display:flex;flex-direction:column;gap:16px}.stat-item{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding-bottom:16px}.stat-item:last-child{border-bottom:none;padding-bottom:0}.stat-label{color:#666;font-size:13px;font-weight:500}.stat-value{color:#2c3e50;font-size:14px;font-weight:600}.stat-value.text-success{color:#28a745}.stat-value.text-danger{color:#dc3545}.permission-text{color:#666;font-size:13px;line-height:1.6;margin:0 0 16px}.permissions-preview{background:#f8f9fa;border-radius:6px;padding:12px}.small-text{color:#666;font-size:12px;font-weight:600;margin:0 0 8px}.permissions-list{list-style:none;margin:0;padding:0}.permissions-list li{color:#333;font-size:13px;padding:4px 0 4px 16px;position:relative}.permissions-list li:before{color:#28a745;content:"✓";font-weight:700;left:0;position:absolute}.permissions-detail-list{display:flex;flex-direction:column;gap:10px}.permission-item{background:#fff;border:1px solid #e9ecef;border-radius:6px;display:flex;flex-direction:column;gap:6px;padding:10px 12px}.permission-module{color:#2c3e50;font-size:13px;font-weight:600;text-transform:capitalize}.permission-actions{display:flex;flex-wrap:wrap;gap:4px}.permission-badge{border-radius:10px;font-size:10px;font-weight:600;letter-spacing:.3px;padding:2px 8px;text-transform:uppercase}.permission-badge.read{background:#e3f2fd;color:#1565c0}.permission-badge.create{background:#e8f5e9;color:#2e7d32}.permission-badge.update{background:#fff3e0;color:#ef6c00}.permission-badge.delete{background:#ffebee;color:#c62828}.more-permissions-btn{background:#0000;border:1px dashed #667eea;border-radius:4px;color:#667eea;cursor:pointer;display:block;font-size:13px;font-weight:600;margin-top:8px;padding:8px 12px;transition:all .2s ease;width:100%}.more-permissions-btn:hover{background:#667eea;border-style:solid;color:#fff}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{flex:1 1;padding-right:45px}.password-toggle-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:18px;justify-content:center;opacity:.7;padding:4px;position:absolute;right:10px;transition:opacity .2s}.password-toggle-btn:hover{opacity:1}@media (max-width:1024px){.detail-grid,.profile-container{grid-template-columns:1fr}}.reports-page{width:100%}.date-filters{align-items:center;display:flex;gap:12px}.reports-content{margin-top:20px}.overview-tab{display:flex;flex-direction:column;gap:24px}.charts-grid{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-template-columns:1fr 1fr}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.chart-card.full-width{grid-column:1/-1}.chart-header{margin-bottom:20px}.chart-header h3{color:#2c3e50;font-size:18px;font-weight:600;margin:0}.stats-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px;text-align:center}.stat-card h4{color:#666;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.stat-value{color:#667eea;font-size:32px;font-weight:700;margin:0}.report-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.report-header h3{color:#2c3e50;font-size:20px;font-weight:600;margin:0}.btn-export{background:linear-gradient(135deg,#43e97b,#38f9d7);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-export:hover{box-shadow:0 4px 12px #43e97b66;transform:translateY(-2px)}.text-success{color:#28a745;font-weight:600}.text-warning{color:#ffc107;font-weight:600}.text-danger{color:#dc3545;font-weight:600}.status-breakdown{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;box-sizing:border-box;display:flex;flex-direction:column;height:100%;padding:24px}.status-breakdown h4{border-bottom:2px solid #667eea;color:#2c3e50;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.status-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:8px;padding:16px 12px;transition:all .2s ease}.status-item:hover{background:#f0f2f5;transform:translateX(4px)}.status-item:last-child{margin-bottom:0}.status-info{align-items:center;display:flex;gap:12px}.status-dot{border-radius:50%;box-shadow:0 2px 4px #0003;flex-shrink:0;height:14px;width:14px}.status-name{color:#333;font-size:14px;font-weight:600;text-transform:capitalize}.status-count{background:#fff;border-radius:20px;box-shadow:0 1px 3px #0000001a;color:#667eea;font-size:18px;font-weight:700;min-width:40px;padding:4px 12px;text-align:center}.progress-bar{background:#e9ecef;border-radius:14px;height:28px;overflow:hidden;position:relative;width:100%}.progress-fill{background:linear-gradient(90deg,#43e97b,#38f9d7);height:100%;left:0;position:absolute;top:0;transition:width .3s ease}.progress-text{align-items:center;color:#333;display:flex;font-size:12px;font-weight:700;height:100%;justify-content:center;position:relative;z-index:1}@media (max-width:768px){.charts-grid,.stats-cards{grid-template-columns:1fr}}
/*# sourceMappingURL=main.ca3d7686.css.map*/