.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{--primary-50: #e6f4ff;--primary-100: #bae3ff;--primary-200: #7cc8ff;--primary-300: #36a9ff;--primary-400: #0090ff;--primary-500: #0072e5;--primary-600: #005bb5;--primary-700: #004488;--primary-800: #002d5c;--primary-900: #001730;--secondary-50: #e0f7f6;--secondary-100: #b3ebe8;--secondary-200: #80dfda;--secondary-300: #4dd2cc;--secondary-400: #26c9c1;--secondary-500: #00bfb6;--secondary-600: #00a69f;--secondary-700: #008c87;--secondary-800: #00736f;--secondary-900: #004a48;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--gray-950: #020617;--success-50: #ecfdf5;--success-500: #10b981;--success-600: #059669;--warning-50: #fffbeb;--warning-500: #f59e0b;--warning-600: #d97706;--error-50: #fef2f2;--error-500: #ef4444;--error-600: #dc2626;--info-50: #eff6ff;--info-500: #3b82f6;--info-600: #2563eb;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--border-light: #e2e8f0;--border-medium: #cbd5e1;--border-dark: #94a3b8;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-glow: 0 0 20px rgba(0, 114, 229, .3);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400;--z-tooltip: 500}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-overlay: rgba(0, 0, 0, .7);--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-tertiary: #64748b;--border-light: #334155;--border-medium: #475569;--border-dark: #64748b;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.app-layout{display:flex;min-height:100vh}.sidebar{width:280px;background:linear-gradient(180deg,var(--primary-700) 0%,var(--primary-900) 100%);color:var(--text-inverse);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:var(--z-sticky);transition:transform var(--transition-slow)}.sidebar-header{padding:var(--space-6);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3)}.sidebar-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--secondary-400) 0%,var(--secondary-600) 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.sidebar-logo-text{font-size:1.25rem;font-weight:700;letter-spacing:-.025em}.sidebar-logo-subtitle{font-size:.75rem;opacity:.7;margin-top:2px}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:var(--radius-full)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.nav-section{margin-bottom:var(--space-6)}.nav-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#ffffff80;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:#fffc;font-weight:500;transition:all var(--transition-fast);margin-bottom:var(--space-1)}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff26;color:#fff;box-shadow:inset 3px 0 0 var(--secondary-400)}.nav-item-icon{width:20px;height:20px;opacity:.8}.nav-item.active .nav-item-icon{opacity:1}.nav-item-badge{margin-left:auto;background:var(--error-500);color:#fff;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full)}.main-content{flex:1;margin-left:280px;display:flex;flex-direction:column}.topbar{height:70px;background:var(--bg-primary);border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);position:sticky;top:0;z-index:var(--z-sticky)}.topbar-left{display:flex;align-items:center;gap:var(--space-4)}.topbar-title{font-size:1.25rem;font-weight:600}.topbar-right{display:flex;align-items:center;gap:var(--space-4)}.topbar-clock{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:.875rem}.topbar-clock-time{font-size:1.5rem;font-weight:700;font-family:var(--font-mono);color:var(--text-primary)}.user-menu{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.user-menu:hover{background:var(--bg-tertiary)}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-600) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem}.user-info{display:flex;flex-direction:column}.user-name{font-size:.875rem;font-weight:600}.user-role{font-size:.75rem;color:var(--text-tertiary)}.page-content{flex:1;padding:var(--space-8)}.card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:1.125rem;font-weight:600}.card-subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:var(--space-1)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);background:var(--bg-secondary);border-top:1px solid var(--border-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:.9375rem;font-weight:600;border-radius:var(--radius-lg);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:var(--shadow-sm),0 2px 8px #0072e54d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-500) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),0 4px 12px #0072e566}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-medium)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-dark)}.btn-success{background:linear-gradient(135deg,var(--success-500) 0%,var(--success-600) 100%);color:#fff;box-shadow:var(--shadow-sm),0 2px 8px #10b9814d}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md),0 4px 12px #10b98166}.btn-danger{background:linear-gradient(135deg,var(--error-500) 0%,var(--error-600) 100%);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon{padding:var(--space-3)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:1.0625rem;border-radius:var(--radius-xl)}.btn-xl{padding:var(--space-6) var(--space-12);font-size:1.25rem;border-radius:var(--radius-2xl)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:1rem;background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-input:disabled{background:var(--bg-tertiary);cursor:not-allowed}.form-input::placeholder{color:var(--text-tertiary)}.form-input-icon{position:relative}.form-input-icon .form-input{padding-left:var(--space-12)}.form-input-icon .icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.form-error{font-size:.8125rem;color:var(--error-500);margin-top:var(--space-1)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-6)}.stat-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-6);border:1px solid var(--border-light);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.primary{background:linear-gradient(135deg,var(--primary-100) 0%,var(--primary-200) 100%);color:var(--primary-600)}.stat-icon.success{background:linear-gradient(135deg,var(--success-50) 0%,rgba(16,185,129,.2) 100%);color:var(--success-600)}.stat-icon.warning{background:linear-gradient(135deg,var(--warning-50) 0%,rgba(245,158,11,.2) 100%);color:var(--warning-600)}.stat-icon.error{background:linear-gradient(135deg,var(--error-50) 0%,rgba(239,68,68,.2) 100%);color:var(--error-600)}.stat-icon.secondary{background:linear-gradient(135deg,var(--secondary-100) 0%,var(--secondary-200) 100%);color:var(--secondary-700)}.stat-content{flex:1}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-top:var(--space-1)}.stat-change{font-size:.75rem;font-weight:600;margin-top:var(--space-2);display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;border-radius:var(--radius-full)}.stat-change.positive{background:var(--success-50);color:var(--success-600)}.stat-change.negative{background:var(--error-50);color:var(--error-600)}.attendance-widget{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-700) 100%);border-radius:var(--radius-2xl);padding:var(--space-8);color:#fff;text-align:center;position:relative;overflow:hidden}.attendance-widget:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.attendance-status{display:inline-flex;align-items:center;gap:var(--space-2);background:#fff3;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;margin-bottom:var(--space-6)}.attendance-status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.attendance-status-dot.connected{background:var(--success-500)}.attendance-status-dot.disconnected{background:var(--error-500)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.attendance-time{font-size:4rem;font-weight:700;font-family:var(--font-mono);line-height:1;margin-bottom:var(--space-2);text-shadow:0 2px 20px rgba(0,0,0,.2)}.attendance-date{font-size:1.125rem;opacity:.9;margin-bottom:var(--space-8)}.check-in-button{width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,var(--success-500) 0%,var(--success-600) 100%);color:#fff;font-size:1.25rem;font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);margin:0 auto var(--space-6);cursor:pointer;transition:all var(--transition-base);box-shadow:0 10px 40px #10b98166,0 0 0 8px #ffffff1a;position:relative;z-index:1}.check-in-button:hover{transform:scale(1.05);box-shadow:0 15px 50px #10b98180,0 0 0 12px #ffffff26}.check-in-button:active{transform:scale(.98)}.check-in-button.checkout{background:linear-gradient(135deg,var(--error-500) 0%,var(--error-600) 100%);box-shadow:0 10px 40px #ef444466,0 0 0 8px #ffffff1a}.check-in-button.disabled{background:var(--gray-500);cursor:not-allowed;box-shadow:none}.check-in-button .icon{width:48px;height:48px}.location-indicator{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.9375rem;padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);margin-top:var(--space-4)}.location-indicator.valid{background:#10b98133;color:#86efac}.location-indicator.invalid{background:#ef444433;color:#fca5a5}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.9375rem}.table th,.table td{padding:var(--space-4);text-align:left;border-bottom:1px solid var(--border-light)}.table th{font-weight:600;color:var(--text-secondary);font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-secondary)}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--bg-tertiary)}.table td{color:var(--text-primary)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:.75rem;font-weight:600;border-radius:var(--radius-full)}.badge-success{background:var(--success-50);color:var(--success-600)}.badge-warning{background:var(--warning-50);color:var(--warning-600)}.badge-error{background:var(--error-50);color:var(--error-600)}.badge-info{background:var(--info-50);color:var(--info-600)}.badge-neutral{background:var(--gray-100);color:var(--gray-600)}.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6)}.module-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-6);border:1px solid var(--border-light);cursor:pointer;transition:all var(--transition-fast);display:flex;flex-direction:column;gap:var(--space-4)}.module-card:hover{border-color:var(--primary-300);box-shadow:var(--shadow-lg),0 0 0 1px var(--primary-200);transform:translateY(-4px)}.module-card-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.module-card-title{font-size:1.125rem;font-weight:600}.module-card-description{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.module-card-stats{display:flex;gap:var(--space-4);margin-top:auto;padding-top:var(--space-4);border-top:1px solid var(--border-light)}.module-stat{text-align:center;flex:1}.module-stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.module-stat-label{font-size:.75rem;color:var(--text-tertiary);margin-top:2px}.login-page{min-height:100svh;padding:1.15rem;display:grid;place-items:center;font-family:"Sora",var(--font-sans);background:radial-gradient(circle at 12% 20%,rgba(45,186,213,.26) 0,transparent 32%),radial-gradient(circle at 82% 16%,rgba(32,118,201,.28) 0,transparent 34%),linear-gradient(135deg,#0a5b72,#0b4767,#0a3556 68%,#082641);position:relative;overflow-x:hidden;overflow-y:auto;isolation:isolate;overscroll-behavior:contain}.login-page:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='640' height='640' viewBox='0 0 640 640' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg opacity='0.18' stroke='%23CBE8F3' stroke-width='1'%3E%3Cpath d='M54 541L208 387L290 469L453 306'/%3E%3Cpath d='M112 592L266 438L348 520L511 357'/%3E%3Cpath d='M120 280L240 160L332 252L454 130'/%3E%3Cpath d='M78 322L198 202L290 294L412 172'/%3E%3C/g%3E%3C/svg%3E"),radial-gradient(circle at 24% 76%,rgba(255,255,255,.08),transparent 30%);background-repeat:no-repeat;background-position:left center,left bottom;background-size:42% auto,50% auto;z-index:-1}.login-page:after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='760' height='760' viewBox='0 0 760 760' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg opacity='0.18' stroke='%23D8EEF6' stroke-width='1.2'%3E%3Cpath d='M630 62C690 96 726 144 726 205C726 265 686 311 622 341C558 370 520 417 520 482C520 545 556 592 622 623'/%3E%3Cpath d='M598 39C664 77 704 136 704 205C704 274 662 327 594 359C526 391 486 434 486 491C486 549 526 598 592 634'/%3E%3Cpath d='M566 17C638 58 680 128 680 206C680 283 638 342 566 376C494 410 454 451 454 500C454 553 492 602 560 642'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right top;background-size:42% auto;opacity:.32;z-index:-1;pointer-events:none}.login-shell{width:100%;max-width:1260px;height:min(700px,calc(100svh - 2.3rem));display:grid;grid-template-columns:minmax(0,1.46fr) minmax(390px,.86fr);border-radius:34px;overflow:hidden;box-shadow:0 30px 90px #0517245c}.login-brand-panel{padding:clamp(2rem,3vw,3rem) clamp(2.1rem,3.2vw,3.2rem);color:#fffffffa;display:flex;flex-direction:column;justify-content:flex-start;gap:1.5rem;background:linear-gradient(135deg,#081f2af0,#0a384ee6),radial-gradient(circle at 18% 18%,rgba(63,204,223,.12) 0,transparent 34%);position:relative;overflow:hidden}.login-brand-panel:before{content:"";position:absolute;inset:0;background-image:linear-gradient(115deg,rgba(255,255,255,.07) 0%,transparent 26%,transparent 74%,rgba(255,255,255,.04) 100%);pointer-events:none}.login-brand-panel:after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 22% 78%,rgba(218,191,124,.12),transparent 22%);pointer-events:none}.login-brand-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);position:relative;z-index:1}.login-brand-image{width:clamp(210px,24vw,290px);height:auto;filter:brightness(1.06) contrast(1.06) drop-shadow(0 4px 18px rgba(0,0,0,.2))}.login-brand-tag{padding:.52rem 1.05rem;border-radius:var(--radius-full);border:1px solid rgba(197,223,232,.42);background:#abc9d329;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.login-brand-title{font-size:clamp(2.05rem,2.7vw,3rem);line-height:1.06;font-weight:700;color:#fff;max-width:9.5ch;position:relative;z-index:1;letter-spacing:-.04em;margin:0}.login-brand-title-accent{color:#d3c18f}.login-brand-subtitle{font-size:.94rem;line-height:1.52;color:#ebf5f8e6;max-width:34ch;position:relative;z-index:1;font-weight:400;margin:0}.login-brand-main{display:grid;grid-template-columns:minmax(0,1fr) 280px;grid-template-areas:"copy visual" "points points";align-items:center;gap:1.5rem;min-height:0;flex:1;position:relative;z-index:1}.login-brand-copy{grid-area:copy;display:flex;flex-direction:column;gap:1.2rem;min-width:0}.login-brand-points{grid-area:points;display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:.9rem;position:relative;z-index:1;width:100%;max-width:none;margin:0;align-self:stretch;justify-self:stretch}.login-brand-point{display:flex;gap:var(--space-3);align-items:flex-start;padding:1.05rem 1.2rem;border-radius:20px;border:1px solid rgba(184,206,214,.32);background:linear-gradient(135deg,#93a7b057,#6f828c33);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 1px #ffffff1f}.login-brand-point svg{color:#dccca0;margin-top:2px;flex-shrink:0}.login-brand-point h2{font-size:.97rem;font-weight:600;color:#fff;margin-bottom:.25rem;letter-spacing:-.02em}.login-brand-point p{font-size:.83rem;line-height:1.48;color:#e4edf1f0;font-weight:400;margin:0}.login-brand-visual{grid-area:visual;position:relative;display:flex;align-items:center;justify-content:center;align-self:center;transform:translateY(-18px)}.login-clock-svg{width:min(100%,280px);height:auto;overflow:visible}.login-mobile-clock{display:none}.login-clock-orbit{fill:none;stroke:#7dd9ef24;stroke-width:1.5;stroke-dasharray:6 10}.login-clock-face{fill:#ffffff0d;stroke:#e2f1f61f;stroke-width:1.2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.login-clock-ring{fill:none;stroke:url(#clockRing);stroke-width:6;stroke-linecap:round;stroke-dasharray:420;stroke-dashoffset:80;filter:drop-shadow(0 0 12px rgba(123,217,239,.16))}.login-clock-center{fill:#f3e3af}.login-clock-index{stroke:#e3eff4b8;stroke-width:3.2;stroke-linecap:round}.login-clock-hand{stroke:#fff;stroke-linecap:round}.login-clock-hand-hour{stroke-width:6}.login-clock-hand-minute{stroke-width:4.5}.login-clock-hand-second{stroke:#d7c48f;stroke-width:2.5}.login-clock-node{fill:#f3e3af;filter:drop-shadow(0 0 10px rgba(243,227,175,.2))}.login-clock-node-soft{fill:#7bd9ef}.login-clock-mark{fill:none;stroke:#e3eff46b;stroke-width:3;stroke-linecap:round}.login-form-panel{background:linear-gradient(180deg,#fffffffc,#f8fbfcfc);padding:clamp(1.9rem,2.7vw,2.5rem) clamp(2rem,3vw,2.55rem) clamp(1.5rem,2.4vw,2rem) clamp(4rem,5.8vw,5.2rem);display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:1rem;position:relative;clip-path:polygon(11.5% 0,100% 0,100% 100%,0 100%,0 13.5%)}.login-form-panel:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 18%,rgba(8,111,148,.05),transparent 24%),linear-gradient(180deg,rgba(235,244,248,.45),transparent 28%);pointer-events:none}.login-header{width:100%;max-width:400px;text-align:center;display:flex;flex-direction:column;align-items:center;margin-bottom:0;position:relative;z-index:1}.login-form-logo-wrap{width:100%;max-width:320px;padding:0;display:flex;align-items:center;justify-content:center;margin-bottom:.7rem}.login-form-logo{width:100%;max-width:314px;object-fit:contain;filter:contrast(1.05) saturate(1.02)}.login-access-pill{display:inline-flex;align-items:center;justify-content:center;height:34px;padding:0 1.05rem;margin-bottom:.85rem;border-radius:var(--radius-full);border:1px solid rgba(58,120,146,.26);background:#1467880f;font-size:.72rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:#2f6275}.login-title{font-size:clamp(1.95rem,2.4vw,2.55rem);font-weight:700;margin-bottom:.55rem;color:#35566b;letter-spacing:-.04em}.login-subtitle{color:#4f6471;font-size:.95rem;line-height:1.45;max-width:24ch;font-weight:400;margin:0;text-align:center}.login-form{display:flex;flex-direction:column;gap:.95rem;position:relative;z-index:1;width:100%;max-width:400px}.login-error-alert{background:#fff6f6;color:var(--error-600);border:1px solid rgba(220,38,38,.16);border-left:4px solid var(--error-500);padding:.85rem 1rem;border-radius:14px;font-size:.875rem}.login-form .form-group{margin-bottom:0}.login-form .form-label{font-size:.88rem;font-weight:600;color:#243746;margin-bottom:.62rem}.login-form .form-input{min-height:54px;border:2px solid #a4c8d4;background:#fff;border-radius:16px;font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 0 0 1px #135e7a0a,0 8px 18px #0b5c8614}.login-form .form-input:hover{border-color:#7db1c2}.login-form .form-input:focus{border-color:#1f6b86;box-shadow:0 0 0 4px #22819f1f,0 10px 24px #0b5c8624}.login-password-input{padding-right:3.35rem}.login-password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#68808e;transition:color var(--transition-fast);padding:.25rem}.login-password-toggle:hover{color:#1f6b86}.login-submit-btn{width:100%;min-height:54px;margin-top:.4rem;letter-spacing:.01em;font-size:1rem;font-weight:600;border-radius:16px;background:linear-gradient(135deg,#176e8b,#1f5e78);box-shadow:0 12px 24px #176e8b3d,inset 0 1px #ffffff2e}.login-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 28px #176e8b47,inset 0 1px #ffffff38}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-footer{margin-top:.25rem;padding-top:0;font-size:.73rem;color:#687b88;text-align:center;font-weight:400;width:100%;max-width:400px}@media(max-width:1180px){.login-page{padding:1rem}.login-shell{max-width:1120px;height:min(660px,calc(100svh - 2rem));grid-template-columns:minmax(0,1.35fr) minmax(375px,.88fr)}.login-brand-panel{padding:2rem}.login-brand-main{grid-template-columns:minmax(0,1fr) 236px;gap:1.2rem}.login-brand-title{font-size:clamp(1.9rem,2.6vw,2.6rem);max-width:9.2ch}.login-brand-points{max-width:100%}.login-form-panel{padding:1.7rem 1.7rem 1.4rem 3.3rem}}.quick-actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.quick-action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);font-size:.875rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.quick-action-btn:hover{background:var(--bg-tertiary);border-color:var(--primary-300);color:var(--primary-600)}@media(max-width:1024px){.sidebar{transform:translate(-100%);box-shadow:4px 0 24px #00000026}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.mobile-menu-btn{display:flex!important}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;pointer-events:none;transition:opacity .3s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.visible{opacity:1;pointer-events:auto}}@media(max-width:940px){.login-page{padding:1.1rem}.login-shell{grid-template-columns:1fr;max-width:640px;height:auto;border-radius:28px}.login-brand-panel{padding:2rem 1.75rem;gap:1.25rem;justify-content:flex-start}.login-brand-main{grid-template-columns:1fr;grid-template-areas:"copy" "visual" "points"}.login-brand-points{grid-template-columns:1fr;width:100%}.login-form-panel{padding:2rem 1.75rem 1.75rem;gap:1.45rem;clip-path:none}.login-header{margin-bottom:0}.login-form,.login-header,.login-footer{max-width:100%}.login-brand-title{max-width:11ch;font-size:2.5rem}.login-brand-points{max-width:none}}@media(max-width:768px){.page-content{padding:var(--space-4)}.stats-grid{grid-template-columns:1fr}.attendance-time{font-size:3rem}.check-in-button{width:150px;height:150px;font-size:1rem}.check-in-button .icon{width:36px;height:36px}.login-page{min-height:100svh;padding:.7rem;background:radial-gradient(circle at 24% 10%,rgba(45,186,213,.22),transparent 32%),linear-gradient(180deg,#0f5d73,#0c4861 44%,#0b3652);align-items:center;justify-items:center}.login-page:before{background-size:74% auto,0 0;background-position:left bottom,left bottom;opacity:.28}.login-page:after{opacity:.18;background-size:78% auto}.login-shell{max-width:min(420px,calc(100vw - 1.5rem));width:min(420px,calc(100vw - 1.5rem));border-radius:24px;box-shadow:0 18px 38px #04162138;margin:auto;height:auto;background:#e5f0f41f}.login-brand-panel{display:none}.login-form-panel{padding:1.4rem 1.05rem 1rem;gap:.85rem;border-radius:24px;align-items:center;justify-content:center;clip-path:none;background:linear-gradient(180deg,#fcfefff7,#f3f8faf7)}.login-header{width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.35rem}.login-mobile-clock{display:flex;justify-content:center;align-items:center;width:100%;max-width:150px;margin:0 auto .25rem;opacity:.92}.login-mobile-clock .login-clock-svg{width:min(100%,136px)}.login-mobile-clock .login-clock-orbit{stroke:#22566c7a;stroke-width:2.6}.login-mobile-clock .login-clock-face{fill:#165d7629;stroke:#194f6361;stroke-width:2.1}.login-mobile-clock .login-clock-ring{filter:none;stroke-width:8.5;stroke-dashoffset:64}.login-mobile-clock .login-clock-index{stroke:#1e4b60d6;stroke-width:3.4}.login-mobile-clock .login-clock-hand{stroke:#1e4b60}.login-mobile-clock .login-clock-hand-hour{stroke-width:6.5}.login-mobile-clock .login-clock-hand-minute{stroke-width:5}.login-mobile-clock .login-clock-hand-second{stroke:#b38835;stroke-width:2.6}.login-mobile-clock .login-clock-center{fill:#a88237}.login-mobile-clock .login-clock-node{fill:#a88237;filter:none}.login-mobile-clock .login-clock-node-soft{fill:#0d7fa3}.login-mobile-clock .login-clock-mark{stroke:#1e4b60d1;stroke-width:4}.login-form-logo-wrap{max-width:230px;margin:0 auto .35rem;justify-content:center}.login-form-logo{max-width:228px}.login-access-pill{margin-bottom:.2rem;font-size:.66rem;height:30px}.login-title{font-size:2.05rem;margin-bottom:0}.login-subtitle{font-size:.92rem;max-width:26ch}.login-form{width:100%;max-width:100%;margin:0 auto;gap:.9rem}.login-form .form-label{font-size:.84rem;margin-bottom:.4rem;text-align:left;color:#243746}.login-form .form-input{min-height:52px;font-size:.94rem;text-align:left;border-radius:14px}.login-form .form-input-icon .icon{display:block}.login-form .form-input-icon .form-input,.login-password-input{padding-left:var(--space-12);padding-right:var(--space-12)}.login-password-toggle{right:.95rem}.login-submit-btn{min-height:54px;max-width:100%;font-size:1rem;margin-top:.45rem;border-radius:14px}.login-footer{margin-top:.4rem;font-size:.69rem;max-width:280px;line-height:1.4}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}@media(max-width:430px){.login-page{padding:.55rem}.login-shell{max-width:calc(100vw - 1.1rem);width:calc(100vw - 1.1rem);border-radius:20px}.login-form-panel{padding:1.35rem .85rem .95rem;border-radius:20px}.login-form-logo-wrap{max-width:220px}.login-title{font-size:1.82rem}.login-submit-btn{min-height:48px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease-out}.animate-slide-up{animation:slideUp var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-slow) ease-out}.animate-spin{animation:spin 1s linear infinite}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-primary{color:var(--text-primary)!important}.text-secondary{color:var(--text-secondary)!important}.text-success{color:var(--success-500)!important}.text-error{color:var(--error-500)!important}.bg-success{background:var(--success-500)!important}.bg-error{background:var(--error-500)!important}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.locations-map{position:relative;border:1px solid var(--border-light)}.locations-map .leaflet-container{font-family:var(--font-sans);z-index:1}.locations-map .leaflet-popup-content-wrapper{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.locations-map .leaflet-popup-content{margin:12px 16px}.locations-map .leaflet-popup-tip{background:#fff}.custom-marker,.user-location-marker{background:transparent!important;border:none!important}.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow-md)!important}.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-primary)!important;border:none!important;width:32px!important;height:32px!important;line-height:32px!important;font-size:16px!important}.leaflet-control-zoom a:hover{background:var(--bg-tertiary)!important}.leaflet-control-zoom-in{border-radius:var(--radius-md) var(--radius-md) 0 0!important}.leaflet-control-zoom-out{border-radius:0 0 var(--radius-md) var(--radius-md)!important}.profile-header{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;flex-wrap:wrap}.profile-name-inputs{display:flex;gap:.5rem;flex-wrap:wrap}.profile-name-inputs input{flex:1;min-width:140px}@media(max-width:768px){.sidebar{position:fixed;left:-280px;top:0;bottom:0;z-index:1000;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px #0000001a}.sidebar.open{left:0}.main-content{margin-left:0!important;width:100%!important;min-width:0!important}.topbar{padding:0 .75rem;width:100%;gap:.5rem;height:56px}.topbar-title{font-size:1rem}.topbar-clock{display:none!important}.user-info{display:none}.user-menu{padding:.25rem}.page-content{padding:.75rem;overflow-x:hidden}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;pointer-events:none;transition:opacity .3s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.mobile-menu-btn{display:flex!important}.stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:.75rem!important}.stat-card{padding:.875rem!important}.stat-icon{width:36px!important;height:36px!important}.stat-icon svg{width:18px!important;height:18px!important}.stat-value{font-size:1.25rem!important}.stat-label{font-size:.75rem!important}.stat-change{font-size:.625rem!important}.card{border-radius:var(--radius-lg)}.card-header{padding:.875rem!important;flex-direction:column;align-items:flex-start!important;gap:.75rem}.card-header .btn{width:100%;justify-content:center}.card-body{padding:.875rem!important}.card-footer{padding:.75rem!important;flex-direction:column;gap:.75rem}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -.875rem;padding:0 .875rem}.table{min-width:700px;font-size:.8125rem}.table th,.table td{padding:.625rem .5rem!important;white-space:nowrap}.form-group{margin-bottom:.875rem}.form-input,.form-select,select.form-input{min-width:0!important;width:100%!important;font-size:16px!important}.form-input-icon{flex:1 1 100%!important;min-width:0!important}.btn{padding:.625rem 1rem;font-size:.875rem}.btn-icon{padding:.5rem}.flex.justify-between,[style*="justify-content: space-between"]{flex-wrap:wrap!important;gap:.75rem!important}[style*=grid-template-columns],.grid-2-cols,.grid-3-cols{display:flex!important;flex-direction:column!important;gap:1rem!important}.module-grid{grid-template-columns:repeat(2,1fr)!important;gap:.75rem!important}.module-card{padding:1rem!important}.module-card-icon{width:40px!important;height:40px!important}.attendance-widget{padding:1.25rem!important;border-radius:var(--radius-xl)!important}.attendance-time{font-size:2.5rem!important}.check-in-button{width:140px!important;height:140px!important}.leaflet-container{min-height:250px!important;max-height:300px!important}.map-container-wrapper{height:280px!important}.badge{font-size:.625rem!important;padding:.25rem .5rem!important}.user-avatar{width:32px!important;height:32px!important;font-size:.75rem!important}.location-indicator{font-size:.8125rem;padding:.75rem!important}[style*="position: absolute"][style*="right: 2rem"]{right:.75rem!important;left:.75rem!important;width:auto!important}.animate-fade-in,.animate-slide-up,.animate-scale-in{animation-duration:.2s!important}.hide-mobile,.desktop-only{display:none!important}.mobile-only{display:block!important}}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;margin-right:.5rem}@media(max-width:480px){.stats-grid,.module-grid{grid-template-columns:1fr!important}.btn{width:100%;justify-content:center}.card-header{padding:.75rem!important}.page-content{padding:.5rem}.attendance-time{font-size:2rem!important}.check-in-button{width:120px!important;height:120px!important}}@media(min-width:1024px){.sidebar.collapsed{width:80px}.main-content.collapsed{margin-left:80px;transition:margin-left var(--transition-slow)}.sidebar.collapsed .sidebar-logo-text,.sidebar.collapsed .sidebar-logo-subtitle,.sidebar.collapsed .nav-section-title,.sidebar.collapsed .nav-item span,.sidebar.collapsed .nav-item-badge{display:none}.sidebar.collapsed .sidebar-header{padding:1.5rem .5rem;display:flex;justify-content:center;align-items:center}.sidebar.collapsed .sidebar-logo{justify-content:center}.sidebar.collapsed .nav-item{justify-content:center;padding-left:0;padding-right:0}.sidebar.collapsed .nav-item-icon{margin:0;width:24px;height:24px}}
