:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--bg-hover: #30363d;--border-color: #30363d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681;--accent-blue: #58a6ff;--accent-green: #3fb950;--accent-yellow: #d29922;--accent-red: #f85149;--accent-purple: #a371f7}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-size:14px}.app-layout{display:flex;min-height:100vh}.sidebar{width:56px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-nav{display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px}.sidebar-item{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--text-secondary);text-decoration:none;font-size:1.2rem;transition:all .15s}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-item.active{background:var(--accent-blue);color:#fff}.sidebar-spacer{flex:1}.main-content{flex:1;margin-left:56px;display:flex;flex-direction:column}.top-bar{height:48px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 16px;gap:16px;position:sticky;top:0;z-index:50}.top-bar h1{font-size:1rem;font-weight:600;color:var(--text-primary)}.top-bar-spacer{flex:1}.top-bar-actions{display:flex;align-items:center;gap:8px}.btn{padding:6px 12px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s;display:inline-flex;align-items:center;gap:6px;text-decoration:none}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{background:#4c9aed}.btn-secondary{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-hover)}.btn-success{background:var(--accent-green);color:#fff}.btn-success:hover{background:#2ea043}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{background:#da3633}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}input,select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:6px 10px;color:var(--text-primary);font-size:.85rem}input:focus,select:focus{outline:none;border-color:var(--accent-blue)}.loading,.error,.empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary)}.error{color:var(--accent-red)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.login-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:32px;width:100%;max-width:360px}.login-card h1{font-size:1.25rem;text-align:center;margin-bottom:24px}.login-card form{display:flex;flex-direction:column;gap:12px}.login-card input{padding:10px 12px}.login-card button{padding:10px;margin-top:8px}.login-card .error{min-height:auto;font-size:.85rem;justify-content:flex-start}.live-page{display:flex;flex-direction:column;height:calc(100vh - 48px)}.camera-groups{display:flex;gap:8px;padding:0 16px}.camera-group-btn{padding:4px 12px;border-radius:16px;font-size:.8rem;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer}.camera-group-btn.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.live-grid{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px;background:#000}.camera-cell{position:relative;background:var(--bg-primary);border-radius:4px;overflow:hidden;cursor:pointer;aspect-ratio:16/9}.camera-cell:hover{outline:2px solid var(--accent-blue)}.camera-cell video{width:100%;height:100%;object-fit:cover}.camera-cell .overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,transparent 30%,transparent 70%,rgba(0,0,0,.6) 100%);pointer-events:none}.camera-cell .cam-name{position:absolute;top:6px;left:8px;font-size:.75rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);z-index:2}.camera-cell .cam-status{position:absolute;top:6px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--accent-green);z-index:2}.camera-cell .cam-status.offline{background:var(--accent-red)}.camera-cell .cam-status.motion{background:var(--accent-yellow);animation:pulse 1s infinite}.camera-cell .cam-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem}.camera-view{display:grid;grid-template-columns:1fr 320px;height:calc(100vh - 48px)}.camera-main{background:#000;display:flex;align-items:center;justify-content:center;position:relative}.camera-main video{max-width:100%;max-height:100%}.camera-sidebar{background:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.camera-sidebar-header{padding:12px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px}.camera-sidebar-header h2{font-size:.95rem;font-weight:600}.camera-sidebar-content{flex:1;overflow-y:auto;padding:12px}.timeline-section{padding:12px 0}.timeline-section h3{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 4px}.timeline-events{display:flex;flex-direction:column;gap:6px}.timeline-event{display:flex;gap:10px;padding:8px;background:var(--bg-tertiary);border-radius:6px;cursor:pointer;transition:background .15s}.timeline-event:hover{background:var(--bg-hover)}.timeline-event img{width:64px;height:40px;object-fit:cover;border-radius:4px}.timeline-event-info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2px}.timeline-event-time{font-size:.8rem;font-weight:500}.timeline-event-meta{font-size:.7rem;color:var(--text-muted)}.timeline-event .status-dot{width:6px;height:6px;border-radius:50%;margin-top:6px}.status-dot.pending{background:var(--accent-yellow)}.status-dot.confirmed{background:var(--accent-green)}.status-dot.false_positive{background:var(--accent-red)}.review-page{display:flex;height:calc(100vh - 48px)}.review-timeline{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column}.review-timeline-header{padding:12px 16px;border-bottom:1px solid var(--border-color)}.review-timeline-header h2{font-size:.9rem;font-weight:600;margin-bottom:8px}.review-filters{display:flex;gap:8px}.review-filters select,.review-filters input{flex:1;font-size:.8rem;padding:4px 8px}.review-timeline-list{flex:1;overflow-y:auto;padding:8px}.review-item{display:flex;gap:10px;padding:10px;border-radius:6px;cursor:pointer;margin-bottom:4px;transition:background .15s}.review-item:hover{background:var(--bg-tertiary)}.review-item.active{background:var(--bg-hover);border:1px solid var(--accent-blue)}.review-item-thumb{width:80px;height:50px;object-fit:cover;border-radius:4px;background:var(--bg-tertiary)}.review-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.review-item-camera{font-size:.8rem;font-weight:600}.review-item-time{font-size:.75rem;color:var(--text-secondary)}.review-item-status{font-size:.65rem;padding:2px 6px;border-radius:3px;width:fit-content;text-transform:uppercase;font-weight:600}.review-item-status.pending{background:var(--accent-yellow);color:#000}.review-item-status.confirmed{background:var(--accent-green);color:#fff}.review-item-status.false_positive{background:var(--accent-red);color:#fff}.review-main{flex:1;display:flex;flex-direction:column;background:var(--bg-primary)}.review-media{flex:1;display:flex;flex-direction:column;padding:16px;gap:16px;overflow-y:auto}.review-images{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.review-image{position:relative;border-radius:6px;overflow:hidden;background:var(--bg-secondary)}.review-image img{width:100%;display:block}.review-image-label{position:absolute;top:6px;left:6px;background:#000000b3;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:500}.review-video{background:var(--bg-secondary);border-radius:8px;overflow:hidden}.review-video-tabs{display:flex;gap:4px;padding:8px;background:var(--bg-tertiary)}.review-video-tabs button{padding:4px 12px;border-radius:4px;font-size:.8rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.review-video-tabs button.active{background:var(--accent-blue);color:#fff}.review-video video{width:100%;display:block}.review-actions{padding:16px;background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;gap:8px}.review-actions .btn{flex:1;justify-content:center;padding:10px}.review-details{width:300px;background:var(--bg-secondary);border-left:1px solid var(--border-color);padding:16px;overflow-y:auto}.review-details h3{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px}.detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color);font-size:.85rem}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-secondary)}.detail-value{font-weight:500}.detection-list{margin-top:16px}.detection-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.85rem}.confidence-bar{flex:1;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.confidence-bar .fill{height:100%;background:var(--accent-green);border-radius:2px}.dashboard-page{padding:20px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dashboard-header h1{font-size:1.25rem}.dashboard-filters{display:flex;gap:12px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px}.stat-value{font-size:2rem;font-weight:700;margin-bottom:4px}.stat-label{font-size:.8rem;color:var(--text-secondary)}.stat-card.pending .stat-value{color:var(--accent-yellow)}.stat-card.confirmed .stat-value{color:var(--accent-green)}.stat-card.false-positive .stat-value{color:var(--accent-red)}.section{margin-bottom:24px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-header h2{font-size:.95rem;font-weight:600}.camera-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.camera-stat{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:12px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .15s}.camera-stat:hover{border-color:var(--accent-blue)}.camera-stat.selected{background:var(--accent-blue);border-color:var(--accent-blue)}.camera-stat-name{font-size:.85rem}.camera-stat-count{font-weight:600;color:var(--accent-blue)}.camera-stat.selected .camera-stat-count{color:#fff}.quick-actions{display:flex;gap:12px}.settings-page{padding:20px;max-width:600px}.settings-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:16px}.settings-section h2{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-color)}.setting-row:last-child{border-bottom:none}.setting-label{color:var(--text-secondary);font-size:.9rem}.setting-value{font-weight:500;font-size:.9rem}.setting-value.small{font-size:.75rem;max-width:250px;text-align:right;word-break:break-all}.camera-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.camera-chip{background:var(--bg-tertiary);padding:4px 10px;border-radius:12px;font-size:.75rem}.history-page{display:flex;flex-direction:column;height:calc(100vh - 48px)}.history-filters{padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;gap:12px;align-items:center}.history-filters .spacer{flex:1}.history-count{font-size:.85rem;color:var(--text-secondary)}.history-grid{flex:1;overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;align-content:start}.history-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s}.history-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.history-card img{width:100%;height:140px;object-fit:cover;background:var(--bg-tertiary)}.history-card-info{padding:10px}.history-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.history-card-camera{font-weight:600;font-size:.85rem}.history-card-status{font-size:.65rem;padding:2px 6px;border-radius:3px;text-transform:uppercase;font-weight:600}.history-card-status.pending{background:var(--accent-yellow);color:#000}.history-card-status.confirmed{background:var(--accent-green);color:#fff}.history-card-status.false_positive{background:var(--accent-red);color:#fff}.history-card-time{font-size:.8rem;color:var(--text-secondary)}.history-card-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.load-more{padding:16px;display:flex;justify-content:center}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:12px;right:12px;background:var(--bg-tertiary);border:none;color:var(--text-primary);width:32px;height:32px;border-radius:6px;font-size:1.2rem;cursor:pointer;z-index:10}.modal-close:hover{background:var(--bg-hover)}.modal-images{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:16px}.modal-image{position:relative}.modal-image img{width:100%;border-radius:6px}.modal-image span{position:absolute;top:6px;left:6px;background:#000000b3;padding:2px 8px;border-radius:4px;font-size:.7rem}.modal-video{padding:0 16px 16px}.modal-video video{width:100%;border-radius:8px}.modal-details{padding:0 16px 16px;display:grid;grid-template-columns:repeat(2,1fr);gap:8px;font-size:.85rem}.modal-details p{color:var(--text-secondary)}.modal-details strong{color:var(--text-muted)}@media(max-width:1200px){.live-grid{grid-template-columns:repeat(3,1fr)}.camera-view{grid-template-columns:1fr}.camera-sidebar{display:none}.review-page{flex-direction:column}.review-timeline{width:100%;height:200px}.review-details{display:none}}@media(max-width:900px){.live-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}.review-images,.modal-images{grid-template-columns:1fr}}@media(max-width:600px){.live-grid{grid-template-columns:1fr}.sidebar{display:none}.main-content{margin-left:0}}.stream-toggle{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:6px;padding:2px}.stream-btn{padding:4px 12px;border:none;background:transparent;color:var(--text-secondary);font-size:.8rem;border-radius:4px;cursor:pointer;transition:all .15s}.stream-btn:hover{color:var(--text-primary)}.stream-btn.active{background:var(--accent-blue);color:#fff}.status-indicator{width:10px;height:10px;border-radius:50%;background:var(--accent-yellow)}.status-indicator.live{background:var(--accent-green)}.status-indicator.error{background:var(--accent-red)}.status-indicator.loading{background:var(--accent-yellow);animation:pulse 1s infinite}.playback-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 70%,transparent 100%);padding:60px 16px 16px}.playback-controls-row{display:flex;align-items:center;gap:16px;margin-bottom:12px}.btn-live{background:var(--accent-red);color:#fff;font-weight:600;font-size:.75rem;padding:6px 12px}.btn-live.active{animation:pulse-live 2s infinite}@keyframes pulse-live{0%,to{box-shadow:0 0 #f8514966}50%{box-shadow:0 0 0 8px #f8514900}}.speed-controls,.range-controls{display:flex;align-items:center;gap:4px}.control-label{font-size:.75rem;color:var(--text-muted);margin-right:4px}.speed-btn,.range-btn{padding:4px 8px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);font-size:.75rem;border-radius:4px;cursor:pointer;transition:all .15s}.speed-btn:hover,.range-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.speed-btn.active,.range-btn.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.timeline-bar{position:relative;height:40px;cursor:pointer}.timeline-track{position:absolute;top:20px;left:0;right:0;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:visible}.timeline-markers{position:absolute;top:-18px;left:0;right:0;height:16px}.timeline-marker{position:absolute;font-size:.65rem;color:var(--text-muted);transform:translate(-50%)}.timeline-position{position:absolute;top:-4px;width:4px;height:16px;background:var(--accent-blue);border-radius:2px;transform:translate(-50%);box-shadow:0 0 8px var(--accent-blue)}.timeline-detection{position:absolute;top:0;width:6px;height:8px;background:var(--accent-yellow);border-radius:2px;transform:translate(-50%);opacity:.8}.timeline-detection:hover{opacity:1;transform:translate(-50%) scaleY(1.5)}.timeline-tooltip{position:absolute;bottom:100%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);padding:4px 8px;border-radius:4px;font-size:.75rem;white-space:nowrap;pointer-events:none;margin-bottom:8px}.status-indicator.playing{background:var(--accent-blue)}.camera-main{flex-direction:column}.camera-main video{flex:1;max-height:calc(100% - 100px)}.clip-controls{display:flex;align-items:center;gap:4px;margin-left:auto}.clip-controls .btn{min-width:32px;padding:4px 8px;font-size:.8rem}.clip-status{font-size:.75rem;padding:4px 0;color:var(--accent-blue)}.clip-status.error{color:var(--accent-red)}.timeline-clip-range{position:absolute;top:0;height:8px;background:#58a6ff4d;border-radius:4px}.timeline-clip-marker{position:absolute;top:-4px;width:3px;height:16px;background:var(--accent-green);border-radius:2px;transform:translate(-50%)}.timeline-clip-marker.start{background:var(--accent-green)}.timeline-clip-marker.end{background:var(--accent-red)}.detection-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.detection-overlay-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:1200px;max-height:90vh;width:100%;overflow:auto;position:relative}.detection-overlay-close{position:absolute;top:12px;right:12px;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);width:32px;height:32px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}.detection-overlay-close:hover{background:var(--bg-hover)}.detection-overlay-header{padding:16px 20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px}.detection-overlay-header h2{font-size:1.1rem;font-weight:500}.status-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-badge.pending{background:var(--accent-yellow);color:#000}.status-badge.confirmed{background:var(--accent-green);color:#000}.status-badge.false_positive{background:var(--accent-red);color:#fff}.detection-overlay-body{display:flex;gap:20px;padding:20px}.detection-overlay-media{flex:1;min-width:0}.detection-overlay-images{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.detection-overlay-image{position:relative;border-radius:8px;overflow:hidden;background:var(--bg-tertiary)}.detection-overlay-image img{width:100%;height:auto;display:block}.detection-overlay-image .image-label{position:absolute;top:8px;left:8px;background:#000000b3;padding:2px 8px;border-radius:4px;font-size:.7rem;color:var(--text-secondary)}.detection-overlay-video{background:var(--bg-tertiary);border-radius:8px;overflow:hidden}.detection-overlay-video .video-tabs{display:flex;border-bottom:1px solid var(--border-color)}.detection-overlay-video .video-tabs button{flex:1;padding:10px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:.85rem}.detection-overlay-video .video-tabs button.active{color:var(--accent-blue);background:var(--bg-secondary)}.detection-overlay-video video{width:100%;display:block}.detection-overlay-details{width:280px;flex-shrink:0}.detection-overlay-details .detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color)}.detection-overlay-details .detail-label{color:var(--text-secondary);font-size:.85rem}.detection-overlay-details .detail-value{color:var(--text-primary);font-size:.85rem;font-weight:500}.detection-overlay-details .detection-list{margin-top:16px}.detection-overlay-details .detection-list h4{font-size:.85rem;color:var(--text-secondary);margin-bottom:12px}.detection-overlay-details .detection-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.8rem}.detection-overlay-details .confidence-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.detection-overlay-details .confidence-bar .fill{height:100%;background:var(--accent-green);border-radius:3px}.detection-overlay-actions{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end}.image-lightbox{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1100;cursor:zoom-out}.image-lightbox img{max-width:95vw;max-height:95vh;object-fit:contain;cursor:default}.detection-overlay-image{cursor:zoom-in}.detection-overlay-image:hover{opacity:.9}.go2rtc-section{margin-bottom:24px}.go2rtc-section .section-header{display:flex;align-items:center;gap:12px}.go2rtc-section .live-indicator{color:var(--accent-red);font-size:.8rem;font-weight:500;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.go2rtc-streams{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:16px;margin-top:12px}.go2rtc-stream{position:relative;background:var(--bg-tertiary);border-radius:8px;overflow:hidden;aspect-ratio:16 / 9}.go2rtc-stream iframe{width:100%;height:100%;border:none}.go2rtc-stream-label{position:absolute;bottom:8px;left:8px;background:#000000b3;padding:4px 10px;border-radius:4px;font-size:.8rem;color:var(--text-primary)}.camera-view.no-sidebar{grid-template-columns:1fr}.camera-view.no-sidebar .camera-main{max-width:1200px;margin:0 auto}.dashboard-stream-section{margin-bottom:24px}.dashboard-stream-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dashboard-stream-header h2{font-size:1.1rem;font-weight:500}.live-badge{font-size:.8rem;font-weight:500;padding:4px 10px;border-radius:4px;background:var(--bg-tertiary)}.live-badge.live{color:var(--accent-red);animation:pulse 2s infinite}.live-badge.loading{color:var(--text-muted)}.live-badge.error{color:var(--accent-yellow)}.dashboard-stream{position:relative;background:var(--bg-tertiary);border-radius:8px;overflow:hidden;cursor:pointer;max-width:800px}.dashboard-stream:hover{outline:2px solid var(--accent-blue)}.dashboard-stream video{width:100%;display:block}.dashboard-stream .stream-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-muted);font-size:.9rem}.archive-page{padding:20px;height:calc(100vh - 48px);display:flex;flex-direction:column}.archive-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.archive-filters{display:flex;gap:12px}.archive-count{font-size:.85rem;color:var(--text-secondary)}.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;flex:1;overflow-y:auto;align-content:start}.archive-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s;position:relative}.archive-card:hover{border-color:var(--accent-blue)}.archive-card.selected{border-color:var(--accent-blue);box-shadow:0 0 0 2px #58a6ff4d}.archive-thumb{width:100%;height:140px;object-fit:cover;background:var(--bg-tertiary)}.archive-card-info{padding:10px}.archive-card-camera{font-weight:600;font-size:.85rem;margin-bottom:2px}.archive-card-time{font-size:.8rem;color:var(--text-secondary)}.archive-card-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.archive-card-archived{font-size:.7rem;color:var(--accent-purple);margin-top:4px}.archive-delete{position:absolute;top:8px;right:8px;width:24px;height:24px;padding:0;font-size:14px;border-radius:50%}.btn-sm{padding:4px 8px;font-size:.75rem}.archive-modal{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.archive-modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;padding:20px}.archive-modal-close{position:absolute;top:12px;right:12px;background:var(--bg-tertiary);border:none;color:var(--text-primary);width:32px;height:32px;border-radius:6px;font-size:1.2rem;cursor:pointer}.archive-modal-close:hover{background:var(--bg-hover)}.archive-modal-content h2{font-size:1.1rem;margin-bottom:16px;padding-right:40px}.archive-modal-images{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.archive-modal-images a{position:relative;display:block;border-radius:8px;overflow:hidden}.archive-modal-images img{width:100%;display:block}.archive-modal-images span{position:absolute;bottom:6px;left:6px;background:#000000b3;padding:2px 8px;border-radius:4px;font-size:.7rem}.archive-modal-video{margin-bottom:16px}.archive-modal-video video{width:100%;border-radius:8px}.archive-modal-details{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;font-size:.85rem;margin-bottom:16px;padding:12px;background:var(--bg-tertiary);border-radius:8px}.archive-modal-details div{color:var(--text-secondary)}.archive-modal-details strong{color:var(--text-muted)}.archive-modal-actions{display:flex;justify-content:flex-end;gap:12px}.history-card{position:relative}.history-card-archive{position:absolute;top:8px;right:8px;width:28px;height:28px;padding:0;background:#000000b3;border:none;border-radius:6px;color:var(--text-primary);font-size:14px;cursor:pointer;opacity:0;transition:opacity .15s;z-index:5}.history-card:hover .history-card-archive{opacity:1}.history-card-archive:hover{background:var(--accent-purple)}.history-card-archive:disabled{opacity:.5;cursor:not-allowed}.bulk-delete-result{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-bottom:12px;border-radius:6px;font-size:.85rem}.bulk-delete-result.success{background:#3fb95026;border:1px solid var(--accent-green);color:var(--accent-green)}.bulk-delete-result.error{background:#f8514926;border:1px solid var(--accent-red);color:var(--accent-red)}.bulk-delete-result button{background:none;border:none;color:inherit;font-size:1.2rem;cursor:pointer;padding:0 4px}.empty-state{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:.9rem}.archive-no-video{padding:20px;text-align:center;color:var(--text-muted);background:var(--bg-tertiary);border-radius:8px;font-size:.85rem}.camera-labels-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.camera-labels-column h4{font-size:.85rem;color:var(--text-secondary);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.camera-label-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.camera-label-id{font-size:.8rem;color:var(--text-muted);width:70px;flex-shrink:0}.camera-label-input{flex:1;padding:6px 10px;font-size:.85rem}.settings-message{padding:10px 12px;border-radius:6px;font-size:.85rem;margin-top:12px}.settings-message.success{background:#3fb95026;border:1px solid var(--accent-green);color:var(--accent-green)}.settings-message.error{background:#f8514926;border:1px solid var(--accent-red);color:var(--accent-red)}@media(max-width:600px){.camera-labels-grid{grid-template-columns:1fr}}.notification-toast-container{position:fixed;top:60px;right:16px;z-index:1000;display:flex;flex-direction:column;gap:8px;max-width:360px}.notification-toast{display:flex;align-items:center;gap:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid var(--accent-yellow);border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #0000004d;animation:slideIn .3s ease-out}.notification-toast.exiting{animation:slideOut .3s ease-in forwards}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast-icon{font-size:1.5rem}.toast-content{flex:1}.toast-title{font-weight:600;font-size:.9rem;margin-bottom:2px}.toast-camera{font-size:.85rem;color:var(--text-secondary)}.toast-time{font-size:.75rem;color:var(--text-muted)}.toast-actions{display:flex;align-items:center;gap:8px}.toast-view-btn{background:var(--accent-blue);color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:.8rem;cursor:pointer;font-weight:500}.toast-view-btn:hover{background:#4c9aed}.toast-dismiss-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:4px;line-height:1}.toast-dismiss-btn:hover{color:var(--text-primary)}.notification-bell{position:relative}.bell-button{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:8px;border-radius:6px;position:relative;transition:background .15s}.bell-button:hover{background:var(--bg-hover)}.bell-button.has-notifications{animation:bellShake .5s ease-in-out}@keyframes bellShake{0%,to{transform:rotate(0)}25%{transform:rotate(10deg)}50%{transform:rotate(-10deg)}75%{transform:rotate(5deg)}}.notification-badge{position:absolute;top:2px;right:2px;background:var(--accent-red);color:#fff;font-size:.65rem;font-weight:600;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.notification-dropdown{position:absolute;top:100%;right:0;width:320px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0006;margin-top:8px;overflow:hidden;z-index:100}.dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:.9rem}.clear-all-btn{background:transparent;border:none;color:var(--accent-blue);font-size:.8rem;cursor:pointer}.clear-all-btn:hover{text-decoration:underline}.dropdown-content{max-height:320px;overflow-y:auto}.no-notifications{padding:24px;text-align:center;color:var(--text-muted);font-size:.85rem}.notification-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-color)}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--bg-hover)}.notification-icon{font-size:1.2rem}.notification-details{flex:1}.notification-camera{font-weight:500;font-size:.85rem;margin-bottom:2px}.notification-time{font-size:.75rem;color:var(--text-muted)}.notification-dismiss{background:transparent;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:4px;opacity:0;transition:opacity .15s}.notification-item:hover .notification-dismiss{opacity:1}.notification-dismiss:hover{color:var(--text-primary)}.dropdown-footer{padding:12px 16px;border-top:1px solid var(--border-color);text-align:center}.dropdown-footer button{background:transparent;border:none;color:var(--accent-blue);font-size:.85rem;cursor:pointer}.dropdown-footer button:hover{text-decoration:underline}.connection-dot{position:absolute;bottom:4px;right:4px;width:8px;height:8px;border-radius:50%;border:1px solid var(--bg-secondary)}.connection-dot.connected{background:var(--accent-green)}.connection-dot.disconnected{background:var(--text-muted)}.connection-status{font-size:.7rem;margin-left:8px;font-weight:400}.connection-status.connected{color:var(--accent-green)}.connection-status.disconnected{color:var(--text-muted)}
