.robot-status{padding:16px}.robot-status-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e5e7eb}.robot-status-item:last-child{border-bottom:none}.robot-status-label{font-weight:500;color:#6b7280}.robot-status-value{font-weight:600;color:#1a1a1a}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.robot-map{width:100%;height:400px;border-radius:8px;overflow:hidden}.map-container{width:100%;height:100%}.leaflet-container{width:100%;height:100%;border-radius:8px}.robot-marker{background-color:#3b82f6;border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003}.camera-view{width:100%}.camera-image{width:100%;border-radius:8px;overflow:hidden}.camera-image img{width:100%;height:auto;display:block}.no-camera{text-align:center;padding:40px 20px;color:#6b7280;background:#f3f4f6;border-radius:8px}.detection-list{list-style:none;margin:0;padding:0}.detection-item{padding:12px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.detection-item:last-child{border-bottom:none}.detection-class{font-weight:500;color:#1a1a1a}.detection-confidence{font-size:14px;color:#6b7280}.no-detections{text-align:center;padding:20px;color:#9ca3af}.dashboard{padding:20px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.dashboard-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a}.dashboard-section h2{margin-bottom:16px;font-size:20px;color:#1a1a1a}.robot-status-dashboard{padding:20px;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.dashboard-header h2{margin:0;font-size:28px;color:#1a1a1a}.header-actions{display:flex;gap:12px;align-items:center}.refresh-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;font-size:14px;cursor:pointer}.refresh-select:hover{border-color:#9ca3af}.robot-select{min-width:180px;font-weight:500;border-color:#3b82f6;background-color:#eff6ff}.robot-select:hover{border-color:#2563eb;background-color:#dbeafe}.robot-select:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px #3b82f61a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.map-section{background:#fff;border-radius:12px;padding:12px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.map-section .section-header{margin-bottom:8px}.map-section .section-header h3{display:flex;align-items:center;gap:10px;margin:0;font-size:20px;color:#1a1a1a;font-weight:600}.map-section .section-header h3 svg{color:#3b82f6}.map-camera-container{display:flex;gap:20px;align-items:stretch}.map-container{flex:0 0 60%;height:500px;min-height:500px;max-height:500px;overflow:hidden}.camera-container{flex:0 0 calc(40% - 20px);height:500px;min-height:500px;background:#f9fafb;border-radius:8px;padding:16px;display:flex;flex-direction:column}.camera-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:16px;font-weight:600;color:#374151}.camera-header svg{color:#6b7280}.camera-view{flex:1;background:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid #e5e7eb}.camera-view img{width:100%;height:100%;object-fit:contain}.camera-placeholder{color:#9ca3af;font-size:14px;text-align:center;padding:20px}.status-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;border:2px solid transparent;transition:all .2s ease;cursor:pointer;box-shadow:0 1px 3px #0000001a}.status-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.status-card-active{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f64d}.status-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:10px;background-color:#f3f4f6}.status-card-blue .status-card-icon{background-color:#dbeafe;color:#3b82f6}.status-card-green .status-card-icon{background-color:#d1fae5;color:#10b981}.status-card-gray .status-card-icon{background-color:#f3f4f6;color:#6b7280}.status-card-orange .status-card-icon{background-color:#fed7aa;color:#f59e0b}.status-card-red .status-card-icon{background-color:#fee2e2;color:#ef4444}.status-card-content{flex:1}.status-card-title{font-size:14px;color:#6b7280;margin-bottom:4px}.status-card-value{font-size:28px;font-weight:700;color:#1a1a1a}.table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.robot-status-table{width:100%;border-collapse:collapse}.robot-status-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.robot-status-table th{padding:16px;text-align:left;font-weight:600;font-size:14px;color:#374151;text-transform:uppercase;letter-spacing:.05em}.robot-status-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s ease}.robot-status-table tbody tr:hover{background-color:#f9fafb}.robot-status-table td{padding:16px;font-size:14px;color:#1f2937}.robot-id{font-family:Courier New,monospace;font-weight:600;color:#1a1a1a}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:500}.status-badge svg{flex-shrink:0}.status-badge.status-active{background-color:#d1fae5;color:#065f46}.status-badge.status-inactive{background-color:#e5e7eb;color:#374151}.status-badge.status-unknown{background-color:#fef3c7;color:#92400e}.status-cell{display:flex;flex-direction:column;gap:6px}.status-task{font-size:12px;font-weight:600;color:#6b7280;text-transform:none}.metric-cell{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border-radius:6px;font-family:Courier New,monospace}.metric-cell svg{flex-shrink:0;opacity:.7}.battery-red,.temp-red{background-color:#fee2e2;color:#991b1b}.battery-orange,.temp-orange{background-color:#fed7aa;color:#92400e}.battery-green{background-color:#d1fae5;color:#065f46}.battery-gray,.temp-gray{background-color:#f3f4f6;color:#6b7280}.text-muted{color:#9ca3af;font-style:italic}.action-buttons{display:flex;gap:8px}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-secondary{background-color:#e5e7eb;color:#374151}.btn-secondary:hover:not(:disabled){background-color:#d1d5db}.btn-icon{padding:8px;background-color:transparent;border:1px solid #d1d5db}.btn-icon:hover:not(:disabled){background-color:#f3f4f6}.btn-edit:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6}.btn-delete:hover:not(:disabled){border-color:#ef4444;color:#ef4444;background-color:#fef2f2}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:32px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h3{margin:0 0 24px;font-size:24px;color:#1a1a1a}.robot-status-form{display:flex;flex-direction:column;gap:20px}.form-section-header{font-size:16px;font-weight:600;color:#374151;padding-top:12px;margin-top:12px;border-top:1px solid #e5e7eb}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#374151}.required{color:#ef4444}.form-group input[type=text],.form-group input[type=number]{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s ease}.form-group input[type=text]:focus,.form-group input[type=number]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input.error{border-color:#ef4444}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.error-message{font-size:13px;color:#ef4444}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:12px;padding-top:20px;border-top:1px solid #e5e7eb}.alert{padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:10px;font-size:14px}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.loading{text-align:center;padding:60px 20px;color:#6b7280;font-size:16px}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.empty-state p{color:#6b7280;font-size:16px;margin:0}.app-nav{display:flex;gap:20px}.app-nav a{color:#fff;text-decoration:none;padding:8px 16px;border-radius:6px;transition:background-color .2s ease}.app-nav a:hover{background-color:#ffffff1a}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}.header-actions{width:100%;flex-direction:column}.refresh-select,.btn{width:100%}.table-container{overflow-x:auto}.robot-status-table{min-width:600px}.modal-content{padding:24px}.map-camera-container{flex-direction:column}.map-container,.camera-container{flex:1 1 100%;width:100%}.camera-container{min-height:300px}}.robot-position-map{position:relative;width:100%;height:500px;background-color:#f9fafb;border-radius:12px;overflow:visible;box-shadow:0 1px 3px #0000001a;gap:12px;padding:0;display:block}.map-background{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.8}.map-canvas{position:absolute;top:0;left:0;width:100%;height:100%;cursor:crosshair;-webkit-user-select:none;user-select:none}.map-canvas-wrapper{position:relative;flex:1;min-width:0;border-radius:12px;overflow:visible;background-color:#f9fafb;width:100%;height:100%}.map-side-panels{display:flex;flex-direction:column;gap:12px;min-width:340px;flex-shrink:0}.robot-position-map:has(.map-side-panels>*){display:flex}.robot-position-map.with-path-drawing{display:flex}.map-canvas:active{cursor:grab}.subaction-menu{position:absolute;z-index:9999;min-width:280px;max-width:350px;width:auto;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px;box-shadow:0 8px 24px #0003;max-height:400px;display:flex;flex-direction:column}.subaction-menu-title{font-size:12px;font-weight:600;color:#374151;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.subaction-menu-checkboxes{max-height:200px;overflow-y:auto;overflow-x:hidden;margin-bottom:12px;flex-shrink:1;scrollbar-width:thin;scrollbar-color:#d1d5db #f9fafb}.subaction-menu-checkboxes::-webkit-scrollbar{width:8px}.subaction-menu-checkboxes::-webkit-scrollbar-track{background:#f9fafb;border-radius:4px}.subaction-menu-checkboxes::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.subaction-menu-checkboxes::-webkit-scrollbar-thumb:hover{background:#9ca3af}.subaction-checkbox-label{display:flex;align-items:center;padding:8px 10px;margin:2px 0;cursor:pointer;border-radius:4px;transition:background-color .15s;white-space:nowrap}.subaction-checkbox-label:hover{background-color:#f3f4f6}.subaction-checkbox-label input[type=checkbox]{margin-right:10px;cursor:pointer;width:16px;height:16px;flex-shrink:0}.subaction-checkbox-label span{font-size:13px;color:#374151;-webkit-user-select:none;user-select:none;white-space:nowrap;overflow:visible}.subaction-option-btn{display:block;width:100%;text-align:left;padding:8px 10px;margin:2px 0;border:1px solid transparent;border-radius:4px;background:#fff;font-size:13px;color:#374151;cursor:pointer;transition:background-color .15s,border-color .15s}.subaction-option-btn:hover{background-color:#f3f4f6;border-color:#e5e7eb}.subaction-menu-buttons{display:flex;gap:8px;padding-top:8px;border-top:1px solid #e5e7eb;flex-shrink:0}.subaction-apply-btn,.subaction-cancel-btn{flex:1;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;border:none}.subaction-apply-btn{background:#10b981;color:#fff}.subaction-apply-btn:hover:not(:disabled){background:#059669}.subaction-apply-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.subaction-cancel-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.subaction-cancel-btn:hover{background:#e5e7eb}.subaction-menu-select,.path-subaction-select,.path-def-input-select{width:100%;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#111827}.map-legend{position:absolute;top:16px;right:16px;background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 2px 8px #00000026;z-index:10}.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;color:#374151}.legend-item:last-child{margin-bottom:0}.legend-divider{height:1px;background-color:#e5e7eb;margin:8px 0}.legend-item.legend-info{font-size:11px;color:#6b7280;margin-bottom:4px}.legend-icon{width:20px;height:16px;border-radius:3px;border:2px solid #ffffff}.legend-icon.active{background-color:#10b981}.legend-icon.inactive{background-color:#6b7280}.legend-battery{width:20px;height:8px;border:1px solid #374151;border-radius:2px;background:linear-gradient(to right,#ef4444,#f59e0b,#10b981)}.legend-path{width:20px;height:16px;position:relative;display:flex;align-items:center;justify-content:center}.legend-path:before{content:"";position:absolute;width:14px;height:2px;background-color:#3b82f6;border-radius:1px}.legend-path:after{content:"";position:absolute;width:4px;height:4px;background-color:#3b82f6;border-radius:50%;right:2px;z-index:1}.map-empty-state{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#9ca3af;font-size:16px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.map-controls{position:absolute;bottom:16px;left:16px;display:flex;flex-direction:column;gap:8px;z-index:10}.map-control-btn{width:40px;height:40px;min-width:40px;min-height:40px;background:#fff;border:1px solid #d1d5db;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000001a;font-size:18px;padding:0}.map-control-btn:hover{background-color:#f3f4f6;border-color:#9ca3af}.map-control-btn:active{transform:scale(.95)}.map-control-btn.active{background-color:#dbeafe;border-color:#3b82f6;color:#3b82f6}.map-control-btn-clear{background-color:#ef4444;color:#fff;border-color:#dc2626}.map-control-btn-clear:hover{background-color:#dc2626;border-color:#b91c1c}.map-info{position:absolute;bottom:16px;right:16px;background:#fff;padding:8px 12px;border-radius:6px;font-size:12px;color:#6b7280;box-shadow:0 1px 3px #0000001a;font-family:Courier New,monospace}.recorded-positions-panel{position:absolute;top:16px;left:16px;background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 2px 8px #00000026;z-index:10;max-width:280px;max-height:350px;display:flex;flex-direction:column}.recorded-positions-panel:before{content:"";position:absolute;left:12px;top:8px;width:4px;height:4px;background-color:#3b82f6;border-radius:50%;box-shadow:0 8px #3b82f6,0 16px #3b82f6}.recorded-positions-panel h4{margin:0 0 8px;font-size:13px;font-weight:600;color:#374151}.recorded-positions-list{overflow-y:auto;font-size:12px;color:#6b7280}.recorded-position-item{display:flex;gap:8px;align-items:center;padding:6px 0;border-bottom:1px solid #f3f4f6;flex-wrap:wrap}.recorded-position-item:last-child{border-bottom:none}.position-index{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:#3b82f6;color:#fff;border-radius:4px;font-size:11px;font-weight:600}.position-coords{font-family:Courier New,monospace;font-weight:500;color:#374151}.position-desc{font-size:11px;color:#9ca3af;width:100%;word-break:break-word}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background:#fff;padding:24px;border-radius:12px;box-shadow:0 10px 40px #0003;min-width:300px;max-width:400px}.modal-content h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937}.modal-info{background-color:#f9fafb;padding:12px;border-radius:8px;margin-bottom:16px;border-left:4px solid #3b82f6}.modal-info p{margin:0;font-size:13px;color:#374151;font-family:Courier New,monospace}.modal-input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-bottom:16px;box-sizing:border-box}.modal-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;gap:12px}.modal-btn-confirm,.modal-btn-cancel{flex:1;padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.modal-btn-confirm{background-color:#3b82f6;color:#fff}.modal-btn-confirm:hover{background-color:#2563eb}.modal-btn-cancel{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.modal-btn-cancel:hover{background-color:#e5e7eb}.recorded-path-panel{position:relative;background:#fff;padding:12px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:12;border-left:4px solid #3b82f6;display:flex;flex-direction:column;flex:1;min-height:0;overflow:visible}.path-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;padding-right:8px;border-bottom:1px solid #f3f4f6}.path-panel-header h4{margin:0;font-size:13px;font-weight:600;color:#1f2937}.path-panel-controls{display:flex;align-items:center;gap:8px;margin-bottom:8px}.path-toggle{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#374151;-webkit-user-select:none;user-select:none}.path-toggle input{width:14px;height:14px}.path-clear-btn{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.path-clear-btn:hover{color:#ef4444}.path-panel-list{overflow-y:auto;max-height:150px;margin-bottom:8px;font-size:12px}.path-item{display:flex;gap:8px;align-items:center;padding:4px 8px 4px 0;border-bottom:1px solid #f3f4f6}.path-item:last-child{border-bottom:none}.path-number{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background-color:#3b82f6;color:#fff;border-radius:3px;font-size:10px;font-weight:600;flex-shrink:0}.path-coords{font-family:Courier New,monospace;color:#374151;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.path-coords-editable{display:flex;gap:4px;flex:1;align-items:center}.path-input{width:85px;padding:4px 6px;border:1px solid #d1d5db;border-radius:4px;font-family:Courier New,monospace;font-size:11px;color:#374151;background-color:#fff;transition:all .2s ease}.path-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;background-color:#f0f7ff}.path-input::placeholder{color:#9ca3af}.path-delete-btn{padding:0;width:20px;height:20px;background:none;border:none;color:#9ca3af;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s ease;flex-shrink:0}.path-delete-btn:hover{background-color:#fee2e2;color:#ef4444}.path-delete-btn:active{transform:scale(.9)}.path-panel-footer{font-size:11px;color:#9ca3af;padding-top:6px;border-top:1px solid #f3f4f6;text-align:center}.path-def-panel{position:relative;background:#fff;padding:12px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:12;border-left:4px solid #8b5cf6;display:flex;flex-direction:column;flex-shrink:0}.path-def-header{margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #f3f4f6}.path-def-header h4{margin:0;font-size:13px;font-weight:600;color:#1f2937}.path-def-content{display:flex;flex-direction:column;gap:10px}.path-def-field{display:flex;flex-direction:column;gap:5px}.path-def-field label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.path-def-input-time{padding:6px 8px;border:1px solid #d1d5db;border-radius:4px;font-family:Courier New,monospace;font-size:12px;color:#374151;background-color:#fff;transition:all .2s ease}.path-def-input-time:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf61a;background-color:#faf5ff}.path-def-input-repeat{padding:6px 8px;border:1px solid #d1d5db;border-radius:4px;font-family:Courier New,monospace;font-size:12px;color:#374151;background-color:#fff;transition:all .2s ease;text-align:center}.path-def-input-repeat:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf61a;background-color:#faf5ff}.path-save-task-btn{width:100%;padding:8px 12px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.path-save-task-btn:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 12px #8b5cf64d}.path-save-task-btn:active:not(:disabled){transform:scale(.98)}.path-save-task-btn:disabled{opacity:.6;cursor:not-allowed}.path-save-message{padding:8px 10px;border-radius:6px;font-size:12px;font-weight:500;margin-top:8px;text-align:center;animation:slideIn .3s ease-out}.path-save-message-success{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.path-save-message-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.position-tooltip{background:#fff;padding:8px 12px;border-radius:6px;box-shadow:0 2px 8px #00000026;font-size:12px;color:#374151;z-index:20;pointer-events:none;max-width:150px;font-family:Courier New,monospace}.tooltip-content{line-height:1.5}.tooltip-content strong{font-weight:600}.clicked-position-display{position:absolute;top:16px;left:16px;z-index:15;max-width:320px}.position-info{background:#fff;padding:16px;border-radius:8px;box-shadow:0 4px 12px #00000026;border-left:4px solid #3b82f6}.position-info h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#1f2937}.position-details{margin-bottom:12px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;border-bottom:1px solid #f3f4f6}.detail-row:last-child{border-bottom:none}.detail-row .label{font-weight:500;color:#6b7280}.detail-row .value{font-weight:600;color:#374151;font-family:Courier New,monospace}.clear-position-btn{width:100%;padding:8px 12px;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-position-btn:hover{background-color:#e5e7eb;border-color:#9ca3af}.clear-position-btn:active{transform:scale(.98)}@media (max-width: 768px){.robot-position-map{height:400px}.map-legend{top:8px;right:8px;padding:8px 12px;font-size:12px}.legend-item{margin-bottom:6px}.legend-icon{width:16px;height:12px}.position-info{max-width:280px}.recorded-path-panel{max-width:520px}.path-panel-list{max-height:120px}}@media (max-width: 1024px){.map-side-panels{min-width:300px}}@media (max-width: 768px){.robot-position-map{flex-direction:column;height:auto}.map-canvas-wrapper{height:350px}.map-side-panels{min-width:100%;flex-direction:row;max-height:200px}.recorded-path-panel{flex:1;max-height:200px}.path-def-panel{flex-shrink:0}.path-panel-list{max-height:120px}}@media (max-width: 480px){.robot-position-map{height:auto;gap:8px;padding:8px}.map-canvas-wrapper{height:300px;border-radius:8px}.map-side-panels{flex-direction:column;min-width:100%;gap:8px}.recorded-path-panel{padding:10px;max-height:none;flex:1}.path-def-panel{padding:10px}.map-legend{padding:6px 10px}.position-info{padding:12px;font-size:12px}.position-info h4{font-size:13px}.detail-row{font-size:12px;padding:4px 0}.path-panel-header h4{font-size:12px}.path-panel-list{max-height:100px;font-size:11px}.path-input{width:60px;font-size:10px}.path-number{width:16px;height:16px;font-size:9px}.path-coords,.path-panel-footer{font-size:10px}}.history-charts-container{background:#fff;border-radius:8px;padding:20px;margin-top:20px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.history-header h3{display:flex;align-items:center;gap:10px;margin:0;font-size:18px;color:#1f2937}.time-range-selector{display:flex;gap:10px}.time-btn{display:flex;flex-direction:column;align-items:center;padding:10px 20px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s ease;font-weight:500;color:#6b7280}.time-detail{font-size:10px;font-weight:400;margin-top:4px;opacity:.8}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:20px}.chart-card{background:#f9fafb;border-radius:8px;padding:15px;border:1px solid #e5e7eb}.chart-header{display:flex;align-items:center;gap:8px;margin-bottom:15px;font-weight:600;color:#374151;font-size:14px}.chart-header svg{color:#6b7280}.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.history-loading .spin{animation:spin 1s linear infinite;color:#3b82f6}.history-loading p{margin-top:15px;font-size:14px}.history-error{padding:40px 20px;text-align:center;color:#ef4444;background:#fef2f2;border-radius:8px;border:1px solid #fecaca}.history-error p{margin:0;font-size:14px}.history-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#9ca3af;text-align:center}.history-empty-state p{margin-top:10px;font-size:14px}@media (max-width: 1200px){.charts-grid{grid-template-columns:1fr}.time-range-selector{flex-direction:column}.time-btn{width:100%}}@media (max-width: 768px){.history-header{flex-direction:column;gap:15px;align-items:flex-start}.time-range-selector{width:100%}.charts-grid{grid-template-columns:1fr}.chart-card{padding:10px}}.recharts-tooltip-wrapper{outline:none}.recharts-default-tooltip{background:#fffffff2!important;border:1px solid #e5e7eb!important;border-radius:6px!important;box-shadow:0 4px 6px -1px #0000001a!important}.recharts-tooltip-label{font-weight:600;color:#374151;margin-bottom:5px}.recharts-tooltip-item{font-size:13px}.recharts-legend-wrapper{padding-top:10px}.recharts-legend-item-text{font-size:12px;color:#6b7280}.detection-list-container{width:100%;padding:20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:20px}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:#6b7280;font-size:16px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:20px;color:#ef4444}.error-state svg{stroke-width:1.5px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:15px;color:#9ca3af}.empty-state svg{opacity:.3;stroke-width:1.5px}.empty-state p{font-size:18px;font-weight:500;color:#6b7280}.empty-state span{font-size:14px;color:#9ca3af}.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.header-info{display:flex;align-items:center;gap:12px}.header-info h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.header-info svg{color:#3b82f6;stroke-width:1.5px}.detection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-top:20px}.detection-card{background:linear-gradient(135deg,#f9fafb,#fff);border:1px solid #e5e7eb;border-radius:10px;padding:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.detection-card:hover{border-color:#3b82f6;box-shadow:0 10px 25px #3b82f626;transform:translateY(-2px)}.detection-card.expanded{grid-column:1 / -1;border-color:#3b82f6;box-shadow:0 10px 25px #3b82f626}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.header-left{display:flex;align-items:center;gap:12px}.detection-id{font-weight:600;color:#1f2937;font-size:14px}.object-class-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize}.header-right{display:flex;gap:10px}.confidence-badge{padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;min-width:70px;text-align:center}.card-body{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.body-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;gap:10px}.body-row .label{color:#6b7280;font-weight:500;min-width:100px}.body-row .value{color:#1f2937;font-weight:500;flex:1;text-align:right}.body-row .robot-id{background:#f3f4f6;padding:4px 8px;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:12px}.body-row .model-name{background:#fef3c7;color:#92400e;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.body-row .timestamp{font-size:12px;color:#6b7280}.confidence-detail{display:flex;align-items:center;gap:8px;flex:1}.confidence-bar{flex:1;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;min-width:60px}.confidence-fill{height:100%;transition:width .3s ease}.bounding-box-display{background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;padding:12px;margin:12px 0;font-size:12px}.bbox-label{font-weight:600;color:#374151;margin-bottom:8px;display:flex;align-items:center;gap:6px}.bbox-info{display:flex;flex-direction:column;gap:6px}.bbox-row{display:flex;justify-content:space-between;padding:4px 0;color:#6b7280}.bbox-row span:first-child{font-weight:500;min-width:80px}.bbox-row span:last-child{color:#1f2937;font-family:Monaco,Courier New,monospace;font-weight:600}.expanded-metadata{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-top:16px;max-height:400px;overflow-y:auto}.metadata-title{font-weight:600;color:#374151;margin-bottom:12px;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.metadata-content{display:flex;flex-direction:column;gap:8px}.metadata-row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;font-size:12px;border-bottom:1px solid #e5e7eb}.metadata-row:last-child{border-bottom:none}.metadata-key{color:#6b7280;font-weight:500;min-width:120px}.metadata-value{color:#1f2937;font-family:Monaco,Courier New,monospace;word-break:break-word;flex:1;text-align:right}.card-footer{display:flex;justify-content:center;padding-top:12px;border-top:1px solid #e5e7eb}.expand-hint{font-size:12px;color:#9ca3af;font-style:italic}.detection-table-container{width:100%;margin-top:20px}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb}.detection-results-table{width:100%;border-collapse:collapse;font-size:13px}.detection-results-table thead{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-bottom:2px solid #d1d5db}.detection-results-table th{padding:14px 16px;text-align:left;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.detection-results-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s ease;cursor:pointer}.detection-results-table tbody tr:hover{background-color:#f9fafb}.detection-results-table tbody tr:last-child{border-bottom:none}.detection-results-table td{padding:12px 16px;color:#1f2937}.class-badge{background:#dbeafe;color:#1e40af;padding:4px 10px;border-radius:4px;font-weight:500;display:inline-block}.confidence-cell{display:flex;align-items:center;gap:8px}.confidence-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.timestamp-cell{font-size:12px;color:#6b7280}@media (max-width: 768px){.detection-grid{grid-template-columns:1fr}.detection-card.expanded{grid-column:1}.card-header{flex-direction:column;align-items:flex-start;gap:10px}.header-right{width:100%}.body-row{flex-direction:column;align-items:flex-start}.body-row .label{min-width:auto;margin-bottom:4px}.body-row .value{text-align:left}.detection-results-table{font-size:12px}.detection-results-table th,.detection-results-table td{padding:10px 12px}.detection-results-table th:nth-child(5),.detection-results-table td:nth-child(5),.detection-results-table th:nth-child(6),.detection-results-table td:nth-child(6){display:none}}.expanded-metadata::-webkit-scrollbar{width:6px}.expanded-metadata::-webkit-scrollbar-track{background:#f3f4f6;border-radius:3px}.expanded-metadata::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.expanded-metadata::-webkit-scrollbar-thumb:hover{background:#9ca3af}.detection-dashboard{padding:20px;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.header-title{display:flex;align-items:center;gap:12px}.header-title h2{margin:0;font-size:24px;color:#1f2937}.refresh-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #3b82f64d}.refresh-btn:disabled{background:#9ca3af;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tab-selector{display:flex;gap:10px;margin-bottom:25px;background:#fff;padding:10px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.tab-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:2px solid #e5e7eb;border-radius:6px;background:#fff;color:#6b7280;font-weight:600;cursor:pointer;transition:all .2s}.tab-btn:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.tab-btn.active{border-color:#3b82f6;background:#3b82f6;color:#fff}.time-range-section{display:flex;align-items:center;gap:12px;margin-bottom:25px;padding:15px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.time-range-section span{font-weight:600;color:#374151}.time-range-buttons{display:flex;gap:10px;margin-left:auto}.time-btn{padding:8px 16px;border:2px solid #e5e7eb;border-radius:6px;background:#fff;color:#6b7280;font-weight:500;cursor:pointer;transition:all .2s}.time-btn:hover{border-color:#3b82f6;background:#eff6ff;color:#3b82f6}.time-btn.active{border-color:#3b82f6;background:#3b82f6;color:#fff}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{display:flex;align-items:center;gap:20px;padding:25px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #00000026}.stat-icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-card.total .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card.types .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.stat-card.robots .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card.confidence .stat-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-info{flex:1}.stat-value{font-size:32px;font-weight:700;color:#1f2937;line-height:1}.stat-label{margin-top:5px;font-size:14px;color:#6b7280;font-weight:500}.charts-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:20px;margin-bottom:30px}.chart-container{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a;position:relative;overflow:visible}.chart-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #e5e7eb}.chart-header h3{margin:0;font-size:16px;color:#1f2937;font-weight:600}.chart-filter{display:flex;align-items:center;gap:8px;margin-left:auto}.chart-filter label{font-size:13px;color:#6b7280;font-weight:500;white-space:nowrap}.robot-filter-select{padding:6px 10px;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#374151;font-size:13px;cursor:pointer;transition:all .2s;min-width:150px;position:relative;z-index:10}.robot-filter-select:hover{border-color:#9ca3af;box-shadow:0 1px 3px #0000001a}.robot-filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;z-index:1000}.filters-section{background:#fff;border-radius:8px;padding:20px;margin-bottom:30px;box-shadow:0 1px 3px #0000001a}.filters-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #e5e7eb}.filters-header h3{margin:0;font-size:16px;color:#1f2937;font-weight:600;flex:1}.clear-filters-btn{padding:6px 12px;background:transparent;color:#6b7280;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s}.clear-filters-btn:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{font-size:13px;font-weight:600;color:#374151}.filter-group select{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#1f2937;font-size:14px;cursor:pointer;transition:all .2s}.filter-group select:hover{border-color:#9ca3af}.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.error-message{display:flex;align-items:center;gap:10px;padding:15px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;margin-bottom:20px}.detections-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-header{padding:20px;border-bottom:2px solid #e5e7eb}.table-header h3{margin:0;font-size:18px;color:#1f2937;font-weight:600}.loading,.no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.loading p,.no-data p{margin-top:15px;font-size:14px}.table-wrapper{overflow-x:auto}.detections-table{width:100%;border-collapse:collapse}.detections-table thead{background:#f9fafb}.detections-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}.detections-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s}.detections-table tbody tr:hover{background:#f9fafb}.detections-table td{padding:14px 16px;font-size:14px;color:#1f2937}.robot-badge{display:inline-block;padding:4px 12px;background:#dbeafe;color:#1e40af;border-radius:12px;font-size:12px;font-weight:600}.type-badge{display:inline-block;padding:4px 12px;background:#dcfce7;color:#166534;border-radius:12px;font-size:12px;font-weight:600}@media (max-width: 1024px){.charts-section{grid-template-columns:1fr}}@media (max-width: 768px){.detection-dashboard{padding:15px}.dashboard-header{flex-direction:column;gap:15px;align-items:flex-start}.time-range-section{flex-direction:column;align-items:flex-start}.time-range-buttons{margin-left:0;width:100%}.time-btn{flex:1}.stats-cards,.filters-grid{grid-template-columns:1fr}.detections-table{font-size:12px}.detections-table th,.detections-table td{padding:10px 12px}}.task-manager{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:16px;height:450px;width:100%}.task-manager-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #f3f4f6;padding-bottom:12px}.task-manager-header h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.task-count{background:#f3f4f6;color:#6b7280;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600}.task-message{padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;animation:slideIn .3s ease}.task-message-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.task-message-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.task-filters{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px;background:#f9fafb;border-radius:8px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.filter-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;background-color:#fff;color:#374151;cursor:pointer;transition:all .2s ease}.filter-select:hover{border-color:#667eea;background-color:#f9fafb}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.task-manager-container{display:grid;grid-template-columns:280px 1fr;gap:16px;flex:1;min-height:0;height:100%}.task-list-panel{border:1px solid #e5e7eb;border-radius:8px;overflow-y:auto;background:#fafbfc}.task-list-empty{padding:32px 20px;text-align:center;color:#9ca3af;font-size:14px}.task-list{display:flex;flex-direction:column;gap:0}.task-list-item{padding:12px;border-bottom:1px solid #e5e7eb;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:all .2s ease;border-left:4px solid transparent}.task-list-item:last-child{border-bottom:none}.task-list-item:hover{background-color:#f0f4f8}.task-list-item.selected{background-color:#eff6ff;border-left-color:#667eea}.task-list-item.active{border-left-color:#10b981}.task-list-item.inactive{opacity:.7}.task-list-item-content{flex:1;min-width:0}.task-list-item-name{font-size:13px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.task-list-item-meta{display:flex;gap:6px;flex-wrap:wrap}.task-robot{font-size:11px;background:#dbeafe;color:#1e40af;padding:2px 6px;border-radius:3px;white-space:nowrap}.task-status-mini{font-size:11px;font-weight:600;padding:2px 6px;border-radius:3px;white-space:nowrap}.task-status-mini.active{background:#d1fae5;color:#065f46}.task-status-mini.inactive{background:#f3f4f6;color:#6b7280}.task-status-mini.executed{background:#dbeafe;color:#1e40af}.task-list-item-actions{display:flex;gap:4px;align-items:center;flex-shrink:0}.task-toggle-btn{padding:4px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.task-toggle-btn.active{color:#10b981;background:#d1fae5}.task-toggle-btn.active:hover{background:#a7f3d0;color:#059669}.task-toggle-btn.inactive{color:#9ca3af;background:#f3f4f6}.task-toggle-btn.inactive:hover{background:#e5e7eb;color:#6b7280}.task-toggle-btn:active{transform:scale(.95)}.task-delete-btn{padding:4px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;color:#9ca3af;flex-shrink:0}.task-delete-btn:hover{background:#fee2e2;color:#991b1b}.task-delete-btn:active{transform:scale(.95)}.task-details-panel{border:1px solid #e5e7eb;border-radius:8px;padding:20px;overflow-y:auto;display:flex;flex-direction:column;background:#fff}.task-details-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#9ca3af;font-size:14px}.task-view{display:flex;flex-direction:column;gap:16px}.task-view-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.task-view-header>div{flex:1}.task-view-header h4{margin:0 0 8px;font-size:16px;font-weight:600;color:#1f2937}.task-status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;width:fit-content}.task-status-badge.active{background:#d1fae5;color:#065f46}.task-status-badge.inactive{background:#f3f4f6;color:#6b7280}.task-status-badge.executed{background:#dbeafe;color:#1e40af}.btn-edit-main{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease;white-space:nowrap}.btn-edit-main:hover{background:#5568d3;box-shadow:0 2px 8px #667eea4d}.btn-edit-main:active{transform:scale(.98)}.task-details{display:flex;flex-direction:column;gap:12px}.detail-row{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:start;padding:12px;background:#f9fafb;border-radius:6px;font-size:13px}.detail-row.full-width{grid-template-columns:1fr}.detail-label{font-weight:600;color:#6b7280}.detail-value{color:#374151;word-break:break-word}.task-execute-btn{display:flex;justify-content:center;margin-top:8px}.btn-execute{padding:10px 20px;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease}.btn-execute:hover{background:#059669;box-shadow:0 2px 8px #10b9814d}.btn-execute:active{transform:scale(.98)}.task-edit-form{display:flex;flex-direction:column;gap:14px}.task-edit-form>h4{margin:0 0 8px;font-size:16px;font-weight:600;color:#1f2937}.edit-field{display:flex;flex-direction:column;gap:6px}.edit-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.edit-field label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.edit-input,.edit-textarea{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-family:inherit;color:#374151;background-color:#fff;transition:all .2s ease}.edit-input:focus,.edit-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background-color:#fff}.edit-textarea{resize:vertical;min-height:60px}.edit-field-checkbox{display:flex;margin-top:8px}.edit-field-checkbox label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;text-transform:none;letter-spacing:normal;cursor:pointer}.edit-field-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#667eea}.edit-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.btn-save,.btn-cancel{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease}.btn-save{background:#10b981;color:#fff}.btn-save:hover{background:#059669;box-shadow:0 2px 8px #10b9814d}.btn-cancel{background:#f3f4f6;color:#6b7280}.btn-cancel:hover{background:#e5e7eb;color:#374151}.btn-save:active,.btn-cancel:active{transform:scale(.98)}@media (max-width: 1200px){.task-manager{height:420px}.task-manager-container{grid-template-columns:240px 1fr}}@media (max-width: 1024px){.task-manager{height:400px}.task-manager-container{grid-template-columns:200px 1fr}.task-list-item-name{font-size:12px}}@media (max-width: 768px){.task-manager{height:auto;padding:16px}.task-manager-header h3{font-size:16px}.task-filters{grid-template-columns:1fr}.task-manager-container{grid-template-columns:1fr;gap:12px;height:auto}.task-list-panel{max-height:250px}.task-details-panel{padding:16px;min-height:300px}.detail-row{grid-template-columns:1fr;padding:10px}.edit-field-row{grid-template-columns:1fr}.edit-actions{flex-direction:column}.btn-save,.btn-cancel{width:100%;justify-content:center}.btn-edit-main{padding:6px 12px;font-size:12px}}@media (max-width: 480px){.task-manager{height:auto;padding:12px;gap:12px}.task-manager-header h3{font-size:14px}.task-count{font-size:11px}.task-list-item{padding:10px}.task-list-item-name{font-size:11px}.task-details-panel{padding:12px;font-size:12px;min-height:250px}.detail-label{font-size:11px}.detail-value{font-size:12px}.task-robot,.task-status-mini{font-size:10px}.filter-select{font-size:12px;padding:6px 10px}}.waypoints-status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:8px;margin-top:8px}.waypoint-status-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;border-radius:6px;border:2px solid;transition:all .2s ease}.waypoint-status-item.status-completed{background:#d1fae5;border-color:#10b981;color:#065f46}.waypoint-status-item.status-failed{background:#fee2e2;border-color:#ef4444;color:#991b1b}.waypoint-status-item.status-in-progress{background:#fef3c7;border-color:#f59e0b;color:#92400e}.waypoint-status-item.status-not-started{background:#f3f4f6;border-color:#d1d5db;color:#6b7280}.waypoint-number{font-size:11px;font-weight:600;margin-bottom:4px}.waypoint-status-value{font-size:13px;font-weight:700;font-family:Courier New,monospace}.engineering-dashboard{display:flex;flex-direction:column;gap:20px;padding:20px;background-color:#f9fafb;min-height:100vh}.engineering-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 12px #00000026}.header-content{max-width:1400px;margin:0 auto;width:100%}.header-title{display:flex;align-items:center;gap:16px}.header-icon{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.header-title h2{margin:0;font-size:28px;font-weight:700}.header-title p{margin:4px 0 0;font-size:14px;opacity:.9}.robot-selector-section{background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 3px #0000001a}.selector-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:#374151}.selector-header h3{margin:0;font-size:18px;font-weight:600}.robot-selector-dropdown-container{display:flex;align-items:center;max-width:400px}.robot-selector-dropdown{width:100%;padding:10px 40px 10px 16px;background-color:#f9fafb;border:2px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center;background-size:20px}.robot-selector-dropdown:hover{border-color:#667eea;background-color:#fff;box-shadow:0 2px 8px #667eea1a}.robot-selector-dropdown:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 3px #667eea1a}.robot-selector-dropdown:disabled{background-color:#f3f4f6;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.robot-selector-dropdown option{padding:8px;background-color:#fff;color:#374151;font-weight:400}.robot-selector-dropdown option:checked{background:linear-gradient(#667eea,#667eea);background-color:#667eea;color:#fff}.map-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;height:600px}.task-manager-container{display:flex}.engineering-info{display:grid;grid-template-columns:1fr 1fr;gap:16px}.info-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 3px #0000001a}.info-card h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#1f2937;display:flex;align-items:center;gap:8px}.info-card h4:before{content:"";display:inline-block;width:4px;height:4px;background-color:#667eea;border-radius:50%}.info-card ul{margin:0;padding:0;list-style:none}.info-card li{padding:8px 0;font-size:13px;color:#6b7280;line-height:1.6;border-bottom:1px solid #f3f4f6}.info-card li:last-child{border-bottom:none}.info-card strong{color:#374151;font-weight:600}@media (max-width: 1024px){.map-container{height:500px}}@media (max-width: 768px){.engineering-dashboard{padding:16px;gap:16px}.engineering-header{padding:16px}.header-title{flex-direction:column;align-items:flex-start}.header-title h2{font-size:24px}.robot-selector{flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px}.robot-btn{flex-shrink:0}.map-container{height:400px}.info-card{padding:16px}.info-card h4{font-size:14px}.info-card li{font-size:12px}}@media (max-width: 480px){.engineering-dashboard{padding:12px;gap:12px}.engineering-header{padding:12px}.header-title h2{font-size:20px}.header-title p{font-size:12px}.header-icon{width:24px;height:24px}.robot-selector-section{padding:16px}.selector-header h3{font-size:16px}.robot-btn{padding:8px 12px;font-size:12px}.map-container{height:300px}.engineering-info{gap:12px}.info-card{padding:12px}.info-card h4{font-size:13px}.info-card li{font-size:11px;padding:6px 0}}.user-menu-container{display:flex;align-items:center;gap:16px}.main-nav{display:flex;gap:8px;align-items:center}.main-nav a{display:flex;align-items:center;gap:8px;color:#fff;text-decoration:none;padding:10px 16px;border-radius:8px;font-weight:500;transition:all .2s ease;background-color:#ffffff1a}.main-nav a:hover{background-color:#fff3;transform:translateY(-1px)}.main-nav a.active{background-color:#ffffff40;box-shadow:0 2px 8px #00000026}.nav-icon{font-size:16px}.nav-label{font-size:14px}.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}.hamburger{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px}.hamburger span{display:block;width:100%;height:2px;background-color:#fff;border-radius:2px;transition:all .3s ease}.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media (max-width: 1024px){.nav-label{display:none}.main-nav a{padding:10px 12px}}@media (max-width: 768px){.mobile-menu-btn{display:block}.main-nav{position:fixed;top:0;left:-100%;width:280px;height:100vh;background:linear-gradient(180deg,#667eea,#764ba2);flex-direction:column;padding:80px 16px 24px;gap:8px;transition:left .3s ease;z-index:1000;box-shadow:4px 0 20px #00000026}.main-nav.open{left:0}.main-nav a{width:100%;justify-content:flex-start;padding:14px 16px;font-size:16px}.nav-label{display:inline}}.main-nav.open:before{content:"";position:fixed;top:0;left:280px;right:0;bottom:0;background:#00000080}*{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;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 40px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.app-header h1{margin:0;font-size:24px;font-weight:600}.app-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;transition:opacity .2s ease}.app-logo:hover{opacity:.9}.logo-icon{font-size:32px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.app-nav{display:flex;gap:12px;align-items:center}.app-nav a{color:#fff;text-decoration:none;padding:10px 20px;border-radius:8px;font-weight:500;transition:all .2s ease;background-color:#ffffff1a}.app-nav a:hover{background-color:#fff3;transform:translateY(-1px)}.app-nav a.active{background-color:#ffffff40}.app-main{flex:1;padding:20px;background-color:#f5f5f5}@media (max-width: 768px){.app-header{padding:12px 16px;flex-wrap:nowrap}.app-header h1{font-size:16px}.app-logo{flex:1;min-width:0}.app-logo h1{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logo-icon{font-size:24px}.app-nav{width:100%;flex-direction:column;gap:8px}.app-nav a{width:100%;text-align:center}.app-main{padding:12px}}@media (max-width: 480px){.app-header h1{font-size:14px}.logo-icon{font-size:20px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #667eea;--color-primary-dark: #764ba2;--color-secondary: #3b82f6;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "Courier New", Courier, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;font-family:var(--font-sans);font-size:var(--text-base);line-height:1.5;color:var(--color-gray-900);background-color:#f5f5f5;min-height:100vh}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}::selection{background-color:#667eea4d;color:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2;color:var(--color-gray-900)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin:0;line-height:1.6}img{max-width:100%;height:auto;display:block}code{font-family:var(--font-mono);background-color:var(--color-gray-100);padding:2px 6px;border-radius:var(--radius-sm);font-size:.9em}pre{font-family:var(--font-mono);background-color:var(--color-gray-100);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto}pre code{background-color:transparent;padding:0}table{width:100%;border-collapse:collapse}button{font-family:inherit;font-size:inherit;line-height:inherit;cursor:pointer;border:none;background:none;padding:0;margin:0}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit}ul,ol{list-style:none;margin:0;padding:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--spacing-md)}@media (max-width: 768px){:root{font-size:14px}.container{padding:0 var(--spacing-sm)}}@media print{body{background-color:#fff}.no-print{display:none!important}}
