code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.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}}.navbar-container{background-color:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;height:64px;justify-content:space-between;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-container,.navbar-left{align-items:center;display:flex}.navbar-left{gap:16px}.icon-btn{border-radius:8px;color:#64748b;display:flex;padding:8px;position:relative;transition:all .2s}.icon-btn:hover{background-color:#f1f5f9;color:#0f172a}.navbar-brand{gap:10px;text-decoration:none}.brand-logo-bg,.navbar-brand{align-items:center;display:flex}.brand-logo-bg{height:32px;justify-content:center;width:32px}.brand-logo-bg img{height:100%;object-fit:contain;width:100%}.brand-text{color:#0f172a;font-size:20px;font-weight:700;letter-spacing:-.5px}.navbar-center{display:flex;flex:1 1;gap:8px;justify-content:center}.nav-link{align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;text-decoration:none;transition:all .2s}.nav-link.active,.nav-link:hover{background-color:#f8fafc;color:#4f46e5}.nav-link.logout-btn{color:#ef4444}.nav-link.logout-btn:hover{background-color:#fef2f2}.navbar-right{align-items:center;display:flex;gap:16px}.user-profile-pill{align-items:center;border:1px solid #e2e8f0;border-radius:24px;cursor:pointer;display:flex;gap:10px;padding:4px 4px 4px 12px;position:relative;transition:all .2s}.user-profile-pill:hover{background-color:#f8fafc;border-color:#cbd5e1}.user-info{line-height:1.1;text-align:right}.user-greeting{color:#94a3b8;font-size:10px;font-weight:600;text-transform:uppercase}.user-name{color:#334155;font-size:13px}.user-avatar{align-items:center;background-color:#4f46e5;color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.profile-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001a;margin-top:8px;opacity:0;padding:4px;position:absolute;right:0;top:100%;transform:translateY(10px);transition:all .2s;visibility:hidden;width:160px;z-index:1001}.user-profile-pill:hover .profile-dropdown{opacity:1;transform:translateY(0);visibility:visible}.dropdown-item{align-items:center;background:#0000;border:none;border-radius:4px;color:#475569;cursor:pointer;display:flex;font-size:13px;gap:10px;padding:8px 12px;text-align:left;text-decoration:none;width:100%}.dropdown-item:hover{background-color:#f1f5f9;color:#0f172a}.dropdown-item.text-red{color:#ef4444}.dropdown-item.text-red:hover{background-color:#fef2f2}.mobile-menu-btn{display:none}.mobile-side-menu{background-color:#fff;box-shadow:-4px 0 15px #0000001a;display:flex;flex-direction:column;height:100vh;position:fixed;right:-280px;top:0;transition:right .3s cubic-bezier(.4,0,.2,1);width:280px;z-index:1100}.mobile-side-menu.open{right:0}.mobile-menu-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;height:100vh;left:0;opacity:0;position:fixed;top:0;transition:opacity .3s;visibility:hidden;width:100%;z-index:1050}.mobile-menu-overlay.open{opacity:1;visibility:visible}.mobile-menu-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;height:64px;justify-content:space-between;padding:0 20px}.mobile-menu-content{flex:1 1;overflow-y:auto;padding:20px}.mobile-user-card{align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:12px;margin-bottom:20px;padding:12px}.user-avatar.large{font-size:16px;height:40px;width:40px}.mobile-nav-links{display:flex;flex-direction:column;gap:4px}.mobile-nav-links .nav-link{font-size:15px;justify-content:flex-start;padding:12px;width:100%}.mobile-divider{background-color:#e2e8f0;height:1px;margin:10px 0}.notification-bell-container{align-items:center;display:flex;position:relative}.bell-btn.shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}.notification-badge-count{align-items:center;background:#ef4444;border:2px solid #fff;border-radius:10px;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;min-width:16px;position:absolute;right:4px;top:4px}.notification-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 25px #0000001a;opacity:0;position:absolute;right:-60px;top:120%;transform:translateY(10px);transition:all .2s ease-in-out;visibility:hidden;width:340px;z-index:1002}.notification-dropdown.show{opacity:1;transform:translateY(0);visibility:visible}.notification-header{background:#f8fafc;border-bottom:1px solid #f1f5f9;border-radius:12px 12px 0 0;padding:12px 16px}.notification-header h4{color:#334155;font-size:14px;font-weight:600;margin:0}.mark-read-text{background:#e0e7ff;border-radius:10px;color:#4338ca;font-size:11px;font-weight:600;padding:2px 8px}.notification-item{border-bottom:1px solid #f1f5f9;display:flex;gap:12px;padding:12px 16px;transition:background .2s}.notification-item:hover{background:#f8fafc}.notification-icon{align-items:center;background:#f1f5f9;border-radius:8px;color:#64748b;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.notification-content{flex:1 1}.notification-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#334155;display:-webkit-box;font-size:13px;line-height:1.4;margin:0 0 4px;overflow:hidden}.notification-time{color:#94a3b8;font-size:11px}.notification-footer{border-top:1px solid #f1f5f9;padding:10px}.notification-footer a{color:#4f46e5;font-size:12px;font-weight:600;text-decoration:none}.notification-empty{color:#94a3b8;font-size:14px;padding:30px;text-align:center}@media screen and (max-width:1024px){.desktop-nav,.desktop-profile{display:none}.mobile-menu-btn{display:flex}.notification-dropdown{right:-50px}}@media screen and (max-width:768px){.navbar-container{height:60px;padding:0 16px}.brand-text{font-size:18px}.brand-logo-bg{height:28px;width:28px}.notification-dropdown{border:none;border-bottom:1px solid #e2e8f0;border-radius:0;box-shadow:0 4px 10px #0000001a;left:0;position:fixed;right:0;top:60px;width:100%}}.notification-item.unread-bg{background-color:#eff6ff}.notification-item.unread-bg:hover{background-color:#dbeafe}.notification-list{max-height:350px;overflow-y:auto}.notification-list::-webkit-scrollbar{width:5px}.notification-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.credit-display-pill{align-items:center;background:#ffffff14;border:1.5px solid #ffd70066;border-radius:50px;box-shadow:0 0 10px #ffd7001a;cursor:pointer;display:flex;margin-right:18px;padding:6px 14px;transition:all .3s cubic-bezier(.4,0,.2,1)}.credit-display-pill:hover{background:#ffd70026;border-color:gold;box-shadow:0 0 15px #ffd70040;transform:translateY(-1px)}.coin-wrapper{align-items:center;display:flex;justify-content:center;margin-right:8px}.golden-coin-icon{animation:coin-rotate 4s linear infinite;color:gold;filter:drop-shadow(0 0 4px rgba(255,215,0,.8))}.credit-amount{color:#080505;font-family:Inter,sans-serif;font-size:16px;font-weight:800;letter-spacing:.5px}@keyframes coin-rotate{0%{transform:rotateY(0deg)}20%{transform:rotateY(1turn)}to{transform:rotateY(1turn)}}.shake{animation:shake .2s ease-in-out infinite}@media (max-width:768px){.credit-display-pill{display:none}}.card-container{align-items:center;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:40px 20px;position:relative}.card-container:before{animation:backgroundFloat 20s ease-in-out infinite;background-image:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff14 0,#0000 50%),radial-gradient(circle at 40% 20%,#ffffff0f 0,#0000 50%);content:"";height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;width:200%}@keyframes backgroundFloat{0%,to{transform:translate(0) rotate(0deg)}50%{transform:translate(30px,30px) rotate(5deg)}}.card-container:after{animation:floatShape 15s ease-in-out infinite;background:#ffffff0d;border-radius:50%;content:"";height:300px;position:absolute;right:-100px;top:-100px;width:300px}@keyframes floatShape{0%,to{transform:translate(0)}50%{transform:translate(-50px,50px)}}.auth-card{animation:cardSlideUp .6s cubic-bezier(.68,-.55,.265,1.55);background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;max-width:480px;overflow:hidden;padding:0;position:relative;width:100%}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-card:before{background:linear-gradient(135deg,#667eea,#764ba2);content:"";display:block;height:120px;position:relative}.auth-card>h2{color:#1e293b;font-size:32px;font-weight:800;letter-spacing:.5px;margin:0;padding:30px 40px 20px;position:relative;text-align:center}.auth-card>h2:after{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;bottom:0;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.message{animation:messageSlideIn .4s ease-out;border-radius:12px;font-size:14px;gap:10px;margin:0 40px 20px;padding:14px 20px}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;color:#065f46}.message.success:before{content:"✓";font-size:18px;font-weight:700}.message.error{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444}.message.error:before{content:"✕";font-size:18px;font-weight:700}.auth-card form{display:flex;flex-direction:column;gap:24px;padding:0 40px 30px}.form-group label{font-weight:700;letter-spacing:.5px;margin-left:4px}.form-group input{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;color:#1e293b;font-size:15px;font-weight:500;padding:16px 18px;transition:all .3s ease}.form-group input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none;transform:translateY(-2px)}.form-group input:hover{background:#fff;border-color:#cbd5e1}.form-group input::placeholder{color:#94a3b8}.btn-primary{border-radius:12px;box-shadow:0 4px 15px #667eea66;font-size:16px;font-weight:700;letter-spacing:1px;overflow:hidden;padding:16px 40px;position:relative;text-transform:uppercase;transition:all .3s ease}.btn-primary:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn-primary:hover:before{height:300px;width:300px}.btn-primary:hover{box-shadow:0 6px 20px #667eea80;transform:translateY(-3px)}.btn-primary:active{transform:translateY(-1px)}.auth-card>p{border-top:1px solid #e2e8f0;color:#64748b;font-size:14px;font-weight:500;margin:0;padding:20px 40px 30px;text-align:center}.auth-card>p a{color:#667eea;font-weight:700;position:relative;text-decoration:none;transition:all .3s ease}.auth-card>p a:after{background:#667eea;bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.auth-card>p a:hover:after{width:100%}.auth-card>p a:hover{color:#764ba2}.card-container .auth-card:before{background:linear-gradient(135deg,#667eea,#764ba2)}.auth-logo,.card-container .auth-card:before{align-items:center;display:flex;justify-content:center}.auth-logo{background:#fff;border-radius:50%;box-shadow:0 8px 24px #0003;height:80px;left:50%;position:absolute;top:30px;transform:translateX(-50%);width:80px;z-index:10}.auth-logo img{height:50px;width:50px}@media (max-width:768px){.card-container{padding:30px 20px}.auth-card{border-radius:20px;max-width:450px}.auth-card:before{height:100px}.auth-card>h2{font-size:28px;padding:24px 30px 16px}.auth-card form{gap:20px;padding:0 30px 24px}.form-group input{font-size:14px;padding:14px 16px}.btn-primary{font-size:15px;padding:14px 36px}.message{font-size:13px;margin:0 30px 16px}.auth-card>p{font-size:13px;padding:16px 30px 24px}}@media (max-width:480px){.card-container{padding:20px 15px}.auth-card{border-radius:16px;max-width:100%}.auth-card:before{height:80px}.auth-card>h2{font-size:24px;padding:20px 24px 14px}.auth-card form{gap:18px;padding:0 24px 20px}.form-group label{font-size:12px}.form-group input{font-size:14px;padding:12px 14px}.btn-primary{font-size:14px;padding:12px 32px}.message{font-size:12px;margin:0 24px 14px;padding:12px 16px}.auth-card>p{font-size:12px;padding:14px 24px 20px}.card-container:after{height:200px;width:200px}}@media (max-width:360px){.card-container{padding:15px 10px}.auth-card{border-radius:12px}.auth-card:before{height:70px}.auth-card>h2{font-size:22px;padding:16px 20px 12px}.auth-card form{gap:16px;padding:0 20px 16px}.form-group input{font-size:13px;padding:10px 12px}.btn-primary{font-size:13px;padding:10px 28px}.message{margin:0 20px 12px;padding:10px 14px}.auth-card>p{padding:12px 20px 16px}}@media (max-height:600px) and (orientation:landscape){.card-container{padding:20px}.auth-card{max-width:600px}.auth-card:before{height:60px}.auth-card>h2{padding:16px 30px 12px}.auth-card form{gap:16px;padding:0 30px 20px}.form-group input{padding:10px 14px}.btn-primary{padding:10px 32px}}@media print{.card-container{background:#fff;padding:0}.auth-card{border:1px solid #ddd;box-shadow:none}.card-container:after,.card-container:before{display:none}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){.auth-card{border:2px solid #000}.form-group input{border:2px solid}.btn-primary{border:2px solid #fff}}.auth-card>p a:focus-visible,.btn-primary:focus-visible,.form-group input:focus-visible{outline:3px solid #667eea;outline-offset:3px}.btn-primary:disabled{background:linear-gradient(135deg,#94a3b8,#64748b)}.btn-primary.loading{pointer-events:none}.btn-primary.loading:after{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:16px;position:absolute;right:20px;top:50%;transform:translateY(-50%);width:16px}.account-settings-wrapper{background-color:#f4f7fe;display:flex;font-family:Poppins,sans-serif;min-height:100vh}.settings-container{display:flex;width:100%}.settings-sidebar{background:#1e222d;color:#fff;height:100vh;position:fixed;transition:.3s ease;width:280px;z-index:100}.sidebar-brand{border-bottom:1px solid #ffffff1a;padding:25px}.sidebar-brand h2{font-size:1.5rem;margin:0}.sidebar-menu{padding:10px 0}.menu-item{align-items:center;background:none;border:none;color:#b5b5c3;cursor:pointer;display:flex;padding:15px 25px;text-align:left;width:100%}.menu-item.active{background:#ffffff0d;border-right:4px solid #f84f6a;color:#fff}.menu-item .icon{color:#f84f6a;margin-right:15px}.settings-content{margin-left:280px;padding:30px;width:100%}.content-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000000d;padding:25px}.page-header{justify-content:space-between;margin-bottom:25px}.grid-2{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.input-group{margin-bottom:15px}.input-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.input-field{border:1px solid #e1e1e1;outline:none;padding:12px}.save-btn{border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;margin-top:20px;padding:12px 30px}.mobile-nav-header{align-items:center;background:#1e222d;color:#fff;display:none;justify-content:space-between;padding:15px}.close-sidebar{background:none;border:none;color:#fff;display:none}@media (max-width:992px){.settings-sidebar{left:-280px}.sidebar-open .settings-sidebar{left:0}.settings-content{margin-left:0;padding:15px}.mobile-nav-header{display:flex}.close-sidebar{display:block}.grid-2{grid-template-columns:1fr}}.content-top-bar{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:0 5px}.tab-title{color:#1e222d;font-size:22px;font-weight:700}.sound-toggle-badge{align-items:center;border-radius:50px;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:8px;padding:8px 15px;transition:all .3s ease;-webkit-user-select:none;user-select:none}.sound-toggle-badge.on{background:#10b9811a;border:1px solid #10b98133;color:#10b981}.sound-toggle-badge.off{background:#f43f5e1a;border:1px solid #f43f5e33;color:#f43f5e}.sound-toggle-badge:hover{box-shadow:0 4px 10px #0000000d;transform:translateY(-2px)}.sound-toggle-badge:active{transform:scale(.95)}.status-popup-wrapper{display:flex;flex-direction:column;gap:10px;pointer-events:none;position:fixed;right:20px;top:80px;z-index:10000}.status-popup-container{background:#fff;border:1px solid #0000000d;border-radius:10px;box-shadow:0 10px 30px #0000001f;max-width:400px;min-width:300px;overflow:hidden;pointer-events:auto;position:relative}.status-content{align-items:center;display:flex;gap:12px;padding:14px 18px}.stat-icon{height:24px;width:24px}.stat-icon.success{color:#10b981}.stat-icon.error{color:#ef4444}.stat-icon.warning{color:#f59e0b}.stat-icon.info{color:#3b82f6}.status-text{flex-grow:1}.status-title{display:block;font-size:11px;font-weight:800;letter-spacing:.5px;opacity:.8}.status-message{color:#374151;font-size:13.5px;font-weight:500;margin:0}.status-close-btn{background:none;border:none;color:#9ca3af;cursor:pointer;transition:.2s}.status-close-btn:hover{color:#333}.status-progress-bar{height:3px}.success .status-progress-bar{background:#10b981}.success.status-popup-container{border-left:4px solid #10b981}.error .status-progress-bar{background:#ef4444}.error.status-popup-container{border-left:4px solid #ef4444}.warning .status-progress-bar{background:#f59e0b}.warning.status-popup-container{border-left:4px solid #f59e0b}.info .status-progress-bar{background:#3b82f6}.info.status-popup-container{border-left:4px solid #3b82f6}.credits-update.success{border-left:4px solid gold}.status-popup-container.error{animation:shake .5s ease-in-out;background:linear-gradient(135deg,#f44,#c00);border-left:4px solid red}.status-popup-container.error .status-icon-box{animation:pulse 1s infinite}.leaflet-draw-section{position:relative}.leaflet-draw-toolbar{margin-top:12px}.leaflet-draw-toolbar-top{margin-top:0}.leaflet-draw-toolbar-notop a:first-child{border-top-right-radius:0}.leaflet-draw-toolbar-nobottom a:last-child{border-bottom-right-radius:0}.leaflet-draw-toolbar a{background-clip:padding-box;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAASwAAAAeCAYAAACWuCNnAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAG7AAABuwBHnU4NQAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAbvSURBVHic7dtdbBxXFQfw/9nZ3SRKwAP7UFFUQOoHqGnUoEAoNghX9tyxVcpD1X0J+WgiUQmpfUB5ACSgG1qJIKASqBIUIauqAbWseIlqb+bOWHVR6y0FKZBEqdIUQROIREGRx3FFvR/38ODZst3a3nE8Ywfv+T2t7hzdM3fle/bOnWtACCGEEEIIIYQQQgghhBBCCCGEEEIIIcRa0EbfgBDdFItFKwzDAa3175LuWylVAvBIR/MxrXUp6Vxx9dp4VyObVEdKKW591lonXgiVUg6AHzPzk9ls9meVSmUh6RzXkz179uQKhcIgM+8CACI6U6vVnp+enm6knXt4ePiuTCbzWQAwxlSDIHg57ZwroDAMnwKwz3XdBzzPG08hxzsTNprQG2lTjtd13WFmfghAP4A+AJcATFiW9YNKpfL3uP0kUliiX4SG1pqUUpx0wXJd9/PMXAGwPWq6yMyPz8/P/7xarf4nyVwt7QV4JWkU52i8YwBu6bh0wRhzJAiCF5POCQCDg4N2Pp//NYDRjkuTxph9QRCESeYrFov5ubm5R5n5AIAPtV1aYOb7BgYGTpZKJeO67lFmPsbM9/i+/8Ja8y6zylhOYquPXhsvAJRKpczMzMwTAIaJ6LFGo+HNzs5eKRQKNxPRAWb+CoAjWuvn4vS35skWFasxAAdbbUlOYqVUPwAPwI4lLr8J4KeWZT1eqVTmksoZ5d2QghUVKx/AlmVCFph5yPf9l5LMCwBKqUksFqszRHQcAJj5GwB2MfOE7/tfTDKf4zjHiejrAE4CuNhqZ+bf2rY9FYbhGBH92/O8o47j3Oj7/uUk86+3XhsvACilHmPmgW3btn3pxIkTVzuvj4yMfNoY85wxZiQIglPd+lvTZIuq5xiAQwCe6evr218ul5tr6bNd9GiiAbyvS+hFrfVHk8oLbEzBih4Dz+G9K6t3IaLXFhYWdib5eBh911UA8wBu1lq/CQBDQ0M3WJb1OoAdRPQZz/NeSSqnUuofAKpa6/vb26MfwacA7AdwFcCdWuu/JpU3yl1C91VHoquNXhvvyMjIx4wxr1iWtbNSqfxruTjHcR4AcMj3/bu79XnNe1hpFyvHcXYT0QS6FysASHR1tVEKhcIguhQrAGDm23K53BcATCWV27KsAWYGgPOtYgUAU1NT/1RKnQewxxjzOQCJFSwANwI4297QtmLfD+AtZr43m83OJ5iz3bGU+l1OT43XGFNk5mdXKlYAYNv2eBiG31dK3aS1vrRSbOZabqRYLFppFisAIKJxAB+MGf56krk30O64gZlMJnZsHMxsoo8fHxoauqHVHn3+BAAQUaxV57Xq2F54i5nvIaJXm81mYoX5etID491JRH/sFlQul5tEdMoYc3u32FUXrLYvObViBQDM/MQqwi8knX8jEJHpHrXIGJNo8WDm1spph2VZgeu6+5RSX7YsK8D/Xnb8Psmcnebm5h7G4uS9ysxutOH8VQC70sy7UTb7eImImTnWlgkzUyaT6fr3v6qC1fGL8EytVjuQRrECANu2fwHg1TixzPyXNO5hvTHz6VWE/znJ3L7vzxBRa9PzDmb+FYBfArgjajvd39+f9vGGKwACZh5te6mwmc8KburxMvO5TCbzqW5xxWLRArDbsqyu8z32HtZSxSrNM0Hlcrnpum6JmZ+NEb4pHglrtdrz+Xz+AoBbu4Ser9fra37d3YEBfBvAkq+XmfmbpVIp9grwWnie9zSAp9PMcT3Z7OPNZrO/aTQaf1BKfbd9X7RTGIaHmPlcnPNYsVZYSikOw7AB4CAzj/f19e1fjwOMnueVEeMxJJfLbYqCNT093TDGHAGw0qHYBQBH0vj+Pc+bYOb3HFRk5nHf9yeTzgfgMhF9uEvMTQD+71/vR3pqvJOTk28AeBJAeXR09P1LxbiuuxfA9wB8LU6fsVdYrUOhtm0fTusxcAlMRN+KziUt5SqAM3v37r00OZnGfFp/QRC86DjOUCaTGWPm2zoun8fiIbuZtPLX6/UH8/n8rQDuippertfrD6aRKyqOR5VS81ji8Z+IbmfmgwB+mEb+9dZr4wWA/v7+R6rV6k+azeYpx3EezeVyJ7dv335lfn7+lkajcZCZDzPzYd/3/xSnv9gFq3UuaR2LFQDA87xAKVUB8BEAZ6N9nrNEdEZr/TcArLVOPG8aJ9jj8n3/pcHBwZ1btmx5519zmPl0vV5/Ie2V7fT09Nujo6Nus9kcA4CtW7ce1lq/nUYu27a/Mzs7CyI6gMVX/u/CzJeZ+Ue2bcc9pb1aXc8lJZms18YLANE2wkOu694N4OFGo3E8DMMPAHiDiCaY+ZOb4YCsEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhEjYfwGO+b5dFNs4OgAAAABJRU5ErkJggg==);background-image:linear-gradient(#0000,#0000),url(/static/media/spritesheet.a4e0eb7ad904a4858361.svg);background-repeat:no-repeat;background-size:300px 30px}.leaflet-retina .leaflet-draw-toolbar a{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAlgAAAA8CAYAAAC6nMS5AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAN1wAADdcBQiibeAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAA16SURBVHic7d1/jBxneQfw7zNzvotdn+9sVQkxoRKoammBqqpbk6uT5mLfvHPn42yn1VFRVCEhoFH5IYpoSaUCKi1NcGkcfrbCVRFKEwG2aHLn83pmLvY2CTqT1AmCOBE0EOT4B0nBPw/snb2dp3/sLr6s77i923dud/a+H8ny7tzMo8f3eud99p133gGIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiFYGaXYCRETUPMYYrWe/MAzZX2QQ27d5OpqdABFROxgZGVlz5cqVrzuOc18QBJPNzofsYvvSYrVcgTVftZ2l6npgYODXHMc5oKoHHcfZHQTB2WbnRETpGRkZWVMoFA6IyO2qutX3/R1Z64TnO8fWOwLSzti+mSKDg4M3l0qlnSJyG4CbAFwP4ByAlwE8paoPX3fddcH4+PjP00yk5QqsrDPGvAZAHsBrReRNqvpeY8x/iMg9QRCcaXJ6ZIHv+xtUdReAHQBej/IHGABOAnhORMY6OjoempiYONe0JC3zPM84jjOqqrfi6r/3RQCPAdgXhmHUvOyaa3R01L1w4cJBALdVNq1W1THP87woir7ZzNyocWzf7PA8b4uI7E6S5A9Frqknb6j8eZOIvKNQKPzU9/1/dhznvlwuV0gjn5YbFapW09Vqu/Z9K9u2bdsNruvmUe50axUAfMV13X/I5XInlzcze2x/28lCu1b19fWt7u7u/hCAvwGwboHdL6jq7unp6T1TU1OXlyG9VAwODv5mkiR7Ady6wK6Plkqldz/yyCPfX468bBkaGuqamZm5E8DbReQNANYscMiLIrI1CILnZ280xrwHwL+hck4VkacBDLTS6HVaIxWt/Blm+zauldu3atOmTas2bNjwWRG5s7LplKp+VUQOuq77/bVr17589uzZ9SKy0XGcAVUdFZE/qOx7zHXdXWn0yy31i6sMw/4MyF6BZYy5XlWPiMhvL7BrrKpfcxznE7Uf4ixYqQWW53kbATw060NZr28nSbJzcnLyRBp5pcnzvNtE5CEAvXUecg7ArjAMH00xLWuGhoZuKpVKEwB+p85DXnRd9/ZcLvcDAOjv778un88XAChwtRMWkW+jxTpfYOV1wGxfO1q1fav6+vpWr1u3blxVtwH4uar+/fT09OcW+mJrjBkBcC+AXwdwBoAJw/AZm7m1zC+uUlyNA9g6189buZH7+/t/tbOz8wiANy7isKKqftV13U8eOnToe2nlZttKLLAqJ+qjAF69xBAnZ2Zmbj58+PApm3mlqTJydRTXFldHAUxVXvcBuLnm5+dU9c1RFP1v2jk2YmhoqKtUKj2B+jvfE0mS3D45OflD4OqcHADPh2H4F6h0wp7nva1YLOby+fz5dDKnerB9Vwzxff8BVX0bgFMAdoZheKzeg4eHh9cXi8WvAfAAvOC67ptzudz/WUvOVqBGVO7OmBCR/vn2adWOuL+/v7ezs3MSwKYlhkgAHBSRjwdB8JTF1FKx0gqsymXBxwH8XoOh/ieO41vz+fwVG3mlzRjzKF55WfA8gD8LwzA3ez/P87aLyIMAeqrbVDUfRdHty5Pp0hhjPgDgM9X3qnq/iNwPYM5RCdd1T1RPvLM63+q/ce/sTpiaj+27Mvi+f6eq/iuAi67r9uVyuWcXG6NSjB8B0KeqE1EUvcVWfk3v3OYZuXosjuPt+Xx+ull51WNgYKBHRKIlXDaaS6Kq+6Mo+lMLsVKz0gosz/M+KiKfsBTub8MwvMdSrNQYYzwAYc3m7bXFVZXv+8OqemD2NlUdiKLokbRybJQx5lsANlfefi4Mww/UedyvADgI4I9mbxeRDwdB8C92s0yHrc9wK3922b6Na+X2BYD+/v61nZ2dz6M8cX00DMP9S421ffv2V83MzDwHoNfmucuxEWSpslxcjYyMrHEcZ8xScQUAjoj8vqVYZIHv+xtE5MMWQ941PDy83mK8VIjIW2s2HZ2vuAKAIAgmADyxQIxWM3uu5J56DhgZGVkDYBw1nS+ApwB82VJeZAfbt82tWrXqPSgXV481UlwBwMGDB3+sqncDgIh81EZ+QBMLrKwXV5Uh5NoPYqMyN+m9nanqHVj4bsHF6InjeKfFeKmoLMUw+/2Ct6KLyOM1m2x/NmxbW30RhuGPFtp5jstGVU+JiNdqE57rEYahzB6lWOz7Fsf2be/2hYj8SeXlvTbiFYvFLwK4DOAWY8z1NmI2pcDKcnE1OjraWSgU9uPaD2LDRKSlJwavQCO2A4rIDtsxU7BxsQeoau2Jeak3BDTDL72kUm/n63neaFoJUkPYvm3G9/0NKN9gc7mrq6t2OsOSVGqPSQCuiAzaiLnsBVaWiysAuHDhwn4AQ2nEVtUfpBGXluwNKcRcaBmPVpDMfiMiW+o4pnafZM69MmYxnW9lsj9lCNs3m1T1tSjXL89aXo39WCX+62wEW9YCK+vFVcXLKcbmJcLW8qoUYmZhZOfFmvc3e563fb6djTFvwdUJxfPFyJx6O1/f999a6Xz5ZIwMYftm2o2Vv60+HUVETldeLnoUfy7LVmC1SXEFVf0YgFSeX5QkCQus9tfyIzsicnSObQ/6vj9cu71SXP1nPTGyplAo5FDT+arqk3Ecb5s9J0dV2flmENs3u0REgTmnJjRkVjwrd2Iuy3+adimuACCKotPGmC8A+GvLoZOZmZkXLMekBojIaVX9DcthTy+8S3MlSTIuIu+q2dyjqgeMMU8A+CYAUdUtAOa8izZJkvG081wG19xN5jjO4ByLTLrLlRBZxfbNrjMAICI3LrTjIlVHrqyMjKU+gtVOxVVVHMf/hHkWrGvAiawsQrlSqOqiF61rRkzbOjo6AsxfCG4G8FcAPvhLlih5qVgsWpl42kIyezcZ1YXtmy0/QvlqwG9V1i6zZRMAiIiV+dCpFljtWFwBQOUbzqcth+XlwdZjfRRGRMZsx7St8mT5zzcQ4r52+LKgqp9S1U8B+GTtZSPKPrZvdlXaagrAalU1NmJWCrVtAEqO4xyyETO1S4TtWlxVXbp06b7u7u6/BHCTjXiqygKrxYjIQ6p6L2Y9BqZB51etWtXyBRYAuK77hVKp9H5cnUxarzOu634xjZyWWxRFdzU7B0oP2zfbVPUbIrLFcZwPAfivRuOJyPtUdbWq5m09jzCVEax2L64AYGpq6rKq/qOteI7jsMBqMUEQnFXV3bbiqerdExMT52zFS1Mul7soIovugETkI7lc7mIaORERVRWLxS8BeElVb/F9v6EnR/i+f6Oq3gUAjuPYejSavQLLGKPVP4VC4Wd4ZXF1pKura7Bdiquq3t7efwfwnKVwLLBa0PT09B5U1kZp0BPFYvGzFuIsmyAI7kf5uWz1OhgEwTV3FLaoX5yLKosWLknNsZcayohsYvu2uUo98TEAUNW9vu8vad3CoaGhLlX9BoBeAONBEByxleNyLNPwWBzHOywvBtYS9u3bV1LVj1sKxwKrBU1NTV12XXcXgFMNhDmpqndkcF6SisifAzhRx76n4jh+Byzd3rwMjldfqOqSV+xPkmT2yvzH592RlhvbdwUIw3AvgAcArFPVcHBwcFHPBvZ9f0OpVDqA8qrwL8Rx/E6b+VkvsGqfZ9ROlwXnEkXRfgDfajCMXrx48Yc28iH7crncSVXdrKpPLvZYEXk6SZItURS1/PIMcwmC4KzjOCMAam9dn+0SgJ35fP4ny5SWDQ/Mer3HGLPoTtgYMyIiv3gOmqpmZfRuJWD7rgwax/G7UH7EzcYkSf7bGHNXX1/f6oUO9H1/Z+WcPoDysgw7bJ/DUl8Hq52LqwoVkb9T1WiRx8UoX158RlWfnJqaupxCbmRJFEWn+/r6buvu7v4ggI9g4Ynv50XknkKh8JkMjly9wqFDh77j+/6oqo4BqD1xXRaRPw6CwMZl1GXjuu6XSqXSOwH8LoD1AMaMMecA1PtF53WV4wCUC+menp699jOlpWD7rhz5fP5Kf3//UFdX132q+l4Ad3d3d7/fGPN1EZlQ1e/19PS8dPbs2fWu694kIgOqOqqqm4Dy4rKlUumOw4cPN3KVYk7WVkE1xsx5aSBLT+duhDEmQrkSnssZlIeXnxWRY6p6PI7j41nveFeq4eHh9XEc7xSRnQBej6t3kp5EuWh+OI7jh+dYsDDTfN/frKrjAKpPmv9pkiS7JicnH29mXku1devWV3d0dBxAuRNeMhF5ulgsjqRxgk7DfOfqxWr1czvbtzGt3r5zGRwc7FPV3ap6y0L7ishPAHx63bp1e/bt2xenkQ8LLEuMMZtE5JCqfhfAMwCeSZLkO2vWrDk+NjbGyZHUFjzP2yginwcAVX1fVi99Vo2OjnaeP3/+3SLydgBvBNBd56GXAHxXVR/s7e3dm9YJOg0rqQNm+y5dFtp3HmKM2QxgF8qr9b8GwA0AzgH4MYBjIjJ28eLFkFeOiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIhWgv8Hnffz4dmwY9cAAAAASUVORK5CYII=);background-image:linear-gradient(#0000,#0000),url(/static/media/spritesheet.a4e0eb7ad904a4858361.svg)}.leaflet-draw a{display:block;text-align:center;text-decoration:none}.leaflet-draw a .sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.leaflet-draw-actions{display:none;left:26px;list-style:none;margin:0;padding:0;position:absolute;top:0;white-space:nowrap}.leaflet-touch .leaflet-draw-actions{left:32px}.leaflet-right .leaflet-draw-actions{left:auto;right:26px}.leaflet-touch .leaflet-right .leaflet-draw-actions{left:auto;right:32px}.leaflet-draw-actions li{display:inline-block}.leaflet-draw-actions li:first-child a{border-left:0}.leaflet-draw-actions li:last-child a{border-radius:0 4px 4px 0}.leaflet-right .leaflet-draw-actions li:last-child a{border-radius:0}.leaflet-right .leaflet-draw-actions li:first-child a{border-radius:4px 0 0 4px}.leaflet-draw-actions a{background-color:#919187;border-left:1px solid #aaa;color:#fff;font:11px/19px Helvetica Neue,Arial,Helvetica,sans-serif;height:28px;line-height:28px;padding-left:10px;padding-right:10px;text-decoration:none}.leaflet-touch .leaflet-draw-actions a{font-size:12px;height:30px;line-height:30px}.leaflet-draw-actions-bottom{margin-top:0}.leaflet-draw-actions-top{margin-top:1px}.leaflet-draw-actions-bottom a,.leaflet-draw-actions-top a{height:27px;line-height:27px}.leaflet-draw-actions a:hover{background-color:#a0a098}.leaflet-draw-actions-top.leaflet-draw-actions-bottom a{height:26px;line-height:26px}.leaflet-draw-toolbar .leaflet-draw-draw-polyline{background-position:-2px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-polyline{background-position:0 -1px}.leaflet-draw-toolbar .leaflet-draw-draw-polygon{background-position:-31px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-polygon{background-position:-29px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-rectangle{background-position:-62px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-rectangle{background-position:-60px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-circle{background-position:-92px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-circle{background-position:-90px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-marker{background-position:-122px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-marker{background-position:-120px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-circlemarker{background-position:-273px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-circlemarker{background-position:-271px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-edit{background-position:-152px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-edit{background-position:-150px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-remove{background-position:-182px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-remove{background-position:-180px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-edit.leaflet-disabled{background-position:-212px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-edit.leaflet-disabled{background-position:-210px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-remove.leaflet-disabled{background-position:-242px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-remove.leaflet-disabled{background-position:-240px -2px}.leaflet-mouse-marker{background-color:#fff;cursor:crosshair}.leaflet-draw-tooltip{background:#363636;background:#00000080;border:1px solid #0000;border-radius:4px;color:#fff;font:12px/18px Helvetica Neue,Arial,Helvetica,sans-serif;margin-left:20px;margin-top:-21px;padding:4px 8px;position:absolute;visibility:hidden;white-space:nowrap;z-index:6}.leaflet-draw-tooltip:before{border-bottom:6px solid #0000;border-right:6px solid #00000080;border-top:6px solid #0000;content:"";left:-7px;position:absolute;top:7px}.leaflet-error-draw-tooltip{background-color:#f2dede;border:1px solid #e6b6bd;color:#b94a48}.leaflet-error-draw-tooltip:before{border-right-color:#e6b6bd}.leaflet-draw-tooltip-single{margin-top:-12px}.leaflet-draw-tooltip-subtext{color:#f8d5e4}.leaflet-draw-guide-dash{font-size:1%;height:5px;opacity:.6;position:absolute;width:5px}.leaflet-edit-marker-selected{background-color:#fe57a11a;border:4px dashed #fe57a199;border-radius:4px;box-sizing:initial}.leaflet-edit-move{cursor:move}.leaflet-edit-resize{cursor:pointer}.leaflet-oldie .leaflet-draw-toolbar{border:1px solid #999}:root{--um-primary:#4f46e5;--um-primary-hover:#4338ca;--um-primary-light:#eef2ff;--um-bg-page:#f9fafb;--um-bg-card:#fff;--um-text-main:#111827;--um-text-sec:#6b7280;--um-text-muted:#9ca3af;--um-border:#e5e7eb;--um-success:#10b981;--um-success-bg:#ecfdf5;--um-danger:#ef4444;--um-danger-bg:#fef2f2;--um-warning:#f59e0b;--um-warning-bg:#fffbeb;--um-radius:8px;--um-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--um-shadow-sm:0 1px 2px 0 #0000000d}.um-container{background-color:#f9fafb;background-color:var(--um-bg-page);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding:24px}.um-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.um-title-group h2{color:#111827;color:var(--um-text-main);font-size:24px;font-weight:700;margin:0}.um-subtitle{color:#6b7280;color:var(--um-text-sec);font-size:14px;margin:4px 0 0}.um-btn{align-items:center;border-radius:8px;border-radius:var(--um-radius);display:inline-flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 20px;transition:all .2s ease}.um-btn-primary{background-color:#4f46e5;background-color:var(--um-primary);box-shadow:0 4px 14px 0 #4f46e54d}.um-btn-primary:hover{background-color:#4338ca;background-color:var(--um-primary-hover);transform:translateY(-1px)}.um-btn-secondary{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--um-border);color:#111827;color:var(--um-text-main)}.um-btn-secondary:hover{background-color:#f9fafb;background-color:var(--um-bg-page)}.um-controls{align-items:center;background:#fff;background:var(--um-bg-card);border:1px solid #e5e7eb;border:1px solid var(--um-border);border-radius:8px;border-radius:var(--um-radius);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--um-shadow-sm);display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:16px}.um-search-wrapper{align-items:center;display:flex;flex:1 1;min-width:250px;position:relative}.um-search-icon{color:#9ca3af;color:var(--um-text-muted);left:12px;pointer-events:none;position:absolute}.um-input-search{border:1px solid #e5e7eb;border:1px solid var(--um-border);border-radius:8px;border-radius:var(--um-radius);font-size:14px;padding:10px 10px 10px 40px;transition:border-color .2s;width:100%}.um-input-search:focus{border-color:#4f46e5;border-color:var(--um-primary);box-shadow:0 0 0 3px #eef2ff;box-shadow:0 0 0 3px var(--um-primary-light);outline:none}.um-filters-group{display:flex;flex-wrap:wrap;gap:12px}.um-select-wrapper{align-items:center;display:flex;position:relative}.um-select-icon{color:#9ca3af;color:var(--um-text-muted);left:10px;pointer-events:none;position:absolute;z-index:1}.um-select{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--um-border);border-radius:8px;border-radius:var(--um-radius);color:#111827;color:var(--um-text-main);cursor:pointer;font-size:14px;min-width:140px;padding:10px 12px 10px 32px}.um-select:focus{border-color:#4f46e5;border-color:var(--um-primary);outline:none}.um-table-card{background:#fff;background:var(--um-bg-card);border:1px solid #e5e7eb;border:1px solid var(--um-border);border-radius:8px;border-radius:var(--um-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--um-shadow);overflow:hidden}.um-table-responsive{overflow-x:auto;width:100%}.um-table{border-collapse:collapse;min-width:900px;width:100%}.um-table thead{background-color:#f3f4f6;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--um-border)}.um-table th{color:#6b7280;color:var(--um-text-sec);font-size:12px;font-weight:600;letter-spacing:.05em;padding:14px 20px;text-align:left;text-transform:uppercase}.um-table tbody tr{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--um-border);transition:background-color .2s}.um-table tbody tr:last-child{border-bottom:none}.um-table tbody tr:hover{background-color:#f9fafb}.um-table tbody tr.um-row-deleted{background-color:#fef2f2;opacity:.8}.um-table td{color:#111827;color:var(--um-text-main);font-size:14px;padding:16px 20px;vertical-align:middle}.um-user-cell{gap:12px}.um-avatar,.um-user-cell{align-items:center;display:flex}.um-avatar{background:linear-gradient(135deg,#4f46e5,#818cf8);background:linear-gradient(135deg,var(--um-primary) 0,#818cf8 100%);border-radius:50%;color:#fff;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.um-user-info{display:flex;flex-direction:column}.um-username{color:#111827;color:var(--um-text-main);font-weight:600}.um-email{color:#6b7280;color:var(--um-text-sec);font-size:12px}.um-badge{border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px;text-transform:capitalize}.um-badge-role{background-color:#eff6ff;border:1px solid #dbeafe;color:#2563eb}.um-badge-role.admin{background-color:#312e81;color:#fff}.um-badge-role.group_admin{background-color:#7c3aed;color:#fff}.um-badge-active{background-color:#ecfdf5;background-color:var(--um-success-bg);border:1px solid #bbf7d0;color:#10b981;color:var(--um-success)}.um-badge-inactive{background-color:#fffbeb;background-color:var(--um-warning-bg);border:1px solid #fde68a;color:#f59e0b;color:var(--um-warning)}.um-badge-deleted{background-color:#fef2f2;background-color:var(--um-danger-bg);color:#ef4444;color:var(--um-danger);margin-top:4px}.um-perms-stack{background:#f3f4f6;border-radius:4px;display:flex;flex-direction:column;font-family:monospace;gap:2px;padding:4px 8px;width:-webkit-fit-content;width:fit-content}.um-perms-stack,.um-text-secondary{color:#6b7280;color:var(--um-text-sec)}.um-text-muted{color:#9ca3af;color:var(--um-text-muted)}.um-managed-list{display:flex;flex-wrap:wrap;gap:6px;max-width:250px}.um-chip{align-items:center;background-color:#f3f4f6;border:1px solid #e5e7eb;border:1px solid var(--um-border);border-radius:12px;display:flex;font-size:11px;gap:4px;padding:2px 8px}.um-chip-remove{background:none;border:none;color:#ef4444;color:var(--um-danger);cursor:pointer;font-size:14px;font-weight:700;line-height:1;padding:0}.um-actions-cell{text-align:right}.um-actions-wrapper{display:flex;gap:8px;justify-content:flex-end}.um-action-btn{align-items:center;background-color:initial;border:none;border-radius:6px;color:#6b7280;color:var(--um-text-sec);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.um-action-btn:hover{background-color:#f3f4f6;transform:translateY(-2px)}.um-btn-login:hover{background-color:#eff6ff;color:#2563eb}.um-btn-view:hover{background-color:#ecfdf5;color:#059669}.um-btn-edit:hover{background-color:#fffbeb;color:#d97706}.um-btn-key:hover{background-color:#f5f3ff;color:#7c3aed}.um-btn-delete:hover{background-color:#fef2f2;color:#dc2626}.um-btn-restore:hover{background-color:#ecfdf5;color:#059669}.um-action-btn[disabled]{cursor:not-allowed;opacity:.3;pointer-events:none}.um-modal-overlay{animation:umFadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;padding:20px;right:0}.um-modal-content{border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.um-modal-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--um-border);padding:20px 24px}.um-modal-header h3{color:#111827;color:var(--um-text-main);font-size:18px}.um-close-icon{background:none;color:#9ca3af;color:var(--um-text-muted)}.um-close-icon:hover{color:#111827;color:var(--um-text-main)}.um-form-grid{grid-gap:20px;gap:20px;grid-template-columns:1fr 1fr;padding:24px}.um-form-group{gap:6px}.um-form-group label{color:#111827;color:var(--um-text-main);font-size:13px}.um-input,.um-select-full{border:1px solid #e5e7eb;border:1px solid var(--um-border);border-radius:6px;font-size:14px;padding:10px;width:100%}.um-input:focus,.um-select-full:focus{border-color:#4f46e5;border-color:var(--um-primary);box-shadow:0 0 0 3px #eef2ff;box-shadow:0 0 0 3px var(--um-primary-light);outline:none}.um-divider{border-bottom:1px solid #0000;padding:0 24px 10px}.um-link-btn{background:none;border:none;color:#4f46e5;color:var(--um-primary);cursor:pointer;font-size:13px;padding:0;text-decoration:underline}.um-advanced-section{background-color:#f9fafb;border-top:1px solid #e5e7eb;border-top:1px solid var(--um-border);padding:20px 24px 24px}.um-checkbox-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));margin-top:8px}.um-checkbox-label{font-size:13px}.um-modal-actions{background-color:#fff;border-radius:0 0 12px 12px;border-top:1px solid #e5e7eb;border-top:1px solid var(--um-border);gap:12px;padding:20px 24px}.um-empty-state{color:#6b7280;color:var(--um-text-sec);padding:40px;text-align:center}.um-empty-icon{font-size:40px;margin-bottom:10px}@keyframes umFadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}@media screen and (max-width:768px){.um-container{padding:16px}.um-header{align-items:stretch;flex-direction:column}.um-btn-primary{width:100%}.um-controls{align-items:stretch}.um-controls,.um-filters-group{flex-direction:column}.um-select,.um-select-wrapper{width:100%}.hide-mobile,.um-table thead{display:none}.um-table,.um-table tbody,.um-table td,.um-table tr{display:block;width:100%}.um-table-card{background:#0000;border:none;box-shadow:none}.um-table tr{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--um-border);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--um-shadow);margin-bottom:16px;padding:16px;position:relative}.um-table td{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:8px 0;text-align:right}.um-table td:last-child{border-bottom:none;justify-content:flex-end;padding-top:16px}.um-table td:before{color:#6b7280;color:var(--um-text-sec);content:attr(data-label);font-size:13px;font-weight:600;text-align:left}.um-user-cell{flex-direction:row;text-align:left}.um-actions-cell{width:100%}.um-actions-wrapper{justify-content:space-between;width:100%}.um-action-btn{background-color:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--um-border);height:40px;width:40px}.um-form-grid{grid-template-columns:1fr}}.fullscreen-dashboard-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.fullscreen-dashboard-container{background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;height:90vh;max-width:1400px;overflow:hidden;width:100%}.dashboard-modal-header{align-items:center;background:linear-gradient(135deg,#4f46e5,#4338ca);background:linear-gradient(135deg,var(--um-primary) 0,#4338ca 100%);color:#fff;display:flex;justify-content:space-between;padding:20px 32px}.user-info-header{align-items:center;display:flex;gap:16px}.user-avatar-large{align-items:center;background:#fff3;border-radius:50%;display:flex;font-size:20px;font-weight:700;height:50px;justify-content:center;width:50px}.user-info-header h2{color:#fff;font-size:20px;margin:0}.user-meta{font-size:13px;margin:0;opacity:.9}.close-dashboard-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;width:40px}.close-dashboard-btn:hover{background:#ffffff4d}.embedded-dashboard-content{background:#f3f4f6;flex:1 1;overflow:hidden;position:relative}.modal-overlay{animation:fadeIn .2s ease-in-out;background-color:#0009;height:100vh;width:100vw}.modal-content.geofence-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;font-family:Inter,sans-serif;max-height:90vh;overflow:hidden;width:90%}.gf-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:16px 24px}.gf-header,.gf-title{align-items:center;display:flex}.gf-title{gap:12px}.gf-title h3{color:#111827;font-size:1.15rem;font-weight:600;margin:0}.gf-title span{color:#6b7280;font-size:.875rem;font-weight:400}.gf-controls{grid-gap:20px;background:#fff;display:grid;gap:20px;grid-template-columns:1fr 1fr;padding:20px 24px}.gf-input-group label{color:#6b7280;display:block;font-size:.75rem;font-weight:700;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.input-field{border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;padding:10px 12px;transition:border-color .2s}.input-field:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.gf-toolbar{border-bottom:1px solid #f3f4f6;gap:12px;padding:0 24px 16px}.btn-tool,.gf-toolbar{align-items:center;display:flex}.btn-tool{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.9rem;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s}.btn-tool:hover{background:#f3f4f6}.btn-tool.active{background:#eff6ff;border-color:#3b82f6;color:#2563eb;font-weight:600}.btn-tool.delete{background:#fef2f2;border-color:#fecaca;color:#dc2626;margin-left:auto}.btn-tool.delete:hover{background:#fee2e2;border-color:#fca5a5}.gf-map-wrapper{background:#e5e7eb;height:500px;position:relative;width:100%}.gf-footer{align-items:center;background:#fff;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.btn-cancel{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-weight:500}.btn-save{align-items:center;background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 20px}.btn-save:disabled{background:#9ca3af;cursor:not-allowed}.btn-save:hover:not(:disabled){background:#1d4ed8}.relative{position:relative}.absolute{position:absolute}.left-3{left:.75rem}.top-3{top:.75rem}.pl-10{padding-left:2.5rem}.embedded-dashboard{background:#f8f9fa;display:flex;flex-direction:column;height:100%;width:100%}.loading-container{align-items:center;display:flex;flex-direction:column;gap:20px;height:500px;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:50px;width:50px}.loading-container p{color:#64748b;font-size:14px}.dashboard-tabs{background:#fff;border-bottom:2px solid #e2e8f0;display:flex;gap:8px;overflow-x:auto;padding:20px 24px}.tab-btn{border-radius:10px;color:#64748b;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.tab-btn:hover{background:#f1f5f9;color:#334155}.tab-btn.active{box-shadow:0 4px 12px #667eea4d}.tab-content{flex:1 1;overflow-y:auto;padding:24px}.overview-grid{display:flex;flex-direction:column;gap:24px}.stats-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.mini-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;display:flex;gap:16px;padding:24px;transition:all .2s ease}.mini-card:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-4px)}.card-icon{align-items:center;border-radius:12px;color:#fff;display:flex;height:60px;justify-content:center;width:60px}.devices-card .card-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.balance-card .card-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.events-card .card-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.activity-card .card-icon{background:linear-gradient(135deg,#10b981,#059669)}.card-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 4px;text-transform:uppercase}.card-value{color:#1e293b;font-size:32px;font-weight:700;margin:0 0 4px}.card-sub{color:#94a3b8;font-size:12px;margin:0}.summary-section{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;padding:28px}.summary-section h3{color:#1e293b;font-size:18px;font-weight:700;margin:0 0 20px}.summary-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:12px;padding:16px}.summary-icon{flex-shrink:0}.summary-icon.success{color:#10b981}.summary-icon.primary{color:#667eea}.summary-icon.warning{color:#f59e0b}.summary-icon.info{color:#3b82f6}.summary-label{color:#64748b;font-size:12px;margin:0 0 4px}.summary-value{color:#1e293b;font-size:16px;font-weight:700;margin:0}.devices-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.device-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;padding:20px;transition:all .2s ease}.device-card:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-4px)}.device-header{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.device-info h4{color:#1e293b;font-size:16px;font-weight:700;margin:0 0 4px}.device-model{color:#64748b;font-size:12px;margin:0}.device-status{border-radius:20px;font-size:11px;font-weight:700;padding:6px 12px;text-transform:uppercase}.device-status.online{background:#d1fae5;color:#065f46}.device-status.offline{background:#fee2e2;color:#991b1b}.device-details{display:flex;flex-direction:column;gap:8px}.detail-row{align-items:center;display:flex;font-size:13px;gap:8px}.detail-label{color:#64748b;font-weight:600;min-width:100px}.detail-value{color:#1e293b;font-weight:500}.transactions-container{display:flex;flex-direction:column;gap:12px}.tx-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;justify-content:space-between;padding:20px;transition:all .2s ease}.tx-card:hover{background:#f8fafc;box-shadow:0 4px 12px #00000014}.tx-left{flex:1 1;gap:16px}.tx-icon,.tx-left{align-items:center;display:flex}.tx-icon{border-radius:50%;flex-shrink:0;font-size:20px;font-weight:700;height:44px;justify-content:center;width:44px}.tx-icon.received{background:#d1fae5;color:#065f46}.tx-icon.sent{background:#fee2e2;color:#991b1b}.tx-info{flex:1 1}.tx-type{color:#1e293b;font-size:14px;margin:0 0 4px}.tx-date{color:#64748b;font-size:12px;margin:0}.tx-note{color:#94a3b8;font-size:12px;font-style:italic;margin:4px 0 0}.tx-amount{font-size:20px;font-weight:700;white-space:nowrap}.tx-amount.received{color:#059669}.tx-amount.sent{color:#dc2626}.events-container{display:flex;flex-direction:column;gap:12px}.event-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;padding:16px;transition:all .2s ease}.event-card:hover{background:#f8fafc;box-shadow:0 4px 12px #00000014}.event-left{gap:16px}.event-icon,.event-left{align-items:center;display:flex}.event-icon{border-radius:50%;color:#fff;height:40px;justify-content:center;width:40px}.event-icon.geofence_exit{background:#ef4444}.event-icon.geofence_entry{background:#10b981}.event-icon.overspeed{background:#f59e0b}.event-device{color:#1e293b;font-size:14px;font-weight:700;margin:0 0 2px}.event-type{color:#667eea;font-size:12px;font-weight:600;margin:0 0 2px}.event-date{color:#94a3b8;font-size:11px;margin:0}.empty-state{align-items:center;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;padding:80px 20px}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state p{font-size:14px;margin:0}@media (max-width:768px){.devices-list,.stats-row,.summary-grid{grid-template-columns:1fr}.dashboard-tabs,.tab-content{padding:16px}}:root{--dm-primary:#4f46e5;--dm-primary-hover:#4338ca;--dm-primary-light:#eef2ff;--dm-bg-page:#f9fafb;--dm-bg-card:#fff;--dm-text-main:#111827;--dm-text-sec:#6b7280;--dm-text-muted:#9ca3af;--dm-border:#e5e7eb;--dm-success:#10b981;--dm-success-bg:#ecfdf5;--dm-danger:#ef4444;--dm-danger-bg:#fef2f2;--dm-warning:#f59e0b;--dm-warning-bg:#fffbeb;--dm-neutral:#6b7280;--dm-neutral-bg:#f3f4f6;--dm-radius:8px;--dm-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--dm-shadow-sm:0 1px 2px 0 #0000000d}.dm-container{background-color:#f9fafb;background-color:var(--dm-bg-page);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding:24px}.dm-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.dm-title-group h2{color:#111827;color:var(--dm-text-main);font-size:24px;font-weight:700;margin:0}.dm-subtitle{color:#6b7280;color:var(--dm-text-sec);font-size:14px;margin:4px 0 0}.dm-btn{align-items:center;border:none;border-radius:8px;border-radius:var(--dm-radius);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 20px;transition:all .2s ease}.dm-btn-primary{background-color:#4f46e5;background-color:var(--dm-primary);box-shadow:0 4px 14px 0 #4f46e54d;color:#fff}.dm-btn-primary:hover{background-color:#4338ca;background-color:var(--dm-primary-hover);transform:translateY(-1px)}.dm-controls{align-items:center;background:#fff;background:var(--dm-bg-card);border:1px solid #e5e7eb;border:1px solid var(--dm-border);border-radius:8px;border-radius:var(--dm-radius);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--dm-shadow-sm);display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:16px}.dm-search-wrapper{align-items:center;display:flex;flex:1 1;min-width:250px;position:relative}.dm-search-icon{color:#9ca3af;color:var(--dm-text-muted);left:12px;pointer-events:none;position:absolute}.dm-input-search{border:1px solid #e5e7eb;border:1px solid var(--dm-border);border-radius:8px;border-radius:var(--dm-radius);font-size:14px;padding:10px 10px 10px 40px;transition:border-color .2s;width:100%}.dm-input-search:focus{border-color:#4f46e5;border-color:var(--dm-primary);box-shadow:0 0 0 3px #eef2ff;box-shadow:0 0 0 3px var(--dm-primary-light);outline:none}.dm-filters-group{display:flex;flex-wrap:wrap;gap:12px}.dm-select-wrapper{align-items:center;display:flex;position:relative}.dm-select-icon{color:#9ca3af;color:var(--dm-text-muted);left:10px;pointer-events:none;position:absolute;z-index:1}.dm-select{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--dm-border);border-radius:8px;border-radius:var(--dm-radius);color:#111827;color:var(--dm-text-main);cursor:pointer;font-size:14px;min-width:180px;padding:10px 12px 10px 32px}.dm-select:focus{border-color:#4f46e5;border-color:var(--dm-primary);outline:none}.dm-table-card{background:#fff;background:var(--dm-bg-card);border:1px solid #e5e7eb;border:1px solid var(--dm-border);border-radius:8px;border-radius:var(--dm-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--dm-shadow);overflow:hidden}.dm-table-responsive{overflow-x:auto;width:100%}.dm-table{border-collapse:collapse;min-width:800px;width:100%}.dm-table thead{background-color:#f3f4f6;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--dm-border)}.dm-table th{color:#6b7280;color:var(--dm-text-sec);font-size:12px;font-weight:600;letter-spacing:.05em;padding:14px 20px;text-align:left;text-transform:uppercase}.dm-table tbody tr{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--dm-border);transition:background-color .2s}.dm-table tbody tr:last-child{border-bottom:none}.dm-table tbody tr:hover{background-color:#f9fafb}.dm-table td{color:#111827;color:var(--dm-text-main);font-size:14px;padding:16px 20px;vertical-align:middle}.dm-device-cell{align-items:center;display:flex;gap:12px}.dm-device-icon{align-items:center;background:linear-gradient(135deg,#4f46e5,#818cf8);background:linear-gradient(135deg,var(--dm-primary) 0,#818cf8 100%);border-radius:8px;color:#fff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.dm-info-col{display:flex;flex-direction:column;gap:2px}.dm-detail-row{align-items:center;color:#111827;color:var(--dm-text-main);display:flex;font-size:13px;gap:6px}.dm-icon-muted{color:#9ca3af;color:var(--dm-text-muted)}.dm-text-main{color:#111827;color:var(--dm-text-main);font-weight:600}.dm-text-sub{color:#6b7280;color:var(--dm-text-sec);font-size:12px}.dm-text-bold{font-weight:600}.dm-text-mono{color:#6b7280;color:var(--dm-text-sec);font-family:Monaco,Consolas,monospace;font-size:12px}.dm-text-xs{color:#9ca3af;color:var(--dm-text-muted);font-size:11px}.dm-badge{border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px;text-transform:capitalize}.dm-badge-green{background-color:#ecfdf5;background-color:var(--dm-success-bg);border:1px solid #bbf7d0;color:#10b981;color:var(--dm-success)}.dm-badge-red{background-color:#fef2f2;background-color:var(--dm-danger-bg);border:1px solid #fecaca;color:#ef4444;color:var(--dm-danger)}.dm-badge-yellow{background-color:#fffbeb;background-color:var(--dm-warning-bg);border:1px solid #fde68a;color:#f59e0b;color:var(--dm-warning)}.dm-badge-gray{background-color:#f3f4f6;background-color:var(--dm-neutral-bg);border:1px solid #e5e7eb;color:#6b7280;color:var(--dm-neutral)}.dm-actions-cell{text-align:right}.dm-actions-wrapper{display:flex;gap:8px;justify-content:flex-end}.dm-action-btn{align-items:center;background-color:initial;border:none;border-radius:6px;color:#6b7280;color:var(--dm-text-sec);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.dm-action-btn:hover{background-color:#f3f4f6;transform:translateY(-2px)}.dm-btn-edit:hover{background-color:#fffbeb;color:#d97706}.dm-btn-map:hover{background-color:#eff6ff;color:#2563eb}.dm-btn-delete:hover{background-color:#fef2f2;color:#dc2626}.dm-empty-state{color:#6b7280;color:var(--dm-text-sec);padding:40px;text-align:center}.dm-empty-icon{font-size:40px;margin-bottom:10px}@media screen and (max-width:768px){.dm-container{padding:16px}.dm-header{align-items:stretch;flex-direction:column}.dm-btn-primary{width:100%}.dm-controls{align-items:stretch;flex-direction:column}.dm-select,.dm-select-wrapper{width:100%}.dm-table thead,.hide-mobile{display:none}.dm-table,.dm-table tbody,.dm-table td,.dm-table tr{display:block;width:100%}.dm-table-card{background:#0000;border:none;box-shadow:none}.dm-table tr{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--dm-border);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--dm-shadow);margin-bottom:16px;padding:16px}.dm-table td{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:10px 0;text-align:right}.dm-table td:last-child{border-bottom:none;justify-content:flex-end;padding-top:16px}.dm-table td:before{color:#6b7280;color:var(--dm-text-sec);content:attr(data-label);flex-shrink:0;font-size:13px;font-weight:600;margin-right:20px;text-align:left}.dm-info-col{align-items:flex-end;text-align:right}.dm-device-cell{flex-direction:row-reverse}.dm-device-icon{border-radius:6px;height:32px;width:32px}.dm-actions-wrapper{justify-content:space-between;width:100%}.dm-action-btn{background-color:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--dm-border);height:36px;margin:0 4px;width:100%}}.am-container{background-color:#f3f4f6;color:#1f2937;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding:32px}.am-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:24px}.am-title-group h2{color:#111827;font-size:28px;font-weight:800;letter-spacing:-.5px;margin:0}.am-subtitle{color:#6b7280;font-size:14px;font-weight:500;margin:8px 0 0}.am-actions-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.am-search-wrapper{position:relative;width:280px}.am-search-icon{color:#9ca3af;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.am-search-input{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#111827;font-size:14px;padding:12px 12px 12px 42px;transition:all .2s ease;width:100%}.am-search-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.am-search-clear{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.am-search-clear:hover{color:#ef4444}.am-btn-group,.am-upload-wrapper{display:flex;gap:10px}.am-btn{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;height:42px;justify-content:center;padding:0 18px;transition:all .2s;white-space:nowrap}.am-btn-primary{background:#4f46e5;border:1px solid #0000;box-shadow:0 1px 2px #0000000d;color:#fff}.am-btn-primary:hover{background:#4338ca}.am-btn-primary:disabled{cursor:not-allowed;opacity:.6}.am-btn-outline{background:#fff;border:1px solid #d1d5db;box-shadow:0 1px 2px #0000000d;color:#374151}.am-btn-outline:hover{background:#f9fafb;border-color:#9ca3af;color:#111827}.am-btn-dashed{background:#f9fafb;border:1px dashed #d1d5db;color:#6b7280}.am-btn-dashed.file-selected,.am-btn-dashed:hover{background:#eef2ff;border-color:#4f46e5;color:#4f46e5}.am-card{animation:fadeIn .3s ease-in-out;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;overflow:hidden}.am-table-responsive{overflow-x:auto;width:100%}.am-table{border-collapse:collapse;min-width:900px;width:100%}.am-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b;font-size:11px;font-weight:700;letter-spacing:.05em;padding:16px 24px;text-align:left;text-transform:uppercase}.am-table td{border-bottom:1px solid #f1f5f9;color:#374151;font-size:14px;padding:16px 24px;vertical-align:middle}.am-table tbody tr{transition:background-color .15s}.am-table tbody tr:hover{background:#f8fafc}.am-table tbody tr:last-child td{border-bottom:none}.am-row-deleted{background:#fef2f2!important}.am-row-deleted td{opacity:.7}.am-info-cell{gap:16px}.am-icon-box,.am-info-cell{align-items:center;display:flex}.am-icon-box{background:#eef2ff;border:1px solid #e0e7ff;border-radius:10px;color:#4f46e5;height:40px;justify-content:center;width:40px}.am-text-bold{color:#111827;display:block;font-size:14px;font-weight:600;margin-bottom:2px}.am-text-mono{background:#f3f4f6;border-radius:4px;color:#6b7280;font-family:Monaco,Consolas,monospace;font-size:12px;padding:2px 6px}.am-stacked-text{display:flex;flex-direction:column}.am-stacked-text span{font-weight:500}.am-stacked-text small{color:#9ca3af;margin-top:2px}.am-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:12px;font-weight:600;padding:4px 12px;text-transform:capitalize}.am-badge:before{border-radius:50%;content:"";height:6px;margin-right:6px;width:6px}.am-badge-success{background:#ecfdf5;border:1px solid #d1fae5;color:#059669}.am-badge-success:before{background:#059669}.am-badge-danger{background:#fef2f2;border:1px solid #fee2e2;color:#dc2626}.am-badge-danger:before{background:#dc2626}.am-badge-warning{background:#fffbeb;border:1px solid #fef3c7;color:#d97706}.am-badge-warning:before{background:#d97706}.am-badge-neutral{background:#f3f4f6;border:1px solid #e5e7eb;color:#4b5563}.am-badge-neutral:before{background:#9ca3af}.text-right{text-align:right}.am-actions-wrapper{display:flex;gap:8px;justify-content:flex-end}.am-action-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;height:34px;justify-content:center;transition:all .2s;width:34px}.am-action-btn:hover{background:#f3f4f6;color:#111827}.am-action-btn.edit:hover{background:#eef2ff;border-color:#c7d2fe;color:#4f46e5}.am-action-btn.danger:hover{background:#fef2f2;border-color:#fecaca;color:#ef4444}.am-action-btn.restore:hover{background:#ecfdf5;border-color:#bbf7d0;color:#10b981}.am-state{color:#6b7280;padding:64px;text-align:center}.am-empty-icon{display:block;font-size:48px;margin-bottom:16px}.am-spinner{animation:am-spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#4f46e5;height:40px;margin:0 auto 16px;width:40px}@keyframes am-spin{to{transform:rotate(1turn)}}.am-state.am-error{color:#ef4444}.am-pagination{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px 24px}.am-page-info{color:#6b7280;font-size:13px;font-weight:500}.am-page-controls{display:flex;gap:8px}.am-page-btn,.am-page-number{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:13px;font-weight:600;height:36px;justify-content:center;min-width:36px;transition:all .2s}.am-page-btn:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.5}.am-page-btn:hover:not(:disabled),.am-page-number:hover{background:#eef2ff;border-color:#4f46e5;color:#4f46e5}.am-page-number.active{background:#4f46e5;border-color:#4f46e5;box-shadow:0 2px 4px #4f46e533;color:#fff}@media screen and (max-width:768px){.am-container{padding:16px}.am-header{align-items:stretch;flex-direction:column;gap:16px}.am-search-wrapper{width:100%}.hide-mobile{display:none}.am-btn-group{justify-content:space-between}.am-btn{flex:1 1}.am-upload-wrapper{flex:1 1;justify-content:flex-end}.am-table thead{display:none}.am-table,.am-table tbody,.am-table td,.am-table tr{box-sizing:border-box;display:block;width:100%}.am-table tr{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:16px;padding:16px}.am-table td{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:12px 0;text-align:right}.am-table td:last-child{border-bottom:none;justify-content:flex-end;padding-top:16px}.am-table td:before{color:#6b7280;content:attr(data-label);font-size:12px;font-weight:600;margin-right:12px;text-align:left;text-transform:uppercase}.am-pagination{flex-direction:column;gap:12px;text-align:center}}:root{--el-primary:#4f46e5;--el-primary-light:#eef2ff;--el-bg-page:#f9fafb;--el-bg-card:#fff;--el-text-main:#111827;--el-text-sec:#6b7280;--el-text-muted:#9ca3af;--el-border:#e5e7eb;--el-success-bg:#ecfdf5;--el-success:#10b981;--el-danger-bg:#fef2f2;--el-danger:#ef4444;--el-warning-bg:#fffbeb;--el-warning:#f59e0b;--el-neutral-bg:#f3f4f6;--el-neutral:#6b7280;--el-radius:8px;--el-shadow:0 4px 6px -1px #0000001a}.el-container{background-color:#f9fafb;background-color:var(--el-bg-page);font-family:Inter,sans-serif;min-height:100vh;padding:24px}.el-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.el-title-group h2{color:#111827;color:var(--el-text-main);font-size:24px;font-weight:700;margin:0}.el-subtitle{color:#6b7280;color:var(--el-text-sec);font-size:14px;margin:4px 0 0}.el-header-stats{display:flex;gap:16px}.el-stat{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--el-border);border-radius:8px;border-radius:var(--el-radius);display:flex;flex-direction:column;padding:8px 16px}.el-stat-label{color:#9ca3af;color:var(--el-text-muted);font-size:11px;text-transform:uppercase}.el-stat-value{color:#4f46e5;color:var(--el-primary);font-size:18px;font-weight:700}.el-controls{background:#fff;background:var(--el-bg-card);border:1px solid #e5e7eb;border:1px solid var(--el-border);border-radius:8px;border-radius:var(--el-radius);box-shadow:0 1px 2px #0000000d;margin-bottom:24px;padding:16px}.el-controls-header{align-items:center;display:flex;gap:12px}.el-search-wrapper{flex:1 1;position:relative}.el-search-icon{color:#9ca3af;color:var(--el-text-muted);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.el-input-search{border:1px solid #e5e7eb;border:1px solid var(--el-border);border-radius:8px;border-radius:var(--el-radius);font-size:14px;padding:10px 10px 10px 40px;width:100%}.el-input-search:focus{border-color:#4f46e5;border-color:var(--el-primary);box-shadow:0 0 0 3px #eef2ff;box-shadow:0 0 0 3px var(--el-primary-light);outline:none}.el-filter-toggle{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--el-border);border-radius:8px;border-radius:var(--el-radius);color:#6b7280;color:var(--el-text-sec);cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s}.el-filter-toggle.active,.el-filter-toggle:hover{background:#f3f4f6;background:var(--el-neutral-bg);border-color:#9ca3af;border-color:var(--el-text-muted);color:#111827;color:var(--el-text-main)}.el-filters-grid{grid-gap:16px;animation:slideDown .2s ease-out;border-top:1px solid #e5e7eb;border-top:1px solid var(--el-border);display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:16px;padding-top:16px}.el-input-group{display:flex;flex-direction:column;gap:6px}.el-input-group label{color:#6b7280;color:var(--el-text-sec);font-size:12px;font-weight:600}.el-input-group input{border:1px solid #e5e7eb;border:1px solid var(--el-border);border-radius:6px;font-size:14px;padding:8px 12px}.el-btn-clear{background:none;border:1px dashed #e5e7eb;border:1px dashed var(--el-border);border-radius:6px;color:#9ca3af;color:var(--el-text-muted);cursor:pointer;font-size:13px;height:38px;margin-top:22px}.el-btn-clear:hover{border-color:#ef4444;border-color:var(--el-danger);color:#ef4444;color:var(--el-danger)}.el-table-card{background:#fff;background:var(--el-bg-card);border:1px solid #e5e7eb;border:1px solid var(--el-border);border-radius:8px;border-radius:var(--el-radius);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--el-shadow);overflow:hidden}.el-table-responsive{overflow-x:auto;width:100%}.el-table{border-collapse:collapse;min-width:900px;width:100%}.el-table thead{background-color:#f3f4f6;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--el-border)}.el-table th{color:#6b7280;color:var(--el-text-sec);font-size:12px;font-weight:600;padding:14px 20px;text-align:left;text-transform:uppercase}.el-table tbody tr{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--el-border);transition:background-color .2s}.el-table tbody tr:hover{background-color:#f9fafb}.el-table td{color:#111827;color:var(--el-text-main);font-size:14px;padding:16px 20px;vertical-align:middle}.el-device-cell{gap:12px}.el-device-cell,.el-icon-box{align-items:center;display:flex}.el-icon-box{background:#eef2ff;background:var(--el-primary-light);border-radius:8px;color:#4f46e5;color:var(--el-primary);height:36px;justify-content:center;width:36px}.el-info-col{display:flex;flex-direction:column}.el-text-main{color:#111827;color:var(--el-text-main);font-weight:600}.el-text-sub{color:#6b7280;color:var(--el-text-sec);font-size:13px}.el-text-mono{font-family:monospace;font-size:12px}.el-text-mono,.el-text-muted{color:#9ca3af;color:var(--el-text-muted)}.el-icon-text{align-items:center;display:flex;gap:8px}.details-text{display:block;font-size:13px;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-badge{border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px;text-transform:capitalize}.el-badge-success{background:#ecfdf5;background:var(--el-success-bg);border:1px solid #bbf7d0;color:#10b981;color:var(--el-success)}.el-badge-danger{background:#fef2f2;background:var(--el-danger-bg);border:1px solid #fecaca;color:#ef4444;color:var(--el-danger)}.el-badge-warning{background:#fffbeb;background:var(--el-warning-bg);border:1px solid #fde68a;color:#f59e0b;color:var(--el-warning)}.el-badge-neutral{background:#f3f4f6;background:var(--el-neutral-bg);border:1px solid #e5e7eb;color:#6b7280;color:var(--el-neutral)}.el-empty-state,.el-error,.el-loading{align-items:center;color:#6b7280;color:var(--el-text-sec);display:flex;flex-direction:column;gap:12px;padding:40px;text-align:center}.el-error{color:#ef4444;color:var(--el-danger)}.el-spin{animation:spin 1s linear infinite;color:#4f46e5;color:var(--el-primary)}.el-empty-icon{font-size:40px}@media screen and (max-width:768px){.el-container{padding:16px}.el-header{align-items:stretch;flex-direction:column;gap:12px}.el-header-stats{justify-content:space-between}.el-stat{flex:1 1}.el-controls-header{align-items:stretch;flex-direction:column-reverse}.el-filter-toggle{justify-content:center}.el-table thead,.hide-mobile{display:none}.el-table,.el-table tbody,.el-table td,.el-table tr{display:block;width:100%}.el-table-card{background:#0000;border:none;box-shadow:none}.el-table tr{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--el-border);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--el-shadow);margin-bottom:16px;padding:16px;position:relative}.el-table td{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:10px 0;text-align:right}.el-table td:last-child{border-bottom:none}.el-table td:before{color:#6b7280;color:var(--el-text-sec);content:attr(data-label);font-size:13px;font-weight:600;text-align:left}.el-device-cell{flex-direction:row-reverse}.el-info-col{text-align:right}}:root{--bg-dark:#0f172a;--bg-light:#f1f5f9;--primary:#2563eb;--primary-hover:#1d4ed8;--text-main:#1e293b;--text-muted:#64748b;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--border:#e2e8f0;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--glass-bg:#fffffff2;--glass-border:1px solid #ffffff80;--glass-blur:blur(12px)}.advanced-map-layout{background:#f1f5f9;background:var(--bg-light);display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;height:calc(100vh - 64px);overflow:hidden;position:relative;width:100%}.loading-screen{align-items:center;background:#f8fafc;color:#64748b;color:var(--text-muted);display:flex;font-size:1.1rem;font-weight:500;height:100%;justify-content:center;width:100%}.map-sidebar{background:#fff;border-right:1px solid #e2e8f0;border-right:1px solid var(--border);box-shadow:4px 0 15px #00000008;display:flex;flex-direction:column;flex-shrink:0;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:340px;z-index:20}.map-sidebar.closed{overflow:hidden;transform:translateX(-380px);width:0}.sidebar-toggle-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-left:none;border-radius:0 8px 8px 0;box-shadow:2px 0 6px #0000000d;color:#64748b;color:var(--text-muted);cursor:pointer;display:flex;height:50px;justify-content:center;position:absolute;right:-20px;top:50%;transition:color .2s;width:20px;z-index:25}.sidebar-toggle-btn:hover{background:#f8fafc;color:#2563eb;color:var(--primary)}.ds-container{display:flex;flex-direction:column;height:100%}.ds-status-dashboard{grid-gap:8px;background:#f8fafc;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:grid;gap:8px;grid-template-columns:repeat(3,1fr);padding:12px}.ds-stat-card{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:8px 4px;text-align:center;transition:all .2s}.ds-stat-card.active,.ds-stat-card:hover{background:#eff6ff;border-color:#2563eb;border-color:var(--primary);transform:translateY(-1px)}.ds-stat-val{color:#1e293b;color:var(--text-main);display:block;font-size:18px;font-weight:800;line-height:1.2}.ds-stat-label{color:#64748b;color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.ds-stat-card.green .ds-stat-val{color:#10b981;color:var(--success)}.ds-stat-card.red .ds-stat-val{color:#ef4444;color:var(--danger)}.ds-search-box{background:#fff;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);padding:10px 12px;position:relative}.ds-search-box .search-icon{color:#64748b;color:var(--text-muted);left:22px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:16px}.ds-search-box input{background:#f8fafc;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;box-sizing:border-box;color:#1e293b;color:var(--text-main);font-size:13px;outline:none;padding:8px 10px 8px 34px;transition:all .2s;width:100%}.ds-search-box input:focus{background:#fff;border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.ds-list-wrapper{background:#fff;flex:1 1;overflow-y:auto}.ds-group-header{align-items:center;background:#f1f5f9;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#64748b;color:var(--text-muted);cursor:pointer;display:flex;font-size:12px;font-weight:700;gap:8px;letter-spacing:.5px;padding:10px 16px;text-transform:uppercase}.group-badge{background:#cbd5e1;border-radius:10px;color:#fff;font-size:10px;margin-left:auto;padding:2px 6px}.ds-device-list{display:flex;flex-direction:column}.ds-device-row{align-items:center;border-bottom:1px solid #f1f5f9;box-sizing:border-box;cursor:pointer;display:flex;height:64px;padding:10px 12px;transition:background .1s}.ds-device-row:hover{background:#f8fafc}.ds-device-row.selected{background:#eff6ff;border-left:3px solid #2563eb;border-left:3px solid var(--primary)}.ds-check-col{align-items:center;display:flex;margin-right:10px}.ds-checkbox{accent-color:#2563eb;accent-color:var(--primary);cursor:pointer;height:16px;width:16px}.ds-icon-col{flex-shrink:0;height:40px;margin-right:12px;width:40px}.ds-icon-col,.vehicle-avatar{align-items:center;display:flex;justify-content:center}.vehicle-avatar{background:#f1f5f9;border:2px solid #0000;border-radius:50%;height:36px;overflow:hidden;width:36px}.vehicle-avatar img{height:24px;object-fit:contain;width:24px}.vehicle-avatar.online{background:#ecfdf5;border-color:#10b981;border-color:var(--success)}.vehicle-avatar.offline{background:#fef2f2;border-color:#ef4444;border-color:var(--danger)}.ds-info-col{display:flex;flex:1 1;flex-direction:column;gap:3px;justify-content:center;overflow:hidden}.ds-row-top{align-items:center;display:flex;justify-content:space-between}.device-name{color:#1e293b;color:var(--text-main);font-size:13px;font-weight:600;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-speed{background:#eef2ff;border-radius:4px;color:#2563eb;color:var(--primary);font-size:12px;font-weight:700;padding:1px 6px}.ds-row-bot{color:#64748b;color:var(--text-muted);font-size:11px;justify-content:space-between}.device-time,.ds-row-bot{align-items:center;display:flex}.device-time{gap:4px}.device-imei{background:#f1f5f9;border-radius:3px;font-family:monospace;font-size:10px;padding:1px 4px}.ds-action-col{margin-left:8px}.ds-more-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:.2s}.ds-more-btn:hover{background:#e2e8f0;color:#1e293b;color:var(--text-main)}.ds-empty{color:#64748b;color:var(--text-muted);font-size:13px;padding:30px;text-align:center}.map-container{background:#e2e8f0;flex:1 1;height:100%;position:relative}.map-top-bar{display:flex;gap:12px;left:50%;max-width:85%;pointer-events:none;position:absolute;top:90px;transform:translateX(-50%);width:450px;z-index:10}.map-search-wrapper{align-items:center;background:#fff;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);display:flex;flex:1 1;height:48px;padding:0 16px;pointer-events:auto}.map-search-box{border:none;color:#1e293b;color:var(--text-main);font-size:14px;margin-left:10px;outline:none;width:100%}.map-tools{display:flex;pointer-events:auto}.tool-btn{align-items:center;background:#fff;border:none;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#64748b;color:var(--text-muted);cursor:pointer;display:flex;height:48px;justify-content:center;position:relative;transition:all .2s;width:48px}.tool-btn:hover{background:#f8fafc;color:#2563eb;color:var(--primary)}.tool-btn.alert-active{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;color:var(--danger)}.badge-count{align-items:center;background:#ef4444;background:var(--danger);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;font-size:10px;font-weight:700;height:20px;justify-content:center;position:absolute;right:-6px;top:-6px;width:20px}.map-right-controls{display:flex;flex-direction:column;gap:10px;position:absolute;right:20px;top:90px;z-index:10}.ctrl-btn{align-items:center;background:#fff;border:none;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#64748b;color:var(--text-muted);cursor:pointer;display:flex;height:44px;justify-content:center;transition:.2s;width:44px}.ctrl-btn:hover{background:#f8fafc;color:#1e293b;color:var(--text-main)}.ctrl-btn.active{background:#2563eb;background:var(--primary);color:#fff}.custom-marker-container{cursor:pointer;position:absolute;will-change:transform}.vehicle-marker-wrapper{align-items:center;display:flex;flex-direction:column;justify-content:center;position:relative;transition:transform .2s}.vehicle-marker-wrapper.selected-marker,.vehicle-marker-wrapper:hover{transform:scale(1.1);z-index:1000}.vehicle-label{background:#fffffff2;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:4px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);color:#1e293b;color:var(--text-main);font-size:11px;font-weight:700;margin-bottom:4px;padding:2px 6px;pointer-events:none;white-space:nowrap}.vehicle-icon-box{align-items:center;background:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 4px 6px #00000026;display:flex;height:40px;justify-content:center;position:relative;width:40px}.vehicle-img{height:24px;object-fit:contain;transition:transform .3s linear;width:24px}.direction-arrow{border-bottom:8px solid #2563eb;border-bottom:8px solid var(--primary);border-left:6px solid #0000;border-right:6px solid #0000;filter:drop-shadow(0 2px 2px rgba(0,0,0,.2));height:0;left:50%;position:absolute;top:-8px;transform:translateX(-50%);width:0}.pulse-dot{border:2px solid #fff;border-radius:50%;height:12px;position:absolute;right:0;top:0;width:12px;z-index:2}.rip-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);background:#fffffff2;background:var(--glass-bg);border:1px solid #ffffff80;border:var(--glass-border);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.rip-header-hero{background:linear-gradient(135deg,#1e293b,#0f172a)}.rip-model{color:#cbd5e1;opacity:.8}.rip-close-glass{background:#ffffff26}.rip-close-glass:hover{background:#ffffff4d}.status-pill.time{align-items:center;background:#fff3;display:flex}.status-pill.warning{align-items:center;background:#f59e0b;background:var(--warning);color:#fff;display:flex}.rip-tabs{background:#fff;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;flex-shrink:0}.rip-tab{border-bottom:2px solid #0000;color:var(--text-muted);padding:12px}.rip-tab.active{background:#f8fafc;border-bottom-color:var(--primary);color:var(--primary)}.fade-in{animation:fadeIn .3s ease-in}.rip-card{border:1px solid var(--border);border-radius:10px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);margin-bottom:16px;padding:12px}.row.flex-align-start{align-items:flex-start;display:flex;gap:10px}.rip-label{color:#64748b;color:var(--text-muted);display:block;font-size:10px;font-weight:700;margin-bottom:4px;text-transform:uppercase}.address-text{color:#1e293b;color:var(--text-main);font-size:13px;font-weight:500;line-height:1.4;margin:2px 0 4px}.coords{color:#2563eb;color:var(--primary);font-family:monospace;font-size:11px}.street-view-preview{background:#f1f5f9;height:100px;margin-top:10px}.sv-badge{gap:4px;padding:2px 6px}.stats-grid{grid-gap:10px;gap:10px}.stat-box{background:#f8fafc;border:1px solid var(--border);border-radius:8px}.stat-box .val{color:var(--text-main)}.stat-box .unit{color:var(--text-muted);font-size:10px}.icon-blue{color:var(--primary)}.icon-orange{color:var(--warning)}.icon-gray{color:#64748b;color:var(--text-muted)}.icon-warning{color:#f59e0b;color:var(--warning)}.text-green{color:var(--success);font-weight:600}.text-red{color:var(--danger);font-weight:600}.text-gray{color:#64748b;color:var(--text-muted)}.act-btn{font-size:12px;gap:6px;transition:.2s}.act-btn.primary{background:var(--primary);box-shadow:0 4px 10px #2563eb33}.act-btn.primary:hover{background:#1d4ed8;background:var(--primary-hover);transform:translateY(-1px)}.act-btn.outline{border:1px solid var(--border);color:var(--text-main)}.act-btn.outline:hover{background:#f8fafc;border-color:#2563eb;border-color:var(--primary);color:#2563eb;color:var(--primary)}.act-btn.success{background:#10b981;background:var(--success);color:#fff}.act-btn.danger{background:#ef4444;background:var(--danger);color:#fff}.act-btn:disabled{cursor:not-allowed;opacity:.5}.sensor-list{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;overflow:hidden}.sensor-row{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;font-size:13px;font-weight:500;justify-content:space-between;padding:12px 16px}.sensor-row:last-child{border-bottom:none}.sensor-info{align-items:center;display:flex;gap:8px}.sensor-icon,.sensor-info{color:#64748b;color:var(--text-muted)}.badge{border-radius:12px;padding:2px 8px}.badge.success{background:#dcfce7;color:#166534}.badge.neutral{background:#f1f5f9;color:#64748b;color:var(--text-muted)}.activity-list{margin-top:16px}.section-title{color:#1e293b;color:var(--text-main);font-size:14px;font-weight:700;margin-bottom:12px}.activity-item{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;display:flex;gap:12px;margin-bottom:8px;padding:12px}.activity-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.activity-icon.ignition{background:#10b981;background:var(--success)}.activity-icon.geofence{background:#2563eb;background:var(--primary)}.activity-content{display:flex;flex-direction:column;gap:2px}.activity-title{color:#1e293b;color:var(--text-main);font-size:13px;font-weight:600}.activity-time{color:#64748b;color:var(--text-muted);font-size:11px}.alerts-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:50}.alerts-panel{animation:scaleIn .2s cubic-bezier(.16,1,.3,1);background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;display:flex;flex-direction:column;height:80vh;max-height:700px;max-width:90%;overflow:hidden;width:500px}.alerts-header{background:#fff;border-bottom:1px solid #f1f5f9;justify-content:space-between;padding:20px}.alerts-header,.alerts-title{align-items:center;display:flex}.alerts-title{color:#1e293b;color:var(--text-main);font-size:18px;font-weight:700;gap:8px;margin:0}.alerts-subtitle{color:#64748b;color:var(--text-muted);display:block;font-size:12px;margin-top:4px}.alerts-filters{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;gap:8px;padding:6px 12px}.filter-tab{background:#0000;border:none;border-radius:6px;color:#64748b;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:12px;font-weight:600;padding:8px;transition:.2s}.filter-tab:hover{background:#fff;color:#1e293b;color:var(--text-main)}.filter-tab.active{background:#fff;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);color:#2563eb;color:var(--primary)}.alerts-list{background:#f8fafc;flex:1 1;overflow-y:auto;padding:16px}.alert-item{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;display:flex;gap:12px;margin-bottom:10px;padding:14px;position:relative;transition:.2s}.alert-item:hover{box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.alert-item.unread{border-left:4px solid #2563eb;border-left:4px solid var(--primary)}.alert-icon-wrapper{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.alert-content{flex:1 1}.alert-header-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.alert-label{color:#1e293b;color:var(--text-main);font-size:14px;font-weight:700}.severity-badge{border-radius:12px;font-size:10px;font-weight:700;padding:2px 8px;text-transform:uppercase}.severity-badge.critical{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;color:var(--danger)}.severity-badge.warning{background:#fffbeb;border:1px solid #fde68a;color:#d97706}.severity-badge.info{background:#eff6ff;border:1px solid #dbeafe;color:#1e3a8a}.alert-message{color:#64748b;color:var(--text-muted);font-size:13px;line-height:1.4;margin:4px 0 8px}.alert-meta{align-items:center;color:#94a3b8;display:flex;font-size:11px;gap:12px}.alert-dismiss-btn{background:#0000;border:none;border-radius:4px;color:#cbd5e1;cursor:pointer;padding:4px;position:absolute;right:12px;top:12px}.alert-dismiss-btn:hover{background:#f1f5f9;color:#ef4444;color:var(--danger)}.alerts-empty{align-items:center;color:#64748b;color:var(--text-muted);display:flex;flex-direction:column;height:100%;justify-content:center}.alerts-footer{background:#fff;border-top:1px solid #e2e8f0;border-top:1px solid var(--border);padding:16px}.playback-modal{bottom:30px;left:50%;max-width:95%;position:absolute;transform:translateX(-50%);width:600px;z-index:40}.playback-panel{animation:slideUp .3s ease-out;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);background:#fffffff2;background:var(--glass-bg);border:1px solid #ffffff80;border:var(--glass-border);border-radius:16px;box-shadow:0 20px 50px #0003;padding:24px}.playback-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.playback-title{color:#1e293b;color:var(--text-main);font-size:18px;font-weight:700;margin:0}.playback-subtitle{color:#64748b;color:var(--text-muted);font-size:12px}.playback-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.stat-mini{align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;color:#1e293b;color:var(--text-main);display:flex;font-size:12px;font-weight:600;gap:8px;padding:8px 12px}.playback-progress-container{margin-bottom:20px}.playback-progress-bar{background:#e2e8f0;border-radius:3px;cursor:pointer;height:6px;margin-bottom:8px;overflow:hidden}.playback-progress-fill{background:#2563eb;background:var(--primary);height:100%;transition:width .1s linear}.playback-progress-label{color:#64748b;color:var(--text-muted);font-family:monospace;font-size:11px;text-align:right}.playback-controls{gap:16px;margin-bottom:20px}.control-btn,.playback-controls{display:flex;justify-content:center}.control-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:50%;color:#64748b;color:var(--text-muted);cursor:pointer;height:44px;transition:.2s;width:44px}.control-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b;color:var(--text-main)}.control-btn.primary{background:#2563eb;background:var(--primary);border:none;box-shadow:0 4px 15px #2563eb66;color:#fff;height:56px;width:56px}.control-btn.primary:hover{background:#1d4ed8;background:var(--primary-hover);transform:scale(1.05)}.playback-location-info{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;display:flex;gap:16px;padding:12px 16px}.info-label{color:#64748b;color:var(--text-muted);font-size:10px;font-weight:700;margin-bottom:2px;text-transform:uppercase}.info-text{color:#1e293b;color:var(--text-main);font-size:14px;font-weight:600;margin:0}.info-time{color:#64748b;color:var(--text-muted);display:block;font-size:11px;margin-top:2px}@media (max-width:1024px){.map-sidebar{width:300px}.rip-panel{right:70px;width:320px}}@media (max-width:768px){.advanced-map-layout{flex-direction:column;height:100vh}.map-sidebar{height:100%;left:0;position:absolute;top:0;transform:translateY(100%);transition:transform .3s ease;width:100%;z-index:50}.map-sidebar.open{transform:translateY(0);width:100%}.map-sidebar.closed{width:100%}.sidebar-toggle-btn{background:#2563eb;background:var(--primary);border:none;border-radius:50%;bottom:90px;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);color:#fff;height:48px;justify-content:center;left:20px;right:auto;top:auto;width:48px}.rip-panel{animation:slideUp .3s ease-out;border-radius:20px 20px 0 0;bottom:0;left:0;max-height:75vh;right:0;top:auto;width:100%}.map-top-bar{flex-direction:column;gap:8px;top:10px;width:90%}.map-search-box{margin:0;width:100%}.map-tools{justify-content:space-between;width:100%}.map-right-controls{right:10px;top:140px}.playback-modal{bottom:10px;width:95%}.playback-panel{padding:16px}.playback-stats{grid-template-columns:1fr 1fr}}@media (max-width:480px){.status-overview-grid{gap:6px}.ds-stat-card{padding:6px}.ds-stat-val{font-size:16px}.rip-header-hero{padding:16px}.rip-name{font-size:16px}.stats-grid{gap:8px}.stat-box{padding:8px}}.rip-panel{animation:slideInRight .3s cubic-bezier(.16,1,.3,1);background:#fff;border:1px solid #fff9;border-radius:16px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;max-height:calc(100vh - 40px);overflow:hidden;position:absolute;right:80px;top:20px;width:360px;z-index:30}.rip-header-hero{color:#fff;flex-shrink:0;padding:20px}.rip-hero-content{position:relative;z-index:2}.flex-justify-between{align-items:flex-start;display:flex;justify-content:space-between}.rip-name{color:#fff;font-size:18px;font-weight:700;margin:0}.rip-model{color:#e2e8f0;display:block;font-size:12px;margin-top:2px;opacity:.9}.rip-close-glass{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;transition:.2s;width:28px}.rip-close-glass:hover{background:#ffffff59}.rip-hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.status-pill{border-radius:20px;color:#fff;font-size:10px;font-weight:700;padding:4px 10px;text-transform:uppercase}.rip-tabs-container{background:#fff;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;position:relative;z-index:10}.rip-tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;display:flex;flex:1 1;font-size:12px;font-weight:600;gap:6px;justify-content:center;padding:12px 8px;transition:all .2s}.rip-tab:hover{background:#f8fafc;color:#1e293b}.rip-tab.active{background:#f0f9ff;border-bottom-color:#2563eb;color:#2563eb}.tab-text{display:inline}.rip-scroll-area{background:#f8fafc;flex:1 1;overflow-x:hidden;overflow-y:auto}.rip-content{padding:16px}.rip-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 2px #0000000d;margin-bottom:12px;padding:14px}.street-view-preview{background:#e2e8f0;border-radius:8px;height:110px;margin-top:12px;overflow:hidden;position:relative}.street-view-preview img{height:100%;object-fit:cover;width:100%}.sv-badge{align-items:center;background:#000000b3;border-radius:4px;bottom:6px;color:#fff;display:flex;font-size:10px;font-weight:600;left:6px;padding:3px 8px;position:absolute}.stats-grid{grid-gap:8px;gap:8px;grid-template-columns:1fr 1fr 1fr;margin-bottom:16px}.stat-box{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 2px #00000005;display:flex;flex-direction:column;padding:10px 4px;text-align:center}.stat-box .val{color:#1e293b;font-size:16px;font-weight:700;margin-top:4px}.stat-box .unit{color:#64748b;font-size:9px;font-weight:600;text-transform:uppercase}.icon-blue{color:#2563eb}.icon-orange{color:#f59e0b}.icon-purple{color:#8b5cf6}.action-buttons{gap:10px;margin-top:auto}.act-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:600;gap:8px;justify-content:center;padding:10px;transition:transform .1s}.act-btn:active{transform:scale(.98)}.act-btn.primary{background:#2563eb;box-shadow:0 4px 6px #2563eb33;color:#fff}.act-btn.outline{background:#fff;border:1px solid #e2e8f0;color:#1e293b}.act-btn.full-width{width:100%}@media (max-width:768px){.rip-panel{border-radius:20px 20px 0 0;bottom:0;left:0;max-height:70vh;right:0;top:auto;width:100%}.tab-text{font-size:11px}}.quick-actions-bar{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid #fff9;border-radius:10px;box-shadow:0 4px 15px #0000001a;display:flex;gap:12px;height:50px;left:100px;max-width:calc(100vw - 100px);padding:0 12px;position:absolute;right:20px;top:1px;transition:left .3s ease,right .3s ease;z-index:25}.quick-actions-bar.full-width{left:20px}.qa-title{border-right:2px solid #e2e8f0;border-right:2px solid var(--border);color:var(--text-main);flex-shrink:0;font-size:13px;gap:4px;padding-right:12px;white-space:nowrap}.qa-buttons{-ms-overflow-style:none;gap:8px;padding:2px 10px 2px 0}.qa-buttons,.qa-scroll-container{display:flex;flex:1 1;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.qa-scroll-container{-webkit-overflow-scrolling:touch;align-items:center;height:100%;white-space:nowrap}.qa-buttons::-webkit-scrollbar,.qa-scroll-container::-webkit-scrollbar{display:none}.qa-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;color:#1e293b;color:var(--text-main);cursor:pointer;display:flex;flex-shrink:0;font-size:12px;font-weight:600;gap:6px;padding:7px 14px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.qa-btn:hover{background:#2563eb;background:var(--primary);border-color:#2563eb;border-color:var(--primary);box-shadow:0 6px 16px #2563eb4d;color:#fff;transform:translateY(-2px)}.qa-btn:active{transform:translateY(0)}.qa-btn svg{flex-shrink:0}@media (max-width:1200px){.quick-actions-bar{left:320px}.quick-actions-bar.full-width{left:20px}}@media (max-width:1024px){.quick-actions-bar{top:85px}.qa-btn{font-size:11px;padding:6px 12px}}@media (max-width:768px){.quick-actions-bar{align-items:stretch;flex-direction:column;left:10px;padding:12px;right:10px;top:130px}.quick-actions-bar.full-width{left:10px}.qa-title{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border);border-right:none;margin-bottom:8px;padding-bottom:8px;padding-right:0}.qa-buttons{flex-wrap:nowrap;gap:6px;overflow-x:auto;padding-bottom:4px}}@media (max-width:480px){.qa-btn span{display:none}.qa-btn{justify-content:center;min-width:40px;padding:8px}.qa-title{font-size:12px}}@media (max-width:768px){.floating-filter-toggle-btn{align-items:center;background:#2563eb;background:var(--primary);border:none;border-radius:50%;bottom:20px;box-shadow:0 4px 12px #2563eb66;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;left:20px;position:absolute;transition:all .2s;width:48px;z-index:25}.floating-filter-toggle-btn:hover{box-shadow:0 6px 16px #2563eb80;transform:scale(1.05)}}.qa-btn.qa-teal:hover svg{color:#0d9488}.advanced-map-layout.viewer-full-mode .map-container{height:100vh!important;margin-left:0!important;width:100vw!important}.logistics-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f172a99;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1050}.logistics-modal-content{animation:slideUp .3s cubic-bezier(.16,1,.3,1);background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:1100px;overflow-y:auto;width:100%}.modal-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;padding:20px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:20}.modal-header h3{color:#1e293b;font-size:18px;font-weight:700;margin:0}.close-btn{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:flex;font-size:24px;justify-content:center;transition:color .2s}.close-btn:hover{color:#ef4444}.modal-body{background:#fff;padding:32px}.form-grid-3{grid-gap:24px;grid-template-columns:repeat(3,1fr)}.form-grid-2,.form-grid-3{display:grid;gap:24px;margin-bottom:24px}.form-grid-2{grid-gap:24px;grid-template-columns:repeat(2,1fr)}.form-grid-1{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;margin-bottom:24px}.form-group{gap:8px}.form-group label{letter-spacing:.02em}.form-control{background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;font-size:14px;padding:10px 14px;transition:all .2s ease}.form-control:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.form-control::placeholder{color:#94a3b8}.date-time-group{display:flex;gap:12px}.date-time-group input[type=date]{flex:2 1}.date-time-group select{flex:1 1}.file-input-wrapper{border:1px solid #cbd5e1;border-radius:8px;display:flex;overflow:hidden;transition:all .2s}.file-input-wrapper:hover{border-color:#94a3b8}.file-label-btn{background-color:#f1f5f9;border-right:1px solid #cbd5e1;color:#475569;cursor:pointer;font-size:13px;font-weight:600;padding:10px 16px;transition:background .2s;white-space:nowrap}.file-label-btn:hover{background-color:#e2e8f0}.file-text{background:#fff;color:#64748b;flex-grow:1;font-size:14px;overflow:hidden;padding:10px 14px;text-overflow:ellipsis;white-space:nowrap}.real-map-container{border:1px solid #e2e8f0;border-radius:12px;height:350px;margin-top:10px;overflow:hidden;position:relative;width:100%}.map-search-overlay{left:50%;position:absolute;top:10px;transform:translateX(-50%);width:300px;z-index:10}.map-search-input{border:1px solid #cbd5e1;border-radius:20px;box-shadow:0 4px 6px -1px #0000001a;font-size:14px;outline:none;padding:10px 16px;width:100%}.modal-footer{background-color:#f8fafc;border-radius:0 0 12px 12px;border-top:1px solid #e2e8f0;padding:24px 32px}.btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;min-width:120px;padding:10px 24px;text-transform:uppercase;transition:all .2s}.btn-submit{background-color:#4f46e5;box-shadow:0 4px 6px -1px #4f46e533}.btn-submit:hover{background-color:#4338ca;transform:translateY(-1px)}.btn-cancel{background-color:#fff;border:1px solid #cbd5e1;color:#475569}.btn-cancel:hover{background-color:#f1f5f9;border-color:#94a3b8;color:#1e293b}@media (max-width:768px){.logistics-modal-content{border-radius:0;max-height:100vh}.form-grid-2,.form-grid-3{gap:16px;grid-template-columns:1fr}.modal-body{padding:20px}.modal-footer{flex-direction:column-reverse;padding:20px}.btn{width:100%}}.add-route-layout{display:flex;gap:24px;height:100%}.route-form-section{display:flex;flex:1 1;flex-direction:column;gap:16px;min-width:320px}.route-map-section{border:1px solid #e2e8f0;border-radius:8px;flex:2 1;overflow:hidden}.stop-input-group{align-items:center;display:flex;gap:8px}.stop-input-group>div{flex-grow:1}.btn-icon-add{align-items:center;background-color:#4f46e5;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;transition:.2s;width:40px}.btn-icon-add:hover{background-color:#4338ca}.stops-list{border:1px solid #f1f5f9;border-radius:6px;margin-top:10px;max-height:100px;overflow-y:auto}.stop-item{align-items:center;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;font-size:13px;justify-content:space-between;padding:8px 12px}.stop-item:last-child{border-bottom:none}.stop-text{align-items:center;color:#334155;display:flex;gap:8px;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stop-remove{background:none;border:none;color:#ef4444;cursor:pointer;padding:4px}.stop-remove:hover{color:#b91c1c}.route-stats-box{background-color:#eff6ff;border:1px solid #dbeafe;border-radius:8px;display:flex;justify-content:space-between;margin-top:auto;padding:12px}.route-stats-box .stat{display:flex;flex-direction:column}.route-stats-box span{color:#64748b;font-size:11px;text-transform:uppercase}.route-stats-box strong{color:#1e3a8a;font-size:16px}@media (max-width:1024px){.add-route-layout{flex-direction:column}.route-map-section{min-height:300px}}.pac-container{border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;font-family:Inter,sans-serif;z-index:1060!important}.pac-item{cursor:pointer;font-size:13px;padding:8px 12px}.pac-item:hover{background-color:#f1f5f9}.pac-item-query{color:#1e293b;font-size:13px;font-weight:600}.map-wrapper-trip{border:2px solid #e2e8f0;border-radius:10px;overflow:hidden}:root{--modal-primary:#4f46e5;--modal-primary-hover:#4338ca;--modal-bg-overlay:#0f172aa6;--modal-bg-surface:#fff;--modal-bg-subtle:#f8fafc;--modal-text-main:#0f172a;--modal-text-sec:#475569;--modal-text-muted:#94a3b8;--modal-border:#e2e8f0;--modal-border-focus:#4f46e5;--modal-radius:12px;--modal-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--modal-transition:all 0.2s cubic-bezier(0.4,0,0.2,1)}.modal-overlay{animation:fadeIn .3s ease-out;background-color:#0f172aa6;background-color:var(--modal-bg-overlay);overflow-y:auto;z-index:9999}.modal-content{animation:slideUp .3s cubic-bezier(.16,1,.3,1);background:var(--modal-bg-surface);border-radius:12px;border-radius:var(--modal-radius);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--modal-shadow);display:flex;flex-direction:column;margin:auto;position:relative;width:100%}.modal-content.geofence-modal{max-width:900px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content h3{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--modal-border);color:#0f172a;color:var(--modal-text-main);display:flex;font-size:1.25rem;font-weight:700;gap:10px;margin:0 0 24px;padding-bottom:16px}.modal-content h3 svg{color:#4f46e5;color:var(--modal-primary)}.modal-content h4{border-bottom:1px dashed #e2e8f0;border-bottom:1px dashed var(--modal-border);color:#475569;color:var(--modal-text-sec);font-size:.95rem;font-weight:600;letter-spacing:.05em;margin:24px 0 16px;padding-bottom:8px;text-transform:uppercase}.grid-cols-1,.md\:grid-cols-2{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr}.responsive-grid{grid-gap:20px;gap:20px}.col-span-full{grid-column:1/-1}@media (min-width:640px){.md\:grid-cols-2,.responsive-grid{grid-template-columns:repeat(2,1fr)}}.form-group label{color:#475569;color:var(--modal-text-sec);font-size:.875rem;font-weight:500}.input-field{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--modal-border);border-radius:8px;box-sizing:border-box;color:#0f172a;color:var(--modal-text-main);font-size:.9375rem;padding:10px 14px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--modal-transition);width:100%}.input-field:focus{border-color:#4f46e5;border-color:var(--modal-primary);box-shadow:0 0 0 3px #4f46e51a;outline:none}.input-disabled,.input-field:disabled,.input-field[readonly]{background-color:#f8fafc;background-color:var(--modal-bg-subtle);border-color:#e2e8f0;border-color:var(--modal-border);color:#94a3b8;color:var(--modal-text-muted);cursor:not-allowed}.input-field::placeholder{color:#cbd5e1}textarea.input-field{min-height:80px;resize:vertical}.form-hint{color:#94a3b8;color:var(--modal-text-muted);font-size:.75rem;margin-top:6px}select.input-field{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.dropdown-list{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--modal-border);border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;left:0;list-style:none;margin-top:4px;max-height:200px;overflow-y:auto;padding:4px 0;position:absolute;right:0;top:100%;z-index:50}.dropdown-list li{color:#0f172a;color:var(--modal-text-main);cursor:pointer;font-size:.9rem;padding:8px 14px;transition:background .1s}.dropdown-list li:hover{background-color:#f8fafc;background-color:var(--modal-bg-subtle);color:#4f46e5;color:var(--modal-primary)}.button-group-center{border-top:1px solid #e2e8f0;border-top:1px solid var(--modal-border);gap:12px;margin-top:32px;padding-top:20px}.btn-primary,.btn-secondary{border-radius:8px;font-weight:600;padding:10px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--modal-transition)}.btn-primary{background-color:#4f46e5;background-color:var(--modal-primary);box-shadow:0 1px 2px #0000000d}.btn-primary:hover{background-color:#4338ca;background-color:var(--modal-primary-hover);transform:translateY(-1px)}.btn-secondary{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--modal-border);color:#475569;color:var(--modal-text-sec)}.btn-secondary:hover{background-color:#f8fafc;background-color:var(--modal-bg-subtle);border-color:#cbd5e1;color:#0f172a;color:var(--modal-text-main)}.modal-content button.text-gray-500{background:none;border:none;color:#94a3b8;color:var(--modal-text-muted);cursor:pointer;padding:4px;transition:color .2s}.modal-content button.text-gray-500:hover{color:#ef4444}.geofence-map-container{background:#f1f5f9;border:1px solid #e2e8f0;border:1px solid var(--modal-border);border-radius:12px;height:400px;margin-bottom:20px;overflow:hidden;width:100%}.global-message{border-radius:6px;font-size:.875rem;margin-top:10px;padding:10px 14px}.global-message.success{background-color:#ecfdf5;color:#059669}.global-message.error{background-color:#fef2f2;color:#dc2626}@media (max-width:768px){.modal-overlay{align-items:flex-end;padding:10px}.modal-content{border-radius:16px 16px 0 0;margin-bottom:0;max-width:100%;padding:24px}.modal-overlay{align-items:center}.modal-content{border-radius:12px;border-radius:var(--modal-radius);max-height:90vh;overflow-y:auto}.button-group-center{flex-direction:column-reverse;gap:12px}.btn-primary,.btn-secondary{width:100%}.geofence-map-container{height:300px}}@media (max-width:480px){.modal-content{padding:20px}.modal-content h3{font-size:1.1rem;margin-bottom:16px}.input-field{padding:10px}}.sidebar-container{background-color:#0f172a;border-right:1px solid #1e293b;box-sizing:border-box;display:flex;transition:all .3s ease;z-index:1000}.sidebar-brand{align-items:center;border-bottom:1px solid #1e293b;color:#fff;display:flex;flex-shrink:0;gap:12px;margin-bottom:10px;padding:24px 20px}.brand-icon{color:#4f46e5}.brand-name{font-size:18px;font-weight:700;letter-spacing:.5px}.sidebar-nav{-ms-overflow-style:none;display:flex;gap:8px;overflow:auto;padding:10px;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{background:#0000;border:none;border-radius:8px;color:#94a3b8;flex-shrink:0;font-family:inherit;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.nav-item:hover{background-color:#ffffff0d;color:#e2e8f0}.nav-item.active{background:linear-gradient(90deg,#4f46e5,#4338ca);box-shadow:0 4px 12px #4f46e54d}.icon-wrapper{align-items:center;display:flex;justify-content:center}.nav-label{font-size:14px;font-weight:500}.active-dot{display:none}@media screen and (min-width:769px){.sidebar-container{flex-direction:column;height:100vh;left:0;position:fixed;top:0;width:260px}.sidebar-nav{flex-direction:column;height:100%;overflow-x:hidden;overflow-y:auto}.nav-item{gap:12px;justify-content:flex-start;padding:12px 16px;width:100%}.active-dot{background-color:#fff;border-radius:50%;box-shadow:0 0 8px #ffffff80;display:block;height:6px;position:absolute;right:12px;width:6px}}@media screen and (max-width:768px){.sidebar-container{border-right:none;border-top:1px solid #1e293b;bottom:0;box-shadow:0 -4px 20px #0003;height:70px;justify-content:center;left:0;padding:0;position:fixed;width:100%}.sidebar-brand{display:none}.sidebar-nav{flex-direction:row;gap:0;justify-content:space-between;overflow-x:auto;overflow-y:hidden;padding:0 10px;width:100%}.sidebar-nav>*{flex:1 1;min-width:65px}.nav-item{background:#0000!important;border-radius:0;box-shadow:none!important;flex-direction:column;gap:4px;justify-content:center;padding:8px 0}.icon-wrapper svg{height:22px;transition:transform .2s;width:22px}.nav-label{font-size:10px;font-weight:500;text-align:center}.nav-item.active{color:#4f46e5}.nav-item.active .icon-wrapper svg{fill:#4f46e533;transform:translateY(-2px)}.nav-item:hover{background-color:initial;color:#fff}}@media screen and (max-width:380px){.sidebar-container{height:60px}.nav-label{font-size:9px;transform:scale(.9)}.icon-wrapper svg{height:20px;width:20px}.sidebar-nav{justify-content:flex-start}.nav-item{padding:0 8px}}body{background-color:#f3f4f6;color:#1f2937;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0}.ad-wrapper{display:flex;min-height:100vh;padding-left:260px;transition:padding-left .3s ease}.ad-main-content{display:flex;flex:1 1;flex-direction:column;height:100vh;overflow-y:auto;width:100%}.ad-tab-container{box-sizing:border-box;margin:0 auto;max-width:1600px;padding:32px 40px;width:100%}.ad-alert{align-items:center;animation:slideInRight .3s ease-out;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;color:#fff;display:flex;font-size:14px;font-weight:600;padding:16px 24px;position:fixed;right:24px;top:24px;z-index:9999}.ad-alert-success{background-color:#10b981;border-left:4px solid #065f46}.ad-alert-error{background-color:#ef4444;border-left:4px solid #7f1d1d}.ad-quick-actions-card{animation:fadeIn .3s ease-in-out;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:28px;padding:24px}.ad-quick-actions-card-header{border-bottom:1px dashed #e5e7eb;margin-bottom:20px;padding-bottom:16px}.ad-quick-actions-card-header h2{color:#111827;font-size:20px;font-weight:700;margin:0 0 4px}.ad-quick-actions-card-header p{color:#6b7280;font-size:14px;margin:0}.ad-quick-actions-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));width:100%}.ad-quick-actions-grid>button,.ad-quick-actions-grid>div{align-items:center;-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 2px #0000000a;box-sizing:border-box;cursor:pointer;display:flex;gap:12px;justify-content:flex-start;min-height:70px;padding:16px 20px;text-align:left;transition:all .25s cubic-bezier(.4,0,.2,1);width:100%}.ad-quick-actions-grid h4,.ad-quick-actions-grid span{color:#374151;flex-grow:1;font-size:15px;font-weight:600;margin:0}.ad-quick-action-icon{align-items:center;background:#eef2ff;border:1px solid #e0e7ff;border-radius:8px;color:#4f46e5;display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.ad-quick-actions-grid>button:hover,.ad-quick-actions-grid>div:hover{border-color:#4f46e5;box-shadow:0 5px 10px -2px #00000014;transform:translateY(-2px)}.ad-quick-actions-grid>button:hover .ad-quick-action-icon,.ad-quick-actions-grid>div:hover .ad-quick-action-icon{background:#4f46e5;color:#fff}.ad-allocation-container{margin-bottom:32px}.ad-forms-wrapper{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.ad-form-box{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column;padding:28px}.ad-form-header{align-items:center;border-bottom:1px solid #f3f4f6;color:#111827;display:flex;font-size:18px;font-weight:700;gap:12px;margin:0 0 24px;padding-bottom:16px}.ad-form-header svg{color:#4f46e5}.ad-input-group{margin-bottom:20px}.ad-input-group label{color:#4b5563;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.ad-input-wrapper{position:relative}.ad-input{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-size:14px;padding:12px 16px;transition:all .2s;width:100%}.ad-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.ad-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;justify-content:center;margin-top:12px;padding:14px 24px;transition:all .2s;width:100%}.ad-btn-primary{background-color:#4f46e5;color:#fff}.ad-btn-primary:hover{background-color:#4338ca;box-shadow:0 4px 6px -1px #4f46e533}.ad-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;left:0;list-style:none;margin:0;max-height:220px;overflow-y:auto;padding:8px 0;position:absolute;right:0;top:110%;z-index:50}.ad-dropdown li{border-bottom:1px solid #f3f4f6;color:#374151;cursor:pointer;display:flex;flex-direction:column;font-size:14px;padding:12px 16px}.ad-dropdown li:last-child{border-bottom:none}.ad-dropdown li:hover{background:#eef2ff;color:#4f46e5}.ad-dropdown li span{font-weight:500}.ad-dropdown li small{color:#9ca3af;font-size:12px;margin-top:2px}.ad-full-width-card{width:100%}.ad-error-screen,.ad-loading-screen{align-items:center;background:#f9fafb;color:#6b7280;display:flex;flex-direction:column;font-size:16px;height:100vh;justify-content:center}.ad-spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#4f46e5;height:48px;margin-bottom:16px;width:48px}@media screen and (max-width:1200px){.ad-quick-actions-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}@media screen and (max-width:992px){.ad-tab-container{padding:24px}.ad-quick-actions-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media screen and (max-width:768px){.ad-wrapper{flex-direction:column;padding-bottom:80px;padding-left:0}.ad-tab-container{padding:16px}.ad-quick-actions-grid{gap:12px;grid-template-columns:1fr}.ad-quick-actions-card{margin-bottom:20px;padding:16px}.ad-quick-actions-card-header h2{font-size:18px}.ad-quick-actions-card-header p{font-size:13px}.ad-forms-wrapper{gap:16px;grid-template-columns:1fr}.ad-form-box{padding:20px}.ad-alert{justify-content:center;left:5%;right:5%;width:90%}}@media screen and (max-width:480px){.ad-quick-actions-grid>button,.ad-quick-actions-grid>div{font-size:14px;min-height:60px;padding:12px 16px}.ad-quick-action-icon{height:32px;width:32px}}.credit-banner{animation:fadeInDown .5s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.btn-primary:disabled{background-color:#9ca3af;opacity:.6}.btn-primary:disabled:hover{background-color:#9ca3af;box-shadow:none;transform:none}.qa-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #0000000d;height:-webkit-fit-content;height:fit-content;padding:24px;transition:all .3s ease}.qa-container:hover{border-color:#cbd5e1;box-shadow:0 10px 25px #00000014}.qa-header{border-bottom:1px dashed #e2e8f0;margin-bottom:24px;padding-bottom:16px}.qa-title{align-items:center;color:#1e293b;display:flex;font-size:18px;font-weight:700;letter-spacing:-.02em;margin:0}.qa-subtitle{color:#64748b;font-size:13px;font-weight:500;margin:4px 0 0}.qa-grid{display:flex;flex-direction:row;gap:16px}.qa-card-btn{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;justify-content:flex-start;overflow:hidden;padding:16px;position:relative;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);width:100%}.qa-card-btn,.qa-icon-box{align-items:center;display:flex}.qa-icon-box{background-color:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 2px 4px #0000000a;color:#64748b;flex-shrink:0;height:40px;justify-content:center;margin-right:14px;transition:all .2s ease;width:40px}.qa-text-group{align-items:flex-start;display:flex;flex:1 1;flex-direction:column}.qa-label{color:#334155;font-size:14px;font-weight:600;transition:color .2s}.qa-arrow{color:#cbd5e1;opacity:0;transform:translateX(-10px);transition:all .3s ease}.qa-card-btn:hover{background-color:#fff;border-color:#4f46e5;box-shadow:0 8px 16px -4px #4f46e526;transform:translateY(-3px)}.qa-card-btn:hover .qa-icon-box{background-color:#4f46e5;border-color:#4f46e5;color:#fff;transform:scale(1.05)}.qa-card-btn:hover .qa-label{color:#4f46e5}.qa-card-btn:hover .qa-arrow{color:#4f46e5;opacity:1;transform:translateX(0)}.qa-card-btn:active{background-color:#f1f5f9;box-shadow:none;transform:translateY(-1px)}@media screen and (min-width:640px){.qa-grid{grid-template-columns:repeat(2,1fr)}}@media screen and (max-width:480px){.qa-container{padding:16px}.qa-card-btn{padding:12px}.qa-icon-box{height:36px;margin-right:12px;width:36px}.qa-label{font-size:13px}}.task-management{margin:0 auto;max-width:1400px;padding:20px}.task-header{margin-bottom:24px}.task-header h1{color:#1a1a2e;font-size:28px;font-weight:700;margin:0}.task-header p{color:#666;margin:4px 0 0}.task-tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:12px;margin-bottom:24px;padding-bottom:12px}.tab-btn{align-items:center;background:#f5f5f5;border-radius:8px;color:#666;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease}.tab-btn:hover{background:#e8e8e8}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2)}.task-form-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:32px}.task-form{display:flex;flex-direction:column;gap:20px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-group{display:flex;flex-direction:column;gap:6px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:8px;font-size:14px;padding:12px 14px;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{min-height:80px}.btn-submit{align-self:flex-start;font-size:15px;font-weight:600;padding:14px 28px;transition:all .3s ease}.btn-submit:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.btn-submit:disabled{transform:none}.task-list-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:24px}.task-filters{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.task-filters select{border:1px solid #ddd;border-radius:8px;font-size:14px;min-width:150px;padding:10px 16px}.btn-refresh{background:#f0f0f0;border:none}.btn-refresh:hover{background:#e0e0e0}.task-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.task-card{background:#fafafa;border:1px solid #eee;border-radius:12px;padding:20px;transition:all .3s ease}.task-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-4px)}.task-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.badge{padding:4px 10px}.badge-cancelled{background:#e2e3e5;color:#383d41}.priority{padding:4px 10px}.task-title{color:#1a1a2e;font-size:16px;font-weight:600;margin:0 0 4px}.task-type{color:#667eea;font-size:13px;margin:0 0 12px;text-transform:capitalize}.task-info{display:flex;flex-direction:column;gap:8px}.info-row{align-items:center;color:#555;display:flex;font-size:13px;gap:10px}.info-row i{color:#888;width:16px}.task-actions{border-top:1px solid #eee;margin-top:16px;padding-top:16px}.btn-verify{align-items:center;background:linear-gradient(135deg,#11998e,#38ef7d);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px;transition:all .3s ease;width:100%}.btn-verify:hover{box-shadow:0 4px 15px #11998e66;transform:translateY(-2px)}.verification-status{align-items:center;border-radius:8px;display:flex;font-size:13px;font-weight:500;gap:8px;margin-top:12px;padding:8px 12px;text-transform:capitalize}.verification-status.approved{background:#d4edda;color:#155724}.verification-status.rejected{background:#f8d7da;color:#721c24}.task-photos{color:#667eea;font-size:12px;margin-top:12px}.modal{max-width:600px}.modal-body h3{font-size:18px;margin:0 0 16px}.modal-body p{font-size:14px;margin:8px 0}.field-notes{background:#f5f5f5;border-radius:8px;margin:16px 0;padding:12px}.field-notes p{margin:8px 0 0}.photos-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin:16px 0}.photo-item{text-align:center}.photo-item img{border-radius:8px;height:80px;object-fit:cover;width:100%}.photo-item span{color:#666;font-size:11px;text-transform:capitalize}.btn-cancel{transition:all .3s ease}.loading,.no-tasks{font-size:15px;padding:40px}@media (max-width:768px){.task-management{padding:16px}.task-header h1{font-size:22px}.task-tabs{flex-direction:column}.tab-btn{justify-content:center}.task-form-container,.task-list-container{padding:20px}.form-row,.task-grid{grid-template-columns:1fr}.modal{margin:16px}}@media (max-width:480px){.task-filters{flex-direction:column}.btn-refresh,.task-filters select{width:100%}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}.my-tasks{margin:0 auto;max-width:1200px;padding:20px}.my-tasks-header{margin-bottom:24px}.my-tasks-header h1{color:#1a1a2e;font-size:28px;font-weight:700;margin:0}.my-tasks-header p{color:#666;margin:4px 0 0}.task-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:24px}.stat-card{background:#fff;box-shadow:0 2px 10px #0000000f;gap:16px;padding:20px}.stat-card,.stat-card i{align-items:center;border-radius:12px;display:flex}.stat-card i{font-size:28px;height:50px;justify-content:center;width:50px}.stat-card.pending i{background:#fff3cd;color:#856404}.stat-card.progress i{background:#cce5ff;color:#004085}.stat-card.completed i{background:#d4edda;color:#155724}.stat-info{display:flex;flex-direction:column}.stat-number{color:#1a1a2e;font-size:24px;font-weight:700}.stat-label{color:#666;font-size:13px}.my-tasks-filters{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.my-tasks-filters select{min-width:150px}.btn-refresh,.my-tasks-filters select{background:#fff;border:1px solid #ddd;border-radius:8px;font-size:14px;padding:10px 16px}.btn-refresh{align-items:center;cursor:pointer;display:flex;gap:6px;transition:all .3s ease}.btn-refresh:hover{background:#f5f5f5}.my-tasks-list{display:flex;flex-direction:column;gap:16px}.my-task-card{background:#fff;border-radius:16px;box-shadow:0 2px 15px #0000000f;overflow:hidden;transition:all .3s ease}.my-task-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.my-task-card.urgent{border-left:4px solid #c62828}.my-task-header{align-items:center;background:#fafafa;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px 20px}.task-badges{display:flex;gap:8px}.badge{border-radius:20px;font-size:11px;font-weight:600;padding:4px 12px}.badge-pending{background:#fff3cd;color:#856404}.badge-accepted{background:#d4edda;color:#155724}.badge-progress{background:#cce5ff;color:#004085}.badge-completed{background:#d1ecf1;color:#0c5460}.badge-rejected{background:#f8d7da;color:#721c24}.priority{border-radius:20px;font-size:11px;font-weight:600;padding:4px 12px}.priority-low{background:#e8f5e9;color:#2e7d32}.priority-medium{background:#fff8e1;color:#f57f17}.priority-high{background:#ffebee;color:#c62828}.priority-urgent{animation:pulse 2s infinite;background:#c62828;color:#fff}.task-date{color:#666;font-size:13px}.my-task-body{padding:20px}.my-task-body h3{color:#1a1a2e;font-size:18px;font-weight:600;margin:0 0 4px}.task-type-label{color:#667eea;font-size:13px;font-weight:500;margin:0 0 12px;text-transform:capitalize}.task-description{color:#555;font-size:14px;line-height:1.5;margin:0 0 16px}.task-details{display:flex;flex-direction:column;gap:10px}.detail-item{align-items:flex-start;color:#444;display:flex;font-size:14px;gap:12px}.detail-item i{color:#667eea;margin-top:2px;width:18px}.detail-item a{color:#667eea;text-decoration:none}.detail-item a:hover{text-decoration:underline}.btn-navigate{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:inline-flex;font-size:14px;font-weight:500;gap:8px;margin-top:16px;padding:10px 20px;text-decoration:none;transition:all .3s ease}.btn-navigate:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.my-task-footer{background:#fafafa;border-top:1px solid #eee;padding:16px 20px}.action-buttons{gap:12px}.btn-accept,.btn-complete,.btn-reject,.btn-start{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 20px;transition:all .3s ease}.btn-accept{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.btn-accept:hover{box-shadow:0 4px 15px #11998e66;transform:translateY(-2px)}.btn-reject{background:#f5f5f5;border:1px solid #ddd;color:#c62828}.btn-reject:hover{background:#ffebee}.btn-start{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;width:100%}.btn-start:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.btn-complete{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;width:100%}.btn-complete:hover{box-shadow:0 4px 15px #f5576c66;transform:translateY(-2px)}.btn-accept:disabled,.btn-complete:disabled,.btn-start:disabled{cursor:not-allowed;opacity:.6;transform:none}.completion-info{align-items:center;color:#155724;display:flex;font-size:13px;gap:8px}.completion-info i{color:#28a745}.verification-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:500;gap:6px;margin-top:12px;padding:6px 12px;text-transform:capitalize}.verification-badge.pending{background:#fff3cd;color:#856404}.verification-badge.approved{background:#d4edda;color:#155724}.verification-badge.rejected{background:#f8d7da;color:#721c24}.modal-overlay{background:#00000080;bottom:0;left:0;padding:20px;right:0;top:0}.modal{background:#fff;border-radius:16px;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal.modal-sm{max-width:400px}.modal-header{border-bottom:1px solid #eee;padding:20px 24px}.modal-header h2{color:#1a1a2e;font-size:20px;margin:0}.modal-close{background:none;color:#888;font-size:20px}.modal-close:hover{color:#333}.modal-body{padding:24px}.modal-body h3{color:#1a1a2e;font-size:16px;margin:0 0 20px}.modal-body p{color:#555;margin:0 0 16px}.form-group{margin-bottom:16px}.form-group label{color:#444;margin-bottom:6px}.form-group textarea{border:1px solid #ddd;border-radius:8px;font-family:inherit;font-size:14px;padding:12px;resize:vertical;width:100%}.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.photo-upload{margin-bottom:12px}.photo-upload input[type=file]{display:none}.upload-btn{align-items:center;background:#f5f5f5;border:2px dashed #ddd;border-radius:8px;color:#666;cursor:pointer;display:inline-flex;font-size:14px;gap:8px;padding:12px 20px;transition:all .3s ease}.upload-btn:hover{background:#eee;border-color:#667eea;color:#667eea}.uploaded-photos{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin-top:12px}.uploaded-photo{border:1px solid #eee;border-radius:8px;overflow:hidden;position:relative}.uploaded-photo img{height:80px;object-fit:cover;width:100%}.uploaded-photo select{background:#f5f5f5;border:none;font-size:11px;padding:4px;width:100%}.remove-photo{align-items:center;background:#c62828e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:10px;height:20px;justify-content:center;position:absolute;right:4px;top:4px;width:20px}.modal-footer{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.btn-cancel{background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;font-size:14px;padding:10px 20px}.btn-cancel:hover{background:#e0e0e0}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.btn-reject-confirm{background:#c62828;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px}.btn-reject-confirm:disabled{cursor:not-allowed;opacity:.6}.loading,.no-tasks{color:#888;padding:60px 20px;text-align:center}.no-tasks i{color:#ddd;font-size:48px;margin-bottom:16px}.no-tasks p{font-size:16px;margin:0}@media (max-width:768px){.my-tasks{padding:16px}.my-tasks-header h1{font-size:22px}.task-stats{grid-template-columns:1fr}.my-task-header{align-items:flex-start;gap:8px}.action-buttons,.my-task-header{flex-direction:column}.btn-accept,.btn-reject{flex:none;width:100%}}@media (max-width:480px){.my-tasks-filters{flex-direction:column}.btn-refresh,.my-tasks-filters select{width:100%}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}.um-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.um-modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0000001a;padding:0;width:95%}.um-modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #eee;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:15px 20px}.um-modal-header h3{color:#333;font-size:1.25rem;margin:0}.um-close-icon{background:#0000;border:none;color:#666;cursor:pointer;transition:color .2s}.um-close-icon:hover{color:#f44336}.um-form-section{border-bottom:1px solid #f0f0f0;padding:20px}.um-section-title{border-left:4px solid #2196f3;color:#2196f3;font-size:1rem;letter-spacing:.5px;margin:0 0 15px;padding-left:10px;text-transform:uppercase}.um-form-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.um-form-group{display:flex;flex-direction:column}.um-form-group label{color:#555;font-size:.85rem;font-weight:600;margin-bottom:5px}.um-input,.um-select-full{border:1px solid #ddd;border-radius:4px;font-size:.9rem;outline:none;padding:8px 12px;transition:border-color .2s}.um-input:focus,.um-select-full:focus{border-color:#2196f3}.um-checkbox-label{align-items:center;color:#444;cursor:pointer;display:flex;font-size:.85rem;gap:8px;margin-bottom:6px;padding:4px 0}.um-checkbox-label input[type=checkbox]{cursor:pointer;height:16px;width:16px}.um-modal-actions{background:#f8f9fa;border-radius:0 0 8px 8px;display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.um-btn{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 20px;transition:opacity .2s}.um-btn:hover{opacity:.9}.um-btn-primary{background:#2196f3;color:#fff}.um-btn-secondary{background:#e0e0e0;color:#333}.um-btn-delete{background:#f44336;border-radius:4px;color:#fff;padding:0 10px}.um-btn-sm{font-size:.75rem;padding:4px 10px}@media (max-width:768px){.um-modal-content{border-radius:0;height:100%;max-height:100vh!important;width:100%}.um-form-section div[style*="grid-template-columns: repeat(3, 1fr)"], .um-form-section div[style*="grid-template-columns: repeat(4, 1fr)"]{grid-template-columns:repeat(2,1fr)!important}}@media (max-width:480px){.um-form-section div[style*="grid-template-columns: repeat(2, 1fr)"]{grid-template-columns:1fr!important}}.protocol-manager{--primary-blue:#2563eb;--primary-blue-hover:#1d4ed8;--primary-blue-light:#dbeafe;--success-green:#10b981;--success-green-light:#d1fae5;--danger-red:#ef4444;--danger-red-light:#fee2e2;--warning-orange:#f59e0b;--info-purple:#8b5cf6;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-hover:#e0f2fe;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-muted:#64748b;--border-light:#e2e8f0;--border-medium:#cbd5e1;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 2px 8px #00000014;--shadow-md:0 4px 16px #0000001a;--shadow-hover:0 6px 20px #0000001f;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1);background:var(--bg-secondary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh}.protocol-form,.protocol-list{margin:0 auto;max-width:1400px;padding:2rem}.protocol-manager h2{align-items:center;color:var(--text-primary);display:flex;font-size:2rem;font-weight:800;gap:.75rem;margin:0 0 2rem}.protocol-manager h3{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.protocol-manager h5{color:var(--text-primary);font-size:1.125rem;font-weight:600}.d-flex{display:flex}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.mb-0{margin-bottom:0}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.py-3{padding-bottom:1rem;padding-top:1rem}.py-5{padding-bottom:3rem;padding-top:3rem}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.fw-bold{font-weight:700}.small{font-size:.875rem}.ms-2{margin-left:.5rem}.me-2{margin-right:.5rem}.cursor-pointer{cursor:pointer}.dashboard-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition)}.dashboard-card:hover{box-shadow:var(--shadow-md)}.card-header{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);border-bottom:2px solid var(--border-light);padding:1.25rem 1.75rem}.card-title{color:var(--text-primary);font-size:1.25rem;gap:.625rem;margin:0}.card-body{padding:1.75rem}.form-group{margin-bottom:1.5rem}.form-label{color:var(--text-primary);font-size:.9375rem;margin-bottom:.5rem}.form-hint{color:var(--text-tertiary);display:block;font-size:.8125rem;font-style:italic;margin-top:.375rem}.form-control{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:.9375rem;padding:.875rem 1rem;transition:var(--transition);width:100%}.form-control::placeholder{color:var(--text-tertiary)}.form-control:hover{border-color:var(--border-medium)}.form-control:focus{background:var(--bg-primary);border-color:var(--primary-blue);box-shadow:0 0 0 4px #2563eb1f;outline:none}.form-control:disabled{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed;opacity:.7}textarea.form-control{min-height:100px;resize:vertical}.form-check{align-items:center;display:flex;gap:.75rem}.form-check-input{-webkit-appearance:none;appearance:none;background:var(--bg-primary);border:2px solid var(--border-medium);border-radius:4px;cursor:pointer;height:20px;transition:var(--transition);width:20px}.form-check-input:checked{background:var(--primary-blue);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23fff'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 0 1 0 1.414l-8 8a1 1 0 0 1-1.414 0l-4-4a1 1 0 0 1 1.414-1.414L8 12.586l7.293-7.293a1 1 0 0 1 1.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");background-size:100%;border-color:var(--primary-blue)}.form-check-label{color:var(--text-primary);cursor:pointer;font-weight:600}.responsive-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr}@media (min-width:640px){.responsive-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.responsive-grid{grid-template-columns:repeat(3,1fr)}}.list-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr;margin-top:1rem}@media (min-width:640px){.list-grid{grid-template-columns:repeat(2,1fr)}}.list-item-card{background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:var(--radius-sm);padding:1rem 1.25rem;transition:var(--transition)}.list-item-card:hover{background:var(--bg-primary);border-color:var(--primary-blue-light)}.list-item-card code{background:var(--bg-secondary);border-radius:4px;color:var(--text-primary);font-family:Courier New,monospace;font-size:.875rem;font-weight:600;padding:.25rem .625rem}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:700;gap:.5rem;justify-content:center;padding:.875rem 1.75rem;transition:var(--transition);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary-blue) 0,var(--primary-blue-hover) 100%);box-shadow:0 4px 14px #2563eb4d;color:#020101}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #2563eb66;transform:translateY(-2px)}.btn-primary:disabled{background:var(--text-tertiary);box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-primary);border:2px solid var(--border-medium);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-secondary);transform:translateY(-1px)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.button-group-center{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.icon-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;display:inline-flex;justify-content:center;padding:.5rem;transition:var(--transition)}.icon-btn:hover{background:var(--primary-blue-light);color:var(--primary-blue)}.trash-icon{color:var(--danger-red)}.trash-icon:hover{background:var(--danger-red-light);color:#991b1b}.btn-close{background:#0000;border:none;color:inherit;cursor:pointer;float:right;font-size:1.5rem;line-height:1;padding:0}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.search-input-assets{background:var(--bg-primary);border:2px solid var(--border-light);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);flex:1 1;font-size:.9375rem;min-width:250px;padding:.875rem 1rem;transition:var(--transition)}.search-input-assets::placeholder{color:var(--text-tertiary)}.search-input-assets:focus{border-color:var(--primary-blue);box-shadow:0 0 0 4px #2563eb1f;outline:none}.filter-bar .form-control{flex-shrink:0;min-width:150px}.table-wrapper{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1.5rem;overflow-x:auto}.device-table{border-collapse:collapse;width:100%}.device-table td,.device-table th{border-bottom:1px solid var(--border-light);padding:1rem 1.25rem;text-align:left}.device-table th{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);color:var(--text-primary);font-size:.8125rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.device-table td{color:var(--text-secondary);font-size:.9375rem}.device-table tbody tr{transition:var(--transition)}.device-table tbody tr:hover{background:var(--bg-hover)}.device-table tbody tr:last-child td{border-bottom:none}.action-icons-container{align-items:center;display:flex;gap:.5rem}.badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.375rem .875rem;text-transform:uppercase;transition:var(--transition)}.bg-success{background:var(--success-green);color:#fff}.bg-secondary{background:var(--text-tertiary);color:#fff}.badge.cursor-pointer:hover{box-shadow:var(--shadow-sm);transform:scale(1.05)}.protocol-type-tcp{background:var(--success-green);color:#fff}.protocol-type-udp{background:var(--primary-blue);color:#fff}.protocol-type-http{background:var(--warning-orange);color:#fff}.protocol-type-https{background:var(--info-purple);color:#fff}.empty-state,.loading-container{background:var(--bg-primary);border:2px dashed var(--border-medium);border-radius:var(--radius-lg);margin:2rem 0;padding:4rem 2rem;text-align:center}.empty-state p,.loading-container p{color:var(--text-muted);font-size:1rem;margin:.5rem 0}.empty-state h3{color:var(--text-primary);margin:1rem 0}.spinner-icon{animation:spin 1s linear infinite;color:var(--primary-blue);margin:0 auto 1rem}.message{align-items:center;border-radius:var(--radius-sm);display:flex;font-weight:600;justify-content:space-between;margin-bottom:1.5rem;padding:1rem 1.5rem}.message.error{background:var(--danger-red-light);border:2px solid var(--danger-red);color:#991b1b}.spinner-border{animation:spin .75s linear infinite;border:2px solid;border-radius:50%;border-right:2px solid #0000;display:inline-block;height:1rem;width:1rem}.spinner-border-sm{border-width:2px;height:.875rem;width:.875rem}@media (max-width:1024px){.protocol-form,.protocol-list{padding:1.5rem}.protocol-manager h2{font-size:1.75rem}.responsive-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.protocol-form,.protocol-list{padding:1rem}.protocol-manager h2{align-items:flex-start;flex-direction:column;font-size:1.5rem;gap:.5rem}.d-flex.justify-content-between.align-items-center{align-items:stretch;flex-direction:column;gap:1rem}.filter-bar{flex-direction:column}.filter-bar .form-control,.search-input-assets{min-width:auto;width:100%}.button-group-center{flex-direction:column-reverse;gap:.75rem}.btn-primary,.btn-secondary{width:100%}.list-grid,.responsive-grid{grid-template-columns:1fr}.table-wrapper{border:none;border-radius:0;box-shadow:none}.device-table thead{display:none}.device-table tbody{display:block}.device-table tbody tr{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:block;margin-bottom:1rem;padding:1rem}.device-table tbody td{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:.75rem 0}.device-table tbody td:last-child{border-bottom:none}.device-table tbody td:before{color:var(--text-primary);content:attr(data-label);font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.action-icons-container{justify-content:flex-end;width:100%}.card-header{padding:1rem 1.25rem}.card-body{padding:1.25rem}}@media (max-width:480px){.protocol-form,.protocol-list{padding:.75rem}.protocol-manager h2{font-size:1.375rem}.form-control{font-size:.875rem;padding:.75rem .875rem}.btn-primary,.btn-secondary{font-size:.875rem;padding:.75rem 1.25rem}.card-body,.card-header{padding:1rem}.list-item-card{padding:.875rem 1rem}.device-table tbody tr{padding:.875rem}}:root{--ct-primary:#6366f1;--ct-primary-dark:#4f46e5;--ct-bg:#f3f4f6;--ct-card-bg:#fff;--ct-text-main:#1f2937;--ct-text-muted:#6b7280;--ct-border:#e5e7eb;--ct-green:#10b981;--ct-red:#ef4444}.ct-container{background-color:#f3f4f6;background-color:var(--ct-bg);font-family:Inter,sans-serif;min-height:100vh;padding:24px}.ct-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:24px}.ct-header-left h1{color:#1f2937;color:var(--ct-text-main);font-size:24px;font-weight:700;margin:0}.ct-header-left p{color:#6b7280;color:var(--ct-text-muted);font-size:14px;margin:4px 0 0}.ct-balance-card{align-items:center;background:linear-gradient(135deg,#6366f1,#818cf8);background:linear-gradient(135deg,var(--ct-primary) 0,#818cf8 100%);border-radius:12px;box-shadow:0 4px 12px #6366f14d;color:#fff;display:flex;gap:24px;padding:16px 24px}.ct-balance-info h2{align-items:center;display:flex;font-size:26px;margin:0}.ct-balance-info span{font-size:12px;letter-spacing:.5px;opacity:.9;text-transform:uppercase}.ct-btn-topup{align-items:center;background:#fff3;border:1px solid #fff6;border-radius:8px;color:#fff;cursor:pointer;display:flex;gap:6px;padding:8px 16px;transition:all .2s}.ct-btn-topup:hover{background:#fff;color:#6366f1;color:var(--ct-primary)}.ct-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:2fr 1fr}@media (max-width:900px){.ct-grid{grid-template-columns:1fr}}.ct-card{background:#fff;background:var(--ct-card-bg);border:1px solid #e5e7eb;border:1px solid var(--ct-border);border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.ct-card-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--ct-border);display:flex;gap:10px;margin-bottom:20px;padding-bottom:12px}.ct-card-header h3{color:#1f2937;color:var(--ct-text-main);font-size:18px;margin:0}.text-primary{color:#6366f1;color:var(--ct-primary)}.text-secondary{color:#6b7280;color:var(--ct-text-muted)}.ct-search-bar{display:flex;gap:10px;margin-bottom:12px;position:relative}.ct-search-icon{color:#6b7280;color:var(--ct-text-muted);left:12px;position:absolute;top:50%;transform:translateY(-50%)}.ct-search-bar input{font-size:14px;padding:10px 10px 10px 38px;width:100%}.ct-btn-icon,.ct-search-bar input{border:1px solid #e5e7eb;border:1px solid var(--ct-border);border-radius:8px}.ct-btn-icon{background:#f3f4f6;background:var(--ct-bg);color:#6b7280;color:var(--ct-text-muted);cursor:pointer;padding:10px}.ct-filters-panel{animation:slideDown .2s ease;display:flex;gap:10px;margin-bottom:12px}.ct-filters-panel select{border-radius:6px;flex:1 1;padding:8px}.ct-filters-panel select,.ct-user-list-wrapper{border:1px solid #e5e7eb;border:1px solid var(--ct-border)}.ct-user-list-wrapper{border-radius:8px;margin-bottom:20px;overflow:hidden}.ct-user-list-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--ct-border);color:#6b7280;color:var(--ct-text-muted);display:flex;font-size:12px;font-weight:600;justify-content:space-between;padding:10px 16px}.ct-user-list{max-height:300px;overflow-y:auto}.ct-user-row{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--ct-border);cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:background .2s}.ct-user-row:hover{background-color:#f3f4f6}.ct-user-row.selected{background-color:#eef2ff;border-left:4px solid #6366f1;border-left:4px solid var(--ct-primary)}.ct-user-info{flex:1 1;gap:10px}.ct-avatar,.ct-user-info{align-items:center;display:flex}.ct-avatar{background:#6366f1;background:var(--ct-primary);border-radius:50%;color:#fff;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.ct-username{color:#1f2937;color:var(--ct-text-main);font-size:14px;font-weight:500}.ct-email{color:#6b7280;color:var(--ct-text-muted);font-size:12px}.ct-user-balance{color:#1f2937;color:var(--ct-text-main);font-size:13px;font-weight:600;min-width:60px;text-align:right}.ct-badge{border-radius:12px;font-size:10px;font-weight:600;margin-right:10px;padding:2px 8px;text-transform:uppercase}.badge-manager{background:#dbeafe;color:#1e40af}.badge-client{background:#fef3c7;color:#92400e}.badge-default,.badge-user{background:#f3f4f6;color:#374151}.ct-input-group{margin-bottom:16px}.ct-input-group label{color:#1f2937;color:var(--ct-text-main);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.ct-input-icon-wrapper{position:relative}.ct-input-icon{color:#6b7280;color:var(--ct-text-muted);left:10px;position:absolute;top:50%;transform:translateY(-50%)}.ct-input-group input,.ct-input-group textarea{border:1px solid #e5e7eb;border:1px solid var(--ct-border);border-radius:8px;font-size:14px;padding:10px 10px 10px 32px;width:100%}.ct-input-group textarea{padding:10px}.ct-btn-submit{align-items:center;background:#6366f1;background:var(--ct-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:background .2s;width:100%}.ct-btn-submit:hover:not(:disabled){background:#4f46e5;background:var(--ct-primary-dark)}.ct-btn-submit:disabled{cursor:not-allowed;opacity:.6}.ct-selected-indicator{background:#e0e7ff;border-radius:6px;color:#4f46e5;color:var(--ct-primary-dark);font-size:13px;margin-bottom:16px;padding:8px 12px}.ct-history-list{display:flex;flex-direction:column}.ct-history-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;padding:12px 0}.ct-history-icon{align-items:center;border-radius:50%;display:flex;height:32px;justify-content:center;margin-right:12px;width:32px}.ct-history-icon.in{background:#ecfdf5;color:#10b981;color:var(--ct-green)}.ct-history-icon.out{background:#fef2f2;color:#ef4444;color:var(--ct-red)}.ct-history-details{flex:1 1}.ct-history-title{color:#1f2937;color:var(--ct-text-main);font-size:14px;font-weight:500}.ct-history-date{color:#6b7280;color:var(--ct-text-muted);font-size:11px}.ct-history-amount{font-size:14px;font-weight:600}.text-green{color:#10b981;color:var(--ct-green)}.text-red{color:#ef4444;color:var(--ct-red)}.ct-alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:12px 16px}.ct-alert-success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.ct-alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.ct-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.ct-modal{background:#fff;border-radius:12px;max-width:400px;padding:24px;width:90%}.ct-modal h3{margin-top:0}.ct-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.ct-btn-text{background:none;border:none;color:#6b7280;color:var(--ct-text-muted);cursor:pointer}.ct-btn-primary{background:#6366f1;background:var(--ct-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px}.gold-theme{background:linear-gradient(135deg,#1a1a1a,#333)!important;border:1px solid gold}.gold-coin{animation:spin-coin 4s linear infinite;color:gold;filter:drop-shadow(0 0 5px rgba(255,215,0,.5))}.coin-text{color:gold!important;font-weight:800}.gold-btn-solid{background:gold!important;color:#000!important;font-weight:700}.gold-btn-solid:hover{background:#fc0!important;box-shadow:0 0 15px #ffd70066}@keyframes spin-coin{0%{transform:rotateY(0deg)}to{transform:rotateY(1turn)}}.ct-selected-indicator.gold-border{background:#ffd6000d;border:1px dashed gold;color:gold}:root{--mm-primary:#4f46e5;--mm-bg-page:#f9fafb;--mm-bg-card:#fff;--mm-border:#e5e7eb;--mm-text-main:#111827;--mm-text-muted:#6b7280;--mm-radius-lg:12px;--mm-radius-sm:8px;--mm-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f}.message-management-container{background-color:#f9fafb;background-color:var(--mm-bg-page);color:#111827;color:var(--mm-text-main);font-family:Inter,-apple-system,sans-serif;margin:0 auto;max-width:1280px;min-height:100vh;padding:24px}.page-header{align-items:center;display:flex;gap:16px;margin-bottom:32px}.header-icon{background:#e0e7ff;border-radius:12px;color:#4f46e5;color:var(--mm-primary);height:48px;padding:10px;width:48px}.page-title{color:#1f2937;font-size:24px;font-weight:700;margin:0}.page-subtitle{color:#6b7280;color:var(--mm-text-muted);font-size:14px;margin:4px 0 0}.messaging-grid{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1.5fr 1fr}.section-card{background:#fff;background:var(--mm-bg-card);border:1px solid #e5e7eb;border:1px solid var(--mm-border);border-radius:12px;border-radius:var(--mm-radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--mm-shadow);padding:24px}.section-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--mm-border);color:#4f46e5;color:var(--mm-primary);display:flex;gap:12px;margin-bottom:24px;padding-bottom:16px}.section-header h2{color:#111827;color:var(--mm-text-main);font-size:18px;font-weight:600;margin:0}.form-group{position:relative}.form-group label{color:#374151;display:block;font-size:13px;font-weight:600;letter-spacing:.03em;margin-bottom:8px;text-transform:uppercase}.toggle-buttons{background:#f3f4f6;border-radius:8px;border-radius:var(--mm-radius-sm);display:flex;gap:4px;padding:4px}.toggle-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--mm-text-muted);cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:10px;transition:all .2s}.toggle-btn.active,.toggle-btn:hover{color:#4f46e5;color:var(--mm-primary)}.toggle-btn.active{background:#fff;box-shadow:0 1px 2px #0000000d;font-weight:600}.subordinates-section{background:#f8fafc;border:1px solid #e5e7eb;border:1px solid var(--mm-border);border-radius:8px;border-radius:var(--mm-radius-sm);margin-bottom:20px;padding:20px}.selected-tag{background:#e0e7ff;border:1px solid #c7d2fe;border-radius:6px;color:#3730a3;font-size:13px;font-weight:600;gap:8px;justify-content:space-between;margin-top:10px;padding:8px 12px}.clear-btn,.selected-tag{align-items:center;display:flex}.clear-btn{background:none;border:none;border-radius:4px;color:#6366f1;cursor:pointer;padding:4px}.clear-btn:hover{background:#ffffff80}.subordinate-actions{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.subordinate-search{flex:1 1;position:relative}.form-input-small{border:1px solid #e5e7eb;border:1px solid var(--mm-border);border-radius:6px;font-size:13px;padding:8px 8px 8px 34px;width:100%}.selection-actions{display:flex;gap:8px}.action-btn{border:1px solid var(--mm-border);border-radius:6px;font-size:11px;font-weight:500;padding:8px 12px}.action-btn:hover{background:#f9fafb;border-color:#cbd5e1}.subordinate-list{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--mm-border);border-radius:6px;max-height:250px;overflow-y:auto}.subordinate-item{align-items:center;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;padding:10px 14px;transition:background .2s}.subordinate-item:last-child{border-bottom:none}.subordinate-item:hover{background:#f8fafc}.subordinate-item.selected{background:#f0fdf4}.checkbox{align-items:center;border:2px solid #d1d5db;border-radius:4px;color:#fff;display:flex;height:18px;justify-content:center;margin-right:14px;transition:all .2s;width:18px}.subordinate-item.selected .checkbox{background:#16a34a;border-color:#16a34a}.user-info{display:flex;flex-direction:column}.username{color:#111827;font-size:14px;font-weight:500}.user-meta{color:#6b7280;color:var(--mm-text-muted);font-size:11px}.selected-count{align-items:center;color:#16a34a;display:flex;font-size:13px;font-weight:600;gap:6px;margin-top:10px}.form-input,.form-select,.form-textarea{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--mm-border);border-radius:8px;border-radius:var(--mm-radius-sm);box-sizing:border-box;color:#111827;color:var(--mm-text-main);font-size:14px;padding:12px;transition:border-color .2s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#4f46e5;border-color:var(--mm-primary);box-shadow:0 0 0 3px #4f46e51a;outline:none}.dropdown-container{position:relative}.search-dropdown-input{cursor:pointer;position:relative}.input-icon{color:#6b7280;color:var(--mm-text-muted);left:12px;position:absolute;top:50%;transform:translateY(-50%);z-index:2}.search-dropdown-input input{cursor:pointer;padding-left:40px}.dropdown-arrow{color:#6b7280;color:var(--mm-text-muted);position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:transform .2s}.dropdown-arrow.rotated{transform:translateY(-50%) rotate(180deg)}.search-dropdown-list{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--mm-border);border-radius:8px;border-radius:var(--mm-radius-sm);box-shadow:0 10px 15px -3px #0000001a;left:0;list-style:none;margin-top:6px;max-height:250px;overflow-y:auto;padding:0;position:absolute;right:0;top:100%;z-index:50}.search-dropdown-list li{align-items:center;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;font-size:14px;gap:12px;padding:10px 14px}.search-dropdown-list li:hover{background:#f8fafc;color:#4f46e5;color:var(--mm-primary)}.no-results{color:#6b7280;color:var(--mm-text-muted);font-size:13px;padding:12px;text-align:center}.delivery-info{align-items:flex-start;border-radius:6px;display:flex;font-size:12px;gap:8px;line-height:1.5;margin-top:10px;padding:12px}.info-notification{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.info-sms{background:#fff7ed;border:1px solid #fed7aa;color:#c2410c}.char-count{color:#6b7280;color:var(--mm-text-muted);font-size:11px;margin-top:6px;text-align:right}.btn-send{align-items:center;background:#4f46e5;background:var(--mm-primary);border:none;border-radius:8px;border-radius:var(--mm-radius-sm);box-shadow:0 4px 6px #4f46e533;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:center;padding:14px;transition:all .2s;width:100%}.btn-send:hover:not(:disabled){background:#4338ca;box-shadow:0 6px 12px #4f46e54d;transform:translateY(-1px)}.btn-send:disabled{box-shadow:none;cursor:not-allowed;opacity:.6}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.alert{align-items:center;animation:slideDown .3s ease;border-radius:8px;border-radius:var(--mm-radius-sm);display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:24px;padding:14px 18px}.alert-success{background:#ecfdf5;border:1px solid #bbf7d0;color:#15803d}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.history-list{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.history-item{background:#fff;border:1px solid #f1f5f9;border-radius:8px;border-radius:var(--mm-radius-sm);display:flex;gap:16px;padding:16px;transition:transform .2s,box-shadow .2s}.history-item:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d;transform:translateX(4px)}.history-icon-box{align-items:center;background:#f1f5f9;border-radius:12px;color:#6b7280;color:var(--mm-text-muted);display:flex;height:44px;justify-content:center;width:44px}.history-notification .history-icon-box{background:#e0e7ff;color:#4f46e5}.history-sms .history-icon-box{background:#ffedd5;color:#f97316}.history-details{flex:1 1}.history-meta{display:flex;font-size:11px;font-weight:600;justify-content:space-between;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.history-type-badge{color:#6b7280;color:var(--mm-text-muted)}.history-status-badge{border-radius:4px;padding:2px 6px}.history-status-badge.status-sent{background:#dcfce7;color:#16a34a}.history-status-badge.status-failed{background:#fee2e2;color:#dc2626}.history-recipient{color:#111827;font-size:14px;font-weight:700;margin-bottom:4px}.history-message{color:#4b5563;font-size:13px;line-height:1.5;margin-bottom:8px}.history-date{color:#9ca3af;font-size:11px}.empty-state{color:#cbd5e1;padding:60px 40px}.empty-state p{color:#6b7280;color:var(--mm-text-muted);font-size:15px;margin-top:16px}@media (max-width:1024px){.messaging-grid{grid-template-columns:1fr}.history-section{order:2}}@media (max-width:640px){.message-management-container{padding:16px}.page-title{font-size:20px}.toggle-buttons{flex-direction:column}.section-card{padding:16px}.subordinate-actions{align-items:stretch;flex-direction:column}.selection-actions{justify-content:flex-end}}.groupadmin-dashboard-container{display:flex;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.groupadmin-sidebar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:4px 0 20px #0000001a;display:flex;flex-direction:column;height:100vh;transition:transform .3s ease;width:260px;z-index:100}.sidebar-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #00000014;padding:24px 20px}.sidebar-logo{align-items:center;color:#fff;display:flex;font-size:22px;font-weight:700;gap:12px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:20px 0}.nav-item{align-items:center;border-radius:10px;color:#4a5568;cursor:pointer;display:flex;font-weight:500;gap:12px;margin:4px 12px;padding:14px 20px;text-decoration:none;transition:all .2s ease}.nav-item:hover{background:#667eea1a;color:#667eea;transform:translateX(4px)}.nav-item.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d;color:#fff}.nav-item svg{flex-shrink:0}.sidebar-footer{border-top:1px solid #00000014;padding:20px}.user-profile{align-items:center;background:#667eea0d;border-radius:10px;display:flex;gap:12px;padding:12px}.user-avatar{border:2px solid #667eea;border-radius:50%;height:40px;object-fit:cover;width:40px}.user-info{flex:1 1;min-width:0}.user-name{color:#2d3748;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#718096;font-size:12px;text-transform:capitalize}.logout-btn{background:#0000;border:none;border-radius:6px;color:#e53e3e;cursor:pointer;padding:8px;transition:all .2s ease}.logout-btn:hover{background:#e53e3e1a}.main-content-wrapper{display:flex;flex:1 1;flex-direction:column;min-height:100vh}.tab-content-area{animation:fadeIn .3s ease;flex:1 1;overflow-y:auto;padding:30px}.card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;padding:24px;transition:transform .2s ease,box-shadow .2s ease}.card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-2px)}.card-title{align-items:center;color:#2d3748;display:flex;font-size:20px;font-weight:700;gap:10px;margin-bottom:20px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 20px #667eea4d;color:#fff;padding:24px;transition:transform .2s ease}.stat-card:hover{box-shadow:0 8px 30px #667eea66;transform:translateY(-4px)}.stat-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.stat-label{font-size:14px;font-weight:500;opacity:.9}.stat-icon{align-items:center;background:#fff3;border-radius:10px;display:flex;height:40px;justify-content:center;width:40px}.stat-value{font-size:36px;font-weight:700;line-height:1}.data-table-wrapper{border-radius:12px;box-shadow:0 2px 10px #0000000d;overflow-x:auto}.data-table{background:#fff;border-collapse:collapse;width:100%}.data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.data-table th{font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:14px;padding:16px}.data-table tbody tr{transition:background .2s ease}.data-table tbody tr:hover{background:#667eea0d}.btn-primary{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:inline-flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.btn-primary:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-secondary{align-items:center;background:#fff;border:2px solid #667eea;border-radius:10px;color:#667eea;cursor:pointer;display:inline-flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-secondary:hover{background:#667eea;color:#fff}.btn-danger{background:#e53e3e;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s ease}.btn-danger:hover{background:#c53030;transform:translateY(-1px)}.btn-icon{align-items:center;background:#0000;border:none;border-radius:6px;color:#667eea;cursor:pointer;display:inline-flex;justify-content:center;padding:8px;transition:all .2s ease}.btn-icon:hover{background:#667eea1a}.action-buttons{align-items:center;display:flex;gap:8px}.status-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:6px 12px;text-transform:capitalize}.status-badge.online{background:#48bb7833;color:#2f855a}.status-badge.offline{background:#e53e3e33;color:#c53030}.status-badge.unknown{background:#ed893633;color:#c05621}.status-badge.active{background:#48bb7833;color:#2f855a}.status-badge.inactive{background:#a0aec033;color:#4a5568}.global-alert{align-items:center;animation:slideInRight .3s ease;border-radius:12px;box-shadow:0 8px 30px #00000026;display:flex;font-weight:600;gap:12px;max-width:400px;opacity:0;padding:16px 24px;position:fixed;right:20px;top:20px;transform:translateX(100%);z-index:1000}.global-alert.show{opacity:1;transform:translateX(0)}.global-alert.success{background:#48bb78f2;color:#fff}.global-alert.error{background:#e53e3ef2;color:#fff}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.loading-spinner{color:#fff}.error-message,.loading-spinner{align-items:center;display:flex;font-size:18px;font-weight:600;justify-content:center;min-height:400px}.error-message{background:#fff;border-radius:16px;color:#e53e3e;margin:20px;padding:40px}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal-content{animation:scaleIn .2s ease;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;padding:32px;width:90%}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.modal-title{color:#2d3748;font-size:24px;font-weight:700}.modal-close{background:#0000;border:none;border-radius:6px;color:#a0aec0;cursor:pointer;padding:4px;transition:all .2s ease}.modal-close:hover{background:#0000000d;color:#4a5568}.form-group{margin-bottom:20px}.form-label{color:#2d3748;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-input{border:2px solid #e2e8f0;border-radius:10px;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-select{background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-checkbox{align-items:center;cursor:pointer;display:flex;gap:8px}.form-checkbox input[type=checkbox]{cursor:pointer;height:18px;width:18px}.quick-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}@media (max-width:768px){.groupadmin-sidebar{transform:translateX(-100%)}.main-content-wrapper{margin-left:0}.stats-grid{grid-template-columns:1fr}.data-table-wrapper{font-size:12px}.modal-content{padding:20px;width:95%}}:root{--np-bg:#f3f4f6;--np-white:#fff;--np-primary:#4f46e5;--np-text:#1f2937;--np-text-muted:#6b7280;--np-border:#e5e7eb}.notif-page-container{background:#f3f4f6;background:var(--np-bg);font-family:Inter,sans-serif;min-height:100vh;padding:32px}.notif-page-header{align-items:center;background:#fff;background:var(--np-white);border-radius:16px;box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;margin-bottom:24px;padding:20px 24px}.header-title{align-items:center;display:flex;gap:16px}.text-indigo{color:#4f46e5;color:var(--np-primary)}.header-title h1{color:#1f2937;color:var(--np-text);font-size:24px;margin:0}.header-title p{color:#6b7280;color:var(--np-text-muted);font-size:14px;margin:4px 0 0}.search-box{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--np-border);border-radius:8px;display:flex;padding:10px 16px;width:300px}.search-box input{background:#0000;border:none;color:#1f2937;color:var(--np-text);margin-left:8px;outline:none;width:100%}.notif-tabs{display:flex;gap:12px;margin-bottom:20px}.tab-btn{background:#0000;border:none;border-radius:20px;color:#6b7280;color:var(--np-text-muted);cursor:pointer;font-weight:600;padding:8px 20px;transition:all .2s}.tab-btn.active{background:#4f46e5;background:var(--np-primary);box-shadow:0 4px 12px #4f46e533;color:#fff}.notif-list-wrapper{background:#0000}.notif-card{align-items:center;background:#fff;background:var(--np-white);border:1px solid #e5e7eb;border:1px solid var(--np-border);border-radius:12px;display:flex;margin-bottom:12px;padding:20px;transition:transform .2s}.notif-card:hover{box-shadow:0 4px 6px #0000000d;transform:translateY(-2px)}.notif-card.unread{background:#fefeff;border-left:4px solid #4f46e5;border-left:4px solid var(--np-primary)}.icon-circle{align-items:center;border-radius:50%;display:flex;height:48px;justify-content:center;margin-right:20px;width:48px}.icon-circle.app{background:#e0e7ff;color:#4f46e5;color:var(--np-primary)}.icon-circle.sms{background:#ffedd5;color:#ea580c}.card-content{flex:1 1}.card-top{display:flex;justify-content:space-between;margin-bottom:6px}.sender-name{color:#1f2937;color:var(--np-text);font-size:15px;font-weight:700}.msg-time{align-items:center;color:#6b7280;color:var(--np-text-muted);display:flex;font-size:12px;gap:4px}.msg-text{color:#4b5563;font-size:14px;line-height:1.5;margin:0}.sms-badge{background:#f3f4f6;border-radius:4px;color:#6b7280;display:inline-block;font-size:10px;margin-top:8px;padding:2px 8px}.card-actions{display:flex;gap:10px;margin-left:20px}.action-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--np-border);border-radius:8px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.action-btn.check:hover{background:#dcfce7;border-color:#bbf7d0;color:#16a34a}.action-btn.trash:hover{background:#fee2e2;border-color:#fecaca;color:#dc2626}.empty-state{color:#6b7280;color:var(--np-text-muted);padding:60px;text-align:center}.empty-icon{color:#cbd5e1;margin-bottom:16px}.pagination-bar{align-items:center;display:flex;justify-content:space-between;margin-top:24px;padding:10px 20px}.page-btns button{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--np-border);border-radius:6px;cursor:pointer;margin-left:8px;padding:8px}.page-btns button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.notif-page-header{align-items:flex-start;flex-direction:column;gap:16px}.search-box{width:100%}.notif-card{align-items:flex-start;flex-direction:column}.card-actions{justify-content:flex-end;margin-left:0;margin-top:12px;width:100%}}.notification-popup-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.notification-popup{animation:slideDown .4s cubic-bezier(.68,-.55,.265,1.55);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:450px;overflow:hidden;padding:0;width:90%}@keyframes slideDown{0%{opacity:0;transform:translateY(-100px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:space-between;padding:20px;position:relative}.notification-icon{animation:bounce .6s ease infinite;font-size:48px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.notification-badge{position:absolute;right:15px;top:15px}.notification-count{animation:pulse 1s ease infinite;background:#ff4757;border-radius:20px;color:#fff;font-size:12px;font-weight:700;padding:4px 10px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-body{padding:25px}.notification-body h3{color:#2c3e50;font-size:20px;font-weight:700;margin:0 0 12px}.notification-body p{color:#555;font-size:15px;line-height:1.5;margin:0 0 15px}.urgent-badge{align-items:center;animation:shake .5s ease infinite;background:#ff4757;border-radius:6px;color:#fff;display:inline-flex;font-size:12px;font-weight:700;gap:6px;margin-bottom:10px;padding:6px 12px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.notification-time{color:#999;font-size:13px;margin-top:10px}.notification-actions{display:flex;gap:12px;padding:0 25px 25px}.notification-actions button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .3s ease}.btn-dismiss{background:#e0e0e0;color:#555}.btn-dismiss:hover{background:#d0d0d0;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-view{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-view:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.notification-footer{background:#f8f9fa;border-top:1px solid #e0e0e0;color:#666;font-size:13px;font-weight:500;padding:12px 25px;text-align:center}@media (max-width:480px){.notification-popup{margin:0 10px;width:95%}.notification-body h3{font-size:18px}.notification-body p{font-size:14px}.notification-actions{flex-direction:column}.notification-actions button{width:100%}}
/*# sourceMappingURL=main.8694111b.css.map*/