:root{--primary-dark:#1a2035;--secondary-dark:#272e48;--accent-blue:#1e88e5;--accent-red:#e53935;--accent-orange:#ff8f00;--accent-green:#28a745;--text-primary:#f0f2f5;--text-light:#f0f2f5;--text-secondary:#b8c2cc;--text-tertiary:#7a8499;--text-muted:#4e566a;--border-color:#464d63;--hover-bg:#303950;--spacing-xs:5px;--spacing-sm:10px;--spacing-md:15px;--spacing-lg:20px;--spacing-xl:30px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-pill:20px;--shadow-sm:0 1px 3px #0003;--shadow-md:0 2px 10px #0003;--shadow-lg:0 4px 20px #0000004d;--transition-fast:0.2s ease;--transition-normal:0.3s ease;--transition-slow:0.4s ease;--sidebar-width:250px;--sidebar-collapsed-width:60px;--topnav-height:60px;--table-row-height:62px;--z-sidebar:1000;--z-topnav:900;--z-modal:2000;--z-notification:3000}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--primary-dark);color:var(--text-light);font-family:Roboto,Segoe UI,Arial,sans-serif;line-height:1.6}img{display:block;height:auto;max-width:100%}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--primary-dark)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}::selection{background-color:var(--accent-blue);color:#fff}:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}a{color:var(--accent-blue);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--text-light)}code{background-color:#0003;border-radius:var(--radius-sm);font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.9em;padding:2px 6px}h1,h2,h3,h4,h5,h6{font-weight:500;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.1rem}h6{font-size:1rem}.m-0{margin:0}.m-1{margin:var(--spacing-xs)}.m-2{margin:var(--spacing-sm)}.m-3{margin:var(--spacing-md)}.m-4{margin:var(--spacing-lg)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.ml-0{margin-left:0}.ml-1{margin-left:var(--spacing-xs)}.ml-2{margin-left:var(--spacing-sm)}.ml-3{margin-left:var(--spacing-md)}.ml-4{margin-left:var(--spacing-lg)}.mr-0{margin-right:0}.mr-1{margin-right:var(--spacing-xs)}.mr-2{margin-right:var(--spacing-sm)}.mr-3{margin-right:var(--spacing-md)}.mr-4{margin-right:var(--spacing-lg)}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--accent-blue)}.text-success{color:var(--accent-green)}.text-danger{color:var(--accent-red)}.text-warning{color:var(--accent-orange)}.text-muted{color:var(--text-secondary)}.text-light{color:var(--text-light)}.font-weight-normal{font-weight:400}.font-weight-medium{font-weight:500}.font-weight-bold{font-weight:700}.text-uppercase{text-transform:uppercase}.text-lowercase{text-transform:lowercase}.text-capitalize{text-transform:capitalize}.d-none{display:none}.d-block{display:block}.d-inline{display:inline}.d-inline-block{display:inline-block}.d-flex{display:flex}.d-grid{display:grid}.flex-column{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.justify-content-start{justify-content:flex-start}.justify-content-center{justify-content:center}.justify-content-end{justify-content:flex-end}.justify-content-between{justify-content:space-between}.justify-content-around{justify-content:space-around}.align-items-start{align-items:flex-start}.align-items-center{align-items:center}.align-items-end{align-items:flex-end}.align-items-stretch{align-items:stretch}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-in-out}.fade-in-up{animation:fadeInUp .4s ease-out}.slide-in{animation:slideIn .3s ease-out}.hover-bg:hover{background-color:var(--hover-bg);transition:background-color var(--transition-fast)}.hover-opacity:hover{opacity:.8;transition:opacity var(--transition-fast)}.hover-scale:hover{transform:scale(1.05);transition:transform var(--transition-fast)}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.position-relative{position:relative}.position-absolute{position:absolute}.position-fixed{position:fixed}.position-sticky{position:-webkit-sticky;position:sticky}.w-100{width:100%}.h-100{height:100%}.min-h-100{min-height:100vh}.border{border:1px solid var(--border-color)}.border-top{border-top:1px solid var(--border-color)}.border-bottom{border-bottom:1px solid var(--border-color)}.border-left{border-left:1px solid var(--border-color)}.border-right{border-right:1px solid var(--border-color)}.rounded{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-pill{border-radius:var(--radius-pill)}.rounded-circle{border-radius:50%}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}@media (max-width:768px){.d-md-none{display:none}.d-md-block{display:block}}@media (max-width:576px){.d-sm-none{display:none}.d-sm-block{display:block}}.main-container{display:flex;min-height:100vh}.main-container,.sidebar{background-color:var(--primary-dark)}.sidebar{border-right:1px solid var(--border-color);height:100vh;overflow-x:hidden;overflow-y:auto;position:fixed;transition:width var(--transition-normal);width:var(--sidebar-width);z-index:var(--z-sidebar)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;min-height:var(--topnav-height);padding:var(--spacing-md)}.sidebar-header-icon{align-items:center;color:var(--accent-red);display:flex;font-size:24px;justify-content:center;min-width:30px}.sidebar-header-title{font-size:1.2rem;font-weight:700;margin-left:var(--spacing-sm);overflow:hidden;transition:opacity var(--transition-normal);white-space:nowrap}.sidebar.collapsed .sidebar-header-title{opacity:0;width:0}.nav-menu{list-style:none;margin-top:var(--spacing-lg);padding:0}.nav-item{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;padding:12px var(--spacing-md);position:relative;text-decoration:none;transition:all var(--transition-normal)}.nav-item .nav-indicator{background-color:initial;bottom:0;left:0;position:absolute;top:0;transition:background-color var(--transition-normal);width:3px}.nav-item:hover{background-color:var(--hover-bg);color:var(--text-light)}.nav-item:hover .nav-indicator{background-color:var(--accent-blue)}.nav-item.active{background-color:#1e88e51a;color:var(--text-light)}.nav-item.active .nav-indicator{background-color:var(--accent-blue)}.nav-item-icon{font-size:18px;margin-right:var(--spacing-sm);min-width:20px;text-align:center;width:20px}.nav-item-text{opacity:1;transition:opacity var(--transition-normal);white-space:nowrap}.sidebar.collapsed .nav-item-text{opacity:0;width:0}.main-content{background-color:var(--primary-dark);flex:1 1;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-normal)}.main-content.expanded{margin-left:var(--sidebar-collapsed-width)}.top-nav{align-items:center;background-color:var(--secondary-dark);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg);min-height:var(--topnav-height);padding:var(--spacing-sm) var(--spacing-lg)}.top-nav-left,.top-nav-right{align-items:center;display:flex;gap:var(--spacing-md)}.toggle-sidebar-btn{align-items:center;background:none;border:none;color:var(--text-light);cursor:pointer;display:flex;font-size:24px;justify-content:center;padding:var(--spacing-xs);transition:color var(--transition-fast)}.toggle-sidebar-btn:hover{color:var(--accent-blue)}.content-wrapper{padding:var(--spacing-lg)}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.mobile-open{transform:translateX(0)}.main-content,.main-content.expanded{margin-left:0}}.sidebar-overlay{background-color:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:calc(var(--z-sidebar) - 1)}@media (max-width:768px){.sidebar-overlay.active{display:block}}.card{background-color:var(--secondary-dark);border-radius:var(--radius-md);box-shadow:var(--shadow-md);contain:layout style;min-height:100px;padding:var(--spacing-lg)}.card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.card-title{color:var(--text-light);font-size:16px;font-weight:500}.card-content{contain:layout style;min-height:100px}.btn{align-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;justify-content:center;padding:8px 15px;transition:all var(--transition-fast)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-icon{font-size:16px;margin-right:6px}.btn-primary{background-color:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){background-color:#1976d2}.btn-secondary{background-color:var(--border-color);color:var(--text-light)}.btn-secondary:hover:not(:disabled){background-color:var(--hover-bg)}.btn-success{background-color:var(--accent-green);color:#fff}.btn-success:hover:not(:disabled){background-color:#218838}.btn-danger{background-color:var(--accent-red);color:#fff}.btn-danger:hover:not(:disabled){background-color:#c62828}.btn-warning{background-color:var(--accent-orange);color:#fff}.btn-warning:hover:not(:disabled){background-color:#e68900}.btn-outline{background-color:initial;border:1px solid var(--border-color);color:var(--text-light)}.btn-outline:hover:not(:disabled){background-color:var(--hover-bg);border-color:var(--accent-blue)}.btn-sm{font-size:12px;padding:6px 12px}.btn-lg{font-size:16px;padding:12px 24px}.status-badge{border-radius:var(--radius-pill);display:inline-block;font-size:12px;font-weight:500;min-width:80px;padding:3px 8px;text-align:center;text-transform:uppercase}.status-active{background-color:var(--accent-green);color:#fff}.status-inactive{background-color:var(--text-secondary);color:#fff}.status-error{background-color:var(--accent-red);color:#fff}.status-pending,.status-warning{background-color:var(--accent-orange);color:#fff}.status-critical{animation:pulse 1.5s infinite;background-color:var(--accent-red);color:#fff}.status-starting{background-color:var(--accent-blue);color:#fff}.status-stopping{background-color:var(--text-secondary);color:#fff}.status-resolved{background-color:var(--accent-green);color:#fff}.status-investigating{background-color:var(--accent-blue);color:#fff}.status-dispatched,.status-en_route{background-color:var(--accent-orange);color:#fff}.status-on_scene{background-color:var(--accent-blue);color:#fff}.status-cleared{background-color:var(--accent-green);color:#fff}.type-badge{border-radius:var(--radius-sm);display:inline-block;font-size:12px;font-weight:500;padding:3px 8px}.type-fire{background-color:#e5393533;border:1px solid var(--accent-red);color:var(--accent-red)}.type-water{background-color:#1e88e533;border:1px solid var(--accent-blue);color:var(--accent-blue)}.type-emergency{background-color:#e5393533;border:1px solid var(--accent-red);color:var(--accent-red)}.table-wrapper{border-radius:var(--radius-md);overflow-x:auto}.data-table,.table-wrapper{background-color:var(--secondary-dark)}.data-table{border-collapse:collapse;width:100%}.data-table td,.data-table th{border-bottom:1px solid var(--border-color);padding:12px 15px;text-align:left}.data-table th{background-color:#0003;color:var(--text-secondary);font-size:14px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.data-table tbody tr{contain:layout style paint;height:var(--table-row-height);transition:background-color var(--transition-fast)}.data-table tbody tr:hover{background-color:var(--hover-bg)}.data-table tbody td{color:var(--text-light);vertical-align:middle}.alert{align-items:center;border-radius:var(--radius-sm);display:flex;margin-bottom:var(--spacing-md);padding:12px 15px}.alert-icon{font-size:20px;margin-right:var(--spacing-sm)}.alert-emergency{background-color:var(--accent-red);color:#fff}.alert-warning{background-color:var(--accent-orange);color:#fff}.alert-info{background-color:var(--accent-blue);color:#fff}.alert-success{background-color:var(--accent-green);color:#fff}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-blue);display:inline-block;height:40px;width:40px}.loading-spinner-sm{border-width:2px;height:20px;width:20px}.loading-spinner-lg{border-width:4px;height:60px;width:60px}.dashboard-grid{grid-gap:var(--spacing-lg);gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:var(--spacing-lg)}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr}}.compact-stats-bar{align-items:center;background-color:var(--secondary-dark);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg);padding:12px 20px}.stats-group{flex-wrap:wrap;gap:var(--spacing-md)}.stat-item,.stats-group{align-items:center;display:flex}.stat-item{font-size:14px;gap:6px}.stat-label{color:var(--text-secondary);font-weight:400}.stat-value{color:var(--text-light);font-weight:600}.stat-sublabel{color:var(--text-secondary);font-size:12px;margin-left:4px}.stat-divider{background-color:var(--border-color);height:24px;width:1px}.stat-item--alert{background-color:#e539351f;border-radius:var(--radius-sm);box-shadow:0 0 8px #e5393540;margin:-3px -4px;padding:3px 8px}.stat-value--alert{font-size:15px;font-weight:700}@media (max-width:768px){.compact-stats-bar{flex-direction:column;gap:var(--spacing-sm)}.stats-group{justify-content:space-between;width:100%}.stat-divider{display:none}}.activity-feed{background-color:var(--secondary-dark);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:100%;overflow:hidden}.activity-feed-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.activity-feed-header h3{color:var(--text-light);font-size:16px;font-weight:600;margin:0}.activity-count{background-color:var(--primary-dark);border-radius:12px;color:var(--text-secondary);font-size:13px;padding:4px 10px}.activity-feed-content{flex:1 1;overflow-y:auto;padding:12px}.activity-item{background-color:var(--primary-dark);border:1px solid #0000;border-radius:var(--radius-sm);cursor:pointer;margin-bottom:10px;padding:12px;transition:all var(--transition-fast)}.activity-item:hover{background-color:var(--hover-bg);border-color:var(--accent-blue);transform:translateX(2px)}.activity-item.emergency{background-color:#e539351a;border-left:3px solid var(--accent-red)}.activity-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.activity-title{align-items:center;display:flex;gap:8px}.stream-name{color:var(--text-light);font-size:14px;font-weight:500}.activity-time{color:var(--text-secondary);font-size:12px}.activity-content{margin-bottom:8px}.transcription-text{color:var(--text-secondary);font-size:13px;font-style:italic;line-height:1.4;margin:0}.emergency-badge{background-color:var(--accent-red);border-radius:4px;color:#fff;font-size:10px;font-style:normal;font-weight:700;margin-right:6px;padding:2px 6px}.no-activity{color:var(--text-secondary);font-size:13px;margin:0;opacity:.7}.activity-stats{display:flex;gap:8px}.stat-chip{background-color:var(--secondary-dark);border-radius:10px;color:var(--text-secondary);font-size:11px;padding:3px 8px}.activity-feed-footer{border-top:1px solid var(--border-color);padding:12px 20px;text-align:center}.empty-state p{margin-bottom:16px}.activity-item.skeleton{pointer-events:none}.skeleton-line{animation:skeleton-loading 1.5s infinite;background:linear-gradient(90deg,var(--primary-dark) 25%,var(--hover-bg) 50%,var(--primary-dark) 75%);background-size:200% 100%;border-radius:4px;height:12px;margin-bottom:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.transmission-row{background-color:var(--primary-dark);border-left:3px solid #0000;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:6px;padding:10px 12px;transition:background-color var(--transition-fast)}.transmission-row:hover{background-color:var(--hover-bg)}.transmission-row.emergency{background-color:#e5393514;border-left-color:var(--accent-red)}.transmission-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.transmission-time{font-feature-settings:"tnum";color:var(--text-tertiary);font-size:11px;font-variant-numeric:tabular-nums;letter-spacing:.02em}.transmission-channel{color:var(--accent-blue);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.transmission-text{color:var(--text-secondary);font-size:13px;line-height:1.45;margin:0}.pulse-dot{animation:pulse-breathe 1.5s ease-in-out infinite alternate;background-color:var(--accent-green);border-radius:50%;display:inline-block;flex-shrink:0;height:7px;width:7px}.pulse-dot--emergency{animation:pulse-alert .6s ease-in-out infinite alternate;background-color:var(--accent-red)}@keyframes pulse-breathe{0%{opacity:.4}to{opacity:1}}@keyframes pulse-alert{0%{opacity:.5;transform:scale(.9)}to{opacity:1;transform:scale(1.2)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.activity-feed-content::-webkit-scrollbar{width:6px}.activity-feed-content::-webkit-scrollbar-track{background:var(--primary-dark)}.activity-feed-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.activity-feed-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.incidents-panel{background-color:var(--secondary-dark);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:100%;overflow:hidden}.incidents-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.incidents-header h3{color:var(--text-light);font-size:16px;font-weight:600;margin:0}.incident-count{background-color:var(--primary-dark);border-radius:12px;color:var(--text-secondary);font-size:13px;padding:4px 10px}.incidents-content{flex:1 1;overflow-y:auto;padding:12px}.incident-card{background-color:var(--primary-dark);border-left:3px solid #0000;border-radius:var(--radius-sm);cursor:pointer;margin-bottom:10px;padding:14px;transition:all var(--transition-fast)}.incident-card:hover{background-color:var(--hover-bg);transform:translateX(2px)}.incident-card.priority-critical{background-color:#e5393526;border-left-color:var(--accent-red)}.incident-card.priority-high{background-color:#ff8f001a;border-left-color:var(--accent-orange)}.incident-card.priority-normal{border-left-color:var(--accent-blue)}.incident-card.priority-low{border-left-color:var(--text-secondary)}.incident-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.incident-title{align-items:center;display:flex;flex:1 1;gap:8px}.priority-icon{font-size:18px;line-height:1}.incident-type{color:var(--text-light);font-size:14px;font-weight:600;line-height:1.3}.incident-time{color:var(--text-secondary);font-size:12px;margin-left:8px;white-space:nowrap}.incident-location{align-items:center;display:flex;gap:4px}.incident-description,.incident-location{color:var(--text-secondary);font-size:13px}.incident-description{line-height:1.4;margin-bottom:10px}.incident-footer{align-items:center;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;margin-top:10px;padding-top:10px}.incident-units{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.units-label{color:var(--text-secondary)}.unit-badge,.units-label{font-size:11px;font-weight:500}.unit-badge{background-color:var(--accent-blue);border-radius:10px;color:#fff;padding:3px 8px}.no-units{color:var(--text-secondary);font-size:11px;font-style:italic}.incident-keywords{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.keyword-tag{background-color:var(--accent-red);border-radius:10px;color:#fff;font-size:10px;font-weight:600;padding:3px 8px;text-transform:uppercase}.incidents-footer{border-top:1px solid var(--border-color);padding:12px 20px;text-align:center}.empty-state{padding:40px 20px}.empty-state p{color:var(--text-secondary);margin:0 0 8px}.empty-subtitle{font-size:13px;opacity:.7}.incident-card.skeleton{pointer-events:none}.incidents-content::-webkit-scrollbar{width:6px}.incidents-content::-webkit-scrollbar-track{background:var(--primary-dark)}.incidents-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.incidents-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width:768px){.incident-header{flex-direction:column;gap:8px}.incident-time{margin-left:0}.incident-footer{align-items:flex-start;flex-direction:column;gap:10px}}.dashboard-container{margin:0 auto;max-width:1800px;padding:20px}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:3fr 2fr;margin-bottom:20px;min-height:600px}.dashboard-column{display:flex;flex-direction:column}.performance-section{background-color:var(--secondary-dark);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.performance-toggle{align-items:center;background-color:var(--secondary-dark);border:none;color:var(--text-light);cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;padding:16px 20px;text-align:left;transition:background-color var(--transition-fast);width:100%}.performance-toggle:hover{background-color:var(--hover-bg)}.performance-content{animation:slideDown .3s ease-out;border-top:1px solid var(--border-color);padding:20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1200px){.dashboard-grid{gap:16px;grid-template-columns:1fr}.dashboard-column{min-height:400px}}@media (max-width:768px){.dashboard-container{padding:12px}.dashboard-grid{gap:12px}.performance-content{padding:12px}}.dashboard-loading{align-items:center;display:flex;justify-content:center;min-height:400px}.dashboard-empty{color:var(--text-secondary);padding:60px 20px;text-align:center}.dashboard-empty h3{color:var(--text-light);margin-bottom:12px}.dashboard-empty p{margin-bottom:20px}.stream-management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.stream-management-title{color:var(--text-primary);font-size:2rem;margin:0}.stream-management-actions{align-items:center;display:flex;gap:10px}.stream-stats-bar{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px 20px}.stream-stats-group{align-items:center;display:flex;gap:32px}.stream-stat-item{display:flex;flex-direction:column;gap:4px}.stream-stat-label{font-size:12px}.stream-stat-value{font-size:24px}.stream-stat-value.success{color:var(--accent-green)}.stream-stat-value.error{color:var(--accent-red)}.stream-stat-value.warning{color:var(--accent-orange)}.stream-filters-bar{align-items:center;display:flex;gap:12px;margin-bottom:20px}.stream-filter-search{flex:1 1;max-width:400px}.stream-filter-select{min-width:150px}.stream-cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-bottom:20px}@media (max-width:1400px){.stream-cards-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media (max-width:900px){.stream-cards-grid{grid-template-columns:1fr}}.stream-card{background:var(--bg-secondary);border:1px solid var(--border-color);transition:all .2s ease}.stream-card:hover{border-color:var(--accent-blue);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stream-card-header{border-bottom:1px solid var(--border-color);padding:16px}.stream-card-title{align-items:center;display:flex;gap:10px}.stream-status-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.stream-card-title h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.stream-card-badges{display:flex;gap:8px}.stream-card-body{padding:16px}.stream-card-url{font-family:Courier New,monospace;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stream-card-description,.stream-card-url{color:var(--text-secondary);font-size:13px}.stream-card-description{line-height:1.4;margin-bottom:12px}.stream-card-stats{grid-gap:12px;border-top:1px solid var(--border-color);display:grid;gap:12px;grid-template-columns:repeat(3,1fr);padding-top:12px}.stream-stat{display:flex;flex-direction:column;gap:4px}.stream-stat-label{color:var(--text-secondary);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.stream-stat-value{color:var(--text-primary);font-size:14px;font-weight:600}.stream-card-actions{background:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.stream-action-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.stream-action-btn:hover:not(:disabled){background:var(--bg-primary);transform:translateY(-1px)}.stream-action-btn:disabled{cursor:not-allowed;opacity:.5}.stream-action-view{border-color:var(--accent-blue);color:var(--accent-blue)}.stream-action-view:hover:not(:disabled){background:#1e88e51a}.stream-action-start{border-color:var(--accent-green);color:var(--accent-green)}.stream-action-start:hover:not(:disabled){background:#28a7451a}.stream-action-stop{border-color:var(--accent-orange);color:var(--accent-orange)}.stream-action-stop:hover:not(:disabled){background:#ff8f001a}.stream-action-delete{border-color:var(--accent-red);color:var(--accent-red)}.stream-action-delete:hover:not(:disabled){background:#e539351a}.stream-empty-state{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:8px;padding:60px 20px;text-align:center}.stream-empty-state h3{color:var(--text-primary);font-size:20px;margin:0 0 12px}.stream-empty-state p{color:var(--text-secondary);font-size:14px;margin:0 0 24px}.emergency-monitor-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.emergency-monitor-title{color:var(--text-primary);font-size:2rem;margin:0}.emergency-monitor-actions{align-items:center;display:flex;gap:10px}.incident-stats-bar{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px 20px}.incident-stats-group{align-items:center;display:flex;gap:32px}.incident-stat-item{display:flex;flex-direction:column;gap:4px}.incident-stat-label{color:var(--text-secondary);font-size:12px;letter-spacing:.5px;text-transform:uppercase}.incident-stat-value{color:var(--text-primary);font-size:24px;font-weight:600}.incident-stat-value.active{color:var(--accent-red)}.incident-stat-value.resolved{color:var(--accent-green)}.incident-stat-value.recent{color:var(--accent-blue)}.incident-filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.incident-filter-search{flex:1 1;min-width:250px}.incident-filter-select{min-width:130px}.incident-cards-container{display:flex;flex-direction:column;gap:16px}.incident-priority-section{margin-bottom:24px}.incident-priority-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;gap:10px;margin-bottom:12px;padding-bottom:8px}.incident-priority-header h3{color:var(--text-primary);font-size:16px;font-weight:600;letter-spacing:.5px;margin:0;text-transform:uppercase}.incident-priority-count{background:var(--bg-primary);border-radius:12px;color:var(--text-secondary);font-size:13px;font-weight:600;padding:4px 10px}.incident-priority-section.critical .incident-priority-header{border-bottom-color:var(--accent-red)}.incident-priority-section.critical .incident-priority-header h3{color:var(--accent-red)}.incident-priority-section.high .incident-priority-header{border-bottom-color:var(--accent-orange)}.incident-priority-section.high .incident-priority-header h3{color:var(--accent-orange)}.incident-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:all .2s ease}.incident-card:hover{border-color:var(--accent-blue);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.incident-card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px}.incident-card-type{align-items:center;display:flex;gap:12px}.incident-type-icon{align-items:center;background:var(--bg-primary);border-radius:8px;color:var(--accent-red);display:flex;height:40px;justify-content:center;width:40px}.incident-card-type h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 4px}.incident-id{color:var(--text-secondary);font-family:Courier New,monospace;font-size:12px}.incident-card-badges{display:flex;gap:8px}.incident-card-body{padding:16px}.incident-location{color:var(--text-primary);font-size:14px;margin-bottom:8px}.incident-location strong{color:var(--text-secondary);font-weight:500}.incident-description{color:var(--text-primary);font-size:14px;line-height:1.5;margin-bottom:12px}.incident-units{margin-bottom:12px}.incident-units strong{color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.incident-units-list{display:flex;flex-wrap:wrap;gap:6px}.incident-unit-badge{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:12px;font-weight:500;padding:4px 10px}.incident-keywords{margin-bottom:12px}.incident-keywords strong{color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.incident-keywords-list{display:flex;flex-wrap:wrap;gap:6px}.incident-keyword-badge{background:#e539351a;border:1px solid var(--accent-red);border-radius:4px;color:var(--accent-red);font-size:12px;font-weight:500;padding:4px 10px}.incident-timestamp{border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:12px;margin-top:12px;padding-top:12px}.incident-card-actions{background:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.incident-action-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.incident-action-btn:hover{background:var(--bg-primary);transform:translateY(-1px)}.incident-action-view{border-color:var(--accent-blue);color:var(--accent-blue)}.incident-action-view:hover{background:#1e88e51a}.incident-action-resolve{border-color:var(--accent-green);color:var(--accent-green)}.incident-action-resolve:hover{background:#28a7451a}.incident-empty-state{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:8px;padding:60px 20px;text-align:center}.incident-empty-state h3{color:var(--text-primary);font-size:20px;margin:0 0 12px}.incident-empty-state p{color:var(--text-secondary);font-size:14px;margin:0 0 24px}.system-status-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.system-status-title{color:var(--text-primary);font-size:2rem;margin:0}.system-status-actions{align-items:center;display:flex;gap:10px}.system-health-banner{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;gap:16px;margin-bottom:24px;padding:20px}.system-health-banner.healthy{background:#28a7450d;border-left:4px solid var(--accent-green)}.system-health-banner.degraded{background:#ff8f000d;border-left:4px solid var(--accent-orange)}.system-health-banner.down{background:#e539350d;border-left:4px solid var(--accent-red)}.system-health-icon{font-size:48px}.system-health-info h2{color:var(--text-primary);font-size:24px;margin:0 0 8px}.system-health-info p{color:var(--text-secondary);font-size:14px;margin:0}.services-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:24px}.service-status-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;transition:all .2s ease}.service-status-card:hover{border-color:var(--accent-blue);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.service-status-header{align-items:center;display:flex;gap:12px;margin-bottom:12px}.service-status-icon{align-items:center;background:var(--bg-primary);border-radius:8px;display:flex;height:40px;justify-content:center;width:40px}.service-status-info h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 4px}.service-status-label{font-size:13px;font-weight:500}.service-status-details{border-top:1px solid var(--border-color);padding:12px 0}.service-detail-item{display:flex;font-size:13px;justify-content:space-between;margin-bottom:6px}.service-detail-label{color:var(--text-secondary);font-weight:500}.service-detail-value{color:var(--text-primary)}.service-metrics{grid-gap:8px;border-top:1px solid var(--border-color);display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin-top:12px;padding-top:12px}.service-metric-item{display:flex;flex-direction:column;gap:4px}.service-metric-label{color:var(--text-secondary);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.service-metric-value{color:var(--text-primary);font-size:16px;font-weight:600}.performance-section{margin-bottom:24px}.performance-section h3{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.performance-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.performance-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px}.performance-card h4{color:var(--text-secondary);font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.performance-value{color:var(--text-primary);font-size:32px;font-weight:700;margin-bottom:8px}.performance-label{color:var(--text-secondary);font-size:12px}.performance-bar{background:var(--bg-primary);border-radius:4px;height:8px;margin-top:8px;overflow:hidden;width:100%}.performance-bar-fill{background:var(--accent-blue);height:100%;transition:width .3s ease}.performance-bar-fill.warning{background:var(--accent-orange)}.performance-bar-fill.critical{background:var(--accent-red)}.activity-log-section{margin-bottom:24px}.activity-log-section h3{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.activity-log{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;max-height:400px;overflow-y:auto}.activity-log-item{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;gap:12px;padding:12px 16px}.activity-log-item:last-child{border-bottom:none}.activity-log-time{color:var(--text-secondary);font-family:Courier New,monospace;font-size:12px;min-width:80px}.activity-log-message{color:var(--text-primary);flex:1 1;font-size:13px}.activity-log-type{border-radius:4px;font-size:11px;font-weight:600;padding:2px 8px;text-transform:uppercase}.activity-log-type.info{background:#1e88e51a;color:var(--accent-blue)}.activity-log-type.success{background:#28a7451a;color:var(--accent-green)}.activity-log-type.warning{background:#ff8f001a;color:var(--accent-orange)}.activity-log-type.error{background:#e539351a;color:var(--accent-red)}.stream-health-section{margin-bottom:24px}.stream-health-section h3{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.stream-health-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.stream-health-item{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;gap:10px;padding:12px}.stream-health-dot{border-radius:50%;height:12px;width:12px}.stream-health-dot.active{background:var(--accent-green);box-shadow:0 0 8px var(--accent-green)}.stream-health-dot.inactive{background:var(--text-secondary)}.stream-health-dot.error{background:var(--accent-red);box-shadow:0 0 8px var(--accent-red)}.stream-health-name{color:var(--text-primary);flex:1 1;font-size:13px;font-weight:500}.stream-health-status{color:var(--text-secondary);font-size:11px;text-transform:uppercase}.transcription-monitor{background:#1a2035;background:var(--bg-primary,#1a2035);color:#f5f5f5;color:var(--text-primary,#f5f5f5);display:flex;flex-direction:column;height:100vh}.filter-controls{align-items:center;background:#272e48;background:var(--bg-secondary,#272e48);border-bottom:2px solid #3a4466;border-bottom:2px solid var(--border-color,#3a4466);display:flex;flex-shrink:0;justify-content:space-between;padding:1.5rem 2rem}.filter-controls-left{align-items:center;display:flex;gap:1.5rem}.monitor-title{color:#f5f5f5;color:var(--text-primary,#f5f5f5);font-size:1.5rem;font-weight:600;margin:0}.monitor-stats{align-items:center;display:flex;gap:.75rem}.stat-badge{background:#1e88e526;border:1px solid #1e88e54d;border-radius:4px;color:#1e88e5;font-size:.875rem;font-weight:500;padding:.375rem .75rem}.stat-badge.emergency-badge{background:#e5393526;border-color:#e539354d;color:#e53935}.filter-controls-right{align-items:center;display:flex;gap:1rem}.filter-checkbox{align-items:center;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;-webkit-user-select:none;user-select:none}.filter-checkbox input[type=checkbox]{cursor:pointer;height:18px;width:18px}.auto-scroll-toggle{background:#1e88e51a;border:1px solid #1e88e54d;border-radius:4px;color:#b8c2cc;color:var(--text-secondary,#b8c2cc);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.auto-scroll-toggle:hover{background:#1e88e533;border-color:#1e88e580}.auto-scroll-toggle.active{background:#1e88e533;border-color:#1e88e5;color:#1e88e5}.monitor-content{flex:1 1;overflow-y:auto;padding:1.5rem;scroll-behavior:smooth}.monitor-content::-webkit-scrollbar{width:10px}.monitor-content::-webkit-scrollbar-track{background:#1a2035;background:var(--bg-primary,#1a2035)}.monitor-content::-webkit-scrollbar-thumb{background:#1e88e54d;border-radius:5px}.monitor-content::-webkit-scrollbar-thumb:hover{background:#1e88e580}.connection-warning{background:#ff8f0026;border:1px solid #ff8f004d;border-radius:6px;color:#ff8f00;font-weight:500;margin-bottom:1rem;padding:1rem;text-align:center}.empty-state{align-items:center;color:#b8c2cc;color:var(--text-secondary,#b8c2cc);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h2{color:#f5f5f5;color:var(--text-primary,#f5f5f5);font-size:1.5rem;margin:0 0 .5rem}.empty-state p{font-size:1rem;margin:.5rem 0}.empty-state-hint{font-size:.875rem;opacity:.7}.streams-container{display:flex;flex-direction:column;gap:1.5rem}.stream-card{animation:slideIn .3s ease-out;background:#272e48;background:var(--bg-secondary,#272e48);border:1px solid #3a4466;border:1px solid var(--border-color,#3a4466);border-radius:8px;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.stream-card-header{align-items:center;background:#1e88e50d;border-bottom:1px solid #3a4466;border-bottom:1px solid var(--border-color,#3a4466);display:flex;justify-content:space-between;padding:1rem 1.25rem}.stream-info{align-items:center;display:flex;gap:.75rem}.stream-status-indicator{animation:pulse 2s infinite;border-radius:50%;height:12px;width:12px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stream-name{color:#f5f5f5;color:var(--text-primary,#f5f5f5);font-size:1.1rem;font-weight:600;margin:0}.stream-status-text{color:#b8c2cc;color:var(--text-secondary,#b8c2cc);font-size:.875rem;font-weight:500;text-transform:uppercase}.stream-stats{align-items:center;display:flex;gap:1rem}.stream-stat{color:#b8c2cc;color:var(--text-secondary,#b8c2cc);font-size:.875rem}.stream-stat.emergency-stat{color:#e53935;font-weight:600}.stream-stat.last-update{opacity:.7}.stream-transcriptions{display:flex;flex-direction:column;gap:.75rem;max-height:600px;overflow-y:auto;padding:1rem}.stream-transcriptions::-webkit-scrollbar{width:6px}.stream-transcriptions::-webkit-scrollbar-track{background:#0000}.stream-transcriptions::-webkit-scrollbar-thumb{background:#1e88e533;border-radius:3px}.empty-transcriptions{color:#b8c2cc;color:var(--text-secondary,#b8c2cc);opacity:.7;padding:2rem;text-align:center}.transcription-item{animation:fadeIn .3s ease-out;background:#ffffff08;border-left:3px solid #3a4466;border-left:3px solid var(--border-color,#3a4466);border-radius:4px;padding:.875rem;transition:all .2s}@keyframes fadeIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.transcription-item:hover{background:#ffffff0d}.transcription-item.critical{background:#e5393526;border-left-color:#e53935}.transcription-item.high{background:#ff8f0026;border-left-color:#ff8f00}.transcription-item.medium{background:#ffc10726;border-left-color:#ffc107}.transcription-item.low{background:#1e88e526;border-left-color:#1e88e5}.transcription-header{align-items:center;display:flex;font-size:.875rem;gap:1rem;margin-bottom:.5rem}.transcription-time{color:#b8c2cc;color:var(--text-secondary,#b8c2cc);font-family:Courier New,monospace;font-weight:600}.transcription-priority{color:#f5f5f5;color:var(--text-primary,#f5f5f5);font-weight:600}.transcription-confidence{color:#b8c2cc;color:var(--text-secondary,#b8c2cc);font-size:.8rem;margin-left:auto}.transcription-text{word-wrap:break-word;color:#f5f5f5;color:var(--text-primary,#f5f5f5);font-family:Courier New,monospace;font-size:.95rem;line-height:1.5;margin:.5rem 0;white-space:pre-wrap}.transcription-metadata{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.metadata-badge{align-items:center;border-radius:3px;display:inline-flex;font-size:.75rem;font-weight:500;gap:.25rem;padding:.25rem .625rem}.type-badge{background:#e5393533;border:1px solid #e539354d;color:#ff6b6b}.keywords-badge{background:#ff8f0033;border:1px solid #ff8f004d;color:#ffb74d}.location-badge{background:#1e88e533;border:1px solid #1e88e54d;color:#64b5f6}.units-badge{background:#4caf5033;border:1px solid #4caf504d;color:#81c784}.incident-badge{background:#9c27b033;border:1px solid #9c27b04d;color:#ba68c8;font-family:Courier New,monospace}.scroll-to-bottom{background:#1e88e5e6;border-radius:25px;bottom:2rem;box-shadow:0 4px 12px #0000004d;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;position:fixed;right:2rem;transition:all .2s;z-index:100}.scroll-to-bottom:hover{background:#1e88e5;box-shadow:0 6px 16px #0006;transform:translateY(-2px)}@media (max-width:768px){.filter-controls{align-items:flex-start;flex-direction:column;gap:1rem}.filter-controls-left,.filter-controls-right{justify-content:space-between;width:100%}.monitor-title{font-size:1.25rem}.stream-card-header{align-items:flex-start;flex-direction:column;gap:.75rem}.stream-stats{justify-content:space-between;width:100%}.transcription-text{font-size:.875rem}}
/*# sourceMappingURL=main.ec5a2ec8.css.map*/