.camera-feed{position:relative;border-radius:var(--border-radius);overflow:hidden;border:2px solid rgba(255,255,255,.1);background:#00000080;transition:all .5s ease;filter:brightness(.9) contrast(1.1)}.camera-feed.fire-detected{border-color:var(--alert-red);animation:glow-pulse .5s ease-in-out infinite;filter:brightness(1.1) contrast(1.2)}.camera-feed.desaturated{filter:grayscale(100%) brightness(.7) contrast(.9)}.camera-video{width:100%;height:100%;object-fit:cover;display:block}.video-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#1e90ff1a,#00000080);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem}.placeholder-content{text-align:center;color:var(--text-primary)}.placeholder-icon{font-size:3rem;opacity:.5}.placeholder-text{font-family:JetBrains Mono,monospace;font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.placeholder-status{font-family:JetBrains Mono,monospace;color:var(--alert-red);font-size:.9rem;font-weight:600}.camera-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;padding:.75rem;background:linear-gradient(to bottom,rgba(0,0,0,.4) 0%,transparent 20%,transparent 80%,rgba(0,0,0,.6) 100%)}.camera-overlay-top{display:flex;justify-content:space-between;align-items:flex-start}.live-badge{background:var(--alert-red);color:#fff;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;font-family:JetBrains Mono,monospace;text-transform:uppercase;box-shadow:0 0 10px #ff3b3b80;animation:pulse 2s ease-in-out infinite}.timestamp{background:#0009;color:var(--text-primary);padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-family:JetBrains Mono,monospace;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.camera-overlay-bottom{display:flex;flex-direction:column;gap:.25rem}.camera-label{background:#000000b3;color:var(--text-primary);padding:.4rem .6rem;border-radius:.25rem;font-size:.9rem;font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:inline-block;width:fit-content}.camera-location{background:#00000080;color:var(--text-primary);padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-family:JetBrains Mono,monospace;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:inline-block;width:fit-content;opacity:.8}.fire-alert-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#ff3b3bf2;border:2px solid var(--alert-red);border-radius:.5rem;padding:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 0 30px #ff3b3bcc;z-index:10;animation:fade-in .5s ease;min-width:200px}.fire-alert-icon{font-size:2rem;text-align:center;margin-bottom:.5rem}.fire-alert-content{color:#fff;font-family:Inter,sans-serif}.fire-alert-title{font-weight:700;font-size:1rem;margin-bottom:.5rem;text-align:center}.fire-alert-detail{font-size:.85rem;margin-bottom:.25rem;font-family:JetBrains Mono,monospace}.crt-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(0,0,0,.1) 0px,transparent 1px,transparent 2px,rgba(0,0,0,.1) 3px);opacity:.3;mix-blend-mode:overlay}.camera-feed:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:var(--border-radius);box-shadow:inset 0 0 50px #00000080;pointer-events:none;z-index:1}.surveillance-grid{height:100%;display:flex;flex-direction:column;background:#ffffff05;border-radius:var(--border-radius);padding:1rem;border:1px solid rgba(255,255,255,.1)}.surveillance-grid-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.surveillance-grid-header h2{font-size:1.2rem;font-weight:600;color:var(--text-primary);font-family:Inter,sans-serif}.system-status{font-family:JetBrains Mono,monospace;font-size:.9rem;padding:.25rem .75rem;border-radius:.5rem;background:#ffffff1a}.surveillance-grid-container{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:1rem;flex:1;min-height:0}.evacuation-map-container{height:100%;display:flex;flex-direction:column;background:#ffffff05;border-radius:var(--border-radius);padding:1rem;border:1px solid rgba(255,255,255,.1);position:relative}.evacuation-map-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.evacuation-map-header h2{font-size:1.2rem;font-weight:600;color:var(--text-primary);font-family:Inter,sans-serif}.map-status{font-family:JetBrains Mono,monospace;font-size:.9rem;padding:.25rem .75rem;border-radius:.5rem;background:#ffffff1a}.evacuation-map{flex:1;min-height:0;border-radius:var(--border-radius);overflow:hidden;background:#0c0f14;position:relative}.map-svg{width:100%;height:100%;display:block}.camera-node{transition:all .3s ease}.fire-node{filter:drop-shadow(0 0 10px rgba(255,59,59,.8))}.node-label,.node-location{font-family:Inter,sans-serif;pointer-events:none;-webkit-user-select:none;user-select:none}.evacuation-route{pointer-events:none}.route-line{filter:drop-shadow(0 0 5px rgba(52,211,153,.6))}.pedestrian{filter:drop-shadow(0 0 3px rgba(52,211,153,.8))}.danger-radius{pointer-events:none}.map-node{transition:all .2s ease}.map-node:hover{filter:drop-shadow(0 0 8px rgba(59,130,246,.8))}.map-node.danger-node:hover{filter:drop-shadow(0 0 8px rgba(255,59,59,.8))}.camera-node{transition:all .2s ease}.camera-node:hover{filter:drop-shadow(0 0 10px rgba(59,130,246,.6))}.camera-node.fire-node:hover{filter:drop-shadow(0 0 10px rgba(255,59,59,.8))}.safe-exit{transition:all .2s ease}.safe-exit:hover{filter:drop-shadow(0 0 8px rgba(52,211,153,.8))}.safe-exit.danger-exit:hover{filter:drop-shadow(0 0 8px rgba(255,59,59,.8))}@keyframes pedestrian-move{0%{offset-distance:0%}to{offset-distance:100%}}.timeline-container{display:flex;gap:2rem;height:100%;align-items:flex-start}.timeline-section{flex:1;display:flex;flex-direction:column;gap:.75rem}.timeline-header{display:flex;align-items:center}.timeline-title{font-size:.9rem;font-weight:600;color:var(--text-primary);font-family:Inter,sans-serif;text-transform:uppercase;letter-spacing:1px}.timeline-scroll{overflow-x:auto;overflow-y:hidden;padding-bottom:.5rem}.timeline-track{position:relative;display:flex;gap:2rem;min-width:max-content;padding:1rem 0;align-items:center}.timeline-event{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;min-width:120px;opacity:.6;transition:opacity .3s ease}.timeline-event.active{opacity:1}.timeline-event-time{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--text-primary);font-weight:600}.timeline-event-dot{width:12px;height:12px;border-radius:50%;background:var(--text-primary);border:2px solid var(--text-primary);position:relative;z-index:2;transition:all .3s ease}.timeline-event.active .timeline-event-dot{background:var(--alert-red);border-color:var(--alert-red);box-shadow:0 0 10px #ff3b3b99;animation:pulse 2s ease-in-out infinite}.timeline-event-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:var(--alert-red);animation:pulse-ring 2s ease-out infinite}@keyframes pulse-ring{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}.timeline-event-label{font-size:.8rem;color:var(--text-primary);text-align:center;font-family:Inter,sans-serif;white-space:nowrap}.timeline-progress{position:absolute;bottom:16px;left:0;right:0;height:2px;background:#ffffff1a;z-index:1}.timeline-progress-bar{height:100%;background:linear-gradient(90deg,var(--alert-red) 0%,var(--safe-green) 100%);box-shadow:0 0 10px #ff3b3b80;transition:width .4s ease;animation:progress-glow 2s ease-in-out infinite}@keyframes progress-glow{0%,to{box-shadow:0 0 10px #ff3b3b80}50%{box-shadow:0 0 20px #ff3b3bcc}}.status-section{flex:0 0 280px;display:flex;flex-direction:column;gap:.75rem}.status-header{display:flex;align-items:center}.status-title{font-size:.9rem;font-weight:600;color:var(--text-primary);font-family:Inter,sans-serif;text-transform:uppercase;letter-spacing:1px}.status-metrics{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:#ffffff08;border-radius:.5rem;border:1px solid rgba(255,255,255,.1)}.status-metric{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.status-label{color:#e4e4e4b3;font-family:Inter,sans-serif}.status-value{color:var(--text-primary);font-weight:600;font-family:JetBrains Mono,monospace;font-size:.9rem}.status-value.alert{color:var(--alert-red)}.status-value.normal{color:var(--safe-green)}.status-value.mode-alert{color:var(--alert-red);text-transform:uppercase;font-weight:700}.status-value.mode-normal{color:var(--safe-green);text-transform:uppercase;font-weight:700}.alert-panel{position:absolute;top:1rem;right:1rem;width:320px;background:#141923f2;border:2px solid var(--alert-red);border-radius:var(--border-radius);padding:1.5rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 0 40px #ff3b3b66;z-index:100;animation:slide-in-right .6s ease-out;font-family:Inter,sans-serif}.alert-panel-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,59,59,.3)}.alert-icon{font-size:1.5rem;animation:pulse 2s ease-in-out infinite}.alert-title{font-size:1.1rem;font-weight:700;color:var(--alert-red);text-transform:uppercase;letter-spacing:1px;font-family:JetBrains Mono,monospace}.alert-panel-content{display:flex;flex-direction:column;gap:1.25rem}.alert-message{font-size:.95rem;color:var(--text-primary);line-height:1.6}.alert-subtext{font-size:.85rem;color:#e4e4e4b3;display:block;margin-top:.25rem}.alert-section{display:flex;flex-direction:column;gap:.75rem}.alert-section-title{font-size:.9rem;font-weight:600;color:var(--safe-green);font-family:Inter,sans-serif}.safe-exits-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.safe-exit-item{padding:.5rem .75rem;background:#34d3991a;border-left:3px solid var(--safe-green);border-radius:.25rem;font-size:.85rem;color:var(--text-primary);font-family:Inter,sans-serif;transition:all .2s ease}.safe-exit-item:hover{background:#34d39933;transform:translate(4px)}.alert-metrics{display:flex;flex-direction:column;gap:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.alert-metric{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.metric-label{color:#e4e4e4cc;font-family:Inter,sans-serif}.metric-value{color:var(--text-primary);font-weight:600;font-family:JetBrains Mono,monospace;font-size:1rem}.dashboard{display:flex;flex-direction:column;height:100vh;width:100vw;background:var(--bg-primary);position:relative}.dashboard-main{display:flex;flex:1;gap:1rem;padding:1rem;overflow:hidden}.dashboard-left{flex:1;min-width:0}.dashboard-right{flex:1;min-width:0;position:relative}.dashboard-bottom{height:120px;flex-shrink:0;border-top:1px solid rgba(255,255,255,.1);padding:1rem}.clear-alert-btn{position:absolute;top:1rem;right:1rem;padding:.5rem 1rem;background:#ff3b3b33;border:1px solid var(--alert-red);color:var(--text-primary);border-radius:.5rem;cursor:pointer;font-family:Inter,sans-serif;font-weight:500;z-index:1000;transition:all .3s ease}.clear-alert-btn:hover{background:#ff3b3b4d;box-shadow:0 0 20px #ff3b3b66}.App{height:100vh;width:100vw;display:flex;flex-direction:column;background:var(--bg-primary)}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0C0F14;--text-primary: #E4E4E4;--accent-blue: #1E90FF;--alert-red: #FF3B3B;--safe-green: #34D399;--map-lines: #7F8C8D;--border-radius: 1rem}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;width:100vw}code{font-family:JetBrains Mono,Courier New,monospace}#root{height:100vh;width:100vw}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff0d}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px #ff3b3b80}50%{box-shadow:0 0 40px #ff3b3bcc}}@keyframes slide-in-right{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes route-draw{0%{stroke-dashoffset:1000;opacity:0}50%{opacity:1}to{stroke-dashoffset:0;opacity:1}}
