.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.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-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=)}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color:#374151;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;color:#333;background-color:#f3f5f8;overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column}.menu-bar-container{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:1100}.menu-bar-left{display:flex;align-items:center;gap:2rem}.waterplan-logo{display:flex;align-items:center;font-weight:500;font-size:1.125rem;color:#374151;text-decoration:none}.logo-svg{height:28px;width:auto;max-width:140px}.main-navigation{display:flex;gap:2rem}.nav-link{color:#6b7280;text-decoration:none;font-weight:500;font-size:.9rem;padding:.5rem 0;border-bottom:2px solid transparent;transition:all .2s ease}.nav-link:hover{color:#374151}.nav-link.active{padding:.5rem .75rem;border-radius:.5rem;background-color:#e9eef7}.nav-link p{margin:0}.menu-bar-right{display:flex;align-items:center;gap:1rem}.header-actions{display:flex;gap:.5rem}.action-button{text-decoration:none}.icon-button{background:transparent;border:none;padding:.5rem;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.icon-button:hover{background:#f3f4f6;color:#374151}.button-icon{display:flex;align-items:center;justify-content:center}.icon{width:24px;height:24px}.language-selector{font-size:.875rem}.language-button{background:transparent;border:none;color:#6b7280;cursor:pointer;font-size:.875rem;padding:.5rem;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;gap:.25rem}.language-button:hover{background:#f3f4f6;color:#374151}.chevron{width:16px;height:16px}.company-avatar{width:32px;height:32px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:all .2s ease}.company-avatar:hover{background:#e5e7eb;transform:scale(1.05)}.avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.company-avatar-container{position:relative}.user-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #0000001a;min-width:240px;z-index:1200;animation:dropdownFadeIn .2s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid #f3f4f6}.dropdown-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.user-info{display:flex;flex-direction:column;gap:.25rem}.user-name{font-weight:600;color:#111827;font-size:.875rem}.user-role{color:#6b7280;font-size:.75rem}.dropdown-divider{height:1px;background:#f3f4f6;margin:.5rem 0}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;color:#374151;font-size:.875rem;transition:background-color .2s ease;text-align:left}.dropdown-item:hover{background:#f9fafb;color:#111827}.dropdown-icon{width:16px;height:16px;opacity:.7}@media (max-width: 1024px){.main-navigation{display:none}.menu-bar-right{gap:.5rem}}@media (max-width: 768px){.menu-bar-container{padding:.5rem 1rem;flex-wrap:wrap;gap:1rem}.menu-bar-left{gap:1rem}.user-dropdown{min-width:200px;right:-.5rem}}@media (max-width: 480px){.menu-bar-container{padding:.5rem;gap:.5rem}.menu-bar-left{gap:.5rem;flex:1;min-width:0}.waterplan-logo{font-size:1.125rem}.logo-svg{height:28px;width:auto;max-width:140px}.menu-bar-right{gap:.25rem;flex-shrink:0}.icon{width:24px;height:24px}.company-avatar{min-width:32px;height:32px}.chevron{width:16px;height:16px}.icon-button{padding:.375rem}.language-button{font-size:.75rem;padding:.375rem}.user-dropdown{min-width:180px;right:-.5rem}}.main-body{flex:1;background:#f3f5f8;display:flex;align-items:flex-start;justify-content:flex-start;padding:0;min-height:calc(100vh - 73px);width:100%}.dev-info{position:fixed;bottom:1rem;right:1rem;background:#000c;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.75rem;font-family:Inter,Monaco,Menlo,Ubuntu Mono,monospace}.sites-page{min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;width:100%}.sites-page-header{background:#fff;border-bottom:1px solid #e9ecef;padding:2rem}.sites-header-content{margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.sites-header-info{flex:1}.sites-header-info>div{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.sites-header-icon{width:48px;height:48px;background:#e7f3ff;border-radius:12px;display:flex;align-items:center;justify-content:center}.sites-site-icon{width:24px;height:24px}.sites-page-title{font-size:2rem;font-weight:700;color:#212529;margin:0}.sites-page-subtitle{font-size:1rem;color:#6c757d;margin:0;line-height:1.5}.sites-header-actions{display:flex;gap:1rem;align-items:center}.view-toggle-buttons{display:flex;background:#f8f9fa;border-radius:8px;padding:4px;border:1px solid #dee2e6}.view-toggle-btn{padding:8px 16px;background:transparent;border:none;border-radius:6px;color:#6c757d;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.view-toggle-btn:hover{background:#e9ecef;color:#495057}.view-toggle-btn.active{background:#fff;color:#0d6efd;box-shadow:0 1px 3px #0000001a;font-weight:600}.sites-learn-more-btn{padding:.75rem 1.5rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.sites-learn-more-btn:hover{background:#e9ecef;border-color:#adb5bd}.scope-new-location-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #10b98133}.scope-new-location-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.sites-section{margin:0 auto;padding:2rem 2rem 0;position:relative;min-height:calc(100vh - 200px)}.table-view-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;margin-top:1rem}.map-background{position:absolute;inset:0;z-index:1}.sites-grid-overlay{position:relative;z-index:2;background:#fffffff2;border-radius:12px;padding:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000001a;border:1px solid rgba(255,255,255,.2);margin:80px 0 0;background:transparent;max-width:460px;height:800px;overflow-y:auto}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem}.site-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .2s ease;border:1px solid #e9ecef;cursor:pointer}.site-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026;border-color:#3b82f6}.site-card-header{padding:1.5rem;border-bottom:1px solid #f1f3f4;background:#f8f9fa}.site-name{font-size:1.25rem;font-weight:600;color:#212529;margin:0 0 .5rem}.site-location{font-size:.875rem;color:#6c757d;font-weight:500}.site-card-body{padding:1.5rem}.site-info{margin-bottom:1rem}.site-info p{margin:.5rem 0;font-size:.875rem;color:#495057;line-height:1.4}.site-info strong{color:#212529;font-weight:600}.site-description{font-size:.875rem;color:#6c757d;line-height:1.5;margin:0;padding-top:1rem;border-top:1px solid #f1f3f4}.site-card-footer{padding:1rem 1.5rem;background:#f8f9fa;border-top:1px solid #f1f3f4;display:flex;justify-content:flex-end;gap:.5rem}.view-site-btn{padding:.5rem 1rem;background:#0d6efd;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.view-site-btn:hover{background:#0b5ed7}.delete-site-btn{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.delete-site-btn:hover{background:#c82333}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{font-size:1.5rem;font-weight:600;color:#212529;margin:0 0 .5rem}.empty-state p{font-size:1rem;color:#6c757d;margin:0}@media (max-width: 768px){.sites-page-header{padding:1rem}.sites-header-content{flex-direction:column;gap:1rem}.sites-header-actions{flex-direction:column;align-items:stretch;gap:.75rem}.view-toggle-buttons{justify-content:center}.sites-page-title{font-size:1.5rem}.sites-section{padding:1rem 1rem 0;min-height:calc(100vh - 150px)}.sites-grid-overlay{max-width:100%;margin:20px 0 0;padding:1rem;height:400px}.sites-grid{grid-template-columns:1fr;gap:1rem}.site-card-header,.site-card-body,.site-card-footer{padding:1rem}.empty-state{padding:2rem 1rem}.empty-icon{font-size:2rem}.empty-state h3{font-size:1.25rem}}.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}}.sites-map{width:100%;height:100%;position:relative}.sites-map .map-container{width:100%;height:100%;min-height:400px}.site-marker .marker-pin{width:16px;height:16px;border-radius:50%;background:#3b82f6;border:2px solid #ffffff;box-shadow:0 2px 4px #0000004d;cursor:pointer;transition:all .2s ease}.site-marker .marker-pin:hover{background:#2563eb;transform:scale(1.2);box-shadow:0 4px 8px #0006}.site-popup{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:8px;min-width:200px}.site-popup h3{margin:0 0 8px;font-size:16px;font-weight:600;color:#1f2937}.site-popup p{margin:4px 0;font-size:14px;color:#6b7280}.site-popup p strong{color:#374151}.site-popup .view-details-btn{margin-top:12px;padding:6px 12px;background:#0d6efd;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%}.site-popup .view-details-btn:hover{background:#0b5ed7;transform:translateY(-1px)}.site-popup .view-details-btn:active{transform:translateY(0)}.leaflet-popup-content-wrapper{border-radius:8px;box-shadow:0 4px 12px #00000026}.leaflet-popup-tip{background:#fff}.leaflet-popup-content{margin:8px;line-height:1.4}.standardized-sites-filter{background-color:#fff;border:1px solid #e0e0e0;border-radius:12px;margin-bottom:24px;box-shadow:0 2px 4px #0000000d;transition:all .2s ease}.standardized-sites-filter:hover{box-shadow:0 4px 8px #0000001a}.filter-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background-color:#f8f9fa;border-radius:12px 12px 0 0}.filter-header-left{display:flex;align-items:center;gap:16px}.filter-title{margin:0;font-size:18px;font-weight:600;color:#212529}.filter-count{padding:4px 12px;background-color:#007bff;color:#fff;border-radius:16px;font-size:12px;font-weight:500}.filter-header-right{display:flex;align-items:center}.filter-toggle-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid #d0d0d0;border-radius:8px;background-color:#fff;color:#495057;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-toggle-btn:hover{border-color:#007bff;color:#007bff;background-color:#f8f9fa}.filter-toggle-btn.expanded{background-color:#007bff;color:#fff;border-color:#007bff}.filter-toggle-icon{font-size:12px;transition:transform .2s ease}.filter-content{padding:24px}.filter-actions{display:flex;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.filter-add-btn{padding:10px 20px;border:2px solid #28a745;border-radius:8px;background-color:#28a745;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.filter-add-btn:hover{background-color:#1e7e34;border-color:#1e7e34;transform:translateY(-1px);box-shadow:0 4px 8px #28a7454d}.filter-clear-btn{padding:10px 20px;border:2px solid #dc3545;border-radius:8px;background-color:#dc3545;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.filter-clear-btn:hover{background-color:#c82333;border-color:#c82333;transform:translateY(-1px);box-shadow:0 4px 8px #dc35454d}.filter-list{display:flex;flex-direction:column;gap:20px}.filter-item{display:flex;align-items:flex-start;gap:16px;padding:20px;border:1px solid #e0e0e0;border-radius:8px;background-color:#f8f9fa;transition:all .2s ease}.filter-item:hover{border-color:#d0d0d0;background-color:#f5f5f5}.filter-property{min-width:200px}.property-select{width:100%;padding:8px 12px;border:1px solid #d0d0d0;border-radius:6px;background-color:#fff;font-size:14px;color:#333;transition:border-color .2s ease}.property-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.filter-value{flex:1;display:flex;flex-direction:column;gap:12px}.text-filter{display:flex;gap:12px;align-items:center}.operator-select{min-width:150px;padding:8px 12px;border:1px solid #d0d0d0;border-radius:6px;background-color:#fff;font-size:14px;color:#333;transition:border-color .2s ease}.operator-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.text-input{flex:1;padding:8px 12px;border:1px solid #d0d0d0;border-radius:6px;background-color:#fff;font-size:14px;color:#333;transition:border-color .2s ease}.text-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.multi-options-filter{display:flex;flex-direction:column;gap:12px}.search-input{width:100%;padding:8px 12px;border:1px solid #d0d0d0;border-radius:6px;background-color:#fff;font-size:14px;color:#333;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.options-list{max-height:200px;overflow-y:auto;border:1px solid #d0d0d0;border-radius:6px;background-color:#fff;padding:8px}.option-item{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;border-radius:4px;transition:background-color .2s ease}.option-item:hover{background-color:#f8f9fa}.option-item input[type=checkbox]{margin:0;cursor:pointer}.option-item span{font-size:14px;color:#333}.selected-values{padding:8px 12px;background-color:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;font-size:12px;color:#1976d2}.number-filter{display:flex;gap:12px;align-items:center}.number-input{flex:1;padding:8px 12px;border:1px solid #d0d0d0;border-radius:6px;background-color:#fff;font-size:14px;color:#333;transition:border-color .2s ease}.number-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.unit-label{padding:8px 12px;background-color:#f8f9fa;border:1px solid #d0d0d0;border-radius:6px;font-size:14px;color:#6c757d;font-weight:500;white-space:nowrap}.remove-filter-btn{width:32px;height:32px;border:none;border-radius:50%;background-color:#dc3545;color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.remove-filter-btn:hover{background-color:#c82333;transform:scale(1.1)}.remove-filter-btn:active{transform:scale(.95)}.filter-empty-state{text-align:center;padding:60px 20px;color:#6c757d;background-color:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.filter-empty-state p{margin:0;font-size:16px;font-style:italic}@media (max-width: 768px){.filter-header{flex-direction:column;gap:16px;align-items:stretch}.filter-header-left,.filter-header-right{justify-content:center}.filter-content{padding:16px}.filter-actions{flex-direction:column}.filter-add-btn,.filter-clear-btn{width:100%;text-align:center}.filter-item{flex-direction:column;align-items:stretch}.filter-property{min-width:auto}.text-filter,.number-filter{flex-direction:column;align-items:stretch}.operator-select{min-width:auto}.remove-filter-btn{align-self:flex-end}}.filter-content{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.export-buttons-container{position:relative;margin-bottom:16px;padding:12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.export-info{display:flex;align-items:center;gap:8px;font-size:14px;color:#6c757d}.export-count{font-weight:500;color:#495057}.filtered-indicator{background:#e3f2fd;color:#1976d2;padding:2px 6px;border-radius:4px;font-size:12px;font-weight:500}.export-controls{display:flex;gap:8px;align-items:center}.export-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid #dee2e6;border-radius:6px;background:#fff;color:#495057;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.export-btn:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.export-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.column-selector-btn{background:#e9ecef;border-color:#ced4da}.column-selector-btn:hover:not(:disabled){background:#dee2e6}.csv-export-btn{background:#d4edda;border-color:#c3e6cb;color:#155724}.csv-export-btn:hover:not(:disabled){background:#c3e6cb;border-color:#b8dacc}.pdf-export-btn{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.pdf-export-btn:hover:not(:disabled){background:#f5c6cb;border-color:#f1b0b7}.column-selector{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;margin-top:8px;max-height:400px;overflow:hidden;display:flex;flex-direction:column}.column-selector-header{padding:16px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa}.column-selector-header h4{margin:0;font-size:16px;color:#495057}.column-selector-actions{display:flex;gap:8px}.select-all-btn,.clear-all-btn{padding:4px 8px;border:1px solid #dee2e6;border-radius:4px;background:#fff;color:#495057;font-size:12px;cursor:pointer;transition:all .2s ease}.select-all-btn:hover,.clear-all-btn:hover{background:#f8f9fa;border-color:#adb5bd}.column-list{flex:1;overflow-y:auto;padding:8px;max-height:300px}.column-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.column-item:hover{background:#f8f9fa}.column-item input[type=checkbox]{margin:0;cursor:pointer}.column-label{flex:1;font-size:14px;color:#495057}.column-type{font-size:12px;color:#6c757d;background:#e9ecef;padding:2px 6px;border-radius:3px}.column-selector-footer{padding:12px 16px;border-top:1px solid #e9ecef;background:#f8f9fa;display:flex;justify-content:flex-end}.close-selector-btn{padding:6px 12px;border:1px solid #007bff;border-radius:4px;background:#007bff;color:#fff;font-size:14px;cursor:pointer;transition:all .2s ease}.close-selector-btn:hover{background:#0056b3;border-color:#0056b3}@media (max-width: 768px){.export-buttons-container{flex-direction:column;align-items:stretch}.export-controls{justify-content:center;flex-wrap:wrap}.export-btn{flex:1;min-width:120px;justify-content:center}.column-selector{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:500px;max-height:80vh}}.sites-table-container{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.sites-table-wrapper{overflow-x:auto}.sites-table{width:100%;border-collapse:collapse;font-size:14px}.sites-table thead{background:#f8f9fa;border-bottom:2px solid #e9ecef}.sites-table th{padding:16px 12px;text-align:left;font-weight:600;color:#495057;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-right:1px solid #e9ecef}.sites-table th:last-child{border-right:none}.sites-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s ease}.sites-table tbody tr:hover{background-color:#f8f9fa}.sites-table tbody tr:last-child{border-bottom:none}.sites-table td{padding:16px 12px;vertical-align:top;border-right:1px solid #e9ecef}.sites-table td:last-child{border-right:none}.site-name-cell{min-width:200px}.site-name-content{display:flex;flex-direction:column;gap:4px}.site-name{margin:0;font-size:15px;font-weight:600;color:#212529}.site-description{margin:0;font-size:12px;color:#6c757d;line-height:1.4}.site-location-cell{min-width:150px}.site-location{font-size:14px;color:#495057}.site-owner-cell{min-width:120px}.site-owner{font-size:14px;color:#495057}.site-size-cell{min-width:100px;text-align:right}.site-size{font-size:14px;color:#495057;font-weight:500}.site-overall-score-cell{min-width:120px;text-align:center}.overall-score{display:inline-flex;align-items:center;gap:2px;padding:6px 12px;border-radius:20px;font-weight:600;font-size:13px}.overall-score.excellent{background-color:#d4edda;color:#155724}.overall-score.good{background-color:#d1ecf1;color:#0c5460}.overall-score.fair{background-color:#fff3cd;color:#856404}.overall-score.poor{background-color:#f8d7da;color:#721c24}.overall-score-value{font-size:14px;font-weight:700}.overall-score-label{font-size:11px;font-weight:700;color:#212529}.site-contact-cell{min-width:180px}.contact-info{display:flex;flex-direction:column;gap:2px}.contact-email{font-size:13px;color:#495057;word-break:break-all}.contact-phone{font-size:12px;color:#6c757d}.site-actions-cell{min-width:140px}.action-buttons{display:flex;gap:8px;align-items:center}.view-details-btn{display:inline-block;padding:6px 12px;background-color:#007bff;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease;text-decoration:none;text-align:center}.view-details-btn:hover{background-color:#0056b3}.delete-btn{padding:6px 12px;background-color:#dc3545;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.delete-btn:hover{background-color:#c82333}.sites-table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#6c757d}.sites-table-empty .empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.sites-table-empty h3{margin:0 0 8px;font-size:18px;color:#495057}.sites-table-empty p{margin:0;font-size:14px}.filter-indicator{margin-left:8px;font-size:12px;opacity:.7}.sites-table th{position:relative}.sites-table th.column-description,.sites-table th.column-windCapacity,.sites-table th.column-solarCapacity,.sites-table th.column-totalCapacity,.sites-table th.column-renewablePercentage,.sites-table th.column-averageLMP,.sites-table th.column-co2Rate,.sites-table td.site-description-cell,.sites-table td.site-windCapacity-cell,.sites-table td.site-solarCapacity-cell,.sites-table td.site-totalCapacity-cell,.sites-table td.site-renewablePercentage-cell,.sites-table td.site-averageLMP-cell,.sites-table td.site-co2Rate-cell{background-color:#f8f9fa;border-left:3px solid #007bff}@media (max-width: 768px){.sites-table-container{border-radius:8px}.sites-table th,.sites-table td{padding:12px 8px;font-size:13px}.site-name{font-size:14px}.action-buttons{flex-direction:column;gap:4px}.view-details-btn,.delete-btn{padding:4px 8px;font-size:11px}}@media (max-width: 480px){.sites-table th,.sites-table td{padding:8px 6px;font-size:12px}.overall-score{padding:4px 8px;font-size:11px}.overall-score-value{font-size:12px}}.site-kml-upload{margin-bottom:1.5rem;width:100%}.upload-area{border:2px dashed #d1d5db;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s ease;background-color:#f9fafb;position:relative;box-sizing:border-box;max-width:100%}.upload-area:hover{border-color:#10b981;background-color:#f0fdf4}.upload-area.dragging{border-color:#10b981;background-color:#f0fdf4;transform:scale(1.02)}.upload-area.loading{border-color:#f59e0b;background-color:#fffbeb;cursor:not-allowed}.upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-area:hover .upload-icon,.upload-area.dragging .upload-icon{color:#10b981}.upload-area.loading .upload-icon{color:#f59e0b}.upload-text h3{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#111827}.upload-text p{margin:.25rem 0;color:#6b7280;font-size:.875rem}.upload-text .file-types{font-size:.75rem;color:#9ca3af;font-style:italic}.upload-area.loading .upload-text p{color:#f59e0b;font-weight:500}.polygon-selection{margin-top:1.5rem;border:1px solid #e5e7eb;border-radius:8px;background-color:#fff;max-width:100%;box-sizing:border-box}.selection-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb;background-color:#f9fafb;border-radius:8px 8px 0 0}.selection-header h4{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#111827}.selection-prompt{margin:.25rem 0 0;font-size:.875rem;color:#f59e0b;font-weight:500}.selection-confirmation{margin:.25rem 0 0;font-size:.875rem;color:#10b981;font-weight:500}.clear-button{background-color:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.polygon-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background-color .2s ease}.polygon-item.selected{background-color:#f0fdf4;border-left:4px solid #10b981}.polygon-item.needs-selection{border-left:4px solid #fbbf24}.polygon-info h5{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#111827}.polygon-info p{margin:.25rem 0;font-size:.875rem;color:#6b7280}.polygon-area{color:#059669!important;font-weight:500}.point-info{color:#6b7280;font-size:.875rem;margin:.25rem 0}.point-info .coordinates{font-family:monospace;font-size:.75rem;color:#4b5563;margin-top:.25rem;display:inline-block}.polygon-preview{flex-shrink:0;margin-left:1rem}.preview-box{width:60px;height:40px;border:1px solid #d1d5db;border-radius:4px;background-color:#f9fafb;display:flex;align-items:center;justify-content:center}.preview-polygon{width:30px;height:20px;background-color:#10b981;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%)}@media (max-width: 768px){.upload-area{padding:1.5rem}.polygon-item{flex-direction:column;align-items:flex-start;gap:.75rem}.polygon-preview{margin-left:0;align-self:flex-end}}.site-creation-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.modal-overlay{position:absolute;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1;pointer-events:none}.modal-content{position:relative;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:1000px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out;z-index:10000;transform:translateZ(0);will-change:transform;backface-visibility:hidden;isolation:isolate;contain:layout style paint}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95) translateZ(0)}to{opacity:1;transform:translateY(0) scale(1) translateZ(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-size:24px;font-weight:600}.close-button{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-button:hover{background-color:#fff3}.site-creation-form{padding:32px;transform:translateZ(0);backface-visibility:hidden}.form-section{margin-bottom:32px}.form-section h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;padding-bottom:8px}.search-container{position:relative;margin-bottom:16px}.search-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.location-search-input{width:100%;padding:12px 48px 12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:16px;transition:border-color .2s}.search-spinner{position:absolute;right:16px;top:50%;transform:translateY(-50%);width:20px;height:20px}.spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;max-height:200px;overflow-y:auto;z-index:10}.search-result-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background-color .2s}.search-result-item:hover{background-color:#f9fafb}.search-result-item.no-results{color:#6b7280;font-style:italic;cursor:default}.search-result-item.no-results:hover{background-color:transparent}.help-text{margin:0;font-size:14px;color:#6b7280;font-style:italic}.kml-info{margin-top:1rem;padding:1rem;background-color:#f0fdf4;border:1px solid #10b981;border-radius:8px;border-left:4px solid #10b981;max-width:550px}.kml-info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.kml-info-header h4{margin:0;font-size:1rem;font-weight:600;color:#065f46}.kml-name{font-size:.875rem;color:#047857;font-weight:500;background-color:#d1fae5;padding:.25rem .5rem;border-radius:4px}.kml-info-details p{margin:.25rem 0;font-size:.875rem;color:#065f46}.kml-info-details strong{color:#047857}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:8px;font-weight:500;color:#374151}.form-group input,.form-group textarea{padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:16px;transition:border-color .2s;transform:translateZ(0);backface-visibility:hidden}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.field-help{margin-top:.5rem;font-size:.75rem;color:#6b7280;font-style:italic;line-height:1.4}.form-actions{display:flex;justify-content:flex-end;gap:16px;padding-top:24px;border-top:1px solid #e5e7eb}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.modal-content{width:95%;margin:1rem}.site-creation-form{padding:1.5rem}.modal-header{padding:1rem 1.5rem}.modal-header h2{font-size:1.25rem}}.cancel-button,.submit-button{padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.cancel-button{background-color:#f3f4f6;color:#374151}.cancel-button:hover{background-color:#e5e7eb}.submit-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}@media (max-width: 768px){.modal-content{width:95%;margin:20px}.site-creation-form{padding:20px}.form-row{grid-template-columns:1fr;gap:16px}.modal-header{padding:20px}.modal-header h2{font-size:20px}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%}}.search-container{display:flex;align-items:center;background:#fff;border:1px solid #e1e5e9;border-radius:8px;padding:8px 12px;gap:8px;flex:1;max-width:400px}.search-input{flex:1;border:none;outline:none;font-size:14px;color:#333;background:transparent}.search-input::placeholder{color:#9ca3af}.search-button{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.search-button:hover{color:#374151}.search-button:active{background-color:#f3f4f6}.filter-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.filter-select{padding:8px 12px;border:1px solid #e1e5e9;border-radius:6px;background:#fff;font-size:14px;color:#333;cursor:pointer;outline:none;transition:border-color .2s ease}.filter-select:hover{border-color:#d1d5db}.filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select option{padding:8px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:#6b7280}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.7}.empty-state h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#374151}.empty-state p{margin:0;font-size:14px;line-height:1.5}.table-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-top:1px solid #e5e7eb;margin-top:16px}.pagination-info{font-size:14px;color:#6b7280}.pagination-controls{display:flex;gap:4px;align-items:center}.pagination-btn{padding:8px 12px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;min-width:40px;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.pagination-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-ellipsis{padding:8px 12px;color:#6b7280;font-size:14px}.mobile-pagination{margin-top:24px;padding-top:16px;border-top:1px solid #e5e7eb}.data-table-container{background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 1px 3px #0000001a}.data-table{width:100%}.table-header-row{display:grid;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;color:#374151;font-size:14px}.table-row{display:grid;border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.table-row:hover{background-color:#f9fafb}.table-row:last-child{border-bottom:none}.table-cell{padding:12px 16px;display:flex;align-items:center;font-size:14px;color:#374151;min-height:48px}.table-header-row .table-cell{font-weight:600;color:#374151}.table-cell.site-name{font-weight:500}.table-cell.actions{justify-content:flex-end}.table-cell.survey-status,.table-cell.status{justify-content:center}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-pending{background:#fef3c7;color:#92400e}.status-submitted{background:#d1fae5;color:#065f46}.status-answered{background:#dbeafe;color:#1e40af}.status-in-progress{background:#f3e8ff;color:#7c3aed}.site-icon{margin-right:8px;font-size:16px}.continue-survey-btn,.view-survey-btn,.start-survey-btn{padding:6px 12px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s ease}.continue-survey-btn:hover,.view-survey-btn:hover,.start-survey-btn:hover{background:#f9fafb;border-color:#9ca3af}@media (max-width: 1200px){.table-cell{padding:10px 14px}}@media (max-width: 768px){.table-cell{padding:8px 12px;font-size:13px}}@media (max-width: 480px){.data-table-container{display:none}}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-container{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:1.5rem 1.5rem 0}.modal-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0}.modal-body{padding:1rem 1.5rem}.modal-message{font-size:1rem;color:#4b5563;line-height:1.5;margin:0}.modal-footer{padding:0 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.modal-button{padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;min-width:80px}.modal-button-cancel{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.modal-button-cancel:hover{background:#e5e7eb;border-color:#9ca3af}.modal-button-confirm{color:#fff}.modal-button-danger{background:#dc2626}.modal-button-danger:hover{background:#b91c1c}.modal-button-warning{background:#f59e0b}.modal-button-warning:hover{background:#d97706}.modal-button-info{background:#3b82f6}.modal-button-info:hover{background:#206078}.modal-danger .modal-title{color:#dc2626}.modal-warning .modal-title{color:#f59e0b}.modal-info .modal-title{color:#3b82f6}@media (max-width: 640px){.modal-backdrop{padding:.5rem}.modal-container{max-width:100%}.modal-header{padding:1rem 1rem 0}.modal-body{padding:.75rem 1rem}.modal-footer{padding:0 1rem 1rem;flex-direction:column-reverse}.modal-button{width:100%}}.modal-container:focus{outline:none}.modal-button:focus{outline:2px solid #3b82f6;outline-offset:2px}@media (prefers-contrast: high){.modal-backdrop{background:#000c}.modal-container{border:2px solid #000000}}.kml-file-upload{width:100%}.upload-area{border:2px dashed #d1d5db;border-radius:8px;padding:32px;text-align:center;cursor:pointer;transition:all .2s ease;background-color:#f9fafb;position:relative}.upload-area:hover{border-color:#3b82f6;background-color:#f0f9ff}.upload-area.dragging{border-color:#3b82f6;background-color:#eff6ff;transform:scale(1.02)}.upload-area.loading{cursor:not-allowed;opacity:.7}.upload-icon{color:#6b7280;transition:color .2s ease}.upload-area:hover .upload-icon{color:#3b82f6}.upload-text h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#374151}.upload-text p{margin:4px 0;color:#6b7280;font-size:14px}.file-types{font-size:12px!important;color:#9ca3af!important;font-style:italic}.polygon-selection{margin-top:24px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.selection-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background-color:#f9fafb;border-bottom:1px solid #e5e7eb}.selection-header h4{margin:0 0 4px;font-size:16px;font-weight:600;color:#374151}.selection-prompt{margin:4px 0 0;font-size:12px;color:#f59e0b;font-weight:500}.selection-confirmation{margin:4px 0 0;font-size:12px;color:#10b981;font-weight:500}.clear-button{padding:6px 12px;background-color:#ef4444;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.clear-button:hover{background-color:#dc2626}.polygon-list{max-height:300px;overflow-y:auto}.polygon-item{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background-color .2s ease}.polygon-item:hover{background-color:#f9fafb}.polygon-item.selected{background-color:#eff6ff;border-left:3px solid #3b82f6}.polygon-item.needs-selection{border-left:3px solid #fbbf24}.polygon-item.needs-selection:hover{background-color:#fffbeb;border-left-color:#f59e0b}.polygon-item:last-child{border-bottom:none}.polygon-info{flex:1}.polygon-info h5{margin:0 0 4px;font-size:14px;font-weight:600;color:#374151}.polygon-info p{margin:0;font-size:12px;color:#6b7280;display:flex;align-items:center;gap:8px}.polygon-area{margin-top:4px!important;color:#059669!important;font-size:11px!important}.point-info{margin-top:4px!important;color:#6b7280!important;font-size:11px!important}.point-info .coordinates{font-family:monospace;font-size:10px!important;color:#4b5563!important;margin-top:2px;display:block}.coordinates{font-family:monospace;background-color:#f3f4f6;padding:2px 6px;border-radius:3px;font-size:11px}.polygon-preview{margin-left:16px}.preview-box{width:40px;height:40px;border:1px solid #d1d5db;border-radius:4px;background-color:#f9fafb;display:flex;align-items:center;justify-content:center;position:relative}.preview-polygon{width:20px;height:20px;background-color:#3b82f6;opacity:.3;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}.upload-area.loading .upload-icon{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.upload-area{padding:24px 16px}.upload-text h3{font-size:16px}.upload-text p{font-size:13px}.polygon-item{flex-direction:column;align-items:flex-start;gap:8px}.polygon-preview{margin-left:0;align-self:flex-end}}.toast{position:fixed;top:80px;right:20px;z-index:1200;min-width:300px;max-width:400px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;border-left:4px solid;animation:slideIn .3s ease-out}.toast-success{border-left-color:#10b981}.toast-info{border-left-color:#3b82f6}.toast-warning{border-left-color:#f59e0b}.toast-error{border-left-color:#ef4444}.toast-content{display:flex;align-items:center;justify-content:space-between;padding:1rem}.toast-message{font-size:.875rem;color:#374151;margin-right:.5rem;line-height:1.4}.toast-close{background:transparent;border:none;color:#9ca3af;font-size:1.25rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease;flex-shrink:0}.toast-close:hover{color:#6b7280;background:#f3f4f6}@media (max-width: 768px){.toast{top:70px;right:10px;left:10px;min-width:auto;max-width:none}.toast-content{padding:.75rem}.toast-message{font-size:.8rem}}.backoffice-site-list-container{padding:2rem;background-color:#f8f9fa;min-height:100vh}.backoffice-site-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.header-content h1{margin:0 0 .5rem;font-size:1.75rem;font-weight:600;color:#212529}.header-content p{margin:0;color:#6c757d;font-size:.875rem}.add-site-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#0d6efd;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.add-site-button:hover{background:#0b5ed7;transform:translateY(-1px)}.add-site-button svg{width:16px;height:16px}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:1rem;color:#6c757d}.backoffice-site-actions{display:flex;gap:.5rem;align-items:center}.action-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease;color:#fff;font-size:.875rem}.action-button.view{background:#0d6efd}.action-button.view:hover{background:#0b5ed7}.action-button.edit{background:#ffc107;color:#212529}.action-button.edit:hover{background:#e0a800}.action-button.delete{background:#dc3545}.action-button.delete:hover{background:#c82333}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:0;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.backoffice-modal{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e9ecef}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#212529}.modal-close{background:none;border:none;font-size:1.5rem;color:#6c757d;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f8f9fa;color:#495057}.modal-body{padding:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#495057}.form-group input,.form-group textarea{padding:.75rem;border:1px solid #dee2e6;border-radius:6px;font-size:.875rem;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0d6efd;box-shadow:0 0 0 3px #0d6efd1a}.form-group textarea{resize:vertical;min-height:80px}.polygon-info{background:#e7f3ff;border:1px solid #b3d9ff;border-radius:6px;padding:1rem;margin-top:1rem}.polygon-info p{margin:.25rem 0;font-size:.875rem;color:#0d6efd}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e9ecef;background:#f8f9fa}.modal-footer button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.modal-footer button:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-primary{background:#0d6efd;color:#fff}.btn-primary:hover:not(:disabled){background:#0b5ed7}@media (max-width: 768px){.backoffice-site-list-container{padding:1rem}.backoffice-site-list-header{flex-direction:column;gap:1rem;align-items:stretch}.add-site-button{justify-content:center}.form-row{grid-template-columns:1fr}.modal-content{width:95%;margin:1rem}.backoffice-site-actions{flex-direction:column;gap:.25rem}.action-button{width:28px;height:28px}}.site-map{width:100%;height:100%;position:relative}.map-container{width:100%;height:100%;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.leaflet-container{width:100%;height:100%;border-radius:8px}.leaflet-control-layers{background:#ffffffe6;border-radius:6px;box-shadow:0 2px 8px #0000001a;padding:8px}.leaflet-control-layers-toggle{background:#fff;border:1px solid #dee2e6;border-radius:4px;width:30px;height:30px}.leaflet-control-zoom{border-radius:6px;box-shadow:0 2px 8px #0000001a}.leaflet-control-zoom a{background:#fff;border:1px solid #dee2e6;color:#495057;font-weight:500}.leaflet-control-zoom a:hover{background:#f8f9fa;color:#212529}.site-popup{padding:8px;max-width:250px}.site-popup h3{margin:0 0 8px;font-size:1rem;font-weight:600;color:#212529}.site-popup p{margin:4px 0;font-size:.875rem;color:#495057;line-height:1.4}.site-popup strong{color:#212529;font-weight:600}.site-center-marker{background:none;border:none}.marker-pin{width:20px;height:20px;background:#0d6efd;border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003;position:relative}.site-map.loading{display:flex;align-items:center;justify-content:center;background:#f8f9fa;color:#6c757d;font-size:.875rem}.site-map.error{display:flex;align-items:center;justify-content:center;background:#f8d7da;color:#721c24;font-size:.875rem;border:1px solid #f5c6cb;border-radius:8px}@media (max-width: 768px){.site-map{height:300px}.site-popup{max-width:200px}.site-popup h3{font-size:.875rem}.site-popup p{font-size:.75rem}}.category-item{width:100%;padding:16px;border:1px solid #e9ecef;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:left;margin-bottom:12px}.category-item:hover{border-color:#3b82f6;box-shadow:0 2px 4px #0000001a}.category-item.active{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 2px 8px #3b82f633}.category-content h4{font-size:16px;font-weight:600;color:#2a2b2d;margin:0 0 8px}.category-content p{font-size:12px;color:#6c757d;margin:0 0 12px}.category-score{font-size:14px;color:#495057;margin-bottom:8px}.category-label{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;color:#fff;display:inline-block}.category-label.complete{background-color:#28a745}.category-label.med-high{background-color:#8bc34a}.category-label.medium{background-color:#ffc107;color:#212529}.category-label.med-low{background-color:#ff9800}.category-label.low{background-color:#f44336}.category-label.high{background-color:#4caf50}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#374151}.info-icon{color:#6b7280;cursor:help}.filter-dropdown{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;color:#374151;cursor:pointer;transition:border-color .2s ease}.filter-dropdown:hover{border-color:#d1d5db}.filter-dropdown span{font-weight:500}.learn-more-button{padding:6px 12px;background-color:#3b82f6;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease;align-self:flex-start}.learn-more-button:hover{background-color:#2563eb}.site-evaluation-container{display:flex;flex-direction:column;height:calc(100vh - 64px);min-height:calc(100vh - 64px);background-color:#f8f9fa;overflow:hidden;width:100%;max-width:100vw;transition:all .3s ease}.site-evaluation-container.interface-hidden{height:calc(100vh - 64px);position:fixed;inset:64px 0 0;z-index:1000;width:100vw}.site-evaluation-container.interface-hidden .step-content-container{height:100%;padding:0;overflow:hidden}.site-evaluation-container.interface-hidden .step-content{height:100%;max-width:100%;margin:0}.evaluation-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 2px 4px #0000001a;flex-shrink:0;transition:all .3s ease}.evaluation-header.hidden{display:none}.evaluation-header h1{font-size:1.75rem;font-weight:600;color:#fff;margin:0;flex:1;text-align:center}.evaluation-summary{display:flex;align-items:center;gap:1rem}.overall-score{font-size:1.125rem;font-weight:600;color:#fff}.score-label{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.score-label.excellent{background-color:#28a745}.score-label.good{background-color:#17a2b8}.score-label.fair{background-color:#ffc107;color:#212529}.score-label.poor{background-color:#dc3545}.score-label.high{background-color:#28a745}.score-label.med-high{background-color:#17a2b8}.score-label.med-low{background-color:#fd7e14}.score-label.low{background-color:#dc3545}.back-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;text-decoration:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;flex-shrink:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-button:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.back-button:disabled{opacity:.6;cursor:not-allowed}.step-navigation{display:flex;background:#fff;border-bottom:1px solid #e9ecef;overflow-x:auto;flex-shrink:0;transition:all .3s ease}.step-navigation.hidden{display:none}.step-tab{display:flex;align-items:center;gap:1rem;padding:1.5rem 2rem;background:none;border:none;border-bottom:3px solid transparent;color:#6c757d;cursor:pointer;transition:all .2s ease;min-width:280px;text-align:left;white-space:nowrap}.step-tab:hover{background-color:#f8f9fa;color:#495057}.step-tab.active{color:#0d6efd;border-bottom-color:#0d6efd;background-color:#f8f9fa}.step-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#f8f9fa;border-radius:8px;color:#6c757d;flex-shrink:0}.step-tab.active .step-icon{background:#e3f2fd;color:#0d6efd}.step-info{flex:1;min-width:0}.step-title{font-size:1rem;font-weight:600;color:inherit;margin-bottom:.25rem;white-space:normal;line-height:1.3}.step-description{font-size:.875rem;color:#6c757d;line-height:1.4;white-space:normal}.step-tab.active .step-description{color:#0d6efd}.step-content-container{flex:1;overflow-y:auto;padding:2rem;min-height:0}.step-content{max-width:1450px;margin:0 auto;pointer-events:auto;position:relative}.water-risk-overview{margin-bottom:2rem}.risk-summary-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #dee2e6;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.risk-summary-card h3{margin:0 0 1rem;font-size:1.25rem;color:#495057;text-align:center}.risk-scores{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.risk-score-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fff;border-radius:8px;border:1px solid #dee2e6}.risk-label{font-weight:600;color:#495057}.risk-value{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.risk-value.medium{background:#fff3cd;color:#856404}.risk-value.medium-high{background:#ffe5d0;color:#7d5a00}.risk-value.high{background:#f8d7da;color:#721c24}.risk-value.low{background:#d4edda;color:#155724}.water-risk-section{margin-bottom:3rem}.water-risk-section-title{font-size:1.5rem;font-weight:600;color:#212529;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #dee2e6}.news-articles-list{display:flex;flex-direction:column;gap:1.5rem}.news-article-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #dee2e6;box-shadow:0 2px 4px #0000000d;transition:all .2s ease}.news-article-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.news-article-header{margin-bottom:1rem}.news-article-header h4{margin:0 0 .75rem;font-size:1.125rem;font-weight:600}.news-article-header h4 a{color:#0d6efd;text-decoration:none;transition:color .2s ease}.news-article-header h4 a:hover{color:#0a58ca;text-decoration:underline}.news-article-meta{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.news-article-date{font-size:.875rem;color:#6c757d;font-weight:500}.news-article-risk-type{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#e9ecef;color:#495057}.news-article-risk-type.water-scarcity{background:#fff3cd;color:#856404}.news-article-risk-type.flood{background:#cfe2ff;color:#084298}.news-article-risk-type.water-quality{background:#f8d7da;color:#721c24}.news-article-sentiment{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.news-article-sentiment.positive{background:#d4edda;color:#155724}.news-article-sentiment.negative{background:#f8d7da;color:#721c24}.news-article-sentiment.neutral{background:#e9ecef;color:#495057}.news-article-summary{margin:0;color:#495057;line-height:1.6;font-size:.9375rem}.water-assessment-main{margin:0 0 1rem;color:#212529;line-height:1.6;font-size:1rem;font-weight:500}.water-assessment-question{margin:0;color:#6c757d;line-height:1.5;font-size:.8125rem;font-style:italic;border-top:1px solid #e9ecef;padding-top:.75rem;margin-top:.75rem}.step-header{text-align:center;margin-bottom:3rem}.step-header h2{font-size:2rem;font-weight:700;color:#212529;margin-bottom:1rem}.step-header p{font-size:1.125rem;color:#6c757d;width:100%;margin:0;line-height:1.6}.evaluation-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:2rem}.evaluation-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a;border:1px solid #e9ecef;transition:all .2s ease}.evaluation-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e9ecef}.card-header h3{font-size:1.25rem;font-weight:600;color:#212529;margin:0}.score-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;color:#fff}.score-badge.high{background-color:#28a745}.score-badge.med-high{background-color:#8bc34a}.score-badge.medium{background-color:#ffc107;color:#212529}.score-badge.med-low{background-color:#ff9800}.score-badge.low{background-color:#f44336}.card-content p{margin:.75rem 0;font-size:.875rem;color:#495057;line-height:1.5}.card-content strong{color:#212529;font-weight:600}.step-controls{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:#fff;border-top:1px solid #e9ecef;box-shadow:0 -2px 4px #0000001a;flex-shrink:0;transition:all .3s ease}.step-controls.hidden{display:none}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#0d6efd;border:1px solid #0d6efd;border-radius:8px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.nav-button:hover:not(:disabled){background:#0b5ed7;border-color:#0b5ed7;transform:translateY(-1px)}.nav-button:disabled{background:#6c757d;border-color:#6c757d;cursor:not-allowed;transform:none}.nav-button.prev{background:#6c757d;border-color:#6c757d}.nav-button.prev:hover:not(:disabled){background:#5a6268;border-color:#5a6268}.step-indicator{font-size:.875rem;color:#6c757d;font-weight:500}@media (max-width: 1200px){.evaluation-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}}@media (max-width: 1024px){.site-evaluation-container{height:calc(100vh - 64px)}.evaluation-header{flex-direction:column;gap:1rem;text-align:center;padding:1rem}.evaluation-header h1{font-size:1.5rem;color:#fff}.step-navigation{flex-wrap:wrap}.step-tab{min-width:250px;padding:1rem 1.5rem}.step-content-container{padding:1.5rem}.evaluation-grid{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 768px){.evaluation-header{padding:1rem}.evaluation-header h1{font-size:1.25rem;color:#fff}.evaluation-summary{flex-direction:column;gap:.5rem}.overall-score{color:#fff}.step-navigation{flex-direction:column}.step-tab{min-width:100%;padding:1rem}.step-content-container{padding:1rem}.step-header h2{font-size:1.5rem}.step-header p{font-size:1rem}.evaluation-card{padding:1rem}.step-controls{flex-direction:column;gap:1rem;padding:1rem}.nav-button{width:100%;justify-content:center}}@media (max-width: 480px){.evaluation-header{padding:.75rem}.evaluation-header h1,.overall-score{color:#fff}.step-content-container,.evaluation-card{padding:.75rem}.card-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.energy-summary{background:#fff;border-radius:12px;padding:2rem;margin-top:2rem;box-shadow:0 4px 12px #0000001a;border:1px solid #e9ecef}.energy-summary h3{font-size:1.5rem;font-weight:600;color:#212529;margin-bottom:1.5rem;text-align:center}.capacity-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.capacity-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.capacity-label{font-size:.875rem;color:#6c757d;font-weight:500}.capacity-value{font-size:1.125rem;font-weight:700;color:#0d6efd}.step-map-container{width:100%;flex:1;padding:15px;min-height:400px;border-radius:8px;overflow:hidden;background-color:#fff;box-shadow:0 2px 8px #0000001a}.step-map-container h3{font-size:1.5rem;font-weight:600;color:#212529;margin-bottom:1.5rem;text-align:center}.map-placeholder{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 12px #0000001a;border:1px solid #e9ecef;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.map-content{position:relative;width:100%;height:300px;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:8px;border:2px solid #2196f3;display:flex;align-items:center;justify-content:center}.cable-route{position:absolute;display:flex;align-items:center;justify-content:center}.cable-point{padding:.5rem 1rem;background:#2196f3;color:#fff;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;box-shadow:0 2px 8px #2196f34d}.cable-point.usa{background:#4caf50;left:20%;top:50%;transform:translateY(-50%)}.cable-point.europe{background:#ff9800;right:15%;top:20%}.cable-point.africa{background:#9c27b0;right:25%;bottom:20%}.cable-point.asia{background:#f44336;right:10%;top:50%;transform:translateY(-50%)}.cable-point.south-america{background:#795548;left:30%;bottom:15%}.cable-line{position:absolute;height:2px;background:linear-gradient(90deg,#2196f3,#64b5f6);box-shadow:0 0 8px #2196f380}.cable-route:nth-child(1) .cable-line{width:200px;left:35%;top:50%;transform:translateY(-50%)}.cable-route:nth-child(2) .cable-line{width:180px;left:35%;top:50%;transform:translateY(-50%) rotate(-30deg)}.cable-route:nth-child(3) .cable-line{width:220px;left:35%;top:50%;transform:translateY(-50%) rotate(30deg)}.cable-route:nth-child(4) .cable-line{width:160px;left:35%;top:50%;transform:translateY(-50%) rotate(-45deg)}.water-map-container{margin-top:2rem;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;position:relative;width:650px;height:650px;margin:10px}.water-map{width:650px;height:650px;border-radius:8px;background:#f8f9fa}.water-map .leaflet-container{width:100%;height:100%;border-radius:8px}.water-map .leaflet-control-layers{background:#ffffffe6;border-radius:6px;box-shadow:0 2px 8px #0000001a;padding:8px}.water-map .leaflet-control-layers-toggle{background:#fff;border:1px solid #dee2e6;border-radius:4px;width:30px;height:30px}.water-map .leaflet-control-zoom{border-radius:6px;box-shadow:0 2px 8px #0000001a}.water-map .leaflet-control-zoom a{background:#fff;border:1px solid #dee2e6;color:#495057;font-weight:500}.water-map .leaflet-control-zoom a:hover{background:#f8f9fa;color:#212529}.water-map .site-popup{padding:8px;max-width:250px}.water-map .site-popup h3{margin:0 0 8px;font-size:1rem;font-weight:600;color:#212529}.water-map .site-popup p{margin:4px 0;font-size:.875rem;color:#495057;line-height:1.4}.water-map .site-popup strong{color:#212529;font-weight:600}.water-map .site-center-marker{background:none;border:none}.water-map .marker-pin{width:20px;height:20px;background:#0d6efd;border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003;position:relative}.marker-pin:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:#fff;border-radius:50%}.water-map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #0000001a;text-align:center;z-index:1000}.water-loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3B82F6;border-radius:50%;animation:water-spin 1s linear infinite;margin:0 auto 1rem}@keyframes water-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.water-map-loading p{margin:0;color:#495057;font-size:.875rem;font-weight:500}.map-legend{margin-top:1rem;text-align:center;font-size:.875rem;color:#6c757d;font-style:italic}.summary-overview{margin-bottom:3rem}.overall-score-card{display:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;padding:3rem;text-align:center;box-shadow:0 8px 32px #667eea4d}.overall-score-card h3{font-size:1.5rem;font-weight:600;margin-bottom:2rem;color:#fff}.score-display{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem}.main-score{font-size:4rem;font-weight:800;color:gold;text-shadow:0 2px 4px rgba(0,0,0,.3)}.score-grade{font-size:1.5rem;font-weight:600;color:gold;text-transform:uppercase;letter-spacing:1px}.score-description{font-size:1.125rem;line-height:1.6;max-width:600px;margin:0 auto;color:#fff;opacity:.95}.strengths-list,.improvements-list,.risks-list,.recommendations-list{list-style:none;padding:0;margin:0}.strengths-list li,.improvements-list li,.risks-list li,.recommendations-list li{padding:.5rem 0;border-bottom:1px solid #e9ecef;font-size:.875rem;line-height:1.5}.strengths-list li:last-child,.improvements-list li:last-child,.risks-list li:last-child,.recommendations-list li:last-child{border-bottom:none}.strengths-list li{color:#28a745}.improvements-list li{color:#ffc107}.risks-list li{color:#dc3545}.recommendations-list li{color:#17a2b8}.final-assessment{background:#fff;border-radius:12px;padding:2rem;margin-top:2rem;box-shadow:0 4px 12px #0000001a;border:1px solid #e9ecef}.final-assessment h3{font-size:1.5rem;font-weight:600;color:#212529;margin-bottom:1.5rem;text-align:center}.final-assessment p{font-size:1rem;line-height:1.7;color:#495057;margin-bottom:1rem}.final-assessment p:last-child{margin-bottom:0;font-weight:600;color:#28a745;text-align:center;font-size:1.125rem}@media (max-width: 1024px){.capacity-breakdown{grid-template-columns:1fr}.map-content{height:250px}.cable-route .cable-line{width:120px!important}.overall-score-card{padding:2rem}.main-score{font-size:3rem}}@media (max-width: 768px){.energy-summary{padding:1.5rem}.map-placeholder{padding:1rem;min-height:300px}.map-content{height:200px}.cable-point,.river,.creek,.lake{font-size:.625rem;padding:.25rem .5rem}.overall-score-card{padding:1.5rem}.main-score{font-size:2.5rem}.score-grade{font-size:1.25rem}.final-assessment{padding:1.5rem}}@media (max-width: 480px){.energy-summary{padding:1rem}.map-placeholder{padding:.75rem;min-height:250px}.map-content{height:180px}.overall-score-card{padding:1rem}.main-score{font-size:2rem}.final-assessment{padding:1rem}}.data-source-section{margin-bottom:3rem;padding:1.5rem;background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:16px;border:1px solid #e9ecef;box-shadow:0 2px 8px #0000000d}.section-title{display:flex;align-items:center;gap:1rem;font-size:1.5rem;font-weight:600;color:#212529;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e9ecef}.data-source-badge{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem 1rem;background:linear-gradient(135deg,#0d6efd,#0b5ed7);color:#fff;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;box-shadow:0 2px 8px #0d6efd4d;min-width:80px;text-decoration:none;transition:all .3s ease;cursor:pointer}.data-source-badge:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0d6efd66;color:#fff;text-decoration:none}.data-source-label{font-size:.625rem;font-weight:500;text-transform:none;letter-spacing:.25px;opacity:.9;margin-top:.125rem}.data-source-badge:nth-child(1){background:linear-gradient(135deg,#28a745,#20c997);box-shadow:0 2px 8px #28a7454d}.data-source-badge:nth-child(2){background:linear-gradient(135deg,#dc3545,#e74c3c);box-shadow:0 2px 8px #dc35454d}.data-source-badge:nth-child(3){background:linear-gradient(135deg,#6f42c1,#8e44ad);box-shadow:0 2px 8px #6f42c14d}.data-source-badge:nth-child(4){background:linear-gradient(135deg,#fd7e14,#f39c12);box-shadow:0 2px 8px #fd7e144d}.data-source-badge:nth-child(5){background:linear-gradient(135deg,#20c997,#17a2b8);box-shadow:0 2px 8px #20c9974d}.data-source-badge:nth-child(6){background:linear-gradient(135deg,#6610f2,#9c27b0);box-shadow:0 2px 8px #6610f24d}.data-source-badge:nth-child(7){background:linear-gradient(135deg,#e83e8c,#e91e63);box-shadow:0 2px 8px #e83e8c4d}.data-source-badge:nth-child(8){background:linear-gradient(135deg,#795548,#8d6e63);box-shadow:0 2px 8px #7955484d}.data-source-section .evaluation-grid{margin-top:1rem}.data-source-section .evaluation-card{border:1px solid #dee2e6;background:#fff;transition:all .3s ease}.data-source-section .evaluation-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000001f;border-color:#0d6efd}.data-source-section .card-header{position:relative}.data-source-section .card-header:before{content:"";position:absolute;left:-1.5rem;top:0;bottom:0;width:4px;background:linear-gradient(135deg,#0d6efd,#0b5ed7);border-radius:2px}.step-layout-with-map{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:start}.evaluation-cards-section{display:flex;flex-direction:column;min-width:700px}.map-section{display:flex;flex-direction:column;position:sticky;top:2rem;min-width:700px}.step-layout-with-map .evaluation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}@media (max-width: 1200px){.step-layout-with-map{grid-template-columns:1fr;gap:1.5rem}.step-layout-with-map .evaluation-grid{grid-template-columns:repeat(2,1fr)}.map-section{position:static;order:-1}}@media (max-width: 768px){.data-source-section{margin-bottom:2rem;padding:1rem}.section-title{font-size:1.25rem;flex-direction:column;align-items:flex-start;gap:.5rem}.data-source-badge{font-size:.75rem;padding:.375rem .75rem;min-width:70px}.data-source-label{font-size:.5rem}.step-layout-with-map{gap:1rem}.step-layout-with-map .evaluation-grid{grid-template-columns:1fr}}.cable-map-container{margin-top:2rem;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;position:relative;width:100%;height:600px;margin:10px}.cable-map-iframe{width:100%;height:1796px;border:none;border-radius:8px;background:#f8f9fa}.cable-map-title{font-size:1.5rem;font-weight:600;color:#212529;margin-bottom:1.5rem;text-align:center;margin-top:10px}@media (max-width: 1200px){.cable-map-container{width:100%;margin:10px 0}.cable-map-iframe{width:100%;height:1200px}}@media (max-width: 768px){.cable-map-container{width:100%;margin:10px 0}.cable-map-iframe{width:100%;height:1000px}}@media (max-width: 480px){.cable-map-container{width:100%;margin:10px 0}.cable-map-iframe{width:100%;height:800px}}.interactive-map-view{display:flex;height:100%;min-height:600px;gap:1.5rem;background-color:#f8f9fa;position:relative}.map-overlay-controls{flex:0 0 320px;background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;overflow-y:auto;max-height:100%;transition:all .3s ease}.map-overlay-controls.hidden{display:none}.map-overlay-controls h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#333}.overlay-description{margin:0 0 1.5rem;font-size:.875rem;color:#666;line-height:1.5}.overlay-list{display:flex;flex-direction:column;gap:.75rem}.overlay-item{display:flex;align-items:center;gap:.75rem;padding:.875rem;border:2px solid #e9ecef;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#fff;position:relative}.overlay-item:hover{border-color:#667eea;background:#f8f9ff;transform:translate(2px)}.overlay-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea;flex-shrink:0}.overlay-item input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.overlay-icon{font-size:1.5rem;flex-shrink:0;width:32px;text-align:center}.overlay-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.overlay-name{font-weight:600;font-size:.9375rem;color:#333}.overlay-desc{font-size:.8125rem;color:#666}.voltage-legend{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.voltage-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.voltage-color-square{width:12px;height:12px;border:1px solid rgba(0,0,0,.2);border-radius:2px;flex-shrink:0;display:inline-block}.voltage-label{color:#666;font-size:.75rem}.overlay-loading{font-size:.75rem;color:#667eea;font-style:italic;position:absolute;right:.875rem}.overlay-item input[type=checkbox]:checked+.overlay-icon+.overlay-info{color:#667eea}.overlay-item input[type=checkbox]:checked~.overlay-info .overlay-name{color:#667eea}.map-container-wrapper{flex:1;min-width:0;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;background:#fff;transition:all .3s ease;position:relative}.interactive-map-container{width:100%;height:100%;min-height:600px}.interactive-map-container .leaflet-container{width:100%;height:100%;border-radius:8px}.site-center-marker{background:transparent;border:none}.marker-pin{width:20px;height:20px;background:#3b82f6;border:3px solid white;border-radius:50%;box-shadow:0 2px 4px #0000004d}.power-plant-marker{background:transparent;border:none}.toggle-interface-button{position:absolute;top:100px;right:1rem;z-index:9999;width:44px;height:44px;background:#fff!important;border:2px solid #e9ecef!important;border-radius:8px;display:flex!important;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #00000026;transition:all .2s ease;color:#495057;pointer-events:auto;margin:0;padding:0}.toggle-interface-button:hover{background:#f8f9fa;border-color:#667eea;color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.toggle-interface-button:active{transform:translateY(0);box-shadow:0 2px 4px #00000026}@media (max-width: 1024px){.interactive-map-view{flex-direction:column}.map-overlay-controls{flex:0 0 auto;max-height:300px}.interactive-map-container{min-height:500px}}@media (max-width: 768px){.map-overlay-controls{padding:1rem}.overlay-item{padding:.75rem}.overlay-icon{font-size:1.25rem;width:28px}.overlay-name{font-size:.875rem}.overlay-desc{font-size:.75rem}}.broadband-data-display{background:#f8f9fa;border-radius:8px;padding:20px;margin:16px 0;border:1px solid #e9ecef}.broadband-header{margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #dee2e6}.broadband-header h3{margin:0 0 8px;color:#495057;font-size:1.25rem;font-weight:600}.region-info{margin:0;color:#6c757d;font-size:.875rem}.scores-section{margin-bottom:24px}.scores-section h4{margin:0 0 12px;color:#495057;font-size:1.1rem;font-weight:600}.scores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.score-item{background:#fff;padding:12px;border-radius:6px;border:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center}.score-label{font-weight:500;color:#495057}.score-value{font-weight:600;color:#28a745;font-size:1.1rem}.providers-section{margin-bottom:24px}.providers-section h4{margin:0 0 16px;color:#495057;font-size:1.1rem;font-weight:600}.providers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.provider-type{background:#fff;padding:16px;border-radius:8px;border:1px solid #dee2e6}.provider-type h5{margin:0 0 12px;color:#495057;font-size:1rem;font-weight:600}.provider-status{font-weight:600;margin:0 0 8px;padding:4px 8px;border-radius:4px;font-size:.875rem}.provider-status.available{background:#d4edda;color:#155724}.provider-status.unavailable{background:#f8d7da;color:#721c24}.provider-speed{margin:0 0 8px;font-weight:500;color:#495057}.provider-list{margin:0;color:#6c757d;font-size:.875rem}.speed-summary{margin-bottom:24px}.speed-summary h4{margin:0 0 16px;color:#495057;font-size:1.1rem;font-weight:600}.speed-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.speed-metric{background:#fff;padding:12px;border-radius:6px;border:1px solid #dee2e6;text-align:center}.metric-label{display:block;font-size:.875rem;color:#6c757d;margin-bottom:4px}.metric-value{display:block;font-size:1.25rem;font-weight:600;color:#495057;margin-bottom:2px}.metric-tier{display:block;font-size:.75rem;color:#28a745;font-weight:500}.detailed-speeds h4{margin:0 0 16px;color:#495057;font-size:1.1rem;font-weight:600}.speed-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.speed-type{background:#fff;padding:12px;border-radius:6px;border:1px solid #dee2e6}.speed-type h5{margin:0 0 8px;color:#495057;font-size:.9rem;font-weight:600}.speed-type p{margin:0 0 4px;color:#6c757d;font-size:.875rem}.loading-state,.error-state,.no-data-state{text-align:center;padding:40px 20px;color:#6c757d}.error-state{color:#dc3545}@media (max-width: 768px){.broadband-data-display{padding:16px;margin:12px 0}.scores-grid,.providers-grid,.speed-metrics,.speed-breakdown{grid-template-columns:1fr}.score-item{flex-direction:column;align-items:flex-start;gap:4px}}.risks-view{padding:24px;max-width:1200px;margin:0 auto}.risks-header{margin-bottom:32px}.risks-header h2{font-size:28px;font-weight:600;color:#1a1a1a;margin:0 0 8px}.risks-subtitle{font-size:16px;color:#666;margin:0 0 24px}.risks-summary{display:flex;gap:24px;flex-wrap:wrap;padding:16px;background:#f8f9fa;border-radius:8px}.risk-summary-item{display:flex;align-items:center;gap:8px}.risk-summary-label{font-weight:500;color:#666}.risk-summary-count{font-weight:600;font-size:18px;padding:4px 12px;border-radius:4px;min-width:32px;text-align:center}.risk-summary-count.critical{background-color:#dc3545;color:#fff}.risk-summary-count.high{background-color:#fd7e14;color:#fff}.risk-summary-count.medium{background-color:#ffc107;color:#1a1a1a}.risk-summary-count.low{background-color:#28a745;color:#fff}.risks-content,.risks-by-severity{display:flex;flex-direction:column;gap:20px}.risk-card{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000001a;border-left:4px solid #ddd;transition:box-shadow .2s ease,transform .2s ease;position:relative}.risk-card:hover{box-shadow:0 4px 8px #00000026}.risk-card-clickable{cursor:pointer!important;-webkit-user-select:none;user-select:none}.risk-card-clickable:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0003}.risk-card-clickable:active{transform:translateY(0);box-shadow:0 2px 4px #00000026}.risk-card-clickable:focus{outline:2px solid #0066cc;outline-offset:2px}.risk-card-clickable .risk-sources{position:relative;z-index:1}.risk-card-clickable .risk-sources a{cursor:pointer;pointer-events:auto;position:relative;z-index:2}.risk-card.risk-severity-critical{border-left-color:#dc3545}.risk-card.risk-severity-high{border-left-color:#fd7e14}.risk-card.risk-severity-medium{border-left-color:#ffc107}.risk-card.risk-severity-low{border-left-color:#28a745}.risk-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.risk-category-badge{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#f0f0f0;border-radius:6px;font-size:14px;font-weight:500;color:#333}.risk-category-badge svg{width:18px;height:18px;color:#666}.risk-category-label{font-size:14px}.risk-severity-badge{padding:6px 14px;border-radius:6px;font-size:13px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.risk-title{font-size:20px;font-weight:600;color:#1a1a1a;margin:0 0 12px}.risk-description{margin-bottom:16px}.risk-description p{font-size:15px;line-height:1.6;color:#444;margin:0}.risk-impact{margin-bottom:12px;padding:12px;background:#fff3cd;border-left:3px solid #ffc107;border-radius:4px}.risk-impact strong{display:block;margin-bottom:4px;color:#856404;font-size:14px}.risk-impact{font-size:14px;line-height:1.6;color:#856404}.risk-mitigation{margin-bottom:12px;padding:12px;background:#d1ecf1;border-left:3px solid #0c5460;border-radius:4px}.risk-mitigation strong{display:block;margin-bottom:4px;color:#0c5460;font-size:14px}.risk-mitigation{font-size:14px;line-height:1.6;color:#0c5460}.risk-sources{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.risk-sources strong{display:block;margin-bottom:8px;font-size:14px;color:#666}.risk-sources ul{margin:0;padding-left:20px;list-style-type:disc}.risk-sources li{margin-bottom:4px;font-size:14px;color:#666}.risk-sources a{color:#06c;text-decoration:none}.risk-sources a:hover{text-decoration:underline}.risks-empty{padding:48px 24px;text-align:center;color:#666}.risks-empty p{margin:8px 0;font-size:15px}@media (max-width: 768px){.risks-view{padding:16px}.risks-header h2{font-size:24px}.risks-summary{flex-direction:column;gap:12px}.risk-card{padding:16px}.risk-card-header{flex-direction:column;align-items:flex-start}.risk-title{font-size:18px}}.site-detail-container{display:flex;flex-direction:column;height:calc(100vh - 64px);min-height:calc(100vh - 64px);background-color:#f8f9fa;overflow:hidden;width:100%;max-width:100vw}.site-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a}.header-content{display:flex;gap:1rem;margin:0}.back-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;text-decoration:none;font-size:.875rem;transition:all .2s ease}.back-button:hover{background:#e9ecef;border-color:#adb5bd}.site-title{font-size:1.5rem;font-weight:600;color:#212529;margin:0}.view-report-button{display:none;padding:.5rem 1rem;background:#0d6efd;border:1px solid #0d6efd;border-radius:6px;color:#fff;font-size:.875rem;cursor:pointer;transition:all .2s ease}.view-report-button:hover:not(:disabled){background:#0b5ed7;border-color:#0b5ed7}.view-report-button:disabled{background:#6c757d;border-color:#6c757d;cursor:not-allowed}.site-detail-tabs{background:#fff;border-bottom:1px solid #e9ecef}.tab-container{display:flex;gap:0}.tab{padding:.75rem 1.5rem;background:none;border:none;color:#6c757d;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.tab.active{color:#0d6efd;border-bottom-color:#0d6efd}.tab:hover{color:#495057}.site-detail-filters{display:flex;gap:2rem;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e9ecef;align-items:center}.learn-more-button{padding:.5rem 1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;font-size:.875rem;cursor:pointer;transition:all .2s ease;margin-left:auto}.learn-more-button:hover{background:#e9ecef;border-color:#adb5bd}.site-detail-content{display:flex;flex:1;width:100%;max-width:100vw;justify-content:center;min-height:0}.site-detail-left-panel{flex:1;padding:1rem;background:#fff;border-right:1px solid #e9ecef;border-radius:8px;margin:15px;max-width:800px;min-height:0;display:flex;flex-direction:column}.map-container{width:100%;flex:1;min-height:400px;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.overall-score-section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.score-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.score-header h4{margin:0;font-size:1.125rem;font-weight:600;color:#212529}.info-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#f8f9fa;border-radius:50%;cursor:help}.score-display{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.score-value{font-size:1.5rem;font-weight:600;color:#212529}.score-label{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff}.score-label.complete{background-color:#28a745}.score-label.med-high{background-color:#8bc34a}.score-label.medium{background-color:#ffc107;color:#212529}.score-label.med-low{background-color:#ff9800}.score-label.low{background-color:#f44336}.score-label.high{background-color:#4caf50}.score-meta{font-size:.875rem;color:#6c757d}.score-meta p{margin:.25rem 0}.score-meta strong{color:#212529}.site-detail-right-panel{padding:1rem;background:#f8f9fa;max-width:800px;flex:1;overflow-y:auto;min-height:0}.site-categories{display:flex;gap:1.5rem}.categories-sidebar{width:200px;flex-shrink:0}.category-details{flex:1;background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.detail-section{width:100%}.detail-header{margin-bottom:2rem}.detail-title{font-size:1.25rem;font-weight:600;color:#212529;margin-bottom:1rem}.detail-description{margin-bottom:1.5rem}.detail-description p{font-size:.875rem;color:#6c757d;line-height:1.5;margin:0}.detail-items{display:flex;flex-direction:column;gap:1.5rem}.detail-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.detail-item-icon{flex-shrink:0;width:24px;height:24px;color:#6c757d}.detail-item-content{flex:1}.detail-item-title{font-size:.875rem;font-weight:600;color:#495057;margin-bottom:.5rem}.detail-item-value{font-size:1rem;color:#212529;font-weight:500}.detail-item-source{font-size:.75rem;color:#6c757d;margin-top:.25rem}@media (max-width: 1024px){.site-detail-container{height:calc(100vh - 64px)}.site-detail-content{flex-direction:column;width:100%;max-width:100vw}.site-detail-left-panel{flex:none;height:400px;border-right:none;border-bottom:1px solid #e9ecef;max-width:none}.site-detail-right-panel{flex:none;width:100%}.site-categories{flex-direction:column}.categories-sidebar{width:100%;display:flex;gap:1rem;overflow-x:auto}.category-item{min-width:200px;margin-bottom:0}.site-detail-header{padding:1rem}.site-title{font-size:1.25rem}.site-detail-filters{padding:1rem}}@media (max-width: 768px){.site-detail-content{flex-direction:column;width:100%;max-width:100vw}.site-detail-left-panel{flex:none;height:300px;border-right:none;border-bottom:1px solid #e9ecef;max-width:none}.site-detail-right-panel{flex:none;width:100%}.site-detail-header{padding:.75rem}.site-title{font-size:1.125rem}.site-detail-filters{padding:.75rem}}@media (max-width: 480px){.site-detail-content{flex-direction:column;width:100%;max-width:100vw}.site-detail-left-panel{flex:none;height:250px;border-right:none;border-bottom:1px solid #e9ecef;max-width:none}.site-detail-right-panel{flex:none;width:100%}}.location-details-section{margin-top:2rem;padding-top:2rem;border-top:1px solid #e9ecef;text-align:center}.location-details-button{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66;margin-bottom:1rem}.location-details-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea99;background:linear-gradient(135deg,#5a6fd8,#6a4190)}.location-details-button:active{transform:translateY(0)}.location-details-button svg{width:20px;height:20px;stroke-width:2.5}.location-details-description{font-size:.875rem;color:#6c757d;line-height:1.5;max-width:500px;margin:0 auto}.backoffice-container{padding:2rem;width:100%}.backoffice-header{text-align:center;margin-bottom:3rem;position:relative}.backoffice-header h1{font-size:2.5rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.backoffice-header p{font-size:1.1rem;color:#666;margin:0}.backoffice-content{width:100%}.backoffice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.backoffice-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000000d;border:1px solid #e5e7eb;transition:all .2s ease-in-out;cursor:pointer}.backoffice-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a;border-color:#d1d5db}.backoffice-card h3{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin-bottom:.75rem}.backoffice-card p{color:#666;margin-bottom:1.5rem;line-height:1.5}.backoffice-button{background:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s ease;width:100%}.backoffice-button:hover{background:#0056b3}.backoffice-button:active{transform:translateY(1px)}@media (max-width: 768px){.backoffice-container{padding:1rem}.backoffice-header{text-align:left}.backoffice-header h1{font-size:2rem}.backoffice-grid{grid-template-columns:1fr;gap:1.5rem}.backoffice-card{padding:1.5rem}}.detail-item{border-radius:8px;overflow:hidden}.item-header{background-color:#f8f9fa;padding:12px 16px;border-bottom:1px solid #e9ecef}.item-header p{font-size:11px;color:#6c757d;margin:2px 0}.item-content{padding:16px;display:flex;justify-content:space-between;align-items:center}.item-title{display:flex;align-items:center;gap:12px}.item-title svg{width:20px;height:20px}.item-title h4{font-size:16px;font-weight:600;color:#2a2b2d;margin:0}.item-value{text-align:right}.item-value p{font-size:14px;color:#495057;margin:0}.file-upload{max-width:800px;margin:0 auto;padding:20px}.upload-area{border:2px dashed #ddd;border-radius:8px;padding:40px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafafa;margin-bottom:20px}.upload-area:hover{border-color:#007bff;background:#f0f8ff}.upload-area.dragging{border-color:#007bff;background:#e3f2fd;transform:scale(1.02)}.upload-area.uploading{border-color:#28a745;background:#f0fff4;cursor:not-allowed}.upload-content{display:flex;flex-direction:column;align-items:center;gap:16px}.upload-icon{color:#666;transition:color .3s ease}.upload-area:hover .upload-icon{color:#007bff}.upload-area.uploading .upload-icon{color:#28a745}.upload-text h3{margin:0 0 8px;color:#333;font-size:18px}.upload-text p{margin:4px 0;color:#666;font-size:14px}.file-types{font-size:12px!important;color:#999!important}.spinner{width:24px;height:24px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.uploaded-file-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;margin-bottom:20px}.uploaded-file-info h4{margin:0 0 16px;color:#333;font-size:16px}.file-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}.file-details p{margin:0;font-size:14px;color:#555}.file-details strong{color:#333}.split-options{border-top:1px solid #e9ecef;padding-top:20px}.split-options h4{margin:0 0 16px;color:#333;font-size:16px}.split-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.split-controls label{display:flex;align-items:center;gap:8px;font-size:14px;color:#555}.split-controls input[type=number]{width:80px;padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.split-btn{background:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s ease}.split-btn:hover:not(:disabled){background:#0056b3}.split-btn:disabled{background:#6c757d;cursor:not-allowed}.split-files{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;margin-bottom:20px}.split-files h4{margin:0 0 16px;color:#333;font-size:16px}.split-files-list{display:flex;flex-direction:column;gap:12px}.split-file-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fff;border:1px solid #e9ecef;border-radius:6px}.split-file-info p{margin:0;font-size:14px}.split-file-info .file-key{font-size:12px;color:#666;font-family:monospace;word-break:break-all}.split-file-actions{display:flex;gap:8px}.download-btn{background:#28a745;color:#fff;text-decoration:none;padding:6px 12px;border-radius:4px;font-size:12px;transition:background-color .3s ease}.download-btn:hover{background:#218838;color:#fff;text-decoration:none}.file-actions{display:flex;justify-content:center;gap:12px}.clear-btn{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s ease}.clear-btn:hover:not(:disabled){background:#c82333}.clear-btn:disabled{background:#6c757d;cursor:not-allowed}@media (max-width: 768px){.file-upload{padding:16px}.upload-area{padding:24px 16px}.file-details{grid-template-columns:1fr}.split-controls{flex-direction:column;align-items:stretch}.split-file-item{flex-direction:column;align-items:stretch;gap:12px}.split-file-actions{justify-content:center}}.file-upload-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.page-header{text-align:center;margin-bottom:40px;padding:40px 20px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.page-header h1{margin:0 0 16px;color:#333;font-size:2.5rem;font-weight:600}.page-header p{color:#666;font-size:1.1rem;max-width:600px;margin:0 auto}.upload-section{margin-bottom:60px}.info-section{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 6px #0000001a}.info-section h2{text-align:center;margin:0 0 40px;color:#333;font-size:2rem;font-weight:600}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.info-card{text-align:center;padding:30px 20px;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef;transition:transform .3s ease,box-shadow .3s ease}.info-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.info-icon{font-size:3rem;margin-bottom:20px}.info-card h3{margin:0 0 16px;color:#333;font-size:1.5rem;font-weight:600}.info-card p{margin:0;color:#666;line-height:1.6;font-size:1rem}.toast{position:fixed;top:20px;right:20px;z-index:1000;min-width:300px;max-width:500px;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out}.toast-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.toast-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.toast-info{background:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.toast-content{display:flex;align-items:center;gap:12px}.toast-icon{font-size:1.2rem;flex-shrink:0}.toast-message{flex:1;font-weight:500}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.file-upload-page{padding:16px}.page-header{padding:30px 16px}.page-header h1{font-size:2rem}.page-header p{font-size:1rem}.info-section{padding:30px 20px}.info-section h2{font-size:1.5rem}.info-grid{grid-template-columns:1fr;gap:20px}.info-card{padding:20px 16px}.toast{top:10px;right:10px;left:10px;min-width:auto}}.evaluation-map{width:100%;height:100%;position:relative;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #00000026}.evaluation-map-container{width:100%;height:100%;border-radius:12px;overflow:hidden}.evaluation-map .leaflet-container{width:100%;height:100%;border-radius:12px;background:#f8fafc}.evaluation-center-marker{background:none;border:none}.evaluation-center-marker .marker-pin{width:24px;height:24px;background:#3b82f6;border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #0000004d;position:relative;animation:pulse-marker 2s ease-in-out infinite}.evaluation-center-marker .marker-pin:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#fff;border-radius:50%}@keyframes pulse-marker{0%,to{transform:scale(1);box-shadow:0 2px 8px #3b82f666}50%{transform:scale(1.15);box-shadow:0 4px 16px #3b82f699}}.connectivity-marker .pulse-dot{width:16px;height:16px;background:#8b5cf6;border:2px solid white;border-radius:50%;box-shadow:0 2px 6px #8b5cf666;animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}.broadband-marker .wifi-icon{font-size:20px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));animation:bounce-icon 2s ease-in-out infinite}@keyframes bounce-icon{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.water-marker .water-icon{font-size:20px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));animation:water-drip 2s ease-in-out infinite}@keyframes water-drip{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}@media (max-width: 768px){.evaluation-map{height:300px;border-radius:8px}.evaluation-map-container{border-radius:8px}.evaluation-center-marker .marker-pin{width:20px;height:20px}}.site-evaluation-calculation{width:100%;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.evaluation-header-section{text-align:center;margin-bottom:3rem}.evaluation-header-section h1{font-size:2.5rem;color:#1e293b;margin-bottom:.5rem;font-weight:700}.evaluation-header-section p{font-size:1.1rem;color:#64748b}.input-section{max-width:800px;margin:0 auto}.location-input-container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 6px #0000001a,0 10px 15px #0000001a}.search-container{margin-bottom:2rem;width:100%}.none-max-width{max-width:none}.search-input-wrapper{position:relative;width:100%}.location-search-input{width:100%;padding:1rem 1.5rem;font-size:1rem;border:2px solid #e2e8f0;border-radius:8px;transition:all .3s ease}.location-search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-spinner{position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.spinner{width:20px;height:20px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-results{margin-top:.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;max-height:300px;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.search-result-item{padding:1rem 1.5rem;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.search-result-item:hover{background-color:#f8fafc}.search-result-item:last-child{border-bottom:none}.search-result-item.no-results{color:#94a3b8;cursor:default}.selected-location{background:#f8fafc;border:2px solid #3b82f6;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.selected-location h3{margin:0 0 .5rem;color:#1e293b;font-size:1.1rem}.selected-location p{margin:.25rem 0;color:#475569}.selected-location .coordinates{font-size:.9rem;color:#64748b;font-family:monospace}.start-calculation-btn{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #667eea66}.start-calculation-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea99}.start-calculation-btn:disabled{opacity:.5;cursor:not-allowed}.calculation-animation-section{max-width:1400px;margin:0 auto}.evaluation-content-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.evaluation-map-section{position:sticky;top:2rem;height:calc(100vh - 8rem);min-height:600px;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 10px 15px #0000001a}.progress-container{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a}.progress-bar{width:100%;height:12px;background:#e2e8f0;border-radius:6px;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:6px;transition:width .1s ease;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{text-align:center;font-size:1.2rem;font-weight:600;color:#1e293b}.current-step-container{background:#fff;border-radius:16px;padding:3rem;box-shadow:0 4px 6px #0000001a,0 10px 15px #0000001a}.step-card{display:flex;align-items:center;gap:2rem;opacity:0;transform:translateY(20px);animation:fadeInUp .5s ease forwards}.step-card.active{opacity:1;transform:translateY(0)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-icon-wrapper{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0}.step-icon{position:relative;z-index:2}.step-pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);opacity:.6;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:.3}}.step-content{flex:1}.step-content h2{font-size:1.8rem;color:#1e293b;margin:0 0 .5rem}.step-content p{font-size:1.1rem;color:#64748b;margin:0 0 1rem}.step-progress{margin-top:1rem}.step-progress-bar{width:100%;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.step-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;transition:width .3s ease}.sub-steps-container{margin:1.5rem 0;padding:1rem;background:#f8fafc;border-radius:8px;max-height:400px;overflow-y:auto}.sub-step-item{display:flex;align-items:center;gap:1rem;padding:.75rem;margin-bottom:.5rem;border-radius:6px;transition:all .3s ease;opacity:.6;transform:translate(-10px)}.sub-step-item.upcoming{opacity:.4}.sub-step-item.active{opacity:1;transform:translate(0);background:#fff;box-shadow:0 2px 4px #667eea33;animation:slideIn .3s ease}.sub-step-item.completed{opacity:1;transform:translate(0);background:#f0fdf4;border-left:3px solid #10b981;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.sub-step-indicator{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sub-step-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1;transition:all .3s ease}.sub-step-item.active .sub-step-dot{background:#667eea;transform:scale(1.5)}.sub-step-spinner{width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.sub-step-item.completed .sub-step-indicator{color:#10b981}.sub-step-content{flex:1;display:flex;justify-content:space-between;align-items:center;gap:1rem}.sub-step-label{font-size:.95rem;color:#475569;font-weight:500}.sub-step-item.active .sub-step-label{color:#1e293b;font-weight:600}.sub-step-item.completed .sub-step-label{color:#059669}.sub-step-value{display:flex;align-items:baseline;gap:.25rem;font-weight:600}.sub-step-value-number{font-size:1.1rem;color:#667eea;animation:countUp .5s ease}.sub-step-item.completed .sub-step-value-number{color:#10b981}.sub-step-unit{font-size:.85rem;color:#64748b;font-weight:500}.sub-step-item.completed .sub-step-unit{color:#059669}@keyframes countUp{0%{opacity:0;transform:translateY(-5px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}.step-indicators{display:flex;justify-content:center;gap:1rem;margin-top:2rem;flex-wrap:wrap}.step-indicator{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#e2e8f0;color:#94a3b8;transition:all .3s ease;cursor:default}.step-indicator svg{width:24px;height:24px}.step-indicator.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:scale(1.2);box-shadow:0 4px 12px #667eea66}.step-indicator.completed{background:#10b981;color:#fff}@media (max-width: 1024px){.evaluation-content-layout{grid-template-columns:1fr;gap:1.5rem}.evaluation-map-section{position:relative;top:0;height:400px;min-height:400px;order:-1}}@media (max-width: 768px){.site-evaluation-calculation{padding:1rem}.evaluation-header-section h1{font-size:2rem}.location-input-container{padding:1.5rem}.evaluation-map-section{height:300px;min-height:300px}.current-step-container{padding:2rem 1.5rem}.step-card{flex-direction:column;text-align:center}.step-content h2{font-size:1.5rem}.sub-steps-container{margin:1rem 0;padding:.75rem;max-height:300px}.sub-step-item{padding:.5rem;gap:.75rem}.sub-step-content{flex-direction:column;align-items:flex-start;gap:.25rem}.sub-step-label{font-size:.85rem}.sub-step-value{align-self:flex-end}.sub-step-value-number{font-size:1rem}.step-indicators{gap:.5rem}.step-indicator{width:40px;height:40px}.step-indicator svg{width:20px;height:20px}}.evaluation-complete-section{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:2rem}.evaluation-complete-content{text-align:center;background:#fff;border-radius:16px;padding:3rem;box-shadow:0 4px 6px #0000001a,0 10px 15px #0000001a;max-width:500px}.completion-icon{margin:0 auto 1.5rem;color:#10b981;display:flex;align-items:center;justify-content:center}.evaluation-complete-content h2{font-size:2rem;color:#1e293b;margin-bottom:1rem;font-weight:700}.evaluation-complete-content p{font-size:1.1rem;color:#64748b;margin-bottom:1.5rem}.saving-spinner{display:flex;justify-content:center;margin-top:1rem}.password-protection{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;z-index:9999}.password-container{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 20px 40px #0000001a;text-align:center;max-width:400px;width:90%;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.logo-container{margin-bottom:2rem}.logo{height:60px;width:auto;margin:0 auto}.password-container h1{color:#333;margin-bottom:.5rem;font-size:1.8rem;font-weight:600}.password-container p{color:#666;margin-bottom:2rem;font-size:1rem;line-height:1.5}.password-form{display:flex;flex-direction:column;gap:1rem}.input-group{position:relative}.password-input{width:100%;padding:1rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:border-color .3s ease;box-sizing:border-box}.password-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-input::placeholder{color:#999}.error-message{color:#e74c3c;font-size:.9rem;margin-top:.5rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.submit-button:active:not(:disabled){transform:translateY(0)}@media (max-width: 480px){.password-container{padding:2rem;margin:1rem}.password-container h1{font-size:1.5rem}.logo{height:50px}}
