.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}}.leaflet-control-fullscreen a{background:#fff url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAA0CAYAAACU7CiIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAN1wAADdcBQiibeAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAACoSURBVFiF7ZZhDoAgCIWxdbF3suxkHM3+1FaOmNqyIr6fiHuJTyKklKgHQxcVF7rCKAUBiA5h5tCSR/T0iTakL9PWz05IZNEM3YSCt6BvCgFI2ps4Q9v3k9Ldgdrr8nrX9LYc7wwu5EIu9KCQT6rq+r8mVbV0ewBEIpqy8MzMsWR/8f+oxmES9u7olZPqLKQeYtqkWuy61V2xND/H3h35pNqMPTPYE1oAnZZStKN8jj8AAAAASUVORK5CYII=) no-repeat 0 0;background-size:26px 52px}.leaflet-touch .leaflet-control-fullscreen a{background-position:2px 2px}.leaflet-fullscreen-on .leaflet-control-fullscreen a{background-position:0 -26px}.leaflet-touch.leaflet-fullscreen-on .leaflet-control-fullscreen a{background-position:2px -24px}.leaflet-container:-webkit-full-screen{width:100%!important;height:100%!important}.leaflet-container.leaflet-fullscreen-on{width:100%!important;height:100%!important}.leaflet-pseudo-fullscreen{position:fixed!important;width:100%!important;height:100%!important;top:0!important;left:0!important;z-index:99999}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.leaflet-control-fullscreen a{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAABoCAYAAAC+NNNnAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAbrwAAG68BXhqRHAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAEhSURBVHic7dpBDoIwFADRj/FiPRlwsh4NN5CoiVKg1Ukzb43ApKK1dliWJXpy+/cN1GYQnUF0BtEZRHcvPTCldGhKkXMefnm+TXcjZBBd8TP0rvQ9ffb1R5+xTXcjZBCdQXQG0Q2u+sAZRGcQnUF0p9cUrv4eanW97kbIIDqD6AyiO70ut7du1mrdbU93I2QQnWsKdAbRGURnEJ1BdAbRGURnEJ1BdAbRueeUziA695zSGURnEN3pT7lvUkpTRIw7h80556n2tauPUGFMRMS4HltV9f+HWs3RSnX3DBlEZxCdQXQt9pzOUfbFuh179Xovqo/QOp35eKNPmkx9mszl1hudWpx7T3fPkEF0BtG555TOIDr3nNIZRGcQnUF0BtE9AF5WX48h7QeZAAAAAElFTkSuQmCC)}}:root{--bg: #050d2e;--bg-elevated: #0f172a;--bg-soft: #060f39;--accent: #38bdf8;--accent-soft: rgba(56, 189, 248, .1);--text: #e5e7eb;--text-muted: #9ca3af;--border: #1f2937;--border-subtle: #1f2937;--danger: #f97373;--warning: #3b82f6;--success: #22c55e;--accent-red: #ef4444;--accent-green: #22c55e;--accent-yellow: #facc15;--radius-lg: 18px;--radius-md: 12px;--card-radius: 12px;--shadow-soft: 0 18px 45px rgba(15, 23, 42, .8);--transition-fast: .18s ease-out;--muted: #9ca3af;--surface-1: var(--bg);--surface-2: var(--bg-elevated);--surface-3: rgba(15, 23, 42, .85);--text-soft: #cbd5f5;--row-even: rgba(15, 23, 42, .85);--row-odd: rgba(12, 16, 32, .95);--overlay: rgba(15, 23, 42, .9);--kpi-bg: radial-gradient( circle at 0 0, rgba(148, 163, 184, .22), rgba(15, 23, 42, .95) );--kpi-border: rgba(56, 189, 248, .55);--kpi-shadow: 0 14px 32px rgba(2, 6, 23, .95), inset 0 1px 0 rgba(255, 255, 255, .06);--mini-chart-bg: radial-gradient( circle at 0 0, rgba(148, 163, 184, .16), var(--surface-3) );--mini-chart-border: rgba(55, 65, 81, .9);--chart-text: var(--text-muted);--chart-muted: rgba(148, 163, 184, .85);--chart-grid: rgba(148, 163, 184, .12);--chart-critical: #EF4444;--chart-major: #F97316;--chart-minor: #FACC15;--critical-bg: rgba(239, 68, 68, .18);--critical-border: rgba(239, 68, 68, .9);--critical-text: #d70000;--critical-glow: rgba(239, 68, 68, .55);--online: #22c55e;--critical: #EF4444;--warning: #FACC15;--offline: #64748b;--maintenance: #3b82f6;--decommissioned: #78716c;--selected: #38bdf8;--default: #9ca3af;--bar: #6b7280}[data-theme=light]{--bg: #eeeeee;--bg-elevated: #ffffff;--bg-soft: #f1f5f9;--surface-1: #f8fafc;--surface-2: #ffffff;--surface-3: #f1f5f9;--text: #0f172a;--text-muted: #475569;--text-soft: #64748b;--muted: #64748b;--border: #e2e8f0;--border-subtle: #cbd5e1;--overlay: rgba(255, 255, 255, .85);--row-even: #f8fafc;--row-odd: #f1f5f9;--shadow-soft: 0 10px 28px rgba(15, 23, 42, .08);--kpi-bg: #ffffff;--kpi-border: var(--accent);--kpi-shadow: var(--shadow-soft);--kpi-shadow: 0 3px 5px rgba(126, 129, 136, .95), inset 0 1px 0 rgba(255, 255, 255, .05);--mini-chart-bg: var(--surface-2);--mini-chart-border: var(--border);--chart-text: var(--text-muted);--chart-muted: #64748b;--chart-grid: rgba(15, 23, 42, .1);--bar: var(--selected)}*{box-sizing:border-box}html,body{margin:0;padding:0;color:var(--text);font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;overscroll-behavior:none}body{display:flex;align-items:stretch;min-height:100vh}.app{display:grid;grid-template-columns:260px 1fr;width:100%;background:var(--surface-1);border-radius:0;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-soft);height:100vh}.sidebar{width:260px;background:var(--surface-2);border-right:1px solid var(--border);padding:18px 16px 14px;display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden}.sidebar:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 0 0,rgba(56,189,248,.12),transparent 45%),radial-gradient(circle at 100% 100%,rgba(79,70,229,.22),transparent 50%);opacity:.9;pointer-events:none}.sidebar>div{position:relative;z-index:1}.logo{display:flex;align-items:center;gap:10px;margin-bottom:0;text-align:left}.logo-img{width:140px;height:auto}.logo-badge{width:34px;height:34px;border-radius:999px;background:radial-gradient(circle at 30% 20%,#e0f2fe,#38bdf8 40%,#4f46e5 75%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#020617;box-shadow:0 10px 26px #38bdf8bf}.logo-title{font-weight:600;letter-spacing:.08em;font-size:13px;text-transform:uppercase;color:var(--text)}.logo-subtitle{font-size:11px;color:var(--text-muted);margin-top:2px}.nav-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);margin:14px 0 6px}.nav-list{display:flex;flex-direction:column;gap:4px}.nav-item{border-radius:999px;padding:8px 10px;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);cursor:pointer;border:1px solid transparent;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform .12s ease-out;text-decoration:none}.nav-item span.icon{width:18px;text-align:center;font-size:14px}.nav-item.active{background:radial-gradient(circle at 0 0,rgba(56,189,248,.16),var(--surface-3)),linear-gradient(135deg,var(--surface-3),var(--bg));border-color:#38bdf880;color:var(--text);transform:translateY(-1px);box-shadow:0 3px 5px #0f172ae6}.nav-item:hover:not(.active){background:var(--overlay);border-color:#334155cc;color:var(--text)}.sidebar-footer{margin-top:auto;padding-top:10px;border-top:1px dashed rgba(51,65,85,.8);font-size:11px;color:var(--text-muted)}.sidebar-footer strong{display:block;font-size:12px;color:var(--text);margin-top:2px}.footer-tag{margin-top:6px;display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;border:1px solid rgba(148,163,184,.8);background:var(--overlay);font-size:10px;color:var(--text-soft)}.footer-dot{width:7px;height:7px;border-radius:999px;background:#4ade80;box-shadow:0 0 0 3px #22c55e66}.main{flex:1;display:flex;flex-direction:column;gap:10px;width:calc(100vw - 262px);background:var(--surface-1);position:relative;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:transparent transparent}.main::-webkit-scrollbar{width:0}.main:hover{scrollbar-width:thin}.main:hover::-webkit-scrollbar{width:4px}.main:hover::-webkit-scrollbar-track{background:transparent}.main:hover::-webkit-scrollbar-thumb{background:#94a3b8cc;border-radius:999px}.main .topbar{position:sticky;top:0;height:64px;padding:0 16px;z-index:2}.main .topbar,header.topbar{background:var(--surface-2)}.topbar-title{color:var(--text)}.views{flex:1;padding:12px 16px 14px}header.topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;min-height:72px;padding:12px 16px;background:var(--surface-2);z-index:1000}.topbar-left{display:flex;align-items:center;height:100%}.topbar-title-block{display:flex;flex-direction:column;gap:2px}.topbar-title{font-size:18px;font-weight:600;letter-spacing:.04em;color:var(--text)}.topbar-subtitle{font-size:11px;color:var(--text-muted)}.topbar-right{display:flex;align-items:center;gap:8px}.user-menu{position:relative}.avatar{cursor:pointer;border:none;background:none}.user-dropdown{position:absolute;top:110%;right:0;min-width:160px;background:var(--overlay);border:1px solid rgba(148,163,184,.2);border-radius:8px;box-shadow:0 12px 30px #00000059;z-index:2000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:240px}.user-dropdown-item{width:100%;padding:10px 14px;background:none;border:none;color:var(--text);text-align:left;cursor:pointer}.user-dropdown-item:hover{background:#94a3b81f}.user-dropdown-divider{height:1px;background:#94a3b833;margin:6px 0}.user-dropdown-item.logout{color:#f87171;display:flex;align-items:center;gap:10px;text-align:left}.user-dropdown-item.logout:hover{background-color:#ef44441a}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;font-size:8px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border:1px solid transparent;background:var(--overlay);color:var(--text)}.chip-dot{width:7px;height:7px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 3px #22c55e66}.chip.critical{background:color-mix(in srgb,var(--chart-critical),transparent calc(100% - var(--alpha-bg) * 100%));color:var(--chart-critical);border-color:var(--chart-critical);box-shadow:0 0 8px color-mix(in srgb,var(--chart-critical),transparent 45%)}.chip.warn{background:color-mix(in srgb,var(--chart-major),transparent calc(100% - var(--alpha-bg) * 100%));color:var(--chart-major);border-color:var(--chart-major);box-shadow:0 0 8px color-mix(in srgb,var(--chart-major),transparent 45%)}.chip.minor{background:color-mix(in srgb,var(--chart-minor),transparent calc(100% - var(--alpha-bg) * 100%));color:var(--chart-minor);border-color:var(--chart-minor);box-shadow:0 0 8px color-mix(in srgb,var(--chart-minor),transparent 45%)}.status-online{color:#bbf7d0;border-color:#22c55ecc;background:#166534b3}.status-warning{color:#dbeafe;border-color:#3b82f6cc;background:#1e40afb3}.status-offline{color:#fecaca;border-color:#f87171cc;background:#e6e6e6b3}.status-critical{color:#fecaca;border-color:#ef4444cc;background:#fbfbfbb3}.select,.search-input{border-radius:999px;border:1px solid rgba(148,163,184,.6);background:var(--surface-2);color:var(--text);font-size:11px;padding:6px 10px;outline:none}.search-input{padding-left:26px;background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='7' cy='7' r='4' stroke='%239CA3AF' stroke-width='1.3'/%3E%3Cline x1='10.5' y1='10.5' x2='14' y2='14' stroke='%239CA3AF' stroke-width='1.3' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:8px center}.select:focus,.search-input:focus{border-color:#38bdf8e6;box-shadow:0 0 0 1px #38bdf8cc}.avatar{width:26px;height:26px;border-radius:999px;background:radial-gradient(circle at 30% 30%,#f97316,#7c2d12);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-soft);position:relative;overflow:hidden}.views{display:flex;flex-direction:column;gap:10px}.view{display:none}.view.active{display:block}.kpi-card{position:relative;overflow:hidden;background:var(--kpi-bg);border:1px solid var(--kpi-border);box-shadow:var(--kpi-shadow);border-radius:var(--card-radius);padding:10px 12px;color:var(--text);text-shadow:0 1px 1px rgba(0,0,0,.35);transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform .12s ease}.kpi-card:hover{border-color:var(--accent);box-shadow:var(--shadow-soft)}.kpi-pill{position:absolute;top:8px;left:8px;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:600;text-transform:uppercase}.kpi-label{margin-top:24px;font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.kpi-value{margin-top:8px;font-size:32px;font-weight:700;color:var(--text)}.kpi-trend{position:absolute;bottom:8px;right:8px;font-size:11px}.kpi-trend.trend-positive{color:var(--success)}.kpi-trend.trend-negative{color:var(--danger)}.status-badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase}.status-online{background:#22c55e1a;color:#22c55e}.status-warning{background:#f59e0b1a;color:#f59e0b}.status-critical{background:#ef44441a;color:#ef4444}.status-offline{background:#6b72801a;color:#6b7280}.section{margin-bottom:16px}.kpi-grid.fleet-summary{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:0}.section-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.section-title{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}.section-subtitle{font-size:11px;color:var(--muted)}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:16px}.kpi-grid.sites-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:10px}.kpi-label{font-size:11px;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.14em;display:flex;justify-content:space-between;align-items:center}.kpi-badge{padding:3px 7px;border-radius:999px;font-size:10px;text-transform:uppercase;letter-spacing:.14em;border:1px solid var(--border-subtle);background:var(--surface-2);color:var(--text-muted)}.kpi-badge.ok{color:var(--accent-green);border-color:#22c55e99}.kpi-badge.warn{color:var(--accent-yellow);border-color:#eab30899}.kpi-value{font-size:22px;font-weight:600}.kpi-subvalue{font-size:11px;color:var(--muted);margin-top:6px}.kpi-trend-positive{font-size:11px;color:var(--accent-green);margin-top:6px}.kpi-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11px;color:var(--muted)}.kpi-pill{padding:3px 8px;border-radius:999px;font-size:10px;text-transform:uppercase;letter-spacing:.14em;border:1px solid color-mix(in srgb,var(--text),transparent 75%);background:var(--overlay);color:var(--text-muted)}.kpi-trend{font-size:11px}.kpi-trend.positive{color:var(--accent-green)}.kpi-trend.negative{color:var(--accent-red)}.kpi-spark{position:absolute;right:6px;bottom:4px;font-size:9px;color:#94a3b899}.row{display:grid;gap:10px;margin-bottom:10px}.row-2-1{grid-template-columns:2fr 1fr}.row-1-1{grid-template-columns:1fr 1fr}.row-2-1-bottom{grid-template-columns:2fr 1fr}.main-grid{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,2fr);gap:10px}.card{background:var(--surface-2);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:10px 12px;box-shadow:var(--shadow-soft)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.card-title{font-size:14px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}.card-subtitle{font-size:12px;color:var(--text-muted)}.card-actions{display:flex;gap:6px;align-items:center}.badge{font-size:10px;padding:3px 7px;border-radius:999px;border:1px solid var(--border-subtle);color:var(--muted)}.map-container{position:relative;border-radius:12px;border:1px solid rgba(55,65,81,.9);overflow:hidden;height:240px;z-index:1}#map{width:100%;height:100%}.map-overlay-label{position:absolute;top:8px;left:10px;font-size:11px;color:#f9fafb;text-shadow:0 1px 2px rgba(0,0,0,.8);z-index:1;background:#0f172ab3;padding:3px 8px;border-radius:999px}.sites-table{width:100%;border-collapse:collapse;border-radius:12px;border-bottom:1px solid var(--border-subtle);overflow:hidden;display:flex;flex-direction:column;min-height:0}.sites-table th,.sites-table td{padding:6px 10px;vertical-align:middle}.sites-table th:not(:first-child),.sites-table td:not(:first-child){text-align:center}.sites-table-header{padding:6px 10px;font-size:11px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-subtle);background:var(--surface-3)}.sites-table-body{max-height:220px;overflow-y:auto;overflow-x:auto;font-size:11px;scrollbar-width:thin;scrollbar-color:transparent transparent;min-height:0}.sites-table-body::-webkit-scrollbar{width:6px;height:6px}.sites-table-body:hover::-webkit-scrollbar{width:6px;height:6px}.sites-table-body::-webkit-scrollbar-track{background:transparent}.sites-table-body::-webkit-scrollbar-thumb{background:transparent;border-radius:999px;transition:background-color .2s ease}.sites-table-body:hover{scrollbar-color:rgba(148,163,184,.7) transparent}.sites-table-body:hover::-webkit-scrollbar-thumb{background:#94a3b8b3}.sites-table-body:hover::-webkit-scrollbar-thumb:hover{background:#d1d5dbe6}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:6px 10px;white-space:nowrap}th{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);border-bottom:1px solid rgba(55,65,81,.9);position:sticky;top:0;z-index:1}th,.small-table th,.reports-table-scroll th{background:var(--surface-2)}tr:nth-child(2n) td{background:var(--row-even)}tr:nth-child(odd) td{background:var(--row-odd)}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:2px 7px;border-radius:999px;font-size:10px;font-weight:600;letter-spacing:.04em;line-height:1;border:1px solid rgba(148,163,184,.6);background:var(--overlay);color:var(--text);white-space:nowrap}.status-online{background:#10b98129;color:var(--accent-green)}.status-offline{background:#4b556359;color:var(--text-soft)}.status-warning{background:#f59e0b29;color:var(--accent-yellow)}.status-critical{background:#ef44442e;color:var(--accent-red)}.status-maintenance{background:#3b82f629;color:#3b82f6}.status-decommissioned{background:#78716c33;color:#a8a29e}.soc-bar{width:52px;height:4px;border-radius:999px;background:#1f2937e6;overflow:hidden;position:relative}.soc-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#22c55e,#eab308)}.align-right{text-align:right}.analytics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.mini-chart{position:relative;overflow:hidden;height:180px;padding:8px 10px;border-radius:10px;border:1px solid var(--mini-chart-border);background:var(--mini-chart-bg);box-shadow:var(--shadow-soft)}.mini-chart-title{font-size:11px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.12em}.mini-chart-body{position:absolute;inset:28px 10px 6px 4px;display:flex;align-items:flex-end;gap:5px}.bar{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,#f8fafce6,#1e40afb3);opacity:.9;position:relative}.bar-label{position:absolute;bottom:-14px;left:50%;transform:translate(-50%);font-size:9px;color:var(--muted)}.legend{position:absolute;top:4px;right:10px;display:flex;gap:6px;font-size:10px;color:var(--muted)}.legend-dot{width:7px;height:7px;border-radius:999px;display:inline-block;margin-right:3px}.legend-critical{background:var(--accent-red)}.legend-major{background:#f97316}.legend-minor{background:var(--accent-yellow)}.pie-container{position:absolute;inset:28px 6px 10px;display:flex;align-items:center;justify-content:center}.pie{width:90px;height:90px;border-radius:50%;background:conic-gradient(var(--accent-red) 0 40deg,#f97316 40deg 140deg,var(--accent-yellow) 140deg 260deg,#4b5563 260deg 360deg);box-shadow:0 0 0 4px #0f172af2;position:relative}.pie-label{position:absolute;font-size:10px;color:var(--text);text-shadow:0 1px 2px rgba(0,0,0,.8);transform:translate(-50%,-50%);pointer-events:none}.pie-label-1{top:18%;left:70%}.pie-label-2{top:22%;left:32%}.pie-label-3{top:72%;left:30%}.pie-label-4{top:72%;left:76%}.pie-legend{margin-left:12px;font-size:10px;color:var(--muted);display:flex;flex-direction:column;gap:4px}.pie-legend-row{display:flex;align-items:center;gap:4px}.small-table-wrap{position:absolute;inset:28px 6px 8px;overflow:auto;font-size:11px;scrollbar-width:thin;scrollbar-color:transparent transparent}.small-table-wrap::-webkit-scrollbar{width:4px;height:4px}.small-table-wrap::-webkit-scrollbar-track{background:transparent}.small-table-wrap::-webkit-scrollbar-thumb{background:transparent;border-radius:999px}.small-table-wrap:hover::-webkit-scrollbar-thumb{background:#94a3b8cc}.small-table-wrap:hover{scrollbar-color:rgba(148,163,184,.8) transparent}.small-table{width:100%;border-collapse:collapse}.small-table th,.small-table td{padding:4px 6px;white-space:nowrap}.small-table th{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);border-bottom:1px solid rgba(55,65,81,.9);position:sticky;top:0}.small-table tr:nth-child(2n) td{background:var(--row-even)}.small-table tr:nth-child(odd) td{background:var(--row-odd)}.availability-bar{width:100%;height:18px;border-radius:999px;background:#0f172af5;border:1px solid rgba(55,65,81,.9);overflow:hidden;display:flex;margin-top:8px;box-shadow:0 12px 30px #0009}.avail-segment-ok{background:linear-gradient(90deg,#22c55e,#4ade80);transition:width .6s ease-out}.avail-segment-minor{background:linear-gradient(90deg,#eab308,#facc15);transition:width .6s ease-out}.avail-segment-major{background:linear-gradient(90deg,#f97316,#fb923c);transition:width .6s ease-out}.avail-segment-warn{background:linear-gradient(90deg,#eab308,#f97316);transition:width .6s ease-out}.avail-segment-critical{background:linear-gradient(90deg,#ef4444,#b91c1c);transition:width .6s ease-out}.availability-legend{display:flex;gap:14px;margin-top:6px;font-size:10px;color:var(--muted)}.availability-legend span{display:inline-flex;align-items:center;gap:4px}.avail-dot-ok,.avail-dot-warn,.avail-dot-critical{width:8px;height:8px;border-radius:999px}.avail-dot-ok{background:#22c55e}.avail-dot-warn{background:#3b82f6}.avail-dot-critical{background:#ef4444}.availability-meta{display:flex;justify-content:space-between;margin-top:6px;font-size:11px;color:var(--muted)}.availability-meta strong{color:var(--text)}.tooltip{position:fixed;padding:4px 8px;font-size:11px;background:var(--overlay);color:var(--text);border-radius:4px;border:1px solid rgba(148,163,184,.8);pointer-events:none;opacity:0;transform:translate(-50%,-120%);z-index:9999;transition:opacity .08s ease;white-space:nowrap}.tooltip.visible{opacity:1}.site-header{display:grid;grid-template-columns:2.2fr 1.2fr;gap:12px;margin-bottom:14px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--surface-2)}.site-header-left{display:flex;flex-direction:column;gap:6px}.site-title-row{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:600;letter-spacing:.03em}.site-title{color:var(--text)}.site-subtitle-row{font-size:10px;color:var(--text-muted)}.site-meta-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.site-header-right{display:flex;align-items:center;justify-content:flex-end}.site-header-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;font-size:11px}.site-header-metric{border-radius:10px;border:1px solid var(--border);padding:6px 8px;background:var(--surface-2)}.site-header-metric-label{display:block;color:var(--text-muted);margin-bottom:2px}.site-header-metric-value{font-weight:600;color:var(--text)}.site-header-metric-value.ok{color:#bbf7d0}.site-header-metric-value.warn{color:#facc15}.device-map-container{display:flex;flex-direction:column;gap:6px}.device-level-toggle-row{display:flex;gap:6px;font-size:11px}.device-level-toggle{padding:4px 8px;border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-2);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .15s ease}.device-level-toggle.active{background:linear-gradient(90deg,#1d4ed8,#7c3aed);color:#f9fafb;border-color:transparent;box-shadow:0 0 8px #3b82f6b3}.device-level-toggle span.icon{font-size:13px}.device-map{flex:1;border-radius:8px;border:1px solid var(--border-subtle);padding:8px;font-size:11px;background:radial-gradient(circle at top left,var(--surface-3),var(--surface-3))}.device-layer{display:none;gap:6px}.device-layer.active{display:flex;flex-direction:column;gap:8px}.flow-row{display:flex;align-items:center;justify-content:space-between;gap:4px;flex-wrap:wrap}.flow-connector{flex:0 0 auto;font-size:14px;color:var(--text-muted)}.device-node{border-radius:8px;padding:6px 6px 4px;border:1px solid var(--border);background:var(--surface-2);display:flex;flex-direction:column;gap:2px;position:relative;min-width:120px;flex:0 0 auto}.device-node-title{font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px}.device-node-icon{width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:10px;background:var(--surface-3);border:1px solid var(--border-subtle)}.device-node-status{font-size:10px;color:var(--text-muted)}.device-node-dot{width:7px;height:7px;border-radius:999px;background:#22c55e;display:inline-block;box-shadow:0 0 6px #22c55ecc}.device-node-dot.warn{background:#eab308;box-shadow:0 0 6px #eab308cc}.device-node-dot.critical{background:#ef4444;box-shadow:0 0 6px #ef4444cc}.device-node.clickable{cursor:pointer;border-color:#3b82f6}.device-node.clickable:hover{box-shadow:0 0 8px #3b82f6b3}.device-layer-caption{font-size:10px;color:var(--text-muted)}.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;font-size:11px}.summary-block{border-radius:8px;border:1px solid var(--border);padding:6px 8px;background:var(--surface-2)}.summary-block-title{font-size:11px;font-weight:600;margin-bottom:4px}.summary-kv-row{display:flex;justify-content:space-between;margin-bottom:2px}.summary-key{color:var(--text-muted)}.summary-value{color:var(--text)}.trend-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.trend-card{border-radius:8px;border:1px solid var(--border);padding:6px 8px;background:var(--surface-2);display:flex;flex-direction:column;gap:6px}.trend-header{display:flex;justify-content:space-between;align-items:baseline;font-size:11px}.trend-title{font-weight:600}.trend-legend{font-size:10px;color:var(--text-muted);text-align:right}.trend-svg-wrapper{height:74px;border-radius:6px;border:1px solid var(--border);background:var(--surface-2);padding:2px 4px;overflow:hidden}.trend-svg{width:100%;height:100%}.trend-stat-row{display:flex;justify-content:space-between;font-size:10px}.workorders-list{display:flex;flex-direction:column;gap:6px;font-size:11px}.wo-item{border-radius:8px;border:1px solid var(--border);padding:6px 8px;background:var(--surface-2);display:flex;flex-direction:column;gap:2px}.wo-row-top{display:flex;justify-content:space-between}.wo-id{font-weight:600}.wo-status{font-size:10px;padding:2px 6px;border-radius:999px}.wo-status-open{background:color-mix(in srgb,var(--accent-yellow),transparent 78%);color:#facc15}.wo-status-inprogress{background:color-mix(in srgb,var(--accent),transparent 78%);color:var(--accent)}.wo-status-critical{background:color-mix(in srgb,var(--accent-red),transparent 75%);color:var(--accent-red)}.wo-desc{color:var(--text-soft)}.wo-meta{font-size:10px;color:var(--text-muted);display:flex;justify-content:space-between}.weather-safety-grid{display:grid;grid-template-columns:1fr;gap:8px;font-size:11px}.mini-block{border-radius:8px;border:1px solid var(--border);padding:6px 8px}.mini-block-title{font-size:11px;font-weight:600;margin-bottom:4px}.weather-row{display:flex;justify-content:space-between;margin-bottom:2px}.safety-matrix{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.safety-item{font-size:10px;display:flex;justify-content:space-between;align-items:center;border-radius:6px;border:1px solid var(--border);padding:4px 6px}.safety-label{color:var(--text-muted)}.safety-status-ok{color:#22c55e}.safety-status-warn{color:#eab308}.safety-status-critical,.safety-status-open{color:#f97316}@media(max-width:1024px){.site-header{grid-template-columns:minmax(0,1fr)}.site-header-right{justify-content:flex-start}.site-header-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-grid-site{grid-template-columns:repeat(3,minmax(0,1fr))}.trend-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.site-header-metrics{grid-template-columns:minmax(0,1fr)}.kpi-grid-site{grid-template-columns:repeat(2,minmax(0,1fr))}.trend-grid,.summary-grid{grid-template-columns:minmax(0,1fr)}}@keyframes monitoringFiltersFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes monitoringFiltersFadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}.monitoring-filters-animated{animation:monitoringFiltersFadeIn .24s ease-out}.filters-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.filters-group{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted)}.filters-group label{color:var(--text-muted);font-size:11px}.device-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.device-card{border-radius:12px;border:1px solid var(--border);padding:6px 7px;background:radial-gradient(circle at top left,var(--surface-3),var(--surface-3));display:flex;flex-direction:column;gap:4px}.device-card-header{display:flex;justify-content:space-between;align-items:center;gap:4px;font-size:11px}.device-card-title{font-weight:500;color:var(--text)}.device-card-body{display:flex;flex-direction:column;gap:2px;font-size:10px;color:var(--text-muted)}.link-text{font-size:10px;color:var(--accent);text-decoration:underline;cursor:pointer}.link-text:hover{color:#60a5fa}.status-online{color:var(--accent-green);border-color:color-mix(in srgb,var(--accent-green),transparent 30%);background:color-mix(in srgb,var(--accent-green),transparent 80%)}.status-warning{color:var(--accent-yellow);border-color:color-mix(in srgb,var(--accent-yellow),transparent 30%);background:color-mix(in srgb,var(--accent-yellow),transparent 80%)}.status-offline{color:#fecaca;border-color:#f87171cc;background:#7f1d1db3}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}@media(max-width:768px){.grid-2,.device-status-grid{grid-template-columns:minmax(0,1fr)}}.summary-bar{border-radius:10px;border:1px solid var(--border);padding:10px 12px;background:radial-gradient(circle at top left,color-mix(in srgb,var(--accent),transparent 82%),transparent 60%)}.summary-title{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text);margin-bottom:6px}.summary-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.summary-item{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;border:1px solid var(--border-subtle);background:var(--overlay)}.summary-dot{width:8px;height:8px;border-radius:999px}.dot-critical{background-color:#ef4444}.dot-major{background-color:#fb923c}.dot-minor{background-color:#facc15}.dot-warning{background-color:#3b82f6}.dot-total{background-color:#a3a3a3}.filters-row{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;font-size:11px;align-items:center}.filters-row .select,.filters-row .input{height:28px}.filters-row .input{min-width:160px}.alarm-table-wrap{overflow:auto;max-height:240px;border-radius:10px;border:1px solid var(--border-subtle);background:var(--overlay)}.alarm-table-wrap table{width:100%;min-width:1200px;border-collapse:collapse;font-size:11px}.alarm-table-wrap thead{background:var(--surface-2);position:sticky;top:0;z-index:2}.alarm-table-wrap th,.alarm-table-wrap td{padding:5px 8px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.alarm-table-wrap th{font-size:10px;letter-spacing:.05em;text-transform:uppercase;opacity:.7}.alarm-table-wrap tbody tr{cursor:pointer}.alarm-table-wrap tbody tr:hover{background:var(--overlay)}.alarm-table-wrap tbody tr.selected{background:color-mix(in srgb,var(--accent),transparent 70%)}.pill-critical{color:var(--accent-red);border:1px solid var(--accent-red);border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--overlay)}.pill-major{color:#f97316;border:1px solid #f97316;border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--overlay)}.pill-minor{color:var(--accent-yellow);border:1px solid var(--accent-yellow);border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--overlay)}.pill-warning{color:var(--warning);border:1px solid var(--warning);border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--overlay)}.sev-pill{display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;border-radius:999px;font-size:11px;border-width:1px;border-style:solid;line-height:1.2}.sev-pill{background:var(--overlay)}.sev-critical{border-color:var(--accent-red);color:var(--accent-red)}.sev-major{border-color:var(--chart-major);color:var(--chart-major)}.sev-minor{border-color:var(--chart-minor);color:var(--chart-minor)}.sev-warning{border-color:var(--warning);color:var(--warning)}.alarm-table{width:100%;border-collapse:collapse;font-size:11px}.alarm-table thead{background:#0f172a99}.alarm-table th{padding:5px 8px;text-align:left;font-size:10px;letter-spacing:.05em;text-transform:uppercase;opacity:.7;border-bottom:1px solid rgba(30,41,59,.9)}.alarm-table td{padding:5px 8px;text-align:left;border-bottom:1px solid rgba(30,41,59,.5)}.alarm-table tbody tr{cursor:pointer}.alarm-table tbody tr:hover{background:#0f172a99}.table-footer-link{margin-top:8px;font-size:11px;color:#60a5fa;cursor:pointer;text-align:right}.table-footer-link:hover{text-decoration:underline}.pill-status-open{color:#b07171;border:1px solid #f97373;border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--bg)}.pill-status-ack{color:var(--text);border:1px solid #a855f7;border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--bg)}.pill-status-cleared{color:#bbf7d0;border:1px solid #22c55e;border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--overlay)}.details-body{flex:1;overflow-y:auto;font-size:12px;padding:8px}.details-section{border-bottom:1px solid var(--border);padding:8px 0}.details-section:last-child{border-bottom:none}.details-title{font-size:10px;text-transform:uppercase;letter-spacing:.09em;opacity:.7;margin-bottom:4px}.details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 12px}.details-label{font-size:10px;opacity:.7}.details-value{font-size:12px}.timeline-list{margin-top:4px;list-style:none;padding-left:0;font-size:12px;max-height:156px;overflow:auto;scrollbar-width:thin;scrollbar-color:transparent transparent}.timeline-list::-webkit-scrollbar{width:4px;height:4px}.timeline-list::-webkit-scrollbar-track{background:transparent}.timeline-list::-webkit-scrollbar-thumb{background:transparent;border-radius:999px}.timeline-list:hover::-webkit-scrollbar-thumb{background:#94a3b8cc}.timeline-list:hover{scrollbar-color:rgba(148,163,184,.8) transparent}.timeline-item{display:flex;flex-direction:column;padding:4px 0;border-bottom:1px dashed rgba(51,65,85,.9)}.timeline-item:last-child{border-bottom:none}.timeline-main{display:flex;justify-content:space-between;gap:8px;flex-wrap:nowrap}.timeline-time{font-size:11px;opacity:.7;min-width:110px}.timeline-text{flex:1}.timeline-meta{font-size:11px;opacity:.7}.cell-name{font-weight:500;font-size:12px}.cell-subtext{font-size:10px;opacity:.7}@media(max-width:768px){.alarm-table-wrap{max-height:180px}.details-grid{grid-template-columns:minmax(0,1fr)}}.content-scroll{height:100%;overflow-y:auto;padding:8px 4px 12px}.content-grid{display:flex;flex-direction:column;gap:12px}.card-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.split-row{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1.4fr);gap:12px;align-items:stretch}.triple-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-items:flex-start}.wo-card{background:var(--surface-2);border-radius:12px;border:1px solid var(--border-subtle);padding:10px 12px;display:flex;flex-direction:column;gap:6px}.wo-card-header{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:11px}.wo-card-title{font-weight:600;font-size:12px}.wo-card-pill{font-size:10px;padding:2px 8px;border-radius:999px;background:var(--overlay);border:1px solid var(--border-subtle);color:var(--text)}.wo-card-main{display:flex;align-items:baseline;gap:4px}.wo-card-main .value{font-size:20px;font-weight:700}.wo-card-main .unit{font-size:11px;color:var(--text-muted)}.wo-card-footer{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted);gap:8px;flex-wrap:wrap}.wo-section{background:var(--surface-2);border-radius:12px;border:1px solid var(--border-subtle);padding:10px 12px;display:flex;flex-direction:column;gap:8px}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.section-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600}.section-subtitle{font-size:10px;color:var(--text-muted)}.section-tools{display:flex;gap:6px;align-items:center}.status-pill.status-open{background:#fbbf2426;color:#fbbf24;border:1px solid rgba(251,191,36,.5)}.status-pill.status-inprogress{background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.5)}.status-pill.status-closed{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.5)}.status-pill.status-parts{background:#60a5fa26;color:#60a5fa;border:1px solid rgba(96,165,250,.5)}.sla-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:500}.sla-badge.sla-critical{background:#ef444426;color:#fecaca;border:1px solid rgba(239,68,68,.6)}.sla-badge.sla-high{background:#fb923c26;color:#fed7aa;border:1px solid rgba(251,146,60,.6)}.sla-badge.sla-normal{background:#60a5fa26;color:#dbeafe;border:1px solid rgba(96,165,250,.5)}.site-pill{display:inline-block;padding:2px 8px;border-radius:999px;background:#0f172acc;border:1px solid rgba(148,163,184,.4);font-size:10px}.detail-header{display:flex;flex-direction:column;gap:4px;font-size:11px}.detail-title-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.detail-title{font-size:13px;font-weight:500}.detail-meta-row{display:flex;flex-wrap:wrap;gap:4px}.meta-badge{padding:2px 6px;border-radius:999px;background:var(--surface-3);border:1px solid var(--border-subtle);color:var(--text-muted);font-size:9px;display:inline-flex;align-items:center;gap:4px}.meta-badge strong{color:var(--text-muted)}.tabs{margin-top:6px;display:flex;flex-direction:column;gap:6px}.tab-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:0}.tab{border-radius:999px;border:1px solid rgba(51,65,85,.9);padding:3px 10px;font-size:10px;background:transparent;cursor:pointer;display:flex;align-items:center;gap:4px}.tab.active{background:linear-gradient(to right,#22c55e,#0ea5e9);color:#0b1120;border-color:transparent}.tab-panels{border-radius:8px;border:1px solid var(--border);background:var(--surface-3);padding:8px 10px;font-size:11px}.tab-panel{display:none}.tab-panel.active{display:block}.panel-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.panel-box{border-radius:8px;border:1px solid var(--border);background:var(--surface-2);padding:6px 7px}.panel-box-title{display:flex;justify-content:space-between;align-items:center;font-size:11px;margin-bottom:6px;color:var(--text-muted)}.panel-box-body{font-size:11px;color:var(--text-soft);line-height:1.45}.panel-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3px;font-size:11px}.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;font-size:11px}.checklist li{display:flex;align-items:flex-start;gap:6px}.check-box{width:10px;height:10px;border-radius:3px;border:1px solid rgba(148,163,184,.8);margin-top:2px;flex-shrink:0}.wo-timeline{list-style:none;padding-left:0;border-left:1px solid #1e293b;margin:0 0 0 6px}.wo-timeline li{padding-left:8px;margin-bottom:4px;position:relative}.wo-timeline li:before{content:"";width:7px;height:7px;border-radius:999px;border:1px solid #38bdf8;background:#020617;position:absolute;left:-4.5px;top:3px}.wo-timeline li strong{color:var(--text)}.calendar-grid{display:grid;grid-template-columns:70px minmax(0,1fr);gap:6px;font-size:11px}.calendar-left{border-radius:9px;border:1px solid var(--border-subtle);background:var(--surface-3);padding:6px 6px 8px;display:flex;flex-direction:column;gap:4px}.calendar-day{font-size:11px;font-weight:600}.calendar-date{font-size:20px;font-weight:700}.calendar-tag{font-size:9px;padding:2px 5px;border-radius:999px;border:1px solid rgba(56,189,248,.6);color:#e0f2fe;background:#082f49f2;align-self:flex-start}.calendar-right{display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto;overflow-x:hidden}.slot-row{display:grid;grid-template-columns:30px minmax(0,1fr);gap:4px;align-items:flex-start}.slot-time{font-size:10px;color:var(--text-soft)}.slot-card{border-radius:8px;border:1px solid var(--border-subtle);background:var(--surface-3);padding:4px 6px;display:flex;flex-direction:column;gap:2px}.slot-title{font-size:11px;color:var(--text-muted)}.slot-meta{font-size:10px;color:var(--text-soft);display:flex;flex-wrap:wrap;gap:4px}.slot-kpi-pill{padding:1px 5px;border-radius:999px;font-size:9px;border:1px solid var(--accent-yellow);color:var(--accent-yellow);background:color-mix(in srgb,var(--accent-yellow),transparent 88%)}.mobile-preview{border-radius:16px;border:1px solid rgba(51,65,85,.9);background:radial-gradient(circle at top,rgba(56,189,248,.12),transparent 55%);padding:10px;font-size:11px;display:flex;flex-direction:column;gap:6px}.mobile-header{display:flex;justify-content:space-between;color:var(--text);font-weight:500}.mobile-chip-row{display:flex;flex-wrap:wrap;gap:4px}.mobile-chip{padding:2px 8px;border-radius:999px;border:1px solid rgba(148,163,184,.6);font-size:10px}.mobile-actions{margin-top:4px;margin-bottom:0;display:flex;flex-wrap:wrap;gap:6px}.mobile-action-btn{padding:3px 10px;border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-3);color:var(--text);font-size:10px;cursor:pointer}.mobile-action-btn:hover{border-color:#38bdf8e6;color:#e0f2fe}.mobile-list{display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto;overflow-x:hidden}.mobile-item{padding:6px 8px;border-radius:8px;border:1px solid var(--border-subtle);background:var(--overlay)}.mobile-item-title{font-weight:500;font-size:11px}.mobile-item-meta{font-size:10px;color:var(--text-muted);display:flex;justify-content:space-between;gap:6px;flex-wrap:wrap}.kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.kpi-box{border-radius:10px;border:1px dashed rgba(55,65,81,.9);padding:8px 9px;font-size:10px;display:flex;flex-direction:column;gap:2px}.kpi-title{color:var(--text-muted)}.kpi-main{font-size:14px;font-weight:600}.kpi-foot{color:#6b7280}.auto-btn{padding:4px 12px;border-radius:999px;border:1px solid rgba(34,197,94,.7);background:#22c55e26;color:#86efac;font-size:10px;font-weight:600;text-align:center;line-height:1.3}.pill{border-radius:999px;padding:2px 6px;font-size:10px;display:inline-flex;align-items:center;gap:4px;background:var(--overlay);border:1px solid var(--border-subtle)}.pill.accent{border-color:#38bdf8b3;color:#e0f2fe;background:#082f49f2}.btn-ghost{padding:4px 10px;border-radius:999px;border:1px solid rgba(148,163,184,.5);background:transparent;color:var(--text);font-size:10px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.btn-ghost:hover{border-color:#38bdf8cc;color:#e0f2fe}@media(max-width:1280px){.card-row{grid-template-columns:repeat(2,minmax(0,1fr))}.split-row,.triple-row,.panel-grid-2{grid-template-columns:minmax(0,1fr)}}@media(max-width:768px){.card-row{grid-template-columns:minmax(0,1fr)}}.reports-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.views.reports-view{min-height:100vh}.reports-title-block{display:flex;flex-direction:column;gap:4px}.reports-page-title{font-size:18px;font-weight:600}.reports-page-subtitle{font-size:12px;color:var(--text-muted)}.reports-page-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.reports-button{border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-3);color:var(--text);font-size:11px;padding:6px 12px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.reports-button:hover{border-color:#38bdf8e6;color:var(--text);background:radial-gradient(circle at top left,rgba(56,189,248,.25),var(--bg))}.reports-filters-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0;align-items:center;font-size:11px}.reports-field{display:flex;flex-direction:column;gap:2px}.reports-field-label{font-size:11px;color:var(--text-muted)}.reports-select,.reports-input{border-radius:999px;border:1px solid rgba(148,163,184,.7);background:var(--surface-2);color:var(--text);font-size:11px;padding:5px 10px;min-width:150px}.reports-select:focus,.reports-input:focus{outline:none;border-color:#38bdf8e6;box-shadow:0 0 0 1px #38bdf880}.reports-tabs-header{display:flex;flex-direction:column;gap:6px;margin-bottom:0}.reports-tab-list{display:flex;flex-wrap:wrap;gap:6px}.reports-tab{border-radius:999px;border:1px solid rgba(148,163,184,.7);background:#0f172ae6;padding:5px 10px;font-size:11px;cursor:pointer;color:#fff}.reports-tab.active{border-color:var(--accent);background:radial-gradient(circle at top left,color-mix(in srgb,var(--accent),transparent 75%),var(--surface-3));color:var(--accent)}.reports-tab-panels{border-radius:10px;border:1px solid color-mix(in srgb,var(--accent),transparent 40%);background:var(--surface-3);padding:10lpx;max-height:540px;overflow-y:auto;font-size:11px}.reports-tab-panel{display:none}.reports-tab-panel.active{display:block}.reports-cards-stack{display:flex;flex-direction:column;gap:10px;padding-bottom:10px}.reports-cards-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding-top:10px;padding-bottom:10px}.reports-cards-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding-bottom:10px}.reports-card{border-radius:var(--radius-lg);border:1px solid var(--border);background:radial-gradient(circle at top left,color-mix(in srgb,var(--accent),transparent 82%),var(--surface-3));padding:10px;box-shadow:var(--shadow-soft)}.reports-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0;padding-bottom:10px}.reports-card-title{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.reports-card-sub{font-size:11px;color:var(--text-muted)}.reports-badge{border-radius:999px;border:1px solid var(--border-subtle);padding:2px 7px;font-size:10px}.reports-kpi-row{display:flex;justify-content:space-between;gap:10px;margin-bottom:0;padding-bottom:10px}.reports-kpi-block{flex:1}.reports-kpi-label{font-size:10px;color:var(--text-muted);margin-bottom:0}.reports-kpi-main{font-size:14px;font-weight:600}.reports-kpi-trend{font-size:10px;color:#6b7280}.reports-kpi-trend.positive{color:#22c55e}.reports-kpi-trend.negative{color:#f97373}.reports-table-scroll{overflow-x:auto;overflow-y:hidden;width:100%}.reports-table-scroll table{min-width:1100px;width:100%;border-collapse:collapse;font-size:11px}.reports-table-scroll th,.reports-table-scroll td{padding:4px 6px;border-bottom:1px solid rgba(31,41,55,.9);text-align:left;white-space:nowrap}.reports-table-scroll th{font-weight:500;color:var(--text-muted);position:sticky;top:0;z-index:1}.reports-table-scroll tr:nth-child(2n) td{background:var(--surface-3)}.reports-table-scroll::-webkit-scrollbar{height:4px}.reports-table-scroll::-webkit-scrollbar-track{background:transparent}.reports-table-scroll::-webkit-scrollbar-thumb{background:transparent;border-radius:999px}.reports-table-scroll:hover::-webkit-scrollbar-thumb{background:#94a3b8cc}.reports-table-scroll{scrollbar-width:thin;scrollbar-color:transparent transparent}.reports-table-scroll:hover{scrollbar-color:rgba(148,163,184,.8) transparent}.reports-mini-note{font-size:10px;color:var(--text-muted);margin-top:4px}.reports-pill-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.reports-pill{border-radius:999px;border:1px solid rgba(75,85,99,.9);padding:2px 6px;font-size:10px}@media(max-width:960px){.reports-cards-grid-2,.reports-cards-grid-3{grid-template-columns:minmax(0,1fr)}}.admin-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:10px;border:1px solid var(--border-subtle);background:var(--surface-3);color:var(--text)}.role-badge-level-1{border-color:#f97373;box-shadow:0 0 6px #f87171b3}.role-badge-level-2{border-color:#facc15;box-shadow:0 0 6px #facc15b3}.role-badge-level-3{border-color:#38bdf8;box-shadow:0 0 6px #38bdf8b3}.role-badge-level-4{border-color:#4ade80;box-shadow:0 0 6px #4ade80b3}.admin-form-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,.9fr) auto;gap:6px;align-items:flex-end;margin-bottom:8px}.admin-form-label{font-size:10px;color:var(--text-muted)}.admin-input,.admin-select{width:100%;padding:6px 10px;font-size:11px;border-radius:999px;border:1px solid rgba(148,163,184,.7);background:var(--surface-2);color:var(--text)}.admin-input:focus,.admin-select:focus{outline:none;border-color:#38bdf8e6;box-shadow:0 0 0 1px #38bdf880}.admin-button{margin-top:14px;padding:7px 14px;font-size:11px;border-radius:999px;border:1px solid rgba(56,189,248,.9);background:var(--surface-3);color:var(--text);cursor:pointer}.admin-button:hover{border-color:#38bdf8;background:radial-gradient(circle at top left,rgba(56,189,248,.25),var(--bg))}.admin-table{width:100%;border-collapse:collapse;min-width:900px;font-size:11px}.admin-table-wrapper{width:100%;overflow-x:auto}.admin-table th,.admin-table td{padding:6px 8px;border-bottom:1px solid var(--border);text-align:left;word-break:break-word}.admin-table th{font-weight:500;color:var(--text-muted);background:var(--surface-3)}.admin-table tr:nth-child(2n) td{background:var(--surface-2)}.admin-role-list{margin:0;padding-left:16px;font-size:11px;color:var(--text)}.admin-role-list li{margin-bottom:6px}@media(max-width:1024px){.admin-grid-2,.admin-form-grid{grid-template-columns:minmax(0,1fr)}.admin-button{margin-top:0}}.avatar-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:50%;z-index:2;display:block}.avatar-initials{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.user-info-section{padding:12px 16px;border-bottom:1px solid rgba(148,163,184,.2);min-width:200px;max-width:280px}.user-display-name{font-weight:600;font-size:14px;color:var(--text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:12px;color:var(--text-muted);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:#38bdf8;background:#38bdf81a;padding:3px 8px;border-radius:12px;display:inline-block;margin-bottom:8px;font-weight:500;border:1px solid rgba(56,189,248,.3)}.microsoft-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:#81bc06;background:#81bc061a;padding:4px 10px;border-radius:12px;border:1px solid rgba(129,188,6,.3)}.microsoft-icon{display:flex;align-items:center}.dropdown-divider{height:1px;background:linear-gradient(90deg,transparent 0%,rgba(148,163,184,.3) 50%,transparent 100%);margin:8px 16px}.logout-icon{font-size:16px;opacity:.9}.logout-provider{margin-left:auto;font-size:11px;color:var(--text-muted);font-weight:400;opacity:.8}.avatar-image[src=""],.avatar-image:not([src]){display:none}.avatar:has(.avatar-image[style*="display: none"]) .avatar-initials{z-index:2}.leaflet-popup-content-wrapper{background:linear-gradient(180deg,var(--bg-elevated),var(--bg));color:var(--text);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);padding:0;border:1px solid var(--border-subtle)}.leaflet-popup-tip{background:var(--bg);border:1px solid var(--border-subtle)}.site-popup{min-width:280px;padding:12px;font-size:10px}.site-popup .popup-header{color:var(--accent);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px;text-align:center}.site-popup .popup-row{display:flex;justify-content:space-between;padding:2px 0;border-bottom:1px solid var(--border)}.site-popup .popup-row:last-child{border-bottom:none}.site-popup .popup-row span{color:var(--text-muted)}.site-popup .popup-row strong{color:var(--text);font-weight:500}.popup-subtitle{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:11px;color:var(--text-muted);margin-bottom:8px;flex-shrink:0}.alarms-summary-container{background:radial-gradient(circle at top left,rgba(56,189,248,.18),transparent 60%);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:16px;margin-bottom:16px;box-shadow:var(--shadow-soft)}.summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.summary-title{font-size:14px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text);margin:0 0 4px}.summary-subtitle{font-size:11px;color:var(--text-muted);margin:0}.summary-info{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.summary-site{font-size:12px;font-weight:500;color:var(--text)}.summary-time{font-size:11px;color:var(--text-muted)}.summary-refresh{padding:4px 10px;border-radius:999px;border:1px solid rgba(148,163,184,.7);background:#0f172ae6;color:var(--text);font-size:11px;cursor:pointer;transition:all .2s ease}.summary-refresh:hover{border-color:var(--accent);color:#e0f2fe}.summary-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.summary-card{background:var(--surface-2);border-radius:10px;border:1px solid rgba(30,64,175,.6);padding:16px;display:flex;flex-direction:column;transition:all .2s ease}.summary-card:hover{border-color:var(--accent);box-shadow:0 8px 24px #0f172ae6}.card-title{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 16px}.donut-container{display:flex;align-items:center;gap:20px;flex:1}.severity-donut{width:120px;height:120px;border-radius:50%;background:conic-gradient(var(--accent-red) 0 var(--p1),#f97316 var(--p1) var(--p2),var(--accent-yellow) var(--p2) var(--p3),var(--warning) var(--p3) 100%);position:relative;flex-shrink:0}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70px;height:70px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--text);border:4px solid var(--bg-elevated)}.severity-legend{display:flex;flex-direction:column;gap:10px;flex:1}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text)}.legend-item b{margin-left:auto;font-weight:600}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot.critical{background:var(--accent-red);box-shadow:0 0 8px #ef444499}.legend-dot.major{background:#f97316;box-shadow:0 0 8px #f9731699}.legend-dot.minor{background:var(--accent-yellow);box-shadow:0 0 8px #facc1599}.legend-dot.warning{background:var(--warning);box-shadow:0 0 8px #3b82f699}.subsystems-bars{display:flex;flex-direction:column;gap:9px;flex:1}.subsystem-row{display:flex;align-items:center;gap:10px;font-size:11px}.subsystem-name{width:100px;color:var(--text);flex-shrink:0;font-weight:500}.subsystem-bar{flex:1;height:8px;background:#1e293bcc;border-radius:4px;overflow:hidden}.subsystem-bar-fill{height:100%;background:var(--bar);border-radius:4px;transition:width .3s ease}.subsystem-count{width:20px;text-align:right;color:var(--text-muted);font-weight:600;flex-shrink:0}.hours-chart{display:flex;flex-direction:column;gap:10px;flex:1}.hours-bars{display:flex;align-items:flex-end;gap:8px;height:90px;padding-bottom:3px;position:relative}.hour-bar{flex:1;background:var(--bar);border-radius:9px;position:relative;cursor:pointer;transition:all .2s ease;min-height:2px}.hour-bar:hover{opacity:.8;transform:translateY(-2px)}.hour-bar-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-elevated);color:var(--text);font-size:11px;padding:6px 10px;border-radius:6px;border:1px solid var(--border-subtle);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease;z-index:10;box-shadow:var(--shadow-soft);pointer-events:none}.hour-bar:hover .hour-bar-tooltip{opacity:1;visibility:visible}.hours-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted);padding:0 4px}@media(max-width:1200px){.summary-cards-grid{grid-template-columns:1fr;gap:12px}.donut-container{justify-content:center}.summary-card{min-height:auto}}@media(max-width:768px){.summary-header{flex-direction:column;gap:12px}.summary-info{align-items:flex-start;width:100%}.donut-container{flex-direction:column;text-align:center;gap:16px}.severity-legend{width:100%}.subsystems-bars{gap:10px}.hours-bars{height:60px}}.header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:20px}.title-block{flex:1;max-width:600px}.page-title{font-size:24px;font-weight:600;color:var(--text);margin-bottom:6px}.page-subtitle{font-size:12px;color:var(--text-muted);line-height:1.4}.controls-block.horizontal-layout{display:flex;flex-direction:column;gap:2px;min-width:400px;background:transparent;border:none;border-radius:0;padding:0;box-shadow:none}.controls-row.labels-row{display:grid;grid-template-columns:180px 180px 80px;gap:16px;align-items:center;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding-bottom:2px;border-bottom:1px solid rgba(30,41,59,.8);margin-bottom:0}.controls-row.labels-row .field-label{margin:0;text-align:left;line-height:1}.controls-row.inputs-row{display:grid;grid-template-columns:180px 180px 80px;gap:16px;align-items:center;margin-top:0;padding-top:2px}.controls-row.inputs-row .field{margin:0;padding:0}.controls-row.inputs-row .select{width:100%;height:32px;padding:6px 12px;font-size:12px;line-height:1;font-weight:500;border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-2);color:var(--text);outline:none;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.controls-row.inputs-row .select:focus{outline:none;border-color:#38bdf8e6;box-shadow:0 0 0 2px #38bdf84d}.controls-row.inputs-row .button.secondary{width:100%;height:32px;padding:0;margin:0;border-radius:999px;border:1px solid rgba(148,163,184,.7);background:var(--surface-2);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1}.controls-row.inputs-row .button.secondary:hover{border-color:#38bdf8e6;background:var(--surface-2);color:var(--text);transform:translateY(-1px)}@media(max-width:1024px){.header-row{flex-direction:column;gap:16px}.controls-block.horizontal-layout{min-width:100%}.controls-row.labels-row,.controls-row.inputs-row{grid-template-columns:1fr 1fr}.controls-row.labels-row .field-label:last-child,.controls-row.inputs-row .button.secondary{grid-column:span 2;justify-self:center;margin-top:4px}}@media(max-width:640px){.controls-row.labels-row,.controls-row.inputs-row{grid-template-columns:1fr}.controls-row.labels-row .field-label:last-child,.controls-row.inputs-row .button.secondary{grid-column:span 1}.controls-row.inputs-row .button.secondary{margin-top:4px}}.filters-row,.panel-header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.panel-header-right.button-group{margin-left:auto;justify-content:flex-end}.filters-row{gap:16px;margin:16px 0}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap;gap:12px}.panel-header-left{flex:1;min-width:300px}.panel-title{font-size:18px;font-weight:600;color:var(--text);margin-bottom:4px}.panel-subtitle{font-size:12px;color:var(--text-muted);line-height:1.4;max-width:600px}.filters-row .select,.filters-row .input,.filters-row .badge,.panel-header-right .button.secondary{height:32px;padding:6px 12px;font-size:12px;border-radius:999px;transition:all .2s ease;line-height:1;white-space:nowrap;display:flex;align-items:center;justify-content:center}.filters-row .select{width:auto;min-width:140px;height:32px;padding:6px 12px;font-size:12px;font-weight:500;line-height:1;border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-2);color:var(--text);cursor:pointer}.filters-row .select:focus{outline:none;border-color:#38bdf8e6;box-shadow:0 0 0 2px #38bdf84d}.filters-row .input{width:200px;border:1px solid var(--border-subtle);background:var(--surface-2);color:var(--text)}.filters-row .input::placeholder{color:var(--text-soft);font-size:11px}.filters-row .input:hover{border-color:#94a3b8e6}.filters-row .input:focus{outline:none;border-color:#38bdf8e6;box-shadow:0 0 0 2px #38bdf84d}.filters-row .badge{min-width:120px;border:1px solid rgba(148,163,184,.2);background:var(--bg);color:var(--text);font-weight:600;margin-left:auto}.filters-row .button.secondary,.panel-header-right .button.secondary{min-width:100px;padding:0 16px;border:1px solid rgba(148,163,184,.7);background:var(--surface-2);color:var(--text);font-weight:500;cursor:pointer}.filters-row .button.secondary:hover,.panel-header-right .button.secondary:hover{border-color:#38bdf8e6;background:#38bdf81a;color:var(--text-muted);transform:translateY(-1px)}@media(max-width:1024px){.filters-row{gap:12px}.filters-row .select,.filters-row .input{min-width:120px}.filters-row .badge{margin-left:0;margin-top:8px;width:100%}}@media(max-width:768px){.filters-row,.panel-header{flex-direction:column;align-items:stretch;gap:8px}.panel-header{gap:12px}.panel-header-left{min-width:auto}.panel-header-right{align-self:flex-end;width:100%;justify-content:flex-end}.filters-row .select,.filters-row .input,.filters-row .badge,.panel-header-right .button.secondary{width:100%;min-width:auto;margin-top:8px}.filters-row .badge{width:100%}}@media(max-width:480px){.panel-header-right{flex-direction:column;align-items:stretch}.panel-header-right .button.secondary{width:100%}}.badge.severity-critical{background:#ef44442e;color:#fecaca;border:1px solid rgba(239,68,68,.55)}.badge.severity-warning{background:#3b82f62e;color:#dbeafe;border:1px solid rgba(59,130,246,.55)}.badge.severity-minor{background:#facc152e;color:#fef08a;border:1px solid rgba(250,204,21,.55)}.badge.status-open{color:var(--accent-red);border:1px solid var(--accent-red);background:color-mix(in srgb,var(--accent-red),transparent 82%)}.badge.status-in-progress{color:var(--warning);border:1px solid var(--warning);background:color-mix(in srgb,var(--warning),transparent 82%)}.badge.status-closed{color:var(--success);border:1px solid var(--success);background:color-mix(in srgb,var(--success),transparent 82%)}.wo-status{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--text)}.wo-dot{width:7px;height:7px;border-radius:999px}.wo-open .wo-dot{background:#ef4444;box-shadow:0 0 6px #ef4444b3}.wo-in-progress .wo-dot{background:#3b82f6;box-shadow:0 0 6px #3b82f6b3}.wo-closed .wo-dot{background:#22c55e;box-shadow:0 0 6px #22c55eb3}.alarm-list-container{border:1px solid rgba(148,163,184,.6);border-radius:var(--card-radius);padding:20px;background:var(--surface-2);margin-bottom:20px;box-shadow:var(--shadow-soft)}.button.secondary{height:32px;padding:6px 12px;font-size:12px;border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-3);color:var(--text);font-weight:500;transition:all .2s ease}.button.secondary:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent),transparent 85%);color:var(--text)}.button.secondary:active{border-color:#38bdf8;background:#38bdf826;transform:scale(.98)}.button.secondary:focus{border-color:var(--accent);box-shadow:0 0 0 2px #38bdf84d;outline:none}.button.secondary:disabled{opacity:.5;cursor:not-allowed;border-color:#94a3b84d}.button.primary{background-color:#0ea5e9;color:var(--text);border:1px solid #0284c7;transition:all .2s ease}.button.primary:hover{background-color:#0284c7}.button.primary:active{background-color:#0369a1;transform:scale(.98)}.button.primary:focus{box-shadow:0 0 0 2px #0ea5e94d;outline:none}.alarm-details-panel{padding:16px;background:var(--bg);height:100%;overflow-y:auto;font-size:12px;color:var(--text)}.panel-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(51,65,85,.9)}.panel-title{font-size:14px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin:0 0 4px}.panel-subtitle{font-size:11px;opacity:.7;margin:0}.details-card{background:var(--bg);border:1px solid rgba(51,65,85,.9);border-radius:8px;padding:16px;margin-bottom:16px}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(51,65,85,.9)}.card-title{font-size:12px;font-weight:600;color:var(--text);margin:0;flex:1}.card-badges{display:flex;gap:8px;flex-shrink:0}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.overview-column{display:flex;flex-direction:column;gap:12px}.overview-item{display:flex;flex-direction:column}.overview-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;opacity:.7;margin-bottom:4px;color:var(--text-muted)}.overview-value{font-size:12px;color:var(--text);line-height:1.4}.phase-logic-text{font-size:12px;color:#94a3b8;line-height:1.5;margin-top:8px}.action-plan-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:12px 0 16px}.action-plan-item{background:var(--bg);border:1px solid rgba(51,65,85,.9);border-radius:6px;padding:12px}.action-plan-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text);margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid rgba(51,65,85,.9)}.action-plan-text{font-size:12px;color:#94a3b8;line-height:1.4}.sop-steps{background:var(--bg);border:1px solid rgba(51,65,85,.9);border-radius:6px;padding:16px 16px 16px 32px;margin-top:12px}.sop-steps ol{margin:0;padding:0}.sop-step{font-size:12px;color:var(--text);line-height:1.5;margin-bottom:8px}.sop-step:last-child{margin-bottom:0}.timeline-footer{font-size:11px;font-style:italic;color:#94a3b8;text-align:center;margin-top:12px;padding-top:12px;border-top:1px solid rgba(51,65,85,.9)}@media(max-width:768px){.overview-grid{grid-template-columns:1fr;gap:16px}.action-plan-grid{grid-template-columns:1fr;gap:12px}.card-header{flex-direction:column;gap:8px}.card-badges{align-self:flex-start}}html{transition:background-color .25s ease,color .25s ease}*{transition:background-color .25s ease,border-color .25s ease,color .25s ease}.flow-main{display:flex;align-items:center;justify-content:space-between;gap:16px}.flow-node-wrapper{display:flex;align-items:center;gap:12px}.flow-containers{display:flex;justify-content:space-between;gap:24px}.flow-aux{display:flex;justify-content:center;gap:24px;margin-top:16px}.flow-arrow{color:var(--text-muted);font-size:18px;opacity:.7}.device-node{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 14px;min-width:160px;box-shadow:var(--shadow-soft);transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.device-node.small{min-width:180px}.device-node.clickable{cursor:pointer}.device-node.clickable:hover{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent),transparent 50%);transform:translateY(-1px)}.device-node.status-warn{border-color:var(--chart-minor)}.device-node.status-critical{border-color:var(--chart-critical)}.device-node-dot.ok{background:var(--success)}.leaflet-container{z-index:1!important}.leaflet-control{z-index:2!important}[data-sonner-toast]{border-radius:16px!important;font-family:Inter,sans-serif}[data-sonner-toast][data-type=error]{background-color:#0000006c!important;border:1px solid #ef4444!important}.add-site-button{display:flex;align-items:center;gap:10px;padding:8px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:var(--bg);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s ease;box-shadow:inset 0 0 0 1px #ffffff0a,0 4px 12px #0000004d}.add-site-button:hover{background:linear-gradient(135deg,#1e2d55f2,#0f1e41);color:var(--text);box-shadow:inset 0 0 0 1px #ffffff0f,0 6px 16px #0006;transform:translateY(-1px)}.status-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e,0 0 12px #22c55e99}.intake-overlay{position:fixed;inset:0;background:#0000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;justify-content:center;align-items:center;z-index:9999}.intake-modal{width:85%;max-width:95vw;height:75vh;max-height:900px;background:var(--bg-elevated);border-radius:16px;display:flex;flex-direction:column;box-shadow:0 25px 70px #0009;overflow:hidden}.close-btn{position:absolute;top:20px;right:30px;background:transparent;border:none;font-size:18px;cursor:pointer;color:var(--text)}.intake-header{display:flex;justify-content:space-between;align-items:flex-start}.intake-header-left{display:flex;gap:20px;align-items:flex-start}.intake-logo{width:180px;height:auto}.intake-modal-body{flex:1;overflow-y:auto;padding:24px 32px}.intake-title-block h1{font-size:22px;font-weight:600;color:var(--text);margin:0}.intake-title-block p{font-size:14px;color:#94a3b8;margin-top:6px;max-width:600px}.intake-header-actions{display:flex;align-items:center;gap:12px}.intake-header-actions button{padding:8px 16px;border-radius:999px;font-size:14px;font-weight:500;cursor:pointer;transition:all .25s ease}.btn-outline{background:transparent;border:1px solid var(--border-subtle);color:var(--text);padding:8px 18px;border-radius:20px;cursor:pointer;font-size:14px}.btn-outline:hover{background:#cb22220d;border:1px solid rgba(24,48,133,.665)}.btn-primary{border:none;color:var(--text);padding:8px 18px;border-radius:20px;cursor:pointer;font-size:14px;border-color:#59a6ffa6;background:linear-gradient(180deg,#59a6ff38,#59a6ff1a)}.section-card{border:1px solid rgba(255,255,255,.05);border-radius:18px;padding:24px 28px;margin-bottom:28px;box-shadow:0 10px 40px #00000059;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center}.section-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text)}.section-divider{height:1px;background:#ffffff0f;margin:16px 0}.section-description{font-size:13px;color:var(--text-muted);margin-bottom:20px}.fields-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px 24px}.section-footer-note{margin-top:24px;font-size:12px;color:#7c8aa5}.intake-main-card{background:var(--bg-elevated);border:1px solid rgba(255,255,255,.05);border-radius:20px;padding:32px;overflow-x:hidden}.intake-section-header{margin:20px 0 10px}.intake-section-header h2{font-size:16px;font-weight:600;color:var(--text-muted);margin-bottom:6px}.intake-section-header p{font-size:13px;color:#94a3b8}.intake-filters{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;color:#94a3b8}.filter-inline{display:flex;gap:8px}.dark-input{flex:1;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 14px;color:var(--text);font-size:13px;outline:none}.dark-input::placeholder{color:#64748b}.dark-input.small{max-width:80px}.dark-select{background:#0000000a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 14px;color:var(--text);font-size:13px}.field-row{display:flex;align-items:flex-start;gap:14px;width:100%;min-width:0}.field-label-text{font-size:13px;color:var(--text);white-space:normal;word-break:break-word;line-height:1.3;flex:1;min-width:0}.field-label-input{background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:4px 8px;color:#fff;font-size:13px;width:160px}.field-input-wrapper{flex:1;min-width:0}.custom-label-input{background:var(--bg-elevated);border:1px solid transparent;border-radius:6px;color:var(--text);font-size:11px;outline:none}.field-label{display:flex;align-items:flex-start;gap:8px;font-size:11px;font-weight:500;color:var(--text);white-space:normal;word-break:break-word;line-height:1.3;flex:1;min-width:0}.map-modal{width:700px;background:#2e65e5;border-radius:12px;padding:24px;box-shadow:0 20px 60px #00000080}.map-modal-header{display:flex;justify-content:space-between;align-items:center}.map-modal-body{margin-top:20px;display:flex;flex-direction:column;gap:12px}.map-modal-overlay{position:fixed;inset:0;background:#000000a6;display:flex;justify-content:center;align-items:center;z-index:9999}.map-modal{width:1100px;background:var(--bg-elevated);border-radius:14px;padding:24px}.map-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.map-subtitle{font-size:12px;opacity:.7;margin-top:4px}.map-picker-body{display:flex;gap:28px;height:520px}.map-picker-left{width:320px;display:flex;flex-direction:column;gap:12px}.map-picker-right{flex:1;display:flex;flex-direction:column}.map-picker-right .leaflet-map{height:420px;border-radius:12px;overflow:hidden}.map-picker-footer{margin-top:16px;display:flex;justify-content:space-between;padding:12px 16px;background:var(--bg);border-radius:8px}.map-container-fixed{height:420px;border-radius:12px;overflow:hidden}.map-picker-footer-card{margin-top:14px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:14px 18px}.map-footer-row{display:flex;justify-content:space-between;align-items:center}.map-footer-label{font-size:13px;color:var(--text-muted)}.map-footer-value{font-size:13px;font-weight:500;color:var(--text)}.search-result-card{margin-top:12px;padding:12px 14px;border-radius:12px;background:#0f172a99;border:1px solid rgba(148,163,184,.2);cursor:pointer;transition:all .2s ease}.search-result-card:hover{border-color:#3b82f699;background:#1e293bb3}.search-result-title{font-size:14px;font-weight:500;color:var(--text)}.map-picker-info{margin-top:10px;font-size:12px;color:var(--text-muted)}.field-row{position:relative}.custom-label-input{flex:1;min-width:0}.field-label button{flex-shrink:0}.modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:modalFadeIn .2s ease-out;z-index:99999!important}.modal-container{background:#0f172af2;border-radius:var(--radius-lg);width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-soft);border:1px solid rgba(56,189,248,.2);overflow:hidden;animation:modalSlideUp .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100000!important}.modal-header{padding:20px 24px 16px;border-bottom:1px solid rgba(56,189,248,.2);background:var(--bg);flex-shrink:0;position:relative}.header-left{flex:1}.modal-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text);padding-right:100px}.modal-subtitle{font-size:.875rem;color:#94a3b8;margin:4px 0 0;font-weight:400;padding-right:100px}.modal-close-text{background:var(--bg);border:1px solid rgba(56,189,248,.3);color:var(--muted);padding:8px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px;text-align:center;text-transform:uppercase;letter-spacing:.05em;height:36px;position:absolute;top:20px;right:20px;display:flex;align-items:center;justify-content:center}.modal-close-text:hover{background:#38bdf833;border-color:#38bdf880;color:var(--muted);transform:translateY(-1px)}.modal-close-text:active{transform:translateY(0)}.modal-content{padding:24px;overflow-y:auto;flex:1;background:var(--bg);-webkit-overflow-scrolling:touch}.modal-footer{padding:20px 24px;border-top:1px solid rgba(56,189,248,.2);background:var(--bg);display:flex;justify-content:flex-end;align-items:center;flex-shrink:0}.modal-buttons{display:flex;gap:12px;width:100%;justify-content:flex-end}.modal-button{padding:8px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid var(--muted);min-width:100px}.modal-button.secondary.cancel{background:var(--bg);color:var(--text)}.modal-button.secondary.cancel:hover{background:var(--bg);border-color:#38bdf880;color:var(--text);transform:translateY(-1px)}.modal-button.secondary.draft{background:var(--bg);color:var(--text);border-color:#38bdf880}.modal-button.secondary.draft:hover{background:var(--bg);border-color:#38bdf8cc;transform:translateY(-1px)}.modal-button.primary:hover{background:#fb923c66;border-color:#c17130cc;color:var(--text);transform:translateY(-1px)}.modal-section-card{border-radius:var(--radius-md);border:1px solid rgba(56,189,248,.2);overflow:hidden;box-shadow:0 4px 12px #00000026;height:100%;display:flex;flex-direction:column;background:var(--bg)}.modal-section-header{padding:14px 16px 10px;border-bottom:1px solid rgba(56,189,248,.2);background:var(--bg);display:flex;justify-content:space-between;align-items:center;gap:12px;min-height:44px;box-sizing:border-box}.modal-section-title{font-size:14px;font-weight:600;color:var(--text);margin:0;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;flex:0 0 auto}.modal-section-body{padding:12px;flex:1;display:flex;flex-direction:column;gap:10px;background:var(--bg)}.section-alarm-snapshot,.section-engineer-selection,.section-action-plan{background:var(--bg)}.section-row{display:flex;justify-content:space-between;align-items:center;gap:6px;min-height:32px}.modal-two-columns{display:grid;grid-template-columns:1fr 1.3fr;gap:16px;margin-bottom:24px}.action-plan-input{flex:1}.scrollbar-thin::-webkit-scrollbar{width:6px}.scrollbar-thin::-webkit-scrollbar-track{background:var(--bg);border-radius:4px}.scrollbar-thin::-webkit-scrollbar-thumb{background:#38bdf866;border-radius:4px}.scrollbar-thin::-webkit-scrollbar-thumb:hover{background:#38bdf880}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-xl .modal-container{max-width:1100px}@media(max-width:768px){.modal-container{max-height:95vh;max-width:95vw}.modal-header{padding:16px 20px 12px}.modal-content{padding:20px}.modal-footer{padding:16px 20px}.modal-buttons{flex-direction:column}.modal-buttons button{width:100%}.modal-two-columns{grid-template-columns:1fr;gap:16px}.work-order-textarea{font-size:14px;padding:10px 12px}.work-order-textarea.small{min-height:38px;height:38px}}@media(max-width:480px){.modal-container{max-width:100vw;max-height:100vh;border-radius:0;margin:0}.modal-header,.modal-content,.modal-footer{padding:14px 16px}.modal-buttons{gap:8px}.work-order-textarea{font-size:16px;padding:10px}.work-order-textarea.small{min-height:36px;height:36px;font-size:14px}.modal-button{font-size:16px!important}}.modal-button:focus,.work-order-textarea:focus{outline:2px solid var(--accent);outline-offset:2px}.modal-container[aria-modal=true]{outline:none}.work-order-input{width:100%;padding:6px 10px;border:1px solid var(--muted);border-radius:6px;font-size:12px;font-family:inherit;background:var(--bg);color:var(--text);line-height:1.4;box-sizing:border-box;transition:all .2s ease}.work-order-input:focus{outline:none;border-color:#38bdf8cc;box-shadow:0 0 0 1px #38bdf833}.work-order-input.small{min-height:28px;height:28px;resize:none}.work-order-input.multi-line{min-height:50px;resize:vertical;font-size:11px;line-height:1.3}.work-order-input::placeholder{color:#64748b}.work-order-input.readonly{background:var(--bg);color:var(--text);cursor:default}.selected-counter{font-size:12px;font-weight:500;color:#94a3b8;white-space:nowrap;background:var(--bg);padding:4px 10px;border-radius:4px;border:1px solid rgba(148,163,184,.2)}.budget-label{font-size:10px;color:var(--text);flex:0 0 140px}.action-plan-fields{padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--bg)}.action-plan-field{display:flex;align-items:flex-start;gap:12px}.action-plan-input .work-order-input,.action-plan-input .work-order-textarea{width:100%}.work-order-textarea{width:100%;padding:8px 12px;border:1px solid rgba(148,163,184,.4);border-radius:6px;font-size:12px;font-family:inherit;background:var(--bg);color:var(--text);line-height:1.5;resize:vertical;min-height:60px;box-sizing:border-box;transition:all .2s ease}.work-order-textarea:focus{outline:none;border-color:#38bdf8cc;box-shadow:0 0 0 1px #38bdf833}.work-order-textarea::placeholder{color:#64748b}.calculate-button{padding:6px 16px;background:#38bdf826;border:1px solid rgba(56,189,248,.4);color:var(--text);border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em}.calculate-button:hover{background:#38bdf840;border-color:#38bdf8b3;transform:translateY(-1px)}.calculate-button-above{display:flex;justify-content:auto;margin-bottom:8px}.currency-input{display:flex;align-items:center;width:100%;position:relative}.currency-symbol{position:absolute;left:10px;color:#94a3b8;font-size:12px;pointer-events:none}.currency-display{padding:6px 10px;border:1px solid rgba(148,163,184,.4);border-radius:6px;font-size:12px;background:var(--bg);color:var(--text);line-height:1.4;min-height:28px;display:flex;align-items:center;justify-content:flex-end;width:100%}.calendar-button{background:var(--bg);border:1px solid rgba(148,163,184,.4);border-radius:6px;cursor:pointer;font-size:13px;width:40px;height:29px;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;color:var(--text);transition:all .2s ease}.calendar-button:hover{background:#38bdf81a;border-color:#38bdf899;color:var(--text)}.calendar-button:active{background-color:#d1d5db;transform:scale(.98)}.date-time-row{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;width:100%;overflow:hidden}.date-time-input{width:160px!important;min-width:153px;max-width:153px;flex-shrink:0;font-size:13px;padding:4px 8px}.map-button{background:#38bdf826;border:1px solid rgba(56,189,248,.4);color:var(--text);padding:4px 12px;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;height:26px;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;justify-content:center}.map-button:hover{background:#38bdf840;border-color:#38bdf8b3;transform:translateY(-1px)}.map-button:active{transform:translateY(0)}.map-button.standalone{padding:6px 12px;font-size:11px;font-weight:600;background:var(--bg);border:1px solid rgba(148,163,184,.4);border-radius:6px;color:var(--muted);cursor:pointer;transition:all .2s ease;white-space:nowrap}.map-button.standalone:hover{background:#38bdf81a;color:var(--text);border-color:#38bdf84d}.engineer-input-group{display:flex;align-items:center;gap:6px;grid-column:2}.engineer-number-container{display:flex;align-items:center}.engineer-number-input{width:50px!important;min-width:50px!important;max-width:50px!important;text-align:center;border-radius:6px!important;padding:6px 8px!important;font-size:12px!important;font-weight:600;color:var(--text);background:var(--muted);border:1px solid rgba(148,163,184,.4)}.engineer-number-input::-webkit-outer-spin-button,.engineer-number-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.spin-box-separated{display:flex;align-items:center}.spin-box-button.single-button{background:var(--bg);border:1px solid rgba(148,163,184,.4);border-radius:6px;color:var(--muted);width:24px;height:26px;padding:0;display:flex;flex-direction:column;cursor:pointer;position:relative;transition:all .2s ease;overflow:hidden}.spin-box-arrows{width:100%;height:100%;position:relative}.spin-up-arrow{position:absolute;top:2px;left:50%;transform:translate(-50%);font-size:8px;height:calc(50% - 2px);display:flex;align-items:flex-end;justify-content:center;width:100%;color:var(--muted)}.spin-down-arrow{position:absolute;bottom:2px;left:50%;transform:translate(-50%);font-size:8px;height:calc(50% - 2px);display:flex;align-items:flex-start;justify-content:center;width:100%;color:var(--muted)}.spin-box-button.single-button:hover .spin-up-arrow,.spin-box-button.single-button:hover .spin-down-arrow{color:#38bdf8}.spin-box-button.single-button:hover{background:#38bdf81a}.spin-box-button.single-button:active{background:#38bdf833}.section-row.combined-row{display:flex;align-items:center;gap:5px;width:100%;margin-bottom:12px}.combined-map-section{display:flex;align-items:center;justify-content:flex-end;min-width:120px;grid-column:3}.double-inputs .input-group{display:flex;gap:8px;width:100%}.double-inputs .work-order-input.small{flex:1;min-width:0}.section-input.double-inputs{flex:1;width:100%}.section-input{flex:1}.budget-grid-4x4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;margin-bottom:8px;padding:8px;background:var(--bg);border-radius:6px;border:1px solid rgba(220,229,233,.2)}.budget-grid-column{display:flex;flex-direction:column;gap:8px}.grand-total-item{margin-top:auto;display:flex;flex-direction:column;gap:4px;background:#38bdf814;border:1px solid rgba(56,189,248,.2);border-radius:45px;padding:6px 8px;height:auto;justify-content:center}.grand-total-item{font-size:10px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;text-align:center}.grand-total-display-empty{height:26px;display:flex;align-items:center;justify-content:center;padding:0 8px;font-size:12px;color:var(--muted);font-weight:600;text-align:center;min-height:28px}.grand-total-display-empty:not(:empty):not([data-value="0"]){color:var(--text);font-weight:700}.budget-grid-item{display:flex;flex-direction:column;gap:0px;margin:0;padding:0}.budget-grid-item{font-size:10px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.budget-grid-item .work-order-input.small{width:100%;min-height:28px;padding:4px 8px;font-size:12px;background:var(--bg);border:1px solid rgba(148,163,184,.4);color:var(--text)}.budget-grid-item .work-order-input.readonly{background:var(--bg);color:var(--text);cursor:default}.currency-input .currency-symbol{position:absolute;left:8px;color:#94a3b8;font-size:12px;font-weight:600;pointer-events:none;z-index:1}.currency-input .work-order-input.small{padding-left:20px;width:100%}.currency-display{height:26px;display:flex;align-items:center;padding:0 6px;background:var(--bg);border:1px solid rgba(148,163,184,.4);border-radius:6px;font-size:11px;color:var(--text);font-weight:600;justify-content:flex-end;margin-top:1px}.work-order-input::placeholder{color:#64748b;opacity:.7}.modal-button.primary.submit-work-order{background:var(--shadow-soft);color:#fed7aa;border:1px solid rgba(251,146,60,.5)}.modal-button.primary.submit-work-order:hover{background:#fb923c4d;border-color:#fb923ccc;color:#ffedd5;transform:translateY(-1px)}.modal-button.primary.submit-work-order:active{transform:translateY(0)}.events-history-modal.modal-container{width:90%;max-width:1200px;height:75vh;max-height:700px;display:flex;flex-direction:column;margin:auto;background:var(--bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(56,189,248,.2);border-radius:12px;box-shadow:0 20px 60px #00000080;overflow:hidden}.events-history-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;padding:16px}.events-history-layout{display:flex;gap:16px;height:100%;flex:1;min-height:0;overflow:hidden}.past-records-column{flex:0 0 280px;display:flex;flex-direction:column;border-right:1px solid rgba(56,189,248,.2);padding-right:16px;min-height:0;overflow:hidden}.past-records-header{padding-bottom:10px;border-bottom:1px solid rgba(56,189,248,.1);margin-bottom:10px;flex-shrink:0}.past-records-title{font-size:13px;font-weight:600;color:var(--text);margin:0 0 10px;text-transform:uppercase;letter-spacing:.05em}.past-records-search-input{width:100%;padding:6px 10px;border:1px solid rgba(148,163,184,.4);border-radius:6px;background:var(--bg);color:var(--text);font-size:12px;transition:all .2s ease}.past-records-search-input:focus{outline:none;border-color:#38bdf8cc;box-shadow:0 0 0 2px #38bdf833}.past-records-search-input::placeholder{color:#64748b}.past-records-table-container{flex:1;overflow-y:auto;margin-right:-6px;padding-right:6px;min-height:0;max-height:320px}.past-records-table{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed}.past-records-table thead{position:sticky;top:0;background:var(--bg);z-index:1}.past-records-table th{padding:6px 10px;text-align:left;font-weight:600;color:#94a3b8;border-bottom:1px solid rgba(56,189,248,.2);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.past-records-table td{padding:6px 10px;border-bottom:1px solid rgba(56,189,248,.1);vertical-align:top;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wo-number-col{width:90px;font-family:Monaco,Consolas,monospace;color:#7dd3fc}.title-col{color:var(--muted);min-width:0;white-space:normal}.date-col{width:80px;color:#94a3b8;text-align:right}.record-row{cursor:pointer;transition:all .2s ease}.record-row:hover{background:#38bdf80d}.record-row.selected{background:#38bdf81a;border-left:3px solid rgba(56,189,248,.8)}.record-row.selected td{color:var(--text)}.work-order-details-column{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.work-order-header{padding-bottom:10px;border-bottom:1px solid rgba(56,189,248,.2);margin-bottom:10px;flex-shrink:0}.work-order-title{font-size:15px;font-weight:600;color:var(--text);margin:0 0 10px;line-height:1.4;padding-right:100px}.work-order-title-wrapper{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:12px}.critical-title-badge{background:#ef444433;color:var(--accent-red);padding:4px 12px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(239,68,68,.4);white-space:nowrap;flex-shrink:0}.work-order-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 16px}.meta-row{display:flex;justify-content:space-between;align-items:center;min-height:24px}.meta-label{font-size:11px;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.05em;flex:0 0 110px}.meta-value{font-size:12px;color:var(--text);text-align:right;flex:1;font-weight:500}.work-order-tabs{display:flex;border-bottom:1px solid rgba(56,189,248,.2);margin-bottom:12px;flex-shrink:0}.work-order-tab{padding:6px 14px;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.work-order-tab:hover{color:#e0f2fe}.work-order-tab.active{color:#38bdf8;border-bottom-color:#38bdf8}.work-order-content{flex:1;overflow-y:auto;padding-right:4px;min-height:0;max-height:280px;margin-top:6px;border-top:1px solid rgba(56,189,248,.1);padding-top:12px}.tab-content{animation:fadeIn .3s ease;height:100%;min-height:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.overview-tab{height:100%;overflow-y:auto;padding-right:8px}.service-summary-section,.site-info-section{margin-bottom:18px}.section-title{font-size:12px;font-weight:600;color:var(--text-primary);margin:0 0 6px;text-transform:uppercase;letter-spacing:.05em}.section-content{font-size:12px;color:var(--text-primary);line-height:1.5;padding:10px;background:var(--bg);border-radius:6px;border-color:var(--accent)}.site-info-table{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed}.site-info-table tr{border-bottom:1px solid rgba(56,189,248,.1)}.site-info-table tr:last-child{border-bottom:none}.site-info-table td{padding:6px 10px;vertical-align:top}.info-label{font-size:12px;color:#94a3b8;width:140px}.info-value{font-size:12px;color:var(--text);font-weight:500}.checkinout-tab,.reports-tab{height:100%;margin:0;padding:10}.daily-check-table-container,.daily-reports-table-container{height:100%;min-height:250px;max-height:260px;overflow-y:auto;margin:0;padding:0}.daily-check-table,.daily-reports-table{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed;margin:0}.daily-check-table th,.daily-reports-table th{padding:6px 10px;text-align:left;font-weight:600;color:#94a3b8;border-bottom:1px solid rgba(56,189,248,.2);background:var(--bg);font-size:11px;text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0;z-index:1}.daily-check-table td,.daily-reports-table td{padding:6px 10px;border-bottom:1px solid rgba(56,189,248,.1);vertical-align:top;overflow:hidden;text-overflow:ellipsis}.daily-check-table tbody tr:hover,.daily-reports-table tr:hover{background:#38bdf80d}.daily-check-table th:nth-child(1),.daily-check-table td:nth-child(1){width:90px}.daily-check-table th:nth-child(2),.daily-check-table td:nth-child(2){width:80px}.daily-check-table th:nth-child(3),.daily-check-table td:nth-child(3){width:80px}.daily-check-table th:nth-child(4),.daily-check-table td:nth-child(4){width:110px}.daily-check-table th:nth-child(5),.daily-check-table td:nth-child(5){width:auto;min-width:180px;white-space:normal}.daily-reports-table th:nth-child(1),.daily-reports-table td:nth-child(1){width:90px}.daily-reports-table th:nth-child(2),.daily-reports-table td:nth-child(2){width:auto;white-space:normal}.modal-footer.events-history-footer{padding:16px;border-top:1px solid rgba(56,189,248,.1);background:var(--bg)}.modal-button.primary{background:#38bdf833;color:#bae6fd}.modal-button.primary:hover{background:#38bdf84d;border-color:#38bdf899;transform:translateY(-1px)}.modal-button.secondary.excel{background:#10b98133;color:var(--accent-green);border-color:#10b98166}.modal-button.secondary.excel:hover{background:#10b9814d;border-color:#10b98199;transform:translateY(-1px)}.modal-map-xl .modal-container{max-width:1200px;width:95vw;height:85vh;max-height:700px;display:flex;flex-direction:column}.map-modal-header{padding:20px 24px 16px;border-bottom:1px solid rgba(56,189,248,.2);background:linear-gradient(135deg,rgba(56,189,248,.12) 0%,var(--bg) 100%);flex-shrink:0;display:flex;justify-content:space-between;align-items:center}.map-modal-header .modal-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.map-instruction{padding:12px 24px;background:#0f172af2;border-bottom:1px solid rgba(56,189,248,.2);display:flex;flex-direction:column;gap:6px}.selection-counter{font-size:13px;color:var(--text);font-weight:500}.draft-message{font-size:12px;color:var(--muted);font-style:italic}.map-only-content{padding:0;display:flex;flex-direction:column;flex:1;overflow:hidden;background:linear-gradient(135deg,rgba(56,189,248,.05) 0%,var(--bg) 100%)}.fullscreen-map-container{flex:1;position:relative;overflow:hidden;background:var(--bg)}.map-modal-wrapper{height:100%;width:100%;padding:0;display:flex;justify-content:center;align-items:center}.map-modal-wrapper .map-container{height:95%;width:98%;max-width:1400px;border-radius:8px;overflow:hidden;border:1px solid rgba(56,189,248,.2);box-shadow:0 4px 12px #0000004d}.map-modal-wrapper .leaflet-container{width:100%!important;height:100%!important;background:var(--bg)!important}.map-tip{padding:10px 24px;background:var(--bg);border-top:1px solid rgba(56,189,248,.1);font-size:12px;color:#94a3b8;text-align:center;font-style:italic;font-weight:400}.tip-text{display:block;line-height:1.4}.header-right.map-buttons-header{display:flex;gap:8px;align-items:center}.map-header-button{padding:8px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid;text-transform:uppercase;letter-spacing:.05em;min-width:80px;text-align:center;height:36px;display:flex;align-items:center;justify-content:center}.map-header-button.save{background:#10b98133;color:#a7f3d0;border-color:#10b98166}.map-header-button.save:hover{background:#10b9814d;border-color:#10b981b3;transform:translateY(-1px)}.map-header-button.clear{background:#64748b33;color:#cbd5e1;border-color:#64748b66}.map-header-button.clear:hover{background:#64748b4d;border-color:#64748bb3;transform:translateY(-1px)}.map-header-button.complete{background:#38bdf833;color:#bae6fd;border-color:#38bdf866}.map-header-button.complete:hover{background:#38bdf84d;border-color:#38bdf8b3;transform:translateY(-1px)}.map-header-button.cancel{background:#ef444433;color:#fecaca;border-color:#ef444466}.map-header-button.cancel:hover{background:#ef44444d;border-color:#ef4444b3;transform:translateY(-1px)}.modal-calendar .modal-container{max-width:450px;width:100%;min-height:520px}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid rgba(56,189,248,.2);background:#0f172ae6}.calendar-title{font-size:.9rem;font-weight:600;color:var(--text);margin:0}.calendar-nav{display:flex;align-items:center;gap:16px}.calendar-nav button{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:1.2rem;padding:4px 8px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.calendar-nav button:hover{background:#38bdf81a;color:#e0f2fe}.calendar-month-year{font-size:1rem;font-weight:500;color:#e5e7eb;min-width:140px;text-align:center}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);padding:12px 20px 8px;background:#1e293be6;border-bottom:1px solid rgba(56,189,248,.1)}.weekday{font-size:12px;font-weight:600;color:#94a3b8;text-align:center;text-transform:uppercase;letter-spacing:.05em}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:12px 20px;background:#1e293bd9;min-height:260px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:400;color:#e5e7eb;background:#0f172a99;border:1px solid rgba(56,189,248,.1);border-radius:6px;cursor:pointer;transition:all .2s ease}.calendar-day:hover{background:#38bdf826;border-color:#38bdf84d;transform:translateY(-1px)}.calendar-day.selected{background:#38bdf840;border-color:#38bdf899;color:#e0f2fe;font-weight:600;box-shadow:0 2px 8px #38bdf833}.calendar-day.today{background:#fb923c33;border-color:#fb923c66;color:#fed7aa}.calendar-day.other-month{color:#64748b;background:#0f172a66}.calendar-day.disabled{color:#475569;background:#0f172a4d;cursor:not-allowed;opacity:.5}.calendar-day.disabled:hover{background:#0f172a4d;border-color:#38bdf81a;transform:none}.calendar-footer-row{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid rgba(56,189,248,.2);background:#0f172acc;margin-top:0;width:100%;box-sizing:border-box}.hour-select-container{display:flex;align-items:center;gap:12px}.hour-label{font-size:14px;font-weight:600;color:#e5f4ff;text-transform:uppercase;letter-spacing:.05em}.hour-select{padding:8px 12px;border:1px solid rgba(148,163,184,.4);border-radius:6px;background:#0f172ae6;color:#e5e7eb;font-size:14px;min-width:100px;cursor:pointer;transition:all .2s ease}.hour-select:focus{outline:none;border-color:#38bdf8cc;box-shadow:0 0 0 2px #38bdf833}.hour-select option{background:#0f172a;color:#e5e7eb}.calendar-buttons-row{display:flex;align-items:center;gap:10px}.calendar-buttons-row .calendar-modal-button.cancel{background:#0f172ae6;color:#e5e7eb;border-right:1px solid rgba(56,189,248,.2)}.calendar-buttons-row .calendar-modal-button.cancel:hover{background:#1e293be6}.calendar-buttons-row .calendar-modal-button.ok{background:#38bdf840;color:#e0f2fe}.calendar-buttons-row .calendar-modal-button.ok:hover{background:#38bdf859}@keyframes calendarFadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-calendar .modal-overlay{animation:modalFadeIn .2s ease-out}.modal-calendar .modal-container{animation:calendarFadeIn .3s ease-out}.budget-calculator-content{padding:20px;display:flex;flex-direction:column;gap:10px}.budget-section{background:#1e293bb3;border-radius:8px;padding:16px;border:1px solid rgba(56,189,248,.1)}.budget-engineer-name{display:flex;align-items:center;gap:12px;margin-bottom:8px}.budget-engineer-name{font-size:12px;font-weight:600;color:#94a3b8;min-width:140px}.budget-engineer-name .budget-input{flex:1}.budget-grid-2col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.budget-grid-item{display:flex;flex-direction:column;gap:6px}.budget-grid-item{font-size:11px;color:var(--text);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.budget-section-title-row{display:flex;align-items:center;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(56,189,248,.2);min-height:28px}.budget-section-title{font-size:14px;font-weight:700;color:#e5f4ff;margin:0;text-transform:uppercase;letter-spacing:.05em}.budget-add-button{background:#38bdf826;border:1px solid rgba(56,189,248,.4);color:#e0f2fe;width:26px;height:26px;border-radius:50%;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;margin-left:8px}.budget-add-button:hover{background:#38bdf840;border-color:#38bdf8b3;transform:translateY(-1px) scale(1.1)}.budget-add-button:active{transform:translateY(0) scale(1)}.budget-section-title-row+.budget-grid-2col,.budget-section-title-row+.budget-table-container,.budget-section-title-row+.travel-expenses-grid{margin-top:12px}.budget-table-container{margin-bottom:12px;overflow-x:auto}.budget-table{width:100%;border-collapse:collapse;font-size:12px}.budget-table th{padding:8px 10px;text-align:left;font-weight:600;color:#94a3b8;border-bottom:1px solid rgba(56,189,248,.2);background:#0f172a99;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.budget-table td{padding:8px 10px;border-bottom:1px solid rgba(56,189,248,.1);vertical-align:middle}.budget-table tbody tr:hover{background:#38bdf80d}.budget-remove-button{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fecaca;width:22px;height:22px;border-radius:4px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.budget-remove-button:hover{background:#ef444440;border-color:#ef444499;transform:translateY(-1px)}.budget-total-row{display:flex;justify-content:flex-end;align-items:center;padding-top:10px;border-top:1px solid rgba(56,189,248,.2);margin-top:8px;gap:5px}.budget-total-label{font-size:12px;font-weight:600;color:#e5f4ff;text-transform:uppercase;letter-spacing:.05em}.budget-total-display{padding:6px 12px;background:#38bdf81a;border:1px solid rgba(56,189,248,.3);border-radius:4px;font-size:13px;font-weight:600;color:#e0f2fe;min-width:100px;text-align:center}.travel-expenses-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}@media(min-width:768px){.travel-expenses-grid{grid-template-columns:repeat(4,1fr)}}.travel-expense-item{display:flex;flex-direction:column;gap:6px}.travel-expense-label{font-size:11px;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.budget-personal-total-section{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#1e293bcc;border-radius:8px;border:1px solid rgba(56,189,248,.2)}.budget-personal-total{display:flex;align-items:center;gap:12px}.budget-personal-total-label{font-size:14px;font-weight:700;color:#e5f4ff;text-transform:uppercase;letter-spacing:.05em}.budget-personal-total-display{padding:8px 16px;background:#38bdf826;border:1px solid rgba(56,189,248,.4);border-radius:6px;font-size:12px;font-weight:700;color:#e0f2fe;min-width:120px;text-align:center}.budget-confirm-button{padding:10px 24px;background:#38bdf833;border:1px solid rgba(56,189,248,.4);color:#e0f2fe;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em;min-width:120px}.budget-confirm-button:hover:not(:disabled){background:#38bdf84d;border-color:#38bdf8b3;transform:translateY(-1px)}.budget-confirm-button:disabled{opacity:.6;cursor:not-allowed}.budget-confirm-button.confirmed{background:#10b98133;border-color:#10b98166;color:#a7f3d0}.grand-total-exact-design{display:flex;flex-direction:column;gap:12px;width:100%}.grand-total-header{font-size:13px;font-weight:700;color:#e5f4ff;text-transform:uppercase;letter-spacing:.05em;padding-bottom:6px;border-bottom:1px solid rgba(56,189,248,.2);margin:0}.grand-total-values-row{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;padding:8px 0}.grand-value-item{font-size:11px;font-weight:600;color:#e5e7eb;white-space:nowrap;padding:6px 10px;background:#0f172ab3;border-radius:6px;border:1px solid rgba(148,163,184,.4);text-align:center;flex:1;min-width:100px;max-width:130px;letter-spacing:.02em}.grand-total-final-item{font-size:12px;font-weight:700;color:#e0f2fe;text-transform:uppercase;white-space:nowrap;padding:8px 14px;background:#38bdf833;border-radius:6px;border:1px solid rgba(56,189,248,.5);text-align:center;min-width:160px;margin-left:10px;letter-spacing:.05em;box-shadow:0 1px 3px #0003;flex-shrink:0}.grand-total-final-item.confirmed{background:#10b98133;border-color:#10b98180;color:#a7f3d0;font-weight:800}@media(max-width:1024px){.budget-grid-4x4{grid-template-columns:1fr 1fr}.grand-total-item{flex-direction:row;justify-content:space-between;align-items:center;padding:8px 12px}.grand-total-item .budget-label{margin-bottom:0;text-align:left}.grand-total-display-empty{min-width:100px;justify-content:flex-end}.events-history-layout{flex-direction:column}.past-records-column{flex:none;height:220px;max-height:220px;border-right:none;border-bottom:1px solid rgba(56,189,248,.2);padding-right:0;padding-bottom:16px;margin-bottom:16px}.past-records-table-container{max-height:150px}.work-order-meta-grid{grid-template-columns:1fr}.work-order-content{max-height:250px}.daily-check-table-container,.daily-reports-table-container{max-height:240px}.map-modal-header{flex-direction:column;gap:12px;align-items:stretch}.header-right.map-buttons-header{justify-content:flex-end;flex-wrap:wrap}.map-header-button{min-width:70px;padding:6px 12px;font-size:11px}}@media(max-width:768px){.budget-grid-4x4{grid-template-columns:1fr}.grand-total-values-row{flex-direction:column;align-items:stretch;gap:8px}.grand-value-item{max-width:100%;min-width:100%;display:flex;justify-content:space-between;padding:8px 12px}.grand-total-final-item{margin-left:0;margin-top:8px;min-width:100%;order:5}.budget-grid-2col{grid-template-columns:1fr}.travel-expenses-grid{grid-template-columns:repeat(2,1fr)}.budget-personal-total-section{flex-direction:column;gap:12px;align-items:stretch}.budget-personal-total{justify-content:space-between}.budget-table{font-size:11px}.budget-table th,.budget-table td{padding:6px 8px}.budget-section-title-row{flex-direction:column;align-items:flex-start;gap:8px}.budget-add-button{align-self:flex-end;margin-top:-40px}.events-history-modal.modal-container{width:95%;height:85vh;margin:10px auto}.work-order-tabs{flex-wrap:wrap}.work-order-tab{flex:1;min-width:120px;text-align:center;padding:8px 12px}.daily-check-table,.daily-reports-table,.site-info-table{display:block;overflow-x:auto;white-space:nowrap}.daily-check-table-container,.daily-reports-table-container{overflow-x:auto}.info-label{width:110px}.work-order-content{max-height:220px}.daily-check-table-container,.daily-reports-table-container{max-height:200px}.daily-check-table th:nth-child(5),.daily-check-table td:nth-child(5){min-width:150px}.modal-buttons{flex-direction:column}.modal-button{width:100%;text-align:center}.modal-map-xl .modal-container{width:100vw;height:100vh;max-height:100vh;border-radius:0;margin:0;padding:0}.map-modal-wrapper{padding:0}.map-modal-wrapper .map-container{border-radius:0;width:100%;height:100%;max-width:none}.map-instruction,.map-tip{padding:10px 16px;font-size:11px}.header-right.map-buttons-header{gap:6px}.map-header-button{min-width:60px;padding:6px 10px;font-size:10px}.date-time-row{flex-wrap:wrap}.date-time-input{min-width:120px}.double-inputs .input-group{flex-direction:column;gap:4px}.section-row .budget-label{flex:0 0 120px}}@media(max-width:480px){.budget-calculator-content{padding:16px}.budget-section{padding:12px}.travel-expenses-grid{grid-template-columns:1fr}.budget-table{display:block;overflow-x:auto;white-space:nowrap}.budget-section-title-row{flex-direction:row;align-items:center}.budget-add-button{margin-top:0}.events-history-modal.modal-container{height:90vh;margin:5px}.past-records-column{height:180px;max-height:180px}.past-records-table-container{max-height:130px}.work-order-content{max-height:180px}.daily-check-table-container,.daily-reports-table-container{max-height:160px}.modal-calendar .modal-container{max-width:95vw;min-height:480px}.calendar-header{padding:16px 20px 12px;flex-direction:column;gap:12px}.calendar-nav{width:100%;justify-content:space-between}.calendar-month-year{min-width:auto}.calendar-weekdays{padding:10px 16px 6px}.calendar-days{padding:10px 16px;min-height:220px}.calendar-day{font-size:13px}.calendar-footer-row{flex-direction:column;gap:16px;align-items:stretch}.hour-select-container{justify-content:space-between}.calendar-buttons-row{justify-content:center}.calendar-buttons-row .calendar-modal-button{flex:1}}@media(min-width:769px)and (max-width:1024px){.grand-total-values-row{flex-wrap:wrap;justify-content:flex-start}.grand-value-item{flex:0 0 calc(50% - 5px);max-width:calc(50% - 5px);margin-bottom:8px}.grand-total-final-item{flex:0 0 100%;max-width:100%;margin-left:0;margin-top:8px}}.work-orders{display:flex;flex-direction:column;gap:12px;color:var(--text)}.work-orders *{box-sizing:border-box}.work-orders .trend-up{color:var(--accent-green)}.work-orders .trend-down{color:var(--accent-red)}.work-orders .trend-warn{color:var(--accent-yellow)}.work-orders .status-open{background:color-mix(in srgb,var(--accent-yellow),transparent 85%);color:var(--accent-yellow)}.work-orders .detail-header{font-size:11px}.work-orders .detail-title{font-size:13px;font-weight:500;color:var(--text)}.work-orders .detail-meta-row{display:flex;flex-wrap:wrap;gap:4px}.work-orders .meta-badge strong{color:var(--text)}.work-orders .wo-item{cursor:pointer}.work-orders .tab{border-radius:999px;padding:3px 10px;font-size:10px;background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;transition:background .2s ease,color .2s ease,transform .15s ease}.work-orders .tab:hover{transform:translateY(-1px)}.work-orders .tab:active{transform:translateY(0)}.work-orders .tab.active{background:color-mix(in srgb,var(--accent),transparent 75%);color:var(--text);border-color:transparent;font-weight:600}.work-orders .panel-list li,.work-orders .checklist li,.work-orders .wo-timeline li{color:var(--text-soft)}.work-orders .panel-list strong,.work-orders .wo-timeline strong{color:var(--text)}.work-orders .wo-timeline{border-left:1px solid var(--border)}.work-orders .wo-timeline li:before{border-color:var(--accent)}.work-orders .mobile-item-meta{font-size:10px;color:var(--text-muted)}.work-orders .kpi-box{border-radius:10px;border:1px dashed var(--border-subtle);padding:8px 9px;transition:transform .2s ease,border-color .2s ease}.work-orders .kpi-box:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent),transparent 40%)}.work-orders .kpi-title{color:var(--text-muted)}.work-orders .kpi-main{font-size:16px;font-weight:600;color:var(--text)}.work-orders .kpi-foot{font-size:10px;color:var(--text-muted)}.work-orders .priority{font-weight:500}.work-orders .priority-critical{color:var(--accent-red)}.work-orders .priority-high{color:var(--accent-yellow)}.work-orders .priority-normal{color:var(--accent)}.work-orders .status-pill.status-pendingparts{background:color-mix(in srgb,var(--accent),transparent 85%);color:var(--accent)}.workorders-list{max-height:420px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:6px}.workorders-list::-webkit-scrollbar{width:6px}.workorders-list::-webkit-scrollbar-track{background:transparent}.workorders-list::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:6px}.wo-item{transition:background-color .25s ease,border-left-color .25s ease,transform .2s ease}.wo-item:hover{transform:translate(2px)}.wo-item.selected{background:color-mix(in srgb,var(--accent),transparent 82%);border-left:3px solid var(--accent);animation:woSelect .25s ease-out}@keyframes woSelect{0%{background-color:transparent;transform:translate(-2px)}to{background-color:color-mix(in srgb,var(--accent),transparent 82%);transform:translate(0)}}.work-orders .detail-header,.work-orders .tabs{animation:detailsFadeIn .3s ease-out}@keyframes detailsFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tab-panel{animation:tabFade .2s ease-out}@keyframes tabFade{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.microsoft-button{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;border-radius:8px;border:1px solid #d1d5db;background:#fff;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;box-shadow:0 1px 2px #0000000d}.microsoft-button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;box-shadow:0 2px 4px #0000001a}.microsoft-button:active:not(:disabled){background:#f3f4f6;transform:translateY(0)}.microsoft-button:disabled{opacity:.6;cursor:not-allowed}.microsoft-logo{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;background:#fff;border:1px solid #e5e7eb;padding:6px}.microsoft-text{flex:1;display:flex;flex-direction:column;gap:2px}.microsoft-title{font-weight:600;font-size:14px;line-height:1.2}.microsoft-subtitle{font-size:11px;color:#6b7280;font-weight:400;line-height:1.2}.microsoft-button-outline{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;border:1px solid #3b82f6;background:transparent;color:#3b82f6;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.microsoft-button-outline:hover:not(:disabled){background:#3b82f60d;border-color:#2563eb}.microsoft-button-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid #d1d5db;background:#fff;cursor:pointer;transition:all .2s ease;padding:6px}.microsoft-button-icon:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.microsoft-icon{flex-shrink:0}.microsoft-spinner{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #3b82f6;border-radius:50%;animation:microsoft-spin .8s linear infinite;margin:0 auto}@keyframes microsoft-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-divider{display:flex;align-items:center;margin:16px 0;color:#6b7280;font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#374151;margin:0 12px}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-container{position:fixed;inset:0;background:radial-gradient(circle at top,rgba(56,189,248,.18),transparent 55%),radial-gradient(circle at bottom,#0f172af5,#020617 80%);display:flex;align-items:center;justify-content:center;z-index:999;padding:20px;overflow-y:auto}.login-card{width:380px;max-width:90vw;border-radius:18px;border:1px solid rgba(30,64,175,.9);box-shadow:0 22px 55px #0f172af2;background:radial-gradient(circle at 0 0,rgba(56,189,248,.18),transparent 55%),radial-gradient(circle at 100% 0,rgba(129,140,248,.22),transparent 60%),linear-gradient(145deg,#020617,#020617);padding:22px 22px 20px;color:#e5e7eb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;position:relative}.login-logo{font-size:32px;font-weight:900;color:#3b82f6;margin-bottom:8px;letter-spacing:1px;text-shadow:0 2px 4px rgba(59,130,246,.3);text-align:center}.login-header{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;text-align:center}.login-title{font-size:18px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#e5f4ff;line-height:1.2;margin-top:4px}.login-subtitle{font-size:12px;color:#9ca3af;line-height:1.5;max-width:320px;margin:0 auto}.login-toast{position:fixed;top:20px;right:20px;padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:10px;max-width:380px;z-index:10000;animation:slideIn .3s ease;box-shadow:0 4px 12px #00000040;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.login-toast-success{background:#10b981f2;color:#fff;border-left:4px solid #059669}.login-toast-error{background:#ef4444f2;color:#fff;border-left:4px solid #dc2626}.login-toast-info{background:#3b82f6f2;color:#fff;border-left:4px solid #1d4ed8}.login-toast-icon{font-size:16px;flex-shrink:0}.login-toast-message{flex:1;font-weight:500}.login-toast-close{background:#fff3;border:none;color:#fff;font-size:18px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s;flex-shrink:0}.login-toast-close:hover{background:#ffffff4d}.login-form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.login-label{font-size:11px;color:#9ca3af;font-weight:500;display:block;margin-left:4px;text-transform:uppercase;letter-spacing:.5px}.login-input,.login-select{border-radius:999px;border:1px solid rgba(148,163,184,.7);background:#0f172af2;color:#e5e7eb;font-size:12px;padding:8px 12px;outline:none;width:100%;box-sizing:border-box;font-family:inherit;transition:all .2s ease}.login-input:focus,.login-select:focus{border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf833}.login-input:disabled,.login-select:disabled{opacity:.7;cursor:not-allowed}.login-input::placeholder{color:#6b7280}.login-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:35px}.login-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:login-spin .8s linear infinite;margin-right:8px}@keyframes login-spin{to{transform:rotate(360deg)}}.login-error{background:#ef44441a;color:#fecaca;padding:8px 12px;border-radius:8px;font-size:12px;margin-bottom:12px;border:1px solid rgba(239,68,68,.3);display:flex;align-items:center;gap:8px;animation:fadeIn .3s ease}.login-error-icon{font-size:14px;flex-shrink:0}.login-button-container{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;margin-bottom:16px;flex-wrap:nowrap}.login-security-badge{display:flex;justify-content:center;gap:6px;padding:10px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.8);font-size:11px;background:#0f172af2;color:#cbd5e1;white-space:normal;word-wrap:break-word;word-break:break-word;text-align:center;line-height:1.4;max-width:65%;min-width:0;flex-shrink:1;min-height:44px;align-items:center}.login-security-badge span:last-child{display:inline-block;white-space:normal;word-wrap:break-word;line-height:1.4}.login-submit-button{border-radius:999px;border:0;padding:10px 20px;font-size:12px;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#38bdf8,#4f46e5);color:#0b1120;box-shadow:0 10px 26px #38bdf8b3;min-width:100px;max-width:35%;transition:all .3s ease;font-family:inherit;white-space:nowrap;flex-shrink:0}.login-submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 30px #38bdf8cc}.login-submit-button:active:not(:disabled){transform:translateY(0)}.login-submit-button:disabled{background:#94a3b880;color:#94a3b8;cursor:not-allowed;box-shadow:none}@media(max-width:480px){.login-container{padding:10px}.login-card{padding:18px 16px;width:100%;max-width:340px}.login-title{font-size:16px}.login-subtitle{font-size:11px}.login-button-container{flex-direction:column;gap:12px}.login-security-badge{max-width:100%;min-height:48px;padding:12px 16px;order:2}.login-submit-button{max-width:100%;width:100%;padding:12px 24px;order:1}.demo-accounts-grid{grid-template-columns:1fr;gap:10px}.microsoft-login-container{margin-top:6px}.login-toast{max-width:calc(100vw - 40px);right:10px;left:10px}}@media(max-width:360px){.login-card{padding:16px 14px}.login-title{font-size:15px}.login-input,.login-select{font-size:11px;padding:7px 10px}.login-security-badge{font-size:10px;padding:10px 12px}.demo-account{padding:10px}}.login-divider{display:flex;align-items:center;margin:20px 0;color:#6b7280;font-size:12px;font-weight:500}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,#374151,transparent);margin:0 12px}.microsoft-login-container{margin-top:8px;margin-bottom:20px}.microsoft-login-info{margin-top:10px;display:flex;flex-direction:column;gap:6px}.microsoft-login-hint,.microsoft-login-note{display:flex;align-items:center;gap:8px;font-size:12px;padding:6px 10px;border-radius:6px;line-height:1.4}.microsoft-login-hint{background:#3b82f61a;color:#93c5fd;border:1px solid rgba(59,130,246,.25)}.microsoft-login-note{background:#eab3081a;color:#fde047;border:1px solid rgba(234,179,8,.25)}.microsoft-hint-icon,.microsoft-note-icon{font-size:12px;flex-shrink:0}.login-demo-info{margin-top:12px;padding:14px;border-radius:10px;background:#0f172a99;border:1px solid rgba(148,163,184,.25);animation:fadeIn .5s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.demo-title{font-weight:700;margin-bottom:10px;color:#38bdf8;font-size:12px;text-transform:uppercase;letter-spacing:.5px;line-height:1.2;display:flex;align-items:center;gap:6px}.demo-accounts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:12px}.demo-account{background:#1e293bcc;border:1px solid #334155;border-radius:8px;padding:12px;text-align:center;transition:transform .2s ease,border-color .2s ease}.demo-account:hover{transform:translateY(-2px);border-color:#38bdf8}.demo-account-role{font-size:11px;font-weight:700;color:#94a3b8;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.demo-account-email{font-size:11px;color:#cbd5e1;font-family:Courier New,monospace;margin-bottom:4px;word-break:break-all;font-weight:500}.demo-account-password{font-size:12px;color:#f8fafc;font-weight:700;font-family:Courier New,monospace;background:#1e293be6;padding:4px 8px;border-radius:4px;display:inline-block;border:1px solid #475569}.demo-row{margin-bottom:4px;font-size:11px;display:flex;align-items:center;gap:6px;padding:2px 0}.demo-label{color:#94a3b8;min-width:60px;flex-shrink:0;font-weight:500}.demo-value{color:#e5e7eb;font-weight:600;word-break:break-all;font-family:Courier New,monospace}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.login-loading{animation:pulse 1.5s infinite ease-in-out}.login-container::-webkit-scrollbar{width:6px}.login-container::-webkit-scrollbar-track{background:#0f172a4d}.login-container::-webkit-scrollbar-thumb{background:#38bdf880;border-radius:3px}.login-container::-webkit-scrollbar-thumb:hover{background:#38bdf8b3}@media(prefers-color-scheme:dark){.login-card{border-color:#38bdf8b3;background:radial-gradient(circle at 0 0,rgba(56,189,248,.12),transparent 55%),radial-gradient(circle at 100% 0,rgba(129,140,248,.15),transparent 60%),linear-gradient(145deg,#020617,#020617)}.login-security-badge{background:#1e293be6}}@media print{.login-container{position:static;background:#fff;color:#000}.login-card{box-shadow:none;border:1px solid #ccc;background:#fff;color:#000}.login-toast,.demo-quick-button,.login-submit-button{display:none}}.login-hidden{display:none!important}.login-visible{display:block!important}.login-text-center{text-align:center}.login-mt-1{margin-top:4px}.login-mt-2{margin-top:8px}.login-mt-3{margin-top:12px}.login-mt-4{margin-top:16px}.login-mb-1{margin-bottom:4px}.login-mb-2{margin-bottom:8px}.login-mb-3{margin-bottom:12px}.login-mb-4{margin-bottom:16px}.login-input.valid{border-color:#10b981}.login-input.invalid{border-color:#ef4444}.login-input.warning{border-color:#f59e0b}.login-tooltip{position:relative;display:inline-block}.login-tooltip .login-tooltip-text{visibility:hidden;width:200px;background-color:#0f172af2;color:#e5e7eb;text-align:center;border-radius:6px;padding:8px;position:absolute;z-index:1;bottom:125%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .3s;border:1px solid rgba(56,189,248,.3);font-size:11px}.login-tooltip:hover .login-tooltip-text{visibility:visible;opacity:1}
