.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::-moz-selection{background:transparent}.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{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;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;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;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;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;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;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}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.table{display:table}.table-row{display:table-row}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{color:#172033;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f6f7f9}*{box-sizing:border-box}body{margin:0;min-width:0;overflow-x:hidden}a{color:inherit;text-decoration:none}button,.button{background:#176b87;border:0;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;min-height:40px;padding:0 16px}input,textarea,select{border:1px solid #cdd5df;border-radius:6px;font:inherit;padding:10px 12px;width:100%}button:disabled{cursor:not-allowed;opacity:.6}.auth-page{display:grid;min-height:100dvh;padding:16px;place-items:center}.auth-card{background:#fff;border:1px solid #e0e6ef;border-radius:8px;display:grid;gap:16px;max-width:420px;padding:28px;width:min(100%,420px)}.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#172033;color:#fff;padding:24px}.sidebar nav{display:grid;gap:8px}.sidebar a{border-radius:6px;padding:10px 12px}.sidebar a.router-link-active{background:#223354}.content,.portal{padding:32px}.topbar{display:flex;justify-content:flex-end;margin-bottom:24px}.user-menu{position:relative}.menu-toggle,.logout-button{background:#263445}.menu-panel{background:#fff;border:1px solid #d7dee8;border-radius:8px;box-shadow:0 12px 24px #0f172a1f;display:grid;min-width:220px;padding:8px;position:absolute;right:0;top:calc(100% + 8px);z-index:10}.menu-panel button{background:transparent;color:#172033;justify-content:flex-start;text-align:left}.dialog-backdrop{align-items:center;background:#0f172a73;display:grid;inset:0;padding:24px;position:fixed;z-index:1000}.dialog{background:#fff;border-radius:8px;display:grid;gap:12px;max-width:420px;padding:24px;width:100%}.dialog label{display:grid;gap:6px;font-weight:700}.tenant-dialog{max-height:calc(100vh - 48px);overflow:auto}.dialog-actions{display:flex;gap:12px;justify-content:flex-end}.secondary-button{background:#e6ebf2;color:#172033}.page-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.metric-grid{display:grid;gap:16px;grid-template-columns:repeat(3,minmax(0,1fr))}.metric-grid article,.table-row{background:#fff;border:1px solid #e0e6ef;border-radius:8px;padding:16px}.metric-grid strong,.metric-grid span{display:block}.row-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.pill-group{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.status-pill{border-radius:999px;font-size:12px;padding:4px 10px;text-transform:uppercase}.status-pill.open{background:#fff0c2;color:#8a5b00}.status-pill.closed{background:#d9f2e3;color:#1d6b3e}.status-pill.outside-radius{background:#ffe1df;color:#9f1f17}.location-meta{color:#5f6b7c;font-size:13px;margin-top:8px}.tenant-meta{color:#5f6b7c;display:flex;flex-wrap:wrap;font-size:13px;gap:8px 24px;margin-top:12px}.tenant-row{display:block;transition:border-color .15s ease,box-shadow .15s ease}.tenant-row:hover{border-color:#176b87;box-shadow:0 3px 10px #176b871f}.debug-banner{background:#fff7d6;border:1px solid #ead27a;border-radius:8px;margin-bottom:20px;padding:14px 16px}.table{display:grid;gap:10px}.actions{display:grid;gap:12px;max-width:640px}.attendance-state{border-radius:8px;display:grid;gap:4px;margin-bottom:16px;max-width:640px;padding:16px}.attendance-state.is-open{background:#fff0c2;border:1px solid #e5bd42}.attendance-state.is-closed{background:#eaf4ef;border:1px solid #9ad0b0}.error{color:#b42318}.error-details{background:#fff1f0;border:1px solid #f3b3ae;border-radius:8px;color:#8f1f16;font:inherit;max-width:720px;padding:12px 14px;white-space:pre-wrap;word-break:break-word}.success{color:#1d6b3e;font-weight:700}.debug{color:#5f6b7c;font-size:12px;margin:0;word-break:break-word}.trace{background:#f4f6f9;border-radius:6px;color:#324054;font-size:12px;margin:0;max-height:120px;overflow:auto;padding:10px;white-space:pre-wrap}@media(max-width:760px){.shell{grid-template-columns:1fr}.sidebar{position:static}.metric-grid{grid-template-columns:1fr}.page-header{align-items:flex-start;flex-direction:column}}.app-shell{--sidebar-width: 240px;background:#f5f7fb;color:#10213c;display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);min-height:100vh}.app-sidebar{background:radial-gradient(circle at 10% 14%,#17345a 0,#0c2341 42%,#091b34);color:#fff;display:flex;flex-direction:column;height:100vh;overflow:hidden;position:sticky;top:0;transition:width .2s ease;z-index:30}.brand{align-items:center;border-bottom:1px solid rgba(255,255,255,.07);display:flex;font-size:27px;gap:13px;height:92px;padding:0 28px}.brand-mark{align-items:center;background:#1577ed;border:3px solid #2c91ff;border-radius:50%;display:flex;height:40px;justify-content:center;width:40px}.brand-mark svg{fill:none;height:25px;stroke:#fff;stroke-linecap:round;stroke-linejoin:round;stroke-width:2;width:25px}.app-nav{display:grid;gap:7px;padding:19px 12px}.app-nav a{align-items:center;border-radius:9px;color:#d9e3f0;display:flex;font-size:15px;gap:17px;min-height:50px;padding:0 20px;transition:background .2s ease,color .2s ease,transform .2s ease}.app-nav a:hover{background:#ffffff12;color:#fff;transform:translate(2px)}.app-nav a.router-link-exact-active{background:linear-gradient(135deg,#1765d5,#1477ec);box-shadow:0 8px 20px #0063e64d;color:#fff}.nav-icon{align-items:center;display:flex;flex:0 0 23px;justify-content:center}.nav-icon svg{fill:none;height:23px;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.9;width:23px}.collapse-button{align-items:center;background:transparent;border-radius:0;border-top:1px solid rgba(255,255,255,.1);color:#e0e9f5;display:flex;font-size:13px;gap:20px;justify-content:flex-start;margin:auto 23px 0;padding:27px 10px;width:calc(100% - 46px)}.app-main{min-width:0}.app-topbar{align-items:center;background:#fffffff5;border-bottom:1px solid #e7ebf2;display:flex;height:92px;justify-content:space-between;padding:0 31px;position:sticky;top:0;z-index:20}.topbar-title,.topbar-actions,.profile-button{align-items:center;display:flex}.topbar-title{gap:22px}.topbar-title h1{font-size:20px;line-height:1.2;margin:0 0 4px}.topbar-title p,.profile-copy small{color:#71809a;font-size:12px;margin:0}.hamburger,.language-button,.notification-button,.profile-button{background:transparent;color:#19304f}.hamburger{font-size:22px;min-height:auto;padding:8px 0}.topbar-actions{gap:18px}.language-button{border:1px solid #e4e9f1;border-radius:8px;gap:9px;min-height:42px;padding:0 14px}.chevron{color:#76869d;margin-left:8px}.notification-button{min-height:42px;padding:8px;position:relative}.notification-button svg{fill:none;height:21px;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8;width:21px}.notification-button span{align-items:center;background:#ff4d4f;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:9px;height:18px;justify-content:center;position:absolute;right:0;top:2px;width:18px}.topbar-divider{background:#e7ebf2;height:40px;width:1px}.profile-button{gap:11px;min-height:52px;padding:0}.profile-avatar,.person-avatar{align-items:center;background:linear-gradient(145deg,#102a49,#346487);border-radius:50%;color:#fff;display:flex;flex:0 0 auto;font-weight:800;justify-content:center}.profile-avatar{border:3px solid #edf1f6;height:43px;width:43px}.profile-copy{display:grid;gap:3px;text-align:left}.profile-copy strong{color:#10213c;font-size:13px}.app-content{padding:27px 31px 36px}.sidebar-collapsed{--sidebar-width: 82px}.sidebar-collapsed .brand{justify-content:center;padding:0}.sidebar-collapsed .brand strong,.sidebar-collapsed .nav-label{display:none}.sidebar-collapsed .app-nav a{justify-content:center;padding:0}.sidebar-collapsed .collapse-button{justify-content:center;margin-inline:12px;width:calc(100% - 24px)}.dashboard-stats,.dashboard-primary,.dashboard-charts{display:grid;gap:20px}.dashboard-stats{grid-template-columns:repeat(4,minmax(0,1fr))}.stat-card,.dashboard-panel{background:#fff;border:1px solid #edf0f5;border-radius:12px;box-shadow:0 7px 22px #1e32500f}.stat-card{align-items:center;display:flex;min-height:142px;padding:24px 20px}.stat-icon{align-items:center;border-radius:11px;display:flex;font-size:31px;font-weight:800;height:63px;justify-content:center;width:63px}.stat-icon.green{background:#dcf8ec;color:#0aaa68}.stat-icon.orange{background:#fff0dc;color:#ff941d}.stat-icon.red{background:#ffe5e6;color:#ff4d4f}.stat-icon.blue{background:#e8ebff;color:#4c57e9}.stat-copy{display:grid;flex:1;gap:5px;margin-left:24px}.stat-copy>span{font-size:13px}.stat-copy strong{font-size:32px;line-height:1}.stat-copy strong.green,.up{color:#0aaa68}.stat-copy strong.orange,.warn{color:#ff8b15}.stat-copy strong.red{color:#ff4d4f}.stat-copy strong.blue{color:#2262d3}.stat-copy small{color:#506079;font-size:10px;margin-top:11px;white-space:nowrap}.stat-copy small b{float:right;font-size:19px;line-height:8px}.dashboard-primary{grid-template-columns:minmax(0,1.45fr) minmax(350px,1fr);margin-top:24px}.dashboard-charts{grid-template-columns:minmax(0,1.1fr) minmax(350px,1fr);margin-top:20px}.dashboard-panel{min-width:0;overflow:hidden}.panel-header{align-items:center;border-bottom:1px solid #e8edf4;display:flex;justify-content:space-between;min-height:61px;padding:0 21px}.panel-header h2,.chart-panel h2,.absence-panel h2{font-size:15px;margin:0}.panel-header a,.panel-footer-link{color:#0865db;font-size:12px}.attendance-table{display:grid}.attendance-row{align-items:center;border-bottom:1px solid #edf0f4;display:grid;font-size:12px;grid-template-columns:1.65fr 1fr .85fr .75fr .85fr;min-height:61px;padding:0 25px}.attendance-head{background:#fafbfc;color:#5d6c84;font-size:11px;min-height:42px}.person-cell{align-items:center;display:flex;gap:12px}.person-cell>span:last-child,.leave-copy{display:grid;gap:2px}.person-cell strong,.leave-copy strong{font-size:12px}.person-cell small,.leave-copy small{color:#6e7e96;font-size:10px}.person-avatar{font-size:10px;height:36px;width:36px}.avatar-blue{background:linear-gradient(145deg,#316c9f,#122a48)}.avatar-pink{background:linear-gradient(145deg,#d5889f,#753c58)}.avatar-amber{background:linear-gradient(145deg,#d99848,#6a4219)}.avatar-violet{background:linear-gradient(145deg,#9779c7,#473568)}.avatar-green{background:linear-gradient(145deg,#4d9b81,#174f41)}.success-text{color:#08a864;font-weight:700}.danger-text{color:#ff4247;font-weight:700}.table-status{border-radius:6px;display:inline-block;font-size:10px;padding:6px 9px}.table-status.ontime{background:#dcf8e9;color:#08a864}.table-status.late{background:#fff0dd;color:#f18712}.panel-footer-link{display:block;padding:12px;text-align:center}.leave-list{display:grid;gap:8px;padding:8px 15px 16px}.leave-card{align-items:center;border:1px solid #e1e7ef;border-radius:8px;display:grid;gap:11px;grid-template-columns:auto minmax(0,1fr) auto;min-height:109px;padding:14px}.leave-copy p{color:#506079;font-size:9px;margin:6px 0 0}.leave-type{border-radius:5px;font-size:9px;justify-self:start;margin-top:5px;padding:4px 7px}.leave-type.annual{background:#fff0d5;color:#ed8a0d}.leave-type.sick{background:#e9edff;color:#4f5fd3}.leave-type.unpaid{background:#e8f1ff;color:#2670d8}.leave-actions{display:flex;gap:10px}.leave-actions button{background:linear-gradient(#28c881,#0eaa68);border-radius:5px;font-size:10px;min-height:36px;padding:0 14px}.leave-actions .reject-button{background:#fff;border:1px solid #ff5c61;color:#ff4247}.chart-panel,.absence-panel{min-height:230px;padding:20px}.chart-legend{color:#52627a;font-size:9px;margin:12px 0 -2px;text-align:center}.green-dot,.blue-dot,.red-dot{border-radius:3px;display:inline-block;height:9px;margin:0 7px 0 11px;width:9px}.green-dot{background:#25ba78}.blue-dot{background:#2d6fd9}.red-dot{background:#ff5a55}.line-chart{height:150px;overflow:visible;width:100%}.chart-grid path{stroke:#dfe6ef;stroke-dasharray:4 4;stroke-width:1}.area{stroke:none}.green-area{fill:url(#greenFill)}.blue-area{fill:url(#blueFill)}.green-line,.blue-line{fill:none;stroke-linecap:round;stroke-width:2.2}.green-line{stroke:#18b56e}.blue-line{stroke:#2169dc}.chart-axis{color:#64738a;display:flex;font-size:9px;justify-content:space-between}.absence-content{align-items:center;display:grid;gap:45px;grid-template-columns:185px 1fr;min-height:180px}.donut-chart{background:conic-gradient(#48c187 0 30%,#3979db 30% 70%,#ff5c57 70% 100%);border-radius:50%;height:145px;margin:auto;position:relative;width:145px}.donut-chart:after{background:#fff;border-radius:50%;content:"";inset:32px;position:absolute}.absence-legend{display:grid;gap:16px}.absence-legend p{align-items:center;color:#263953;display:grid;font-size:10px;grid-template-columns:auto 1fr auto;margin:0}.absence-legend strong{font-size:10px}@media(max-width:1180px){.dashboard-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-primary,.dashboard-charts{grid-template-columns:1fr}}@media(max-width:820px){.app-shell{display:block}.app-sidebar{box-shadow:12px 0 30px #05162d40;left:-260px;position:fixed;transition:left .25s ease;width:240px}.mobile-nav-open .app-sidebar{left:0}.collapse-button{display:none}.app-topbar{height:76px;padding:0 18px}.app-content{padding:18px}.topbar-actions{gap:7px}.language-button span:nth-child(2),.profile-copy,.topbar-divider{display:none}.language-button{min-width:42px;padding:0 9px}.dashboard-stats{grid-template-columns:1fr 1fr}.attendance-table{overflow-x:auto}.attendance-row{min-width:690px}}@media(max-width:560px){.auth-card{padding:22px 18px}.app-topbar{gap:12px}.topbar-title{gap:10px;min-width:0}.topbar-title h1{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-button,.topbar-divider{display:none}.dashboard-stats{grid-template-columns:1fr}.stat-card{min-height:120px}.leave-card{grid-template-columns:auto 1fr}.leave-actions{grid-column:1 / -1;justify-content:flex-end}.absence-content{gap:16px;grid-template-columns:1fr}.topbar-title p{display:none}}.resource-toolbar{align-items:center;display:flex;justify-content:space-between;margin-bottom:22px}.resource-toolbar h2{font-size:22px;margin:0 0 5px}.resource-toolbar p,.muted{color:#71809a;font-size:13px;margin:0}.toolbar-actions,.row-actions{display:flex;gap:9px;justify-content:flex-end}.resource-card{background:#fff;border:1px solid #edf0f5;border-radius:12px;box-shadow:0 7px 22px #1e32500f;overflow:hidden}.resource-table{display:grid}.resource-head,.resource-row{align-items:center;display:grid;gap:18px;padding:14px 20px}.resource-head{background:#f8fafc;color:#64748b;font-size:11px;font-weight:700;min-height:46px;text-transform:uppercase}.resource-row{border-top:1px solid #edf0f5;font-size:13px;min-height:72px}.resource-row>div:first-child{display:grid;gap:4px}.resource-row small{color:#71809a;font-size:11px}.employee-grid .resource-head,.employee-grid .resource-row{grid-template-columns:minmax(190px,1.4fr) minmax(110px,.8fr) minmax(100px,.7fr) 80px 190px}.branch-grid .resource-head,.branch-grid .resource-row{grid-template-columns:minmax(190px,1.3fr) minmax(180px,1fr) 80px 80px 300px}.department-grid .resource-head,.department-grid .resource-row{grid-template-columns:minmax(180px,1fr) 100px 190px}.row-actions button{font-size:11px;min-height:34px;padding:0 12px}.danger-button{background:#fff1f0;border:1px solid #ffb8b5;color:#c9362f}.empty-state{color:#71809a;padding:34px;text-align:center}.resource-dialog{max-height:calc(100vh - 48px);max-width:620px;overflow:auto}.location-picker{display:grid;gap:8px}.location-map{border:1px solid #cdd5df;border-radius:8px;height:320px;overflow:hidden;width:100%}.location-picker-footer{align-items:center;color:#71809a;display:flex;font-size:12px;gap:12px;justify-content:space-between}.location-pin{background:transparent}.location-pin span{background:#176b87;border:3px solid #fff;border-radius:50% 50% 50% 0;box-shadow:0 2px 8px #0f172a59;display:block;height:24px;transform:rotate(-45deg);width:24px}.shift-grid .resource-head,.shift-grid .resource-row{grid-template-columns:minmax(160px,1.2fr) 100px 100px 120px 90px 210px}.assignment-dialog{max-width:520px}.verification-settings{background:#f8fafc;border:1px solid #e5eaf1;border-radius:8px;display:grid;gap:10px;padding:14px}.verification-settings small{color:#71809a}.toggle-setting{align-items:center;display:flex!important;gap:9px!important}.toggle-setting input{height:18px;width:18px}.verification-summary{display:flex;flex-wrap:wrap;gap:8px}.verification-pill{background:#fff0c2;border-radius:999px;color:#8a5b00;font-size:12px;font-weight:700;padding:6px 10px}.verification-pill.optional{background:#eaf4ef;color:#1d6b3e}.qr-dialog{max-width:480px}.qr-dialog-header,.portal-panel-header,.qr-status-card{align-items:center;display:flex;gap:16px;justify-content:space-between}.qr-dialog-header h3,.qr-dialog-header p,.portal-panel-header h2{margin:0}.qr-dialog-header p{color:#71809a;font-size:12px;margin-top:5px}.qr-timer{background:#e8f1ff;border-radius:999px;color:#1765d5;flex:0 0 auto;font-weight:800;padding:8px 12px}.qr-timer.expired{background:#fff1f0;color:#b42318}.qr-canvas-wrap{align-items:center;background:#f8fafc;border:1px solid #e5eaf1;border-radius:12px;display:flex;justify-content:center;min-height:360px;padding:16px}.qr-canvas-wrap img{display:block;max-width:100%}.portal-attendance-grid{display:grid;gap:22px;grid-template-columns:minmax(0,1.1fr) minmax(340px,.9fr)}.portal-panel{background:#fff;border:1px solid #edf0f5;border-radius:12px;box-shadow:0 7px 22px #1e32500f;padding:20px}.attendance-summary{display:grid;gap:16px}.attendance-summary .attendance-state{align-items:center;display:flex;margin:0;max-width:none}.attendance-state-icon{align-items:center;background:#ffffffb3;border-radius:50%;display:flex;flex:0 0 42px;font-size:22px;height:42px;justify-content:center}.attendance-state>div,.qr-status-card>div{display:grid;gap:4px}.qr-status-card{background:#f8fafc;border:1px dashed #b9c4d2;border-radius:10px;padding:14px}.qr-status-card.ready{background:#eef8f3;border-color:#81c6a3}.qr-status-card span,.portal-help{color:#71809a;font-size:12px}.qr-scanner{display:grid;gap:12px}.scanner-frame{background:#101827;border-radius:12px;min-height:320px;overflow:hidden;position:relative}.scanner-frame video{height:100%;inset:0;-o-object-fit:cover;object-fit:cover;position:absolute;width:100%}.scanner-placeholder{align-items:center;color:#dbe5f2;display:flex;flex-direction:column;gap:8px;inset:0;justify-content:center;padding:24px;position:absolute;text-align:center}.scanner-placeholder span{color:#96a7bd;font-size:12px}.scanner-guide{border:2px solid rgba(255,255,255,.8);border-radius:14px;height:min(65%,240px);left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:min(65%,240px)}.scanner-guide span{animation:scanner-line 1.8s ease-in-out infinite;background:#32d296;box-shadow:0 0 12px #32d296;height:2px;left:8px;position:absolute;right:8px;top:12px}@keyframes scanner-line{50%{top:calc(100% - 14px)}}.scanner-actions,.portal-actions{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.scanner-actions>button:only-child{grid-column:1 / -1}.manual-qr{background:#f8fafc;border:1px solid #e6ebf2;border-radius:8px;padding:12px}.manual-qr summary{cursor:pointer;font-size:12px;font-weight:700}.manual-qr label{display:grid;font-size:12px;gap:6px;margin:12px 0}.checkout-button{background:#e25151}.portal-panel-header{border-bottom:1px solid #edf0f5;margin:-4px -4px 10px;padding:0 4px 14px}.portal-history{display:grid}.portal-history-row{align-items:center;border-bottom:1px solid #edf0f5;display:grid;gap:8px;grid-template-columns:minmax(0,1fr) auto;padding:14px 2px}.portal-history-row>div{display:grid;gap:4px}.portal-history-row span,.portal-history-row small{color:#71809a;font-size:11px}.portal-history-row>small{grid-column:1 / -1}.filter-bar{align-items:end;background:#fff;border:1px solid #edf0f5;border-radius:10px;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(140px,1fr)) auto;margin-bottom:18px;padding:16px}.filter-bar label{display:grid;font-size:12px;font-weight:700;gap:5px}.form-grid{display:grid;gap:12px}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}@media(max-width:980px){.resource-card{overflow-x:auto}.resource-table{min-width:850px}.portal-attendance-grid{grid-template-columns:1fr}}@media(max-width:620px){.resource-toolbar{align-items:flex-start;flex-direction:column;gap:14px}.form-grid.two,.form-grid.three,.filter-bar{grid-template-columns:1fr}.scanner-frame{min-height:280px}.portal-actions{grid-template-columns:1fr}}
