.bounding-box-canvas{pointer-events:none;z-index:5;width:100%;height:100%;position:absolute;top:0;left:0}.camera-view{background-color:var(--bg-medium);width:100%;height:100%;min-height:500px;box-shadow:var(--shadow-lg);border:2px solid var(--border-color);border-radius:12px;position:relative;overflow:hidden}.video-container{background-color:#000;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.video-element{object-fit:contain;width:100%;height:100%;display:block}.no-stream-message{text-align:center;color:var(--text-secondary);z-index:10;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.no-stream-message p{margin:.5rem 0;font-size:1.2rem}.no-stream-message .hint{opacity:.7;font-size:.9rem}@media (width<=640px){.camera-view{min-height:300px}}.image-test-section{padding:0}.image-test-section h3{color:#888;margin-bottom:12px;font-size:14px}.dropzone{text-align:center;cursor:pointer;background:#ffffff05;border:2px dashed #444;border-radius:10px;margin-bottom:12px;padding:16px;transition:all .2s}.dropzone:hover{background:#ffffff0a;border-color:#666}.dropzone-active{background:#2196f314;border-style:solid;border-color:#2196f3}.dropzone-has-image{border-style:solid;border-color:#333;padding:8px}.dropzone-placeholder{flex-direction:column;align-items:center;gap:6px;display:flex}.dropzone-icon{color:#666;margin-bottom:4px}.dropzone-active .dropzone-icon{color:#2196f3}.dropzone-text{color:#aaa;margin:0;font-size:13px}.dropzone-active .dropzone-text{color:#2196f3}.dropzone-sub{color:#666;margin:0;font-size:11px}.dropzone-preview{flex-direction:column;align-items:center;gap:6px;display:flex}.dropzone-thumb{object-fit:contain;border-radius:6px;max-width:100%;max-height:160px}.dropzone-hint{color:#666;font-size:11px}.preview-area{background:#111;border-radius:8px;margin-bottom:12px;overflow:hidden}.preview-image{object-fit:contain;width:100%;max-height:200px;display:block}.test-actions{gap:8px;margin-bottom:12px;display:flex}.btn.small{flex:1;padding:8px 16px;font-size:12px}.test-result{background:#4caf5026;border:1px solid #4caf504d;border-radius:8px;padding:12px}.result-summary{color:#aaa;margin-bottom:8px;font-size:12px}.result-summary strong{color:#4caf50}.result-item{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:4px 0;display:flex}.result-item:last-child{border-bottom:none}.result-class{color:#4caf50;font-size:14px;font-weight:500}.result-conf{color:#fff;font-size:14px;font-weight:700}.test-error{color:#f44336;background:#f4433626;border:1px solid #f443364d;border-radius:8px;padding:12px;font-size:12px}.test-hint{color:#666;text-align:center;padding:12px;font-size:12px}.model-selector-overlay{z-index:1000;background:#000000d9;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.model-selector-modal{background:#1a1a1a;border:1px solid #444;border-radius:12px;flex-direction:column;width:90vw;max-width:1100px;height:85vh;animation:.25s slideUp;display:flex;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.model-selector-header{border-bottom:1px solid #333;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.model-selector-title{align-items:baseline;gap:12px;display:flex}.model-selector-title h2{color:#fff;margin:0;font-size:1.25rem;font-weight:600}.model-selector-total{color:#888;font-size:.8rem}.model-selector-close{color:#fff;cursor:pointer;background:#333;border:1px solid #555;border-radius:6px;padding:8px 20px;font-size:.875rem;transition:all .2s}.model-selector-close:hover{background:#444;border-color:#666}.model-selector-search{flex-shrink:0;align-items:center;gap:12px;padding:16px 24px;display:flex}.model-selector-input{color:#fff;background:#252525;border:1px solid #444;border-radius:8px;outline:none;flex:1;padding:12px 16px;font-size:1rem;transition:border-color .2s}.model-selector-input:focus{border-color:#2196f3}.model-selector-input::placeholder{color:#666}.model-selector-clear{color:#aaa;cursor:pointer;white-space:nowrap;background:#333;border-radius:6px;padding:6px 14px;font-size:.8rem}.model-selector-clear:hover{color:#fff;background:#444}.model-selector-result-count{color:#888;flex-shrink:0;padding:0 24px 8px;font-size:.8rem}.model-selector-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));align-content:start;gap:12px;padding:8px 24px 24px;display:grid;overflow-y:auto}.model-selector-card{cursor:pointer;background:#252525;border:1px solid #444;border-radius:8px;padding:16px;transition:all .2s;position:relative}.model-selector-card:hover:not(.disabled){background:#2a2a2a;border-color:#2196f3}.model-selector-card.selected{background:#2196f314;border-color:#2196f3}.model-selector-card.disabled{opacity:.5;cursor:not-allowed}.model-selector-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.model-selector-card-name{color:#fff;font-size:1rem;font-weight:600}.model-selector-card-tag{border:1px solid;border-radius:4px;padding:2px 8px;font-size:.7rem;font-weight:500}.model-selector-card-desc{color:#aaa;margin-bottom:8px;font-size:.8rem;line-height:1.4}.model-selector-card-meta{color:#666;gap:16px;font-size:.7rem;display:flex}.model-selector-card-check{color:#fff;background:#2196f3;border-radius:4px;padding:2px 10px;font-size:.7rem;font-weight:600;position:absolute;top:12px;right:12px}.model-selector-empty{text-align:center;color:#666;grid-column:1/-1;padding:48px 0;font-size:1rem}.model-selector-grid::-webkit-scrollbar{width:6px}.model-selector-grid::-webkit-scrollbar-track{background:0 0}.model-selector-grid::-webkit-scrollbar-thumb{background:#444;border-radius:3px}.model-selector-grid::-webkit-scrollbar-thumb:hover{background:#555}.model-selector-trigger{cursor:pointer;background:#1a1a1a;border:1px solid #444;border-radius:6px;justify-content:space-between;align-items:center;padding:10px 12px;transition:all .2s;display:flex}.model-selector-trigger:hover{border-color:#2196f3}.model-selector-info{flex-direction:column;gap:4px;min-width:0;display:flex}.model-selector-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.model-selector-desc{color:#888;white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.model-selector-arrow{color:#666;flex-shrink:0;margin-left:8px;font-size:.875rem}.model-count{color:#2196f3;margin-left:6px;font-size:.75rem;font-weight:400}.app{color:#fff;background:#1a1a1a;flex-direction:column;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.header{background:#252525;border-bottom:1px solid #444;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.header h1{margin:0;font-size:1.25rem;font-weight:600}.header-left{align-items:center;gap:12px;display:flex}.header-logo{object-fit:contain;border-radius:4px;width:36px;height:36px}.status{color:#888;gap:20px;font-size:.875rem;display:flex}.status span{align-items:center;gap:6px;display:flex}.status .active{color:#4caf50}.main{flex:1;grid-template-columns:1fr 320px;gap:20px;min-height:0;padding:20px;display:grid;overflow:hidden}.video-area{background:#000;border-radius:8px;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.video-area video{object-fit:contain;width:100%;height:100%}.detection-badge{background:#f44336e6;border-radius:4px;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:500;display:flex;position:absolute;top:16px;right:16px}.pulse{background:#fff;border-radius:50%;width:8px;height:8px;animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.panel{flex-direction:column;gap:16px;min-height:0;max-height:calc(100vh - 80px);padding-right:4px;display:flex;overflow:hidden auto}.section{background:#252525;border:1px solid #444;border-radius:8px;padding:16px}.section h3{color:#888;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;font-size:.875rem;font-weight:600}.section select{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #444;border-radius:6px;width:100%;padding:10px 12px;font-size:.875rem}.section select:focus{border-color:#2196f3;outline:none}.section select:disabled{opacity:.5;cursor:not-allowed}.desc{color:#888;margin-top:8px;font-size:.75rem;line-height:1.4}.btn{cursor:pointer;border:none;border-radius:6px;width:100%;padding:12px;font-size:.875rem;font-weight:600;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{color:#fff;background:#2196f3}.btn.primary:hover:not(:disabled){background:#1976d2}.btn.success{color:#fff;background:#4caf50}.btn.success:hover:not(:disabled){background:#388e3c}.btn.danger{color:#fff;background:#f44336}.btn.danger:hover:not(:disabled){background:#d32f2f}.btn.secondary{color:#fff;background:#333;border:1px solid #444}.btn.secondary:hover{background:#444}.btn.loading{color:#888;background:#333}.stats .stat-row{border-bottom:1px solid #444;justify-content:space-between;padding:10px 0;display:flex}.stats .stat-row:last-child{border-bottom:none}.stats .value{color:#2196f3;font-family:SF Mono,monospace;font-weight:600}.object-list{flex-direction:column;gap:8px;display:flex}.object-item{background:#1a1a1a;border-radius:6px;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.object-item .name{text-transform:capitalize;font-size:.875rem}.object-item .count{color:#2196f3;background:#2196f326;border-radius:12px;padding:2px 10px;font-family:SF Mono,monospace;font-size:.875rem;font-weight:600}.section.error{background:#f443361a;border-color:#f44336}.section.error h3{color:#f44336}.section.error p{color:#fff;margin:0;font-size:.875rem;line-height:1.5}@media (width<=900px){.main{grid-template-columns:1fr}.video-area{min-height:400px}}@media (width<=600px){.header{text-align:center;flex-direction:column;gap:12px}.main{padding:12px}.video-area{min-height:300px}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{color:#fff;background:#1a1a1a;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow-x:hidden}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#252525}::-webkit-scrollbar-thumb{background:#444;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#666}
