.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}:root{--ctp-base: #1e1e2e;--ctp-mantle: #181825;--ctp-crust: #11111b;--ctp-text: #cdd6f4;--ctp-subtext1: #bac2de;--ctp-subtext0: #a6adc8;--ctp-overlay2: #9399b2;--ctp-overlay1: #7f849c;--ctp-overlay0: #6c7086;--ctp-surface2: #585b70;--ctp-surface1: #45475a;--ctp-surface0: #313244;--ctp-lavender: #b4befe;--ctp-blue: #89b4fa;--ctp-sapphire: #74c7ec;--ctp-sky: #89dceb;--ctp-teal: #94e2d5;--ctp-green: #a6e3a1;--ctp-yellow: #f9e2af;--ctp-peach: #fab387;--ctp-maroon: #eba0ac;--ctp-red: #f38ba8;--ctp-mauve: #cba6f7;--ctp-pink: #f5c2e7;--ctp-flamingo: #f2cdcd;--ctp-rosewater: #f5e0dc;--header-height: 60px;--sidebar-width: 60px;--banner-height: 36px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--ctp-base);color:var(--ctp-text);margin:0;padding:0;padding-bottom:env(safe-area-inset-bottom)}.app{min-height:100vh;min-height:100dvh;background:var(--ctp-base);display:flex;flex-direction:column}.app-header{background:var(--ctp-mantle);border-bottom:1px solid var(--ctp-surface0);padding:1.5rem 2rem;padding-top:max(1.5rem,env(safe-area-inset-top));position:fixed;top:0;left:60px;right:0;height:60px;display:flex;justify-content:space-between;align-items:center;z-index:10000;box-sizing:border-box}.header-left{display:flex;align-items:center;gap:1rem}.header-title{display:flex;align-items:center;gap:.75rem}.header-logo{height:2rem;width:auto;object-fit:contain}.app-header h1{margin:0;color:var(--ctp-lavender);font-size:2rem;font-weight:700}.node-info{display:flex;gap:.5rem;align-items:center;font-size:.9rem;color:var(--ctp-subtext0)}.node-address{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;background:var(--ctp-surface0);padding:.25rem .5rem;border-radius:4px;color:var(--ctp-blue)}.device-name{color:var(--ctp-green);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.warning-banner,.update-banner{position:fixed;left:var(--sidebar-width);right:0;padding:8px 16px;text-align:center;font-size:14px;font-weight:500;z-index:9999;box-sizing:border-box}.warning-banner{top:var(--header-height);background-color:#dc2626;color:#fff;border-bottom:2px solid #991b1b}.update-banner{background-color:#3b82f6;color:#fff;border-bottom:2px solid #1d4ed8}.connection-status{display:flex;align-items:center;gap:.5rem;color:var(--ctp-text);font-weight:500}.status-indicator{width:12px;height:12px;border-radius:50%;background:var(--ctp-overlay1)}.status-indicator.connected{background:var(--ctp-green);animation:pulse 2s infinite}.status-indicator.connecting{background:var(--ctp-yellow);animation:pulse 1s infinite}.status-indicator.configuring{background:var(--ctp-blue);animation:pulse 1.5s infinite}.status-indicator.disconnected{background:var(--ctp-red)}.status-indicator.rebooting{background:var(--ctp-peach);animation:pulse 1s infinite}@keyframes pulse{0%{box-shadow:0 0 #a6e3a1b3}70%{box-shadow:0 0 0 10px #a6e3a100}to{box-shadow:0 0 #a6e3a100}}.connection-control-btn{margin-left:8px;padding:4px 12px;font-size:12px;border:1px solid var(--ctp-overlay0);background:var(--ctp-surface0);color:var(--ctp-text);border-radius:4px;cursor:pointer;transition:all .2s;font-weight:500}.connection-control-btn:hover{background:var(--ctp-surface1);border-color:var(--ctp-overlay1)}.connection-control-btn.reconnect{background:var(--ctp-blue);border-color:var(--ctp-blue);color:var(--ctp-base)}.connection-control-btn.reconnect:hover{background:var(--ctp-sapphire);border-color:var(--ctp-sapphire)}.tab-nav,.tab-btn{display:none}.app-main{padding:2rem;padding-top:calc(var(--header-height) + 2rem);padding-bottom:max(2rem,env(safe-area-inset-bottom));width:calc(100% - 60px);margin:0 0 0 60px;flex:1;transition:margin-left .3s ease;box-sizing:border-box}.tab-content{min-height:60vh}.channels-tab-content{margin-left:-1rem;margin-right:-1rem}.nodes-section{margin-bottom:2rem}.filter-container{margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.filter-input{background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:.75rem 1rem;border-radius:8px;font-size:1rem;min-width:250px;transition:border-color .2s}.filter-input:focus{outline:none;border-color:var(--ctp-blue)}.filter-input::placeholder{color:var(--ctp-overlay1)}.filter-label{color:var(--ctp-subtext1);font-weight:500;font-size:.9rem}.nodes-table{background:var(--ctp-surface0);border-radius:12px;overflow:hidden;border:1px solid var(--ctp-surface1)}.nodes-table table{width:100%;border-collapse:collapse}.nodes-table th{background:var(--ctp-surface1);color:var(--ctp-text);padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid var(--ctp-surface2);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;position:relative}.nodes-table th:hover{background:var(--ctp-surface2);color:var(--ctp-lavender)}.nodes-table th.sortable:after{content:"↕";position:absolute;right:.5rem;opacity:.5;font-size:.8rem;transition:opacity .2s}.nodes-table th.sortable:hover:after{opacity:1}.nodes-table th.sorted-asc:after{content:"↑";opacity:1;color:var(--ctp-blue)}.nodes-table th.sorted-desc:after{content:"↓";opacity:1;color:var(--ctp-blue)}.nodes-table td{padding:.75rem 1rem;color:var(--ctp-text);border-bottom:1px solid var(--ctp-surface1)}.nodes-table tbody tr:hover{background:var(--ctp-surface1)}.channel-selector{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.channel-btn{background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.channel-btn:hover{background:var(--ctp-surface2);border-color:var(--ctp-blue)}.channel-btn.active{background:var(--ctp-blue);color:var(--ctp-base);border-color:var(--ctp-blue)}.channel-messages{background:var(--ctp-surface0);border-radius:12px;padding:1.5rem;border:1px solid var(--ctp-surface1)}.dm-selector{margin-bottom:1.5rem}.node-select{background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:.75rem 1rem;border-radius:8px;font-size:1rem;min-width:250px;cursor:pointer}.node-select:focus{outline:none;border-color:var(--ctp-blue)}.dm-conversation{background:var(--ctp-surface0);border-radius:12px;padding:1.5rem;border:1px solid var(--ctp-surface1)}.dm-conversation-panel{height:100%;display:flex;flex-direction:column;overflow-y:auto}.no-selection{display:flex;align-items:center;justify-content:center;height:100%;color:var(--ctp-subtext0);font-size:1.1rem}.message-item.sent{margin-left:2rem}.message-item.received{margin-right:2rem}.message-item.sent .message-text{background:var(--ctp-blue);color:var(--ctp-base);margin-left:auto}.message-item.received .message-text{background:var(--ctp-surface1)}.device-info{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.info-section{background:var(--ctp-surface0);border-radius:12px;padding:1.5rem;border:1px solid var(--ctp-surface1)}.info-section-full-width{background:var(--ctp-surface0);border-radius:12px;padding:1.5rem;border:1px solid var(--ctp-surface1);margin-top:1.5rem;width:100%}.info-section h3,.info-section-full-width h3{color:var(--ctp-lavender);margin-bottom:1rem;font-size:1.25rem}.info-section p{margin-bottom:.5rem;color:var(--ctp-text)}.info-section strong{color:var(--ctp-blue)}.status-text{font-weight:600;text-transform:capitalize}.status-text.connected{color:var(--ctp-green)}.status-text.disconnected{color:var(--ctp-red)}.status-text.connecting{color:var(--ctp-yellow)}.status-text.rebooting{color:var(--ctp-peach)}.channel-config{margin-top:.5rem}.channel-item{padding:.5rem 0}.channel-item hr{border:none;border-top:1px solid var(--ctp-surface2);margin:.5rem 0}.no-data{text-align:center;color:var(--ctp-subtext1);font-style:italic;padding:2rem}.connection-panel,.nodes-panel,.messages-panel{background:var(--ctp-surface0);border-radius:12px;padding:1.5rem;margin-bottom:2rem;border:1px solid var(--ctp-surface1)}.connection-panel h2,.nodes-panel h2,.messages-panel h2{margin-top:0;margin-bottom:1rem;color:var(--ctp-subtext1);font-weight:600}.connection-form{display:flex;gap:1rem}.connection-form input{flex:1;padding:.75rem 1rem;border:2px solid var(--ctp-surface1);border-radius:8px;font-size:1rem;background:var(--ctp-base);color:var(--ctp-text);transition:border-color .2s}.connection-form input:focus{outline:none;border-color:var(--ctp-lavender)}.connection-form input::placeholder{color:var(--ctp-overlay1)}.connection-form button{padding:.75rem 2rem;background:var(--ctp-blue);color:var(--ctp-base);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.connection-form button:hover:not(:disabled){background:var(--ctp-sapphire);transform:translateY(-2px);box-shadow:0 8px 25px -5px #89b4fa4d}.connection-form button:disabled{opacity:.5;cursor:not-allowed}.connection-form button.disconnect-btn{background:var(--ctp-red);color:var(--ctp-base)}.connection-form button.disconnect-btn:hover:not(:disabled){background:var(--ctp-maroon)}.error-panel{background:var(--ctp-surface0);border:1px solid var(--ctp-red);border-radius:8px;padding:1.5rem;margin-bottom:1rem;color:var(--ctp-red)}.error-panel h3{margin:0 0 .75rem;color:var(--ctp-red);font-size:1.1rem}.error-panel p{margin:0 0 1rem;line-height:1.5;color:var(--ctp-text)}.error-actions{display:flex;gap:.75rem;align-items:center}.retry-btn{background:var(--ctp-blue);color:var(--ctp-base);border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.retry-btn:hover{background:var(--ctp-sapphire)}.dismiss-error{background:none;border:1px solid var(--ctp-overlay0);color:var(--ctp-text);padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.dismiss-error:hover{background:var(--ctp-surface1);border-color:var(--ctp-overlay1)}.device-info{margin-top:1.5rem;padding:1rem;background:var(--ctp-mantle);border-radius:8px;border:1px solid var(--ctp-surface1)}.device-info h3{margin:0 0 1rem;color:var(--ctp-subtext1);font-size:1.1rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item .label{font-size:.85rem;color:var(--ctp-overlay2);font-weight:600}.info-item .value{font-size:.95rem;color:var(--ctp-text);font-family:JetBrains Mono,SF Mono,Consolas,monospace}.nodes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.node-card{background:var(--ctp-mantle);padding:1.25rem;border-radius:8px;border:1px solid var(--ctp-surface1);transition:all .2s}.node-card:hover{border-color:var(--ctp-surface2);transform:translateY(-2px);box-shadow:0 8px 25px -5px #0000004d}.node-card h3{margin:0 0 .75rem;color:var(--ctp-subtext1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-card p{margin:.5rem 0;color:var(--ctp-subtext0);font-size:.9rem}.no-nodes,.no-messages{text-align:center;color:var(--ctp-overlay1);padding:2rem;font-style:italic}.messages-container{max-height:600px;overflow-y:auto;border:1px solid var(--ctp-surface1);border-radius:8px;padding:1rem;background:var(--ctp-mantle)}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:var(--ctp-surface0);border-radius:4px}.messages-container::-webkit-scrollbar-thumb{background:var(--ctp-overlay0);border-radius:4px}.message-item{padding:.75rem;border-bottom:1px solid var(--ctp-surface0);border-radius:6px;margin-bottom:.5rem;background:var(--ctp-surface0)}.message-header{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem;font-size:.85rem}.message-from{font-weight:600;color:var(--ctp-blue)}.message-to{color:var(--ctp-green);font-weight:500}.message-time{color:var(--ctp-overlay2);font-size:.8rem;margin-left:auto;font-family:JetBrains Mono,SF Mono,Consolas,monospace}.message-text{color:var(--ctp-text);margin-bottom:.5rem;line-height:1.4;word-wrap:break-word;font-size:.95rem}.message-details{display:flex;gap:1rem;font-size:.75rem;color:var(--ctp-overlay1);font-family:JetBrains Mono,SF Mono,Consolas,monospace}.send-message{margin-bottom:1rem;padding:1rem;background:var(--ctp-mantle);border-radius:8px;border:1px solid var(--ctp-surface1)}.message-input-container{display:flex;gap:.75rem}.message-input-container input{flex:1;padding:.75rem;border:2px solid var(--ctp-surface1);border-radius:6px;font-size:.95rem;background:var(--ctp-base);color:var(--ctp-text);transition:border-color .2s}.message-input-container input:focus{outline:none;border-color:var(--ctp-lavender)}.message-input-container input::placeholder{color:var(--ctp-overlay1)}.send-btn{padding:.75rem .5rem;min-width:40px;width:40px;background:var(--ctp-green);color:var(--ctp-base);border:none;border-radius:6px;font-weight:600;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-btn:hover:not(:disabled){background:var(--ctp-teal);transform:translateY(-1px);box-shadow:0 6px 20px -3px #a6e3a166}.channels-table{overflow-x:auto;margin-bottom:2rem}.channels-table table{width:100%;border-collapse:collapse;background:var(--ctp-surface0);border-radius:8px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.channels-table th,.channels-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--ctp-surface1)}.channels-table th{background:var(--ctp-surface1);font-weight:600;color:var(--ctp-lavender)}.channels-table tr:hover{background:var(--ctp-surface1)}.channel-name{font-weight:600;color:var(--ctp-blue)}.status-indicator.enabled{color:var(--ctp-green);font-weight:600}.status-indicator.disabled{color:var(--ctp-red);font-weight:600}.channel-info{background:var(--ctp-surface0);border-radius:8px;padding:1.5rem;margin-top:2rem;border-left:2px solid var(--ctp-blue)}.channel-info h3{color:var(--ctp-lavender);margin-bottom:1rem}.channel-info p{margin-bottom:1rem;line-height:1.6;color:var(--ctp-subtext1)}.channel-info ul{list-style-position:inside;color:var(--ctp-subtext1)}.channel-info li{margin-bottom:.5rem;line-height:1.5}.channel-info strong{color:var(--ctp-text)}@media (max-width: 768px){:root{--header-height: 48px;--sidebar-width: 48px}body{font-size:.875rem}.app-header{padding:.5rem;height:48px;left:48px}.filter-popup-overlay{left:var(--sidebar-width)}.warning-banner,.update-banner{font-size:13px;padding:6px 12px}.app-header .header-logo,.app-header .node-info,.app-header h1{display:none}.connection-status{margin:0;padding:0}.connection-status .status-indicator{width:16px;height:16px}.app-main{padding:.5rem;padding-top:calc(var(--header-height) + .5rem);padding-bottom:max(.5rem,env(safe-area-inset-bottom));padding-left:56px;margin-left:0!important;width:100%!important}.channels-tab-content{margin-left:-.25rem;margin-right:-.25rem}.channels-grid{display:none!important}.channel-dropdown-mobile{display:block!important;margin-bottom:1rem}.channel-dropdown-select{width:100%;padding:.75rem 2.5rem .75rem .75rem;background:var(--ctp-surface0);border:2px solid var(--ctp-surface2);border-radius:8px;color:var(--ctp-text);font-size:.875rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23cdd6f4' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.channel-dropdown-select:focus{outline:none;border-color:var(--ctp-blue)}.connection-form{flex-direction:column}.nodes-grid,.info-grid{grid-template-columns:1fr}.channels-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.message-bubble{max-width:100%}.config-custom-dropdown,.config-custom-dropdown-menu{width:100%!important;max-width:calc(100vw - 120px)!important}.automation-section-header{flex-wrap:wrap!important;gap:.75rem!important}.automation-button-container{flex-direction:column!important;width:100%!important;margin-top:.5rem!important}.automation-button-container button{width:100%!important}.modal-overlay{left:48px!important;padding:.5rem!important;align-items:center!important;justify-content:center!important}.modal-content{width:100%!important;max-width:100%!important;margin:0!important;max-height:calc(100vh - 1rem)!important}.modal-header,.modal-body{padding:.75rem!important}.modal-header h2{font-size:1.125rem!important}.form-group{margin-bottom:.75rem!important}.form-group input,.button{font-size:.9rem!important;padding:.75rem!important}.login-divider{margin:1rem 0!important}.app-main:after{content:"";display:block;height:8rem;height:calc(8rem + env(safe-area-inset-bottom))}body{overflow-y:auto!important;-webkit-overflow-scrolling:touch}}.channel-messages-section{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--ctp-surface2)}.channels-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.channels-controls{display:flex;align-items:center;gap:.75rem}.mqtt-toggle{display:flex;align-items:center;gap:.5rem;background:var(--ctp-surface1);padding:.5rem .75rem;border-radius:8px;border:1px solid var(--ctp-surface2);font-size:.85rem;color:var(--ctp-text);transition:all .2s ease}.mqtt-toggle:hover{background:var(--ctp-surface2);border-color:var(--ctp-blue)}.mqtt-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--ctp-blue);cursor:pointer}.mqtt-toggle label{cursor:pointer;-webkit-user-select:none;user-select:none;margin:0}.dm-section{margin-top:2rem}.channel-selector,.dm-selector{margin-bottom:1.5rem}.channel-select,.node-select{padding:.5rem 1rem;border:2px solid var(--ctp-surface1);border-radius:8px;font-size:1rem;background:var(--ctp-surface0);color:var(--ctp-text);cursor:pointer;min-width:200px;transition:border-color .2s}.channel-select:focus,.node-select:focus{outline:none;border-color:var(--ctp-lavender)}.send-message-form{flex-shrink:0;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--ctp-surface2)}.message-input-container{display:flex;gap:1rem;align-items:center}.message-input{flex:1;padding:.75rem 1rem;border:2px solid var(--ctp-surface1);border-radius:8px;font-size:1rem;background:var(--ctp-base);color:var(--ctp-text);transition:border-color .2s}.message-input:focus{outline:none;border-color:var(--ctp-lavender)}.message-input::placeholder{color:var(--ctp-overlay1)}.send-btn{padding:.75rem 1.5rem;background:var(--ctp-blue);color:var(--ctp-base);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.send-btn:hover:not(:disabled){background:var(--ctp-sapphire);transform:translateY(-1px)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.channel-dropdown-mobile,.node-dropdown-mobile{display:none}.channels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.channel-button{background:var(--ctp-surface0);border:2px solid var(--ctp-surface2);border-radius:12px;padding:1rem;cursor:pointer;transition:all .3s ease;color:var(--ctp-text);font-weight:500;position:relative}.channel-button:hover{background:var(--ctp-surface1);border-color:var(--ctp-blue);transform:translateY(-2px);box-shadow:0 8px 25px -5px #89b4fa4d}.channel-button.selected{background:var(--ctp-blue);border-color:var(--ctp-blue);color:var(--ctp-base);transform:translateY(-2px);box-shadow:0 8px 25px -5px #89b4fa80}.channel-button-content{display:flex;justify-content:space-between;align-items:center;gap:1rem}.channel-button-left{display:flex;flex-direction:column;gap:.5rem;flex:1}.channel-button-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.channel-button-header{display:flex;align-items:baseline;gap:.5rem}.channel-button .channel-name{font-size:1.1rem;font-weight:600;color:inherit}.channel-button .channel-id{font-size:.85rem;opacity:.7;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.channel-button-indicators{display:flex;gap:.5rem;align-items:center}.encryption-icon{font-size:.9rem;opacity:.8}.encryption-icon.encrypted{color:var(--ctp-green)}.encryption-icon.unencrypted{color:var(--ctp-yellow)}.channel-button.selected .encryption-icon{opacity:.9}.channel-info-link{font-size:.75rem;color:var(--ctp-blue);text-decoration:none;padding:2px 6px;border-radius:3px;transition:all .2s ease}.channel-info-link:hover{background:var(--ctp-surface0);color:var(--ctp-sky)}.channel-button-status{display:flex;gap:.25rem;align-items:center}.arrow-icon{font-size:.85rem;font-weight:700;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.arrow-icon.uplink.enabled{color:var(--ctp-green);background:#a6e3a133}.arrow-icon.uplink.disabled{color:var(--ctp-overlay0);background:#6c70861a;opacity:.5}.arrow-icon.downlink.enabled{color:var(--ctp-green);background:#a6e3a133}.arrow-icon.downlink.disabled{color:var(--ctp-overlay0);background:#6c70861a;opacity:.5}.channel-button.selected .arrow-icon.enabled{color:var(--ctp-base);background:#11111b4d}.channel-button.selected .arrow-icon.disabled{color:var(--ctp-base);background:#11111b33;opacity:.4}.channel-conversation-section{background:var(--ctp-surface0);border-radius:12px;padding:.75rem;border:none}.channel-conversation-section h3{color:var(--ctp-lavender);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;font-size:1.3rem}.channel-id-label{background:var(--ctp-surface2);color:var(--ctp-text);padding:.25rem .5rem;border-radius:6px;font-size:.9rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-weight:500}.channel-conversation{background:var(--ctp-mantle);border-radius:8px;padding:1rem;border:1px solid var(--ctp-surface2)}.message-bubble-container{display:flex;align-items:flex-end;margin-bottom:.75rem;gap:.5rem}.message-bubble-container.mine{flex-direction:row-reverse;justify-content:flex-start}.message-bubble-container.theirs{flex-direction:row;justify-content:flex-start}.sender-dot{width:32px;height:32px;border-radius:50%;background:var(--ctp-blue);color:var(--ctp-base);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0;margin-bottom:2px;cursor:help}.message-bubble{max-width:100%;padding:.75rem 1rem;border-radius:18px;position:relative;word-wrap:break-word;box-shadow:0 2px 8px #0000001a}.message-bubble.mine{background:var(--ctp-blue);color:var(--ctp-base);border-bottom-right-radius:6px}.message-bubble.theirs{background:var(--ctp-surface1);color:var(--ctp-text);border-bottom-left-radius:6px}.message-bubble .message-text{margin:0;line-height:1.4;font-size:.95rem}.message-bubble .message-time{font-size:.7rem;margin-top:.25rem;opacity:.7;text-align:right}.message-bubble.theirs .message-time{color:var(--ctp-subtext0)}.message-bubble.mine .message-time{color:#1e1e2eb3}.message-bubble{position:relative}.message-actions{position:absolute;top:4px;right:8px;display:flex;flex-wrap:wrap;gap:.25rem;max-width:200px;opacity:0;transition:opacity .2s ease;z-index:10}.message-bubble-container:hover .message-actions{opacity:1}.reply-button,.emoji-button{background:var(--ctp-surface2);color:var(--ctp-text);border:1px solid var(--ctp-overlay0);border-radius:12px;padding:.25rem .5rem;font-size:.75rem;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .1s ease;white-space:nowrap}.emoji-button{padding:.25rem .4rem;font-size:.9rem;line-height:1;width:40px;height:32px;display:flex;align-items:center;justify-content:center}.reply-button:hover,.emoji-button:hover{background:var(--ctp-surface1);border-color:var(--ctp-overlay1);transform:scale(1.1)}.emoji-button:active{transform:scale(.95)}.reply-indicator{background:var(--ctp-surface1);border:1px solid var(--ctp-surface2);border-radius:8px;padding:.5rem .75rem;margin-bottom:.5rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.reply-indicator-content{flex:1;min-width:0}.reply-indicator-label{font-size:.75rem;color:var(--ctp-blue);font-weight:600;margin-bottom:.25rem}.reply-indicator-text{font-size:.85rem;color:var(--ctp-subtext0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-indicator-close{background:transparent;border:none;color:var(--ctp-overlay1);cursor:pointer;font-size:1.2rem;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;transition:background .2s ease,color .2s ease}.reply-indicator-close:hover{background:var(--ctp-surface2);color:var(--ctp-text)}.message-status{display:flex;align-items:center;margin-bottom:2px;padding-left:.25rem}.status-pending{color:var(--ctp-yellow);font-size:.8rem}.status-delivered{color:var(--ctp-green);font-size:.8rem;font-weight:700}.status-failed{color:var(--ctp-red);font-size:.8rem;font-weight:700}.messages-container{flex:1;min-height:300px;max-height:600px;overflow-y:auto;padding:1rem;display:flex;flex-direction:column}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:var(--ctp-overlay0);border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--ctp-overlay1)}.nodes-split-view{position:fixed;inset:60px 0 0 60px;overflow:hidden;z-index:1}.nodes-split-view .leaflet-top.leaflet-left{inset:auto 20px 20px auto!important}.nodes-sidebar{position:absolute;top:16px;left:16px;width:350px;max-height:calc(100% - 32px);background:var(--ctp-surface0);border:2px solid var(--ctp-surface2);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;z-index:1000;box-shadow:0 8px 32px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:width .3s ease,transform .3s ease}.messages-sidebar{position:static;top:auto;left:auto;width:350px;max-height:100%;border-radius:0;border-left:none;border-top:none;border-bottom:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.messages-split-view{display:flex;flex-direction:row}.messages-split-view .nodes-main-content{flex:1;min-width:0;padding:1.5rem 2rem 1.5rem 1.5rem}.nodes-sidebar.collapsed{width:auto;max-width:60px;top:0;left:0}.nodes-sidebar.collapsed .nodes-list{display:none}.nodes-main-content{flex:1;padding-left:1.5rem;display:flex;flex-direction:column;overflow-y:auto;min-width:0}.sidebar-header{padding:1rem;border-bottom:1px solid var(--ctp-surface2);background:var(--ctp-mantle);flex-shrink:0;position:relative}.sidebar-header-content{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.sidebar-header h3{margin:0;color:var(--ctp-text);font-size:1.1rem}.filter-popup-btn{background:var(--ctp-surface1);border:1px solid var(--ctp-surface2);color:var(--ctp-text);padding:.5rem .75rem;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-popup-btn:hover{background:var(--ctp-blue);border-color:var(--ctp-blue);color:var(--ctp-base)}.filter-popup-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.filter-popup{background:var(--ctp-base);border:2px solid var(--ctp-surface2);border-radius:8px;max-width:500px;width:90%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.filter-popup-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--ctp-surface2);background:var(--ctp-mantle);flex-shrink:0}.filter-popup-header h4{margin:0;color:var(--ctp-text);font-size:1.1rem}.filter-popup-close{background:transparent;border:none;color:var(--ctp-text);font-size:1.5rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.filter-popup-close:hover{background:var(--ctp-red);color:var(--ctp-base)}.filter-popup-content{padding:1rem;overflow-y:auto;flex:1;min-height:0}.filter-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--ctp-surface1)}.filter-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.filter-section-title{color:var(--ctp-subtext1);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;display:block}.filter-icon-wrapper{display:inline-block!important;width:20px!important;max-width:20px!important;min-width:20px!important;overflow:hidden!important;text-align:center;margin-right:.5rem;vertical-align:middle}.filter-section-title .filter-icon{display:inline-block;font-size:1rem;line-height:1}.filter-mode-description{color:var(--ctp-subtext0);font-size:.8rem;font-style:italic;margin-top:.5rem;padding:.5rem;background:var(--ctp-surface0);border-radius:4px;border-left:3px solid var(--ctp-blue)}.filter-toggle-group{display:flex;border:1px solid var(--ctp-surface2);border-radius:6px;overflow:hidden;width:100%;margin-bottom:.5rem}.filter-toggle-btn{flex:1;padding:.6rem 1rem;background:var(--ctp-surface0);color:var(--ctp-text);border:none;cursor:pointer;font-size:.9rem;transition:all .2s;border-right:1px solid var(--ctp-surface2)}.filter-toggle-btn:last-child{border-right:none}.filter-toggle-btn:hover{background:var(--ctp-surface1)}.filter-toggle-btn.active{background:var(--ctp-blue);color:var(--ctp-base);font-weight:600}.filter-icon{font-size:1.1rem;line-height:1;display:inline-block;flex-shrink:0}.filter-label-with-icon{display:flex;align-items:center;gap:.4rem;flex:1}.filter-label-with-icon .filter-icon{width:20px!important;max-width:20px!important;min-width:20px!important;flex:0 0 auto!important;overflow:hidden;text-align:center}.filter-group{margin-bottom:1rem}.filter-group label{color:var(--ctp-text);font-size:.9rem;display:block;margin-bottom:.5rem}.filter-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.6rem .75rem;border-radius:6px;transition:background .2s;margin-bottom:.5rem}.filter-checkbox:hover{background:var(--ctp-surface0)}.filter-checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px;flex-shrink:0}.filter-checkbox span{flex:1}.filter-radio-group{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.filter-role-group{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.5rem}.filter-radio{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.filter-radio:hover{background:var(--ctp-surface0)}.filter-radio input[type=radio]{cursor:pointer;width:16px;height:16px}.filter-range-group{display:flex;gap:1rem;margin-top:.5rem}.filter-range-input{flex:1;display:flex;align-items:center;gap:.5rem}.filter-range-input label{margin:0;min-width:40px}.filter-range-input input[type=number]{flex:1;background:var(--ctp-surface0);border:1px solid var(--ctp-surface2);color:var(--ctp-text);padding:.5rem;border-radius:4px;font-size:.9rem}.filter-popup-actions{display:flex;gap:.5rem;padding:1rem;border-top:1px solid var(--ctp-surface2);background:var(--ctp-mantle);flex-shrink:0}.filter-reset-btn,.filter-apply-btn{flex:1;padding:.75rem;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.filter-reset-btn{background:var(--ctp-surface1);color:var(--ctp-text)}.filter-reset-btn:hover{background:var(--ctp-surface2)}.filter-apply-btn{background:var(--ctp-blue);color:var(--ctp-base)}.filter-apply-btn:hover{background:var(--ctp-sapphire)}.collapse-nodes-btn{position:absolute;top:8px;left:8px;background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:0;border-radius:4px;font-size:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;width:18px;height:18px;z-index:10}.collapse-nodes-btn:hover{background:var(--ctp-blue);border-color:var(--ctp-blue);color:var(--ctp-base);transform:scale(1.1)}.nodes-sidebar.collapsed .sidebar-header{display:flex;align-items:center;justify-content:center;padding:.5rem;border-bottom:none}.nodes-sidebar.collapsed .collapse-nodes-btn{position:static;margin:auto}.nodes-sidebar.collapsed .sidebar-header h3,.nodes-sidebar.collapsed .sidebar-header-content,.nodes-sidebar.collapsed .node-controls{display:none}.filter-input-small{background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:.5rem .75rem;border-radius:6px;font-size:.9rem;width:100%;transition:border-color .2s}.filter-input-small:focus{outline:none;border-color:var(--ctp-blue)}.filter-input-small::placeholder{color:var(--ctp-overlay1)}.sort-controls{display:flex;gap:.5rem;margin-top:.5rem}.sort-dropdown{background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:.4rem .6rem;border-radius:6px;font-size:.85rem;flex:1;cursor:pointer;transition:border-color .2s}.sort-dropdown:focus{outline:none;border-color:var(--ctp-blue)}.sort-dropdown:hover{border-color:var(--ctp-surface2)}.sort-direction-btn{background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:.4rem .75rem;border-radius:6px;font-size:1.2rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-width:40px}.sort-direction-btn:hover{background:var(--ctp-surface2);border-color:var(--ctp-blue)}.sort-direction-btn:active{transform:scale(.95)}.nodes-list{flex:1;overflow-y:auto;padding:.5rem 0}.node-item{padding:.75rem 1rem;border-bottom:1px solid var(--ctp-surface1);cursor:pointer;transition:all .2s ease;position:relative}.node-item:hover{background:var(--ctp-surface1)}.node-item.selected{background:var(--ctp-blue);color:var(--ctp-base)}.node-item.selected .node-stats .stat{color:#1e1e2ecc}.node-item.selected .node-time,.node-item.selected .node-location{color:#1e1e2eb3}.node-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.node-name{font-weight:600;font-size:.95rem;flex:1;margin-right:.5rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.node-actions{display:flex;align-items:center;gap:.5rem}.dm-icon{background:var(--ctp-blue);border:none;border-radius:6px;padding:.25rem .5rem;font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.dm-icon:hover{background:var(--ctp-sapphire);transform:scale(1.1)}.dm-icon:active{transform:scale(.95)}.favorite-star{background:none;border:none;font-size:1.2rem;padding:0;margin-right:.5rem;cursor:pointer;transition:all .2s ease;line-height:1}.favorite-star:hover{transform:scale(1.2);filter:brightness(1.2)}.favorite-star:active{transform:scale(.9)}.favorite-indicator{font-size:1rem;margin-right:.5rem}.node-short{font-size:.8rem;font-weight:500;color:var(--ctp-subtext1);background:var(--ctp-surface2);padding:.2rem .5rem;border-radius:4px;min-width:fit-content}.node-item.selected .node-short{background:#1e1e2e33;color:#1e1e2ecc}.node-details{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:.4rem}.node-stats{display:flex;gap:.75rem;flex:1}.stat{font-size:.8rem;color:var(--ctp-subtext1);display:flex;align-items:center;gap:.25rem}.node-time{font-size:.75rem;color:var(--ctp-subtext0);text-align:right}.node-indicators{display:flex;gap:.5rem;margin-top:.25rem;flex-wrap:wrap}.node-location{font-size:.75rem;color:var(--ctp-subtext0)}.node-telemetry,.node-weather{font-size:.75rem;color:var(--ctp-subtext0);cursor:help}.node-hops{font-size:.75rem;color:var(--ctp-subtext0);cursor:help;background:var(--ctp-surface1);padding:.1rem .4rem;border-radius:4px;font-weight:600}.nodes-list::-webkit-scrollbar{width:6px}.nodes-list::-webkit-scrollbar-track{background:transparent}.nodes-list::-webkit-scrollbar-thumb{background:var(--ctp-overlay0);border-radius:3px}.nodes-list::-webkit-scrollbar-thumb:hover{background:var(--ctp-overlay1)}.map-container{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--ctp-surface0);z-index:1}.map-placeholder{display:flex;align-items:center;justify-content:center;height:100%;background:var(--ctp-surface0)}.placeholder-content{text-align:center;color:var(--ctp-subtext1)}.placeholder-content h3{margin:0 0 .5rem;color:var(--ctp-text)}.placeholder-content p{margin:0;font-size:.9rem}.map-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;pointer-events:none}.overlay-content{background:#1e1e2ef2;border:2px solid var(--ctp-surface2);border-radius:12px;padding:2rem;text-align:center;color:var(--ctp-subtext1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 8px 32px #0000004d}.overlay-content h3{margin:0 0 1rem;color:var(--ctp-text);font-size:1.2rem}.overlay-content p{margin:.5rem 0;font-size:.9rem;line-height:1.4}.leaflet-popup-content-wrapper{background:var(--ctp-surface0);color:var(--ctp-text);border-radius:8px;box-shadow:0 4px 12px #0000004d}.leaflet-popup-tip{background:var(--ctp-surface0)}.node-popup{min-width:200px}.popup-header{margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--ctp-surface2)}.popup-short{color:var(--ctp-subtext1);margin-left:.5rem;font-size:.9rem}.popup-details{font-size:.85rem;line-height:1.5}.popup-details>div{margin:.25rem 0;color:var(--ctp-subtext1)}.popup-dm-btn{width:100%;margin-top:.75rem;padding:.5rem 1rem;background:var(--ctp-blue);color:var(--ctp-base);border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.popup-dm-btn:hover{background:var(--ctp-sapphire);transform:translateY(-1px);box-shadow:0 4px 8px #0003}@media (max-width: 768px){.nodes-split-view{top:48px;left:48px}.filter-popup{width:70%!important;max-width:70%!important}.messages-split-view .node-dropdown-mobile{display:block!important;position:relative;margin-bottom:.75rem;z-index:10}.node-dropdown-select{width:100%;padding:.75rem 2.5rem .75rem .75rem;background:var(--ctp-surface0);border:2px solid var(--ctp-surface2);border-radius:8px;color:var(--ctp-text);font-size:.875rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23cdd6f4' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.node-dropdown-select:focus{outline:none;border-color:var(--ctp-blue)}.messages-split-view .messages-sidebar{display:none!important}.messages-split-view .nodes-main-content{padding-left:.5rem;padding-right:.5rem;padding-top:0}.messages-split-view .dm-header{display:flex;flex-direction:column}.messages-split-view .dm-header-top{order:-2;margin-bottom:.75rem}.messages-split-view .traceroute-info{order:-1;margin-bottom:.75rem}.nodes-sidebar{top:0;left:0;right:auto;width:90vw;max-width:350px;max-height:calc(100vh - 120px);border-radius:12px}.nodes-sidebar.collapsed{top:0;left:0;width:auto;max-width:40px;max-height:40px;padding:0}.nodes-sidebar.collapsed .sidebar-header{padding:.5rem;min-height:40px}.map-container{width:100%;height:100%}.map-controls{top:16px;right:8px;left:56px;max-width:calc(100vw - 64px);padding:.5rem}.map-control-item span{font-size:.8rem}.nodes-split-view .leaflet-top.leaflet-left{bottom:10px!important;right:10px!important}}.sender-dot.clickable{cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.sender-dot.clickable:hover{background-color:var(--ctp-blue);transform:scale(1.1);box-shadow:0 2px 8px #89b4fa4d}.node-popup{background:var(--ctp-surface0);border:1px solid var(--ctp-surface2);border-radius:8px;padding:12px;box-shadow:0 4px 20px #0006;max-width:280px;font-size:14px;z-index:1000}.node-popup .popup-header{margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--ctp-surface2)}.node-popup .popup-header strong{color:var(--ctp-text);font-size:15px}.node-popup .popup-short{color:var(--ctp-subtext1);font-weight:400;margin-left:4px}.node-popup .popup-details{display:flex;flex-direction:column;gap:4px}.node-popup .popup-details>div{color:var(--ctp-subtext0);font-size:13px}.message-meta{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:4px}.hop-count{font-size:11px;color:var(--ctp-overlay1);font-style:italic;white-space:nowrap}.node-role{font-size:12px;color:var(--ctp-overlay1);font-weight:400;margin-left:6px}@media (max-width: 768px){.node-popup{max-width:240px;padding:10px;font-size:13px}.node-popup .popup-header strong{font-size:14px}.node-popup .popup-details>div{font-size:12px}}.message-content{display:flex;flex-direction:column;gap:4px;width:100%}.replied-message{display:flex;align-items:flex-start;gap:6px;padding:6px 10px;background:var(--ctp-surface1);border-left:3px solid var(--ctp-blue);border-radius:6px;font-size:12px;margin-bottom:4px;opacity:.8}.reply-arrow{color:var(--ctp-blue);font-size:14px;flex-shrink:0}.reply-content{display:flex;flex-direction:column;gap:2px;overflow:hidden}.reply-from{color:var(--ctp-blue);font-weight:600;font-size:11px}.reply-text{color:var(--ctp-subtext0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.message-reactions{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.reaction{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;background:var(--ctp-surface1);border:1px solid var(--ctp-surface2);border-radius:12px;font-size:14px;cursor:pointer;transition:all .2s ease}.reaction:hover{background:var(--ctp-surface2);transform:scale(1.1)}.unread-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--ctp-red);color:var(--ctp-base);border-radius:10px;font-size:11px;font-weight:600;margin-left:8px}.unread-badge-inline{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--ctp-red);color:var(--ctp-base);border-radius:9px;font-size:10px;font-weight:600;margin-left:6px}.tab-notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--ctp-red);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.tab-btn{position:relative}.dm-header{flex-shrink:0;margin-bottom:1rem}.dm-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.traceroute-info{background:var(--ctp-surface1);border-left:4px solid var(--ctp-mauve);padding:.75rem;border-radius:8px;font-size:.85rem;margin-top:.5rem}.traceroute-route{margin-bottom:.5rem;color:var(--ctp-text);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.traceroute-route:last-of-type{margin-bottom:.25rem}.traceroute-route strong{color:var(--ctp-mauve);margin-right:.5rem;display:inline-block;min-width:80px}.traceroute-age{font-size:.75rem;color:var(--ctp-subtext0);font-style:italic;margin-top:.5rem}.traceroute-btn{background:var(--ctp-mauve);color:var(--ctp-base);border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.traceroute-btn:hover:not(:disabled){background:var(--ctp-pink);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.traceroute-btn:disabled{opacity:.5;cursor:not-allowed}.message-item.traceroute{background:var(--ctp-surface1);border-left:4px solid var(--ctp-mauve)}.traceroute-badge{background:var(--ctp-mauve);color:var(--ctp-base);padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.5px}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top:2px solid var(--ctp-base);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.node-popup{min-width:240px;max-width:280px;max-height:400px;overflow-y:auto;overflow-x:hidden;font-family:system-ui,-apple-system,sans-serif}.node-popup::-webkit-scrollbar{width:6px}.node-popup::-webkit-scrollbar-track{background:var(--ctp-surface0);border-radius:3px}.node-popup::-webkit-scrollbar-thumb{background:var(--ctp-surface2);border-radius:3px}.node-popup::-webkit-scrollbar-thumb:hover{background:var(--ctp-overlay0)}.node-popup-header{margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid var(--ctp-mauve)}.node-popup-title{font-size:1.1rem;font-weight:700;color:var(--ctp-text);margin-bottom:.25rem;line-height:1.3;overflow-wrap:break-word;word-break:break-word}.node-popup-subtitle{font-size:.9rem;font-weight:600;color:var(--ctp-mauve);background:var(--ctp-surface1);padding:.25rem .5rem;border-radius:4px;display:inline-block;margin-top:.25rem}.node-popup-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.node-popup-item{display:flex;align-items:center;gap:.4rem;padding:.4rem .5rem;background:var(--ctp-surface0);border-radius:6px;font-size:.85rem;transition:background .2s ease}.node-popup-item:hover{background:var(--ctp-surface1)}.node-popup-icon{font-size:1.1rem;line-height:1;flex-shrink:0}.node-popup-value{color:var(--ctp-text);font-weight:500;overflow-wrap:break-word;word-break:break-word;line-height:1.2;max-width:100%}.node-popup-footer{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--ctp-surface0);border-radius:6px;font-size:.8rem;color:var(--ctp-subtext1);margin-bottom:.75rem;justify-content:center}.node-popup-btn{width:100%;padding:.6rem 1rem;background:var(--ctp-blue);color:var(--ctp-base);border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.node-popup-btn:hover{background:var(--ctp-sapphire);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.node-popup-btn:active{transform:translateY(0)}.route-popup{min-width:200px}.route-popup h4{margin:0 0 .5rem;color:var(--ctp-mauve);font-size:1rem;border-bottom:2px solid var(--ctp-mauve);padding-bottom:.25rem}.route-endpoints{margin:.75rem 0;padding:.5rem;background:var(--ctp-surface1);border-radius:4px;text-align:center;font-size:.9rem}.route-endpoints strong{color:var(--ctp-text);font-weight:600}.route-usage{margin-top:.5rem;font-size:.85rem;color:var(--ctp-subtext1);text-align:center}.route-usage strong{color:var(--ctp-mauve);font-weight:600}.route-snr-stats{margin-top:.75rem;padding:.5rem;background:var(--ctp-surface1);border-radius:4px;border:1px solid var(--ctp-surface2)}.route-snr-stats h5{margin:0 0 .5rem;color:var(--ctp-mauve);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.snr-stat-row{display:flex;justify-content:space-between;margin:.25rem 0;font-size:.85rem}.snr-stat-row:only-child{justify-content:center;font-size:1rem}.route-popup .snr-stat-row .stat-label{color:var(--ctp-subtext1);font-weight:500;font-size:.875rem;font-family:inherit}.route-popup .snr-stat-row .stat-value{color:var(--ctp-text);font-weight:600;font-size:.875rem;font-family:inherit}.snr-timeline-chart{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--ctp-surface2)}.snr-timeline-chart .recharts-wrapper{font-size:10px}.map-controls{position:absolute;top:10px;right:10px;z-index:1000;background:var(--ctp-surface0);padding:.75rem;border-radius:8px;box-shadow:0 2px 8px #0000004d}.map-control-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.map-control-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--ctp-mauve)}.map-control-item span{color:var(--ctp-text);font-size:.9rem;font-weight:500}.app-footer{background:var(--ctp-crust);border-top:1px solid var(--ctp-surface0);padding:.75rem 1rem;margin-top:auto}.footer-content{display:flex;align-items:center;justify-content:center;gap:1rem;font-size:.85rem;color:var(--ctp-subtext0)}.footer-title{font-weight:600;color:var(--ctp-mauve)}.footer-version{color:var(--ctp-subtext1);font-family:Courier New,monospace;background:var(--ctp-surface0);padding:.15rem .5rem;border-radius:4px}.footer-link{color:var(--ctp-blue);text-decoration:none;transition:color .2s ease;font-weight:500}.footer-link:hover{color:var(--ctp-sapphire);text-decoration:underline}.settings-header-card{background:var(--ctp-surface0);border:1px solid var(--ctp-surface1);border-radius:12px;padding:2rem;margin-bottom:2rem;display:flex;align-items:center;gap:1.5rem;box-shadow:0 4px 12px #0003;flex-wrap:wrap}.automation-section-header{justify-content:space-between}.settings-logo{height:4rem;width:auto;object-fit:contain}.settings-title-section{display:flex;flex-direction:column;gap:.25rem}.settings-app-name{margin:0;color:var(--ctp-lavender);font-size:2rem;font-weight:700}.settings-version{margin:0;color:var(--ctp-subtext1);font-size:1rem;font-family:Courier New,monospace}.settings-content{background:var(--ctp-surface0);border:1px solid var(--ctp-surface1);border-radius:12px;padding:2rem;min-height:200px}.settings-section{margin-bottom:2rem}.settings-section:last-child{margin-bottom:0}.settings-section h3{color:var(--ctp-text);font-size:1.2rem;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--ctp-surface2)}.setting-item{margin-bottom:1.5rem}.setting-item:last-child{margin-bottom:0}.setting-item label{display:flex;flex-direction:column;gap:.5rem;color:var(--ctp-text);font-size:1rem;font-weight:500;margin-bottom:.75rem}.setting-description{font-size:.85rem;color:var(--ctp-subtext0);font-weight:400}.setting-input{background:var(--ctp-surface1);border:2px solid var(--ctp-surface2);color:var(--ctp-text);padding:.75rem 1rem;border-radius:8px;font-size:1rem;width:200px;transition:border-color .2s,background-color .2s}.setting-input:focus{outline:none;border-color:var(--ctp-blue);background:var(--ctp-base)}.setting-input:hover{border-color:var(--ctp-overlay0)}.danger-zone{border:2px solid var(--ctp-red);border-radius:8px;padding:1.5rem;background:#f38ba80d;margin-top:2rem}.danger-zone h3{color:var(--ctp-red);border-bottom-color:var(--ctp-red)}.danger-zone-description{color:var(--ctp-subtext0);font-size:.95rem;margin-bottom:1.5rem;font-style:italic}.danger-action{display:flex;flex-direction:column;padding:1rem;margin-bottom:1rem;background:var(--ctp-surface0);border-radius:8px;border:1px solid var(--ctp-surface2)}.danger-action:last-child{margin-bottom:0}.danger-action-info{margin-bottom:1rem}.danger-action-info h4{color:var(--ctp-text);font-size:1rem;margin:0 0 .5rem;font-weight:600}.danger-action-info p{color:var(--ctp-subtext0);font-size:.875rem;margin:0;line-height:1.6}.danger-action .danger-button{align-self:flex-end}.danger-button{background:var(--ctp-red);color:var(--ctp-base);border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s;white-space:nowrap;min-width:150px}.danger-button:hover{background:var(--ctp-maroon);transform:translateY(-1px)}.danger-button:active{transform:translateY(0)}.settings-buttons{display:flex;gap:1rem;margin-top:1rem}.save-button{background:var(--ctp-green);color:var(--ctp-base);border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s,opacity .2s;white-space:nowrap;min-width:120px;display:flex;align-items:center;justify-content:center}.save-button:hover:not(:disabled){background:var(--ctp-teal);transform:translateY(-1px)}.save-button:active:not(:disabled){transform:translateY(0)}.save-button:disabled{opacity:.5;cursor:not-allowed}.reset-button{background:var(--ctp-yellow);color:var(--ctp-base);border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s,opacity .2s;white-space:nowrap;min-width:120px;display:flex;align-items:center;justify-content:center}.reset-button:hover:not(:disabled){background:var(--ctp-peach);transform:translateY(-1px)}.reset-button:active:not(:disabled){transform:translateY(0)}.reset-button:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--ctp-base);border:1px solid var(--ctp-surface2);border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--ctp-surface2)}.modal-header h2{margin:0;color:var(--ctp-text);font-size:1.5em}.modal-close{background:none;border:none;font-size:2em;color:var(--ctp-subtext0);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:var(--ctp-surface2);color:var(--ctp-text)}.modal-body{padding:20px}.status-grid{display:grid;gap:16px}.status-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--ctp-surface0);border-radius:8px;border:1px solid var(--ctp-surface1)}.status-item strong{color:var(--ctp-subtext1);font-weight:600}.status-item span{color:var(--ctp-text);font-family:Courier New,monospace}.channel-info-modal{max-width:500px}.channel-info-grid{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--ctp-surface0);border-radius:6px;border:1px solid var(--ctp-surface1)}.info-label{color:var(--ctp-subtext1);font-weight:600;font-size:.9rem}.info-value{color:var(--ctp-text);font-family:Courier New,monospace;font-size:.9rem;text-align:right;word-break:break-all;max-width:65%}.status-encrypted{color:var(--ctp-green);font-weight:600}.status-unencrypted{color:var(--ctp-yellow);font-weight:600}.status-enabled{color:var(--ctp-green);font-weight:600}.status-disabled{color:var(--ctp-overlay0);font-weight:600}.leaflet-marker-icon.arrow-icon{background:transparent!important;border:none!important;pointer-events:none}.leaflet-marker-icon.arrow-icon div{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-shadow:0 0 3px rgba(0,0,0,.8)}.login-divider{display:flex;align-items:center;margin:24px 0;color:var(--ctp-subtext0)}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--ctp-surface2)}.login-divider span{padding:0 16px;font-size:.9em;font-weight:600}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--ctp-subtext1);font-weight:600;font-size:.95em}.form-group input{width:100%;padding:12px;background:var(--ctp-surface0);border:1px solid var(--ctp-surface2);border-radius:8px;color:var(--ctp-text);font-size:1em;transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--ctp-blue);box-shadow:0 0 0 3px #89b4fa1a}.form-group input:disabled{opacity:.5;cursor:not-allowed}.error-message{padding:12px;background:#f38ba81a;border:1px solid var(--ctp-red);border-radius:8px;color:var(--ctp-red);margin-bottom:16px;font-size:.95em;white-space:pre-line;text-align:left}.success-message{padding:12px;background:#a6e3a11a;border:1px solid var(--ctp-green);border-radius:8px;color:var(--ctp-green);margin-bottom:16px;font-size:.95em}.form-hint{display:block;margin-top:4px;font-size:.85em;color:var(--ctp-subtext0)}.modal-actions{display:flex;gap:12px;margin-top:20px}.modal-actions .button{flex:1}.button{width:100%;padding:12px 24px;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .2s ease}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background:var(--ctp-blue);color:var(--ctp-base)}.button-primary:hover:not(:disabled){background:var(--ctp-sapphire);transform:translateY(-1px);box-shadow:0 4px 12px #89b4fa4d}.button-secondary{background:var(--ctp-surface1);color:var(--ctp-text);border:1px solid var(--ctp-surface2)}.button-secondary:hover:not(:disabled){background:var(--ctp-surface2);transform:translateY(-1px)}.close-button{background:none;border:none;font-size:2em;color:var(--ctp-subtext0);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;line-height:1}.close-button:hover{background:var(--ctp-surface2);color:var(--ctp-text)}.user-menu{position:relative;margin-left:16px}.user-menu-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--ctp-surface0);border:1px solid var(--ctp-surface2);border-radius:8px;color:var(--ctp-text);cursor:pointer;font-size:.95em;font-weight:500;transition:all .2s ease}.user-menu-button:hover{background:var(--ctp-surface1);border-color:var(--ctp-blue);transform:translateY(-1px)}.user-icon{font-size:1.2em}.user-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-badge{font-size:.9em;opacity:.9}.menu-overlay{position:fixed;top:0;left:var(--sidebar-width, 240px);right:0;bottom:0;z-index:9998}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:250px;background:var(--ctp-base);border:1px solid var(--ctp-surface2);border-radius:8px;box-shadow:0 10px 40px #0000004d;z-index:9999;overflow:hidden}.user-menu-header{padding:16px;background:var(--ctp-surface0);border-bottom:1px solid var(--ctp-surface2)}.user-menu-name{font-weight:600;color:var(--ctp-text);font-size:1.1em;margin-bottom:4px}.user-menu-username{color:var(--ctp-subtext0);font-size:.9em;margin-bottom:4px}.user-menu-email{color:var(--ctp-subtext1);font-size:.85em;margin-bottom:8px}.user-menu-provider{display:inline-block;padding:2px 8px;background:var(--ctp-surface1);border-radius:4px;font-size:.75em;color:var(--ctp-subtext0);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.user-menu-admin{display:inline-block;margin-left:8px;padding:2px 8px;background:#f9e2af33;border:1px solid var(--ctp-yellow);border-radius:4px;font-size:.75em;color:var(--ctp-yellow);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.user-menu-divider{height:1px;background:var(--ctp-surface2)}.user-menu-item{width:100%;padding:12px 16px;background:none;border:none;color:var(--ctp-text);text-align:left;cursor:pointer;font-size:.95em;transition:all .2s ease}.user-menu-item:hover:not(:disabled){background:var(--ctp-surface0);color:var(--ctp-red)}.user-menu-item:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.menu-overlay{left:0!important}}.login-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--ctp-blue);border:none;border-radius:8px;color:var(--ctp-base);cursor:pointer;font-size:.95em;font-weight:600;transition:all .2s ease;margin-left:16px}.login-button:hover{background:var(--ctp-sapphire);transform:translateY(-1px);box-shadow:0 4px 12px #89b4fa4d}@media (max-width: 768px){.user-name{display:none}.user-menu-dropdown{right:-8px}}.users-tab{padding:20px;max-width:1600px;margin:0 auto;height:100%;overflow:auto}.users-container{display:grid;grid-template-columns:350px 1fr;gap:24px;height:calc(100vh - 200px);min-height:600px}.users-list{background:var(--ctp-surface0);border-radius:12px;padding:16px;overflow-y:auto}.users-list-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--ctp-surface2)}.users-list-header h2{margin:0;color:var(--ctp-text);font-size:1.2em;flex-shrink:0}.users-list-header .button{white-space:nowrap;flex-shrink:0;width:auto;min-width:auto}.user-item{padding:12px;background:var(--ctp-base);border:1px solid var(--ctp-surface1);border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center}.user-item:hover{background:var(--ctp-surface1);border-color:var(--ctp-blue)}.user-item.selected{background:var(--ctp-surface1);border-color:var(--ctp-blue);box-shadow:0 0 0 2px #89b4fa33}.user-item-info{flex:1}.user-item-name{font-weight:600;color:var(--ctp-text);margin-bottom:4px;display:flex;align-items:center;gap:8px}.user-item-meta{font-size:.85em;color:var(--ctp-subtext0)}.inactive-badge{padding:2px 8px;background:#f38ba833;border:1px solid var(--ctp-red);border-radius:4px;font-size:.75em;color:var(--ctp-red);text-transform:uppercase;font-weight:600}.user-details{background:var(--ctp-surface0);border-radius:12px;padding:24px;overflow-y:auto}.user-details h2{margin:0 0 20px;color:var(--ctp-text)}.user-details h3{margin:24px 0 16px;color:var(--ctp-text);font-size:1.1em}.user-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.info-item{padding:12px;background:var(--ctp-base);border-radius:8px;border:1px solid var(--ctp-surface1)}.info-item label{display:block;font-size:.85em;color:var(--ctp-subtext0);margin-bottom:4px;font-weight:600}.info-item div{color:var(--ctp-text);font-size:1em}.user-actions{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.user-actions .button{width:auto;padding:8px 16px}.permissions-grid{display:grid;gap:12px;margin-bottom:24px}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--ctp-base);border:1px solid var(--ctp-surface1);border-radius:8px}.permission-label{font-weight:600;color:var(--ctp-text)}.permission-actions{display:flex;gap:24px}.permission-actions label{display:flex;align-items:center;gap:8px;color:var(--ctp-subtext1);cursor:pointer;-webkit-user-select:none;user-select:none}.permission-actions input[type=checkbox]{width:18px;height:18px;cursor:pointer}@media (max-width: 1200px){.users-container,.user-info-grid{grid-template-columns:1fr}}.audit-log-tab{padding:24px;max-width:100%;overflow-x:hidden}.audit-log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.audit-log-header h2{font-size:1.5rem;font-weight:600;color:var(--ctp-text);margin:0}.audit-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--ctp-surface0);border:1px solid var(--ctp-surface1);border-radius:8px;padding:16px}.stat-card h3{font-size:.875rem;font-weight:500;color:var(--ctp-subtext1);margin:0 0 8px}.stat-value{font-size:1.875rem;font-weight:700;color:var(--ctp-text);margin:0}.stat-label{font-size:1.125rem;font-weight:600;color:var(--ctp-text);margin:0}.audit-filters{background:var(--ctp-surface0);border:1px solid var(--ctp-surface1);border-radius:8px;padding:20px;margin-bottom:24px}.audit-filters h3{font-size:1rem;font-weight:600;color:var(--ctp-text);margin:0 0 16px}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.filter-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:16px}.inline-group{display:flex;align-items:center;gap:8px;margin:0}.inline-group label{margin:0;padding:0}.inline-group select{width:auto;min-width:100px}.audit-table-container{background:var(--ctp-surface0);border:1px solid var(--ctp-surface1);border-radius:8px;overflow:hidden;margin-bottom:24px}.audit-table{width:100%;border-collapse:collapse}.audit-table thead{background:var(--ctp-surface1)}.audit-table thead th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;color:var(--ctp-subtext1);text-transform:uppercase;letter-spacing:.05em}.audit-table tbody tr.audit-row{border-bottom:1px solid var(--ctp-surface1);cursor:pointer;transition:background-color .15s ease}.audit-table tbody tr.audit-row:hover{background:var(--ctp-surface1)}.audit-table tbody td{padding:12px 16px;font-size:.875rem;color:var(--ctp-text)}.timestamp-cell{white-space:nowrap;color:var(--ctp-subtext0)}.system-label{color:var(--ctp-subtext0);font-style:italic}.action-cell{font-weight:500}.action-error{color:var(--ctp-red)}.action-warning{color:var(--ctp-yellow)}.action-success{color:var(--ctp-green)}.details-cell{max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-detail-row td{padding:0!important;background:var(--ctp-mantle)}.audit-details{padding:16px 24px}.detail-section{margin-bottom:16px}.detail-section:last-child{margin-bottom:0}.detail-section strong{display:block;font-size:.875rem;font-weight:600;color:var(--ctp-text);margin-bottom:8px}.detail-pre{background:var(--ctp-base);border:1px solid var(--ctp-surface1);border-radius:4px;padding:12px;font-size:.75rem;font-family:Courier New,Courier,monospace;overflow-x:auto;margin:0;color:var(--ctp-text)}.detail-comparison{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.detail-section.before .detail-pre{background:#f38ba81a;border-color:var(--ctp-red)}.detail-section.after .detail-pre{background:#a6e3a11a;border-color:var(--ctp-green)}.audit-pagination{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.pagination-info{font-size:.875rem;color:var(--ctp-subtext1)}.pagination-controls{display:flex;align-items:center;gap:12px}.page-indicator{padding:8px 12px;font-size:.875rem;color:var(--ctp-text)}.audit-loading,.audit-empty{text-align:center;padding:48px 24px;color:var(--ctp-subtext0);font-size:1rem}.audit-empty{background:var(--ctp-surface0);border:1px solid var(--ctp-surface1);border-radius:8px}@media (max-width: 1024px){.audit-stats,.filter-grid,.detail-comparison{grid-template-columns:1fr}}@media (max-width: 768px){.audit-log-tab{padding:16px}.audit-log-header{flex-direction:column;align-items:flex-start;gap:12px}.audit-table-container{overflow-x:auto}.audit-table{min-width:800px}.filter-actions{flex-direction:column;align-items:stretch}.pagination-controls{width:100%;justify-content:center}}.telemetry-graphs{width:100%;margin-bottom:20px;padding:20px;background-color:#181825;border-radius:8px}.telemetry-title{color:#cdd6f4;margin:0 0 20px;font-size:1.2rem;font-weight:600}.telemetry-loading,.telemetry-empty{color:#a6adc8;text-align:center;padding:20px;font-style:italic}.graphs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.graph-container{background-color:#1e1e2e;border:1px solid #45475a;border-radius:8px;padding:15px}.graph-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.graph-title{color:#cdd6f4;margin:0;font-size:1rem;font-weight:500}.favorite-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#585b70;transition:color .2s ease}.favorite-btn:hover,.favorite-btn.favorited{color:#f9e2af}@media (max-width: 768px){.graphs-grid{grid-template-columns:1fr}.telemetry-graphs{padding:10px}}.dashboard{padding:20px;width:100%;max-width:100%;overflow-x:hidden}.dashboard-title{color:#cdd6f4;margin:0 0 10px;font-size:1.5rem;font-weight:600}.dashboard-subtitle{color:#a6adc8;margin:0 0 20px;font-size:.9rem}.dashboard-loading,.dashboard-error,.dashboard-empty{color:#a6adc8;text-align:center;padding:40px 20px;background-color:#181825;border-radius:8px;margin:20px}.dashboard-empty h2{color:#cdd6f4;margin-bottom:10px}.dashboard-empty p{color:#a6adc8}.dashboard-error{color:#f38ba8}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:20px;width:100%}.dashboard-chart-container{background-color:#1e1e2e;border:1px solid #45475a;border-radius:8px;padding:15px}.dashboard-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.dashboard-chart-title{color:#cdd6f4;margin:0;font-size:.95rem;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:10px}.dashboard-remove-btn{background:none;border:none;color:#585b70;font-size:1.2rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s ease;flex-shrink:0}.dashboard-remove-btn:hover{color:#f38ba8}.dashboard-no-data{color:#a6adc8;text-align:center;padding:40px 20px;font-style:italic}@media (max-width: 1024px){.dashboard-grid{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard{padding:10px}.dashboard-grid{gap:15px}.dashboard-chart-container{padding:10px}.dashboard-chart-title{font-size:.9rem}}.map-legend{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:8px;box-shadow:0 2px 8px #0000004d;display:flex;align-items:center;gap:12px;font-family:system-ui,-apple-system,sans-serif;font-size:12px}.legend-title{font-weight:600;color:#333;margin-right:4px}.legend-item{display:flex;align-items:center;gap:4px}.legend-dot{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.2);flex-shrink:0}.legend-label{color:#333;font-weight:500;white-space:nowrap}@media (max-width: 768px){.map-legend{display:none}}.sidebar{position:fixed;left:0;top:0;bottom:0;height:100vh;width:60px;background:var(--color-bg-primary, #1a1a1a);border-right:1px solid var(--color-border, #333);transition:width .3s ease,transform .3s ease;z-index:10001;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);padding-bottom:max(1rem,env(safe-area-inset-bottom));padding-left:env(safe-area-inset-left);box-sizing:border-box}.sidebar.collapsed{width:60px}.sidebar:not(.collapsed){width:240px}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--color-border, #333);display:flex;align-items:center;gap:12px;background:var(--color-bg-secondary, #1a1a1a);margin-top:auto}.sidebar.collapsed .sidebar-footer{justify-content:center;padding:12px 8px}.version-text{font-size:12px;color:var(--color-text-secondary, #999);font-weight:500;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.github-link{color:var(--color-text-secondary, #999);display:flex;align-items:center;justify-content:center;transition:color .2s;text-decoration:none}.github-link:hover{color:var(--color-text-primary, #e0e0e0)}.sidebar-toggle{position:absolute;right:8px;bottom:70px;background:var(--ctp-blue, #2a2a2a);border:1px solid var(--ctp-sapphire, #333);color:var(--ctp-base, #e0e0e0);width:36px;height:36px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;transition:all .2s;z-index:1;box-shadow:0 2px 8px #0000004d}.sidebar-toggle:hover{background:var(--ctp-sapphire, #74c7ec);transform:scale(1.05)}.sidebar-header{padding:12px;border-bottom:1px solid var(--color-border, #333);display:flex;align-items:center;gap:12px;background:var(--color-bg-primary, #1a1a1a);flex-shrink:0}.sidebar.collapsed .sidebar-header{justify-content:center;padding:12px 8px}.sidebar-logo{width:32px;height:32px;object-fit:contain;flex-shrink:0}.sidebar-header-text{display:flex;flex-direction:column;gap:2px;overflow:hidden;flex:1;min-width:0}.sidebar-app-name{font-size:16px;font-weight:600;color:var(--color-text-primary, #e0e0e0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-node-name{font-size:11px;color:var(--color-text-secondary, #999);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:8px 8px 120px;overflow-y:auto;overflow-x:hidden;flex:1}.sidebar-section-header{font-size:11px;font-weight:600;color:var(--color-text-secondary, #999);text-transform:uppercase;letter-spacing:.5px;padding:12px 12px 4px;margin-top:8px}.sidebar-section{display:flex;flex-direction:column;gap:2px}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;border-radius:6px;color:var(--color-text-primary, #e0e0e0);cursor:pointer;transition:background-color .2s;text-align:left;font-size:14px;position:relative;white-space:nowrap}.sidebar-nav-item:hover{background:var(--color-bg-secondary, #2a2a2a)}.sidebar-nav-item.active{background:var(--color-primary, #2196F3);color:#fff}.sidebar-nav-item .nav-icon{font-size:18px;width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-nav-item .nav-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .sidebar-nav-item{justify-content:center;padding:10px}.sidebar.collapsed .nav-label{display:none}.nav-notification-dot{width:8px;height:8px;background:#f44;border-radius:50%;flex-shrink:0;margin-left:auto}.sidebar.collapsed .nav-notification-dot{position:absolute;top:8px;right:8px}@media (max-width: 768px){.sidebar{width:48px;padding-bottom:6rem;padding-bottom:max(6rem,calc(env(safe-area-inset-bottom) + 4rem))}.sidebar:not(.collapsed){width:240px;box-shadow:2px 0 16px #0000004d}.sidebar.collapsed{width:48px}.app-main{margin-left:0!important;width:100%!important}.sidebar-toggle{background:var(--color-primary, #2196F3);color:#fff;right:6px}.sidebar.collapsed .sidebar-toggle{background:var(--color-primary, #2196F3);color:#fff}}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary, #3a3a3a);border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--color-border, #555)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:40px;max-width:400px;width:100%;text-align:center}.login-logo{margin-bottom:30px}.login-logo svg{color:#667eea;margin-bottom:10px}.login-logo h1{font-size:32px;font-weight:700;color:#2d3748;margin:0}.login-form-container{margin-bottom:30px}.login-form{display:flex;flex-direction:column;gap:16px}.login-form .form-group{text-align:left}.login-form .form-group label{display:block;margin-bottom:6px;font-weight:500;color:#4a5568;font-size:14px}.login-form .form-group input{width:100%;padding:12px;border:1px solid #cbd5e0;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.login-form .form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-form .form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.error-message{background-color:#fed7d7;color:#9b2c2c;padding:12px;border-radius:6px;font-size:14px;text-align:left;white-space:pre-line}.login-button{width:100%;padding:12px;font-size:16px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s;border:none}.login-button.button-primary{background-color:#667eea;color:#fff}.login-button.button-primary:hover:not(:disabled){background-color:#5568d3}.login-button.button-secondary{background-color:#edf2f7;color:#2d3748}.login-button.button-secondary:hover:not(:disabled){background-color:#e2e8f0}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-divider{margin:20px 0;position:relative;text-align:center}.login-divider:before{content:"";position:absolute;left:0;top:50%;width:100%;height:1px;background-color:#e2e8f0}.login-divider span{position:relative;background-color:#fff;padding:0 15px;color:#a0aec0;font-size:14px;font-weight:500}.login-footer{border-top:1px solid #e2e8f0;padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:13px}.login-footer .version{color:#718096}.login-footer .github-link{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s}.login-footer .github-link:hover{color:#5568d3;text-decoration:underline}@media (max-width: 480px){.login-container{padding:30px 20px}.login-logo h1{font-size:28px}.login-footer{flex-direction:column;gap:10px;text-align:center}}.tileset-selector{position:absolute;bottom:20px;left:50%;transform:translate(-20%);background:#fffffff2;border-radius:8px;padding:12px 16px;box-shadow:0 2px 8px #0003;display:flex;align-items:center;gap:12px;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tileset-selector-label{font-size:14px;font-weight:600;color:#333;white-space:nowrap}.tileset-buttons{display:flex;gap:8px}.tileset-button{display:flex;flex-direction:column;align-items:center;gap:6px;background:#fff;border:2px solid #ddd;border-radius:6px;padding:8px;cursor:pointer;transition:all .2s ease;min-width:80px}.tileset-button:hover{border-color:#007bff;transform:translateY(-2px);box-shadow:0 4px 8px #007bff33}.tileset-button.active{border-color:#007bff;background:#e7f3ff;box-shadow:0 0 0 2px #007bff1a}.tileset-preview{width:64px;height:64px;border-radius:4px;background-size:cover;background-position:center;background-repeat:no-repeat;box-shadow:0 2px 4px #0000001a}.tileset-name{font-size:11px;font-weight:500;color:#555;text-align:center;line-height:1.2;max-width:80px;word-wrap:break-word}.tileset-button.active .tileset-name{color:#007bff;font-weight:600}.collapse-button{background:#fff;border:2px solid #ddd;border-radius:6px;padding:8px 12px;cursor:pointer;font-size:16px;transition:all .2s ease;color:#555;min-width:40px}.collapse-button:hover{border-color:#007bff;color:#007bff;background:#f0f8ff}.expand-button{background:#fff;border:2px solid #007bff;border-radius:6px;padding:8px 16px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s ease;color:#007bff;white-space:nowrap}.expand-button:hover{background:#007bff;color:#fff}.tileset-selector.collapsed{padding:8px 12px;bottom:10px}@media (max-width: 768px){.tileset-selector{display:none}}@media (max-width: 1024px){.tileset-selector{bottom:10px;padding:8px 12px}.tileset-selector-label{font-size:12px}.tileset-buttons{gap:6px}.tileset-button{min-width:70px;padding:6px}.tileset-preview{width:56px;height:56px}.tileset-name{font-size:10px;max-width:70px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
