*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{display:flex;min-height:100vh}.main-content{background-color:#f8f9fa;flex:1 1;margin-left:60px;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.container{margin:0 auto;max-width:95vw;padding:10px}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.card,.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:500;margin-bottom:5px}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px;width:100%}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.loading{color:#666;padding:40px;text-align:center}.error{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;margin-bottom:20px;padding:10px}.timeline-container{background:#fff;border:1px solid #e9ecef;border-radius:8px;display:flex;flex-direction:column;margin:20px 0;overflow:hidden}.timeline-scroll{background:#f8f9fa;display:flex;flex-direction:column;overflow-x:auto}.timeline-scroll::-webkit-scrollbar{height:8px}.timeline-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.timeline-scroll::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.timeline-scroll::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.timeline-content{display:flex;flex-direction:column;min-width:-webkit-max-content;min-width:max-content}.timeline-items{display:flex;gap:1px;padding:10px 10px 30px}.timeline-item{align-items:center;border-radius:3px;cursor:pointer;display:flex;height:30px;justify-content:center;position:relative;transition:all .2s ease;width:12px}.timeline-item.no-video{background-color:#e9ecef;border:1px solid #dee2e6}.timeline-item.has-video{background-color:#28a745;border:1px solid #1e7e34;box-shadow:0 2px 4px #28a7454d}.timeline-item:hover{transform:scaleY(1.3);z-index:10}.timeline-item.has-video:hover{background-color:#218838;box-shadow:0 4px 8px #28a74566}.timeline-labels{background:#fff;border-top:1px solid #e9ecef;color:#666;display:flex;font-size:10px;gap:0;justify-content:flex-start;padding:8px 10px}.timeline-label{color:#007bff;flex-shrink:0;font-size:10px;font-weight:600;text-align:center;width:12px}.timeline-item:after{border-left:3px solid #0000;border-right:3px solid #0000;border-top:4px solid #007bff;content:"";height:0;left:50%;opacity:0;position:absolute;top:-2px;transform:translateX(-50%);transition:opacity .2s ease;width:0}.timeline-item.has-video:after{opacity:1}.timeline-item:hover:after{border-top-color:#0056b3;opacity:1}.timeline-legend{background:#f8f9fa;border-radius:6px;display:flex;font-size:13px;gap:30px;justify-content:center;margin:15px 0;padding:10px}.timeline-legend-item{align-items:center;display:flex;gap:8px}.timeline-legend-color{border:1px solid #dee2e6;border-radius:3px;height:16px;width:16px}.timeline-legend-color.has-video{background-color:#28a745;border-color:#1e7e34}.timeline-legend-color.no-video{background-color:#e9ecef;border-color:#dee2e6}.video-section{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 8px #0000001a;padding:15px}.video-row-top{display:flex;justify-content:center;margin-bottom:15px}.map-item{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 8px #0000001a;padding:15px;transition:transform .2s ease,box-shadow .2s ease}.front-camera:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.video-row-bottom{grid-gap:min(20px,2vw);align-items:start;display:grid;gap:min(20px,2vw);grid-template-columns:1fr 1fr 1fr;max-width:100%}.front-camera,.side-camera{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 8px #0000001a;display:flex;flex-direction:column;padding:15px;transition:transform .2s ease,box-shadow .2s ease}.front-camera:hover,.map-item:hover,.side-camera:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.map-item{aspect-ratio:1;min-height:auto}.front-camera .video-container,.front-camera .youtube-container,.side-camera .video-container,.side-camera .youtube-container{background:#0000;border-radius:8px;box-shadow:0 2px 8px #0000001a;height:0;margin:0 auto;max-width:100%;overflow:hidden;padding-bottom:56.25%;position:relative;width:100%}.front-camera,.side-camera{max-width:min(600px,30vw);width:100%}.map-item{max-width:min(400px,30vw);width:100%}@media (max-width:1400px){.container{max-width:95vw}.front-camera,.side-camera{max-width:min(450px,28vw)}.map-item{max-width:min(350px,25vw)}}@media (max-width:1200px){.front-camera,.side-camera{max-width:min(400px,32vw)}.map-item{max-width:min(300px,28vw)}}@media (max-width:1000px){.front-camera,.side-camera{max-width:min(350px,35vw)}.map-item{max-width:min(250px,30vw)}}@media (max-width:768px){.front-camera,.map-item,.side-camera{max-width:none}.video-row-bottom{gap:12px;grid-template-columns:1fr}}.video-item h4,.video-item h5{color:#333;font-weight:600;margin-bottom:15px}.video-item video{background-color:#000;border-radius:8px;width:100%}.video-container video{brightness:1;contrast:1;background-color:initial;border-radius:8px;filter:none;height:100%;object-fit:cover;opacity:1;width:100%}.video-container video::-webkit-media-controls,.video-container video::-webkit-media-controls-panel{background-color:#0000004d}.video-container video::-webkit-media-controls-current-time-display,.video-container video::-webkit-media-controls-play-button,.video-container video::-webkit-media-controls-time-remaining-display,.video-container video::-webkit-media-controls-timeline{background-color:#0000004d;color:#fff}.video-container,.video-item{filter:none!important;opacity:1!important}.video-container video{filter:brightness(1.1) contrast(1.1) saturate(1.1)!important}.video-container:before{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;content:"";height:40px;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .3s ease;width:40px;z-index:1}.video-container.loading:before{opacity:1}.youtube-container{border-radius:8px;box-shadow:0 2px 8px #0000001a}.map-container{box-shadow:0 2px 8px #0000001a;height:100%}@media (max-width:1024px){.main-content{margin-left:50px}.container{max-width:100%;padding:8px}.front-camera,.map-item,.side-camera,.video-section{padding:12px}}@media (max-width:768px){.main-content{margin-left:45px}}@media (max-width:480px){.main-content{margin-left:0}}@media (min-width:1600px){.container{max-width:95vw;padding:20px}.front-camera,.side-camera{max-width:min(700px,28vw)}.map-item{max-width:min(450px,25vw)}.video-row-bottom{gap:min(30px,3vw)}}@media (min-width:2000px){.container{max-width:95vw;padding:30px}.front-camera,.side-camera{max-width:min(800px,25vw)}.map-item{max-width:min(500px,20vw)}.video-row-bottom{gap:min(40px,4vw)}}@media (min-width:2560px){.container{max-width:95vw;padding:40px}.front-camera,.side-camera{max-width:min(900px,22vw)}.map-item{max-width:min(600px,18vw)}.video-row-bottom{gap:min(50px,5vw)}}@media (max-width:768px){.container{max-width:100%;padding:5px}.video-row-top{margin-bottom:12px}.front-camera,.map-item,.side-camera{max-width:100%;padding:10px}.video-row-bottom{gap:10px;grid-template-columns:1fr}.front-camera .video-container,.side-camera .video-container{padding-bottom:60%}}.gps-info{background:#f8f9fa;border-radius:4px;color:#666;font-size:12px;margin-top:10px;padding:10px}.time-controls{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 8px #0000001a;padding:20px}.play-controls{align-items:center;background-color:#f8f9fa;border-radius:8px;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px;padding:15px}.time-navigation input[type=range]{-webkit-appearance:none;appearance:none;background:#0000;cursor:pointer}.time-navigation input[type=range]::-webkit-slider-track{background:#ddd;border-radius:3px;height:6px}.time-navigation input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#007bff;border-radius:50%;cursor:pointer;height:20px;width:20px}.time-navigation input[type=range]::-moz-range-track{background:#ddd;border:none;border-radius:3px;height:6px}.time-navigation input[type=range]::-moz-range-thumb{background:#007bff;border:none;border-radius:50%;cursor:pointer;height:20px;width:20px}.side-nav{background:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;height:100vh;left:0;overflow:visible;position:fixed;top:0;width:60px;z-index:1000}.side-nav-header{background:#fff;border-bottom:1px solid #e9ecef;padding:20px 15px}.logo-icon,.nav-logo{align-items:center;display:flex;justify-content:center}.logo-icon{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;font-size:1.5rem;height:30px;width:30px}.side-nav-menu{display:flex;flex:1 1;flex-direction:column;gap:8px;padding:20px 0}.logout-btn,.side-nav-item{align-items:center;background:none;border:none;border-radius:8px;color:#6c757d;cursor:pointer;display:flex;justify-content:center;margin:0 10px;padding:12px;position:relative;transition:all .2s ease;width:100%}.logout-btn:hover,.side-nav-item:hover{background:#e9ecef;color:#495057}.side-nav-item.active{background:#fff;border:1px solid #e9ecef;color:#212529}.side-nav-icon{align-items:center;display:flex;flex-shrink:0;font-size:1.1rem;height:24px;justify-content:center;transition:all .2s ease;width:24px}.side-nav-item.active .side-nav-icon{font-size:1.4rem;height:32px;width:32px}.logout-btn:hover .side-nav-icon,.side-nav-item:hover .side-nav-icon{transform:scale(1.1)}.selected-item-description{display:none}.side-nav-footer{background:#fff;border-top:1px solid #e9ecef;padding:15px}.logout-btn{color:#dc3545}.logout-btn:hover{background:#f8d7da;color:#721c24}.logout-btn:hover:after,.side-nav-item:hover:after{animation:fadeIn .2s ease;background:#212529;border-radius:4px;color:#fff;content:attr(title);font-size:.85rem;left:70px;padding:6px 12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap;z-index:1001}@keyframes fadeIn{0%{opacity:0;transform:translateY(-50%) translateX(-5px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}@media (max-width:768px){.side-nav{width:50px}.logout-btn:hover:after,.side-nav-item:hover:after{font-size:.8rem;left:60px;padding:5px 10px}.logout-btn,.side-nav-item{margin:0 5px;padding:10px}.logo-icon{font-size:1.3rem;height:25px;width:25px}.side-nav-icon{font-size:1rem;height:20px;width:20px}.side-nav-item.active .side-nav-icon{font-size:1.2rem;height:28px;width:28px}}@media (max-width:480px){.side-nav{width:45px}.logout-btn:hover:after,.side-nav-item:hover:after{font-size:.75rem;left:55px;padding:4px 8px}}.annotations-view{background-color:#f8f9fa;margin-left:60px;min-height:100vh;padding:20px;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.annotations-header{margin-bottom:30px}.annotations-header h1{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:10px}.annotations-header p{color:#6c757d;font-size:1.1rem;margin:0}.annotations-content{display:flex;gap:20px;height:calc(100vh - 120px)}.vehicles-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-y:auto;padding:20px;width:300px}.vehicles-panel h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin:0 0 20px}.vehicles-list{display:flex;flex-direction:column;gap:10px}.vehicle-item{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;padding:15px;transition:all .3s ease}.vehicle-item:hover{background-color:#f8f9ff;border-color:#3498db;box-shadow:0 4px 8px #3498db33;transform:translateY(-2px)}.vehicle-item.selected{background-color:#e3f2fd;border-color:#3498db;box-shadow:0 4px 8px #3498db4d}.vehicle-icon{font-size:1.5rem;margin-right:15px}.vehicle-info{flex:1 1}.vehicle-name{color:#2c3e50;font-weight:600;margin-bottom:5px}.vehicle-id{color:#6c757d;font-size:.9rem;margin-bottom:5px}.device-id{color:#8e8e93;font-size:.8rem;margin-bottom:10px}.annotation-stats{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin:10px 0;padding:8px}.stat-row{align-items:center;display:flex;font-size:.85rem;justify-content:space-between;margin-bottom:4px}.stat-row:last-child{margin-bottom:0}.stat-label{color:#6c757d;font-weight:500}.stat-value{color:#2c3e50;font-weight:600}.stat-value.annotated{color:#28a745}.stat-value.unprocessed{color:#e74c3c}.stat-value.total{color:#3498db}.progress-bar{background-color:#e9ecef;border-radius:4px;height:8px;margin-top:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#28a745,#20c997);height:100%;transition:width .3s ease}.images-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;flex:1 1;overflow-y:auto;padding:20px}.images-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.images-header h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin:0}.image-count-info{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.image-count{background-color:#3498db;border-radius:20px;color:#fff;font-size:.9rem;font-weight:500;padding:5px 12px}.camera-breakdown{display:flex;font-size:.8rem;gap:12px}.camera-stat{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;color:#6c757d;font-weight:500;padding:3px 8px}.images-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.image-item{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;overflow:hidden;transition:all .3s ease}.image-item:hover{border-color:#3498db;box-shadow:0 6px 12px #3498db4d;transform:translateY(-4px)}.image-thumbnail{background-color:#f8f9fa;height:150px;overflow:hidden;position:relative;width:100%}.image-thumbnail img{height:100%;object-fit:cover;width:100%}.image-placeholder{align-items:center;background-color:#e9ecef;color:#6c757d;display:flex;flex-direction:column;font-size:2rem;height:100%;justify-content:center;width:100%}.placeholder-text{color:#6c757d;font-size:.8rem;font-weight:500;margin-top:8px}.image-info{padding:15px}.image-id{color:#2c3e50;font-weight:600;margin-bottom:8px}.image-status{font-size:.9rem}.annotated{color:#28a745;font-weight:500}.pending{color:#ffc107;font-weight:500}.unprocessed{color:#e74c3c;font-weight:500}.no-selection{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:400px;justify-content:center;text-align:center}.no-selection-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.no-selection h3{color:#495057;margin:0 0 10px}.no-selection p{font-size:1.1rem;margin:0}.error,.loading{font-size:1.1rem;padding:40px;text-align:center}.loading{color:#6c757d}.error{color:#dc3545}.no-images{color:#6c757d;font-style:italic;padding:40px;text-align:center}@media (max-width:1024px){.annotations-view{margin-left:50px}.annotations-content{flex-direction:column;height:auto}.vehicles-panel{height:300px;width:100%}.images-panel{height:600px}}@media (max-width:768px){.annotations-view{margin-left:45px}.images-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.image-thumbnail{height:120px}}@media (max-width:480px){.annotations-view{margin-left:0}}.annotation-tool-modal{align-items:center;background-color:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;height:95vh;max-width:1400px;overflow:hidden;width:95vw}.modal-header{align-items:center;background-color:#f8f9fa;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#2c3e50;font-size:1.5rem;margin:0}.header-actions{align-items:center;display:flex;gap:15px}.class-selector-btn{background:#fff;border:2px solid #3498db;border-radius:6px;color:#3498db;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.class-selector-btn:hover{background:#3498db;color:#fff}.close-btn{align-items:center;background:#e74c3c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:40px;justify-content:center;transition:all .3s ease;width:40px}.close-btn:hover{background:#c0392b;transform:scale(1.1)}.class-selector{background-color:#f8f9fa;border-bottom:2px solid #e9ecef;padding:20px}.class-selector h4{color:#2c3e50;margin:0 0 15px}.class-options{display:flex;flex-wrap:wrap;gap:10px}.class-option{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 15px;transition:all .3s ease}.class-option:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.class-option.selected{background-color:#f8f9ff;box-shadow:0 4px 8px #3498db4d}.class-color{border-radius:50%;display:inline-block;height:12px;width:12px}.toolbar{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:15px 20px}.toolbar-section{color:#6c757d;font-size:.9rem}.toolbar-actions{display:flex;gap:10px}.save-btn{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .3s ease}.save-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.save-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.canvas-container{align-items:center;background-color:#f8f9fa;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px;position:relative}.annotation-canvas{background:#fff;border:2px solid #dee2e6;border-radius:8px;box-shadow:0 4px 8px #0000001a;cursor:crosshair;max-height:100%;max-width:100%}.image-loading{color:#6c757d;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e9ecef;border-radius:50%;border-top-color:#3498db;height:40px;margin:0 auto 15px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.annotations-list{background-color:#f8f9fa;border-top:1px solid #e9ecef;max-height:200px;overflow-y:auto;padding:20px}.annotations-list h4{color:#2c3e50;font-size:1.1rem;margin:0 0 15px}.annotations-items{display:flex;flex-direction:column;gap:8px}.annotation-item{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:6px;display:flex;gap:15px;padding:10px 15px}.annotation-class{font-weight:600;min-width:80px}.annotation-id{color:#6c757d;font-size:.9rem;min-width:50px}.delete-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;margin-left:auto;padding:5px 10px;transition:all .3s ease}.delete-btn:hover{background:#c82333;transform:scale(1.05)}@media (max-width:768px){.modal-content{height:98vh;width:98vw}.modal-header{padding:15px}.modal-header h2{font-size:1.2rem}.class-options,.toolbar{flex-direction:column}.toolbar{align-items:stretch;gap:10px}.canvas-container{padding:10px}.annotations-list{max-height:150px}}
/*# sourceMappingURL=main.c01d2de7.css.map*/