*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e6ed;background:#0a0e17;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.header{z-index:100;background:#111827;border-bottom:1px solid #1e293b;justify-content:space-between;align-items:center;padding:12px 24px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:12px;display:flex}.logo{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:800;display:flex}.header h1{color:#f1f5f9;font-size:18px;font-weight:600}nav{gap:4px;display:flex}nav button{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s}nav button:hover{color:#e2e8f0;background:#1e293b}nav button.active{color:#fff;background:#6366f1}.job-selector{color:#e2e8f0;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:6px;padding:6px 10px;font-size:12px}.job-selector:hover{border-color:#6366f1}.main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:24px}.home-view{max-width:800px;margin:0 auto}.hero{text-align:center;margin-bottom:32px}.hero h2{background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:32px;font-weight:700}.hero p{color:#94a3b8;font-size:15px}.input-section textarea{color:#e2e8f0;resize:vertical;background:#111827;border:2px solid #1e293b;border-radius:10px;outline:none;width:100%;padding:16px;font-family:monospace;font-size:14px;transition:border-color .15s}.input-section textarea:focus{border-color:#6366f1}.input-section textarea::placeholder{color:#475569}.input-actions{gap:12px;margin-top:12px;display:flex}.btn-primary{cursor:pointer;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .15s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{cursor:pointer;color:#94a3b8;background:0 0;border:1px solid #334155;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:500}.btn-secondary:hover{color:#e2e8f0;border-color:#6366f1}.config-panel{background:#111827;border:1px solid #1e293b;border-radius:12px;margin-bottom:20px;padding:20px}.config-section{margin-bottom:16px}.config-section:last-child{margin-bottom:0}.config-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:600;display:block}.config-row{gap:20px;display:flex}.config-flex{flex:1.5}.config-narrow{flex:1}.mode-selector{gap:10px;display:flex}.mode-btn{color:#94a3b8;cursor:pointer;text-align:left;background:#0d1117;border:2px solid #1e293b;border-radius:8px;flex:1;align-items:center;gap:10px;padding:12px 14px;font-size:13px;transition:all .15s;display:flex}.mode-btn:hover{border-color:#334155}.mode-btn.active{color:#e2e8f0;background:#6366f114;border-color:#6366f1}.mode-btn strong{color:#e2e8f0;font-size:13px;display:block}.mode-btn small{color:#64748b;font-size:11px}.mode-btn.active small{color:#94a3b8}.mode-icon{color:#818cf8;white-space:nowrap;background:#1e293b;border-radius:5px;padding:5px 8px;font-size:10px;font-weight:700}.mode-btn.active .mode-icon{color:#fff;background:#6366f1}.model-grid{flex-wrap:wrap;gap:8px;display:flex}.model-btn{color:#94a3b8;cursor:pointer;text-align:left;background:#0d1117;border:1px solid #1e293b;border-radius:6px;min-width:130px;padding:8px 12px;transition:all .15s}.model-btn:hover{border-color:#334155}.model-btn.active{background:#6366f11a;border-color:#6366f1}.model-name{color:#e2e8f0;font-size:12px;font-weight:600;display:block}.model-meta{gap:6px;margin-top:2px;display:flex}.model-tag{color:#22c55e;font-size:10px}.model-cost{color:#475569;font-size:10px}.model-btn.active .model-name{color:#a5b4fc}.fps-grid{flex-direction:column;gap:6px;display:flex}.fps-btn{color:#94a3b8;cursor:pointer;text-align:left;background:#0d1117;border:1px solid #1e293b;border-radius:6px;align-items:center;gap:10px;padding:8px 12px;transition:all .15s;display:flex}.fps-btn:hover{border-color:#334155}.fps-btn.active{background:#6366f11a;border-color:#6366f1}.fps-label{color:#e2e8f0;min-width:50px;font-size:12px;font-weight:700}.fps-desc{color:#64748b;font-size:10px}.fps-btn.active .fps-label{color:#a5b4fc}.url-count{color:#64748b;text-align:right;margin-top:8px;font-size:13px}@media (width<=768px){.config-row,.model-grid{flex-direction:column}}.features{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px;display:grid}.feature{text-align:center;background:#111827;border:1px solid #1e293b;border-radius:12px;padding:24px}.feature-icon{color:#6366f1;margin-bottom:8px;font-size:28px;font-weight:800}.feature h3{margin-bottom:4px;font-size:15px;font-weight:600}.feature p{color:#94a3b8;font-size:13px}.dashboard-view{flex-direction:column;gap:20px;display:flex}.job-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.job-info{align-items:center;gap:12px;display:flex}.job-info h2{font-size:20px;font-weight:600}.status-badge{text-transform:uppercase;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.status-created{color:#94a3b8;background:#1e293b}.status-running{color:#818cf8;background:#6366f133}.status-completed{color:#4ade80;background:#22c55e33}.status-error{color:#f87171;background:#ef444433}.job-progress-bar{background:#1e293b;border-radius:14px;flex:1;max-width:400px;height:28px;position:relative;overflow:hidden}.job-progress-bar .progress-fill{background:linear-gradient(90deg,#6366f1,#22c55e);border-radius:14px;height:100%;transition:width .5s}.job-progress-bar span{color:#fff;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex;position:absolute;inset:0}.video-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.video-card{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:16px;transition:border-color .2s}.video-card.video-analyzing{border-color:#6366f1}.video-card.video-completed{border-color:#22c55e}.video-card.video-error{border-color:#ef4444}.video-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.video-id{color:#e2e8f0;font-family:monospace;font-size:14px;font-weight:700}.status-dot{border-radius:50%;width:10px;height:10px}.status-dot.status-pending{background:#475569}.status-dot.status-analyzing{background:#6366f1;animation:1.5s infinite pulse}.status-dot.status-completed{background:#22c55e}.status-dot.status-error{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.video-url{color:#64748b;word-break:break-all;margin-bottom:12px;font-size:11px}.video-stats{color:#4ade80;text-align:center;margin-top:8px;font-size:12px;font-weight:600}.agents-grid{flex-direction:column;gap:4px;max-height:130px;display:flex;overflow:hidden auto}.agents-grid::-webkit-scrollbar{width:4px}.agents-grid::-webkit-scrollbar-track{background:0 0}.agents-grid::-webkit-scrollbar-thumb{background:#334155;border-radius:2px}.agent-bar{background:#1e293b;border-radius:4px;flex-shrink:0;align-items:center;height:22px;min-height:22px;display:flex;position:relative;overflow:hidden}.agent-bar-fill{border-radius:4px;height:100%;transition:width .3s;position:absolute;top:0;left:0}.agent-bar.agent-pending .agent-bar-fill{background:#334155}.agent-bar.agent-running .agent-bar-fill{background:linear-gradient(90deg,#6366f1,#818cf8)}.agent-bar.agent-completed .agent-bar-fill{background:#22c55e}.agent-bar-label{z-index:1;color:#e2e8f0;margin-left:8px;font-size:11px;font-weight:600;position:relative}.agent-bar-pct{z-index:1;color:#cbd5e1;margin-left:auto;margin-right:8px;font-size:10px;position:relative}.terminal-section{background:#0d1117;border:1px solid #1e293b;border-radius:12px;overflow:hidden}.terminal-header{background:#161b22;border-bottom:1px solid #1e293b;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.terminal-header h3{font-size:14px;font-weight:600}.terminal-filters{align-items:center;gap:8px;display:flex}.terminal-filters select{color:#e2e8f0;background:#1e293b;border:1px solid #334155;border-radius:4px;padding:4px 8px;font-size:12px}.log-count{color:#64748b;font-size:11px}.terminal{height:350px;padding:8px 12px;font-family:monospace;font-size:12px;line-height:1.6;overflow-y:auto}.terminal::-webkit-scrollbar{width:6px}.terminal::-webkit-scrollbar-track{background:0 0}.terminal::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.log-line{gap:8px;padding:1px 0;display:flex}.log-ts{color:#475569;min-width:85px}.log-agent{color:#818cf8;min-width:70px;font-weight:600}.log-vid{color:#64748b;min-width:50px}.log-msg{flex:1}.log-info .log-msg{color:#94a3b8}.log-debug .log-msg{color:#64748b}.log-success .log-msg{color:#4ade80}.log-error .log-msg{color:#f87171}.terminal-empty{color:#475569;text-align:center;padding:40px;font-style:italic}.results-view h2{font-size:24px;font-weight:700}.results-subtitle{color:#94a3b8;margin-bottom:20px}.results-selector{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.result-tab{color:#94a3b8;cursor:pointer;background:#111827;border:1px solid #334155;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:10px 20px;font-size:13px;transition:all .15s;display:flex}.result-tab:hover{border-color:#6366f1}.result-tab.active{color:#fff;background:#6366f1;border-color:#6366f1}.tab-count{opacity:.7;font-size:10px}.annotation-display{flex-direction:column;gap:20px;display:flex}.stats-bar{background:#111827;border:1px solid #1e293b;border-radius:12px;flex-wrap:wrap;gap:16px;padding:16px;display:flex}.stat{text-align:center;flex:1;min-width:80px}.stat-value{color:#6366f1;font-size:24px;font-weight:700;display:block}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.timeline{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:16px}.timeline-bar{background:#1e293b;border-radius:6px;height:40px;position:relative;overflow:hidden}.timeline-segment{opacity:.8;cursor:pointer;border-radius:3px;height:36px;transition:opacity .15s;position:absolute;top:2px}.timeline-segment:hover{opacity:1;z-index:2}.timeline-labels{color:#64748b;justify-content:space-between;margin-top:6px;font-size:11px;display:flex}.annotation-table{background:#111827;border:1px solid #1e293b;border-radius:12px;overflow:hidden}.table-header{color:#64748b;text-transform:uppercase;letter-spacing:.5px;background:#161b22;border-bottom:1px solid #1e293b;padding:10px 16px;font-size:11px;font-weight:700;display:flex}.table-row{border-bottom:1px solid #1e293b4d;padding:8px 16px;font-size:13px;transition:background .1s;display:flex}.table-row:hover{background:#1e293b66}.col-num{color:#475569;width:40px;font-weight:600}.col-time{color:#818cf8;width:140px;font-family:monospace}.col-dur{color:#94a3b8;width:60px}.col-text{color:#e2e8f0;flex:1}.col-conf{align-items:center;width:100px;display:flex}.conf-bar{background:#1e293b;border-radius:3px;width:100%;height:6px;overflow:hidden}.conf-fill{background:linear-gradient(90deg,#ef4444,#eab308,#22c55e);border-radius:3px;height:100%}.results-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.total-cost-bar{background:#111827;border:1px solid #1e293b;border-radius:10px;gap:20px;padding:12px 20px;display:flex}.total-cost-item{text-align:center}.total-cost-val{color:#22c55e;font-size:18px;font-weight:700;display:block}.total-cost-lbl{color:#64748b;text-transform:uppercase;font-size:10px}.player-section{flex-wrap:wrap;gap:16px;display:flex}.video-player{background:#111827;border:1px solid #1e293b;border-radius:12px;flex:2;min-width:300px;overflow:hidden}.video-player video{background:#000;width:100%;max-height:400px;display:block}.active-panel{flex:1;min-width:220px}.active-annotation{background:#111827;border:1px solid #6366f1;border-radius:12px;flex-direction:column;justify-content:center;height:100%;padding:20px;display:flex}.active-annotation.empty{text-align:center;color:#475569;border-color:#1e293b}.active-hint{color:#334155;margin-top:8px;font-size:12px}.active-ann-time{color:#818cf8;margin-bottom:8px;font-family:monospace;font-size:18px;font-weight:700}.active-ann-text{color:#e2e8f0;margin-bottom:12px;font-size:16px;line-height:1.5}.active-ann-objects{flex-wrap:wrap;gap:6px;display:flex}.object-tag{color:#94a3b8;background:#1e293b;border-radius:12px;padding:3px 10px;font-size:11px}.loop-btn{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #334155;border-radius:6px;margin-top:12px;padding:8px 14px;font-size:12px;transition:all .15s}.loop-btn:hover{color:#e2e8f0;border-color:#6366f1}.loop-btn.active{color:#fff;background:#6366f1;border-color:#6366f1;animation:2s infinite loopPulse}@keyframes loopPulse{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 6px #6366f100}}.timeline-segment.active{opacity:1;z-index:5;box-shadow:0 0 8px #6366f199}.table-row{cursor:pointer}.table-row.row-active{background:#6366f126;border-left:3px solid #6366f1}.result-actions{justify-content:flex-end;gap:12px;display:flex}.json-viewer{background:#0d1117;border:1px solid #1e293b;border-radius:12px;max-height:400px;padding:16px;overflow:auto}.json-viewer pre{color:#94a3b8;white-space:pre-wrap;word-break:break-all;font-family:monospace;font-size:11px}.json-viewer::-webkit-scrollbar{width:6px}.json-viewer::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.no-selection{text-align:center;color:#475569;padding:60px;font-size:16px}.login-page{background:#0a0e17;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-form{text-align:center;background:#111827;border:1px solid #1e293b;border-radius:16px;width:360px;padding:40px}.login-logo{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:20px;font-weight:800;display:flex}.login-form h2{color:#f1f5f9;margin-bottom:4px;font-size:22px}.login-form p{color:#64748b;margin-bottom:24px;font-size:13px}.login-form input{color:#e2e8f0;background:#0d1117;border:1px solid #1e293b;border-radius:8px;outline:none;width:100%;margin-bottom:12px;padding:12px 14px;font-size:14px}.login-form input:focus{border-color:#6366f1}.login-form .btn-primary{width:100%;margin-top:8px}.login-error{color:#f87171;background:#ef44441a;border-radius:6px;margin-bottom:12px;padding:8px;font-size:13px}.btn-logout{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #334155;border-radius:6px;margin-left:8px;padding:6px 12px;font-size:11px}.btn-logout:hover{color:#f87171;border-color:#ef4444}.video-error{color:#f87171;text-align:center;margin-top:8px;font-size:12px;font-weight:600}.btn-stop{color:#eab308;cursor:pointer;background:0 0;border:1px solid #eab308;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600}.btn-stop:hover{background:#eab30826}.btn-delete-sm{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #ef4444;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600}.btn-delete-sm:hover{background:#ef444426}.btn-delete{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #475569;border-radius:4px;padding:4px 10px;font-size:11px}.btn-delete:hover{color:#f87171;border-color:#ef4444}.prev-jobs{margin-top:40px}.prev-jobs h3{color:#94a3b8;margin-bottom:12px;font-size:16px;font-weight:600}.prev-jobs-list{flex-direction:column;gap:6px;display:flex}.prev-job-row{background:#111827;border:1px solid #1e293b;border-radius:8px;align-items:center;gap:12px;padding:10px 16px;display:flex}.prev-job-id{color:#818cf8;cursor:pointer;min-width:70px;font-family:monospace;font-weight:700}.prev-job-id:hover{text-decoration:underline}.prev-job-count{color:#64748b;font-size:12px}.prev-job-date{color:#475569;margin-left:auto;font-size:12px}.status-stopped,.status-interrupted{color:#eab308;background:#eab30833}@media (width<=768px){.features,.video-grid{grid-template-columns:1fr}.header{flex-direction:column;gap:8px}}
