.control-panel{display:flex;flex-direction:column;gap:12px;padding:12px;height:100%;overflow-y:auto;background:var(--bg-panel)}.control-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:12px}.section-title{font-size:13px;font-weight:600;color:var(--text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px}.section-title .icon{font-size:14px}.button-group{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}.button-group .btn{flex:1;min-width:80px}.checkbox-group{display:flex;flex-direction:column;gap:8px}.checkbox-group label{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);cursor:pointer}.checkbox-group label:hover{color:var(--text-primary)}.checkbox-group input[type=checkbox]{width:16px;height:16px}.slider-group:last-child{margin-bottom:0}.slider-label span:last-child{color:var(--accent-cyan);font-family:Consolas,Monaco,monospace;font-size:11px}.select-group{margin-bottom:12px}.select-group label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:4px}.select-group select{width:100%;padding:6px 8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:12px;cursor:pointer}.select-group select:focus{outline:none;border-color:var(--accent-blue)}.btn{font-family:inherit;cursor:pointer;border:none;border-radius:4px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.inspector{display:flex;flex-direction:column;height:100%;background:var(--bg-panel);border-left:1px solid var(--border-color)}.inspector-tabs{display:flex;gap:2px;padding:8px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);overflow-x:auto}.inspector-tab{display:flex;align-items:center;gap:4px;padding:6px 10px;background:transparent;color:var(--text-secondary);border:none;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s ease}.inspector-tab:hover{background:#ffffff0d;color:var(--text-primary)}.inspector-tab.active{background:var(--accent-blue);color:#fff}.tab-icon{font-size:12px}.tab-label{display:none}@media (min-width: 1400px){.tab-label{display:inline}}.inspector-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.panel-content{flex:1;overflow-y:auto;padding:12px}.stats-row{display:flex;gap:12px;margin-bottom:16px}.stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px;background:var(--bg-tertiary);border-radius:6px;border:1px solid var(--border-color)}.stat-value{font-size:24px;font-weight:700;color:var(--accent-cyan);font-family:Consolas,Monaco,monospace}.stat-value.stat-weapon{color:var(--accent-purple)}.stat-value.stat-pending{color:var(--text-muted)}.stat-value.stat-crowd{color:var(--accent-yellow)}.stat-value.stat-mob{color:var(--accent-red)}.stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:11px}th{padding:8px 6px;text-align:left;background:var(--bg-tertiary);color:var(--text-secondary);font-weight:600;text-transform:uppercase;font-size:10px;letter-spacing:.5px;border-bottom:1px solid var(--border-color);position:sticky;top:0}td{padding:6px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}tr{cursor:pointer;transition:background .1s ease}tr.row-selected{background:#3b82f633}tr.row-weapon{background:#a855f71a}tr.row-suspect{background:#ef44441a}tr.row-pending{opacity:.6}tr.row-crowd{background:#eab3081a}tr.row-mob{background:#ef444426}.mono{font-family:Consolas,Monaco,monospace}.badge{display:inline-block;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase}.badge-person{background:#3b82f633;color:var(--accent-blue)}.badge-suspect{background:#ef444433;color:var(--accent-red)}.badge-mob{background:#ef44444d;color:var(--accent-red)}.grid-preview{margin-bottom:12px;border-radius:6px;overflow:hidden;border:1px solid var(--border-color);background:#000}.preview-canvas{display:block}.grid-info{font-size:12px;color:var(--text-secondary)}.grid-info p{margin:4px 0}.reasoning-list{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.reasoning-item{padding:8px 10px;background:var(--bg-tertiary);border-radius:4px;font-size:12px;border-left:3px solid var(--border-color)}.reasoning-item.reasoning-ok{border-left-color:var(--accent-green);background:#22c55e1a}.reasoning-item.reasoning-warning{border-left-color:var(--accent-purple);background:#a855f71a}.reasoning-item.reasoning-crowd{border-left-color:var(--accent-yellow);background:#eab3081a}.reasoning-item.reasoning-mob{border-left-color:var(--accent-red);background:#ef444426}.thresholds-summary{background:var(--bg-tertiary);border-radius:6px;padding:12px}.thresholds-summary h4{margin:0 0 10px;font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.threshold-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;font-size:12px}.threshold-grid span:nth-child(odd){color:var(--text-secondary)}.threshold-grid span:nth-child(2n){color:var(--accent-cyan);font-family:Consolas,Monaco,monospace}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center;padding:24px}.empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{margin:0;font-size:14px}.pipeline-view{display:flex;flex-direction:column;height:100%;background:var(--bg-panel);overflow-y:auto;padding:12px}.pipeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.pipeline-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.frame-badge{font-size:11px;font-family:Consolas,Monaco,monospace;background:var(--bg-tertiary);padding:4px 8px;border-radius:4px;color:var(--accent-cyan)}.pipeline-stages{display:flex;flex-direction:column;gap:0}.pipeline-stage{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:12px;transition:all .2s ease}.pipeline-stage.stage-idle{opacity:.6}.pipeline-stage.stage-active{border-color:var(--accent-blue);box-shadow:0 0 0 1px #3b82f633}.pipeline-stage.stage-warning{border-color:var(--accent-yellow);box-shadow:0 0 0 1px #eab30833}.pipeline-stage.stage-alert{border-color:var(--accent-red);box-shadow:0 0 0 1px #ef44444d;animation:pulse-alert 1.5s infinite}@keyframes pulse-alert{0%,to{box-shadow:0 0 0 1px #ef44444d}50%{box-shadow:0 0 0 3px #ef444433}}.stage-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.stage-icon{font-size:20px;flex-shrink:0}.stage-title-group{flex:1;min-width:0}.stage-title{margin:0;font-size:12px;font-weight:600;color:var(--text-primary)}.stage-desc{margin:2px 0 0;font-size:11px;color:var(--text-muted)}.stage-canvas{margin:10px 0;border-radius:4px;overflow:hidden;background:#000}.stage-canvas canvas{width:100%;height:auto;display:block;image-rendering:pixelated}.stage-stats{display:flex;flex-wrap:wrap;gap:8px}.stage-stat{display:flex;flex-direction:column;align-items:center;padding:6px 10px;background:var(--bg-tertiary);border-radius:4px;min-width:50px}.stage-stat.stat-highlight{background:#ef444433}.stage-stat .stat-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stage-stat .stat-value{font-size:14px;font-weight:600;color:var(--text-primary);font-family:Consolas,Monaco,monospace}.stat-highlight .stat-value{color:var(--accent-red)}.pipeline-arrow{display:flex;justify-content:center;padding:6px 0;color:var(--text-muted);font-size:16px}.pipeline-output{margin-top:12px;padding:16px;border-radius:8px;text-align:center}.pipeline-output.output-safe{background:#22c55e26;border:1px solid var(--accent-green)}.pipeline-output.output-crowd{background:#eab30826;border:1px solid var(--accent-yellow)}.pipeline-output.output-mob{background:#ef444433;border:1px solid var(--accent-red);animation:pulse-output 1s infinite}@keyframes pulse-output{0%,to{opacity:1}50%{opacity:.8}}.output-header{display:flex;align-items:center;justify-content:center;gap:8px}.output-icon{font-size:24px}.output-title{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1px}.output-safe .output-title{color:var(--accent-green)}.output-crowd .output-title{color:var(--accent-yellow)}.output-mob .output-title{color:var(--accent-red)}.weapon-indicator{margin-top:8px;font-size:12px;color:var(--accent-purple);display:flex;align-items:center;justify-content:center;gap:4px}.pipeline-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:14px}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg-primary)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.header-title{display:flex;align-items:baseline;gap:12px}.header-title h1{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.header-title .subtitle{font-size:12px;color:var(--text-muted);font-weight:400}.header-badges{display:flex;gap:8px}.header-badge{padding:4px 12px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.header-badge.badge-mob{background:var(--accent-red);color:#fff;animation:flash-badge .5s infinite}@keyframes flash-badge{0%,to{opacity:1}50%{opacity:.7}}.header-badge.badge-crowd{background:var(--accent-yellow);color:#000}.header-badge.badge-weapon{background:var(--accent-purple);color:#fff}.header-badge.badge-safe{background:var(--accent-green);color:#fff}.app-content{display:flex;flex:1;overflow:hidden}.panel-left{width:280px;flex-shrink:0;border-right:1px solid var(--border-color);overflow:hidden}.panel-center{flex:1;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--bg-primary);overflow:hidden}.panel-right{width:320px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border-color);overflow:hidden}.panel-right-section{flex:1;overflow:hidden;display:flex;flex-direction:column}.pipeline-section{flex:0 0 45%;border-bottom:1px solid var(--border-color)}.inspector-section{flex:1}.app-footer{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:var(--bg-secondary);border-top:1px solid var(--border-color);font-size:11px;color:var(--text-muted);flex-shrink:0}.footer-link a{color:var(--accent-blue);text-decoration:none}.footer-link a:hover{text-decoration:underline}@media (max-width: 1400px){.panel-left{width:260px}.panel-right{width:280px}}@media (max-width: 1200px){.panel-left{width:240px}.panel-right{width:260px}.header-title .subtitle{display:none}}@media (max-width: 1000px){.app-content{flex-direction:column}.panel-left,.panel-right{width:100%;height:auto;max-height:200px;border:none;border-bottom:1px solid var(--border-color)}.panel-left{order:1}.panel-center{order:2;flex:1;min-height:300px}.panel-right{order:3;flex-direction:row}.pipeline-section,.inspector-section{flex:1;border:none;border-right:1px solid var(--border-color)}.pipeline-section{border-bottom:none}}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a24;--bg-panel: #16161e;--border-color: #2a2a3a;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--text-muted: #606070;--accent-blue: #3b82f6;--accent-green: #22c55e;--accent-yellow: #eab308;--accent-red: #ef4444;--accent-purple: #a855f7;--accent-cyan: #06b6d4}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;width:100%;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5;background:var(--bg-primary);color:var(--text-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3a3a4a}button{font-family:inherit;cursor:pointer;border:none;border-radius:4px;padding:6px 12px;font-size:13px;transition:all .15s ease}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:#252530}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--accent-green);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-warning{background:var(--accent-yellow);color:#000}.btn-warning:hover:not(:disabled){background:#ca8a04}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent-blue);border-radius:50%;cursor:pointer}input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--accent-blue);border-radius:50%;cursor:pointer;border:none}input[type=checkbox]{accent-color:var(--accent-blue)}.panel{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.panel-header{background:var(--bg-tertiary);padding:10px 12px;font-weight:600;font-size:13px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px}.panel-body{padding:12px}table{width:100%;border-collapse:collapse;font-size:12px}th,td{padding:6px 8px;text-align:left;border-bottom:1px solid var(--border-color)}th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:11px;letter-spacing:.5px}tr:hover{background:#3b82f61a}.tabs{display:flex;gap:2px;background:var(--bg-tertiary);padding:4px;border-radius:6px}.tab{padding:6px 12px;background:transparent;color:var(--text-secondary);border:none;border-radius:4px;font-size:12px;font-weight:500}.tab.active{background:var(--accent-blue);color:#fff}.tab:hover:not(.active){background:#ffffff0d}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.badge-crowd{background:#eab30833;color:var(--accent-yellow)}.badge-mob{background:#ef444433;color:var(--accent-red)}.badge-weapon{background:#a855f733;color:var(--accent-purple)}.badge-safe{background:#22c55e33;color:var(--accent-green)}.alert-banner{padding:8px 16px;font-weight:700;text-align:center;font-size:14px;text-transform:uppercase;letter-spacing:1px}.alert-crowd{background:linear-gradient(90deg,#eab3084d,#eab3081a);color:var(--accent-yellow);border:1px solid var(--accent-yellow)}.alert-mob{background:linear-gradient(90deg,#ef444466,#ef44441a);color:var(--accent-red);border:1px solid var(--accent-red);animation:pulse-mob 1s infinite}@keyframes pulse-mob{0%,to{opacity:1}50%{opacity:.7}}.alert-weapon{background:linear-gradient(90deg,#a855f74d,#a855f71a);color:var(--accent-purple);border:1px solid var(--accent-purple)}.slider-group{margin-bottom:12px}.slider-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:12px}.slider-label span:first-child{color:var(--text-secondary)}.slider-label span:last-child{color:var(--accent-cyan);font-family:monospace}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mb-2{margin-bottom:8px}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-muted{color:var(--text-muted)}.font-mono{font-family:Consolas,Monaco,monospace}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.w-full{width:100%}.h-full{height:100%}
