.header{height:60px;background:#0a0e27f2;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;padding:0 20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-left{display:flex;align-items:center;gap:30px}.logo{display:flex;align-items:center;gap:10px}.logo-icon{color:#4ade80}.logo-text{font-size:18px;font-weight:700;color:#fff;letter-spacing:1px}.platform-selector{display:flex;gap:12px;height:100%;align-items:center}.platform-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:8px 16px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:row;gap:10px;height:42px;justify-content:center;align-items:center;box-sizing:border-box}.platform-button:hover{background:#ffffff1a;border-color:#4ade8080}.platform-button.active{background:#4ade8026;border-color:#4ade80;box-shadow:0 0 15px #4ade804d,inset 0 0 10px #4ade801a}.platform-name{font-size:13px;font-weight:600;color:#fff;line-height:1}.platform-button.active .platform-name{color:#4ade80;text-shadow:0 0 8px rgba(74,222,128,.4)}.platform-line{font-size:10px;color:#9ca3af;line-height:1;padding:2px 8px;background:#ffffff0d;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.platform-button.active .platform-line{background:#4ade8033;border-color:#4ade8066;color:#4ade80}.header-right{display:flex;align-items:center;gap:20px}.weather-info{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#ffffff0d;border-radius:4px}.weather-icon{color:#fbbf24}.weather-text{font-size:12px;color:#9ca3af}.datetime-info{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#ffffff0d;border-radius:4px}.time-icon{color:#4ade80}.datetime{display:flex;flex-direction:column;gap:2px}.time{font-size:14px;font-weight:600;color:#fff;font-family:Courier New,monospace}.date{font-size:10px;color:#9ca3af}.header-actions{display:flex;gap:10px}.action-button{position:relative;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:8px;cursor:pointer;transition:all .3s ease;color:#9ca3af}.action-button:hover{background:#ffffff1a;color:#fff}.notification-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:10px;font-weight:600;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.sidebar{width:60px;background:#0a0e27f2;border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;justify-content:space-between;padding:10px 0}.sidebar-nav{display:flex;flex-direction:column;gap:5px}.nav-item{background:transparent;border:none;padding:12px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;color:#9ca3af}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item.active{background:#4ade801a;color:#4ade80}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:30px;background:#4ade80;border-radius:0 2px 2px 0}.nav-icon{transition:all .3s ease}.nav-label{font-size:10px;font-weight:500;transition:all .3s ease}.sidebar-footer{display:flex;flex-direction:column;gap:10px;padding:10px}.system-status{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 0;border-top:1px solid rgba(255,255,255,.1)}.status-indicator{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e80;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 8px #22c55e80}50%{opacity:.7;box-shadow:0 0 12px #22c55ecc}}.status-text{font-size:9px;color:#9ca3af;text-align:center}.version-info{text-align:center}.version{font-size:9px;color:#6b7280}.three-scene{width:100%;height:100%;position:relative}.sci-fi-border{position:relative;background:#0a0e27f2;border:1px solid rgba(74,222,128,.3);border-radius:4px}.sci-fi-border:before,.sci-fi-border:after,.sci-fi-border .corner:before,.sci-fi-border .corner:after{content:"";position:absolute;width:8px;height:8px;border-color:#4ade80;border-style:solid;transition:all .3s ease}.sci-fi-border:before{top:-1px;left:-1px;border-width:2px 0 0 2px}.sci-fi-border:after{top:-1px;right:-1px;border-width:2px 2px 0 0}.sci-fi-border .corner:before{bottom:-1px;left:-1px;border-width:0 0 2px 2px}.sci-fi-border .corner:after{bottom:-1px;right:-1px;border-width:0 2px 2px 0}.camera-label{background:#0a0e27d9;color:#fff;padding:6px 12px;border-radius:4px;font-size:10px;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .3s ease;border:1px solid rgba(74,222,128,.3);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:relative;overflow:hidden}.camera-label:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(74,222,128,.2),transparent);transition:left .5s ease}.camera-label:hover:before{left:100%}.camera-label:hover{background:#4ade8040;border-color:#4ade80cc;transform:scale(1.08);box-shadow:0 0 20px #4ade8066}.camera-label.active{background:#4ade8059;border-color:#4ade80;box-shadow:0 0 25px #4ade8099;animation:cameraPulse 2s infinite}@keyframes cameraPulse{0%,to{box-shadow:0 0 25px #4ade8099}50%{box-shadow:0 0 35px #4ade80e6}}.platform-info{background:linear-gradient(135deg,#0a0e27f2,#0d1233f2);padding:16px 24px;border-radius:8px;text-align:center;border:1px solid rgba(74,222,128,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.platform-info:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#4ade80,transparent);animation:scanLine 3s infinite}@keyframes scanLine{0%{opacity:0;transform:scaleX(.5)}50%{opacity:1;transform:scaleX(1)}to{opacity:0;transform:scaleX(.5)}}.platform-name{font-size:16px;font-weight:800;color:#4ade80;margin-bottom:6px;text-shadow:0 0 10px rgba(74,222,128,.5);letter-spacing:1px}.platform-line{font-size:11px;color:#60a5fa;margin-bottom:8px;padding:2px 8px;background:#60a5fa26;border-radius:4px;display:inline-block}.people-count{font-size:12px;color:#9ca3af;letter-spacing:.5px}.platform-info.compact{padding:12px 24px;background:linear-gradient(135deg,#0a0e27e6,#0d1233f2);border:1px solid rgba(245,158,11,.4);box-shadow:0 4px 20px #0006,0 0 30px #f59e0b33}.platform-info.compact:before{background:linear-gradient(90deg,transparent,#f59e0b,transparent)}.people-count-large{display:flex;align-items:center;gap:12px}.people-label{font-size:14px;font-weight:600;color:#d1d5db;letter-spacing:1px}.people-value{font-size:32px;font-weight:800;color:#f59e0b;text-shadow:0 0 10px rgba(245,158,11,.6),0 0 20px rgba(245,158,11,.4);letter-spacing:2px}.people-unit{font-size:14px;font-weight:600;color:#f59e0b;text-shadow:0 0 8px rgba(245,158,11,.5)}.camera-info-panel{position:absolute;top:20px;right:20px;width:340px;background:linear-gradient(180deg,#0a0e27fa,#0d1233fa);border-radius:8px;border:1px solid rgba(74,222,128,.3);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #0009,0 0 60px #4ade801a;animation:slideIn .3s ease-out;z-index:100;overflow:hidden}.camera-info-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#4ade80,#22c55e,#4ade80);background-size:200% 100%;animation:gradientMove 3s linear infinite}@keyframes gradientMove{0%{background-position:0% 0%}to{background-position:200% 0%}}@keyframes slideIn{0%{opacity:0;transform:translate(30px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.camera-info-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(74,222,128,.15);background:#4ade800d}.camera-info-header h3{font-size:14px;font-weight:700;color:#fff;margin:0;display:flex;align-items:center;gap:8px}.camera-icon{font-size:16px}.close-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#9ca3af;font-size:16px;cursor:pointer;line-height:1;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .3s ease}.close-btn:hover{background:#ef444433;border-color:#ef444480;color:#ef4444;transform:rotate(90deg)}.camera-video{padding:12px;border-bottom:1px solid rgba(74,222,128,.1)}.video-placeholder{aspect-ratio:16 / 9;background:linear-gradient(135deg,#0a0e27,#16213e);border-radius:6px;position:relative;overflow:hidden;border:1px solid rgba(74,222,128,.2)}.scan-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(74,222,128,.6),transparent);animation:scanMove 3s linear infinite;pointer-events:none;z-index:2}@keyframes scanMove{0%{top:0;opacity:0}10%{opacity:1}90%{opacity:1}to{top:100%;opacity:0}}.grid-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(74,222,128,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(74,222,128,.05) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;z-index:1}.video-overlay-top{position:absolute;top:8px;left:8px;right:8px;display:flex;justify-content:space-between;align-items:center;z-index:3}.location-tag{font-size:11px;color:#fff;background:#0009;padding:4px 10px;border-radius:4px;border-left:2px solid #4ade80}.live-badge{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:#ef4444;background:#0009;padding:4px 10px;border-radius:4px}.pulse-dot{width:8px;height:8px;background:#ef4444;border-radius:50%;animation:livePulse 1s infinite}@keyframes livePulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 6px #ef4444cc}50%{opacity:.5;transform:scale(.8);box-shadow:0 0 10px #ef4444}}.video-overlay-bottom{position:absolute;bottom:8px;left:8px;right:8px;display:flex;justify-content:space-between;align-items:center;z-index:3}.time-tag{font-size:11px;color:#fff;background:#0009;padding:4px 10px;border-radius:4px;font-family:Courier New,monospace;letter-spacing:1px}.rec-tag{font-size:10px;font-weight:700;color:#ef4444;background:#0009;padding:4px 10px;border-radius:4px;animation:recFlash 1.5s infinite}@keyframes recFlash{0%,to{opacity:1}50%{opacity:.5}}.video-content{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center}.video-content:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.15) 2px,rgba(0,0,0,.15) 4px);pointer-events:none}.camera-stats{padding:14px 16px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(74,222,128,.08)}.stat-item:last-child{border-bottom:none}.stat-label{font-size:12px;color:#9ca3af;letter-spacing:.3px}.stat-value{font-size:12px;font-weight:600;color:#fff}.stat-value.people{display:flex;align-items:baseline;gap:4px}.stat-value.people .count{font-size:18px;font-weight:800;color:#4ade80}.stat-value.people .unit{font-size:10px;color:#9ca3af}.stat-value.status{display:flex;align-items:center;gap:6px}.stat-value.status .status-indicator{width:8px;height:8px;border-radius:50%}.stat-value.normal .status-indicator{background:#4ade80;box-shadow:0 0 8px #4ade8099}.stat-value.normal{color:#4ade80}.stat-value.online .status-indicator{background:#4ade80;box-shadow:0 0 8px #4ade8099}.stat-value.online .status-indicator.pulse{animation:livePulse 1.5s infinite}.stat-value.online{color:#4ade80}.scene-controls-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:20px;background:#0a0e27d9;padding:8px 20px;border-radius:20px;border:1px solid rgba(74,222,128,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:50}.hint-item{display:flex;align-items:center;gap:6px}.hint-key{font-size:11px;color:#4ade80;background:#4ade8026;padding:3px 8px;border-radius:4px;font-weight:600}.hint-text{font-size:11px;color:#9ca3af}.decorative-lines{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:1}.corner-decor{position:absolute;width:40px;height:40px;border-color:#4ade804d;border-style:solid}.corner-decor.top-left{top:10px;left:10px;border-width:2px 0 0 2px}.corner-decor.top-right{top:10px;right:10px;border-width:2px 2px 0 0}.corner-decor.bottom-left{bottom:10px;left:10px;border-width:0 0 2px 2px}.corner-decor.bottom-right{bottom:10px;right:10px;border-width:0 2px 2px 0}.data-flow{position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,#4ade80,#22c55e,#4ade80,transparent);background-size:200% 100%;animation:dataFlow 4s linear infinite}@keyframes dataFlow{0%{background-position:-200% 0}to{background-position:200% 0}}.breathing{animation:breathing 3s ease-in-out infinite}@keyframes breathing{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}.neon-glow{text-shadow:0 0 5px #4ade80,0 0 10px #4ade80,0 0 20px #4ade80,0 0 40px #22c55e}.hover-lift{transition:all .3s ease}.hover-lift:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0006}.progress-animate{animation:progressFill 1s ease-out forwards}@keyframes progressFill{0%{width:0}}.number-scroll{animation:numberPulse .5s ease-out}@keyframes numberPulse{0%{transform:scale(1.1);color:#4ade80}to{transform:scale(1)}}.warning-flash{animation:warningFlash 1s infinite}@keyframes warningFlash{0%,to{opacity:1}50%{opacity:.5}}.loading-spinner{width:40px;height:40px;border:3px solid rgba(74,222,128,.2);border-top-color:#4ade80;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-enter{opacity:0;transform:translateY(10px)}.fade-enter-active{opacity:1;transform:translateY(0);transition:all .3s ease}.fade-exit{opacity:1;transform:translateY(0)}.fade-exit-active{opacity:0;transform:translateY(-10px);transition:all .3s ease}.glass-effect{background:#0a0e27cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(74,222,128,.2)}.hologram-effect{position:relative}.hologram-effect:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(74,222,128,.1) 50%,transparent 70%);background-size:200% 200%;animation:hologramShimmer 3s linear infinite;pointer-events:none}@keyframes hologramShimmer{0%{background-position:0% 0%}to{background-position:200% 200%}}.stats-panel{display:flex;flex-direction:column;gap:16px}.value.large{font-size:32px;color:#4ade80}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-grid-item{display:flex;align-items:center;gap:10px;padding:10px;background:#ffffff08;border-radius:6px}.stat-icon{width:36px;height:36px;border-radius:6px;display:flex;align-items:center;justify-content:center}.stat-icon.arrival{background:#4ade8033;color:#4ade80}.stat-icon.departure{background:#3b82f633;color:#60a5fa}.stat-info{display:flex;flex-direction:column;gap:2px}.stat-info .stat-value{font-size:16px;font-weight:700;color:#fff}.stat-info .stat-label{font-size:10px;color:#9ca3af}.status-card{padding:12px;background:#ffffff08;border-radius:6px}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.status-title{font-size:12px;color:#fff;font-weight:500}.status-count{display:flex;align-items:baseline;gap:4px;font-size:12px}.status-count .online{font-size:16px;font-weight:700;color:#4ade80}.status-count .separator{color:#6b7280}.status-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.status-fill{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:3px;transition:width .3s ease}.alerts-summary{display:flex;gap:12px}.alert-item{flex:1;padding:12px;background:#ffffff08;border-radius:6px;text-align:center}.alert-item.critical{border-left:3px solid #ef4444}.alert-item.warning{border-left:3px solid #f59e0b}.alert-count{font-size:24px;font-weight:700;margin-bottom:4px}.alert-item.critical .alert-count{color:#ef4444}.alert-item.warning .alert-count{color:#f59e0b}.alert-label{font-size:10px;color:#9ca3af}.area-list{display:flex;flex-direction:column;gap:10px}.area-item{padding:10px;background:#ffffff08;border-radius:6px}.area-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.area-name{font-size:12px;color:#fff;font-weight:500}.area-count{font-size:10px;color:#9ca3af}.area-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.area-fill{height:100%;border-radius:3px;transition:width .3s ease}.hourly-chart{display:flex;gap:8px;height:120px;align-items:flex-end}.hourly-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}.hourly-bar{width:100%;background:#4ade8033;border-radius:4px 4px 0 0;position:relative;min-height:20px;display:flex;align-items:flex-end}.hourly-bar:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,#4ade8099,#4ade8033);border-radius:4px 4px 0 0;transition:all .3s ease}.hourly-value{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:10px;color:#4ade80;font-weight:600;white-space:nowrap}.hourly-label{font-size:9px;color:#9ca3af;text-align:center}.video-panel{display:flex;flex-direction:column;gap:16px}.video-detail-view{margin-bottom:8px}.video-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.video-detail-header h3{margin:0}.close-detail-btn{background:none;border:none;color:#9ca3af;font-size:20px;cursor:pointer;line-height:1;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .3s ease}.close-detail-btn:hover{background:#ffffff1a;color:#fff}.video-player{border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.video-stream{aspect-ratio:16 / 9;background:linear-gradient(45deg,#1a1a2e,#16213e);position:relative;overflow:hidden}.stream-image{width:100%;height:100%;object-fit:cover;display:block}.stream-image:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.05) 2px,rgba(0,0,0,.05) 4px);pointer-events:none}.offline-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;pointer-events:none}.offline-text{font-size:14px;color:#9ca3af;font-weight:600}.location-tag{font-size:12px;color:#9ca3af;margin-bottom:8px}.live-badge{font-size:12px;color:#ef4444;font-weight:600;display:flex;align-items:center;gap:6px}.live-badge:before{content:"";width:8px;height:8px;background:#ef4444;border-radius:50%;animation:livePulse 1s infinite}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.video-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;padding:12px;display:flex;justify-content:space-between;align-items:flex-start}.time-overlay{font-size:10px;color:#ffffffb3;background:#00000080;padding:4px 8px;border-radius:4px;font-family:Courier New,monospace}.people-overlay{display:flex;align-items:center;gap:4px;font-size:10px;color:#ffffffb3;background:#00000080;padding:4px 8px;border-radius:4px}.video-controls{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#00000080;border-top:1px solid rgba(255,255,255,.1)}.control-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:6px;cursor:pointer;color:#fff;transition:all .3s ease}.control-btn:hover{background:#fff3}.control-info{display:flex;align-items:center;gap:12px}.status-badge{font-size:10px;padding:2px 8px;border-radius:4px;font-weight:600}.status-badge.online{background:#4ade8033;color:#4ade80}.status-badge.warning{background:#f59e0b33;color:#f59e0b}.status-badge.offline{background:#6b728033;color:#9ca3af}.density-info{font-size:10px;color:#9ca3af}.density{font-weight:600}.density.normal{color:#4ade80}.density.warning{color:#f59e0b}.camera-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.camera-stat-item{text-align:center;padding:10px;border-radius:6px}.camera-stat-item.online{background:#4ade801a;border:1px solid rgba(74,222,128,.3)}.camera-stat-item.warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3)}.camera-stat-item.offline{background:#6b72801a;border:1px solid rgba(107,114,128,.3)}.stat-number{font-size:20px;font-weight:700;margin-bottom:2px}.camera-stat-item.online .stat-number{color:#4ade80}.camera-stat-item.warning .stat-number{color:#f59e0b}.camera-stat-item.offline .stat-number{color:#9ca3af}.stat-label{font-size:10px;color:#9ca3af}.total-people-info{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff08;border-radius:6px;font-size:12px;color:#9ca3af}.total-people-info strong{color:#4ade80;font-size:14px}.camera-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.camera-item{display:flex;gap:10px;padding:10px;background:#ffffff08;border-radius:6px;cursor:pointer;transition:all .3s ease;border:1px solid transparent}.camera-item:hover{background:#ffffff14;border-color:#4ade804d}.camera-item.selected{background:#4ade801a;border-color:#4ade80}.camera-preview{width:80px;height:60px;border-radius:4px;overflow:hidden;position:relative;background:linear-gradient(45deg,#1a1a2e,#16213e)}.preview-status{position:absolute;top:4px;left:4px;z-index:1}.preview-status .status-dot{width:8px;height:8px;border-radius:50%}.preview-status.online .status-dot{background:#4ade80;box-shadow:0 0 6px #4ade8080}.preview-status.warning .status-dot{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.preview-status.offline .status-dot{background:#6b7280}.preview-content{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:flex-end;justify-content:center;padding:4px}.preview-name{font-size:8px;color:#ffffffb3;background:#00000080;padding:2px 6px;border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.preview-image{width:100%;height:100%;object-fit:cover;display:block}.preview-offline-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;pointer-events:none}.preview-offline-text{font-size:10px;color:#9ca3af;font-weight:600}.camera-info{flex:1;display:flex;flex-direction:column;gap:4px}.camera-location{display:flex;align-items:center;gap:4px;font-size:11px;color:#fff;font-weight:500}.camera-details{display:flex;align-items:center;gap:8px}.status-indicator{font-size:10px;padding:2px 6px;border-radius:3px;font-weight:600}.status-indicator.online{background:#4ade8033;color:#4ade80}.status-indicator.warning{background:#f59e0b33;color:#f59e0b}.status-indicator.offline{background:#6b728033;color:#9ca3af}.people-count{display:flex;align-items:center;gap:4px;font-size:10px;color:#9ca3af}.warning-alert{display:flex;align-items:center;gap:4px;font-size:10px;color:#f59e0b;background:#f59e0b1a;padding:2px 6px;border-radius:3px;align-self:flex-start}.tips-list{display:flex;flex-direction:column;gap:8px}.tip-item{display:flex;align-items:flex-start;gap:8px}.tip-icon{width:18px;height:18px;border-radius:50%;background:#4ade8033;color:#4ade80;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tip-text{font-size:11px;color:#9ca3af;line-height:1.5}.alert-panel{display:flex;flex-direction:column;gap:16px}.alert-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.alert-stat-item{display:flex;align-items:center;gap:8px;padding:10px;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.alert-stat-item.critical{background:#ef44441a;border-color:#ef44444d}.alert-stat-item.warning{background:#f59e0b1a;border-color:#f59e0b4d}.alert-stat-item.active{background:#4ade801a;border-color:#4ade804d}.alert-stat-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center}.alert-stat-item.critical .alert-stat-icon{background:#ef444433;color:#ef4444}.alert-stat-item.warning .alert-stat-icon{background:#f59e0b33;color:#f59e0b}.alert-stat-item.active .alert-stat-icon{background:#4ade8033;color:#4ade80}.alert-stat-info{display:flex;flex-direction:column;gap:2px}.alert-stat-number{font-size:18px;font-weight:700}.alert-stat-item.critical .alert-stat-number{color:#ef4444}.alert-stat-item.warning .alert-stat-number{color:#f59e0b}.alert-stat-item.active .alert-stat-number{color:#4ade80}.alert-stat-label{font-size:10px;color:#9ca3af}.filter-tabs{display:flex;gap:6px;flex-wrap:wrap}.filter-tab{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:6px 10px;cursor:pointer;font-size:11px;color:#9ca3af;transition:all .3s ease;display:flex;align-items:center;gap:4px}.filter-tab:hover{background:#ffffff1a;color:#fff}.filter-tab.active{background:#4ade8033;border-color:#4ade8080;color:#4ade80}.tab-count{background:#ffffff1a;padding:1px 6px;border-radius:8px;font-size:10px}.filter-tab.active .tab-count{background:#4ade8033}.alerts-list{display:flex;flex-direction:column;gap:10px;max-height:500px;overflow-y:auto}.no-alerts{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.no-alerts-icon{color:#4ade80;margin-bottom:12px;opacity:.5}.no-alerts-text{font-size:14px;color:#9ca3af}.alert-card{background:#ffffff08;border-radius:8px;padding:12px;cursor:pointer;transition:all .3s ease;border:1px solid transparent}.alert-card:hover{background:#ffffff14}.alert-card.selected{border-color:#fff3}.alert-card.critical{border-left:3px solid #ef4444}.alert-card.warning{border-left:3px solid #f59e0b}.alert-card.info{border-left:3px solid #60a5fa}.alert-card.resolved{opacity:.6}.alert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.alert-type-badge{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}.alert-card.critical .alert-type-badge{background:#ef444433;color:#ef4444}.alert-card.warning .alert-type-badge{background:#f59e0b33;color:#f59e0b}.alert-card.info .alert-type-badge{background:#60a5fa33;color:#60a5fa}.alert-status-badge{display:flex;align-items:center;gap:4px;font-size:10px;color:#9ca3af}.pulse-dot{width:6px;height:6px;background:#ef4444;border-radius:50%;animation:pulse-red 1.5s infinite}@keyframes pulse-red{0%,to{opacity:1;box-shadow:0 0 4px #ef444480}50%{opacity:.5;box-shadow:0 0 8px #ef4444cc}}.alert-title{font-size:13px;font-weight:600;color:#fff;margin-bottom:4px}.alert-description{font-size:11px;color:#9ca3af;margin-bottom:8px;line-height:1.4}.alert-details{display:flex;gap:12px;margin-bottom:8px}.detail-item{display:flex;align-items:center;gap:4px;font-size:10px;color:#9ca3af}.density-bar-container{margin-bottom:8px}.density-label{display:flex;justify-content:space-between;font-size:10px;color:#9ca3af;margin-bottom:4px}.density-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.density-fill{height:100%;border-radius:3px;transition:all .3s ease}.density-fill.normal{background:linear-gradient(90deg,#4ade80,#22c55e)}.density-fill.warning{background:linear-gradient(90deg,#f59e0b,#d97706)}.density-fill.critical{background:linear-gradient(90deg,#ef4444,#dc2626)}.alert-actions{display:flex;gap:6px;padding-top:8px;border-top:1px solid rgba(255,255,255,.05)}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 10px;border-radius:4px;font-size:11px;cursor:pointer;transition:all .3s ease;border:none}.action-btn.acknowledge{background:#4ade8033;color:#4ade80}.action-btn.acknowledge:hover{background:#4ade804d}.action-btn.sound{background:#60a5fa33;color:#60a5fa}.action-btn.sound:hover{background:#60a5fa4d}.action-btn.dismiss{background:#6b728033;color:#9ca3af}.action-btn.dismiss:hover{background:#6b72804d}.action-btn.resolve{background:#4ade8033;color:#4ade80}.action-btn.resolve:hover{background:#4ade804d}.safety-tips{display:flex;flex-direction:column;gap:8px}.safety-tip{display:flex;align-items:center;gap:10px;padding:8px;background:#ffffff08;border-radius:6px}.tip-icon{width:12px;height:12px;border-radius:50%}.tip-icon.normal{background:#4ade80;box-shadow:0 0 6px #4ade8080}.tip-icon.warning{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.tip-icon.critical{background:#ef4444;box-shadow:0 0 6px #ef444480}.tip-content{display:flex;flex-direction:column;gap:2px}.tip-title{font-size:11px;font-weight:600;color:#fff}.tip-desc{font-size:10px;color:#9ca3af}.app{width:100vw;height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#0a0e27,#0d1b2a,#1a1f3a,#0d1b2a,#0a0e27);position:relative;overflow:hidden}.app:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(74,222,128,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(74,222,128,.02) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}.app:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;height:80%;background:radial-gradient(circle,rgba(74,222,128,.08) 0%,rgba(96,165,250,.05) 30%,transparent 70%);pointer-events:none;z-index:0}.main-content{flex:1;display:flex;overflow:hidden;position:relative;z-index:1}.content-area{flex:1;display:flex;overflow:hidden}.three-scene-container{flex:1;position:relative;overflow:hidden;border-radius:8px;margin:8px;box-shadow:inset 0 0 30px #4ade800d,0 0 40px #0000004d}.three-scene-container:before,.three-scene-container:after{content:"";position:absolute;width:30px;height:30px;border-color:#4ade8066;border-style:solid;z-index:10;pointer-events:none}.three-scene-container:before{top:0;left:0;border-width:2px 0 0 2px;border-radius:8px 0 0}.three-scene-container:after{top:0;right:0;border-width:2px 2px 0 0;border-radius:0 8px 0 0}.right-panels{width:340px;background:linear-gradient(180deg,#0a0e27f2,#0d1b2afa);border-left:1px solid rgba(74,222,128,.15);overflow-y:auto;padding:12px 12px 12px 8px;position:relative}.right-panels:before{content:"";position:absolute;top:0;left:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent 0%,rgba(74,222,128,.5) 20%,rgba(74,222,128,.5) 80%,transparent 100%)}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.slide-in-left{animation:slideInLeft .4s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.scale-in{animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.glass-panel{background:linear-gradient(135deg,#0a0e27e6,#0d1b2af2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(74,222,128,.2);border-radius:8px;padding:16px;margin-bottom:12px;position:relative;overflow:hidden;transition:all .3s ease}.glass-panel:hover{border-color:#4ade8066;box-shadow:0 4px 24px #0000004d,0 0 40px #4ade801a}.glass-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(74,222,128,.6) 30%,rgba(96,165,250,.6) 70%,transparent 100%)}.glass-panel:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(74,222,128,.3) 50%,transparent 100%)}.glass-panel h3{font-size:14px;font-weight:700;margin-bottom:14px;color:#4ade80;display:flex;align-items:center;gap:10px;letter-spacing:.5px;position:relative;padding-left:12px}.glass-panel h3:before{content:"";position:absolute;left:0;top:2px;bottom:2px;width:3px;background:linear-gradient(180deg,#4ade80,#22c55e,#4ade80);border-radius:2px;box-shadow:0 0 8px #4ade8080}.glass-panel h3 svg{filter:drop-shadow(0 0 4px rgba(74,222,128,.5))}.data-card{background:linear-gradient(135deg,#ffffff0a,#ffffff05);border-radius:8px;padding:14px 16px;margin-bottom:12px;transition:all .3s ease;border:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}.data-card:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:linear-gradient(180deg,#4ade80,transparent);opacity:.6}.data-card:hover{background:linear-gradient(135deg,#4ade8014,#ffffff0a);border-color:#4ade8033;transform:translateY(-3px);box-shadow:0 8px 24px #0000004d,0 0 40px #4ade801a}.data-card .label{font-size:12px;color:#9ca3af;margin-bottom:6px;letter-spacing:.3px}.data-card .value{font-size:24px;font-weight:800;color:#fff;text-shadow:0 0 10px rgba(74,222,128,.3)}.data-card .value.highlight{color:#4ade80;text-shadow:0 0 15px rgba(74,222,128,.5)}.data-card .trend{font-size:11px;margin-top:6px;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px}.data-card .trend.up{color:#ef4444;background:#ef44441a}.data-card .trend.down{color:#22c55e;background:#22c55e1a}.number-animate{animation:numberPulse .6s ease-out}@keyframes numberPulse{0%{transform:scale(1.1);color:#4ade80}50%{transform:scale(1.05)}to{transform:scale(1)}}.blink{animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.glow-pulse{animation:glowPulse 2s ease-in-out infinite}@keyframes glowPulse{0%,to{box-shadow:0 0 10px #4ade804d}50%{box-shadow:0 0 25px #4ade8099}}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(74,222,128,.15),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.status-indicator-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-indicator-dot.online{background:#4ade80;box-shadow:0 0 8px #4ade8099;animation:pulse 2s infinite}.status-indicator-dot.warning{background:#f59e0b;box-shadow:0 0 8px #f59e0b99;animation:pulse 1.5s infinite}.status-indicator-dot.offline{background:#6b7280}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.9)}}.loading-dots span{animation:loadingDots 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes loadingDots{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}::-webkit-scrollbar-track{background:#ffffff08;border-radius:3px}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#4ade8066,#60a5fa66);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#4ade8099,#60a5fa99)}.highlight-on-select{transition:all .3s ease}.highlight-on-select.selected{border-color:#4ade8099;box-shadow:0 0 20px #4ade804d,inset 0 0 20px #4ade800d}.tooltip{position:absolute;background:#0a0e27f2;border:1px solid rgba(74,222,128,.3);padding:8px 12px;border-radius:4px;font-size:11px;color:#fff;z-index:1000;pointer-events:none;box-shadow:0 4px 16px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tooltip:before{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(74,222,128,.3)}.data-stream{position:relative;overflow:hidden}.data-stream:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:2px;background:linear-gradient(90deg,transparent,#4ade80,#22c55e,#4ade80,transparent);animation:dataStream 3s linear infinite}@keyframes dataStream{0%{left:-100%}to{left:100%}}.count-up{animation:countUp 1s ease-out}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#0a0e27;color:#fff;overflow:hidden}#root{width:100vw;height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}
