.login-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8eaf6,#f5f5f5,#fff3e0);padding:2rem;box-sizing:border-box}.login-card{display:flex;width:100%;max-width:900px;min-height:520px;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #00000026;background:#fff}.login-branding{flex:0 0 45%;background:linear-gradient(135deg,#1565c0,#0d47a1 60%,#002171);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2.5rem;color:#fff;text-align:center}.branding-content{max-width:300px}.branding-logo{margin-bottom:1.5rem}.brand-logo{width:90px;height:90px;border-radius:16px;background:#fff;padding:6px;box-shadow:0 8px 24px #0003}.branding-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem;line-height:1.3}.branding-subtitle{font-size:.9rem;opacity:.9;line-height:1.6}.login-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:2.5rem;background:#fff}.login-form-container{width:100%;max-width:320px}.form-logo{text-align:center;margin-bottom:1.25rem}.form-logo-img{width:55px;height:55px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.form-header{text-align:center;margin-bottom:1.5rem}.form-header h2{font-size:1.5rem;font-weight:700;color:#1e3a5f;margin-bottom:.375rem}.form-header p{color:#64b5f6;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1rem}.input-group{display:flex;flex-direction:column;gap:.375rem}.input-group label{font-size:.85rem;font-weight:500;color:#374151}.input-group input{width:100%;padding:.75rem 1rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.9rem;background:#fff;color:#1e293b;transition:all .2s ease}.input-group input::placeholder{color:#9ca3af}.input-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.error-message{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.8rem}.error-message .material-symbols-outlined{font-size:1rem}.login-btn{width:100%;padding:.75rem 1.25rem;background:#f97316;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease;margin-top:.25rem}.login-btn:hover:not(:disabled){background:#ea580c;transform:translateY(-1px);box-shadow:0 4px 12px #f973164d}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn .material-symbols-outlined{font-size:1.2rem}.loading-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{margin-top:1.5rem;text-align:center;color:#6b7280;font-size:.8rem}.login-footer a{color:#f97316;text-decoration:none;font-weight:600}.login-footer a:hover{text-decoration:underline}@media (max-width: 900px){.login-page{padding:1.5rem}.login-card{max-width:100%;min-height:480px}.login-branding{flex:0 0 40%;padding:2rem}.brand-logo{width:70px;height:70px}.branding-title{font-size:1.3rem}}@media (max-width: 700px){.login-page{padding:2rem 1rem 1rem;align-items:flex-start}.login-card{flex-direction:column;min-height:auto;border-radius:16px}.login-branding{flex:none;padding:1.5rem}.branding-content{display:flex;flex-direction:column;align-items:center;max-width:100%}.branding-logo{margin-bottom:.75rem}.brand-logo{width:56px;height:56px;border-radius:12px}.branding-title{font-size:1.15rem;margin-bottom:.5rem}.branding-subtitle{font-size:.8rem;max-width:280px}.login-form-panel{padding:1.5rem}.form-logo{margin-bottom:1rem}.form-logo-img{width:45px;height:45px}.form-header{margin-bottom:1.25rem}.form-header h2{font-size:1.3rem}}@media (max-width: 480px){.login-page{padding:1rem .75rem .75rem}.login-card{border-radius:12px}.login-branding{padding:1.25rem}.brand-logo{width:48px;height:48px}.branding-title{font-size:1.05rem}.branding-subtitle{font-size:.75rem}.login-form-panel{padding:1.25rem}.login-form-container{max-width:100%}.form-header h2{font-size:1.2rem}.form-header p{font-size:.85rem}.input-group input{padding:.65rem .875rem;font-size:.85rem}.login-btn{padding:.7rem;font-size:.9rem}.login-footer{font-size:.75rem}}.dashboard-container{min-height:100vh;display:flex;flex-direction:column;background:#f8f9fa;font-family:Inter,Segoe UI,sans-serif}.nav-actions{display:flex;align-items:center;gap:1.5rem}.user-greeting{font-size:.9rem;color:#424242;font-weight:500}.dashboard-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:3rem;max-width:1200px;margin:0 auto;width:100%}.welcome-section{text-align:center;max-width:600px}.welcome-section h2{font-size:2rem;color:#1a237e;margin-bottom:.5rem;font-weight:700}.welcome-section p{font-size:1.1rem;color:#616161;line-height:1.6}.action-cards{display:flex;gap:2rem;width:100%;justify-content:center;flex-wrap:wrap}.action-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:400px;display:flex;flex-direction:column;gap:1.5rem;cursor:pointer;border:1px solid #e0e0e0;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.action-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px #1a237e1a;border-color:#c5cae9}.card-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.view-card .card-icon{background:#e3f2fd;color:#1565c0}.share-card .card-icon{background:#fff3e0;color:#ef6c00}.card-icon .material-symbols-outlined{font-size:2.5rem}.card-content h3{font-size:1.5rem;color:#212121;margin:0 0 .75rem;font-weight:600}.card-content p{font-size:.95rem;color:#757575;line-height:1.5;margin:0 0 1.5rem}.card-link{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;transition:gap .2s ease}.view-card .card-link{color:#1565c0}.share-card .card-link{color:#ef6c00}.action-card:hover .card-link{gap:.75rem}@media (max-width: 768px){.dashboard-nav{padding:1rem;flex-direction:column;gap:1rem;align-items:stretch}.nav-brand{justify-content:center}.nav-actions{justify-content:space-between;padding-top:1rem;border-top:1px solid #f5f5f5}.dashboard-content{padding:2rem 1rem;gap:2rem}.action-card{padding:1.5rem}}.common-footer{background:#fff;border-top:1px solid #e0e0e0;padding:2rem;margin-top:auto;width:100%}.footer-text{text-align:center;display:flex;flex-direction:column;gap:.5rem}.credits{font-size:.8rem;color:#9e9e9e;margin:0;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem}.credits a{color:#5c6bc0;text-decoration:none;font-weight:500;transition:color .2s}.credits a:hover{color:#3949ab;text-decoration:underline}.separator{color:#bdbdbd}@media (max-width: 768px){.common-footer{padding:1.5rem 1rem}.credits{flex-direction:column;gap:.25rem}.separator{display:none}}.view-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#e3f2fd,#fff,#ffe0b2);font-family:Poppins,sans-serif}.header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:#fff;border-bottom:3px solid #2196f3;box-shadow:0 2px 8px #2196f31a}.header-left{display:flex;align-items:center;gap:1rem}.header-right{display:flex;gap:1rem}.header h1{font-size:1.5rem;color:#1976d2;font-weight:600}.icon-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:12px;font-weight:500;cursor:pointer;transition:all .3s ease;font-size:.9rem}.back-btn{background:#e0e0e0;color:#424242;border:2px solid #bdbdbd}.back-btn:hover{background:#bdbdbd;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.logout-btn{background:linear-gradient(135deg,#ff6f00,#f57c00);color:#fff;border:none}.logout-btn:hover{background:linear-gradient(135deg,#f57c00,#ef6c00);transform:translateY(-2px);box-shadow:0 8px 20px #ff6f004d}.status-bar{padding:1rem 2rem;background:#fff;border-bottom:2px solid #e3f2fd;box-shadow:0 2px 4px #2196f30d}.status-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.status-indicator{display:flex;align-items:center;gap:.5rem;font-weight:500;padding:.5rem 1rem;border-radius:8px;background:#f5f5f5;border:2px solid #e0e0e0;color:#424242}.status-indicator.connected{background:#e8f5e9;color:#2e7d32;border-color:#81c784}.status-indicator.disconnected{background:#ffebee;color:#c62828;border-color:#ef5350}.network-info{display:flex;align-items:center;gap:.5rem;color:#424242;font-size:.9rem}.network-stats{margin-left:.5rem;color:#616161;font-size:.75rem;display:flex;align-items:center}.network-stats small{background:#2196f30f;padding:4px 8px;border-radius:6px;border:1px solid rgba(33,150,243,.08)}.network-status{font-weight:500}.quality-dropdown{background:#fff;color:#424242;border:2px solid #bbdefb;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:all .3s ease}.quality-dropdown:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.video-section{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem;position:relative}.video-wrapper{position:relative;width:100%;max-width:1920px;display:flex;justify-content:center;align-items:center}.video{width:100%;height:auto;background:#000;border-radius:12px;box-shadow:0 8px 24px #2196f333;transition:all .3s ease;border:3px solid #e3f2fd}.video-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-between;width:90%;max-width:800px;background:#fffffff2;border-radius:12px;padding:1rem;transition:all .3s ease;border:2px solid #e3f2fd;box-shadow:0 4px 16px #2196f333;z-index:200}.video-controls.hidden{opacity:0;transform:translate(-50%) translateY(20px)}.controls-center{justify-content:center;gap:.5rem;flex-wrap:wrap;max-width:100%;overflow-x:auto}.control-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:#fff;color:#424242;border:2px solid #bbdefb;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap;flex-shrink:0}.control-btn .material-symbols-outlined{font-size:1.1rem}.control-btn:hover:not(:disabled){background:#e3f2fd;border-color:#2196f3;color:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #2196f333}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.recording{background:#ffebee;color:#c62828;border-color:#ef5350;animation:pulse 2s infinite}.recording-indicator{display:flex;align-items:center;gap:.5rem;color:#c62828;font-weight:600;font-size:.9rem}.recording-icon{animation:pulse 1.5s infinite}.recording-text{font-weight:700;letter-spacing:1px}.site-logo{width:56px;height:56px;object-fit:contain;background:#fff;padding:6px;border-radius:8px;border:2px solid #e3f2fd}.footer-credit{padding:1.5rem;text-align:center;color:#616161;background:#fff;border-top:2px solid #e3f2fd}.footer-logos{display:flex;justify-content:center;align-items:center;gap:2rem;margin-bottom:1rem}.footer-logo{height:50px;width:auto;object-fit:contain;transition:transform .3s ease}.footer-logo:hover{transform:scale(1.1)}.footer-credit a{color:#ff6f00;text-decoration:none;transition:color .3s ease;font-weight:500}.footer-credit a:hover{color:#f57c00}@media (max-width: 1024px){.header{padding:1rem 1.5rem}.header h1{font-size:1.25rem}.icon-btn{padding:.6rem 1rem;font-size:.85rem}.status-bar{padding:.75rem 1.5rem}.video-controls{width:95%;padding:.75rem 1rem}.control-btn{padding:.6rem 1rem;font-size:.8rem}.control-btn .material-symbols-outlined{font-size:1.1rem}}@media (max-width: 768px){.header{flex-direction:column;gap:.75rem;padding:.75rem 1rem}.header-left{width:100%;justify-content:center}.header h1{font-size:1.1rem}.header-right{width:100%;justify-content:space-between}.icon-btn{padding:.5rem .75rem;font-size:.8rem;flex:1;justify-content:center}.status-bar{padding:.5rem 1rem}.status-content{flex-direction:column;align-items:stretch;gap:.5rem}.status-content .ai-status-badge,.status-content .depth-status-badge,.status-content .camera-info-badge,.status-content .frame-size-badge{justify-content:center;font-size:.75rem;padding:.4rem .6rem}.video-section{padding:.5rem}.video-controls{flex-direction:column;gap:.75rem;width:100%;padding:.75rem;border-radius:12px}.controls-left,.controls-center,.controls-right{justify-content:center;width:100%}.controls-center{flex-wrap:wrap;gap:.5rem}.control-btn{flex:1 1 calc(33% - .5rem);min-width:80px;padding:.6rem .5rem;font-size:.75rem;justify-content:center}.control-btn .material-symbols-outlined{font-size:1rem}.control-btn span:not(.material-symbols-outlined){display:none}.footer-logos{gap:.75rem;flex-wrap:wrap;justify-content:center}.footer-logo{height:35px}.developer-credit{font-size:.7rem;padding:.5rem}}@media (max-width: 480px){.header{padding:.5rem .75rem;gap:.5rem}.header h1{font-size:1rem}.icon-btn{padding:.4rem .6rem;font-size:.75rem;border-radius:8px}.icon-btn span:not(.material-symbols-outlined){display:none}.status-bar{padding:.4rem .75rem}.video-wrapper{border-radius:8px;border-width:2px}.video-controls{padding:.5rem;border-radius:10px}.controls-center{gap:.375rem}.control-btn{flex:1 1 calc(25% - .375rem);min-width:60px;padding:.5rem .4rem;border-radius:8px}.control-btn .material-symbols-outlined{font-size:1.1rem}.footer-logo{height:28px}}@media (max-width: 768px) and (orientation: landscape){.header{flex-direction:row;padding:.5rem 1rem}.header-left,.header-right{width:auto}.status-bar{padding:.4rem 1rem}.video-section{padding:.25rem}.video-controls{flex-direction:row;flex-wrap:wrap;gap:.5rem;padding:.5rem}.controls-left,.controls-center,.controls-right{flex:0 0 auto}}.video-section:fullscreen{background:#000;width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;padding:0}.video-section:fullscreen .video-wrapper{width:100%;height:100%;max-width:100%;display:flex;justify-content:center;align-items:center}.video-section:fullscreen .video{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh;object-fit:contain;border-radius:0;border:none}.video-section:fullscreen .detection-canvas{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh}.video-section:fullscreen .video-controls{bottom:30px;z-index:10}.video-section:-webkit-full-screen{background:#000;width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;padding:0}.video-section:-webkit-full-screen .video-wrapper{width:100%;height:100%;max-width:100%;display:flex;justify-content:center;align-items:center}.video-section:-webkit-full-screen .video{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh;object-fit:contain;border-radius:0;border:none}.video-section:-webkit-full-screen .detection-canvas{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh}.video-section:-webkit-full-screen .video-controls{bottom:30px;z-index:10}.video-section:-moz-full-screen{background:#000;width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;padding:0}.video-section:-moz-full-screen .video-wrapper{width:100%;height:100%;max-width:100%}.video-section:-moz-full-screen .video{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh;object-fit:contain;border-radius:0;border:none}.video-section:-moz-full-screen .detection-canvas{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh}.video-section:-ms-fullscreen{background:#000;width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;padding:0}.video-section:-ms-fullscreen .video-wrapper{width:100%;height:100%;max-width:100%}.video-section:-ms-fullscreen .video{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh;object-fit:contain;border-radius:0;border:none}.video-section:-ms-fullscreen .detection-canvas{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh}.detection-panel{background:linear-gradient(135deg,#fff,#f8f9fa);border-bottom:2px solid #e3f2fd;padding:1rem 2rem;box-shadow:0 4px 12px #2196f31a}.detection-panel-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#1976d2}.detection-panel-header h3{margin:0;font-size:1.1rem;font-weight:600}.detection-panel-header .material-symbols-outlined{font-size:1.5rem}.detection-counts{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.count-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-radius:12px;min-width:140px;transition:all .3s ease;border:2px solid transparent}.count-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.count-card .material-symbols-outlined{font-size:1.75rem}.count-info{display:flex;flex-direction:column}.count-label{font-size:.75rem;font-weight:500;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.count-value{font-size:1.5rem;font-weight:700}.count-card.humans{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#c62828;border-color:#ef5350}.count-card.animals{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32;border-color:#66bb6a}.count-card.vehicles{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1565c0;border-color:#42a5f5}.count-card.objects{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;border-color:#ffa726}.count-card.total{background:linear-gradient(135deg,#ede7f6,#d1c4e9);color:#5e35b1;border-color:#7e57c2}.confidence-slider{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#fff;border-radius:8px;border:1px solid #e0e0e0;margin-bottom:1rem}.confidence-slider label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#424242;min-width:160px}.confidence-slider input[type=range]{flex:1;height:6px;border-radius:3px;background:linear-gradient(to right,#ff5252,#ffeb3b,#4caf50);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.confidence-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#1976d2;border:3px solid #fff;box-shadow:0 2px 6px #0000004d;cursor:pointer;transition:transform .2s ease}.confidence-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.distance-panel{background:linear-gradient(135deg,#e0f7fa,#b2ebf2);border-radius:12px;padding:1rem;margin-bottom:1rem;border:2px solid #00bcd4}.distance-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#00838f}.distance-header h4{margin:0;font-size:.9rem;font-weight:600}.distance-list{display:flex;flex-wrap:wrap;gap:.5rem}.distance-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#fff;border-radius:8px;min-width:150px;font-size:.85rem;border-left:4px solid}.distance-item.humans{border-color:#c62828}.distance-item.animals{border-color:#2e7d32}.distance-item.vehicles{border-color:#1565c0}.distance-item.objects{border-color:#e65100}.distance-item .obj-name{font-weight:500;color:#333}.distance-item .obj-distance{font-weight:700;color:#00838f}.distance-item .obj-distance small{font-weight:400;font-size:.7rem;color:#757575;margin-left:4px}.detection-list{background:#fff;border-radius:12px;padding:1rem;border:1px solid #e0e0e0}.detection-list-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#424242}.detection-list-header h4{margin:0;font-size:.9rem;font-weight:600}.detection-items{display:flex;flex-wrap:wrap;gap:.5rem}.detection-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.4rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.detection-item.humans{background:#ffebee;color:#c62828}.detection-item.animals{background:#e8f5e9;color:#2e7d32}.detection-item.vehicles{background:#e3f2fd;color:#1565c0}.detection-item.objects{background:#fff3e0;color:#e65100}.detection-item .det-class{text-transform:capitalize}.detection-item .det-score{background:#0000001a;padding:.15rem .5rem;border-radius:10px;font-size:.7rem}.ai-status-badge,.depth-status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.85rem;transition:all .3s ease}.ai-status-badge{background:#f3e5f5;color:#7b1fa2;border:2px solid #ce93d8}.ai-status-badge.active{background:linear-gradient(135deg,#7b1fa2,#9c27b0);color:#fff;animation:ai-pulse 2s infinite}.depth-status-badge{background:#e0f7fa;color:#00838f;border:2px solid #4dd0e1}.depth-status-badge.active{background:linear-gradient(135deg,#00838f,#00acc1);color:#fff;animation:depth-pulse 2s infinite}@keyframes ai-pulse{0%,to{box-shadow:0 0 #9c27b066}50%{box-shadow:0 0 0 8px #9c27b000}}@keyframes depth-pulse{0%,to{box-shadow:0 0 #00bcd466}50%{box-shadow:0 0 0 8px #00bcd400}}.control-btn.ai-btn{background:linear-gradient(135deg,#f3e5f5,#e1bee7);border-color:#ce93d8;color:#7b1fa2}.control-btn.ai-btn:hover:not(:disabled){background:linear-gradient(135deg,#e1bee7,#ce93d8);border-color:#9c27b0}.control-btn.ai-btn.active{background:linear-gradient(135deg,#7b1fa2,#9c27b0);color:#fff;border-color:#7b1fa2}.control-btn.ai-btn.loading{animation:loading-pulse 1.5s infinite}@keyframes loading-pulse{0%,to{opacity:1}50%{opacity:.5}}.control-btn.depth-btn{background:linear-gradient(135deg,#e0f7fa,#b2ebf2);border-color:#4dd0e1;color:#00838f}.control-btn.depth-btn:hover:not(:disabled){background:linear-gradient(135deg,#b2ebf2,#80deea);border-color:#00bcd4}.control-btn.depth-btn.active{background:linear-gradient(135deg,#00838f,#00acc1);color:#fff;border-color:#00838f}.ai-indicator{display:flex;align-items:center;gap:.5rem;color:#9c27b0;font-weight:600;font-size:.9rem}.ai-icon{animation:ai-spin 2s linear infinite}@keyframes ai-spin{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}.ai-text{font-weight:700;letter-spacing:.5px}.detection-canvas,.depth-canvas{border-radius:12px}.stream-type-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32;border-radius:8px;font-weight:500;font-size:.85rem;border:2px solid #81c784}.video-wrapper{position:relative;width:100%;max-width:1280px;display:flex;justify-content:center;align-items:center}@media (max-width: 1024px){.detection-counts{justify-content:center}.count-card{min-width:120px;padding:.6rem 1rem}.count-value{font-size:1.25rem}}@media (max-width: 768px){.detection-panel{padding:1rem}.detection-counts{gap:.5rem}.count-card{min-width:100px;flex:1 1 calc(50% - .5rem)}.distance-panel,.detection-list{padding:.75rem}.control-btn.ai-btn,.control-btn.depth-btn{padding:.6rem .8rem;font-size:.8rem}}@media (max-width: 480px){.count-card{flex:1 1 100%}.detection-panel-header h3{font-size:.95rem}.ai-status-badge,.depth-status-badge{padding:.4rem .75rem;font-size:.75rem}}.camera-info-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32;border:2px solid #66bb6a;font-weight:500;font-size:.85rem;transition:all .3s ease}.camera-info-badge .material-symbols-outlined{font-size:1.2rem}.camera-info-badge.native{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;border-color:#ffa726}.camera-info-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3233}.camera-info-badge.native:hover{box-shadow:0 4px 12px #e6510033}.stream-type-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1565c0;border:2px solid #42a5f5;font-weight:500;font-size:.85rem}.stream-type-badge .material-symbols-outlined{font-size:1.2rem}.responsive-video{width:100%;height:auto;max-width:100%;aspect-ratio:16 / 9;object-fit:contain;background:#000;border-radius:12px;box-shadow:0 8px 24px #2196f333;border:3px solid #e3f2fd}.frame-size-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;background:linear-gradient(135deg,#e8eaf6,#c5cae9);color:#3949ab;border:2px solid #7986cb;font-weight:500;font-size:.85rem;transition:all .3s ease}.frame-size-badge .material-symbols-outlined{font-size:1.2rem}.frame-size-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3949ab33}@media (max-width: 1400px){.video-wrapper{max-width:100%}}@media (max-width: 768px){.responsive-video{border-radius:8px;border-width:2px}.camera-info-badge,.frame-size-badge,.stream-type-badge{padding:.4rem .75rem;font-size:.75rem}.status-content{gap:.5rem}}@media (max-width: 480px){.camera-info-badge,.frame-size-badge{display:none}.status-bar{padding:.75rem 1rem}}.main-content-area{display:flex;flex:1;gap:1rem;padding:1rem;max-width:100%;overflow:hidden}.main-content-area .video-section{flex:1;min-width:0}.main-content-area.with-sidebar .video-section{flex:3}.stats-sidebar{flex:1;min-width:280px;max-width:320px;display:flex;flex-direction:column;gap:1rem;overflow-y:auto;max-height:calc(100vh - 200px)}.sidebar-section{background:#fff;border-radius:12px;border:2px solid #e3f2fd;padding:1rem;box-shadow:0 2px 8px #2196f31a}.sidebar-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#1565c0}.sidebar-header h4{margin:0;font-size:.9rem;font-weight:600}.sidebar-header .material-symbols-outlined{font-size:1.2rem}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.stat-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:8px;background:#f5f5f5}.stat-item .material-symbols-outlined{font-size:1.25rem}.stat-item.humans{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1565c0}.stat-item.animals{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}.stat-item.vehicles{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100}.stat-item.objects{background:linear-gradient(135deg,#f3e5f5,#e1bee7);color:#7b1fa2}.stat-data{display:flex;flex-direction:column}.stat-value{font-size:1.25rem;font-weight:700;line-height:1}.stat-label{font-size:.7rem;opacity:.8}.total-count{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;background:linear-gradient(135deg,#e8eaf6,#c5cae9);border-radius:8px;color:#3949ab;font-weight:500}.total-count .material-symbols-outlined{font-size:1.2rem}.distance-list-sidebar{display:flex;flex-direction:column;gap:.375rem}.distance-item-sidebar{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;border-radius:6px;font-size:.8rem;background:#f5f5f5}.distance-item-sidebar.humans{background:#e3f2fd}.distance-item-sidebar.animals{background:#e8f5e9}.distance-item-sidebar.vehicles{background:#fff3e0}.distance-item-sidebar .obj-distance{font-weight:600;color:#1565c0}.objects-list-sidebar{display:flex;flex-direction:column;gap:.25rem}.object-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;border-radius:6px;font-size:.8rem;background:#f5f5f5}.object-item.humans{background:#e3f2fd;color:#1565c0}.object-item.animals{background:#e8f5e9;color:#2e7d32}.object-item.vehicles{background:#fff3e0;color:#e65100}.object-item.objects{background:#f3e5f5;color:#7b1fa2}.obj-score{font-weight:600;font-size:.75rem}.confidence-control{display:flex;flex-direction:column;gap:.5rem}.confidence-control label{font-size:.85rem;color:#424242}.confidence-control input[type=range]{width:100%;height:6px;border-radius:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(135deg,#bbdefb,#1565c0)}.confidence-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#1565c0;cursor:pointer;box-shadow:0 2px 6px #1565c066}@media (max-width: 1024px){.main-content-area{flex-direction:column}.stats-sidebar{max-width:100%;max-height:none;flex-direction:row;flex-wrap:wrap}.sidebar-section{flex:1 1 300px}}@media (max-width: 768px){.stats-sidebar{display:none}.main-content-area{padding:.5rem}}.gesture-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}.control-btn.gesture-btn{transition:all .3s ease}.control-btn.gesture-btn.active{background:#ffab0040;border-color:#ffab00;color:#ffab00;box-shadow:0 0 12px #ffab004d}.control-btn.gesture-btn.loading{opacity:.7;pointer-events:none}.control-btn.gesture-btn.loading .material-symbols-outlined{animation:spin-gesture 1s linear infinite}@keyframes spin-gesture{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gesture-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600;background:#ffab001a;border:1px solid rgba(255,171,0,.3);color:#ffab00;transition:all .3s ease}.gesture-status-badge .material-symbols-outlined{font-size:16px}.gesture-status-badge.fist{background:#ff6b6b26;border-color:#ff6b6b66;color:#ff6b6b}.gesture-status-badge.countdown-active{animation:pulse-badge .8s ease-in-out infinite alternate}@keyframes pulse-badge{0%{box-shadow:0 0 4px #ff6b6b4d}to{box-shadow:0 0 14px #ff6b6b99}}.gesture-indicator{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#ffab0026;border-radius:12px;font-size:12px;font-weight:600;color:#ffab00}.gesture-indicator .gesture-icon{font-size:16px}.gesture-indicator.fist-detected{background:#ff6b6b26;color:#ff6b6b}.share-container{min-height:100vh;display:flex;flex-direction:column;background:#f8f9fa;font-family:Inter,Segoe UI,sans-serif}.dashboard-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000d}.nav-brand{display:flex;align-items:center;gap:1rem}.nav-logo{height:48px;width:auto;object-fit:contain}.nav-text h1{font-size:1.25rem;color:#1a237e;margin:0;font-weight:700;letter-spacing:-.01em}.nav-text p{font-size:.75rem;color:#5c6bc0;margin:0;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.nav-actions{display:flex;align-items:center;gap:1rem}.icon-btn.back-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:#e8eaf6;color:#3949ab;border:1px solid #c5cae9;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.85rem}.icon-btn.back-btn:hover{background:#c5cae9;transform:translateY(-2px)}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:#fff;color:#d32f2f;border:1px solid #ffcdd2;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.85rem}.logout-btn:hover{background:#ffebee;border-color:#ef9a9a}.status-bar{padding:1rem 2rem;background:#fff;border-bottom:1px solid #e0e0e0}.status-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;max-width:1280px;margin:0 auto}.status-indicator{display:flex;align-items:center;gap:.5rem;font-weight:600;padding:.5rem 1rem;border-radius:50px;font-size:.9rem}.status-indicator.connected{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}.status-indicator.streaming{background:#e3f2fd;color:#1565c0;border:1px solid #90caf9}.status-indicator.disconnected{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}.quality-selector{display:flex;align-items:center;gap:.5rem;color:#424242}.quality-dropdown{background:#f5f5f5;color:#424242;border:1px solid #e0e0e0;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:all .2s ease}.quality-dropdown:focus{outline:none;border-color:#1a237e;background:#fff}.share-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem;gap:2rem}.video-section{width:100%;max-width:1280px;display:flex;justify-content:center;align-items:center;position:relative}.video-wrapper{position:relative;width:100%;display:flex;justify-content:center;align-items:center;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a;background:#000}.video{width:100%;height:auto}.video-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-between;width:90%;max-width:800px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:.75rem 1.5rem;transition:all .3s ease;border:1px solid rgba(255,255,255,.5);box-shadow:0 8px 32px #0000001a;z-index:20}.video-controls.hidden{opacity:0;transform:translate(-50%) translateY(20px);pointer-events:none}.video-controls.visible{opacity:1;transform:translate(-50%) translateY(0)}.controls-left,.controls-center,.controls-right{display:flex;align-items:center;gap:.5rem}.controls-center{justify-content:center;gap:1rem}.control-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:#fffc;color:#424242;border:1px solid #e0e0e0;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.control-btn:hover:not(:disabled){background:#f5f5f5;transform:translateY(-2px)}.control-btn.recording{background:#ffebee;color:#d32f2f;border-color:#ffcdd2;animation:pulse 2s infinite}.recording-indicator{display:flex;align-items:center;gap:.5rem;color:#d32f2f;font-weight:700;font-size:.85rem;background:#ffffffe6;padding:.4rem .8rem;border-radius:50px}.recording-icon{font-size:.8rem;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.main-controls{display:flex;gap:1rem;justify-content:center}.main-control-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 2.5rem;font-size:1rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #00000026}.start-btn{background:linear-gradient(135deg,#1a237e,#303f9f);color:#fff}.start-btn:hover{transform:translateY(-4px);box-shadow:0 8px 24px #1a237e4d}.stop-btn{background:linear-gradient(135deg,#d32f2f,#c62828);color:#fff}.stop-btn:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d32f2f4d}.dashboard-footer{background:#fff;border-top:1px solid #e0e0e0;padding:2rem;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem}.footer-logos{display:flex;gap:2rem;align-items:center;margin-bottom:.5rem}.footer-logo{height:32px;width:auto;object-fit:contain;opacity:.8;transition:opacity .2s}.footer-logo:hover{opacity:1}.copyright{font-size:.85rem;color:#757575;margin:0}.credits{font-size:.8rem;color:#9e9e9e;margin:0}.credits a{color:#5c6bc0;text-decoration:none;font-weight:500}.credits a:hover{text-decoration:underline}@media (max-width: 768px){.dashboard-nav{padding:1rem;flex-direction:column;gap:1rem;align-items:stretch}.nav-brand{justify-content:center}.nav-actions{justify-content:space-between}.status-content{flex-direction:column;align-items:stretch}.share-content{padding:1rem}.video-controls{flex-direction:column;gap:1rem;width:95%;padding:1rem}.controls-center{flex-wrap:wrap}}.video-section:fullscreen{background:#000}.video-section:-webkit-full-screen{background:#000}.video-section:-moz-full-screen{background:#000}.video-section:-ms-fullscreen{background:#000}*{box-sizing:border-box;margin:0;padding:0}#root{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Poppins,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0f0f23,#1a1a2e,#16213e);color:#fff;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;-webkit-user-select:none;user-select:none}*{transition:color .3s ease,background-color .3s ease,border-color .3s ease,transform .3s ease,box-shadow .3s ease}button:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid #667eea;outline-offset:2px}
