@import "https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500;600&family=Manrope:wght@600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--bg-base:#07090e;--bg-surface:#0d1117;--bg-surface-raised:#131921;--bg-surface-overlay:#1a2233;--bg-surface-hover:#1e2a3a;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--text-dim:#475569;--accent:#22d3ee;--accent-hover:#06b6d4;--accent-dim:#22d3ee1f;--accent-glow:#22d3ee14;--accent-strong-glow:0 0 24px #22d3ee26;--secondary:#60a5fa;--secondary-dim:#60a5fa1a;--success:#34d399;--success-dim:#34d3991a;--warning:#fbbf24;--warning-dim:#fbbf241a;--error:#fb7185;--error-dim:#fb71851a;--border:#ffffff0f;--border-visible:#ffffff1a;--border-active:#22d3ee4d;--radius-xs:3px;--radius-sm:5px;--radius:8px;--radius-md:10px;--radius-lg:14px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--font-display:"Manrope", system-ui, sans-serif;--font-body:"Plus Jakarta Sans", system-ui, sans-serif;--font-mono:"Fira Code", "Menlo", monospace;--focus-ring:0 0 0 2px var(--bg-base), 0 0 0 4px var(--accent)}[data-theme=light]{--bg-base:#f1f5f9;--bg-surface:#fff;--bg-surface-raised:#f8fafc;--bg-surface-overlay:#e2e8f0;--bg-surface-hover:#e2e8f0;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--text-dim:#94a3b8;--accent:#0891b2;--accent-hover:#0e7490;--accent-dim:#0891b21a;--accent-glow:#0891b20f;--accent-strong-glow:0 0 24px #0891b21f;--secondary:#3b82f6;--secondary-dim:#3b82f614;--success:#059669;--success-dim:#05966914;--warning:#d97706;--warning-dim:#d9770614;--error:#e11d48;--error-dim:#e11d4814;--border:#00000014;--border-visible:#0000001f;--border-active:#0891b266;--shadow-sm:0 1px 2px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--focus-ring:0 0 0 2px var(--bg-base), 0 0 0 4px var(--accent)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:13px;line-height:1.6}body:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");position:fixed;inset:0}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.01em;font-weight:600;line-height:1.2}a{color:var(--accent);text-decoration:none;transition:color .15s}a:hover{color:var(--accent-hover)}:focus-visible{box-shadow:var(--focus-ring);outline:none}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{box-shadow:var(--focus-ring);border-radius:var(--radius-sm);outline:none}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-visible);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}[data-theme=light] body:before{opacity:0}.app-layout{z-index:1;min-height:100dvh;display:flex;position:relative}.app-body{flex-direction:column;flex:1;min-height:100dvh;margin-left:220px;display:flex}@media (width<=1024px){.app-body{margin-left:0}}.main-content{flex:1;padding:0 32px 28px}@media (width<=1024px){.main-content{padding:0 16px 20px}}.label-caps{font-family:var(--font-mono);letter-spacing:.03em;text-transform:uppercase;color:var(--text-dim);font-size:10px;font-weight:500}.mono-data{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-muted);font-size:11px;font-weight:400}.sidebar-overlay{display:none}@media (width<=1024px){.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;background:#0009;display:block;position:fixed;inset:0}}.placeholder-page{text-align:center;padding:100px 0}.placeholder-page h1{margin-bottom:6px;font-size:18px}.placeholder-page p{font-family:var(--font-body);color:var(--text-dim);text-transform:none;font-size:13px}.sparkle-mode{--sparkle-pink:#ff6bc1;--sparkle-purple:#c56cf0;--sparkle-indigo:#7c5cfc;--sparkle-cyan:#18dcff;--sparkle-mint:#7efff5}.sparkle-mode .brand{background:linear-gradient(90deg, var(--sparkle-pink), var(--sparkle-purple), var(--sparkle-indigo), var(--sparkle-cyan), var(--sparkle-mint), var(--sparkle-pink));-webkit-text-fill-color:transparent;filter:brightness(1.2);background-size:300%;-webkit-background-clip:text;background-clip:text;animation:2s linear infinite sparkle-gradient}.sparkle-mode .brand:after{content:" 🦄";-webkit-text-fill-color:initial;font-size:1.1em}.sparkle-mode .brand-sub{color:var(--sparkle-purple);text-shadow:0 0 8px #c56cf080}@keyframes sparkle-gradient{to{background-position:300%}}.sparkle-mode .sidebar{border-right-color:#c56cf026;box-shadow:inset -1px 0 20px #c56cf00d}.sparkle-mode .nav-item.active{color:var(--sparkle-purple);box-shadow:inset 3px 0 0 var(--sparkle-pink);background:linear-gradient(90deg,#ff6bc11f,#c56cf01f)}.sparkle-mode .nav-item:hover{color:var(--sparkle-pink)}.sparkle-mode .status-bar{background:linear-gradient(90deg, var(--bg-surface), #c56cf008, var(--bg-surface));background-size:200% 100%;border-bottom-color:#c56cf026;animation:4s infinite sparkle-shimmer}@keyframes sparkle-shimmer{0%,to{background-position:0 0}50%{background-position:200% 0}}.sparkle-mode .status-indicator.ok{background:var(--sparkle-pink);box-shadow:0 0 12px var(--sparkle-pink)}.sparkle-mode .status-value{color:var(--sparkle-cyan)}.sparkle-mode .camera-card{border-color:#c56cf01a;transition:all .3s}.sparkle-mode .camera-card:hover{border-color:#c56cf080;transform:translateY(-3px);box-shadow:0 0 20px #ff6bc126,0 0 40px #c56cf01a,0 0 80px #7c5cfc0d}.sparkle-mode .status-badge.active{color:var(--sparkle-pink);background:#ff6bc140;box-shadow:0 0 10px #ff6bc14d}.sparkle-mode .status-badge.active .status-dot{background:var(--sparkle-pink);box-shadow:0 0 8px var(--sparkle-pink), 0 0 16px #ff6bc180}.sparkle-mode .camera-name{background:linear-gradient(90deg, var(--text-primary), var(--sparkle-cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.sparkle-mode .connect-card:hover{border-color:var(--sparkle-purple);background:linear-gradient(135deg,#ff6bc10d,#7c5cfc0d);box-shadow:0 0 30px #c56cf01a}.sparkle-mode .play-btn,.sparkle-mode .btn-primary{background:linear-gradient(135deg, var(--sparkle-pink), var(--sparkle-purple), var(--sparkle-indigo));background-size:200%;animation:3s linear infinite sparkle-gradient;box-shadow:0 0 15px #c56cf04d}.sparkle-mode .event-counter{color:var(--sparkle-pink);background:linear-gradient(135deg,#ff6bc114,#c56cf014);border-color:#ff6bc14d;box-shadow:0 0 15px #ff6bc11a}.sparkle-mode .event-counter-dot{background:var(--sparkle-pink);box-shadow:0 0 8px var(--sparkle-pink), 0 0 16px #ff6bc180}.sparkle-mode .event-card:hover{border-color:#c56cf04d;box-shadow:0 0 20px #c56cf01a}.sparkle-mode .confidence-high{color:var(--sparkle-pink);background:linear-gradient(135deg,#ff6bc126,#c56cf026);border:1px solid #ff6bc133}.sparkle-mode .event-toast{border-left-color:var(--sparkle-purple);box-shadow:0 0 20px #c56cf033, var(--shadow-lg)}.sparkle-mode .app-footer{border-top-color:#c56cf026}.sparkle-mode .demo-toggle.active{border-color:var(--sparkle-purple);color:var(--sparkle-purple);background:linear-gradient(135deg,#ff6bc11a,#c56cf01a)}.sparkle-mode ::-webkit-scrollbar-thumb{background:#c56cf04d}.sparkle-mode ::-webkit-scrollbar-thumb:hover{background:#ff6bc180}.sparkle-mode h1{background:linear-gradient(90deg, var(--text-primary), var(--sparkle-cyan), var(--text-primary));-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;animation:4s infinite sparkle-shimmer}.sparkle-bg{pointer-events:none;z-index:99998;position:fixed;inset:0}.disco-diamond{width:6px;height:6px;animation:disco-twinkle var(--dur) ease-in-out var(--delay) infinite;opacity:0;position:absolute;transform:rotate(45deg)}.disco-diamond:after{content:"";background:inherit;filter:blur(4px);opacity:.6;border-radius:1px;position:absolute;inset:-4px}@keyframes disco-twinkle{0%,to{opacity:0;transform:rotate(45deg)scale(.6)}15%{opacity:1;transform:rotate(45deg)scale(1.1)}30%{opacity:.3;transform:rotate(45deg)scale(.8)}45%{opacity:.9;transform:rotate(45deg)scale(1)}60%{opacity:0;transform:rotate(45deg)scale(.7)}75%{opacity:.7;transform:rotate(45deg)scale(1.05)}90%{opacity:.1;transform:rotate(45deg)scale(.9)}}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:220px;padding:20px 0;display:flex;position:fixed;top:0;bottom:0;left:0}@media (width<=1024px){.sidebar{transition:transform .2s ease-out;transform:translate(-100%)}.sidebar.open{transform:translate(0)}}.sidebar-header{border-bottom:1px solid var(--border);flex-direction:column;margin-bottom:20px;padding:0 20px 24px;display:flex}.brand{font-family:var(--font-display);letter-spacing:-.01em;color:var(--text-primary);font-size:18px;font-weight:700}.brand-sub{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-dim);margin-top:3px;font-size:10px;font-weight:400}.sidebar-nav{flex:1;padding:0 10px}.nav-section{flex-direction:column;gap:1px;margin-bottom:20px;display:flex}.nav-group-label{font-family:var(--font-body);letter-spacing:0;color:var(--text-dim);padding:0 10px 6px;font-size:11px;font-weight:500}.nav-item{border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav-item:hover{background:var(--bg-surface-hover);color:var(--text-secondary)}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:1px;padding:12px 10px 0;display:flex}.theme-toggle{border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:flex}.theme-toggle:hover{background:var(--bg-surface-hover);color:var(--text-secondary)}.status-bar{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:0;padding:10px 16px;display:flex;position:sticky;top:0}.menu-toggle{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;margin-right:8px;padding:4px;transition:background .12s,color .12s;display:none}.menu-toggle:hover{background:var(--bg-surface-hover);color:var(--text-primary)}@media (width<=1024px){.menu-toggle{display:flex}}.status-item{align-items:center;gap:6px;padding:0 16px;display:flex}.status-item:first-child{padding-left:4px}.status-indicator{border-radius:50%;width:7px;height:7px}.status-indicator.ok{background:var(--success);box-shadow:0 0 10px var(--success)}.status-indicator.down{background:var(--error);box-shadow:0 0 10px var(--error)}.status-label{font-family:var(--font-mono);letter-spacing:.03em;text-transform:uppercase;color:var(--text-dim);font-size:10px;font-weight:500}.status-value{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-primary);font-size:14px;font-weight:500}.status-warn{font-family:var(--font-mono);letter-spacing:.03em;color:var(--warning);font-size:10px}.status-sep{background:var(--border-visible);flex-shrink:0;width:1px;height:20px}@media (width<=768px){.status-bar{flex-wrap:wrap;gap:6px;padding:10px 12px}.status-sep{display:none}.status-item{background:var(--bg-surface-raised);border-radius:var(--radius-sm);padding:4px 10px}.status-item:first-child{padding-left:10px}}.app-footer{border-top:1px solid var(--border);margin-top:auto;padding:12px 32px}.footer-row{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.footer-copy{font-family:var(--font-body);color:var(--text-dim);font-size:11px}.footer-row a{font-family:var(--font-body);color:var(--text-dim);font-size:11px;transition:color .12s}.footer-row a:hover{color:var(--text-secondary)}.footer-sep{background:var(--border-visible);width:1px;height:10px}.demo-toggle{border-radius:var(--radius-full);border:1px solid var(--border-visible);font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-dim);cursor:pointer;background:0 0;align-items:center;gap:5px;margin-left:auto;padding:3px 10px;font-size:10px;font-weight:500;transition:all .15s;display:inline-flex}.demo-toggle:hover{border-color:var(--accent);color:var(--accent)}.demo-toggle.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.demo-toggle-dot{background:var(--text-dim);border-radius:50%;width:5px;height:5px;transition:background .15s,box-shadow .15s}.demo-toggle.active .demo-toggle-dot{background:var(--accent);box-shadow:0 0 6px var(--accent)}.footer-version{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-dim);font-size:10px}.sparkle-secret{cursor:text;font:inherit;color:inherit;letter-spacing:inherit;-webkit-user-select:none;user-select:none;line-height:inherit;box-shadow:none;background:0 0;border:none;outline:none;margin:0;padding:0;display:inline}@media (width<=768px){.app-footer{padding:10px 16px}.footer-row{gap:8px}.footer-status{margin-left:0}.footer-sep{display:none}}.camera-card{color:inherit;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-decoration:none;transition:transform .2s,border-color .2s,box-shadow .2s;display:block;overflow:hidden}.camera-card:hover{border-color:var(--border-active);box-shadow:var(--accent-strong-glow);transform:translateY(-2px)}.camera-feed{aspect-ratio:16/9;background:var(--bg-base);position:relative;overflow:hidden}.camera-feed:after{content:"";pointer-events:none;z-index:1;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 2px 4px);position:absolute;inset:0}.camera-feed img,.camera-feed-video{object-fit:cover;width:100%;height:100%}.camera-placeholder{width:100%;height:100%;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}.placeholder-text{font-family:var(--font-mono);letter-spacing:.03em;font-size:10px}.feed-overlay{z-index:2;position:absolute;top:6px;left:6px}.status-badge{border-radius:var(--radius-xs);font-family:var(--font-mono);letter-spacing:.03em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;align-items:center;gap:4px;padding:2px 6px;font-size:10px;font-weight:500;display:inline-flex}.status-badge.active{color:var(--success)}.status-badge.inactive{color:var(--error)}.status-dot{background:currentColor;border-radius:50%;width:4px;height:4px}.status-badge.active .status-dot{animation:2s ease-in-out infinite pulse;box-shadow:0 0 6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.camera-info{padding:10px 12px}.camera-name{font-family:var(--font-display);letter-spacing:-.01em;color:var(--text-primary);margin-bottom:1px;font-size:13px;font-weight:600}.camera-context{font-family:var(--font-body);color:var(--text-muted);font-size:12px;font-weight:400;line-height:1.4}.connect-card{border:1px dashed var(--border-visible);border-radius:var(--radius-md);background:0 0;text-decoration:none;transition:border-color .15s,background .15s;display:block}.connect-card:hover{border-color:var(--accent);background:var(--accent-glow);border-style:solid}.connect-card-inner{color:var(--text-dim);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:40px 20px;display:flex}.connect-card:hover .connect-card-inner{color:var(--accent)}.connect-card-inner h3{font-family:var(--font-body);color:var(--text-secondary);text-transform:none;letter-spacing:0;font-size:13px;font-weight:500}.connect-card:hover .connect-card-inner h3{color:var(--text-primary)}.connect-card-inner p{font-family:var(--font-body);color:var(--text-dim);font-size:11px}.toast-container{z-index:1000;flex-direction:column-reverse;gap:6px;max-width:340px;display:flex;position:fixed;bottom:60px;right:20px}.event-toast{background:var(--bg-surface-raised);border:1px solid var(--border-visible);border-left:2px solid var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-lg);gap:10px;padding:10px;animation:.2s ease-out toast-slide;display:flex}@keyframes toast-slide{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.toast-thumb{border-radius:var(--radius-xs);object-fit:cover;flex-shrink:0;width:56px;height:42px}.toast-content{flex:1;min-width:0}.toast-camera{font-family:var(--font-display);letter-spacing:.04em;text-transform:none;color:var(--text-primary);margin-bottom:1px;font-size:11px;font-weight:600;display:block}.toast-desc{font-family:var(--font-body);color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:11px;line-height:1.4;display:-webkit-box;overflow:hidden}.toast-time{margin-top:2px;display:block}.camera-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;display:grid}@media (width<=768px){.camera-grid{grid-template-columns:1fr}}.camera-setup{max-width:520px;margin:0 auto}.setup-header{text-align:center;margin-bottom:28px}.setup-header h1{font-size:22px}.setup-header p{font-family:var(--font-body);color:var(--text-dim);text-transform:none;margin-top:4px;font-size:12px}.setup-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px}.form-group{margin-bottom:18px}.form-group label,.form-group .label-caps{justify-content:space-between;align-items:center;margin-bottom:5px;display:flex}.form-group input[type=text],.form-group input[type=url],.form-group textarea{background:var(--bg-base);border:1px solid var(--border-visible);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-body);outline:none;padding:9px 12px;font-size:13px;transition:border-color .12s,box-shadow .12s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-dim)}.form-group textarea{resize:vertical;min-height:68px;line-height:1.5}.input-with-btn{gap:6px;display:flex}.input-with-btn input{flex:1}.btn-secondary{background:var(--bg-surface-raised);border:1px solid var(--border-visible);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;white-space:nowrap;padding:9px 14px;font-size:12px;font-weight:500;transition:border-color .12s,color .12s}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.stream-preview{aspect-ratio:16/9;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:center;align-items:center;display:flex;overflow:hidden}.stream-preview img{object-fit:cover;width:100%;height:100%}.preview-placeholder{color:var(--text-dim);opacity:.4;flex-direction:column;align-items:center;gap:8px;display:flex}.preview-placeholder span{font-family:var(--font-body);font-size:11px}.threshold-value{font-family:var(--font-mono);letter-spacing:.03em;color:var(--accent);text-transform:none;font-size:12px}.range-input{appearance:none;background:var(--border-visible);border-radius:var(--radius-full);outline:none;width:100%;height:3px;margin:6px 0}.range-input::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border:2px solid var(--bg-surface);border-radius:50%;width:14px;height:14px;box-shadow:0 0 8px #22d3ee4d}.range-input::-moz-range-thumb{background:var(--accent);cursor:pointer;border:2px solid var(--bg-surface);border-radius:50%;width:14px;height:14px}.threshold-labels{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-dim);justify-content:space-between;margin-top:2px;font-size:10px;display:flex}.btn-primary{background:var(--accent);border-radius:var(--radius-sm);width:100%;color:var(--bg-base);font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;border:none;padding:10px;font-size:14px;font-weight:600;transition:background .12s,box-shadow .12s}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 0 20px #22d3ee33}.btn-primary:disabled{opacity:.3;cursor:not-allowed}.error-message{background:var(--error-dim);border-radius:var(--radius-sm);color:var(--error);font-family:var(--font-body);border:1px solid #fb718533;margin-bottom:14px;padding:8px 12px;font-size:12px}.pro-tip{background:var(--bg-surface-raised);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);align-items:flex-start;gap:8px;margin-top:18px;padding:12px;display:flex}.pro-tip p{font-family:var(--font-body);font-size:11px;line-height:1.5}.pro-tip strong{color:var(--text-secondary)}@media (width<=768px){.setup-form{padding:18px}.input-with-btn{flex-direction:column}}.event-history{max-width:860px}.history-header{border-bottom:1px solid var(--border);background:var(--bg-base);z-index:10;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;padding:10px 0;display:flex;position:sticky;top:0}.history-title-row{align-items:baseline;gap:10px;display:flex}.history-header h1{font-size:14px}.event-total{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-dim);font-size:11px}.camera-filter{background:var(--bg-surface);border:1px solid var(--border-visible);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;outline:none;padding:6px 10px;font-size:12px}.camera-filter option{background:var(--bg-surface)}.events-list{flex-direction:column;gap:6px;display:flex}.event-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .12s;overflow:hidden}.event-card:hover{border-color:var(--border-visible)}.event-main{cursor:pointer;align-items:flex-start;gap:14px;padding:14px;display:flex}.event-main:focus-visible{box-shadow:inset var(--focus-ring);border-radius:var(--radius)}.event-thumb-wrap{border-radius:var(--radius-sm);flex-shrink:0;width:110px;height:70px;position:relative;overflow:hidden}.event-thumb{object-fit:cover;width:100%;height:100%;display:block}.frame-count{border-radius:var(--radius-xs);font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-secondary);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;padding:1px 5px;font-size:10px;position:absolute;bottom:4px;right:4px}.event-details{flex:1;min-width:0}.event-top-row{align-items:center;gap:8px;margin-bottom:2px;display:flex}.event-camera{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-dim);font-size:10px;font-weight:500}.event-time{color:var(--text-dim)}.event-title{font-family:var(--font-body);color:var(--text-primary);text-transform:none;letter-spacing:0;margin-bottom:4px;font-size:14px;font-weight:600;line-height:1.3}.confidence-badge{border-radius:var(--radius-xs);font-family:var(--font-mono);letter-spacing:.03em;margin-bottom:5px;padding:1px 6px;font-size:10px;font-weight:500;display:inline-block}.confidence-high{background:var(--error-dim);color:var(--error)}.confidence-medium{background:var(--warning-dim);color:var(--warning)}.confidence-low{background:var(--success-dim);color:var(--success)}.event-desc{font-family:var(--font-body);color:var(--text-muted);margin-bottom:8px;font-size:12px;line-height:1.5}.event-actions{gap:4px;display:flex}.action-btn{border-radius:var(--radius-xs);font-family:var(--font-body);cursor:pointer;border:none;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:inline-flex}.play-btn{background:var(--accent);color:var(--bg-base)}.play-btn:hover{background:var(--accent-hover)}.solana-btn{background:var(--bg-surface-raised);border:1px solid var(--border-visible);color:var(--text-muted)}.solana-btn:hover{color:var(--text-secondary)}.expand-icon{color:var(--text-dim);flex-shrink:0;margin-top:2px;transition:transform .15s}.expand-icon.rotated{transform:rotate(180deg)}.event-expanded{border-top:1px solid var(--border);padding:12px 14px 14px}.expanded-section{margin-bottom:12px}.expanded-section .label-caps{margin-bottom:5px;display:block}.expanded-section p{font-family:var(--font-body);color:var(--text-muted);font-size:12px;line-height:1.5}.expanded-frames{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:4px;display:grid}.expanded-frames img{aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-xs);width:100%}.expanded-meta{text-align:right}.loading-state{color:var(--text-dim);font-family:var(--font-body);flex-direction:column;align-items:center;gap:10px;padding:80px 0;font-size:12px;display:flex}.loading-spinner{border:2px solid var(--border-visible);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;font-family:var(--font-body);color:var(--text-dim);padding:80px 0;font-size:12px}@media (width<=768px){.history-header{flex-direction:column}.event-thumb-wrap{display:none}.event-main{padding:10px}}.stream-view{max-width:1100px}.stream-header{border-bottom:1px solid var(--border);background:var(--bg-base);z-index:10;align-items:center;gap:12px;margin-bottom:16px;padding:10px 0;display:flex;position:sticky;top:0}.back-btn{border-radius:var(--radius-sm);border:1px solid var(--border-visible);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:color .12s,border-color .12s;display:flex}.back-btn:hover{color:var(--text-primary);border-color:var(--accent)}.stream-title{flex:1;align-items:baseline;gap:10px;display:flex}.stream-title h1{font-size:14px}.stream-status{font-family:var(--font-mono);letter-spacing:.03em;align-items:center;gap:4px;font-size:10px;font-weight:500;display:inline-flex}.stream-status.active{color:var(--success)}.stream-status.inactive{color:var(--error)}.stream-status-dot{background:currentColor;border-radius:50%;width:5px;height:5px}.stream-status.active .stream-status-dot{box-shadow:0 0 8px}.stream-actions{gap:4px;display:flex}.stream-action-btn{border-radius:var(--radius-sm);border:1px solid var(--border-visible);width:30px;height:30px;color:var(--text-dim);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:color .12s,border-color .12s;display:flex}.stream-action-btn:hover{color:var(--text-secondary)}.stream-action-btn.danger:hover{color:var(--error);border-color:var(--error)}.stream-layout{grid-template-columns:1fr 280px;gap:16px;display:grid}.stream-feed{aspect-ratio:16/9;background:var(--bg-base);border:1px solid var(--border-visible);border-radius:var(--radius);position:relative;overflow:hidden}.stream-feed img,.stream-feed-video{object-fit:cover;width:100%;height:100%}.stream-feed:after{content:"";pointer-events:none;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 2px 4px);position:absolute;inset:0}.stream-no-signal{width:100%;height:100%;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:.03em;justify-content:center;align-items:center;font-size:11px;display:flex}.stream-feed-overlay{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-muted);z-index:1;background:linear-gradient(#0000,#000000b3);padding:8px 10px;font-size:11px;position:absolute;bottom:0;left:0;right:0}.stream-context{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:12px;padding:12px}.stream-context .label-caps{margin-bottom:4px;display:block}.stream-context p{font-family:var(--font-body);color:var(--text-secondary);font-size:13px}.stream-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;padding:14px}.stream-panel .label-caps{margin-bottom:10px;display:block}.config-rows{flex-direction:column;gap:6px;display:flex}.config-row{justify-content:space-between;align-items:center;display:flex}.config-label{font-family:var(--font-body);color:var(--text-muted);font-size:12px}.config-value{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-primary);font-size:11px}.no-events{font-family:var(--font-body);color:var(--text-dim);font-size:12px}.stream-events{flex-direction:column;gap:8px;display:flex}.stream-event-item{border-bottom:1px solid var(--border);flex-direction:column;gap:2px;padding-bottom:8px;display:flex}.stream-event-item:last-child{border-bottom:none;padding-bottom:0}.stream-event-time{font-family:var(--font-mono);letter-spacing:.03em;color:var(--text-dim);font-size:10px}.stream-event-desc{font-family:var(--font-body);color:var(--text-secondary);font-size:12px;line-height:1.4}.stream-empty{text-align:center;font-family:var(--font-body);color:var(--text-dim);padding:80px 0;font-size:13px}.stream-empty a{margin-top:8px;display:inline-block}@media (width<=768px){.stream-layout{grid-template-columns:1fr}}
