*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#e6f4ff;background-attachment:fixed;color:#333;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@keyframes loadingBar{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin-slow{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.animate-spin-slow{animation:spin-slow 1.2s linear}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@keyframes fadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow{0%,to{box-shadow:0 0 20px #667eea4d}50%{box-shadow:0 0 30px #667eea99}}.fade-in{animation:fadeIn .8s cubic-bezier(.4,0,.2,1)}.slide-in{animation:slideIn .6s cubic-bezier(.4,0,.2,1)}.slide-in-up{animation:slideInUp .8s cubic-bezier(.4,0,.2,1)}.pulse{animation:pulse 2s infinite}.float{animation:float 3s ease-in-out infinite}.shimmer{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);background-size:200% 100%}.glow{animation:glow 2s ease-in-out infinite}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.nice-scroll{scrollbar-color:#94a3b899 #0000;scrollbar-width:thin}.nice-scroll::-webkit-scrollbar{width:8px}.nice-scroll::-webkit-scrollbar-track{background:#0000}.nice-scroll::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#94a3b88c,#64748ba6);border-radius:9999px}.nice-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#64748ba6,#475569bf)}@media (max-width:1024px){.panel-row{justify-content:stretch!important}.panel-row>div{flex:1 1 auto!important;width:100%!important}}@media (max-width:1280px){.analytics-row{grid-template-columns:1fr!important}}.leaflet-image-layer,.leaflet-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane,.leaflet-pane>canvas,.leaflet-pane>svg,.leaflet-tile,.leaflet-tile-container,.leaflet-zoom-box{left:0;position:absolute;top:0}.leaflet-container{overflow:hidden}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.leaflet-tile::selection{background:#0000}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{height:1600px;-webkit-transform-origin:0 0;width:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-height:none!important;max-width:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer{max-height:none!important;max-width:none!important;padding:0;width:auto}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{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{box-sizing:border-box;height:0;width:0;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{height:1px;width:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{pointer-events:visiblePainted;pointer-events:auto;position:relative;z-index:800}.leaflet-bottom,.leaflet-top{pointer-events:none;position:absolute;z-index:1000}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{clear:both;float:left}.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;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-pan-anim .leaflet-tile,.leaflet-zoom-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-control,.leaflet-popup-pane{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-image-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-image-layer.leaflet-interactive,.leaflet-marker-icon.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{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;color:#000;display:block;height:26px;line-height:26px;text-align:center;text-decoration:none;width:26px}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:focus,.leaflet-bar a:hover{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:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.leaflet-bar a.leaflet-disabled{background-color:#f4f4f4;color:#bbb;cursor:default}.leaflet-touch .leaflet-bar a{height:30px;line-height:30px;width: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{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.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);height:36px;width: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{height:44px;width: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{background:#fff;color:#333;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{overflow-x:hidden;overflow-y:scroll;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{border-top:1px solid #ddd;height:0;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{color:#333;line-height:1.4;padding:0 5px}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:focus,.leaflet-control-attribution a:hover{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;height:.6669em;vertical-align:initial!important;width:1em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{background:#fffc;border:2px solid #777;border-top:none;box-sizing:border-box;line-height:1.1;padding:2px 5px 1px;text-shadow:1px 1px #fff;white-space:nowrap}.leaflet-control-scale-line:not(:first-child){border-bottom:none;border-top:2px solid #777;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers{box-shadow:none}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-layers{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{margin-bottom:20px;position:absolute;text-align:center}.leaflet-popup-content-wrapper{border-radius:12px;padding:1px;text-align:left}.leaflet-popup-content{font-size:13px;font-size:1.08333em;line-height:1.3;margin:13px 24px 13px 20px;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{height:20px;left:50%;margin-left:-20px;margin-top:-1px;overflow:hidden;pointer-events:none;position:absolute;width:40px}.leaflet-popup-tip{height:17px;margin:-10px auto 0;padding:1px;pointer-events:auto;transform:rotate(45deg);width:17px}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;box-shadow:0 3px 14px #0006;color:#333}.leaflet-container a.leaflet-popup-close-button{background:#0000;border:none;color:#757575;font:16px/24px Tahoma,Verdana,sans-serif;height:24px;position:absolute;right:0;text-align:center;text-decoration:none;top:0;width:24px}.leaflet-container a.leaflet-popup-close-button:focus,.leaflet-container a.leaflet-popup-close-button:hover{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678,M12=0.70710678,M21=-0.70710678,M22=0.70710678);margin:0 auto;width:24px}.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-control-zoom,.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{background-color:#fff;border:1px solid #fff;border-radius:3px;box-shadow:0 1px 3px #0006;color:#222;padding:6px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;white-space:nowrap}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before,.leaflet-tooltip-top:before{background:#0000;border:6px solid #0000;content:"";pointer-events:none;position:absolute}.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{border-top-color:#fff;bottom:0;margin-bottom:-12px}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-left:-6px;margin-top:-12px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;left:0;margin-left:-12px}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.toast-wrap{grid-gap:10px;display:grid;gap:10px;max-width:min(420px,90vw);position:fixed;right:18px;top:76px;z-index:9999}.toast{animation:toastIn .18s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 24px #0206171f;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;padding:12px 14px}.toast-title{color:#0f172a;font-weight:600;margin-bottom:2px}.toast-msg{color:#475569;font-size:13px}.toast-info{border-left:5px solid #3b82f6}.toast-ok{border-left:5px solid #16a34a}.toast-warn{border-left:5px solid #f59e0b}.toast-error{border-left:5px solid #ef4444}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.App{background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;display:block;margin:0;min-height:100vh;overflow-x:hidden;padding:0;position:relative}.App:before{background:radial-gradient(circle at 20% 80%,#7877c64d 0,#0000 50%),radial-gradient(circle at 80% 20%,#ff77c64d 0,#0000 50%),radial-gradient(circle at 40% 40%,#78dbff33 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.auth-page{align-items:center;background:linear-gradient(135deg,#3b82f61a,#9333ea1a),url(/static/media/water.a7bde6a8cc58c8428f70.jpg) 50%/cover no-repeat;display:flex;justify-content:center;min-height:100vh;padding:20px;position:relative}.auth-page:before{background:linear-gradient(135deg,#3b82f633,#9333ea33);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.auth-page .auth-container{position:relative;z-index:2}.auth-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:24px;box-shadow:0 32px 80px #0000004d,0 0 0 1px #fff3;max-width:520px;overflow:hidden;padding:48px;position:relative;width:100%;z-index:0}.auth-container:before{animation:gradientShift 8s ease-in-out infinite;background:linear-gradient(135deg,#3b82f666,#9333ea66 25%,#22c55e66 50%,#3b82f666 75%,#9333ea66);border-radius:26px;content:"";inset:-2px;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:2px;pointer-events:none;position:absolute;z-index:0}@keyframes gradientShift{0%,to{background:linear-gradient(135deg,#3b82f666,#9333ea66 25%,#22c55e66 50%,#3b82f666 75%,#9333ea66)}50%{background:linear-gradient(135deg,#9333ea66,#22c55e66 25%,#3b82f666 50%,#9333ea66 75%,#22c55e66)}}.auth-header{margin-bottom:40px;position:relative;text-align:center}.auth-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1e40af,#7c3aed 50%,#059669);-webkit-background-clip:text;background-clip:text;font-size:36px;font-weight:800;letter-spacing:-.5px;margin-bottom:12px}.auth-subtitle{color:#64748b;font-size:18px;font-weight:500;opacity:.9}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:8px}.two-col{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.two-col>.form-group{min-width:0}.form-label{color:#4a5568;font-size:14px;font-weight:500}.form-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:2px solid #e2e8f0cc;border-radius:16px;color:#1e293b;font-size:16px;font-weight:500;padding:16px 20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.form-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f626;outline:none;transform:translateY(-1px)}.form-input::placeholder{color:#94a3b8;font-weight:400}.form-input.error{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e1a}.form-error{color:#e53e3e;font-size:14px;margin-top:4px}.auth-button{background:linear-gradient(135deg,#3b82f6,#8b5cf6 50%,#06b6d4);border:none;border-radius:16px;box-shadow:0 8px 32px #3b82f64d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;letter-spacing:.5px;overflow:hidden;padding:18px 32px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.auth-button:hover{background:linear-gradient(135deg,#2563eb,#7c3aed 50%,#0891b2);box-shadow:0 20px 40px #3b82f666;transform:translateY(-4px)}.auth-button:active{transform:translateY(-2px)}.auth-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.auth-button.loading{color:#0000}.auth-button.loading:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.auth-link{color:#718096;font-size:14px;margin-top:20px;text-align:center}.auth-link a{color:#667eea;font-weight:500;text-decoration:none;transition:color .3s ease}.auth-link a:hover{color:#764ba2}.alert{border-radius:12px;font-size:14px;font-weight:500;margin-bottom:20px;padding:12px 16px}.alert.error{background:#fed7d7;border:1px solid #feb2b2;color:#c53030}.alert.success{background:#c6f6d5;border:1px solid #9ae6b4;color:#2f855a}.dashboard{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:20px;box-shadow:0 25px 60px #00000040;max-width:600px;padding:40px;text-align:center;width:100%}.dashboard-header{margin-bottom:30px}.dashboard-title{color:#2d3748;font-size:32px;font-weight:700;margin-bottom:10px}.dashboard-subtitle{color:#718096;font-size:18px}.user-info{background:#f7fafc;border-radius:12px;margin-bottom:30px;padding:20px}.user-name{color:#2d3748;font-size:24px;font-weight:600;margin-bottom:8px}.user-email{color:#718096;font-size:16px}.logout-button{background:#e53e3e;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.logout-button:hover{background:#c53030;box-shadow:0 8px 16px #e53e3e4d;transform:translateY(-2px)}@media (max-width:768px){.auth-page{padding:16px}.auth-container{border-radius:20px;max-width:100%;padding:32px 24px}.auth-title{font-size:28px}.auth-subtitle,.form-input{font-size:16px}.form-input{padding:14px 18px}.auth-button{font-size:16px;padding:16px 28px}}@media (max-width:480px){.auth-page{padding:12px}.auth-container{padding:24px 20px}.auth-title{font-size:24px}.auth-subtitle{font-size:14px}.form-input{font-size:16px;padding:12px 16px}.auth-button{font-size:16px;padding:14px 24px}.two-col{gap:12px;grid-template-columns:1fr}}.wqms-dashboard{background:#0000!important;background-attachment:fixed;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;min-height:100vh;min-height:auto!important;padding-top:0!important;position:relative;z-index:1}.App.neutral-page-bg{display:flex;flex-direction:column;min-height:100vh}.wqms-dashboard:before{background:radial-gradient(circle at 20% 80%,#7877c633 0,#0000 50%),radial-gradient(circle at 80% 20%,#ff77c633 0,#0000 50%),radial-gradient(circle at 40% 40%,#78dbff26 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.wqms-dashboard .dashboard-header{align-items:center;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:linear-gradient(135deg,#fffffff2,#ffffffe6);border:1px solid #ffffff4d;border-radius:0;box-shadow:0 16px 48px #00000026;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:0;overflow:visible;padding:.75rem 1rem;position:relative;z-index:20}.wqms-dashboard .dashboard-header:before{background:linear-gradient(135deg,#667eea0d,#764ba20d);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.wqms-dashboard .header-left h1{-webkit-text-fill-color:#0000;animation:fadeIn .8s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:900;letter-spacing:-1px;margin:0;position:relative;text-shadow:0 4px 8px #667eea33;z-index:1}.wqms-dashboard .header-left p{color:#64748b;font-size:1rem;font-weight:600;margin:.5rem 0 0;opacity:.9;position:relative;z-index:1}.wqms-dashboard .header-right{align-items:center;display:flex;gap:1rem}.wqms-dashboard .user-info{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;color:#4a5568;display:flex;font-weight:600;gap:.75rem;margin:0;padding:.75rem 1rem;transition:all .3s ease}.wqms-dashboard .user-info:hover{background:#fff3;transform:translateY(-1px)}.wqms-dashboard .logout-btn{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:12px;box-shadow:0 4px 12px #ef44444d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.wqms-dashboard .logout-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 8px 20px #ef444466;transform:translateY(-2px)}.dashboard-controls{align-items:center;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:linear-gradient(135deg,#ffffffe6,#ffffffd9);border:1px solid #ffffff4d;box-shadow:0 8px 32px #00000014;display:flex;justify-content:space-between;overflow:visible;padding:.75rem 1rem;position:relative;z-index:10}.dashboard-controls:before{background:linear-gradient(135deg,#667eea08,#764ba208);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.time-filter{align-items:center;display:flex;gap:.75rem}.time-filter,.time-select{color:#4a5568;font-weight:500}.time-select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:2px solid #cbd5e080;border-radius:12px;cursor:pointer;font-size:.875rem;padding:.75rem 1rem;transition:all .3s ease}.time-select:hover{background:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-1px)}.refresh-control{padding-right:12px}.refresh-button{align-items:center;background:#ffffffe6;border:1px solid #cbd5e0b3;border-radius:10px;color:#374151;cursor:pointer;display:inline-flex;font-weight:600;gap:6px;padding:6px 10px;transition:all .2s ease}.refresh-button:hover:not(:disabled){background:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-1px)}.refresh-button:disabled{cursor:not-allowed;opacity:.7}.refresh-icon{transition:transform .2s ease}.refresh-icon.spinning{animation:spinRefresh 1s linear infinite}@keyframes spinRefresh{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.refresh-ripple{animation:ripple 1.6s ease-out infinite;background:#667eea99;border-radius:9999px;box-shadow:0 0 0 0 #667eea66;height:8px;position:absolute;right:-8px;width:8px}@keyframes ripple{0%{box-shadow:0 0 0 0 #667eea66;opacity:1}70%{box-shadow:0 0 0 12px #667eea00;opacity:.6}to{box-shadow:0 0 0 0 #667eea00;opacity:0}}@keyframes slideInUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.wqms-dashboard.refreshing .map-container,.wqms-dashboard.refreshing .stats-grid{filter:saturate(.95);opacity:.85;transition:opacity .2s ease,filter .2s ease}.station-names-banner{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#f8fafcd9;border:none;border-radius:0;box-shadow:0 6px 18px #00000014;display:flex;flex-wrap:wrap;gap:8px;margin:0;overflow-x:auto;padding:8px 10px}.station-chip{align-items:center;background:#fff;background-clip:initial;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 2px 8px #0000000f;color:#1f2937;display:inline-flex;font-weight:600;gap:6px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.station-chip:hover{border-color:#94a3b8e6;box-shadow:0 6px 16px #0000001f;transform:translateY(-2px)}.station-chip-dot{border-radius:9999px;height:10px;width:10px}.station-chip-text{font-size:.85rem;max-width:220px;overflow:hidden;text-overflow:ellipsis}.time-select:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.refresh-btn{align-items:center;background:linear-gradient(135deg,#3182ce,#2563eb);border:none;border-radius:12px;box-shadow:0 4px 12px #3182ce4d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.refresh-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 20px #3182ce66;transform:translateY(-2px)}.refresh-btn:disabled{background:linear-gradient(135deg,#a0aec0,#94a3b8);box-shadow:none;cursor:not-allowed;transform:none}.stats-grid{grid-gap:.5rem;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:linear-gradient(135deg,#fffffff2,#ffffffe6);border:1px solid #ffffff4d;box-shadow:0 16px 48px #0000001a;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding:.5rem .75rem;position:relative;z-index:1}.stats-grid:before{background:radial-gradient(circle at 20% 20%,#667eea0d 0,#0000 50%),radial-gradient(circle at 80% 80%,#764ba20d 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.stat-card{align-items:center;animation:slideInUp .35s ease-out;animation-fill-mode:both;background:linear-gradient(135deg,#667eea,#8b5cf6 50%,#764ba2);border:1px solid #fff3;border-radius:14px;box-shadow:0 8px 24px #667eea4d;color:#fff;display:flex;gap:.5rem;overflow:hidden;padding:.6rem .5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}@media (prefers-reduced-motion:reduce){.stat-card{animation:none}}.stat-card:first-child{animation-delay:.04s}.stat-card:nth-child(2){animation-delay:.08s}.stat-card:nth-child(3){animation-delay:.12s}.stat-card:nth-child(4){animation-delay:.16s}.stat-card:nth-child(5){animation-delay:.2s}.stat-card:nth-child(6){animation-delay:.24s}.stat-card:nth-child(7){animation-delay:.28s}.stat-card:nth-child(8){animation-delay:.32s}.stat-card:nth-child(9){animation-delay:.36s}.stat-card:nth-child(10){animation-delay:.4s}.stat-card:nth-child(11){animation-delay:.44s}.stat-card:nth-child(12){animation-delay:.48s}.stat-card:nth-child(13){animation-delay:.52s}.stat-card:nth-child(14){animation-delay:.56s}.stat-card:nth-child(15){animation-delay:.6s}.stat-card:nth-child(16){animation-delay:.64s}.stat-card:before{background:linear-gradient(135deg,#ffffff26,#ffffff0d 50%,#0000);bottom:0;left:0;right:0;top:0}.stat-card:after,.stat-card:before{content:"";pointer-events:none;position:absolute}.stat-card:after{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);height:200%;left:-50%;opacity:0;top:-50%;transition:opacity .3s ease;width:200%}.stat-card:hover{box-shadow:0 24px 64px #667eea80;transform:translateY(-8px) scale(1.02)}.stat-card:hover:after{opacity:1}.stat-card h3{font-size:.95rem;font-weight:800;letter-spacing:-.25px;text-shadow:0 1px 2px #00000026}.stat-card h3,.stat-card p{margin:0;position:relative;z-index:1}.stat-card p{font-size:.7rem;font-weight:600;opacity:.95;text-shadow:0 1px 2px #00000014}.map-container{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:none;border-radius:0;box-shadow:none;height:calc(100vh - 142px);margin:0;overflow:visible;position:relative}.map-container:before{background:radial-gradient(circle at 30% 30%,#667eea0d 0,#0000 50%),radial-gradient(circle at 70% 70%,#764ba20d 0,#0000 50%);content:"";pointer-events:none;z-index:1}.loading-overlay,.map-container:before{bottom:0;left:0;position:absolute;right:0;top:0}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;display:flex;flex-direction:column;justify-content:center;z-index:1000}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #667eea33;border-radius:50%;border-top-color:#667eea;height:50px;margin-bottom:1rem;width:50px}.loading-overlay p{color:#4a5568;font-size:1.1rem;font-weight:600}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{background:#fed7d7;border:1px solid #feb2b2;border-radius:.375rem;color:#c53030;margin:1rem;padding:1rem}.station-popup{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 12px 28px #0000002e;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;max-height:50vh;max-width:320px;min-width:260px;overflow-x:hidden;overflow-y:auto;padding:.9rem 1rem .8rem;position:relative}.station-popup:before{background:linear-gradient(135deg,#667eea0d,#764ba20d);content:"";inset:0;pointer-events:none;position:absolute}.station-popup h3{color:#1d4ed8;font-size:1.05rem;font-style:normal;font-weight:800;letter-spacing:-.15px;margin:0 0 .3rem;position:relative;z-index:1}.station-popup p{color:#475569;font-size:.9rem;font-weight:600;margin:.25rem 0 .75rem;position:relative;word-break:break-word;z-index:1}.station-popup p strong{color:#64748b;font-weight:700;letter-spacing:.1px}.station-popup .parameters-grid{grid-gap:6px;display:grid!important;gap:6px;grid-template-columns:repeat(3,1fr);margin-top:.4rem;position:relative;z-index:1}.param-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;box-shadow:inset 0 1px 0 #fff9;display:flex;flex-direction:column;gap:.15rem;min-width:0;overflow:hidden;padding:.35rem .45rem;transition:transform .15s ease,background .2s ease}.param-item:hover{background:#667eea1a;transform:translateY(-2px)}.station-popup .param-item strong{color:#334155;display:block;font-size:.6rem!important;font-weight:700!important;line-height:1.1;white-space:normal;word-break:break-word}.station-popup .param-item .param-reading{font-feature-settings:"tnum";color:#0f172a;display:block;font-size:.68rem!important;font-variant-numeric:tabular-nums;font-weight:500!important}.station-popup::-webkit-scrollbar{width:8px}.station-popup::-webkit-scrollbar-thumb{background:#64748b4d;border-radius:8px}.station-popup::-webkit-scrollbar-track{background:#0000}.leaflet-popup-content-wrapper{background:#0000;border-radius:16px;box-shadow:none;max-width:none!important}.leaflet-popup-tip{background:#ffffffe6;box-shadow:0 10px 20px #0000001f}.leaflet-popup-content{margin:0}.leaflet-popup{max-width:none!important}.leaflet-popup-close-button{background:#0000000f;border:2px solid #000;border-radius:8px;box-shadow:0 3px 8px #00000026;color:#000!important;font-size:16px;font-weight:900;height:22px;line-height:20px;right:6px!important;text-align:center;text-decoration:none!important;top:6px!important;width:22px;z-index:2}.leaflet-popup-close-button:hover{background:#0000001f;transform:translateY(-1px)}.wqi-badge{align-items:center;border-radius:50%;box-shadow:0 3px 8px #0003;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:48px;justify-content:center;min-width:48px;position:absolute;right:12px;top:10px;z-index:3}.wqi-badge.good{background:#16a34a}.wqi-badge.moderate{background:#f59e0b}.wqi-badge.poor{background:#ef4444}.wqi-badge.excellent{background:#2563eb}@media (max-width:768px){.station-popup{max-width:280px;min-width:210px}}.details-btn{background:linear-gradient(135deg,#3182ce,#2563eb);border:none;border-radius:12px;box-shadow:0 4px 12px #3182ce4d;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.details-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 20px #3182ce66;transform:translateY(-2px)}.modal-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:2000}.modal-content{animation:slideIn .4s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 32px 64px #0003;max-height:85vh;max-width:700px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-bottom:1px solid #fff3;display:flex;justify-content:space-between;padding:2rem}.modal-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0}.close-btn{align-items:center;background:#ef44441a;border:2px solid #ef444433;border-radius:12px;color:#ef4444;cursor:pointer;display:flex;font-size:1.25rem;font-weight:600;height:36px;justify-content:center;padding:0;transition:all .3s ease;width:36px}.close-btn:hover{background:#ef444433;border-color:#ef444466;color:#dc2626;transform:scale(1.05)}.modal-body{padding:1.5rem}.station-info{background:#f7fafc;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.station-info p{color:#4a5568;margin:.5rem 0}.parameters-detailed h3{color:#2d3748;font-size:1.125rem;margin:0 0 1rem}.params-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,minmax(0,1fr))}.parameters-detailed .params-grid{gap:.75rem;grid-template-columns:repeat(3,minmax(0,1fr))!important}.parameters-detailed .param-card{padding:.8rem}.param-card{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid #667eea33;border-radius:12px;overflow:hidden;padding:1.5rem;position:relative;text-align:center;transition:all .3s ease}.param-card:before{background:linear-gradient(135deg,#ffffff1a,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.param-card:hover{border-color:#667eea4d;box-shadow:0 8px 24px #667eea26;transform:translateY(-2px)}.param-card h4{color:#475569;font-size:.85rem;font-weight:700;letter-spacing:.1px;margin:0 0 .5rem;position:relative;z-index:1}.param-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:400;position:relative;z-index:1}@media (max-width:1024px){.stats-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stat-card,.stats-grid{padding:1.5rem}.stat-card h3{font-size:1.5rem}}@media (max-width:768px){.wqms-dashboard .dashboard-header{align-items:stretch;flex-direction:column;gap:1rem;padding:1rem}.wqms-dashboard .header-left h1{font-size:1.75rem}.wqms-dashboard .header-right{flex-wrap:wrap;gap:.75rem;justify-content:space-between}.wqms-dashboard .user-info{font-size:.9rem;padding:.5rem .75rem}.wqms-dashboard .logout-btn{font-size:.9rem;padding:.5rem 1rem}.dashboard-controls{align-items:stretch;flex-direction:column;gap:1rem;padding:1rem}.time-filter{flex-wrap:wrap;gap:.5rem}.time-select{font-size:.8rem;padding:.5rem .75rem}.stats-grid{gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));padding:1rem}.stat-card{padding:1.25rem}.stat-card h3{font-size:1.25rem}.stat-card p{font-size:.8rem}.map-container{height:calc(100vh - 450px);margin:0 .5rem .5rem}.params-grid{grid-template-columns:1fr 1fr}.parameters-detailed .params-grid{grid-template-columns:1fr 1fr!important}.param-card{padding:1rem}.modal-content{margin:.5rem;max-height:90vh}.modal-header{padding:1.5rem}.modal-header h2{font-size:1.25rem}}@media (max-width:480px){.wqms-dashboard .dashboard-header{padding:.75rem}.wqms-dashboard{padding-bottom:env(safe-area-inset-bottom);padding-top:env(safe-area-inset-top)}@media (max-width:768px){.wqms-dashboard .dashboard-header{align-items:flex-start;flex-direction:column;gap:.75rem}.wqms-dashboard .header-right{flex-wrap:wrap;gap:.5rem;justify-content:flex-start}.logout-btn,.refresh-btn{font-size:.8rem;padding:.5rem .75rem}}@media (max-width:640px){.dashboard-controls{align-items:stretch;flex-direction:column;gap:.75rem}.time-filter{flex-wrap:wrap;gap:.5rem}.time-select{text-align:center;width:100%}}@media (max-width:768px){.stats-grid{gap:.6rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card h3{font-size:1rem}.stat-card p{font-size:.8rem}}@media (max-width:480px){.stats-grid{gap:.5rem;grid-template-columns:1fr;padding:.5rem}.map-container{border-radius:12px;height:calc(100vh - 500px);margin:0 .25rem}.station-names-banner{gap:6px;overflow-x:auto;scroll-snap-type:x mandatory}.station-chip{flex-shrink:0;font-size:12px;padding:6px 8px;scroll-snap-align:start}.wqms-dashboard .header-left h1{font-size:1.4rem}.wqms-dashboard .header-left p{font-size:.8rem}}.react-datepicker,.react-datepicker-popper,.react-datepicker__tab-loop{overflow:visible!important;z-index:9999!important}.absolute-range,.quick-ranges,.time-range-menu{left:auto!important;max-width:100vw;overflow:visible!important;right:0!important}.dashboard-controls,.wqms-dashboard .dashboard-header{overflow:visible!important}.wqms-dashboard .header-right .logout-btn,.wqms-dashboard .header-right button{align-items:center;border-radius:8px;box-shadow:0 2px 6px #0000001a;display:flex;font-size:.85rem;font-weight:600;gap:6px;line-height:1;padding:6px 12px}.wqms-dashboard .header-right button svg{height:16px;width:16px}.wqms-dashboard .logout-btn{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 10px #ef44444d}.wqms-dashboard .logout-btn:hover{transform:translateY(-1px)}.wqms-dashboard .header-right .permissions-btn,.wqms-dashboard .header-right .users-btn{background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;color:#fff}.wqms-dashboard .header-right .permissions-btn:hover,.wqms-dashboard .header-right .users-btn:hover{transform:translateY(-1px)}.dashboard-controls{flex-wrap:wrap;justify-content:space-between}.dashboard-controls,.dashboard-controls .left-controls{align-items:center;display:flex;gap:.5rem}.dashboard-controls .left-controls .filter-icon{align-items:center;background:#ffffffe6;border:1px solid #cbd5e0b3;border-radius:10px;display:flex;justify-content:center;padding:6px}.dashboard-controls .refresh-btn{align-items:center;display:flex;font-size:.8rem;gap:6px;justify-content:center;padding:6px 10px}.wqms-dashboard .header-left h1{font-size:1.6rem;margin-bottom:.25rem}.wqms-dashboard .header-left p{font-size:.9rem}.dashboard-controls,.stats-grid{padding:.75rem}.stats-grid{gap:.5rem;grid-template-columns:1fr}.stat-card{padding:1rem}.stat-card h3{font-size:1.1rem}.stat-card p{font-size:.75rem}.map-container{height:calc(100vh - 500px);margin:0 .25rem .25rem}.time-select{font-size:.75rem;padding:.5rem}.refresh-btn{font-size:.8rem;padding:.5rem .75rem}.modal-content{border-radius:16px;margin:.25rem}.modal-header{padding:1rem}.modal-header h2{font-size:1.1rem}.param-card{padding:.75rem}.param-card h4{font-size:.75rem}.param-value{font-size:1.1rem}}.permission-modal{max-width:960px}.modal-subtitle{color:#4a5568;font-size:12px}.perm-row{align-items:flex-start;display:flex;gap:12px}.perm-column{background:#ffffffe6;border:1px solid #edf2f7;border-radius:8px;padding:12px}.segmented{border:1px solid #cbd5e0;border-radius:8px;display:inline-flex;overflow:hidden}.segment{background:#f7fafc;border:none;color:#4a5568;cursor:pointer;font-size:12px;padding:6px 12px}.segment.active{background:linear-gradient(135deg,#667eea,#764ba2)}.segmented{background:#f3f4f6;border:1px solid #e5e7eb;gap:4px;padding:4px}.segment,.segmented{border-radius:9999px}.segment{background:#0000;color:#374151;font-weight:600;padding:8px 14px;transition:all .2s ease}.segment:hover{background:#fff}.segment.active{background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 6px 16px #2563eb40;color:#fff}.role-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #0000000f;padding:12px}.role-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.count-badge{background:#eef2ff;border:1px solid #c7d2fe;border-radius:9999px;color:#3730a3;font-size:12px;font-weight:700;padding:2px 8px}.role-users{display:flex;flex-wrap:wrap;gap:8px}.user-chip{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:9999px;color:#111827;display:inline-flex;font-weight:600;gap:8px;padding:6px 10px}.user-chip .avatar-circle{font-size:12px;height:22px;width:22px}.field-label{color:#4a5568;font-size:12px;font-weight:600;margin-bottom:6px}.perm-input{margin-bottom:8px;padding:8px 10px}.perm-input,.perm-select{border:1px solid #e2e8f0;border-radius:6px;font-size:12px;width:100%}.perm-select{background:#fff;padding:6px 8px}.radio-group{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.radio-item{align-items:flex-start;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:10px;padding:8px}.radio-title{font-size:13px;font-weight:700}.radio-desc{color:#4a5568;font-size:12px}.helper-text{color:#718096;font-size:12px;margin-top:6px}.badge{background:#edf2f7;border:1px solid #e2e8f0;border-radius:9999px;color:#2d3748;display:inline-block;font-size:11px;padding:2px 8px}.badge.role.viewer{background:#e6fffa;border-color:#b2f5ea;color:#234e52}.badge.role.editor{background:#ebf8ff;border-color:#bee3f8;color:#2a4365}.badge.role.admin{background:#fef3c7;border-color:#fde68a;color:#7c2d12}.drawer{animation:slideInRight .3s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff7;border-left:1px solid #cbd5e099;box-shadow:-24px 0 64px #0000002e;display:flex;flex-direction:column;height:100vh;width:min(560px,92vw)}@keyframes slideInRight{0%{opacity:0;transform:translateX(8px)}to{opacity:1;transform:translateX(0)}}.drawer-header{align-items:center;justify-content:space-between;padding:16px}.drawer-header,.drawer-tabs{border-bottom:1px solid #e2e8f0cc;display:flex}.drawer-tabs{gap:0}.drawer-tabs .tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#4a5568;cursor:pointer;flex:none;font-weight:600;padding:10px 14px}.drawer-tabs .tab.active{border-bottom-color:#667eea;color:#2d3748}.drawer-body{overflow-y:auto}.inline-add{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:1fr 1fr auto auto}.drawer .inline-add .apply-btn:first-child{justify-self:start}.user-picker{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 12px 40px #00000026;display:flex;flex-direction:column;max-height:70vh;overflow:hidden;width:min(520px,92vw)}.picker-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:12px 14px}.picker-title{color:#111827;font-weight:700}.picker-list{overflow-y:auto;padding:8px}.picker-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;gap:10px;margin-bottom:8px;padding:10px 12px;width:100%}.picker-item:hover{background:#f9fafb}.picker-item.active{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.avatar-circle{align-items:center;background:#e5e7eb;border-radius:9999px;color:#111827;display:flex;font-weight:700;height:36px;justify-content:center;width:36px}.picker-text{color:#111827;font-weight:600}.chip{border:1px solid #e5e7eb;border-radius:9999px;display:inline-block;font-size:12px;font-weight:700;padding:2px 10px;text-transform:capitalize}.chip.perm-viewer{background:#f3f4f6;color:#374151}.chip.perm-editor{background:#dbeafe;border-color:#bfdbfe;color:#1e3a8a}.chip.perm-admin{background:#fee2e2;border-color:#fecaca;color:#991b1b}.drawer{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:none;height:auto;max-height:85vh;width:min(760px,92vw)}.drawer-header{background:#fff}.drawer-header,.drawer-tabs{border-bottom:1px solid #e5e7eb}.drawer-tabs .tab{color:#6b7280;padding:10px 12px}.drawer-tabs .tab.active{border-bottom-color:#2563eb;color:#111827}.drawer-body{padding:12px 16px}.perm-column,.perm-input,.perm-select{background:#fff;border:1px solid #e5e7eb}.perm-input,.perm-select{border-radius:6px}.radio-item{background:#fff;border:1px solid #e5e7eb}.badge{border:1px solid #e5e7eb}.badge,.badge.role.viewer{background:#f3f4f6;color:#111827}.badge.role.viewer{border-color:#e5e7eb}.badge.role.admin,.badge.role.editor{background:#f3f4f6;border-color:#e5e7eb;color:#111827}.apply-btn{background:#111827;border:1px solid #111827;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 12px}.apply-btn:hover{background:#374151;border-color:#374151}.apply-btn:disabled{cursor:not-allowed;opacity:.6}.table-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #0000000f;overflow:hidden}.table-wrapper table{width:100%}.table-wrapper thead th{background:#f8fafc;color:#111827;font-size:12px;font-weight:700}.table-wrapper tbody tr:hover{background:#f9fafb}.danger-btn{background:linear-gradient(135deg,#ef4444,#dc2626);border:1px solid #dc2626;border-radius:6px;box-shadow:0 4px 12px #ef444440;color:#fff;cursor:pointer;font-weight:700;padding:6px 10px}.danger-btn:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px)}.danger-btn:disabled{cursor:not-allowed;opacity:.5}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-weight:600;padding:10px 12px}.detail-page{background:linear-gradient(180deg,#fff,#f8fafc);min-height:100vh}.detail-grid{grid-gap:16px;align-items:start;display:grid;gap:16px;grid-template-columns:1.5fr 1fr}.detail-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 6px 18px #0000000a;padding:16px}.detail-card .card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.section-title{color:#111827;font-weight:800}.control-row{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:8px}.chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px}.mini-kpi-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.mini-kpi-card{align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;display:flex;justify-content:space-between;padding:10px 12px}.mini-kpi-title{color:#64748b;font-size:12px;font-weight:600}.mini-kpi-value{color:#0f172a;font-weight:800}.gauge-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.gauge-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:8px}.param-chip-row{display:flex;gap:8px;overflow-x:auto;padding:4px 0 6px}.param-chip{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:9999px;color:#1f2937;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:6px 10px;transition:all .2s ease;white-space:nowrap}.param-chip:hover{background:#f8fafc;border-color:#cbd5e1}.param-chip.active{background:#eef2ff;border-color:#c7d2fe;color:#3730a3}.sticky-side{align-self:start;position:-webkit-sticky;position:sticky;top:72px}.side-stack{display:flex;flex-direction:column;gap:12px}.filter-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.filter-chip{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:9999px;color:#111827;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:4px 8px}.filter-chip.active{background:#eef2ff;border-color:#c7d2fe;color:#3730a3}.neutral-page-bg{background:#f8fafc}.param-standard{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;justify-content:space-between;min-height:68px;padding:10px}.status-chip{align-items:center;border:1px solid #e5e7eb;border-radius:9999px;display:inline-flex;font-size:11px;font-weight:700;gap:6px;padding:2px 8px}.kpi-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.params-grid-detail{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.param-card-detail{align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;justify-content:space-between;padding:10px}.subtle-text{color:#64748b}.muted-text{color:#475569}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}.sticky-side{position:relative;top:0}.gauge-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.side-stack{flex-direction:row;flex-wrap:wrap;gap:12px}.chart-card,.detail-card{padding:14px}}@media (max-width:768px){.detail-grid{gap:12px}.detail-grid,.gauge-grid{grid-template-columns:1fr}.gauge-grid{gap:10px}.mini-kpi-grid{grid-template-columns:1fr 1fr}.side-stack{flex-direction:column;gap:10px}.chart-card,.trend-card{margin-top:8px;padding:10px}.param-chip-row{gap:6px;padding:4px 0}.param-chip{font-size:11px;padding:4px 8px}.status-chip{font-size:10px;padding:2px 6px}.section-title{font-size:1rem}}@media (max-width:480px){.gauge-card{padding:6px}.param-standard{min-height:56px;padding:8px}.mini-kpi-grid{grid-template-columns:1fr}.mini-kpi-card{font-size:12px;padding:8px}.filter-chips{gap:4px}.filter-chip{font-size:11px;padding:3px 6px}.chart-card canvas,.chart-card svg{height:auto!important;width:100%!important}.trend-card{margin-top:6px;padding:6px}}@media (max-height:700px){.sticky-side{max-height:80vh;overflow-y:auto}}@media (max-width:992px){.dashboard-controls,.wqms-dashboard .header-right{flex-wrap:wrap;gap:8px;justify-content:flex-start}.wqms-dashboard .header-right button{flex-basis:calc(50% - 8px);flex-grow:1;flex-shrink:1;min-width:140px}}@media (max-width:600px){.wqms-dashboard .header-right button{flex:1 1 100%;justify-content:center;min-width:100%}}.wqms-toolbar{justify-content:space-between}.wqms-toolbar .toolbar-left,.wqms-toolbar .toolbar-right{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.wqms-toolbar a,.wqms-toolbar button{flex-shrink:0}.param-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}@media (max-width:1024px){.station-layout{grid-template-columns:1fr}.side-panel{margin-top:20px;position:static!important}}@media (max-width:600px){.logout-btn{font-size:12px;padding:4px 8px}}.wqms-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;margin-bottom:10px}.wqms-toolbar .logout-btn,.wqms-toolbar a,.wqms-toolbar button{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:10px;box-shadow:0 2px 8px #ef444440;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:6px;justify-content:center;padding:10px 16px;transition:all .2s ease;white-space:nowrap}.wqms-toolbar .logout-btn svg{height:16px;width:16px}@media (min-width:993px){.wqms-toolbar{justify-content:flex-end}}@media (max-width:992px){.wqms-toolbar{justify-content:center}.wqms-toolbar .logout-btn,.wqms-toolbar a,.wqms-toolbar button{flex-basis:calc(50% - 8px);flex-grow:1;flex-shrink:1;min-width:140px}}@media (max-width:600px){.wqms-toolbar{align-items:stretch;flex-direction:column;gap:6px}.wqms-toolbar .logout-btn,.wqms-toolbar a,.wqms-toolbar button{flex:1 1 100%;font-size:.85rem;justify-content:center;padding:8px 12px;width:100%}}@media (max-width:768px){.gauge-grid{gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}.actions-bar{gap:10px}.actions-group,.btn{gap:8px}.btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 0 #00000005,0 2px 8px #0f172a0a;color:#1f2937;display:inline-flex;font-size:13px;font-weight:600;height:34px;line-height:1;padding:0 12px;transition:transform .06s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.btn:hover{background:#f9fafb;border-color:#dbe2ea;box-shadow:0 2px 10px #0f172a0f}.btn:active{transform:translateY(1px)}.btn-ghost{background:#fff;border-color:#eef2f7;color:#334155}.btn-ghost:hover{background:#f8fafc}.btn svg{height:16px;width:16px}@media (max-width:520px){.actions-bar{justify-content:stretch}.actions-group{flex:1 1 auto;justify-content:flex-end}}.btn[data-accent=danger]{border-color:#fecaca}.btn[data-accent=danger]:hover{background:#fff5f5;border-color:#fca5a5}@media (max-width:380px){.btn span{display:none}.btn{padding:0 10px}}.actions-bar,.wqms-toolbar{overflow:visible}.actions-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}.actions-group{display:flex;gap:10px}.actions-bar .btn,.actions-bar .btn-ghost{align-items:center;border:1px solid #0000000f;border-radius:12px;cursor:pointer;display:inline-flex;font-weight:600;gap:8px;padding:8px 14px;text-decoration:none;transition:box-shadow .12s ease,transform .12s ease,background-color .12s ease;white-space:nowrap}.actions-bar .btn{background:linear-gradient(180deg,#ef4444,#dc2626);box-shadow:0 2px 10px #dc26262e;color:#fff}.actions-bar .btn:hover{box-shadow:0 6px 16px #dc262640;transform:translateY(-1px)}.actions-bar .btn:active{box-shadow:inset 0 2px 6px #00000026;transform:translateY(0)}.actions-bar .btn-ghost{background:#fff;border-color:#e5e7eb;box-shadow:0 1px 4px #0206170f;color:#111827}.actions-bar .btn-ghost:hover{background:#f8fafc;box-shadow:0 4px 12px #0206171a}.actions-bar .btn-ghost:active{box-shadow:inset 0 2px 6px #02061714}.actions-bar .btn svg,.actions-bar .btn-ghost svg{flex:0 0 auto;height:16px;width:16px}.actions-bar .btn span,.actions-bar .btn-ghost span{line-height:1}@media (max-width:640px){.actions-group .btn span{display:none}.actions-bar .btn,.actions-bar .btn-ghost{border-radius:10px;min-width:36px;padding:8px}.actions-bar{gap:8px;justify-content:flex-start}}@media (prefers-reduced-motion:reduce){.actions-bar .btn,.actions-bar .btn-ghost{transition:none}}.react-datepicker-popper{z-index:2200!important}.actions-bar .icon-btn{align-items:center;background:#ef4444;border:1px solid #ef4444;border-radius:0;box-shadow:0 2px 8px #ef444440;color:#fff;display:inline-flex;height:42px;justify-content:center;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;width:42px}.actions-bar .icon-btn:hover{transform:translateY(-1px)}.actions-bar .icon-btn:active{transform:translateY(0)}.actions-bar .icon-btn:focus{box-shadow:0 0 0 3px #ef444440;outline:none}.actions-bar .icon-btn.danger{background:#dc2626;border-color:#dc2626}.leaflet-tooltip.wqi-on-marker{background:#0000!important;border:none!important;box-shadow:none!important;color:#fff!important;font-size:12px!important;font-weight:800!important;margin:0!important;padding:0!important;pointer-events:none!important}.leaflet-tooltip.wqi-on-marker:before{display:none!important}.rlp-marker-wrapper{background:#0000!important;border:none!important}.rlp-marker-pill{align-items:center;border:2px solid #fffffff2;border-radius:10px;box-shadow:0 8px 22px #00000059;color:#fff;display:flex;font-size:13px;font-weight:900;height:32px;justify-content:center;letter-spacing:.2px;min-width:76px;padding:0 10px;white-space:nowrap}.rpc-controlsBlock{margin-bottom:14px}.rpc-controlsBlockTitle{font-weight:800;margin-bottom:8px;opacity:.92}.rpc-controls2col{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.twoy-wrap{background:radial-gradient(1200px 600px at 20% -10%,#a78bfa33,#0000 60%),radial-gradient(1200px 600px at 90% 10%,#60a5fa33,#0000 60%),linear-gradient(180deg,#f5f3ff,#f1f5ff 30%,#eef2ff 60%,#f8fafc);min-height:100dvh;padding:16px}.twoy-toolbar{align-items:center;display:flex;gap:8px;margin-bottom:12px}.twoy-toolbar .btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:9999px;box-shadow:0 2px 10px #0f172a0d;display:inline-flex;gap:6px;padding:8px 12px}.twoy-toolbar .btn-ghost{background:#0000;border-color:#e5e7eb}.twoy-ribbon{align-items:center;color:#0f172a;display:flex;font-size:22px;font-weight:800;gap:8px;margin:8px 0 12px}.twoy-controls{grid-gap:12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fffc;border:1px solid #e5e7eb;border-radius:16px;display:grid;gap:12px;grid-template-columns:repeat(5,minmax(0,1fr));margin-bottom:14px;padding:12px}@media (max-width:900px){.twoy-controls{grid-template-columns:1fr}}.twoy-field label{color:#64748b;display:block;font-size:11px;margin-bottom:4px}.twoy-field input[type=date],.twoy-field select{background:#fff;border:1px solid #e5e7eb;border-radius:12px;color:#0f172a;padding:10px 12px;width:100%}.twoy-card{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fffc;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 15px 50px #0f172a0f,0 3px 10px #0f172a0d;padding:12px}.twoy-chip{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:9999px;color:#334155;display:inline-flex;font-size:12px;gap:6px;padding:6px 10px}:root{--card-bg:#ffffffb3;--card-border:#fff9;--card-shadow:0 10px 30px #203e711f;--chip-bg:linear-gradient(135deg,#eef2ff,#e0e7ff);--chip-text:#3949ab;--text-muted:#6b7280;--table-border:#eef2f7;--row-hover:#f8fafc;--ok:#16a34a;--warn:#f59e0b;--bad:#ef4444}.exceedance-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb3;background:var(--card-bg);border:1px solid #fff9;border:1px solid var(--card-border);border-radius:18px;box-shadow:0 10px 30px #203e711f;box-shadow:var(--card-shadow);padding:18px}.exceedance-toolbar{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px}.ex-chip{align-items:center;background:linear-gradient(135deg,#eef2ff,#e0e7ff);background:var(--chip-bg);border-radius:999px;color:#3949ab;color:var(--chip-text);display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:6px 12px}.ex-helper{color:#6b7280;color:var(--text-muted);font-size:13px}.ex-table-wrap{border:1px solid #eef2f7;border:1px solid var(--table-border);border-radius:12px;overflow:auto}.ex-table{background:#fff;min-width:880px}.ex-table thead th{background:linear-gradient(180deg,#fff 30%,#f8fafc);font-size:13px;font-weight:700;letter-spacing:.02em;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:1}.ex-table tbody td,.ex-table thead th{border-bottom:1px solid #eef2f7;border-bottom:1px solid var(--table-border);padding:12px 14px}.ex-table tbody td{font-size:13.5px;white-space:nowrap}.ex-table tbody tr:nth-child(2n){background:#fcfdff}.ex-table tbody tr:hover{background:#f8fafc;background:var(--row-hover)}.ex-num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;text-align:right}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:700;gap:6px;padding:4px 10px}.badge.ok{background:#ecfdf5;border:1px solid #bbf7d0;color:#16a34a;color:var(--ok)}.badge.warn{background:#fffbeb;border:1px solid #fde68a;color:#f59e0b;color:var(--warn)}.badge.bad{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;color:var(--bad)}.ex-empty{color:#6b7280;color:var(--text-muted);font-weight:600;padding:28px 10px;text-align:center}@media (max-width:768px){.ex-table{min-width:0}.ex-table thead{display:none}.ex-table tbody tr{background:#fff;border:1px solid #eef2f7;border:1px solid var(--table-border);border-radius:12px;display:block;margin:10px 8px;overflow:hidden}.ex-table tbody td{border-bottom:1px dashed #eef2f7;border-bottom:1px dashed var(--table-border);display:flex;justify-content:space-between;white-space:normal}.ex-table tbody td:last-child{border-bottom:none}.ex-label{color:#64748b;font-weight:600;margin-right:16px}.ex-num{text-align:left}}.ex-table{border-collapse:initial;border-spacing:0;table-layout:auto;width:100%}.ex-table td,.ex-table th{padding:12px 16px;text-align:left;vertical-align:middle;white-space:nowrap}.ex-table .ex-num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;text-align:right}.ex-table thead th{background:#fff;border-bottom:1px solid #e5e7eb;color:#0f172a;font-weight:600}@media (max-width:900px){.ex-table{table-layout:fixed}.ex-table td,.ex-table th{white-space:normal}}.ex-pager{align-items:center;border-top:1px solid #0000000f;display:flex;gap:12px;justify-content:space-between;padding:12px 8px}.ex-pager-info{color:#64748b}.ex-pager-buttons{align-items:center;display:flex;gap:8px}.ex-page-chip{background:#6366f114;border:1px solid #4f46e526;border-radius:999px;color:#4f46e5;font-weight:600;padding:4px 10px}:root{--bg-1:#0b1220;--bg-2:#0c1a2f;--bg-3:#1b1030;--panel:#ffffff0f;--panel-2:#ffffff0a;--stroke:#ffffff1f;--stroke-2:#ffffff24;--text:#e5e7eb;--muted:#e5e7ebb8;--focus:#6366f1a6;--focusRing:#6366f12e;--radius:16px;--radius-sm:12px}.rpc-page{background:radial-gradient(900px 500px at 10% 10%,#6366f147,#0000 60%),radial-gradient(900px 500px at 90% 20%,#ec489938,#0000 60%),linear-gradient(135deg,#0b1220,#0c1a2f 45%,#1b1030);background:radial-gradient(900px 500px at 10% 10%,#6366f147,#0000 60%),radial-gradient(900px 500px at 90% 20%,#ec489938,#0000 60%),linear-gradient(135deg,var(--bg-1) 0,var(--bg-2) 45%,var(--bg-3) 100%);color:#e5e7eb;color:var(--text);min-height:100vh;padding:18px 18px 40px}.rpc-wrap{margin:0 auto;max-width:1400px}.rpc-header{align-items:flex-end;display:flex;gap:14px;justify-content:space-between;margin-bottom:14px}.rpc-title{background:linear-gradient(135deg,#93c5fd,#f0abfc 50%,#fda4af);-webkit-background-clip:text;background-clip:text;color:#0000;font-size:28px;font-weight:900;letter-spacing:.2px;line-height:1.1;margin:0}.rpc-subtitle{color:#e5e7ebb8;color:var(--muted);font-size:13px;margin:6px 0 0}.rpc-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0f;background:var(--panel);border:1px solid #ffffff1f;border:1px solid var(--stroke);border-radius:16px;border-radius:var(--radius);box-shadow:0 18px 60px #00000059}.rpc-controls{margin-bottom:14px;padding:14px}.rpc-controlsGrid{grid-gap:18px;align-items:start;display:grid;gap:18px;grid-template-columns:minmax(380px,520px) 1fr}.rpc-leftControls{display:flex;flex-direction:column;gap:10px}.rpc-leftGrid{grid-gap:12px;align-items:end;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.rpc-leftActions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start;margin-top:10px}.rpc-rightControls{display:flex;flex-direction:column;gap:10px}.rpc-rightGrid{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:1fr}.rpc-rightControls--stations .rpc-rightGrid{grid-template-columns:280px 1fr 170px}.rpc-rightGrid .rpc-multi{min-height:170px}.rpc-rightControls--stations .rpc-multi{min-height:190px}.rpc-field label{color:#e5e7ebe0;display:block;font-size:12px;font-weight:800;margin:0 0 6px}.rpc-input,.rpc-multi,.rpc-select{background:#0f172a8c;border:1px solid #ffffff24;border:1px solid var(--stroke-2);border-radius:12px;border-radius:var(--radius-sm);box-sizing:border-box;color:#e5e7eb;color:var(--text);outline:none;padding:10px 12px;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;width:100%}.rpc-select{height:42px;padding-right:34px}.rpc-input:focus,.rpc-multi:focus,.rpc-select:focus{border-color:#6366f1a6;border-color:var(--focus);box-shadow:0 0 0 4px #6366f12e;box-shadow:0 0 0 4px var(--focusRing)}.rpc-multi{overflow:auto;padding:8px 10px}.rpc-multi option{line-height:1.2;padding:7px 10px}.rpc-hint{color:#e5e7eb9e;font-size:11px;margin-top:6px}.rpc-btn{background:linear-gradient(135deg,#6366f1f2,#ec4899d9);border:1px solid #ffffff2e;border-radius:12px;border-radius:var(--radius-sm);box-shadow:0 10px 28px #00000059;color:#fff;cursor:pointer;font-weight:900;height:42px;padding:0 14px;transition:transform .15s ease,filter .15s ease;-webkit-user-select:none;user-select:none}.rpc-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}.rpc-btn:active{filter:brightness(.98);transform:translateY(0)}.rpc-btn:disabled{cursor:not-allowed;filter:grayscale(.2);opacity:.65}.rpc-btn-secondary{background:#ffffff14;border:1px solid #ffffff2e}.rpc-pill{align-items:center;background:#ffffff0f;border:1px solid #ffffff24;border-radius:999px;color:#e5e7ebe6;display:inline-flex;font-size:12px;gap:8px;padding:8px 10px}.rpc-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.rpc-alert{background:#ef44441f;border:1px solid #ef444459;border-radius:12px;border-radius:var(--radius-sm);color:#fecaca;font-size:13px;margin-top:10px;padding:10px 12px}.rpc-chart{margin-top:12px;padding:12px}.rpc-chartHeader{align-items:center;display:flex;gap:12px;justify-content:space-between;margin:0 0 10px;padding:0 2px}.rpc-chartTitle{color:#e5e7ebeb;font-size:13px;font-weight:900}.rpc-chartBox{background:linear-gradient(135deg,#ffffff0f,#ffffff0a);border:1px solid #ffffff24;border-radius:16px;border-radius:var(--radius);box-shadow:inset 0 1px 0 #ffffff14;height:440px;overflow:hidden;padding:10px}.rpc-empty{background:#ffffff0a;border:1px dashed #ffffff2e;border-radius:16px;border-radius:var(--radius);color:#e5e7ebb8;display:grid;height:440px;padding:18px;place-items:center;text-align:center}.rpc-empty strong{color:#e5e7ebeb}.rpc-legend{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;padding:6px 8px 0}.rpc-legendItem{align-items:center;display:inline-flex;font-size:12px;font-weight:900;gap:8px;opacity:.95}.rpc-legendItem:before{background:currentColor;border-radius:999px;box-shadow:0 0 0 2px #ffffff2e;content:"";height:10px;width:10px}.rpc-tooltip{background:#0a0c14f0;border:1px solid #ffffff1f;border-radius:10px;box-shadow:0 14px 40px #00000059;color:#fffffff2;min-width:220px;padding:10px 12px}.rpc-tooltipDate{color:#ffffffeb;font-size:13px;font-weight:900;margin-bottom:6px}.rpc-tooltipRow{align-items:center;display:flex;font-size:12px;font-weight:800;gap:14px;justify-content:space-between;padding:2px 0}.rpc-tooltipName{opacity:.95;white-space:nowrap}.rpc-tooltipVal{font-feature-settings:"tnum";color:#fffffffa;font-variant-numeric:tabular-nums;font-weight:900;white-space:nowrap}.rpc-summary{margin-top:14px;padding:12px}.rpc-summary h3{color:#e5e7ebf2;font-size:14px;font-weight:900;margin:0 0 10px}.rpc-tableWrap{border:1px solid #ffffff1f;border-radius:14px;overflow:auto}.rpc-table{background:#0f172a59;border-collapse:collapse;min-width:640px;width:100%}.rpc-table th{background:#020617bf;border-bottom:1px solid #ffffff1f;color:#e5e7ebeb;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:2}.rpc-table td,.rpc-table th{font-size:12px;padding:10px 12px}.rpc-table td{border-bottom:1px solid #ffffff14;color:#e5e7ebe0}.rpc-table tr:nth-child(2n) td{background:#ffffff08}.rpc-tableWrap::-webkit-scrollbar{height:10px;width:10px}.rpc-tableWrap::-webkit-scrollbar-thumb{background:#ffffff29;background-clip:padding-box;border:2px solid #0000;border-radius:999px}@media (max-width:1100px){.rpc-controlsGrid{grid-template-columns:1fr}.rpc-leftGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.rpc-rightControls--stations .rpc-rightGrid{grid-template-columns:1fr}}@media (max-width:620px){.rpc-page{padding:14px 12px 28px}.rpc-title{font-size:22px}.rpc-leftGrid{grid-template-columns:1fr}}.rpc-controls--vvr .rpc-vvrGrid{grid-gap:16px;align-items:start;display:grid;gap:16px;grid-template-columns:520px 1fr}.rpc-controls--vvr .rpc-vvrLeftGrid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.rpc-controls--vvr .rpc-vvrSpan2{grid-column:1/-1}.rpc-controls--vvr .rpc-vvrActions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start;margin-top:12px}.rpc-controls--vvr .rpc-multi--rivers{max-height:180px;min-height:140px}.rpc-controls--vvr .rpc-multi--params{max-height:420px;min-height:320px}@media (max-width:1100px){.rpc-controls--vvr .rpc-vvrGrid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.d9f72a2d.css.map*/