*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#2c3e50;color:#000}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.app{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.container{max-width:1400px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;overflow:hidden}.header{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:30px;text-align:center}.header h1{margin:0;font-size:2.5em}.header p{margin:10px 0 0;opacity:.9}.connection-status{padding:15px;text-align:center;font-weight:700;font-size:1.1em}.connection-status.connected{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.connection-status.streaming{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.connection-status.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.connection-status.disconnected{background:#f8f9fa;color:#6c757d;border:1px solid #e9ecef}.status-indicator{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:10px}.connected .status-indicator{background:#28a745}.streaming .status-indicator{background:#17a2b8}.error .status-indicator{background:#dc3545}.disconnected .status-indicator{background:#6c757d}.processing-indicator{margin-left:20px;color:#856404;background:#fff3cd;padding:5px 10px;border-radius:4px;font-size:.9em}.controls{padding:20px;background:#f8f9fa;border-bottom:1px solid #dee2e6}.control-group h3{margin:0 0 15px;color:#495057}.button-group{display:flex;gap:10px;flex-wrap:wrap}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s ease}.btn:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-primary{background:#007bff;color:#fff}.btn-success{background:#28a745;color:#fff}.btn-danger{background:#dc3545;color:#fff}.btn-warning{background:#ffc107;color:#212529}.btn-info{background:#17a2b8;color:#fff}.btn.disabled{opacity:.6;cursor:not-allowed;transform:none}.main-content{display:grid;grid-template-columns:2fr 1fr;gap:20px;padding:20px}.video-container{background:#000;border-radius:8px;min-height:400px;display:flex;align-items:center;justify-content:center;position:relative}.processed-video{max-width:100%;border-radius:8px}.placeholder-text{text-align:center;color:#6c757d;padding:40px}.placeholder-text h2{margin-bottom:15px}.warning{color:#dc3545;font-weight:700;margin-top:15px}.info-panel{display:flex;flex-direction:column;gap:20px}.info-card{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px}.info-card h3{margin:0 0 15px;color:#495057;border-bottom:2px solid #007bff;padding-bottom:8px}.detection-status{padding:15px;border-radius:6px;font-weight:700;text-align:center;margin-bottom:15px;font-size:1.1em}.detection-safe{background:#d4edda;color:#155724;border:2px solid #c3e6cb}.detection-danger{background:#f8d7da;color:#721c24;border:2px solid #f5c6cb}.detection-neutral{background:#e2e3e5;color:#383d41;border:2px solid #d6d8db}.status-item{display:flex;justify-content:between;margin-bottom:8px;padding:5px 0}.status-item strong{flex:1;color:#495057}.status-item span{flex:1;text-align:right;font-weight:500}.confidence-value{color:#007bff;font-weight:700}.statistics{display:flex;flex-direction:column;gap:10px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fff;border-radius:6px;border:1px solid #dee2e6}.stat-label{font-weight:500}.stat-value{font-weight:700;font-size:1.2em;padding:5px 12px;border-radius:20px}.stat-value.safe{background:#d4edda;color:#155724}.stat-value.danger{background:#f8d7da;color:#721c24}.api-log{max-height:200px;overflow-y:auto;background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:10px}.log-entry{padding:5px 0;border-bottom:1px solid #f8f9fa;font-family:monospace;font-size:.9em}.log-entry:last-child{border-bottom:none}@media(max-width:1024px){.main-content{grid-template-columns:1fr}.button-group{justify-content:center}.header h1{font-size:2em}}
