html,body{margin:0;padding:0;height:100%;width:100%;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100vw;height:100vh;max-width:100vw;max-height:100vh;overflow:hidden}:root{--primary-color: #667eea;--primary-dark: #5568d3;--secondary-color: #764ba2;--text-primary: #1a202c;--text-secondary: #718096;--border-color: #e2e8f0;--bg-light: #f7fafc;--white: #ffffff;--error-color: #e53e3e;--success-color: #48bb78;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04)}.login-page-wrapper{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#667eea4d,#764ba24d),url(/images/dpalogin.png);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;display:flex;align-items:flex-start;justify-content:flex-start;padding:80px 20px 20px 60px;z-index:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--text-primary)}.login-container{width:100%;max-width:440px;margin:40px 0 0;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-wrapper{display:flex;justify-content:center;align-items:center;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #00000026,0 8px 25px #0000001a;min-height:auto;width:100%;max-width:440px;margin:0;border:1px solid rgba(102,126,234,.2);position:relative}.login-wrapper:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color) 0%,var(--secondary-color) 100%);z-index:0;pointer-events:none}.login-left{background:linear-gradient(135deg,#667eeacc,#764ba2cc),url(/images/dpalogin.png);background-size:cover;background-position:center;background-repeat:no-repeat;padding:40px 35px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:pulse 20s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:.8}}.brand-section{position:relative;z-index:1}.logo{margin-bottom:30px;animation:fadeInDown .6s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.brand-section h1{font-size:28px;font-weight:700;color:var(--white);margin-bottom:12px;animation:fadeInDown .6s ease-out .2s both}.brand-section p{font-size:16px;color:#ffffffe6;font-weight:400;animation:fadeInDown .6s ease-out .4s both}.illustration{position:relative;z-index:1;height:150px;margin-top:30px}.floating-shapes{position:relative;width:100%;height:100%}.shape{position:absolute;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.shape-1{width:120px;height:120px;top:0;left:0;animation:float 6s ease-in-out infinite}.shape-2{width:80px;height:80px;top:40px;right:20px;animation:float 8s ease-in-out infinite reverse}.shape-3{width:60px;height:60px;bottom:0;left:50%;animation:float 7s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) translate(0)}33%{transform:translateY(-20px) translate(10px)}66%{transform:translateY(10px) translate(-10px)}}.login-right{padding:48px 42px 50px;display:flex;align-items:center;justify-content:center;background:transparent;width:100%;position:relative;z-index:1}.login-form-container{width:100%;max-width:100%;position:relative;z-index:2}.container-title{text-align:center;margin-bottom:36px;animation:fadeInDown .6s ease-out}.container-title h1{font-size:26px;font-weight:700;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;color:var(--text-primary);letter-spacing:1px;line-height:1.2;margin:0;background:linear-gradient(135deg,#4c63d2,#6b3d91);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.1);filter:drop-shadow(0 1px 2px rgba(255,255,255,.5));text-transform:uppercase}.brand-logo{display:flex;justify-content:center;margin-bottom:32px;animation:fadeInDown .6s ease-out}.brand-logo svg{filter:drop-shadow(0 4px 12px rgba(102,126,234,.25));transition:transform .3s ease}.brand-logo:hover svg{transform:scale(1.05)}.form-header{margin-bottom:36px;text-align:center;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-header h2{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:10px;letter-spacing:-.5px;line-height:1.2}.form-header p{font-size:15px;color:var(--text-secondary);font-weight:400;line-height:1.5}.login-form{animation:fadeInUp .6s ease-out .2s both}.form-group{margin-bottom:24px}.form-group:last-of-type{margin-bottom:32px}.form-group label{display:block;font-size:13px;font-weight:600;color:#1a202c;margin-bottom:10px;letter-spacing:.2px;text-shadow:0 1px 2px rgba(255,255,255,.8)}.input-wrapper{position:relative;display:flex;align-items:center;z-index:1}.input-icon{position:absolute;left:18px;color:#4a5568;pointer-events:none;z-index:1;transition:color .3s ease}.form-group input:focus~.input-icon,.form-group:hover .input-icon{color:var(--primary-color)}.form-group input{width:100%;padding:15px 16px 15px 50px;font-size:15px;border:1.5px solid var(--border-color);border-radius:10px;background:var(--white);color:var(--text-primary);transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;box-shadow:0 1px 2px #0000000a;position:relative;z-index:2;pointer-events:auto}.form-group input:hover{border-color:#667eea66;box-shadow:0 2px 4px #0000000f}.form-group input:focus{outline:none;border-color:var(--primary-color);background:var(--white);box-shadow:0 0 0 4px #667eea1f,0 2px 8px #667eea26;transform:translateY(-1px)}.form-group input::placeholder{color:#718096;opacity:.8}.password-toggle{position:absolute;right:16px;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center;justify-content:center;transition:color .3s ease;z-index:1}.password-toggle:hover{color:var(--text-primary)}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;font-size:13px}.checkbox-label{display:flex;align-items:center;cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{display:none}.checkmark{width:18px;height:18px;border:1.5px solid var(--border-color);border-radius:5px;margin-right:10px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;flex-shrink:0}.checkbox-label:hover .checkmark{border-color:var(--primary-color)}.checkbox-label input[type=checkbox]:checked+.checkmark{background:var(--primary-color);border-color:var(--primary-color)}.checkbox-label input[type=checkbox]:checked+.checkmark:after{content:"";position:absolute;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.forgot-password{color:var(--primary-color);text-decoration:none;font-weight:500;transition:color .3s ease}.forgot-password:hover{color:var(--primary-dark);text-decoration:underline}.submit-btn{width:100%;padding:15px 20px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:var(--white);border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;box-shadow:0 4px 12px #667eea59,0 2px 4px #667eea33;letter-spacing:.3px;position:relative;overflow:hidden}.submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.submit-btn:hover:before{left:100%}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66,0 4px 8px #667eea40}.submit-btn:active{transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.submit-btn .arrow-icon{transition:transform .3s ease}.submit-btn:hover .arrow-icon{transform:translate(4px)}.divider{margin:28px 0;text-align:center;position:relative;color:var(--text-secondary);font-size:13px;font-weight:500}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:var(--border-color)}.divider:before{left:0}.divider:after{right:0}.social-login{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.social-btn{padding:13px 16px;border:1.5px solid var(--border-color);border-radius:10px;background:var(--white);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;box-shadow:0 1px 2px #0000000a}.social-btn:hover{border-color:var(--primary-color);background:var(--bg-light);transform:translateY(-2px);box-shadow:0 4px 12px #667eea26,0 2px 4px #667eea1a}.social-btn:active{transform:translateY(0)}.social-btn svg{flex-shrink:0}.google-btn svg{width:20px;height:20px}.github-btn{color:var(--text-primary)}.signup-link{text-align:center;font-size:14px;color:var(--text-secondary);margin-top:8px}.signup-link a{color:var(--primary-color);text-decoration:none;font-weight:600;transition:color .3s ease}.signup-link a:hover{color:var(--primary-dark);text-decoration:underline}.sso-divider{margin:24px 0;text-align:center;position:relative;color:var(--text-secondary);font-size:13px;font-weight:500}.sso-divider:before,.sso-divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:var(--border-color)}.sso-divider:before{left:0}.sso-divider:after{right:0}.sso-btn{width:100%;padding:13px 16px;border:1.5px solid var(--border-color);border-radius:10px;background:var(--white);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;box-shadow:0 1px 2px #0000000a;margin-top:8px}.sso-btn:hover{border-color:#0078d4;background:#f3f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #0078d426,0 2px 4px #0078d41a}.sso-btn:active{transform:translateY(0)}.sso-btn svg{flex-shrink:0}@media(max-width:968px){.login-page-wrapper{justify-content:center;padding:20px}.login-container{margin:0 auto}.login-wrapper{max-width:100%;margin:0 auto}.login-right{padding:40px 30px}}@media(max-width:480px){.login-page-wrapper{padding:10px;justify-content:center}.login-container{margin:0 auto}.login-wrapper{border-radius:16px;min-height:auto;margin:0 auto}.login-right{padding:30px 20px}.form-header h2{font-size:24px}.social-login{grid-template-columns:1fr}}.microsoft-sso-btn{background:#2f2f2f!important;box-shadow:0 2px 8px #0003!important}.microsoft-sso-btn:hover{background:#1a1a1a!important;box-shadow:0 4px 12px #0000004d!important}.microsoft-sso-btn .microsoft-icon{flex-shrink:0}.login-form.sso-only .login-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:20px;text-align:center}.login-error{padding:12px 16px;margin-bottom:16px;background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:var(--error-color);font-size:14px}.submit-btn.loading{pointer-events:none;opacity:.7}.submit-btn.loading .arrow-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}.dashboard-container{width:100vw;height:100vh;max-width:100vw;max-height:100vh;background:linear-gradient(135deg,#0f1419,#1a1f2e);color:#e0e0e0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;padding:0;overflow:hidden;display:flex;flex-direction:column}.dashboard-top-bar{display:flex;flex-direction:row;justify-content:space-between;align-items:center;flex-shrink:0;background:linear-gradient(135deg,#1a2332,#0f1419);border-bottom:2px solid #2a3441;box-shadow:0 2px 8px #0000004d;height:auto;padding:8px 20px}.logo-section{display:flex;align-items:center;background:transparent;flex-shrink:0}.logo-image{height:40px;width:auto;object-fit:contain}.logo-text{font-size:24px;font-weight:700;background:linear-gradient(135deg,#a78bfa,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:2px}.header-bar{display:flex;justify-content:flex-end;align-items:center;background:transparent;flex:1}.header-bar h1{font-size:18px;font-weight:600;color:#fff;letter-spacing:.3px;margin:0}.logout-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #dc26264d}.logout-btn:hover{background:linear-gradient(135deg,#ef4444,#dc2626);transform:translateY(-1px);box-shadow:0 4px 8px #dc262666}.logout-btn:active{transform:translateY(0);box-shadow:0 2px 4px #dc26264d}.logout-btn svg{flex-shrink:0}.status-indicator{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:#4ade80;text-transform:uppercase;letter-spacing:1px;padding:6px 12px;background:#10b9811a;border-radius:6px;border:1px solid rgba(16,185,129,.2)}.live-dot{font-size:18px;color:#4ade80;animation:pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 4px rgba(16,185,129,.6))}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.dashboard-content{display:grid;grid-template-columns:320px 1fr 320px;gap:14px;flex:1;min-height:0;max-height:100%;overflow:hidden;padding:14px;height:100%}.left-panel,.right-panel{background:linear-gradient(135deg,#1a2332,#151b28);border-radius:12px;border:1px solid #2a3441;padding:16px;overflow:hidden;box-shadow:0 4px 6px #0006,inset 0 1px #ffffff0d;display:flex;flex-direction:column;min-height:0;max-height:100%;height:100%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box}.panel-header{margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid #2a3441;flex-shrink:0}.panel-header h2{font-size:16px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1.5px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.panel-content{color:#9ca3af;overflow:hidden;flex:1;min-height:0;display:flex;flex-direction:column}.placeholder-text{font-size:13px;color:#64748b;text-align:center;margin-top:30px;font-style:italic;overflow:hidden;text-overflow:ellipsis;line-height:1.6;padding:0 10px}.feature-tabs{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.feature-tab{width:100%;padding:10px 14px;text-align:left;font-size:13px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;background:#0003;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.feature-tab:hover{background:#00000059;color:#fff;border-color:#ffffff26}.feature-tab.active{background:#4ade8026;border-color:#4ade8066;color:#4ade80}.feature-tab-content{flex:1;min-height:0;overflow:auto}.feature-pane{padding:4px 0}.feature-pane .placeholder-text{margin-top:8px;text-align:left}.detection-section{display:flex;flex-direction:column;gap:0;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent;padding-right:2px}.detection-section::-webkit-scrollbar{width:4px}.detection-section::-webkit-scrollbar-track{background:transparent}.detection-section::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.detection-card{background:linear-gradient(135deg,#1e293b,#0f172a);border:1.5px solid #334155;border-radius:12px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 4px 12px #0000004d}.detection-icon{color:#3b82f6;display:flex;align-items:center;justify-content:center}.detection-count{text-align:center}.count-number{font-size:48px;font-weight:700;color:#4ade80;line-height:1;margin-bottom:8px;text-shadow:0 0 20px rgba(74,222,128,.3)}.count-label{font-size:14px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:1px}.detection-status{display:flex;justify-content:center}.status-indicator-small{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-indicator-small.idle{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:#60a5fa}.status-indicator-small.detecting{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);color:#fbbf24}.status-indicator-small.error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#f87171}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s ease-in-out infinite}.status-indicator-small.detecting .status-dot{animation:blink 1s ease-in-out infinite}.detection-stats{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #334155;border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:12px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #2a3441}.stat-item:last-child{border-bottom:none}.stat-label{font-size:13px;color:#94a3b8;font-weight:500}.stat-value{font-size:14px;color:#e0e0e0;font-weight:600}.detection-message{text-align:center;padding:16px;background:#64748b1a;border-radius:8px;border:1px solid rgba(100,116,139,.2)}.detection-message p{font-size:13px;color:#64748b;margin:0;font-style:italic}.detection-error{text-align:center;padding:16px;background:#ef44441a;border-radius:8px;border:1px solid rgba(239,68,68,.3)}.detection-error p{font-size:12px;color:#f87171;margin:0 0 12px;line-height:1.5}.retry-btn{padding:8px 16px;border:1px solid rgba(239,68,68,.3);border-radius:6px;background:#ef444426;color:#f87171;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.retry-btn:hover{background:#ef444440;border-color:#ef444480;transform:translateY(-1px)}.center-panel{background:linear-gradient(135deg,#1a2332,#151b28);border-radius:12px;border:1px solid #2a3441;padding:16px;display:flex;flex-direction:column;box-shadow:0 4px 6px #0006,inset 0 1px #ffffff0d;overflow:hidden;min-width:0;min-height:0;max-height:100%;height:100%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.video-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid #2a3441;flex-wrap:wrap;gap:10px;flex-shrink:0;min-height:fit-content}.mode-selector{display:flex;align-items:center;gap:12px}.mode-selector label{font-size:13px;font-weight:600;color:#cbd5e1;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.mode-toggle{display:flex;gap:4px;background:linear-gradient(135deg,#1e293b,#0f172a);border:1.5px solid #334155;border-radius:8px;padding:4px}.mode-btn{padding:8px 20px;border:none;border-radius:6px;background:transparent;color:#94a3b8;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.mode-btn:hover{color:#e0e0e0;background:#ffffff0d}.mode-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f64d}.camera-selector,.file-selector{display:flex;align-items:center;gap:12px}.camera-selector label,.file-selector label{font-size:13px;font-weight:600;color:#cbd5e1;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.file-btn{padding:10px 20px;border:1.5px solid #334155;border-radius:8px;background:linear-gradient(135deg,#1e293b,#0f172a);color:#e0e0e0;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;min-width:200px;text-align:center;box-shadow:inset 0 1px 2px #0003}.file-btn:hover{border-color:#475569;background:linear-gradient(135deg,#1e293b,#1a2332);box-shadow:inset 0 1px 2px #0003,0 0 0 3px #3b82f61a}.camera-dropdown{background:linear-gradient(135deg,#1e293b,#0f172a);border:1.5px solid #334155;border-radius:8px;padding:10px 16px;color:#e0e0e0;font-size:14px;min-width:280px;cursor:pointer;transition:all .3s ease;font-weight:500;box-shadow:inset 0 1px 2px #0003}.camera-dropdown:hover{border-color:#475569;background:linear-gradient(135deg,#1e293b,#1a2332);box-shadow:inset 0 1px 2px #0003,0 0 0 3px #3b82f61a}.camera-dropdown:focus{outline:none;border-color:#3b82f6;box-shadow:inset 0 1px 2px #0003,0 0 0 3px #3b82f626}.control-buttons{display:flex;gap:10px;flex-wrap:wrap}.control-btn{padding:10px 22px;border:1.5px solid #334155;border-radius:8px;background:linear-gradient(135deg,#1e293b,#0f172a);color:#e0e0e0;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;text-transform:uppercase;letter-spacing:.5px;box-shadow:inset 0 1px 2px #0003,0 2px 4px #0000001a}.control-btn:hover:not(:disabled){background:linear-gradient(135deg,#1e293b,#1a2332);border-color:#475569;transform:translateY(-2px);box-shadow:inset 0 1px 2px #0003,0 4px 8px #0003}.control-btn:active:not(:disabled){transform:translateY(0);box-shadow:inset 0 1px 2px #0000004d,0 1px 2px #0000001a}.control-btn:disabled{opacity:.4;cursor:not-allowed;background:linear-gradient(135deg,#0f172a,#0a0e1a)}.start-btn:hover:not(:disabled){background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff;box-shadow:0 4px 12px #10b9814d}.pause-btn{display:inline-flex;align-items:center;gap:6px}.pause-btn:hover:not(:disabled){background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff;box-shadow:0 4px 12px #f59e0b4d}.stop-btn{display:inline-flex;align-items:center;gap:6px}.stop-btn:hover:not(:disabled){background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff;box-shadow:0 4px 12px #ef44444d}.record-btn:hover:not(:disabled){background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff;box-shadow:0 4px 12px #f59e0b4d}.stop-rec-btn:hover:not(:disabled){background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff;box-shadow:0 4px 12px #ef44444d}.snapshot-btn:hover:not(:disabled){background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f6;color:#fff;box-shadow:0 4px 12px #3b82f64d}.video-feed-container{flex:1;position:relative;background:#000;border-radius:10px;overflow:hidden;border:2px solid #1e293b;min-height:0;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 8px #00000080,0 2px 8px #0000004d}.video-feed{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;background:#000}.video-element{width:100%;height:100%;min-width:100%;min-height:100%;object-fit:contain;background:#000;display:block}.video-overlay{position:absolute;top:20px;left:20px;background:#0009;padding:10px 15px;border-radius:6px;color:#fff;font-size:14px;z-index:5;pointer-events:none;opacity:.8;animation:fadeOut 3s ease-in-out 2s forwards}@keyframes fadeOut{to{opacity:0}}.video-overlay p{margin:0;padding:2px 0;color:#fff}.video-overlay .video-status{font-size:12px;color:#d1d5db;margin-top:5px}.video-feed-disconnected{background:#0a0a0a}.video-placeholder{text-align:center;color:#6b7280;padding:50px 40px}.video-placeholder svg{color:#475569;margin-bottom:24px;opacity:.6}.video-placeholder p{font-size:15px;margin-bottom:12px;color:#94a3b8;font-weight:500}.video-status{font-size:14px;color:#6b7280;margin-top:10px}.video-instruction{font-size:13px;color:#64748b;margin-top:24px;line-height:1.7;max-width:420px;margin-left:auto;margin-right:auto;font-weight:400}.recording-indicator{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#ef4444f2,#dc2626f2);padding:8px 16px;border-radius:8px;font-size:13px;font-weight:700;color:#fff;z-index:10;text-transform:uppercase;letter-spacing:1px;box-shadow:0 2px 8px #ef444466,0 0 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.2)}.recording-dot{width:10px;height:10px;background:#fff;border-radius:50%;animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@media(max-width:1400px){.dashboard-content{grid-template-columns:280px 1fr 280px}}@media(max-width:1200px){.dashboard-content{grid-template-columns:250px 1fr 250px}.camera-dropdown{min-width:200px}}@media(max-width:968px){.dashboard-content{grid-template-columns:1fr;height:auto}.left-panel,.right-panel{min-height:200px}.video-controls{flex-direction:column;align-items:stretch}.camera-selector{width:100%}.camera-dropdown{width:100%;min-width:auto}.control-buttons{width:100%;justify-content:center}}
