@import"https://fonts.googleapis.com/css2?family=Khula:wght@300;400;600;700;800&family=Poppins:wght@300;400;500;600;700;800&display=swap";.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}}:root{--client-sidebar-w: 290px;--client-sidebar-col-w: 92px;--client-sidebar-anim: .24s ease;--client-topbar-h: 70px;--client-device-panel-w: 380px;--client-map-min-h: 580px;--client-chart-h: 252px;--client-anim-fast: .15s;--client-anim-base: .22s;--client-anim-slow: .42s;--client-anim-chart: .68s}.client-panel{border:1px solid rgba(128,223,255,.14);border-radius:var(--r-lg);background:linear-gradient(135deg,#0d1638e0,#07102bf5);overflow:hidden}.client-panel__header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;border-bottom:1px solid rgba(128,223,255,.1)}.client-panel__header h3{margin:0;display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;color:var(--text);font-family:var(--font-h)}.client-tracking-layout{display:grid;grid-template-columns:var(--client-device-panel-w) 1fr;gap:0;min-height:0;overflow:hidden;flex:1}@media(max-width:1200px){.client-tracking-layout{grid-template-columns:340px 1fr}}@media(max-width:900px){.client-tracking-layout{grid-template-columns:1fr;overflow:visible;flex:unset}}.client-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#80dfff21;border:1px solid rgba(128,223,255,.3);color:var(--cyan);padding:0 16px;min-height:40px;border-radius:var(--r-sm);font-family:var(--font-h);font-weight:700;font-size:.82rem;white-space:nowrap;transition:background var(--client-anim-fast),transform var(--client-anim-fast)}.client-btn-primary:hover:not(:disabled){background:#80dfff38;transform:translateY(-1px)}.client-btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;color:var(--text-soft);border:1px solid var(--line);padding:0 14px;min-height:40px;border-radius:var(--r-sm);font-family:var(--font-h);font-size:.8rem;font-weight:600;white-space:nowrap;transition:border-color var(--client-anim-fast),background var(--client-anim-fast),color var(--client-anim-fast)}.client-btn-secondary:hover:not(:disabled){border-color:#80dfff61;color:var(--cyan);background:#80dfff0d}.client-chip{display:inline-flex;align-items:center;gap:5px;min-height:26px;padding:0 10px;border-radius:999px;font-size:.71rem;font-weight:700;font-family:var(--font-h);border:1px solid transparent;background:none;cursor:pointer;white-space:nowrap;transition:filter .12s,box-shadow .12s,transform .1s}.client-chip:hover{filter:brightness(1.22);transform:translateY(-1px)}.client-chip:active{transform:translateY(0)}.client-chip.all{color:var(--text-soft);background:#80dfff12;border-color:#80dfff2e}.client-chip.all.active{color:var(--cyan);background:#80dfff29;border-color:#80dfff80;box-shadow:0 0 0 2px #80dfff2e}.client-chip.online{color:#22c55e;background:#22c55e1f;border-color:#22c55e38}.client-chip.online.active{background:#22c55e40;border-color:#22c55e;box-shadow:0 0 0 2px #22c55e2e}.client-chip.intermittent{color:#e4840a;background:#e4840a1f;border-color:#e4840a38}.client-chip.intermittent.active{background:#e4840a40;border-color:#e4840a;box-shadow:0 0 0 2px #e4840a2e}.client-chip.offline{color:#fb7185;background:#ef44441f;border-color:#ef444438}.client-chip.offline.active{background:#ef444440;border-color:#ef4444;box-shadow:0 0 0 2px #ef44442e}.client-chip.theft{color:#f0abfc;background:#d846ef1f;border-color:#d846ef38}.client-chip.theft.active{background:#d846ef3d;border-color:#d946ef;box-shadow:0 0 0 2px #d846ef2e}.client-chip.muted{color:#94a3b8;background:#94a3b81a;border-color:#94a3b833}.client-chip.muted.active{background:#94a3b838;border-color:#94a3b8;box-shadow:0 0 0 2px #94a3b826}.client-count-pill{background:#80dfff14;color:var(--cyan);padding:1px 9px;border-radius:99px;font-size:.67rem;font-family:var(--font-h);font-weight:700;border:1px solid rgba(128,223,255,.14)}@keyframes client-fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes client-fade-in{0%{opacity:0}to{opacity:1}}@keyframes client-scale-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}:root{--font-h: "Poppins", system-ui, -apple-system, sans-serif;--font-b: "Khula", system-ui, -apple-system, sans-serif;--bg-navy: #050A1F;--bg-dark: #07142E;--bg-panel: #0B1736;--bg-raised: #101F46;--bg: #07142E;--cyan: #80DFFF;--blue-act: #4899C9;--blue-grad: #2563EB;--success: #22C55E;--warning: #F59E0B;--danger: #EF4444;--theft: #D946EF;--muted-st: #94A3B8;--line: rgba(128, 223, 255, .14);--line-act: rgba(128, 223, 255, .55);--line-err: rgba(239, 68, 68, .45);--text: #F5F8FF;--text-soft: #C5D5F6;--text-muted: #8EA4D1;--glow-cyan: 0 0 24px rgba(128, 223, 255, .24);--glow-blue: 0 0 32px rgba(72, 153, 201, .18);--glow-err: 0 0 18px rgba(239, 68, 68, .22);--r-xl: 28px;--r-lg: 20px;--r-md: 14px;--r-sm: 10px;--r-xs: 7px;--sh-lg: 0 28px 64px rgba(0, 0, 0, .5);--sh-md: 0 16px 36px rgba(0, 0, 0, .32)}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-b);background:radial-gradient(circle at 20% 10%,rgba(128,223,255,.1) 0%,transparent 30%),radial-gradient(circle at 80% 90%,rgba(72,153,201,.08) 0%,transparent 28%),linear-gradient(160deg,var(--bg-navy) 0%,#081332 50%,var(--bg-dark) 100%);background-attachment:fixed;color:var(--text);line-height:1.55}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{opacity:.55;cursor:not-allowed}h1,h2,h3,h4,label,button{font-family:var(--font-h)}p,span,small,li,div{font-family:var(--font-b)}.mono{font-family:Courier New,monospace}.mono-sm{font-family:Courier New,monospace;font-size:.75rem}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes logoGlow{0%,to{opacity:.3;transform:scale(.96)}50%{opacity:.7;transform:scale(1.06)}}@keyframes splashFadeIn{0%{opacity:0}to{opacity:1}}@keyframes bgShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes bootPulse{0%,to{opacity:.6}50%{opacity:1}}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--blue-grad) 0%,var(--blue-act) 60%,var(--cyan) 140%);color:#fff;border:none;padding:13px 26px;border-radius:var(--r-sm);font-family:var(--font-h);font-weight:700;font-size:.95rem;letter-spacing:.01em;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 18px #2563eb47}.btn-primary:hover:not(:disabled){opacity:.88;transform:translateY(-2px);box-shadow:0 8px 24px #2563eb61,var(--glow-cyan)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;color:var(--text-soft);border:1px solid var(--line);padding:8px 16px;border-radius:var(--r-sm);font-family:var(--font-h);font-size:.82rem;font-weight:500;transition:border-color .18s,background .18s,color .18s}.btn-outline:hover:not(:disabled){border-color:var(--cyan);color:var(--cyan);background:#80dfff0f}.status-badge{display:inline-block;padding:2px 10px;border-radius:99px;font-size:.69rem;font-weight:700;font-family:var(--font-h);letter-spacing:.03em;text-transform:uppercase;background:#94a3b824;color:var(--text-muted)}.status-badge.online{background:#22c55e29;color:#4ade80}.status-badge.intermittent{background:#f59e0b29;color:#fbbf24}.status-badge.offline{background:#ef444429;color:#f87171}.status-badge.theft{background:#d946ef29;color:#e879f9}.status-badge.active{background:#22c55e1f;color:#4ade80}.status-badge.inactive{background:#94a3b81a;color:var(--text-muted)}.device-signal-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:5px;background:var(--text-muted)}.device-signal-dot.online{background:var(--success);box-shadow:0 0 6px var(--success)}.device-signal-dot.intermittent{background:var(--warning);box-shadow:0 0 6px var(--warning)}.device-signal-dot.offline{background:var(--danger)}.device-signal-dot.theft{background:var(--theft);box-shadow:0 0 6px var(--theft)}.portal-boot-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;animation:splashFadeIn .4s ease}.boot-logo-wrap{display:flex;align-items:center;gap:12px}.portal-logo-text{font-family:var(--font-h);font-weight:800;font-size:1.35rem;letter-spacing:.08em;background:linear-gradient(90deg,var(--cyan) 0%,#a78bfa 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.portal-boot-msg{color:var(--text-muted);font-size:.9rem;animation:bootPulse 1.6s ease-in-out infinite}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;overflow:hidden;animation:splashFadeIn .35s ease;transition:opacity .44s ease}.splash-screen.splash-exit{opacity:0;pointer-events:none}.splash-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.splash-fallback-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(-45deg,#050a1f,#071427,#0a1f50,#050a1f,#0d1e4a);background-size:400% 400%;animation:bgShift 10s ease infinite}.splash-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#050a1fb8,#050a1f94,#050a1fcc);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.splash-content{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.splash-logo-area{position:relative;display:flex;flex-direction:column;align-items:center;gap:14px;animation:logoFloat 3.6s ease-in-out infinite}.splash-logo-glow{position:absolute;top:-32px;right:-32px;bottom:-32px;left:-32px;border-radius:50%;background:radial-gradient(circle,rgba(128,223,255,.22) 0%,transparent 70%);animation:logoGlow 3.6s ease-in-out infinite;pointer-events:none}.splash-eye-svg{filter:drop-shadow(0 0 16px rgba(128,223,255,.5))}.splash-logo-text{font-family:var(--font-h);font-weight:800;font-size:clamp(2.8rem,6vw,4.2rem);letter-spacing:.12em;background:linear-gradient(90deg,var(--cyan) 0%,#e0f2fe 50%,#a5f3fc 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 0 28px rgba(128,223,255,.35))}.splash-tagline{margin:0;font-family:var(--font-h);font-weight:500;font-size:clamp(1rem,2.5vw,1.25rem);color:#f5f8ffe6;letter-spacing:.04em}.splash-sub{margin:0;font-size:clamp(.8rem,2vw,.95rem);color:#c5d5f6a6;letter-spacing:.02em}.splash-skip-btn{position:absolute;top:20px;right:24px;z-index:2;background:#ffffff14;color:#f5f8ffbf;border:1px solid rgba(255,255,255,.18);border-radius:99px;padding:7px 18px;font-family:var(--font-h);font-size:.8rem;font-weight:500;min-height:44px;min-width:80px;transition:background .18s,color .18s,border-color .18s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.splash-skip-btn:hover{background:#80dfff1f;color:var(--cyan);border-color:#80dfff59}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px}.login-card{background:#0b1736d1;border:1px solid var(--line);border-radius:var(--r-xl);padding:48px 52px 44px;width:100%;max-width:440px;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:var(--sh-lg),0 0 0 1px #80dfff0f;animation:splashFadeIn .4s ease}.login-brand{text-align:center;margin-bottom:36px;display:flex;flex-direction:column;align-items:center;gap:6px}.login-icon-wrap{position:relative;margin-bottom:8px;animation:logoFloat 4s ease-in-out infinite}.login-icon-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:50%;background:radial-gradient(circle,rgba(128,223,255,.2) 0%,transparent 70%);animation:logoGlow 4s ease-in-out infinite;pointer-events:none}.login-eye-svg{filter:drop-shadow(0 0 14px rgba(128,223,255,.45));display:block}.login-title{margin:0;font-family:var(--font-h);font-weight:800;font-size:1.8rem;letter-spacing:.04em;background:linear-gradient(90deg,#e0f2fe 0%,var(--cyan) 50%,#a5f3fc 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.15}.login-subtitle{margin:0;font-family:var(--font-h);font-size:.8rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:22px}.login-field{display:flex;flex-direction:column;gap:7px}.login-field label{font-family:var(--font-h);font-size:.78rem;font-weight:600;color:var(--text-soft);letter-spacing:.02em}.login-field input{background:#ffffff0a;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text);padding:13px 16px;font-size:.94rem;transition:border-color .18s,background .18s,box-shadow .18s;outline:none;min-height:48px}.login-field input:focus{border-color:var(--line-act);background:#80dfff0a;box-shadow:0 0 0 3px #80dfff1f}.login-field input::placeholder{color:var(--text-muted);opacity:.75}.login-field input:disabled{opacity:.55}.login-error{display:flex;align-items:center;gap:8px;background:#ef44441f;border:1px solid var(--line-err);border-radius:var(--r-sm);color:#fca5a5;padding:11px 14px;font-size:.84rem;line-height:1.4;box-shadow:var(--glow-err)}.login-error-icon{font-size:.95rem;flex-shrink:0}.login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:linear-gradient(135deg,var(--blue-grad) 0%,var(--blue-act) 55%,#38bdf8 130%);color:#fff;border:none;padding:15px;border-radius:var(--r-sm);font-family:var(--font-h);font-weight:700;font-size:1rem;letter-spacing:.01em;margin-top:6px;min-height:52px;box-shadow:0 4px 20px #2563eb4d;transition:opacity .2s,transform .15s,box-shadow .2s}.login-btn:hover:not(:disabled){opacity:.9;transform:translateY(-2px);box-shadow:0 8px 28px #2563eb6b,var(--glow-cyan)}.login-btn:active:not(:disabled){transform:translateY(0);opacity:1}.login-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.login-footer{margin:28px 0 0;text-align:center;font-size:.76rem;color:var(--text-muted);opacity:.7}.portal-shell{display:flex;flex-direction:column;min-height:100vh}.portal-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;padding:0 28px;height:58px;background:#07142eeb;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);position:sticky;top:0;z-index:40;gap:12px}.portal-header-brand{display:flex;align-items:center;gap:11px;min-width:0}.portal-header-brand .portal-logo-text{font-size:1.25rem}.portal-divider{color:#80dfff40;font-size:1rem;flex-shrink:0}.portal-client-name{color:var(--text-soft);font-family:var(--font-h);font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.portal-header-actions{display:flex;align-items:center;gap:14px;flex-shrink:0}.portal-device-count{font-size:.78rem;color:var(--text-muted);background:#80dfff12;padding:4px 12px;border-radius:99px;border:1px solid var(--line);white-space:nowrap}.portal-logout-btn{font-size:.78rem;min-height:36px;padding:6px 14px}.portal-error-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#ef44441f;border-bottom:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:10px 28px;font-size:.84rem;box-shadow:var(--glow-err)}.portal-error-bar button{background:none;border:none;color:#fca5a5;font-size:1.05rem;padding:2px;line-height:1;flex-shrink:0}.portal-kpi-strip{display:flex;gap:12px;padding:14px 24px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--line) transparent}.portal-kpi-card{background:var(--bg-panel);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 18px;min-width:116px;flex:1;display:flex;flex-direction:column;gap:5px;transition:border-color .2s,box-shadow .2s}.portal-kpi-card:hover{border-color:#80dfff47}.portal-kpi-card.kpi-active{border-color:#22c55e40}.portal-kpi-card.kpi-online{border-color:#22c55e33}.portal-kpi-card.kpi-warn{border-color:#f59e0b40}.portal-kpi-card.kpi-danger{border-color:#ef444447}.portal-kpi-label{font-size:.68rem;font-family:var(--font-h);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.portal-kpi-value{font-size:1.65rem;font-weight:700;color:var(--text);font-family:var(--font-h);line-height:1}.portal-kpi-card.kpi-active .portal-kpi-value,.portal-kpi-card.kpi-online .portal-kpi-value{color:#4ade80}.portal-kpi-card.kpi-warn .portal-kpi-value{color:#fbbf24}.portal-kpi-card.kpi-danger .portal-kpi-value{color:#f87171}.portal-content-grid{display:grid;grid-template-columns:340px 1fr;flex:1;min-height:0;overflow:hidden}.portal-devices-panel{display:flex;flex-direction:column;background:#07142ec7;border-right:1px solid var(--line);min-height:0;overflow:hidden}.portal-panel-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px 10px;border-bottom:1px solid var(--line);flex-shrink:0}.portal-panel-header h3{margin:0;font-size:.88rem;font-weight:600;font-family:var(--font-h);color:var(--text-soft);display:flex;align-items:center;gap:8px}.count-chip{background:#80dfff1a;color:var(--cyan);padding:1px 9px;border-radius:99px;font-size:.68rem;font-family:var(--font-h);font-weight:700}.portal-search-bar{display:flex;gap:7px;padding:10px 14px;border-bottom:1px solid var(--line);flex-shrink:0}.portal-search-bar input{flex:1;background:#ffffff0a;border:1px solid var(--line);border-radius:var(--r-xs);color:var(--text);padding:8px 12px;font-size:.82rem;outline:none;transition:border-color .16s,box-shadow .16s;min-height:38px}.portal-search-bar input:focus{border-color:#80dfff73;box-shadow:0 0 0 2px #80dfff1a}.portal-search-bar input::placeholder{color:var(--text-muted);opacity:.7}.portal-search-bar button{background:#80dfff14;color:var(--cyan);border:1px solid rgba(128,223,255,.2);border-radius:var(--r-xs);padding:8px 13px;font-size:.8rem;font-family:var(--font-h);font-weight:600;min-height:38px;min-width:64px;transition:background .16s}.portal-search-bar button:hover{background:#80dfff29}.portal-device-list{flex:1;overflow-y:auto;padding-bottom:12px;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.15) transparent}.portal-list-loading,.portal-list-empty{padding:28px 18px;color:var(--text-muted);font-size:.85rem;text-align:center}.portal-load-more{display:block;margin:10px 14px;width:calc(100% - 28px);text-align:center;font-size:.8rem;min-height:40px}.portal-device-card{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;background:transparent;border:none;border-bottom:1px solid rgba(128,223,255,.05);padding:12px 16px;cursor:pointer;transition:background .14s;color:var(--text);min-height:44px}.portal-device-card:hover{background:#80dfff0a}.portal-device-card.selected{background:#80dfff12;border-left:3px solid var(--cyan);padding-left:13px;box-shadow:inset 4px 0 12px #80dfff0f}.device-card-main{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.device-name{font-size:.87rem;font-weight:600;font-family:var(--font-h);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.device-card-main small{font-size:.73rem;color:var(--text-muted);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-uuid{color:var(--text-muted)!important;opacity:.7}.device-card-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:3px}.device-last-seen{font-size:.71rem;color:var(--text-muted);opacity:.8}.portal-map-section{display:flex;flex-direction:column;min-height:0;overflow:hidden;background:var(--bg-navy)}.portal-map-loading-badge{font-size:.68rem;font-weight:500;color:var(--cyan);margin-left:8px;opacity:.7}.portal-refresh-btn{font-size:.78rem;min-height:34px;padding:5px 13px}.portal-map-wrap{flex:1;position:relative;min-height:0}.portal-leaflet-map{width:100%;height:100%;min-height:420px;background:var(--bg-navy)}.portal-map-popup{font-family:var(--font-b);min-width:150px;padding:2px 4px}.portal-map-popup strong{display:block;font-family:var(--font-h);margin-bottom:4px;font-size:.88rem;color:#111}.portal-map-popup p{margin:3px 0;font-size:.77rem;color:#444}.portal-map-popup .popup-status{font-weight:700}.portal-map-popup .popup-status.online{color:#16a34a}.portal-map-popup .popup-status.intermittent{color:#d97706}.portal-map-popup .popup-status.offline{color:#dc2626}.portal-map-popup .popup-status.theft{color:#9333ea}.portal-map-popup .popup-ts{color:#666;font-size:.73rem}@media(max-width:900px){.portal-content-grid{grid-template-columns:290px 1fr}.portal-client-name{max-width:160px}.portal-device-count{display:none}}@media(max-width:680px){.portal-content-grid{grid-template-columns:1fr;grid-template-rows:auto 1fr;overflow:visible}.portal-devices-panel{border-right:none;border-bottom:1px solid var(--line);max-height:46vh;min-height:0}.portal-map-section{min-height:56vmax}.portal-leaflet-map{min-height:300px}.portal-kpi-strip{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:12px 14px;overflow-x:visible}.portal-kpi-card{flex:unset;min-width:unset}.portal-kpi-value{font-size:1.35rem}.portal-header{padding:0 14px;height:52px}.portal-client-name{max-width:110px;font-size:.82rem}.login-card{padding:36px 28px 32px;border-radius:var(--r-lg);max-width:100%}.login-title{font-size:1.5rem}.splash-logo-text{font-size:2.4rem}.portal-error-bar{padding:10px 14px}.portal-panel-header{padding:11px 12px 8px}.portal-search-bar{padding:8px 12px}.portal-device-card{padding:10px 12px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 40%,#0f172a,#020617);padding:1.5rem;animation:bgFadeIn .8s ease-out}@keyframes bgFadeIn{0%{opacity:0}to{opacity:1}}.login-card{background:#0f192da6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:2rem;padding:2.5rem 2rem;width:100%;max-width:440px;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #80dfff26;transition:transform .2s ease,box-shadow .2s ease;animation:cardSlideUp .6s cubic-bezier(.16,1,.3,1)}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-brand{text-align:center;margin-bottom:2rem}.login-icon-wrap{position:relative;display:inline-flex;justify-content:center;align-items:center;margin-bottom:1rem}.login-logo-icon{width:96px;height:96px;filter:drop-shadow(0 0 8px rgba(128,223,255,.5));animation:gentleFloat 3s infinite ease-in-out}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.login-icon-glow{position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;background:radial-gradient(circle,rgba(128,223,255,.25),transparent 70%);border-radius:50%;filter:blur(10px);animation:pulseGlowLogin 2.5s infinite}@keyframes pulseGlowLogin{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.login-title{font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:1.9rem;font-weight:700;letter-spacing:-.3px;background:linear-gradient(135deg,#fff,#b8e6ff);-webkit-background-clip:text;background-clip:text;color:transparent;margin:.5rem 0 .25rem}.login-subtitle{font-family:Inter,system-ui,sans-serif;font-size:.85rem;font-weight:500;color:#80dfff;letter-spacing:1px;text-transform:uppercase;opacity:.8;margin:0}.login-form{display:flex;flex-direction:column;gap:1.2rem}.login-field{display:flex;flex-direction:column;gap:.5rem}.login-field label{font-family:Inter,system-ui,sans-serif;font-size:.8rem;font-weight:500;color:#cbd5e6;letter-spacing:.3px}.login-field input{background:#02081799;border:1px solid rgba(128,223,255,.25);border-radius:1rem;padding:.85rem 1rem;font-size:.95rem;color:#fff;font-family:Inter,system-ui,sans-serif;transition:all .2s ease}.login-field input:focus{outline:none;border-color:#80dfff;box-shadow:0 0 0 3px #80dfff33;background:#050f23cc}.login-field input::placeholder{color:#c8dcfa66}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{flex:1;padding-right:3rem}.password-toggle{position:absolute;right:.75rem;background:transparent;border:none;color:#80dfff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:999px;transition:all .2s;opacity:.7}.password-toggle:hover{opacity:1;transform:scale(1.05)}.login-options{display:flex;align-items:center;margin-top:-.2rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.8rem;color:#b0c4e8;font-family:Inter,system-ui,sans-serif}.checkbox-label input{display:none}.checkbox-custom{width:18px;height:18px;border-radius:5px;border:1.5px solid rgba(128,223,255,.6);background:#02081799;transition:all .2s;position:relative}.checkbox-label input:checked+.checkbox-custom{background:#80dfff;border-color:#80dfff}.checkbox-label input:checked+.checkbox-custom:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:#0a0f1e}.login-btn{background:linear-gradient(105deg,#1e4a76,#0f2f4a);border:none;border-radius:2rem;padding:.9rem;font-weight:600;font-size:1rem;font-family:Inter,system-ui,sans-serif;color:#fff;cursor:pointer;transition:all .2s ease;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 12px #0000004d}.login-btn:hover:not(:disabled){background:linear-gradient(105deg,#2c628f,#1a4668);transform:translateY(-2px);box-shadow:0 8px 20px #001e3c80}.login-btn:disabled{opacity:.65;cursor:not-allowed}.login-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-error{background:#dc262626;border-left:3px solid #ef4444;padding:.75rem 1rem;border-radius:.75rem;font-size:.8rem;color:#ffb3b3;display:flex;align-items:center;gap:.5rem;animation:shake .3s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-footer{text-align:center;font-size:.7rem;color:#7f8ea3;margin-top:1.8rem;font-family:Inter,system-ui,sans-serif;letter-spacing:.3px}@media(max-width:480px){.login-card{padding:1.8rem 1.5rem}.login-title{font-size:1.5rem}.login-logo-icon{width:44px;height:44px}}.csb-root{display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow:hidden;background:radial-gradient(circle at 50% 10%,rgba(128,223,255,.12),transparent 18%),linear-gradient(180deg,#080936fa,#080427);border-right:1px solid var(--line, rgba(128, 223, 255, .2));z-index:50;transition:width .22s cubic-bezier(.2,.9,.4,1.1)}.csb-logo-btn{position:relative;min-height:120px;width:100%;background:transparent;border:0;border-bottom:1px solid var(--line, rgba(128, 223, 255, .2));cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;transition:background .18s,min-height .22s ease}.csb-logo-btn:hover{background:#80dfff0f}.csb-glow-ring{position:absolute;width:160px;height:72px;border-radius:999px;background:radial-gradient(circle,rgba(128,223,255,.28),rgba(72,153,201,.08) 42%,transparent 72%);filter:blur(7px);opacity:.85;animation:csbLogoPulse 3.4s ease-in-out infinite;pointer-events:none;transition:width .2s,height .2s}@keyframes csbLogoPulse{0%,to{transform:scale(.92);opacity:.55}50%{transform:scale(1.08);opacity:1}}.csb-logo-full{width:180px;max-width:calc(100% - 32px);filter:drop-shadow(0 10px 24px rgba(128,223,255,.14));position:relative;z-index:1;transition:opacity .2s,transform .2s}.csb-logo-icon{display:none;width:42px;height:42px;filter:drop-shadow(0 0 20px rgba(128,223,255,.28));position:relative;z-index:1}.csb-nav{flex:1;display:grid;gap:6px;padding:18px 14px;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.csb-nav::-webkit-scrollbar{display:none}.csb-nav-item{position:relative;display:flex;align-items:center;gap:12px;width:100%;min-height:52px;padding:0 16px;background:transparent;border:1px solid transparent;border-radius:16px;color:var(--text-soft, #b0c4de);cursor:pointer;transition:background .18s,color .18s,transform .15s,padding .22s;text-align:left;white-space:nowrap;font-family:var(--font-h, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, sans-serif)}.csb-nav-item:hover{background:#80dfff1a;color:var(--text, #ffffff);transform:translate(3px)}.csb-nav-item.csb-active{background:linear-gradient(135deg,#4899c940,#80dfff1a);border-color:#80dfff40;color:#fff;box-shadow:inset 0 0 0 1px #80dfff1a,0 4px 12px #0003}.csb-nav-item.csb-active .csb-nav-icon{color:#7fdcff}.csb-nav-icon{width:28px;height:28px;display:grid;place-items:center;flex-shrink:0;color:#dce7ff;font-size:0}.csb-nav-copy{display:grid;gap:1px}.csb-nav-label{font-size:.92rem;font-weight:700;letter-spacing:-.01em}.csb-footer{padding:18px 14px 22px;border-top:1px solid var(--line, rgba(128, 223, 255, .2));flex-shrink:0}.csb-status-block{display:grid;gap:10px;padding:12px 14px;background:#80dfff0b;border:1px solid rgba(128,223,255,.08);border-radius:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.csb-status-row{display:flex;align-items:center;gap:12px;color:var(--text-soft, #b0c4de);font-size:.85rem;font-weight:600;font-family:var(--font-h, system-ui);min-height:32px}.csb-status-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.csb-mini-dot{width:12px;height:12px;border-radius:999px;border:1.5px solid currentColor;flex-shrink:0;background-color:currentColor;color:var(--text-muted, #6c86a3)}.csb-mini-dot.ok{color:#22c55e;box-shadow:0 0 10px #22c55e66}.csb-mini-dot.err{color:#ef4444;box-shadow:0 0 8px #ef44444d}.csb-root.csb-collapsed{width:80px}.csb-root.csb-collapsed .csb-logo-btn{min-height:92px}.csb-root.csb-collapsed .csb-glow-ring{width:60px;height:60px}.csb-root.csb-collapsed .csb-logo-full{display:none}.csb-root.csb-collapsed .csb-logo-icon{display:block;width:38px;height:38px}.csb-root.csb-collapsed .csb-nav{padding:14px 8px;gap:8px}.csb-root.csb-collapsed .csb-nav-item{justify-content:center;padding:0;min-height:48px;gap:0}.csb-root.csb-collapsed .csb-nav-copy,.csb-root.csb-collapsed .csb-status-text{display:none}.csb-root.csb-collapsed .csb-status-block{padding:10px;place-items:center;gap:8px;border-radius:16px}.csb-root.csb-collapsed .csb-status-row{justify-content:center;gap:0}.csb-root.csb-collapsed .csb-status-row svg{margin-right:0}.csb-root.csb-collapsed .csb-nav-item:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);padding:6px 12px;border-radius:12px;background:#0a0f2a;border:1px solid rgba(128,223,255,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#f0f6ff;white-space:nowrap;opacity:0;pointer-events:none;box-shadow:0 8px 20px #0000004d;transition:opacity .18s ease;z-index:100;font-size:.8rem;font-weight:600;font-family:var(--font-h, system-ui);letter-spacing:-.01em}.csb-root.csb-collapsed .csb-nav-item:hover:after{opacity:1}.csb-root.csb-collapsed .csb-status-row:hover:after{content:"Red CICLOPE";position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:#0a0f2a;border:1px solid rgba(128,223,255,.3);padding:4px 10px;border-radius:10px;font-size:.75rem;white-space:nowrap;pointer-events:none;color:#fff;z-index:100}.csb-root.csb-collapsed .csb-status-row{position:relative}@media(max-width:900px){.csb-root{position:fixed;left:-280px;top:0;bottom:0;height:100%;width:280px;transition:left .25s ease,box-shadow .25s;z-index:1000}.csb-root.csb-mobile-open{left:0;box-shadow:6px 0 32px #00000080}.csb-root .csb-logo-full{display:block!important}.csb-root .csb-logo-icon{display:none!important}.csb-root .csb-nav-copy{display:grid!important}.csb-root .csb-nav-item{justify-content:flex-start!important;padding:0 16px!important;gap:12px!important}.csb-root .csb-status-text{display:block!important}.csb-root .csb-status-block{place-items:unset;padding:12px 14px}.csb-root .csb-status-row svg{display:block!important;margin-right:6px}.csb-root.csb-collapsed .csb-status-text{display:block!important}.csb-mobile-close{display:flex;position:absolute;top:16px;right:16px;background:#ffffff0d;border:none;color:var(--text-muted, #9aaebe);padding:8px;border-radius:40px;cursor:pointer;transition:all .14s;z-index:2}.csb-mobile-close:hover{background:#80dfff33;color:#fff}.csb-footer{display:none}}@media(prefers-reduced-motion:reduce){.csb-root,.csb-logo-btn,.csb-nav-item,.csb-nav-item:after{transition:none!important}.csb-glow-ring{animation:none;opacity:.4}}.csb-mobile-close{display:none}.csb-health-btn{width:100%;min-height:38px;margin-top:10px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;border:1px solid rgba(128,223,255,.2);background:#80dfff12;color:#80dfff;font-family:var(--font-h, system-ui);font-weight:800;font-size:.78rem;cursor:pointer;transition:background .16s ease,transform .16s ease,border-color .16s ease}.csb-health-btn:hover{transform:translateY(-1px);background:#80dfff1f;border-color:#80dfff57}.csb-root.csb-collapsed .csb-health-btn span{display:none}.csb-root.csb-collapsed .csb-health-btn{width:44px;height:38px;padding:0;margin:10px auto 0}@media(max-width:900px){.csb-mobile-close{display:flex}}.cpl-root{display:grid;grid-template-columns:var(--client-sidebar-w) 1fr;height:100vh;overflow:hidden;transition:grid-template-columns var(--client-sidebar-anim)}.cpl-root.cpl-collapsed{grid-template-columns:var(--client-sidebar-col-w) 1fr}.cpl-main{display:flex;flex-direction:column;min-width:0;overflow:hidden;height:100vh}.cpl-mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;z-index:45;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:900px){.cpl-root{display:block;height:100vh;overflow:hidden}.cpl-main{height:100vh}}@media(prefers-reduced-motion:reduce){.cpl-root{transition:none}}.ctb-root{display:flex;align-items:center;justify-content:space-between;min-height:var(--client-topbar-h);padding:0 28px;background:#08112ce0;border-bottom:1px solid var(--line);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-shrink:0;gap:14px;position:sticky;top:0;z-index:30}.ctb-left{display:flex;align-items:center;gap:16px;min-width:0}.ctb-hamburger{background:#80dfff0f;border:1px solid var(--line);color:var(--text-soft);padding:0;width:42px;height:42px;border-radius:var(--r-md);cursor:pointer;transition:background var(--client-anim-fast),color var(--client-anim-fast);flex-shrink:0;display:none;align-items:center;justify-content:center}.ctb-hamburger:hover{background:#80dfff1f;color:var(--cyan)}.ctb-title-block{display:flex;flex-direction:column;gap:2px;min-width:0}.ctb-eyebrow{font-family:var(--font-h);font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);opacity:.72;white-space:nowrap}.ctb-title-row{display:flex;align-items:center;gap:10px}.ctb-title-bar{display:block;width:3px;height:22px;border-radius:2px;background:linear-gradient(180deg,var(--cyan) 0%,rgba(72,153,201,.35) 100%);flex-shrink:0}.ctb-section-title{font-family:var(--font-h);font-weight:800;font-size:1.4rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0;line-height:1.1}.ctb-title-decoration{width:52px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--blue-act, #4899C9));margin-top:4px}.ctb-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.ctb-date-pill{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(128,223,255,.12);background:#80dfff0f;font-family:var(--font-h);font-size:.78rem;font-weight:700;color:var(--text-soft);white-space:nowrap}.ctb-status-pill{display:inline-flex;align-items:center;gap:6px;min-height:38px;padding:0 14px;border-radius:999px;border:1px solid;font-family:var(--font-h);font-size:.78rem;font-weight:700;white-space:nowrap}.ctb-status-pill.ok{color:var(--success);border-color:#22c55e47;background:#22c55e17}.ctb-status-pill.err{color:var(--danger);border-color:#ef444447;background:#ef444417}.ctb-status-dot{width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block;flex-shrink:0}.ctb-device-chip{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(128,223,255,.12);background:#80dfff12;font-size:.78rem;font-weight:700;color:var(--text-soft);white-space:nowrap}.ctb-user-name{font-family:var(--font-h);font-weight:700;font-size:.85rem;color:var(--cyan);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.ctb-logout-btn{font-size:.8rem;min-height:38px;padding:0 14px;white-space:nowrap}.ctb-error-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#ef44441c;border-bottom:1px solid rgba(239,68,68,.28);color:#fca5a5;padding:9px 28px;font-size:.84rem;flex-shrink:0}.ctb-error-bar button{background:none;border:none;color:#fca5a5;font-size:1.2rem;line-height:1;padding:2px 4px;flex-shrink:0;cursor:pointer}@media(max-width:900px){.ctb-hamburger{display:flex}.ctb-root{padding:0 18px}}@media(max-width:768px){.ctb-device-chip,.ctb-date-pill{display:none}.ctb-user-name{max-width:120px;font-size:.8rem}.ctb-logout-btn span{display:none}.ctb-logout-btn{padding:0 10px}.ctb-section-title{font-size:1.1rem}.ctb-title-bar{height:18px}}@media(max-width:520px){.ctb-user-name,.ctb-status-pill,.ctb-eyebrow,.ctb-title-decoration{display:none}}@media(prefers-reduced-motion:reduce){.ctb-hamburger{transition:none}}.cfb-root{flex-shrink:0;background:#07142eeb;border-bottom:1px solid var(--line);padding:10px 16px}.cfb-form{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cfb-search-wrap{display:flex;align-items:center;gap:7px;background:#ffffff0a;border:1px solid var(--line);border-radius:var(--r-xs);padding:7px 10px;min-width:200px;flex:1;max-width:320px;transition:border-color .14s}.cfb-search-wrap:focus-within{border-color:#80dfff73}.cfb-search-wrap svg{color:var(--text-muted);flex-shrink:0}.cfb-search-input{flex:1;background:none;border:none;color:var(--text);font-size:.8rem;outline:none;min-width:0}.cfb-search-input::placeholder{color:var(--text-muted);opacity:.7}.cfb-select{background:#ffffff0a;border:1px solid var(--line);border-radius:var(--r-xs);color:var(--text-soft);font-size:.8rem;padding:7px 26px 7px 10px;height:34px;cursor:pointer;outline:none;transition:border-color .14s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238EA4D1' strokeWidth='1.5' fill='none' strokeLinecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.cfb-select:focus{border-color:#80dfff73}.cfb-select option{background:#07142e;color:var(--text)}.cfb-range-tabs{display:flex;gap:2px;background:#ffffff08;border:1px solid var(--line);border-radius:var(--r-xs);padding:3px}.cfb-range-tab{background:none;border:none;color:var(--text-muted);font-family:var(--font-h);font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:5px;transition:background .12s,color .12s;white-space:nowrap}.cfb-range-tab:hover{background:#80dfff0f;color:var(--text-soft)}.cfb-range-tab.active{background:#80dfff24;color:var(--cyan)}.cfb-date-row{display:flex;align-items:center;gap:6px}.cfb-date{background:#ffffff0a;border:1px solid var(--line);border-radius:var(--r-xs);color:var(--text);font-size:.78rem;padding:6px 8px;height:34px;outline:none}.cfb-date::-webkit-calendar-picker-indicator{filter:invert(.6)}.cfb-date-sep{color:var(--text-muted);font-size:.82rem}.cfb-actions{display:flex;gap:6px;flex-shrink:0;margin-left:auto}.cfb-btn-primary{background:#80dfff24;border:1px solid rgba(128,223,255,.28);color:var(--cyan);font-family:var(--font-h);font-size:.78rem;font-weight:700;padding:6px 14px;border-radius:var(--r-xs);height:34px;white-space:nowrap;transition:background .14s}.cfb-btn-primary:hover:not(:disabled){background:#80dfff38}.cfb-btn-outline{background:transparent;border:1px solid var(--line);color:var(--text-muted);font-family:var(--font-h);font-size:.78rem;font-weight:600;padding:6px 12px;border-radius:var(--r-xs);height:34px;white-space:nowrap;transition:background .14s,color .14s,border-color .14s}.cfb-btn-outline:hover:not(:disabled){background:#80dfff0d;color:var(--text-soft);border-color:#80dfff4d}.cfb-btn-refresh{display:inline-flex;align-items:center;gap:5px;padding:6px 12px}@media(max-width:768px){.cfb-root{padding:8px 12px}.cfb-form{gap:6px}.cfb-search-wrap{min-width:0;max-width:100%}.cfb-range-tabs,.cfb-date-row,.cfb-refresh-label{display:none}.cfb-actions{margin-left:0}}@media(max-width:520px){.cfb-select{display:none}}@media(prefers-reduced-motion:reduce){.cfb-search-wrap,.cfb-range-tab,.cfb-btn-primary,.cfb-btn-outline{transition:none}}.ckg-root.ckg-empty{display:flex;align-items:center;justify-content:center;min-height:90px;padding:20px}.ckg-spinner{width:24px;height:24px;border:2px solid rgba(128,223,255,.2);border-top-color:var(--cyan);border-radius:50%;animation:ckgSpin .8s linear infinite}@keyframes ckgSpin{to{transform:rotate(360deg)}}.ckg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;padding:24px}.ckg-card{background:var(--bg-panel);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 20px;display:flex;align-items:center;gap:16px;transition:border-color .18s,box-shadow .18s,transform .15s;cursor:default}.ckg-card:hover{border-color:#80dfff47;box-shadow:0 4px 20px #00000038;transform:translateY(-1px)}.ckg-icon-wrap{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;flex-shrink:0;background:#80dfff0f;border:1px solid rgba(128,223,255,.1);color:var(--cyan)}.ckg-body{display:flex;flex-direction:column;gap:4px;min-width:0}.ckg-value{font-family:var(--font-h);font-size:1.9rem;font-weight:700;color:var(--text);line-height:1}.ckg-label{font-family:var(--font-h);font-size:.66rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ckg-card.kpi-active{border-color:#22c55e2e}.ckg-card.kpi-online{border-color:#22c55e1f}.ckg-card.kpi-warn{border-color:#f59e0b33}.ckg-card.kpi-danger{border-color:#ef444433}.ckg-card.kpi-theft{border-color:#d946ef38}.ckg-card.kpi-muted{border-color:#94a3b829}.ckg-card.kpi-active .ckg-icon-wrap{background:#22c55e1a;border-color:#22c55e33;color:#4ade80}.ckg-card.kpi-online .ckg-icon-wrap{background:#22c55e14;border-color:#22c55e26;color:#4ade80}.ckg-card.kpi-warn .ckg-icon-wrap{background:#f59e0b1a;border-color:#f59e0b33;color:#fbbf24}.ckg-card.kpi-danger .ckg-icon-wrap{background:#ef44441a;border-color:#ef444433;color:#f87171}.ckg-card.kpi-theft .ckg-icon-wrap{background:#d946ef1a;border-color:#d946ef33;color:#e879f9}.ckg-card.kpi-muted .ckg-icon-wrap{background:#94a3b814;border-color:#94a3b82e;color:#94a3b8}.ckg-card.kpi-active .ckg-value,.ckg-card.kpi-online .ckg-value{color:#4ade80}.ckg-card.kpi-warn .ckg-value{color:#fbbf24}.ckg-card.kpi-danger .ckg-value{color:#f87171}.ckg-card.kpi-theft .ckg-value{color:#e879f9}@media(max-width:680px){.ckg-grid{grid-template-columns:1fr 1fr;padding:14px;gap:10px}.ckg-card{padding:14px 16px;gap:12px}.ckg-value{font-size:1.5rem}.ckg-icon-wrap{width:40px;height:40px;border-radius:10px}}@media(max-width:380px){.ckg-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.ckg-card{transition:none}.ckg-spinner{animation:none}}.csd-root{background:var(--bg-panel, rgba(8, 9, 54, .6));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line, rgba(128, 223, 255, .15));border-radius:24px;padding:20px 22px;display:flex;flex-direction:column;gap:14px;flex:1;min-width:260px;transition:all .2s ease;box-shadow:0 8px 20px #0003}.csd-root:hover{border-color:#80dfff4d;box-shadow:0 12px 28px #0000004d}.csd-label{font-family:var(--font-h, "Poppins", system-ui);font-size:.72rem;font-weight:700;color:var(--text-muted, #8ba0bc);text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:8px}.csd-label:before{content:"";width:20px;height:2px;background:linear-gradient(90deg,var(--cyan, #7fdcff),transparent);border-radius:2px}.csd-body{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.csd-svg-wrap{width:140px;height:140px;flex-shrink:0;position:relative}.csd-svg{width:100%;height:100%;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.csd-legend{flex:1;display:flex;flex-direction:column;gap:8px;min-width:140px}.csd-legend-row{display:flex;align-items:center;gap:10px;min-width:0;padding:6px 8px;border-radius:12px;transition:background .15s;cursor:default}.csd-legend-row:hover{background:#80dfff0f}.csd-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:transform .2s,box-shadow .2s}.csd-legend-row:hover .csd-legend-dot{transform:scale(1.3);box-shadow:0 0 8px currentColor}.csd-legend-label{flex:1;font-size:.78rem;font-weight:500;color:var(--text-soft, #b8c7e7);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.csd-legend-val{font-family:var(--font-h, "Poppins", system-ui);font-size:.82rem;font-weight:700;color:var(--text, #ffffff);white-space:nowrap;background:#ffffff0d;padding:2px 6px;border-radius:20px}.csd-legend-pct{font-size:.7rem;font-weight:600;color:var(--text-muted, #8ba0bc);width:38px;text-align:right;flex-shrink:0}@media(max-width:640px){.csd-root{padding:16px}.csd-body{flex-direction:column;align-items:stretch}.csd-svg-wrap{width:120px;height:120px;align-self:center}.csd-legend-row{padding:4px 0}.csd-legend-label{font-size:.72rem}.csd-legend-val{font-size:.75rem}}@media(prefers-reduced-motion:reduce){.csd-legend-dot{transition:none}.csd-legend-row:hover .csd-legend-dot{transform:none}}.csb2-root{background:var(--bg-panel, rgba(8, 9, 54, .6));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line, rgba(128, 223, 255, .15));border-radius:24px;padding:20px 22px;display:flex;flex-direction:column;gap:14px;flex:1;min-width:240px;transition:all .2s ease;box-shadow:0 8px 20px #0003}.csb2-root:hover{border-color:#80dfff4d;box-shadow:0 12px 28px #0000004d}.csb2-label{font-family:var(--font-h, "Poppins", system-ui);font-size:.72rem;font-weight:700;color:var(--text-muted, #8ba0bc);text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:8px}.csb2-label:before{content:"";width:20px;height:2px;background:linear-gradient(90deg,var(--cyan, #7fdcff),transparent);border-radius:2px}.csb2-bars{display:flex;flex-direction:column;gap:12px}.csb2-row{display:flex;align-items:center;gap:12px}.csb2-row-label{font-family:var(--font-h, "Poppins", system-ui);font-size:.75rem;font-weight:600;color:var(--text-soft, #b8c7e7);width:95px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.csb2-bar-track{flex:1;height:10px;background:#ffffff0f;border-radius:10px;overflow:hidden;position:relative}.csb2-bar-fill{height:100%;border-radius:10px;position:relative;overflow:hidden}.csb2-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.csb2-row-val{font-family:var(--font-h, "Poppins", system-ui);font-size:.78rem;font-weight:700;color:var(--text, #ffffff);width:48px;text-align:right;flex-shrink:0;background:#ffffff0d;padding:2px 6px;border-radius:20px}.csb2-row:hover .csb2-bar-fill{filter:brightness(1.1);transform:scaleY(1.2);transition:transform .2s}.csb2-row:hover .csb2-row-val{background:#80dfff26;color:var(--cyan, #7fdcff)}@media(max-width:640px){.csb2-root{padding:16px}.csb2-row{gap:8px}.csb2-row-label{font-size:.68rem;width:80px}.csb2-row-val{font-size:.7rem;width:40px}.csb2-bar-track{height:8px}}@media(prefers-reduced-motion:reduce){.csb2-bar-fill:after{animation:none}.csb2-row:hover .csb2-bar-fill{transform:none}}:root{--cdp-bg: rgba(7, 20, 46, .92);--cdp-card-bg: rgba(11, 23, 54, .72);--cdp-hover-bg: rgba(128, 223, 255, .045);--cdp-sel-bg: rgba(128, 223, 255, .08);--cdp-border: rgba(128, 223, 255, .1);--cdp-cyan: #80DFFF;--cdp-text: #E8F0FF;--cdp-muted: rgba(197, 213, 246, .58);--cdp-faint: rgba(197, 213, 246, .38)}.cdp-root{display:flex;flex-direction:column;background:var(--cdp-bg);border-right:1px solid var(--cdp-border);width:320px;flex-shrink:0;min-height:0;overflow:hidden}.cdp-root.cdp-full{width:100%;border-right:none}.cdp-header{display:flex;align-items:center;gap:8px;padding:12px 16px 10px;border-bottom:1px solid var(--cdp-border);flex-shrink:0}.cdp-header-title{font-family:var(--font-h, system-ui);font-size:.8rem;font-weight:800;color:var(--cdp-text);letter-spacing:-.01em;flex:1}.cdp-header-badge{background:#80dfff1f;color:var(--cdp-cyan);padding:2px 10px;border-radius:999px;font-size:.68rem;font-family:var(--font-h, system-ui);font-weight:800;border:1px solid rgba(128,223,255,.18)}.cdp-status-strip{display:flex;align-items:center;gap:12px;padding:7px 16px;border-bottom:1px solid var(--cdp-border);flex-shrink:0;flex-wrap:wrap}.cdp-ss{font-family:var(--font-h, system-ui);font-size:.66rem;font-weight:700;white-space:nowrap}.cdp-ss--ok{color:#22c55e}.cdp-ss--warn{color:#e4840a}.cdp-ss--err{color:#ef4444}.cdp-ss--theft{color:#d946ef}.cdp-list{flex:1;overflow-y:auto;padding:6px 0 8px;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.14) transparent}.cdp-list::-webkit-scrollbar{width:3px}.cdp-list::-webkit-scrollbar-thumb{background:#80dfff2e;border-radius:2px}.cdp-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 16px;color:var(--cdp-muted);font-size:.82rem;text-align:center}.cdp-spinner{width:20px;height:20px;border:2px solid rgba(128,223,255,.18);border-top-color:var(--cdp-cyan);border-radius:50%;animation:cdpSpin .8s linear infinite}@keyframes cdpSpin{to{transform:rotate(360deg)}}.cdp-card{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;background:transparent;border:none;border-bottom:1px solid rgba(128,223,255,.05);border-left:3px solid transparent;padding:12px 12px 12px 13px;cursor:pointer;color:var(--cdp-text);transition:background .15s ease,border-left-color .15s ease,box-shadow .15s ease;position:relative}.cdp-card:hover{background:var(--cdp-hover-bg);box-shadow:inset 0 0 0 1px #80dfff0f}.cdp-card.cdp-card--selected{background:var(--cdp-sel-bg);border-left-color:var(--cdp-cyan);box-shadow:inset 0 0 0 1px #80dfff1a,0 0 24px #80dfff0f}.cdp-signal{--sig-color: #22c55e;width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px;background:var(--sig-color);box-shadow:0 0 8px var(--sig-color)}.cdp-signal--online{--sig-color: #22c55e}.cdp-signal--intermittent{--sig-color: #E4840A}.cdp-signal--offline{--sig-color: #ef4444;box-shadow:none}.cdp-signal--theft{--sig-color: #d946ef}.cdp-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.cdp-name-row{display:flex;align-items:flex-start;justify-content:space-between;gap:6px;flex-wrap:wrap}.cdp-name{font-family:var(--font-h, system-ui);font-size:.84rem;font-weight:800;color:#f5f8ff;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.cdp-badges{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}.cdp-badge-status,.cdp-badge-active,.cdp-badge-theft{border-radius:999px;border:1px solid;padding:1px 7px;font-family:var(--font-h, system-ui);font-size:.6rem;font-weight:900;white-space:nowrap}.cdp-badge-status--online{color:#4ade80;border-color:#22c55e4d;background:#22c55e14}.cdp-badge-status--intermittent{color:#fb923c;border-color:#e4840a4d;background:#e4840a14}.cdp-badge-status--offline{color:#f87171;border-color:#ef44444d;background:#ef444414}.cdp-badge-status--theft{color:#f0abfc;border-color:#d946ef4d;background:#d946ef14}.cdp-badge-active--ok{color:#80dfff;border-color:#80dfff38;background:#80dfff12}.cdp-badge-active--off{color:#94a3b8bf;border-color:#94a3b829;background:#94a3b80d}.cdp-badge-theft{color:#f0abfc;border-color:#d946ef57;background:#d946ef1a}.cdp-cliente{font-size:.7rem;color:var(--cdp-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cdp-uuid-row{display:flex;align-items:center;gap:6px}.cdp-uuid{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.64rem;color:var(--cdp-faint);letter-spacing:.01em}.cdp-copy-btn{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border:1px solid rgba(128,223,255,.14);border-radius:5px;background:#80dfff0d;color:var(--cdp-muted);font-family:var(--font-h, system-ui);font-size:.58rem;font-weight:700;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease;white-space:nowrap;flex-shrink:0}.cdp-copy-btn:hover{background:#80dfff1f;color:var(--cdp-cyan);border-color:#80dfff47}.cdp-copy-btn--copied{background:#22c55e1f;color:#4ade80;border-color:#22c55e47}.cdp-copy-label{line-height:1}.cdp-meta-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:1px}.cdp-chip{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-h, system-ui);font-size:.62rem;color:var(--cdp-muted);background:#ffffff09;border:1px solid rgba(128,223,255,.08);padding:1px 6px;border-radius:5px;white-space:nowrap}.cdp-chip--time{color:var(--cdp-faint)}.cdp-chip--warn{color:#ef4444b8;border-color:#ef444429}.cdp-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0;align-self:center}.cdp-act-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;border:1px solid rgba(128,223,255,.16);background:#80dfff0f;color:var(--cdp-cyan);cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.cdp-act-btn:hover{background:#80dfff24;border-color:#80dfff4d}.cdp-act-btn--disabled{opacity:.32;cursor:default}.cdp-act-btn--detail{border-color:#4899c938;background:#4899c914;color:#80dfff}.cdp-act-btn--detail:hover{background:#4899c92e;border-color:#4899c961}.cdp-load-more{display:block;margin:8px 12px;width:calc(100% - 24px);padding:9px 0;text-align:center;font-family:var(--font-h, system-ui);font-size:.76rem;font-weight:700;color:var(--cdp-cyan);background:#80dfff0f;border:1px solid rgba(128,223,255,.16);border-radius:10px;cursor:pointer;transition:background .12s ease}.cdp-load-more:hover:not(:disabled){background:#80dfff1f}.cdp-load-more:disabled{opacity:.5;cursor:default}@media(max-width:1024px){.cdp-root{width:290px}}@media(max-width:680px){.cdp-root{width:100%;border-right:none;border-bottom:1px solid var(--cdp-border);max-height:44vh}}@media(prefers-reduced-motion:reduce){.cdp-card,.cdp-act-btn,.cdp-copy-btn{transition:none!important}.cdp-spinner{animation:none}}.clm-root{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;position:relative;background:linear-gradient(180deg,#0b1736f5,#050a1ffa);border-left:1px solid rgba(128,223,255,.08)}.clm-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid rgba(128,223,255,.12);flex-shrink:0}.clm-title-area{display:flex;align-items:center;gap:10px;min-width:0;color:#80dfff}.clm-title-area>div{display:grid;gap:2px;min-width:0}.clm-title{font-family:var(--font-h, system-ui);font-weight:800;font-size:.96rem;color:#f5f8ff;letter-spacing:-.015em}.clm-subtitle{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.72rem;color:#c5d5f6b8}.clm-loading-tag{margin-left:4px;font-size:.68rem;color:#80dfff;border:1px solid rgba(128,223,255,.22);background:#80dfff14;padding:4px 8px;border-radius:999px}.clm-refresh-btn{min-height:34px;padding:0 13px;flex-shrink:0}.clm-tabs{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid rgba(128,223,255,.1);flex-shrink:0;overflow-x:auto;scrollbar-width:none}.clm-tabs::-webkit-scrollbar{display:none}.clm-tab{--chip-color: #80DFFF;display:inline-flex;align-items:center;gap:7px;min-height:31px;padding:0 12px;border:1px solid color-mix(in srgb,var(--chip-color) 32%,transparent);border-radius:999px;background:color-mix(in srgb,var(--chip-color) 10%,rgba(5,10,31,.88));color:color-mix(in srgb,var(--chip-color) 86%,white 14%);font-family:var(--font-h, system-ui);font-size:.72rem;font-weight:800;white-space:nowrap;cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.clm-tab:hover:not(.zero){transform:translateY(-1px);background:color-mix(in srgb,var(--chip-color) 18%,rgba(5,10,31,.82));box-shadow:0 0 18px color-mix(in srgb,var(--chip-color) 18%,transparent)}.clm-tab.active{background:color-mix(in srgb,var(--chip-color) 24%,rgba(5,10,31,.76));border-color:color-mix(in srgb,var(--chip-color) 68%,transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--chip-color) 20%,transparent),0 0 22px color-mix(in srgb,var(--chip-color) 20%,transparent)}.clm-tab.zero{opacity:.42;cursor:default}.clm-tab.all{--chip-color: #80DFFF}.clm-tab.reportando{--chip-color: #22c55e}.clm-tab.intermitente{--chip-color: #f59e0b}.clm-tab.sin-reporte{--chip-color: #ef4444}.clm-tab.theft{--chip-color: #d946ef}.clm-tab.no-location{--chip-color: #94a3b8}.clm-tab-dot{width:7px;height:7px;border-radius:50%;background:var(--chip-color);box-shadow:0 0 10px var(--chip-color)}.clm-tab-count{min-width:24px;padding:2px 7px;text-align:center;border-radius:999px;background:color-mix(in srgb,var(--chip-color) 16%,rgba(255,255,255,.05));color:#f5f8ff;font-size:.66rem}.clm-map-wrap{flex:1;position:relative;min-height:0;overflow:hidden}.clm-leaflet-map{width:100%;height:100%;min-height:560px;background:#050a1f}.clm-leaflet-map .leaflet-control-zoom a{background:#0a0f2af2!important;color:#f5f8ff!important;border-bottom-color:#80dfff24!important}.clm-leaflet-map .leaflet-control-zoom{border:1px solid rgba(128,223,255,.18)!important;border-radius:10px!important;overflow:hidden;box-shadow:0 12px 28px #0000004d!important}.clm-no-location-notice{position:absolute;top:52%;left:50%;transform:translate(-50%,-50%);z-index:500;display:grid;gap:6px;min-width:min(360px,calc(100% - 40px));padding:18px 22px;border:1px solid rgba(148,163,184,.22);border-radius:18px;background:#050a1feb;color:#c5d5f6;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none}.clm-no-location-notice strong{color:#f5f8ff}.clm-no-location-notice span{color:#c5d5f6b8;font-size:.82rem}.clm-div-icon,.clm-cluster-icon{background:transparent!important;border:0!important}.clm-beacon-marker{--status-color: #22c55e;position:relative;display:grid;place-items:center;animation:clmMarkerIn .24s ease both;will-change:transform}.clm-beacon-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--status-color);background:color-mix(in srgb,var(--status-color) 13%,transparent);box-shadow:0 0 20px color-mix(in srgb,var(--status-color) 62%,transparent),0 0 44px color-mix(in srgb,var(--status-color) 22%,transparent)}.clm-beacon-core{position:relative;z-index:2;width:24px;height:24px;display:grid;overflow:hidden;place-items:center;border-radius:50%;color:#80dfff;background:radial-gradient(circle,#80dfff29,#050a1feb 62%);border:1px solid rgba(128,223,255,.34);box-shadow:inset 0 0 14px #80dfff29}.clm-ciclope-svg{width:17px;height:17px;display:block}.clm-beacon-status-dot{position:absolute;z-index:3;right:2px;bottom:2px;width:10px;height:10px;border-radius:50%;background:var(--status-color);border:2px solid #07142E;box-shadow:0 0 10px var(--status-color)}.clm-beacon-marker.selected{transform:scale(1.12)}.clm-beacon-marker.selected .clm-beacon-ring{border-width:3px;animation:clmSelectedPulse 1.45s ease-in-out infinite}.clm-ciclope-marker-img{position:relative;z-index:4;width:24px!important;height:24px!important;max-width:24px!important;max-height:24px!important;min-width:24px!important;min-height:24px!important;object-fit:contain!important;display:block!important;border-radius:999px;padding:3px;box-sizing:border-box;background:#03091fd1;filter:drop-shadow(0 0 8px rgba(128,223,255,.44));pointer-events:none}.clm-popup-brand-img{width:24px!important;height:24px!important;max-width:24px!important;max-height:24px!important;object-fit:contain!important;display:block!important;filter:drop-shadow(0 0 8px rgba(128,223,255,.45));pointer-events:none}.clm-leaflet-map .clm-ciclope-marker-img,.clm-leaflet-map .clm-popup-brand-img{max-width:24px!important}.clm-cluster-bubble{--status-color: #22c55e;position:relative;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,color-mix(in srgb,var(--status-color) 80%,#0B1736 20%),#4899c9d1);border:2px solid color-mix(in srgb,var(--status-color) 62%,#80DFFF 38%);box-shadow:0 0 0 5px color-mix(in srgb,var(--status-color) 12%,transparent),0 0 30px color-mix(in srgb,var(--status-color) 52%,transparent),0 16px 38px #00000070;animation:clmClusterIn .26s ease both}.clm-cluster-aura{position:absolute;top:-9px;right:-9px;bottom:-9px;left:-9px;border-radius:inherit;background:radial-gradient(circle,color-mix(in srgb,var(--status-color) 22%,transparent),transparent 66%);filter:blur(4px)}.clm-cluster-value{position:relative;z-index:1;color:#f8fbff;font-family:var(--font-h, system-ui);font-size:.86rem;font-weight:900;text-shadow:0 2px 6px rgba(0,0,0,.36)}.clm-legend{position:absolute;right:16px;bottom:16px;z-index:1000;display:flex;flex-wrap:wrap;gap:10px;padding:8px 12px;border:1px solid rgba(128,223,255,.14);border-radius:12px;background:#050a1fe0;color:#c5d5f6d1;font-size:.68rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none}.clm-legend-item{display:inline-flex;align-items:center;gap:6px}.clm-legend-dot{width:8px;height:8px;border-radius:50%}.clm-leaflet-map .leaflet-popup-content-wrapper{background:#050a1ff7!important;border:1px solid rgba(128,223,255,.2)!important;border-radius:16px!important;box-shadow:0 18px 52px #0000009e!important;-webkit-backdrop-filter:blur(14px)!important;backdrop-filter:blur(14px)!important;padding:0!important;overflow:hidden}.clm-leaflet-map .leaflet-popup-content{margin:0!important;min-width:260px!important;color:inherit}.clm-leaflet-map .leaflet-popup-tip{background:#050a1ff7!important}.clm-leaflet-map .leaflet-popup-close-button{color:#c5d5f6b3!important;font-size:18px!important;padding:8px 10px!important}.clm-leaflet-map .leaflet-popup-close-button:hover{color:#f5f8ff!important;background:transparent!important}.clm-popup{min-width:260px;font-family:var(--font-b, system-ui)}.clm-popup-header{display:flex;align-items:center;gap:11px;padding:14px 40px 12px 14px;border-bottom:1px solid rgba(128,223,255,.1)}.clm-popup-brand{width:30px;height:30px;display:grid;place-items:center;flex-shrink:0;color:#80dfff;border-radius:12px;background:#80dfff14;border:1px solid rgba(128,223,255,.16)}.clm-popup-brand .clm-ciclope-svg{width:20px;height:20px}.clm-popup-title-wrap{display:grid;min-width:0;gap:3px}.clm-popup-name{color:#f5f8ff;font-family:var(--font-h, system-ui);font-weight:900;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clm-popup-sub{color:#c5d5f6ad;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.66rem;max-width:190px;overflow:hidden;text-overflow:ellipsis}.clm-popup-body{display:grid;gap:8px;padding:12px 14px}.clm-popup-status-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:2px}.clm-popup-status-badge,.clm-popup-active-badge,.clm-popup-theft-badge{border-radius:999px;border:1px solid;padding:3px 8px;font-family:var(--font-h, system-ui);font-size:.64rem;font-weight:900}.clm-popup-status-badge.reportando{color:#4ade80;border-color:#22c55e57;background:#22c55e1a}.clm-popup-status-badge.intermitente{color:#fbbf24;border-color:#f59e0b57;background:#f59e0b1a}.clm-popup-status-badge.sin_reporte{color:#f87171;border-color:#ef444457;background:#ef44441a}.clm-popup-status-badge.theft{color:#f0abfc;border-color:#d946ef57;background:#d946ef1a}.clm-popup-active-badge.active{color:#80dfff;border-color:#80dfff38;background:#80dfff12}.clm-popup-active-badge.inactive{color:#94a3b8;border-color:#94a3b838;background:#94a3b80f}.clm-popup-theft-badge{color:#f0abfc;border-color:#d946ef57;background:#d946ef1a}.clm-popup-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.clm-popup-key{color:#8ca5d2bd;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.clm-popup-val{color:#c5d5f6;font-size:.76rem;text-align:right}.clm-popup-footer-btns{display:flex;border-top:1px solid rgba(128,223,255,.1)}.clm-popup-map-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:9px 10px;border:0;border-right:1px solid rgba(128,223,255,.1);background:#80dfff0d;color:#c5d5f6c7;cursor:pointer;font-family:var(--font-h, system-ui);font-size:.68rem;font-weight:700}.clm-popup-map-btn:hover{background:#80dfff1a;color:#f5f8ff}.clm-popup-detail-btn{flex:1.4;display:inline-flex;align-items:center;justify-content:center;padding:9px 14px;border:0;background:#80dfff14;color:#80dfff;cursor:pointer;font-family:var(--font-h, system-ui);font-size:.72rem;font-weight:900}.clm-popup-detail-btn:hover{background:#80dfff24}@keyframes clmMarkerIn{0%{opacity:0;transform:scale(.72)}to{opacity:1;transform:scale(1)}}@keyframes clmClusterIn{0%{opacity:0;transform:scale(.76)}to{opacity:1;transform:scale(1)}}@keyframes clmSelectedPulse{0%,to{box-shadow:0 0 20px color-mix(in srgb,var(--status-color) 62%,transparent),0 0 44px color-mix(in srgb,var(--status-color) 22%,transparent)}50%{box-shadow:0 0 28px color-mix(in srgb,var(--status-color) 78%,transparent),0 0 70px color-mix(in srgb,var(--status-color) 34%,transparent)}}@media(max-width:900px){.clm-header{padding:10px 12px}.clm-tabs{padding:8px 10px}.clm-leaflet-map{min-height:440px}}@media(max-width:680px){.clm-header{align-items:flex-start;flex-direction:column}.clm-refresh-btn{width:100%;justify-content:center}.clm-leaflet-map{min-height:360px}.clm-legend{left:10px;right:10px;bottom:10px;justify-content:center}}@media(prefers-reduced-motion:reduce){.clm-tab,.clm-popup-detail-btn{transition:none!important}.clm-beacon-marker,.clm-cluster-bubble,.clm-beacon-marker.selected .clm-beacon-ring{animation:none!important}}.clm-mode-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid rgba(128,223,255,.1);flex-shrink:0;flex-wrap:wrap}.clm-mode-tabs{display:flex;gap:4px}.clm-mode-tab{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:8px;border:1px solid rgba(128,223,255,.14);background:#80dfff0a;color:#c5d5f69e;font-family:var(--font-h, system-ui);font-size:.72rem;font-weight:800;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap}.clm-mode-tab:hover:not(:disabled):not(.clm-mode-tab--active){background:#80dfff17;color:#c5d5f6;border-color:#80dfff38}.clm-mode-tab--active{background:linear-gradient(135deg,#80dfff33,#b478ff24);border-color:#80dfff61;color:#80dfff;box-shadow:0 0 14px #80dfff1a}.clm-mode-tab--disabled{opacity:.34;cursor:not-allowed}.clm-mode-tab-icon{font-size:.8rem;line-height:1}.clm-range-pills{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}.clm-range-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid rgba(128,223,255,.13);background:transparent;color:#c5d5f68f;font-family:var(--font-h, system-ui);font-size:.67rem;font-weight:700;cursor:pointer;transition:background .13s ease,border-color .13s ease,color .13s ease;white-space:nowrap}.clm-range-pill:hover{background:#80dfff12;color:#c5d5f6;border-color:#80dfff38}.clm-range-pill.active{background:#80dfff21;border-color:#80dfff57;color:#80dfff}.clm-route-meta{display:flex;align-items:center;gap:8px;padding:6px 14px;border-bottom:1px solid rgba(128,223,255,.07);flex-shrink:0;flex-wrap:wrap;background:#80dfff06}.clm-route-beacon-name{font-family:var(--font-h, system-ui);font-size:.76rem;font-weight:800;color:#f5f8ff;flex-shrink:0}.clm-route-stat{font-family:var(--font-h, system-ui);font-size:.64rem;font-weight:700;color:#c5d5f694;background:#80dfff0e;border:1px solid rgba(128,223,255,.09);padding:2px 8px;border-radius:999px;white-space:nowrap}.clm-error-tag{font-family:var(--font-h, system-ui);font-size:.66rem;font-weight:700;color:#f87171;border:1px solid rgba(239,68,68,.26);background:#ef444412;padding:2px 8px;border-radius:999px}.clm-overlay-center{position:absolute;top:0;right:0;bottom:0;left:0;z-index:600;display:flex;align-items:center;justify-content:center;background:#050a1f85;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none}.clm-overlay-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 32px;border-radius:20px;border:1px solid rgba(128,223,255,.15);background:#050a1ff0;color:#c5d5f6cc;text-align:center;max-width:min(360px,calc(100% - 40px));box-shadow:0 16px 48px #00000080}.clm-overlay-card strong{color:#f5f8ff;font-family:var(--font-h, system-ui);font-size:.9rem;font-weight:800}.clm-overlay-card span{font-size:.78rem;color:#c5d5f69e}.clm-overlay-icon{font-size:2rem;line-height:1}.clm-trips-panel{position:absolute;right:16px;bottom:56px;z-index:800;width:min(276px,calc(100% - 32px));max-height:272px;display:flex;flex-direction:column;border-radius:14px;border:1px solid rgba(128,223,255,.13);background:#050a1fed;box-shadow:0 12px 38px #00000075;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden}.clm-trips-panel-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 13px;border-bottom:1px solid rgba(128,223,255,.09);flex-shrink:0;font-family:var(--font-h, system-ui);font-size:.73rem;font-weight:800;color:#c5d5f6}.clm-trips-count{background:#80dfff17;color:#80dfff;border:1px solid rgba(128,223,255,.17);border-radius:999px;padding:1px 8px;font-size:.63rem;font-weight:900}.clm-trips-list{overflow-y:auto;flex:1;padding:4px 0;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.14) transparent}.clm-trips-list::-webkit-scrollbar{width:3px}.clm-trips-list::-webkit-scrollbar-thumb{background:#80dfff2e;border-radius:2px}.clm-trips-empty{padding:14px;text-align:center;font-size:.74rem;color:#c5d5f67a}.clm-trip-card{display:flex;flex-direction:column;gap:3px;padding:9px 13px;border-bottom:1px solid rgba(128,223,255,.05)}.clm-trip-card:last-child{border-bottom:none}.clm-trip-title{display:flex;align-items:center;justify-content:space-between;gap:6px}.clm-trip-title strong{font-family:var(--font-h, system-ui);font-size:.73rem;font-weight:800;color:#f5f8ff}.clm-trip-dur{font-family:var(--font-h, system-ui);font-size:.62rem;font-weight:700;color:#80dfff;background:#80dfff12;border:1px solid rgba(128,223,255,.13);padding:1px 6px;border-radius:999px;white-space:nowrap}.clm-trip-meta{display:flex;align-items:center;gap:4px;font-size:.62rem;color:#c5d5f685;flex-wrap:wrap}.clm-trip-arrow{color:#80dfff6b}.clm-trip-stats{display:flex;gap:8px;font-size:.6rem;color:#c5d5f66b}.clm-replay-bar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:800;display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:50px;border:1px solid rgba(217,70,239,.22);background:#050a1fed;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 28px #0000006b,0 0 0 1px #d946ef14;white-space:nowrap;max-width:calc(100% - 32px)}.clm-rp-ctrl{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 8px;border-radius:8px;border:1px solid rgba(128,223,255,.15);background:#80dfff0d;color:#c5d5f6c7;font-size:.74rem;cursor:pointer;transition:background .12s ease,color .12s ease}.clm-rp-ctrl:hover:not(:disabled){background:#80dfff1f;color:#f5f8ff}.clm-rp-ctrl:disabled{opacity:.34;cursor:default}.clm-rp-ctrl--play{min-width:86px;background:#d946ef17;border-color:#d946ef38;color:#f0abfc;font-family:var(--font-h, system-ui);font-size:.72rem;font-weight:800}.clm-rp-ctrl--play:hover{background:#d946ef29;border-color:#d946ef5c;color:#f5d0fe}.clm-rp-ctrl--play.playing{background:#d946ef26;border-color:#d946ef57;box-shadow:0 0 12px #d946ef33}.clm-rp-counter{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.68rem;color:#c5d5f69e;padding:0 4px}.clm-rp-ts{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.62rem;color:#c5d5f675}.clm-endpoint-marker{--ep-color: #22c55e;position:relative;display:grid;place-items:center;width:38px;height:38px}.clm-ep-halo{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--ep-color);background:color-mix(in srgb,var(--ep-color) 13%,transparent);box-shadow:0 0 14px color-mix(in srgb,var(--ep-color) 52%,transparent)}.clm-ep-img{position:relative;z-index:2;width:22px!important;height:22px!important;object-fit:contain;display:block;filter:drop-shadow(0 0 6px rgba(128,223,255,.38));pointer-events:none}.clm-ep-label{position:absolute;bottom:-18px;left:50%;transform:translate(-50%);font-family:var(--font-h, system-ui);font-size:.56rem;font-weight:900;color:var(--ep-color);background:#050a1fe6;border:1px solid color-mix(in srgb,var(--ep-color) 36%,transparent);border-radius:4px;padding:1px 5px;white-space:nowrap;pointer-events:none}.clm-replay-marker{--rp-color: #d946ef;position:relative;display:grid;place-items:center;width:46px;height:46px}.clm-rp-pulse{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--rp-color);background:color-mix(in srgb,var(--rp-color) 11%,transparent);animation:clmReplayPulse 1s ease-in-out infinite}.clm-rp-img{position:relative;z-index:2;width:26px!important;height:26px!important;object-fit:contain;display:block;filter:drop-shadow(0 0 8px rgba(217,70,239,.52));pointer-events:none}@keyframes clmReplayPulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--rp-color) 46%,transparent);transform:scale(1)}50%{box-shadow:0 0 0 8px color-mix(in srgb,var(--rp-color) 0%,transparent);transform:scale(1.06)}}.clm-route-popup{display:flex;flex-direction:column;gap:4px;padding:2px 0;font-family:var(--font-b, system-ui)}.clm-route-popup strong{color:#f5f8ff;font-family:var(--font-h, system-ui);font-size:.8rem;font-weight:800}.clm-route-popup span{color:#c5d5f6ad;font-size:.7rem}.clm-live-loading-tag{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:900;padding:4px 12px;border-radius:999px;border:1px solid rgba(128,223,255,.2);background:#050a1fe6;color:#80dfff;font-family:var(--font-h, system-ui);font-size:.67rem;font-weight:700;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none}@media(max-width:900px){.clm-mode-tab{padding:4px 11px;font-size:.68rem}.clm-trips-panel{max-height:220px}}@media(max-width:680px){.clm-mode-bar{padding:7px 10px;gap:6px}.clm-mode-tab{padding:4px 9px;font-size:.65rem}.clm-range-pills{margin-left:0}.clm-trips-panel{right:8px;left:8px;bottom:8px;width:auto;max-height:180px}.clm-replay-bar{padding:6px 10px;gap:4px;bottom:8px}.clm-rp-ts{display:none}}@media(prefers-reduced-motion:reduce){.clm-mode-tab,.clm-range-pill,.clm-rp-ctrl{transition:none!important}.clm-rp-pulse{animation:none!important}}.crp-root{flex:1;padding:32px 28px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.14) transparent;display:flex;flex-direction:column;gap:28px;max-width:1100px}.crp-root::-webkit-scrollbar{width:3px}.crp-root::-webkit-scrollbar-thumb{background:#80dfff2e;border-radius:2px}.crp-hero{display:flex;align-items:flex-start;gap:18px;background:#80dfff08;border:1px solid rgba(128,223,255,.1);border-radius:18px;padding:24px 26px}.crp-hero-icon{width:56px;height:56px;border-radius:16px;background:#80dfff14;border:1px solid rgba(128,223,255,.14);display:grid;place-items:center;color:#80dfff;flex-shrink:0}.crp-hero-title{font-family:var(--font-h, system-ui);font-size:1.2rem;font-weight:800;color:#f5f8ff;margin:0 0 6px;letter-spacing:-.01em}.crp-hero-sub{font-size:.88rem;color:#c5d5f6b3;line-height:1.6;margin:0}.crp-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.crp-kpi-card{display:flex;flex-direction:column;gap:16px;padding:24px 22px;border-radius:20px;border:1px solid rgba(128,223,255,.09);background:#0b1736b8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:default;box-shadow:0 4px 28px #0000003d;will-change:transform}.crp-kpi-green{border-color:#22c55e2e}.crp-kpi-warn{border-color:#f59e0b2e}.crp-kpi-red{border-color:#ef444438;box-shadow:0 4px 28px #ef444414}.crp-kpi-cyan{border-color:#80dfff29}.crp-kpi-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.crp-kpi-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0}.crp-kpi-icon--green{background:#22c55e14;border:1px solid rgba(34,197,94,.2);color:#4ade80}.crp-kpi-icon--warn{background:#f59e0b14;border:1px solid rgba(245,158,11,.2);color:#fbbf24}.crp-kpi-icon--red{background:#ef444417;border:1px solid rgba(239,68,68,.22);color:#f87171}.crp-kpi-icon--cyan{background:#80dfff12;border:1px solid rgba(128,223,255,.18);color:#80dfff}.crp-kpi-badge{font-family:var(--font-h, system-ui);font-size:.6rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:999px;border:1px solid;white-space:nowrap}.crp-kpi-badge--green{color:#4ade80;border-color:#22c55e47;background:#22c55e12}.crp-kpi-badge--warn{color:#fbbf24;border-color:#f59e0b47;background:#f59e0b12}.crp-kpi-badge--red{color:#f87171;border-color:#ef444447;background:#ef444414}.crp-kpi-badge--cyan{color:#80dfff;border-color:#80dfff3d;background:#80dfff12}.crp-kpi-metric{display:flex;align-items:baseline;gap:5px;line-height:1}.crp-kpi-value{font-family:var(--font-h, system-ui);font-size:3.2rem;font-weight:900;color:#f5f8ff;letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums}.crp-kpi-unit{font-family:var(--font-h, system-ui);font-size:1.05rem;font-weight:700;color:#c5d5f685}.crp-kpi-bar-track{height:5px;background:#80dfff0f;border-radius:999px;overflow:hidden}.crp-kpi-bar-fill{height:100%;border-radius:999px}.crp-kpi-bar-fill--green{background:linear-gradient(90deg,#16a34a,#4ade80)}.crp-kpi-bar-fill--cyan{background:linear-gradient(90deg,#2563eb,#80dfff)}.crp-kpi-fraction{font-family:var(--font-h, system-ui);font-size:.84rem;font-weight:700;color:#c5d5f699;font-variant-numeric:tabular-nums}.crp-kpi-fraction-value{font-size:1rem;font-weight:900;color:#f5f8ff}.crp-kpi-fraction-sep{color:#c5d5f652}.crp-kpi-fraction-total{color:#c5d5f675}.crp-kpi-fraction-label{color:#c5d5f685;font-weight:700}.crp-kpi-breakdown{display:flex;flex-direction:column;gap:8px}.crp-kpi-breakdown-row{display:flex;align-items:center;gap:9px}.crp-kpi-bd-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.crp-kpi-bd-dot--warn{background:#f59e0b;box-shadow:0 0 8px #f59e0b61}.crp-kpi-bd-dot--gray{background:#94a3b8}.crp-kpi-bd-label{flex:1;font-size:.76rem;color:#c5d5f694}.crp-kpi-bd-val{font-family:var(--font-h, system-ui);font-size:.9rem;font-weight:900;color:#f5f8ff;font-variant-numeric:tabular-nums}.crp-kpi-severity-bar{height:5px;background:#ef444417;border-radius:999px;overflow:hidden}.crp-kpi-severity-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#dc2626,#f87171)}.crp-kpi-secondary{display:flex;align-items:center;gap:7px;font-family:var(--font-h, system-ui);font-size:.73rem;font-weight:700;color:#f59e0bc7}.crp-kpi-secondary-dot{width:7px;height:7px;border-radius:50%;background:#f59e0b;box-shadow:0 0 7px #f59e0b61;flex-shrink:0}.crp-kpi-caption{font-size:.73rem;color:#c5d5f66b;line-height:1.5;margin:auto 0 0}.crp-note{font-size:.8rem;color:#c5d5f675;padding:14px 18px;background:#80dfff06;border:1px solid rgba(128,223,255,.08);border-radius:10px;margin:0;line-height:1.55}@media(max-width:900px){.crp-kpi-grid{grid-template-columns:1fr 1fr}.crp-kpi-value{font-size:2.6rem}}@media(max-width:680px){.crp-root{padding:18px 14px;gap:18px}.crp-hero{flex-direction:column;padding:18px;gap:14px}.crp-kpi-grid{grid-template-columns:1fr}.crp-kpi-value{font-size:2.8rem}}@media(prefers-reduced-motion:reduce){.crp-kpi-card{will-change:auto}}.cst-root{flex:1;padding:32px 28px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.14) transparent;display:flex;flex-direction:column;gap:20px;max-width:640px}.cst-section{background:var(--bg-panel);border:1px solid var(--line);border-radius:var(--r-md);padding:24px;display:flex;flex-direction:column;gap:20px}.cst-section-head{display:flex;align-items:flex-start;gap:16px}.cst-section-icon{width:48px;height:48px;border-radius:14px;background:#80dfff12;border:1px solid rgba(128,223,255,.12);display:grid;place-items:center;color:var(--cyan);flex-shrink:0}.cst-section-title{font-family:var(--font-h);font-size:1.05rem;font-weight:700;color:var(--text);margin:0 0 5px}.cst-section-sub{font-size:.82rem;color:var(--text-muted);margin:0}.cst-fields{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden}.cst-field{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;gap:16px;border-bottom:1px solid var(--line)}.cst-field:last-child{border-bottom:none}.cst-field-label{font-family:var(--font-h);font-size:.78rem;font-weight:700;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.cst-field-value{font-size:.88rem;color:var(--text);text-align:right;word-break:break-all}.cst-field-badge{font-family:var(--font-h);font-size:.72rem;font-weight:700;color:var(--cyan);background:#80dfff17;border:1px solid rgba(128,223,255,.18);padding:3px 10px;border-radius:99px}.cst-info-section{flex-direction:row;align-items:flex-start;gap:16px;background:#80dfff08;border-color:#80dfff1a}.cst-info-icon{width:40px;height:40px;border-radius:12px;background:#80dfff12;border:1px solid rgba(128,223,255,.12);display:grid;place-items:center;color:var(--cyan);flex-shrink:0;margin-top:2px}.cst-info-title{font-family:var(--font-h);font-size:.92rem;font-weight:700;color:var(--text);margin:0 0 8px}.cst-info-body{font-size:.82rem;color:var(--text-soft);line-height:1.6;margin:0}@media(max-width:680px){.cst-root{padding:18px 14px}.cst-section{padding:18px}.cst-info-section{flex-direction:column}}.cbdp-root{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;background:#050a1f;color:#c5d5f6;font-family:var(--font-b, system-ui)}.cbdp-header{display:flex;align-items:center;gap:16px;padding:14px 24px;border-bottom:1px solid rgba(128,223,255,.12);background:#07142efa;flex-shrink:0}.cbdp-back-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;min-height:34px;border:1px solid rgba(128,223,255,.22);border-radius:999px;background:#80dfff12;color:#80dfff;font-family:var(--font-h, system-ui);font-size:.78rem;font-weight:700;cursor:pointer;flex-shrink:0;transition:background .16s ease,border-color .16s ease}.cbdp-back-btn:hover{background:#80dfff21;border-color:#80dfff61}.cbdp-title-area{flex:1;min-width:0;display:grid;gap:4px}.cbdp-title-main{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.cbdp-title-h2{margin:0;font-family:var(--font-h, system-ui);font-size:1.1rem;font-weight:900;color:#f5f8ff;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cbdp-uuid{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.68rem;color:#c5d5f68c;white-space:nowrap}.cbdp-title-meta{display:flex;gap:8px;flex-wrap:wrap}.cbdp-meta-chip{font-size:.72rem;color:#c5d5f6b8;background:#80dfff12;border:1px solid rgba(128,223,255,.12);border-radius:999px;padding:2px 8px}.cbdp-header-badges{display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0}.cbdp-badge{border-radius:999px;border:1px solid;padding:4px 10px;font-family:var(--font-h, system-ui);font-size:.68rem;font-weight:900}.cbdp-badge--online{color:#4ade80;border-color:#22c55e57;background:#22c55e1a}.cbdp-badge--intermittent{color:#fbbf24;border-color:#e4840a57;background:#e4840a1a}.cbdp-badge--offline{color:#f87171;border-color:#ef444457;background:#ef44441a}.cbdp-badge--theft{color:#f0abfc;border-color:#d946ef57;background:#d946ef1a}.cbdp-badge--active{color:#80dfff;border-color:#80dfff38;background:#80dfff12}.cbdp-badge--inactive{color:#94a3b8;border-color:#94a3b838;background:#94a3b80f}.cbdp-filters{display:flex;align-items:center;gap:12px;padding:10px 24px;border-bottom:1px solid rgba(128,223,255,.08);background:#0b1736f5;flex-shrink:0;flex-wrap:wrap}.cbdp-presets{display:flex;gap:6px;flex-wrap:wrap}.cbdp-preset-btn{padding:5px 13px;min-height:30px;border:1px solid rgba(128,223,255,.18);border-radius:999px;background:#80dfff0f;color:#c5d5f6c7;font-family:var(--font-h, system-ui);font-size:.72rem;font-weight:700;cursor:pointer;transition:background .14s ease,color .14s ease,border-color .14s ease}.cbdp-preset-btn:hover{background:#80dfff1c;color:#f5f8ff}.cbdp-preset-btn.active{background:#80dfff2e;border-color:#80dfff70;color:#80dfff}.cbdp-custom-dates{display:flex;gap:10px;flex-wrap:wrap}.cbdp-custom-dates label{display:flex;align-items:center;gap:6px;font-size:.72rem;color:#c5d5f6b8}.cbdp-custom-dates input{padding:4px 8px;background:#0b1736e6;border:1px solid rgba(128,223,255,.18);border-radius:8px;color:#f5f8ff;font-size:.72rem;outline:none}.cbdp-custom-dates input:focus{border-color:#80dfff70}.cbdp-btn-outline{padding:6px 14px;min-height:32px;border:1px solid rgba(128,223,255,.22);border-radius:10px;background:#80dfff12;color:#80dfff;font-family:var(--font-h, system-ui);font-size:.74rem;font-weight:700;cursor:pointer;transition:background .14s ease,border-color .14s ease}.cbdp-btn-outline:hover:not(:disabled){background:#80dfff21;border-color:#80dfff61}.cbdp-btn-outline:disabled{opacity:.5;cursor:default}.cbdp-refresh-btn{margin-left:auto}.cbdp-error-notice{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 24px;background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.22);color:#fca5a5;font-size:.82rem;flex-shrink:0}.cbdp-error-notice button{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;opacity:.7}.cbdp-error-notice button:hover{opacity:1}.cbdp-kpis{display:flex;gap:10px;padding:12px 24px;border-bottom:1px solid rgba(128,223,255,.08);flex-shrink:0;overflow-x:auto;scrollbar-width:none}.cbdp-kpis::-webkit-scrollbar{display:none}.cbdp-kpi-card{display:grid;gap:3px;min-width:110px;padding:10px 14px;background:#0b1736e6;border:1px solid rgba(128,223,255,.1);border-radius:14px;flex-shrink:0}.cbdp-kpi-card.small{min-width:90px}.cbdp-kpi-label{font-family:var(--font-h, system-ui);font-size:.62rem;font-weight:800;color:#80dfffb3;text-transform:uppercase;letter-spacing:.06em}.cbdp-kpi-value{font-family:var(--font-h, system-ui);font-size:1.04rem;font-weight:900;color:#f5f8ff}.cbdp-kpi-card.small .cbdp-kpi-value{font-size:.84rem}.cbdp-tabs{display:flex;gap:2px;padding:10px 24px 0;border-bottom:1px solid rgba(128,223,255,.1);flex-shrink:0;overflow-x:auto;scrollbar-width:none}.cbdp-tabs::-webkit-scrollbar{display:none}.cbdp-tab-btn{padding:8px 16px;min-height:36px;border:0;border-bottom:2px solid transparent;background:transparent;color:#c5d5f69e;font-family:var(--font-h, system-ui);font-size:.8rem;font-weight:700;cursor:pointer;white-space:nowrap;border-radius:10px 10px 0 0;transition:color .14s ease,background .14s ease}.cbdp-tab-btn:hover{color:#f5f8ff;background:#80dfff0f}.cbdp-tab-btn.active{color:#80dfff;border-bottom-color:#80dfff;background:#80dfff14}.cbdp-tab-content{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.cbdp-map-wrap{flex:1;position:relative;min-height:0;overflow:hidden}.cbdp-leaflet-map{width:100%;height:100%;min-height:420px;background:#050a1f}.cbdp-leaflet-map .leaflet-control-zoom a{background:#0a0f2af2!important;color:#f5f8ff!important;border-bottom-color:#80dfff24!important}.cbdp-leaflet-map .leaflet-control-zoom{border:1px solid rgba(128,223,255,.18)!important;border-radius:10px!important;overflow:hidden}.cbdp-map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:800;display:flex;align-items:center;justify-content:center;background:#050a1fb8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cbdp-map-overlay span{color:#80dfff;font-family:var(--font-h, system-ui);font-weight:700;font-size:.88rem}.cbdp-map-overlay--muted{background:#050a1f8c}.cbdp-map-overlay--muted span{color:#c5d5f69e}.cbdp-map-footer{position:absolute;bottom:14px;left:14px;z-index:900;display:flex;align-items:center;gap:10px;font-size:.72rem;color:#c5d5f6bf;background:#050a1fdb;padding:5px 12px;border-radius:10px;border:1px solid rgba(128,223,255,.12);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none}.cbdp-trip-active-badge{display:inline-flex;align-items:center;gap:6px;color:#80dfff;pointer-events:all}.cbdp-trip-active-badge button{background:none;border:none;color:inherit;cursor:pointer;font-size:.82rem;opacity:.7;padding:0 2px}.cbdp-trip-active-badge button:hover{opacity:1}.cbdp-replay-controls{position:absolute;bottom:14px;left:50%;transform:translate(-50%);z-index:900;display:flex;align-items:center;gap:8px;padding:8px 16px;background:#050a1feb;border:1px solid rgba(128,223,255,.18);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cbdp-replay-ctrl{padding:5px 12px;min-height:30px;border:1px solid rgba(128,223,255,.18);border-radius:8px;background:#80dfff12;color:#80dfff;font-family:var(--font-h, system-ui);font-size:.78rem;font-weight:700;cursor:pointer;transition:background .12s ease}.cbdp-replay-ctrl:hover:not(:disabled){background:#80dfff24}.cbdp-replay-ctrl:disabled{opacity:.4;cursor:default}.cbdp-replay-ctrl--play{min-width:64px}.cbdp-replay-counter{color:#c5d5f6bf;font-size:.74rem}.cbdp-replay-ts{color:#c5d5f69e;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.68rem}.cbdp-list-panel{flex:1;overflow-y:auto;padding:16px 24px;display:grid;gap:10px;align-content:start;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.14) transparent}.cbdp-trip-card,.cbdp-stop-card{display:grid;gap:6px;padding:14px 16px;background:#0b1736e6;border:1px solid rgba(128,223,255,.1);border-radius:16px;transition:border-color .14s ease}.cbdp-trip-card:hover,.cbdp-stop-card:hover{border-color:#80dfff38}.cbdp-trip-card.selected{border-color:#80dfff6b;background:#80dfff0f}.cbdp-card-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.cbdp-card-header strong{color:#f5f8ff;font-family:var(--font-h, system-ui);font-size:.86rem;font-weight:900}.cbdp-trip-duration{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.72rem;color:#80dfff;background:#80dfff14;padding:2px 8px;border-radius:999px;border:1px solid rgba(128,223,255,.16)}.cbdp-card-meta{display:flex;gap:6px;flex-wrap:wrap;font-size:.72rem;color:#c5d5f6ad}.cbdp-arrow{color:#80dfff70}.cbdp-card-stats{display:flex;gap:12px;font-size:.72rem;color:#c5d5f6b8}.cbdp-packets-panel{flex:1;overflow-y:auto;padding:16px 24px;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.14) transparent}.cbdp-packets-chart{display:grid;gap:8px}.cbdp-bar-row{display:flex;align-items:center;gap:10px;font-size:.74rem}.cbdp-bar-date{min-width:70px;color:#c5d5f6b8;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.cbdp-bar-track{flex:1;height:8px;border-radius:999px;background:#80dfff14;overflow:hidden}.cbdp-bar-fill{height:100%;background:linear-gradient(90deg,#4899c9,#80dfff);border-radius:999px;transition:width .4s ease}.cbdp-bar-count{min-width:44px;text-align:right;color:#c5d5f6;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.cbdp-empty{padding:32px 24px;text-align:center;color:#c5d5f685;font-size:.84rem}.cbdp-popup{min-width:160px;font-family:var(--font-b, system-ui);color:#c5d5f6}.cbdp-popup strong{color:#f5f8ff;font-weight:900;display:block;margin-bottom:4px}.cbdp-popup p{margin:0;font-size:.74rem;color:#c5d5f6b8}.cbdp-leaflet-map .leaflet-popup-content-wrapper{background:#050a1ff7!important;border:1px solid rgba(128,223,255,.2)!important;border-radius:14px!important;box-shadow:0 18px 52px #00000094!important;padding:10px 14px!important}.cbdp-leaflet-map .leaflet-popup-content{margin:0!important;color:inherit}.cbdp-leaflet-map .leaflet-popup-tip{background:#050a1ff7!important}.cbdp-leaflet-map .leaflet-popup-close-button{color:#c5d5f6b3!important}.cbdp-div-marker{background:transparent!important;border:0!important}.cbdp-endpoint-marker{--m-color: #22c55e;position:relative;width:42px;height:42px;display:grid;place-items:center}.cbdp-ep-halo{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--m-color);background:color-mix(in srgb,var(--m-color) 14%,transparent);box-shadow:0 0 18px color-mix(in srgb,var(--m-color) 52%,transparent)}.cbdp-ep-img{position:relative;z-index:2;width:22px;height:22px;object-fit:contain}.cbdp-ep-label{position:absolute;bottom:-18px;left:50%;transform:translate(-50%);white-space:nowrap;font-size:.6rem;font-weight:900;font-family:var(--font-h, system-ui);color:var(--m-color);background:#050a1fd9;padding:1px 5px;border-radius:4px}.cbdp-replay-marker{--marker-color: #80DFFF;position:relative;width:54px;height:54px;display:grid;place-items:center}.cbdp-replay-marker>span{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--marker-color);background:color-mix(in srgb,var(--marker-color) 12%,transparent);box-shadow:0 0 22px color-mix(in srgb,var(--marker-color) 50%,transparent);animation:cbdpReplayPulse 1.2s ease-in-out infinite}.cbdp-replay-img{position:relative;z-index:2;width:26px;height:26px;object-fit:contain}.cbdp-stop-marker{width:32px;height:32px;border-radius:50%;background:#4899c9d9;border:2px solid #80DFFF;display:flex;align-items:center;justify-content:center;color:#f5f8ff;font-family:var(--font-h, system-ui);font-size:.7rem;font-weight:900}@keyframes cbdpReplayPulse{0%,to{opacity:.7;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}@media(max-width:900px){.cbdp-header{padding:10px 16px;gap:10px;flex-wrap:wrap}.cbdp-filters{padding:8px 16px}.cbdp-kpis{padding:10px 16px}.cbdp-tabs{padding:8px 16px 0}.cbdp-list-panel,.cbdp-packets-panel{padding:12px 16px}}@media(max-width:680px){.cbdp-title-h2{font-size:.96rem}.cbdp-header-badges{display:none}.cbdp-replay-controls{left:12px;right:12px;transform:none;flex-wrap:wrap;justify-content:center}}@media(prefers-reduced-motion:reduce){.cbdp-replay-marker>span{animation:none}.cbdp-preset-btn,.cbdp-back-btn,.cbdp-btn-outline{transition:none!important}}.dash-body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.dash-section-map{flex:1;display:flex;overflow:hidden;min-height:0}.dash-section-scroll{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(128,223,255,.14) transparent}.dash-section-flex{flex:1;display:flex;overflow-y:auto}.dash-charts-row{display:flex;gap:14px;padding:0 24px 16px;flex-shrink:0}.dash-home-layout{display:flex;height:480px;flex-shrink:0;overflow:hidden;border-top:1px solid var(--line)}.dash-analytics-toggle-bar{display:flex;justify-content:flex-end;padding:6px 24px 2px;flex-shrink:0}.dash-analytics-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;min-height:30px;border:1px solid rgba(128,223,255,.22);border-radius:999px;background:#80dfff12;color:#80dfff;font-family:var(--font-h, system-ui);font-size:.74rem;font-weight:700;cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .16s ease}.dash-analytics-toggle-btn:hover{background:#80dfff21;border-color:#80dfff61;transform:translateY(-1px)}.dash-section-scroll--map-expanded{display:flex;flex-direction:column;overflow:hidden}.dash-home-layout--map-expanded{flex:1;height:auto;min-height:calc(100vh - 220px)}@media(max-width:1024px){.dash-charts-row{flex-direction:column;padding:0 16px 14px;gap:10px}.dash-home-layout{height:440px}}@media(max-width:680px){.dash-section-map{flex-direction:column;overflow:visible;flex:unset;min-height:unset}.dash-body{overflow-y:auto}.dash-charts-row{padding:0 12px 12px;gap:8px}.dash-home-layout{flex-direction:column;height:auto;min-height:600px;border-top:none}}
