*{margin:0;padding:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100%;min-height:100vh}.search-bar{width:100%;max-width:500px;margin:0 auto;padding:1rem}.search-input-container{display:flex;gap:.5rem;margin-bottom:.75rem;align-items:stretch}.search-input{flex:4;padding:.5rem .75rem;font-size:.85rem;line-height:1.5;border:1px solid #d0d0d0;border-radius:6px;transition:border-color .2s;background:#ffffff;box-sizing:border-box}.search-input:focus{outline:none;border-color:#4a4a4a}.search-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.search-button{flex:1;padding:.5rem .75rem;font-size:.85rem;line-height:1.5;font-weight:500;color:#fff;background-color:#4a4a4a;border:1px solid #4a4a4a;border-radius:6px;cursor:pointer;transition:background-color .2s;min-width:80px;box-sizing:border-box}.search-button:hover:not(:disabled){background-color:#2c2c2c}.search-options{display:flex;gap:1.5rem;justify-content:center}.checkbox-label{display:flex;align-items:center;gap:.4rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:14px;height:14px;cursor:pointer}.checkbox-label span{font-size:.8rem;color:#666}.image-upload{width:100%;max-width:500px;margin:0 auto;padding:1.5rem}.image-history{margin-bottom:1.5rem}.history-title{font-size:.9rem;font-weight:600;color:#4a4a4a;margin:0 0 .75rem}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem}.history-item{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;border:2px solid #e0e0e0;transition:all .2s;cursor:pointer}.history-item:hover{border-color:#4a4a4a;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.history-thumbnail{width:100%;height:100%;object-fit:cover;display:block}.history-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;padding:0;background-color:#0009;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}.history-item:hover .history-remove{opacity:1}.history-remove:hover{background-color:#000c;transform:scale(1.1)}.upload-area{border:2px dashed #d0d0d0;border-radius:6px;padding:2rem 1.5rem;text-align:center;transition:all .2s;background-color:#fafafa}.upload-area.drag-active{border-color:#4a4a4a;background-color:#f0f0f0}.upload-prompt{display:flex;flex-direction:column;align-items:center;gap:.75rem}.upload-icon{font-size:2.5rem;color:#9a9a9a}.upload-prompt p{color:#666;margin:0;font-size:.85rem}.file-input{display:none}.file-input-label{cursor:pointer}.file-input-button{display:inline-block;padding:.5rem 1rem;background-color:#4a4a4a;color:#fff;border-radius:6px;font-weight:500;font-size:.85rem;transition:background-color .2s}.file-input-button:hover{background-color:#333}.preview-container{display:flex;flex-direction:column;align-items:center;gap:.75rem}.preview-image{max-width:100%;max-height:400px;border-radius:6px;box-shadow:0 2px 4px #00000014}.clear-button{padding:.4rem .85rem;background-color:#6a6a6a;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.8rem;transition:background-color .2s}.clear-button:hover:not(:disabled){background-color:#555}.clear-button:disabled{background-color:#ccc;cursor:not-allowed}.search-button{width:100%;margin-top:.85rem;padding:.65rem;font-size:.85rem;font-weight:500;color:#fff;background-color:#4a4a4a;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}.search-button:hover:not(:disabled){background-color:#333}.search-button:disabled{background-color:#ccc;cursor:not-allowed}.video-upload-container{background:white;border-radius:6px;padding:1.5rem;box-shadow:0 1px 4px #00000014;max-width:800px;margin:0 auto}.video-upload-container h2{margin:0 0 .4rem;color:#2c2c2c;font-size:1.2rem;font-weight:600}.video-upload-description{color:#666;margin-bottom:1.25rem;line-height:1.5;font-size:.85rem}.source-type-selector{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.source-button{flex:1;min-width:150px;padding:.6rem .85rem;border:1px solid #d0d0d0;background:white;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.source-button:hover{border-color:#4a4a4a;background:#f8f8f8}.source-button.active{border-color:#4a4a4a;background:#4a4a4a;color:#fff}.upload-section,.url-section{margin-bottom:1.25rem}.file-input-wrapper{margin-bottom:.85rem}.file-input-wrapper input[type=file]{display:none}.file-input-label{display:inline-block;padding:.85rem 1.5rem;background:#fafafa;border:2px dashed #d0d0d0;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s;width:100%;text-align:center;box-sizing:border-box}.file-input-label:hover{background:#f0f0f0;border-color:#4a4a4a}.file-size{display:block;font-size:.75rem;color:#666;margin-top:.2rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.4rem;font-weight:500;color:#2c2c2c;font-size:.85rem}.form-group input{width:100%;padding:.5rem .7rem;border:1px solid #d0d0d0;border-radius:6px;font-size:.85rem;transition:border-color .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#4a4a4a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-group small{display:block;margin-top:.2rem;color:#666;font-size:.75rem}.process-button{width:100%;padding:.65rem 1.5rem;background:#4a4a4a;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:.85rem}.process-button:hover:not(:disabled){background:#333333}.process-button:disabled{background:#cccccc;cursor:not-allowed}.message{padding:.75rem;border-radius:6px;margin-top:.85rem;font-weight:500;font-size:.85rem}.error-message{background:#fee;color:#c33;border:1px solid #fcc}.success-message{background:#f0f0f0;color:#4a4a4a;border:1px solid #d0d0d0}.pipeline-info{margin-top:1.5rem;padding:1.25rem;background:#fafafa;border-radius:6px;border-left:3px solid #4a4a4a}.pipeline-info h3{margin:0 0 .85rem;color:#2c2c2c;font-size:1rem;font-weight:600}.pipeline-info ol{margin:0;padding-left:1.5rem}.pipeline-info li{margin-bottom:.4rem;line-height:1.5;color:#555;font-size:.85rem}@media (max-width: 768px){.video-upload-container{padding:1.25rem}.source-type-selector{flex-direction:column}.source-button{min-width:100%}}.video-status-card{background:white;border-radius:6px;padding:1.25rem;box-shadow:0 1px 4px #00000014;margin-bottom:.85rem;border-left:3px solid #4a4a4a}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.85rem}.status-header h3{margin:0;color:#2c2c2c;font-size:1rem;font-weight:600}.close-button-icon{background:none;border:none;font-size:1.25rem;cursor:pointer;color:#999;padding:0;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-button-icon:hover{background:#f0f0f0;color:#4a4a4a}.status-info{margin-bottom:1.25rem}.status-badge{display:inline-block;padding:.35rem .75rem;border-radius:12px;color:#fff;font-weight:500;font-size:.75rem;margin-bottom:.85rem}.progress-bar-container{position:relative;width:100%;height:24px;background:#f0f0f0;border-radius:12px;overflow:hidden}.progress-bar{height:100%;transition:width .3s ease;border-radius:12px}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:500;color:#2c2c2c;font-size:.75rem}.steps-completed{margin-bottom:.85rem}.steps-completed h4{margin:0 0 .4rem;color:#2c2c2c;font-size:.85rem;font-weight:600}.steps-completed ul{margin:0;padding-left:1.5rem;list-style:none}.steps-completed li{padding:.2rem 0;color:#4a4a4a;font-weight:500;font-size:.8rem}.stats{display:flex;gap:1.5rem;margin-bottom:.85rem;padding:.85rem;background:#fafafa;border-radius:6px}.stat-item{display:flex;flex-direction:column;gap:.2rem}.stat-label{font-size:.75rem;color:#7a7a7a;font-weight:500}.stat-value{font-size:1.2rem;font-weight:600;color:#2c2c2c}.error-details{padding:.75rem;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;margin-bottom:.85rem;font-size:.85rem}.timestamps{display:flex;flex-direction:column;gap:.2rem;padding-top:.85rem;border-top:1px solid #f0f0f0}.timestamps small{color:#7a7a7a;font-size:.75rem}.loading-spinner{text-align:center;padding:1.5rem;color:#4a4a4a;font-size:.9rem}.error{padding:.75rem;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;margin-bottom:.85rem;font-size:.85rem}.close-button{padding:.4rem .85rem;background:#6a6a6a;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;transition:background .2s}.close-button:hover{background:#555555}@media (max-width: 768px){.stats{flex-direction:column;gap:.85rem}}.video-filter{width:100%;max-width:500px;margin:0 auto 20px;background:white;border:1px solid #ddd;border-radius:8px;overflow:hidden}.filter-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;background:#f8f9fa;-webkit-user-select:none;user-select:none;transition:background .2s}.filter-header:hover{background:#e9ecef}.filter-title{font-weight:600;color:#2c3e50}.filter-toggle{color:#7f8c8d;font-size:12px}.filter-content{padding:16px;border-top:1px solid #e9ecef}.filter-actions{display:flex;gap:10px;margin-bottom:12px}.filter-action-btn{padding:6px 12px;border:1px solid #3498db;background:white;color:#3498db;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s}.filter-action-btn:hover:not(:disabled){background:#3498db;color:#fff}.filter-action-btn:disabled{opacity:.5;cursor:not-allowed}.video-list{max-height:300px;overflow-y:auto;border:1px solid #e9ecef;border-radius:4px;padding:8px;background:#fafafa}.video-item{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:2px 0}.video-checkbox-label{display:flex;align-items:center;padding:8px;cursor:pointer;border-radius:4px;transition:background .2s;flex:1}.video-checkbox-label:hover{background:#e9ecef}.video-checkbox{margin-right:10px;cursor:pointer;width:16px;height:16px}.video-name{flex:1;font-size:14px;color:#2c3e50;word-break:break-word}.play-video-btn{padding:4px 8px;background:transparent;border:none;cursor:pointer;font-size:16px;transition:transform .2s;flex-shrink:0}.play-video-btn:hover{transform:scale(1.2)}.video-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.video-modal-content{background:white;border-radius:8px;padding:20px;max-width:90vw;max-height:90vh;position:relative;display:flex;flex-direction:column;gap:12px}.video-modal-close{position:absolute;top:10px;right:10px;background:#e74c3c;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:1}.video-modal-close:hover{background:#c0392b}.video-modal-title{margin:0;padding-right:40px;color:#2c3e50;font-size:16px;font-weight:600;word-break:break-word}.video-player{width:100%;max-width:1200px;max-height:70vh;border-radius:4px;background:#000}.filter-summary{margin-top:12px;padding:8px 12px;background:#e3f2fd;border-left:3px solid #2196f3;border-radius:4px;font-size:13px;color:#1565c0}.video-filter.error{padding:12px 16px;color:#e74c3c}.results-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:.75rem}.spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top:3px solid #4a4a4a;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.results-empty{text-align:center;padding:3rem 2rem;color:#666}.results-display{padding:1.5rem;max-width:1200px;margin:0 auto}.results-header{margin-bottom:1.5rem;border-bottom:1px solid #e0e0e0;padding-bottom:.75rem}.results-header h2{margin:0 0 .25rem;color:#2c2c2c;font-size:1.2rem;font-weight:600}.results-count{margin:0;color:#666;font-size:.8rem}.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.result-card{background:white;border-radius:6px;overflow:hidden;border:1px solid #e0e0e0;transition:transform .2s,box-shadow .2s}.result-card:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.result-image-container{position:relative;width:100%;padding-top:56.25%;background-color:#f5f5f5;overflow:hidden}.result-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.result-image-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;background:#e0e0e0;color:#9a9a9a}.result-score{position:absolute;top:8px;right:8px;background-color:#4a4a4aeb;color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:500}.result-info{padding:.85rem}.result-title{margin:0 0 .4rem;font-size:.95rem;color:#2c2c2c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.result-timestamp,.result-detail{margin:.2rem 0;font-size:.8rem;color:#666}.result-path{font-family:monospace;background-color:#f5f5f5;padding:.3rem .45rem;border-radius:4px;font-size:.72rem;color:#555;word-break:break-all}.result-objects{margin-top:.6rem;font-size:.75rem;color:#666}.object-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.object-tag{display:inline-block;padding:.25rem .5rem;background-color:#e3f2fd;color:#1976d2;border-radius:4px;font-size:.75rem}.result-type-badge{display:inline-block;margin-top:.5rem;padding:.25rem .75rem;background-color:#f3e5f5;color:#7b1fa2;border-radius:12px;font-size:.8rem;font-weight:500}.result-link{display:inline-block;margin-top:1rem;padding:.5rem 1rem;background-color:#2196f3;color:#fff;text-decoration:none;border-radius:6px;font-weight:600;font-size:.9rem;transition:background-color .3s}.result-link:hover{background-color:#1976d2}.video-player-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.video-player-container{background:white;border-radius:12px;max-width:900px;width:100%;overflow:hidden;box-shadow:0 8px 32px #0000004d}.video-player-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0}.video-player-header h3{margin:0;font-size:1.1rem;color:#333}.close-video-button{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:.25rem .5rem;line-height:1;transition:color .2s}.close-video-button:hover{color:#d32f2f}.video-player{width:100%;max-height:70vh;background-color:#000}.video-timestamp-info{text-align:center;padding:.75rem;margin:0;background-color:#f9f9f9;color:#666;font-size:.9rem}.result-timestamp-container{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.result-actions{display:flex;gap:.5rem;flex-wrap:wrap}.play-video-button,.copy-info-button{padding:.5rem 1rem;color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s,background .3s;display:flex;align-items:center;justify-content:center;gap:.5rem;flex:1;min-width:120px}.play-video-button{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.play-video-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.copy-info-button{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.copy-info-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.copy-info-button.copied{background:linear-gradient(135deg,#4ade80 0%,#22c55e 100%)}.play-video-button:active,.copy-info-button:active{transform:translateY(0)}.app{min-height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.app-header{text-align:center;padding:1.5rem 1rem;background:#ffffff;border-bottom:1px solid #e0e0e0}.app-header h1{color:#2c2c2c;font-size:2rem;margin:0 0 .5rem;font-weight:600}.subtitle{color:#666;font-size:.9rem;margin:0}.app-main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:1.5rem 1rem}.main-tabs{display:flex;gap:0;justify-content:center;margin-bottom:2rem;background:#e8e8e8;padding:.35rem;border-radius:8px;max-width:500px;margin-left:auto;margin-right:auto}.tab-button{flex:1;padding:.85rem 2rem;font-size:1rem;font-weight:600;border:none;background:transparent;color:#666;border-radius:6px;cursor:pointer;transition:all .25s ease}.tab-button:hover{color:#4a4a4a}.tab-button.active{background:#ffffff;color:#2c2c2c;box-shadow:0 2px 4px #0000001a}.search-mode-toggle{display:inline-flex;gap:.4rem;margin:0 auto 1.5rem;background:#f8f8f8;padding:.25rem;border-radius:20px;border:1px solid #e0e0e0}.mode-button{padding:.4rem 1rem;font-size:.8rem;font-weight:500;border:none;background:transparent;color:#7a7a7a;border-radius:16px;cursor:pointer;transition:all .2s ease}.mode-button:hover{color:#4a4a4a}.mode-button.active{background:#4a4a4a;color:#fff;box-shadow:0 2px 4px #00000026;font-weight:600}.processing-videos-section{margin-top:2rem;padding:1.5rem;background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px}.processing-videos-section h2{color:#fff;margin:0 0 1rem;font-size:1.5rem}.search-container{margin-bottom:1.5rem;display:flex;flex-direction:column;align-items:center}.error-message{background:#e57373;color:#fff;padding:.75rem;border-radius:6px;margin:1rem 0;text-align:center;font-weight:500;font-size:.9rem}.app-footer{text-align:center;padding:1rem;background:#ffffff;border-top:1px solid #e0e0e0;color:#666;font-size:.75rem}.results-controls{width:100%;max-width:500px;margin:0 auto 1.5rem;background:#ffffff;padding:1rem;border-radius:6px;border:1px solid #e0e0e0}.results-slider-label{display:flex;flex-direction:column;gap:.5rem;cursor:pointer}.results-slider-label span{font-weight:500;color:#4a4a4a;font-size:.85rem;text-align:center}.results-slider{width:100%;height:4px;border-radius:2px;background:#d0d0d0;outline:none;opacity:.8;transition:opacity .2s;cursor:pointer;-webkit-appearance:none}.results-slider:hover{opacity:1}.results-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#4a4a4a;cursor:pointer;box-shadow:0 1px 4px #0003;border:2px solid #ffffff;transition:transform .2s}.results-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.results-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#4a4a4a;cursor:pointer;box-shadow:0 1px 4px #0003;border:2px solid #ffffff;transition:transform .2s}.results-slider::-moz-range-thumb:hover{transform:scale(1.1)}.slider-markers{display:flex;justify-content:space-between;font-size:.75rem;color:#999;padding:0 4px}.processing-videos-section{margin-top:1.5rem;padding:1rem;background:#ffffff;border-radius:6px;border:1px solid #e0e0e0}.processing-videos-section h2{color:#2c2c2c;margin:0 0 1rem;font-size:1.2rem;font-weight:600}@media (max-width: 768px){.app-header h1{font-size:1.5rem}.subtitle{font-size:.8rem}.main-tabs{flex-direction:column;gap:.5rem}.tab-button{width:100%}.search-mode-toggle{flex-direction:column;gap:.5rem}.mode-button{width:100%}}
