.login-container{align-items:center;background:linear-gradient(135deg,var(--color-bg-dark) 0,#1e3a8a 100%);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);max-width:420px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,var(--color-pd) 0,#1e40af 100%);color:#fff;padding:40px 30px;text-align:center}.login-logo{display:flex;justify-content:center;margin-bottom:20px}.login-header h1{font-size:28px;font-weight:700;letter-spacing:-.5px;margin-bottom:8px}.login-header p{font-size:14px;font-weight:500;opacity:.9}.login-form{padding:40px 30px}.form-group{margin-bottom:24px}.form-group input{background:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;padding:12px 14px;transition:var(--transition);width:100%}.form-group input:focus{border-color:var(--color-pd);box-shadow:0 0 0 3px #1e40af1a;outline:none}.form-group input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.error-message{border-radius:8px;color:var(--color-error);margin-bottom:20px}.login-button{background:linear-gradient(135deg,var(--color-pd) 0,#1e40af 100%);border-radius:8px;color:#fff;font-size:15px;font-weight:600;padding:12px;transition:var(--transition);width:100%}.login-button:hover:not(:disabled){box-shadow:0 6px 12px #1e40af66;transform:translateY(-2px)}.login-button:disabled{cursor:not-allowed;opacity:.7}.login-footer{background-color:#f8fafc;border-top:1px solid var(--color-border);padding:30px}.login-footer p{color:#64748b;font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:15px;text-transform:uppercase}.demo-accounts{display:flex;flex-direction:column;gap:12px}.account{background-color:#fff;color:#475569;display:flex;font-size:13px;gap:10px;padding:8px}.account,.badge{align-items:center;border-radius:6px}.badge{color:#fff;display:inline-flex;font-size:11px;font-weight:700;height:28px;justify-content:center;width:40px}.badge.pd{background:linear-gradient(135deg,var(--color-pd),#1e40af)}.badge.ems{background:linear-gradient(135deg,var(--color-ems),#b91c1c)}.badge.superadmin{background:linear-gradient(135deg,var(--color-superadmin),#6d28d9)}@media (max-width:480px){.login-box{max-width:100%}.login-header{padding:30px 20px}.login-header h1{font-size:24px}.login-form{padding:30px 20px}.login-footer{padding:20px}}.upload-container{background:linear-gradient(135deg,var(--color-bg-dark) 0,#1e3a8a 100%);min-height:100vh;padding:40px 20px}.upload-header{margin-bottom:40px;text-align:center}.upload-header h1{color:#fff;font-size:36px;font-weight:700;margin-bottom:10px}.upload-header p{color:#64748b;font-size:16px}.upload-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 350px;margin:0 auto;max-width:900px}.upload-form{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-lg);padding:40px}.form-section{margin-bottom:35px}.form-section h3{color:var(--text-tertiary);font-size:16px;font-weight:700;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.department-selector{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.dept-option{align-items:center;background:var(--input-bg);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:16px;transition:var(--transition)}.dept-option input{display:none}.dept-option.active{background-color:#1e40af0d}.dept-option.active,.dept-option:hover{border-color:var(--color-pd)}.dept-icon{align-items:center;border-radius:10px;color:#fff;display:flex;flex-shrink:0;height:50px;justify-content:center;width:50px}.dept-icon.pd{background:linear-gradient(135deg,var(--color-pd),#1e40af)}.dept-icon.ems{background:linear-gradient(135deg,var(--color-ems),#b91c1c)}.dept-icon.staff{background:linear-gradient(135deg,#10b981,#059669)}.dept-info{display:flex;flex-direction:column;gap:4px}.dept-name{color:var(--text-primary);font-size:14px;font-weight:600}.dept-desc{color:var(--text-tertiary);font-size:12px}.form-group{margin-bottom:20px}.form-group label{color:var(--text-primary);display:block;margin-bottom:8px}.form-group input,.form-group textarea{background:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;padding:12px;transition:var(--transition);width:100%}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-pd);box-shadow:0 0 0 3px #1e40af1a;outline:none}.char-count{color:#94a3b8;display:block;font-size:12px;margin-top:6px;text-align:right}.file-upload-area{position:relative}.file-upload-label{align-items:center;background-color:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center;transition:var(--transition)}.file-upload-label:hover{background-color:#1e40af05;border-color:var(--color-pd)}.upload-icon{color:var(--color-pd);margin-bottom:16px}.upload-text{display:flex;flex-direction:column;gap:4px}.upload-main{color:var(--text-primary);font-size:15px;font-weight:600}.upload-sub{color:var(--text-tertiary);font-size:13px}.progress-section{background-color:var(--bg-tertiary);border-radius:8px;margin-bottom:20px;padding:20px}.progress-info{color:var(--text-primary);display:flex;font-size:14px;font-weight:600;justify-content:space-between;margin-bottom:12px}.progress-bar{background-color:#e2e8f0;border-radius:3px;height:6px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,var(--color-pd),#1e40af);height:100%;transition:width .3s ease}.progress-fill.processing{animation:processing-pulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,#1e40af,var(--color-pd),#1e40af);background-size:200% 100%}@keyframes processing-pulse{0%,to{background-position:0 50%;opacity:.8}50%{background-position:100% 50%;opacity:1}}.progress-note{color:var(--text-tertiary);font-size:13px;font-style:italic;margin-top:12px;text-align:center}.message{align-items:flex-start;border-left:4px solid;gap:12px;padding:16px}.message.success{border-color:var(--color-success)}.message.error{border-color:var(--color-error)}.message svg{flex-shrink:0;margin-top:2px}.success-id-box{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid var(--color-success);border-radius:10px;margin-bottom:20px;margin-top:-10px;padding:20px}.id-content{display:flex;flex-direction:column;gap:12px}.id-content label{color:#166534;font-size:14px;font-weight:700}.id-display{align-items:center;display:flex;gap:10px}.id-display code{background-color:#fff;border:1px solid #bbf7d0;color:#166534;flex:1 1;font-family:Monaco,Courier New,monospace;line-height:1.5;padding:10px 12px;word-break:break-all}.copy-button,.id-display code{border-radius:6px;font-size:13px}.copy-button{align-items:center;background-color:var(--color-success);color:#fff;display:flex;flex-shrink:0;font-weight:700;gap:6px;padding:10px 14px;transition:var(--transition);white-space:nowrap}.copy-button:hover{background-color:#15803d;box-shadow:0 2px 6px #16a34a4d;transform:translateY(-1px)}.copy-button:active{transform:translateY(0)}.id-info{color:#166534;font-size:12px;margin:0;opacity:.85}.id-content+.id-content{border-top:1px dashed #bbf7d0;margin-top:16px;padding-top:16px}.video-id{border-top:1px solid;font-size:13px;margin-top:10px;opacity:.8;padding-top:10px}.video-id code{background-color:#0000000d;display:block;margin-top:6px;padding:6px;word-break:break-all}.upload-button{background:linear-gradient(135deg,var(--color-pd),#1e40af);border-radius:8px;color:#fff;font-size:15px;font-weight:700;padding:14px;transition:var(--transition);width:100%}.upload-button:hover:not(:disabled){box-shadow:0 8px 16px #1e40af66;transform:translateY(-2px)}.upload-button:disabled{cursor:not-allowed;opacity:.6}.upload-info{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-lg);height:-webkit-fit-content;height:fit-content;padding:24px;position:-webkit-sticky;position:sticky;top:20px}.upload-info h3{color:var(--text-primary);font-size:15px;font-weight:700;margin-bottom:20px;text-align:center}.info-grid{display:flex;flex-direction:column;gap:20px}.info-item{padding:12px 0;position:relative;text-align:center}.info-item strong{align-items:center;color:var(--text-primary);display:inline-flex;font-size:14px;font-weight:700;gap:8px;justify-content:center;margin-bottom:6px}.info-item strong:after{color:var(--color-success);content:"✓";font-size:18px;font-weight:700}.info-item p{color:var(--text-secondary);font-size:13px;line-height:1.6;margin:0}@media (max-width:900px){.upload-content{grid-template-columns:1fr}.upload-info{position:static}}@media (max-width:640px){.upload-container{padding:20px 10px}.upload-header h1{font-size:28px}.upload-form{padding:24px}.department-selector{grid-template-columns:1fr}.file-upload-label{padding:30px 15px}}.video-player-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.video-player-container{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:1000px;overflow:hidden;width:100%}.video-player-header{align-items:flex-start;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px}.video-player-info{flex:1 1}.video-player-header h2{color:#1f2937;font-size:20px;margin:0 0 12px}.video-metadata{color:#6b7280;font-size:13px;line-height:1.6}.video-metadata p{margin:4px 0}.video-metadata strong{color:#374151}.close-button{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:32px;height:40px;justify-content:center;padding:0;transition:all .2s;width:40px}.close-button:hover{background-color:#e5e7eb;color:#1f2937}.close-button:active{transform:scale(.95)}.video-player-body{align-items:center;background-color:#000;display:flex;flex:1 1;justify-content:center;min-height:400px;overflow:hidden;padding:0;position:relative}.video-element{display:block;height:auto;max-height:100%;max-width:100%;object-fit:contain;width:100%}.video-element::-webkit-media-controls,.video-element::-webkit-media-controls-panel{display:flex!important}.video-element::-moz-media-controls{display:flex!important}.error,.loading{align-items:center;color:#e5e7eb;display:flex;font-size:16px;justify-content:center;padding:40px;text-align:center}.error{background-color:#7f1d1d;border:1px solid #dc2626;border-radius:6px;color:#fca5a5;margin:20px}@media (max-width:768px){.video-player-overlay{padding:10px}.video-player-container{border-radius:8px;max-height:100vh}.video-player-header{flex-direction:column;gap:12px;padding:16px}.video-player-info{width:100%}.video-player-header h2{font-size:18px}.close-button{align-self:flex-end}.video-player-body{min-height:300px}.video-metadata{font-size:12px}}@media (max-width:480px){.video-player-header{padding:12px}.video-player-header h2{font-size:16px;margin-bottom:8px}.video-metadata{font-size:11px;line-height:1.4}.video-player-body{min-height:250px}}.search-filter-section{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-md);margin-bottom:30px;padding:24px}.search-filter-form h2{color:var(--text-primary);font-size:16px;font-weight:700;margin-bottom:20px}[data-role=ems] .filter-group input:focus,[data-role=ems] .filter-group select:focus{border-color:var(--color-ems);box-shadow:0 0 0 3px #dc26261a}.reset-button,.search-button{cursor:pointer}.search-button{border:none}[data-role=ems] .search-button{background:linear-gradient(135deg,var(--color-ems),#b91c1c)}[data-role=ems] .search-button:hover{box-shadow:0 4px 12px #dc26264d}.reset-button{border:none}@media (max-width:768px){.filter-inputs{grid-template-columns:1fr}.filter-actions{flex-direction:column}.reset-button,.search-button{justify-content:center;width:100%}}.case-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:3000}.case-modal-content{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;margin:auto;max-height:90vh;max-width:900px;width:100%}.dark-mode .case-modal-content{box-shadow:0 20px 60px #000000b3}.case-modal-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px}.case-modal-header h2{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.case-modal-body{flex:1 1;overflow-y:auto;padding:24px}.case-section{background:var(--bg-tertiary);border-radius:10px;margin-bottom:20px;padding:20px}.case-section:last-child{margin-bottom:0}.case-section h3{color:var(--text-primary);font-size:18px;font-weight:700;margin:0 0 16px}.case-section h4{color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 12px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header h3{margin:0}.edit-case-btn{background:linear-gradient(135deg,var(--color-pd),#1e40af);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s}.edit-case-btn:hover{box-shadow:0 4px 12px #1e40af4d;transform:translateY(-2px)}.case-info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{display:flex;flex-direction:column;gap:6px}.info-item.full-width{grid-column:1/-1}.info-label{color:var(--text-tertiary);font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.info-value{color:var(--text-primary);font-size:14px;font-weight:500}.info-value p{line-height:1.6;margin:0}.add-note-form,.case-edit-form{background:var(--input-bg);border:2px solid #94a3b833;border-radius:8px;display:flex;flex-direction:column;gap:16px;margin-bottom:16px;padding:16px}.dark-mode .add-note-form,.dark-mode .case-edit-form{border-color:#94a3b84d}.form-row{gap:6px}.form-row input,.form-row select,.form-row textarea{padding:10px 12px}.form-row textarea{min-height:80px}.add-note-btn,.save-case-btn{align-self:flex-start;background:linear-gradient(135deg,var(--color-pd),#1e40af);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.add-note-btn:hover,.save-case-btn:hover{box-shadow:0 4px 12px #1e40af4d;transform:translateY(-2px)}.status-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:11px;font-weight:700;justify-content:center;padding:6px 12px}.add-video-section{background:var(--input-bg);border:2px solid #94a3b833;border-radius:8px;margin-bottom:16px;padding:16px}.dark-mode .add-video-section{background:#1e293b;border-color:#94a3b84d}.search-video-form{display:flex;gap:12px;margin-bottom:12px}.search-video-form input{background:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);flex:1 1;font-size:14px;padding:10px 12px;transition:var(--transition)}.dark-mode .search-video-form input{background:#1e293b;border-color:#475569}.search-video-form input:focus{border-color:var(--color-pd);box-shadow:0 0 0 3px #1e40af1a;outline:none}.search-video-form button{background:linear-gradient(135deg,var(--color-pd),#1e40af);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.search-video-form button:hover:not(:disabled){box-shadow:0 4px 12px #1e40af4d;transform:translateY(-2px)}.search-video-form button:disabled{cursor:not-allowed;opacity:.6}.search-results{display:flex;flex-direction:column;gap:12px}.search-result-item{align-items:center;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;display:flex;justify-content:space-between;padding:12px}.dark-mode .search-result-item{border-color:#475569}.search-result-item .video-info{flex:1 1}.search-result-item .video-info strong{color:var(--text-primary);display:block;margin-bottom:4px}.search-result-item .video-info p{color:var(--text-secondary);font-size:13px;margin:2px 0}.add-video-btn{background:var(--color-success);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.add-video-btn:hover{background:#059669}.videos-list{display:flex;flex-direction:column;gap:12px}.video-item{align-items:flex-start;background:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;display:flex;justify-content:space-between;padding:16px;transition:all .2s}.dark-mode .video-item{background:#1e293b;border-color:#475569}.video-item:hover{border-color:var(--color-pd);box-shadow:var(--shadow-sm)}.video-item .video-info{flex:1 1}.video-item .video-info:hover{opacity:.8}.video-item .video-info h4{color:var(--text-primary);font-size:15px;margin:0 0 8px;transition:color .2s}.video-item .video-info:hover h4{color:var(--color-pd)}.video-item .video-info p{color:var(--text-secondary);font-size:13px;margin:4px 0}.remove-video-btn{background:var(--color-error);border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.remove-video-btn:hover{background:#b91c1c}.notes-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.note-item{background:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;padding:16px}.dark-mode .note-item{background:#1e293b;border-color:#475569}.note-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.note-type-badge{border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.note-type-badge.general{background:#6b7280;color:#fff}.note-type-badge.evidence{background:#3b82f6;color:#fff}.note-type-badge.interview{background:#8b5cf6;color:#fff}.note-type-badge.follow-up{background:#f59e0b;color:#fff}.note-type-badge.administrative{background:#10b981;color:#fff}.note-meta{color:var(--text-secondary);font-size:13px;font-weight:500}.delete-note-btn{background:#0000;border:1px solid var(--color-error);border-radius:4px;color:var(--color-error);cursor:pointer;font-size:12px;font-weight:600;margin-left:auto;padding:6px 12px;transition:all .2s}.delete-note-btn:hover{background:var(--color-error);color:#fff}.note-content{color:var(--text-primary);font-size:14px;line-height:1.6;margin:0}.no-content{font-size:14px;font-style:italic;padding:20px}.error-state,.loading-state,.no-content{color:var(--text-secondary);text-align:center}.error-state,.loading-state{font-size:15px;padding:40px}.error-state{color:var(--color-error)}@media (max-width:768px){.case-modal-content{border-radius:0;max-height:100vh;max-width:100%}.case-modal-body{padding:16px}.case-info-grid{grid-template-columns:1fr}.search-video-form{flex-direction:column}.search-result-item,.video-item{flex-direction:column;gap:12px}.add-video-btn,.remove-video-btn{width:100%}.note-header{align-items:flex-start;flex-direction:column}.delete-note-btn{align-self:flex-start;margin-left:0}}.create-case-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:3000}.create-case-modal-content{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;margin:auto;max-height:90vh;max-width:600px;width:100%}.dark-mode .create-case-modal-content{box-shadow:0 20px 60px #000000b3}.create-case-modal-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px}.create-case-modal-header h2{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.close-modal-btn{align-items:center;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.close-modal-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.create-case-modal-body{flex:1 1;overflow-y:auto;padding:24px}.form-row{display:flex;flex-direction:column;gap:8px}.form-row label{color:var(--text-tertiary);font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.form-row input,.form-row select,.form-row textarea{background:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;padding:12px 14px;transition:var(--transition)}.dark-mode .form-row input,.dark-mode .form-row select,.dark-mode .form-row textarea{background:#1e293b;border-color:#475569}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--color-pd);box-shadow:0 0 0 3px #1e40af1a;outline:none}.form-row textarea{min-height:100px;resize:vertical}.error-message{background-color:#fef2f2;border-left:4px solid var(--color-error);font-weight:500;padding:12px 16px}.dark-mode .error-message{background-color:#dc26261a;color:#fca5a5}.form-actions{margin-top:8px}.cancel-btn,.submit-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.cancel-btn:hover:not(:disabled){background-color:var(--border-color)}.submit-btn{background:linear-gradient(135deg,var(--color-pd),#1e40af);color:#fff}.submit-btn:hover:not(:disabled){box-shadow:0 4px 12px #1e40af4d;transform:translateY(-2px)}.cancel-btn:disabled,.submit-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.create-case-modal-content{border-radius:0;max-height:100vh;max-width:100%}.create-case-modal-body{padding:16px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.dashboard{background-color:var(--color-bg-light);min-height:100vh}.dark-mode .dashboard{background-color:#0a0f1a}.dashboard-header{background:linear-gradient(135deg,var(--color-bg-dark) 0,#1e3a8a 100%);box-shadow:var(--shadow-md);color:#fff;padding:20px 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.dashboard[data-role=ems] .dashboard-header{background:linear-gradient(135deg,#7f1d1d,#991b1b)}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 20px}.header-left h1{font-size:28px;font-weight:700;margin-bottom:4px}.user-info{font-size:13px;opacity:.9}.user-info strong{font-weight:600}.header-right{gap:12px}.header-right,.nav-link{align-items:center;display:flex}.nav-link{background-color:#ffffff1a;border-radius:8px;color:#fff;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;text-decoration:none;transition:var(--transition)}.nav-link:hover{background-color:#fff3}.theme-toggle{align-items:center;background-color:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:8px 10px;transition:all .2s}.theme-toggle:hover{background-color:#fff3}.theme-toggle:active{transform:scale(.95)}.logout-button{align-items:center;background-color:#ffffff1a;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:var(--transition)}.logout-button:hover{background-color:#dc262699}.dashboard-main{margin:0 auto;max-width:1400px;padding:40px 20px}.filters-section{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-md);margin-bottom:30px;padding:24px}.filter-form h2{color:var(--text-primary);font-size:16px;font-weight:700;margin-bottom:20px}.filter-inputs{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.filter-group{display:flex;flex-direction:column}.filter-group label{color:var(--text-tertiary);font-size:13px;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.filter-group input,.filter-group select{background:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;padding:10px 12px;transition:var(--transition)}.filter-group input:focus,.filter-group select:focus{border-color:var(--color-pd);box-shadow:0 0 0 3px #1e40af1a;outline:none}.dashboard[data-role=ems] .filter-group input:focus,.dashboard[data-role=ems] .filter-group select:focus{border-color:var(--color-ems);box-shadow:0 0 0 3px #dc26261a}.filter-actions{display:flex;gap:12px;justify-content:flex-end}.reset-button,.search-button{align-items:center;border-radius:8px;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:var(--transition)}.search-button{background:linear-gradient(135deg,var(--color-pd),#1e40af);color:#fff}.search-button:hover{box-shadow:0 4px 12px #1e40af4d;transform:translateY(-2px)}.dashboard[data-role=ems] .search-button{background:linear-gradient(135deg,var(--color-ems),#b91c1c)}.dashboard[data-role=ems] .search-button:hover{box-shadow:0 4px 12px #dc26264d}.reset-button{background-color:var(--bg-tertiary);color:var(--text-primary)}.reset-button:hover{background-color:var(--border-color)}.message{align-items:center;border-radius:8px;display:flex;font-size:14px;font-weight:600;gap:10px;margin-bottom:20px;padding:14px 16px}.message.success{background-color:#f0fdf4;border-left:4px solid var(--color-success);color:#166534}.message.error{background-color:#fef2f2;border-left:4px solid var(--color-error);color:#991b1b}.videos-section{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-md);padding:30px}.videos-section h2{color:var(--text-primary);font-size:18px;font-weight:700;margin-bottom:24px}.loading-state{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.spinner{animation:spin .8s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top:4px solid var(--color-pd);height:40px;margin-bottom:16px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.loading-state p{font-size:14px;font-weight:500}.empty-state{align-items:center;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-state svg{color:#cbd5e1;margin-bottom:20px}.empty-state h3{color:var(--text-primary);font-size:18px;font-weight:700;margin-bottom:8px}.empty-state p{font-size:14px}.content-section{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-md);padding:30px}.content-section h2{color:var(--text-primary);font-size:18px;font-weight:700;margin-bottom:24px}.section-header{margin-bottom:24px}.section-header h2{color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.content-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.content-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:10px;display:flex;flex-direction:column;overflow:visible;position:relative;transition:var(--transition)}.content-card:hover{border-color:var(--color-pd);box-shadow:var(--shadow-lg);transform:translateY(-4px)}[data-role=ems] .content-card:hover{border-color:var(--color-ems)}.card-thumbnail{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:8px;height:180px;justify-content:center;position:relative;transition:var(--transition)}.case-thumbnail,.video-thumbnail{border-radius:10px 10px 0 0}.case-thumbnail{background:linear-gradient(135deg,#7c3aed,#5b21b6)}.case-thumbnail:before,.video-thumbnail:before{background:#0000;content:"";inset:0;position:absolute;transition:var(--transition)}.case-thumbnail:hover:before,.video-thumbnail:hover:before{background:#0003}.case-thumbnail svg,.video-thumbnail svg{color:#fff;opacity:.9;position:relative;transition:var(--transition);z-index:1}.case-thumbnail:hover svg,.video-thumbnail:hover svg{opacity:1;transform:scale(1.1)}.card-header{align-items:center;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:14px 16px}.card-body{flex:1 1;padding:16px}.card-title{color:var(--text-primary);font-size:15px;font-weight:700;line-height:1.4;margin:0 0 8px}.card-description{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.card-footer{background-color:var(--bg-tertiary);border-top:1px solid var(--border-color);padding:14px 16px}.card-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px}.card-info{align-items:center;display:flex;font-size:12px;justify-content:space-between}.info-secondary{color:var(--text-secondary);font-weight:600}.info-date{color:var(--text-muted)}.videos-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.video-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:10px;overflow:visible}.video-card,.video-thumbnail{display:flex;flex-direction:column;position:relative;transition:var(--transition)}.video-thumbnail{align-items:center;background:linear-gradient(135deg,#1e40af,#1e3a8a);cursor:pointer;gap:8px;height:180px;justify-content:center;overflow:hidden}.video-thumbnail:before{background:#0000;content:"";inset:0;position:absolute;transition:var(--transition)}.video-thumbnail:hover:before{background:#0003}.video-thumbnail svg{color:#fff;opacity:.9;position:relative;transition:var(--transition);z-index:1}.video-thumbnail:hover svg{opacity:1;transform:scale(1.1)}.play-label{color:#fff;font-size:12px;font-weight:600;opacity:.8;position:relative;transition:var(--transition);z-index:1}.video-thumbnail:hover .play-label{opacity:1}.video-card:hover{border-color:var(--color-pd);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.video-header{align-items:center;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:14px 16px}.dept-badge{align-items:center;border-radius:6px;color:#fff;display:inline-flex;font-size:11px;font-weight:700;justify-content:center;padding:6px 12px}.dept-badge.pd{background:linear-gradient(135deg,var(--color-pd),#1e40af)}.dept-badge.ems{background:linear-gradient(135deg,var(--color-ems),#b91c1c)}.dept-badge.staff{background:linear-gradient(135deg,#10b981,#059669)}.dept-badge.superadmin{background:linear-gradient(135deg,var(--color-superadmin),#6d28d9)}.video-date{color:#64748b;font-size:13px;font-weight:600}.video-body{flex:1 1;padding:16px}.uploader-name{color:var(--text-primary);font-size:15px;font-weight:700;line-height:1.4;margin-bottom:8px}.video-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box;font-size:13px;line-height:1.5;overflow:hidden}.video-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;padding:12px 16px}.video-actions{align-items:center;display:flex;gap:8px;justify-content:space-between;width:100%}.delete-button,.play-button{align-items:center;border-radius:6px;display:flex;font-size:12px;font-weight:700;gap:6px;padding:6px 12px;transition:var(--transition);white-space:nowrap}.play-button{background-color:#dbeafe;color:var(--color-pd);min-width:44px}.play-button:hover:not(:disabled){background-color:#bfdbfe;transform:translateY(-1px)}.play-button:disabled{cursor:wait;opacity:.7}.play-button span{font-size:11px;font-weight:700}.dashboard[data-role=ems] .play-button{background-color:#fee2e2;color:var(--color-ems)}.dashboard[data-role=ems] .play-button:hover{background-color:#fecaca}.play-button:active{transform:translateY(0)}.delete-button{background-color:#fee2e2;color:var(--color-error)}.delete-button:hover{background-color:#fecaca}.video-id{align-items:center;display:flex;font-size:12px;gap:8px;width:100%}.video-id .label{color:#64748b;flex-shrink:0;font-weight:700}.video-id code{background-color:var(--bg-tertiary);border-radius:4px;color:var(--text-primary);flex:1 1;font-family:Monaco,Courier New,monospace;overflow:hidden;padding:2px 6px;text-overflow:ellipsis;white-space:nowrap}.tab-navigation{border-bottom:2px solid var(--color-border);display:flex;gap:8px;margin-bottom:24px}.tab-button{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;margin-bottom:-2px;padding:12px 20px;transition:all .2s}.tab-button:hover{background-color:#3b82f60d;color:var(--text-primary)}.tab-button.active{border-bottom-color:var(--color-primary);color:var(--color-primary)}.case-number{font-size:12px;letter-spacing:.5px;text-transform:uppercase}.meta-item svg{flex-shrink:0}.meta-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cases-section{background-color:var(--color-bg-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.cases-header{margin-bottom:20px}.cases-header h2{color:var(--text-primary);font-size:20px;font-weight:700}.cases-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.case-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.status-badge{border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.case-number{color:var(--color-primary);font-size:14px;font-weight:700;margin-bottom:8px}.case-title{color:var(--text-primary);font-size:18px;font-weight:600;line-height:1.4;margin-bottom:12px}.case-description{color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:16px}.case-meta{border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding-top:12px}.meta-item{color:var(--text-secondary);font-size:13px;gap:6px}.case-footer,.meta-item{align-items:center;display:flex}.case-footer{border-top:1px solid var(--color-border);color:var(--text-muted);font-size:12px;justify-content:space-between;padding-top:12px}.created-by{font-weight:600}.create-case-button{background-color:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:15px;font-weight:600;margin-top:20px;padding:12px 24px;transition:background-color .2s}.create-case-button:hover{background-color:#2563eb}.video-menu-container{position:relative;z-index:100}.menu-button{align-items:center;background-color:#0000000d;border:1px solid var(--color-border);border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s}.menu-button:hover{background-color:#0000001a}.dark-mode .menu-button{background-color:#ffffff1a;color:#fff}.dark-mode .menu-button:hover{background-color:#fff3}.video-dropdown-menu{background:var(--card-bg);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:4px;min-width:180px;overflow:hidden;position:absolute;right:0;top:100%;z-index:200}.dark-mode .video-dropdown-menu{background:#1e293b;box-shadow:0 4px 12px #0006}.video-dropdown-menu button{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;gap:10px;padding:12px 16px;text-align:left;transition:background-color .2s;width:100%}.video-dropdown-menu button:hover{background-color:#3b82f61a}.dark-mode .video-dropdown-menu button:hover{background-color:#3b82f633}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.modal-content{background:var(--card-bg);border-radius:12px;box-shadow:0 10px 40px #0003;max-width:500px;width:100%}.dark-mode .modal-content{box-shadow:0 10px 40px #0009}.modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:var(--text-primary);font-size:20px;margin:0}.close-modal{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;transition:color .2s}.close-modal:hover{color:var(--text-primary)}.modal-body{padding:24px}.video-info-text{background-color:var(--bg-tertiary);border-radius:6px;color:var(--text-secondary);font-size:14px;margin-bottom:20px;padding:12px}.case-select{background-color:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;padding:12px;transition:var(--transition);width:100%}.case-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.modal-footer{border-top:1px solid var(--color-border);display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.assign-btn,.cancel-btn{border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.cancel-btn{background-color:var(--bg-tertiary);border:none;color:var(--text-primary)}.cancel-btn:hover{background-color:var(--border-color)}.assign-btn{background-color:var(--color-primary);border:none;color:#fff}.assign-btn:hover:not(:disabled){background-color:#2563eb}.assign-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1024px){.header-content{flex-direction:column;gap:16px;text-align:center}.header-right{justify-content:center;width:100%}.filter-inputs{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.dashboard-main{padding:20px 12px}.header-left h1{font-size:22px}.filters-section{padding:16px}.filter-inputs{grid-template-columns:1fr}.filter-actions{flex-direction:column}.reset-button,.search-button{justify-content:center;width:100%}.videos-grid{grid-template-columns:1fr}.video-footer{align-items:flex-start;flex-direction:column;gap:10px}.delete-button{justify-content:center;width:100%}.header-right{flex-direction:column;gap:12px;width:100%}.logout-button,.nav-link{justify-content:center;width:100%}}.create-case-container{margin:0 auto;max-width:800px;padding:20px}.create-case-header{align-items:center;display:flex;gap:20px;margin-bottom:30px}.back-button{background-color:#6b7280;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .3s}.back-button:hover{background-color:#4b5563}.create-case-header h1{color:#1f2937;font-size:28px;margin:0}.create-case-content{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:32px}.create-case-form{gap:20px}.create-case-form,.form-group{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#374151;font-size:14px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:15px;padding:12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group textarea{resize:vertical}.error-message{background-color:#fee2e2;border-radius:6px;color:#991b1b;font-size:14px;padding:12px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:10px}.cancel-button{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.cancel-button:hover:not(:disabled){background-color:#e5e7eb}.submit-button{background-color:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#2563eb}.cancel-button:disabled,.submit-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.create-case-container{padding:10px}.create-case-content{padding:20px}.create-case-header{align-items:flex-start;flex-direction:column}.form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}*{box-sizing:border-box;margin:0;padding:0}:root{--color-pd:#1e40af;--color-ems:#dc2626;--color-superadmin:#7c3aed;--color-bg-dark:#0f172a;--color-bg-light:#f8fafc;--color-text-dark:#1e293b;--color-text-light:#e2e8f0;--color-border:#e2e8f0;--color-success:#16a34a;--color-warning:#ea580c;--color-error:#dc2626;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #00000026;--transition:all 0.3s ease;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--text-primary:#1e293b;--text-secondary:#475569;--text-tertiary:#64748b;--border-color:#e2e8f0;--input-bg:#fff;--card-bg:#fff}.dark-mode{--bg-primary:#1e293b;--bg-secondary:#0f172a;--bg-tertiary:#334155;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-tertiary:#94a3b8;--border-color:#334155;--input-bg:#334155;--card-bg:#1e293b;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 15px #0006}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;background-color:var(--color-bg-light);color:#1e293b;color:var(--color-text-dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}html{scroll-behavior:smooth}button{border:none;cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f8fafc;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.dark-mode ::-webkit-scrollbar-thumb{background:#475569}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dark-mode ::-webkit-scrollbar-thumb:hover{background:#64748b}
/*# sourceMappingURL=main.dcd06990.css.map*/