.video-player-wrapper{position:absolute;top:0;left:0;width:100%;height:100%}.video-element{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;background:#000}.bbox-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.timeline-container{position:absolute;bottom:.5rem;left:1rem;right:1rem;z-index:20}.timeline-track{height:.3rem;background:#fff3;border-radius:.15rem;cursor:pointer;position:relative}.timeline-event{position:absolute;height:100%;background:#ef4444;opacity:.9;border-radius:.15rem}.timeline-cursor{position:absolute;width:2px;height:14px;background:#fff;top:-6px;transform:translate(-50%);pointer-events:none}.log-panel{background:var(--bg-secondary);border-radius:1rem;overflow:hidden;display:flex;flex-direction:column;height:300px}.log-header{display:flex;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-tertiary);font-weight:700;flex-shrink:0}.log-header button{background:none;border:none;color:var(--text-secondary);cursor:pointer}.log-list{flex:1;overflow-y:auto;padding:.5rem;font-family:Courier New,monospace;font-size:.8rem}.log-entry{padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.log-time{color:var(--accent);margin-right:.5rem}.history-panel{background:var(--bg-secondary);border-radius:1rem;overflow:hidden;display:flex;flex-direction:column;height:350px}.history-header{display:flex;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-tertiary);font-weight:700;flex-shrink:0}.history-header button{background:none;border:none;color:var(--text-secondary);cursor:pointer}.history-list-content{flex:1;overflow-y:auto;padding:.5rem;font-family:inherit;font-size:.9rem}.history-empty{padding:1rem;text-align:center;color:var(--text-secondary)}.history-item{background:var(--bg-tertiary);margin-bottom:.5rem;padding:.75rem;border-radius:.75rem;cursor:pointer;transition:background .2s}.history-item:hover{background:var(--border-color)}.history-info{display:flex;justify-content:space-between;margin-bottom:.5rem}.history-name{font-weight:700;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-date{font-size:.7rem;color:var(--text-secondary)}.history-feedback{display:flex;gap:.5rem}.history-feedback button{flex:1;padding:.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;color:var(--text-primary);transition:background .2s}.history-feedback button:hover{background:var(--accent)}.history-status{font-size:.7rem;text-align:center;padding:.25rem}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border-color: #334155;--accent: #ef4444;--accent-hover: #dc2626}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5}.app-root{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.app-header h1{font-size:1.8rem;background:linear-gradient(135deg,var(--accent),#f97316);-webkit-background-clip:text;background-clip:text;color:transparent}.mode-switch{display:flex;gap:.5rem}.mode-switch button{padding:.5rem 1.5rem;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);border-radius:2rem;cursor:pointer;transition:all .2s}.mode-switch button.active{background:var(--accent);border-color:var(--accent)}.upload-page{max-width:1400px;margin:0 auto;padding:1rem;width:100%}.upload-main{display:flex;gap:1.5rem}.upload-player-section{flex:1 1 65%;display:flex;flex-direction:column;gap:1rem}.video-container{position:relative;background:#000;border-radius:1rem;overflow:hidden;width:100%;aspect-ratio:16 / 9}.video-container .video-player-wrapper,.video-container .bbox-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.video-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-secondary)}.upload-controls{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;background:var(--bg-secondary);padding:1rem;border-radius:1rem}.upload-controls input[type=file],.upload-controls input[type=text]{padding:.5rem .8rem;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:.5rem;flex:1;min-width:150px}.upload-controls button{padding:.5rem 1.5rem;background:var(--accent);border:none;color:#fff;border-radius:.5rem;cursor:pointer;font-weight:700;transition:background .2s}.upload-controls button:hover:not(:disabled){background:var(--accent-hover)}.upload-controls button:disabled{opacity:.6;cursor:not-allowed}.upload-panels{flex:0 0 320px;display:flex;flex-direction:column;gap:1rem}.stream-page{max-width:1000px;margin:0 auto;padding:1rem}.stream-controls{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem;background:var(--bg-secondary);padding:1rem;border-radius:1rem}.stream-url-input,.stream-id-input{flex:1;padding:.5rem .8rem;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:.5rem}.stream-controls button{padding:.5rem 1.5rem;background:var(--accent);border:none;color:#fff;border-radius:.5rem;cursor:pointer;font-weight:700}.stream-controls button:disabled{opacity:.6;cursor:not-allowed}.stream-info{background:var(--bg-secondary);padding:1rem;border-radius:1rem;margin-bottom:1rem}.stream-error{color:var(--accent);margin:.5rem 0}.stream-video-container{position:relative;background:#000;border-radius:1rem;overflow:hidden;width:100%;aspect-ratio:16 / 9;margin-top:1rem}.stream-video-container .video-player-wrapper,.stream-video-container .bbox-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.stream-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-secondary)}@media(max-width:900px){.upload-main{flex-direction:column}.upload-panels{flex:0 0 auto;width:100%;flex-direction:row;gap:1rem}}@media(max-width:600px){.upload-panels{flex-direction:column}}.login-page{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-card{background:var(--bg-secondary);padding:2rem;border-radius:1rem;width:320px;box-shadow:0 4px 12px #0000004d}.login-card h2{margin-bottom:1rem;text-align:center}.login-card input{width:100%;padding:.5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:.5rem;margin-bottom:1rem}.login-card button{width:100%;padding:.5rem;background:var(--accent);border:none;color:#fff;border-radius:.5rem;cursor:pointer;font-weight:700}.login-error{color:var(--accent);margin-top:.5rem;text-align:center}.analysis-result h3{margin-bottom:.5rem}.analysis-result p,.analysis-result li{font-size:.9rem}.stream-events{margin-top:1rem;background:var(--bg-secondary);padding:.75rem;border-radius:.75rem;max-height:200px;overflow-y:auto}.stream-event-entry{font-family:monospace;font-size:.85rem;padding:.25rem 0;border-bottom:1px solid var(--border-color)}.event-time{color:var(--accent)}.aggression-alert{text-align:center;font-size:1.5rem;font-weight:700;color:#ef4444;background:#ef444426;padding:.5rem;border-radius:.5rem;margin:.5rem 0;animation:blink 1s infinite}.analysis-result{background:var(--bg-secondary);padding:1rem;border-radius:.75rem;margin-top:.5rem}.result-status{font-size:1.1rem;font-weight:700;margin-bottom:.3rem}.result-status.aggression{color:#ef4444}.result-status.normal{color:#22c55e}.mae-details{font-size:.9rem;margin-top:.5rem}.stream-main{display:flex;gap:1rem}.stream-events{background:var(--bg-secondary);padding:.75rem;border-radius:.75rem;font-size:.9rem}.stream-event-entry{padding:.2rem 0;border-bottom:1px solid var(--border-color)}.event-time{color:var(--accent);margin-right:.5rem}.aggression-alert{text-align:center;font-size:1.5rem;font-weight:700;color:#ef4444;background:#ef444426;padding:.5rem;border-radius:.5rem;animation:blink 1s infinite}@keyframes blink{0%{opacity:1}50%{opacity:.3}to{opacity:1}}
