*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;overflow:hidden}#map{position:absolute;top:0;left:0;width:100%;height:100%}#sidebar{position:fixed;top:0;right:0;width:360px;height:100vh;background:#fff;box-shadow:-2px 0 12px #00000026;z-index:1000;display:flex;flex-direction:column;overflow:hidden}@media(max-width:768px){#sidebar{inset:auto 0 0;width:100%;height:50vh;box-shadow:0 -2px 12px #00000026}}.sidebar-header{padding:20px;background:linear-gradient(135deg,#4a5568,#2d3748);color:#fff;flex-shrink:0}.sidebar-header h1{font-size:20px;margin:0 0 8px;font-weight:700}.sidebar-header p{font-size:12px;margin:0;opacity:.9}.sidebar-content{flex:1;overflow-y:auto;overflow-x:hidden}.location-info{padding:16px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.location-info.empty{display:none}.map-legend{margin-bottom:12px}.legend-bar{height:12px;border-radius:6px;background:linear-gradient(to right,#4caf50,#ffeb3b,#dc3545);margin-bottom:4px}.legend-labels{display:flex;justify-content:space-between;font-size:11px;color:#666;font-weight:500}.location-data{display:grid;gap:8px}.layers-section{padding:12px}.layers-title{font-size:14px;font-weight:600;color:#666;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.layer-item{margin-bottom:6px;padding:10px 12px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;transition:all .2s;position:relative;cursor:pointer}.layer-item:hover{border-color:#a5b4fc;background:#fafbff}.layer-item.active{border-color:#6366f1;background:#fafbff;box-shadow:0 0 0 3px #6366f11a}.layer-item-header{display:flex;align-items:center;gap:8px}.layer-name{flex:1;font-size:13px;font-weight:600;color:#333;line-height:1.3}.layer-reading{display:flex;align-items:baseline;gap:2px;margin-right:4px}.layer-reading .layer-value-amount{font-size:14px;font-weight:700;color:#333}.layer-reading .layer-value-unit{font-size:11px;color:#666}.layer-date{display:inline;margin-left:6px}.layer-date-badge{display:inline-block;background:#e8f4fd;color:#1a73e8;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}.layer-info-icon{font-size:16px;color:#007bff;cursor:pointer;padding:4px;flex-shrink:0}.layer-info-icon:hover{color:#0056b3}.explore-guide{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:8px;padding:12px;margin-bottom:12px}.explore-guide p{margin:0 0 6px;font-size:13px;color:#1e3a5f;line-height:1.4}.explore-guide p:last-child{margin-bottom:0}.explore-guide em{background:#f3f4f6;padding:1px 4px;border-radius:3px;font-style:normal;font-size:11px}.explore-guide.hidden{display:none}.freshness-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.freshness-current{background:#d1fae5;color:#065f46}.freshness-recent{background:#fef3c7;color:#92400e}.freshness-older{background:#fee2e2;color:#991b1b}.layer-value-unit{font-size:11px;color:#999;margin-left:4px}.layer-concern-badge{font-size:10px;padding:3px 8px;background:#999;color:#fff;border-radius:4px;font-weight:600;flex-shrink:0;min-width:50px;text-align:center}.loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:20px 40px;border-radius:8px;box-shadow:0 2px 12px #0003;z-index:2000}.sidebar-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sidebar-header-actions{display:flex;gap:8px;align-items:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.maplibregl-popup-close-button{font-size:24px;width:32px;height:32px;line-height:28px;padding:0;right:4px;top:4px;color:#666;background:#f3f4f6;border-radius:50%;border:none;cursor:pointer}.maplibregl-popup-close-button:hover{background:#e5e7eb;color:#333}.maplibregl-popup-content{padding:36px 16px 16px;border-radius:8px}.header-btn{width:32px;height:32px;border-radius:50%;border:none;background:#fff3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.header-btn:hover{background:#ffffff4d}.header-btn.loading{animation:pulse 1s infinite}.search-panel{background:#fffffff2;backdrop-filter:blur(5px);padding:12px;border-radius:8px;margin:0 12px 12px;box-shadow:0 2px 8px #0000001a;transition:opacity .2s,transform .2s}.search-panel.hidden{display:none}.search-input-row{display:flex;align-items:center;gap:8px}.search-input-row input{flex:1;padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;outline:none}.search-input-row input:focus{border-color:#4a5568;box-shadow:0 0 0 2px #4a55681a}.search-close-btn{width:32px;height:32px;border:none;background:#f0f0f0;border-radius:6px;font-size:20px;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center}.search-close-btn:hover{background:#e0e0e0;color:#333}.search-results{max-height:250px;overflow-y:auto;display:none;margin-top:8px}.search-results.visible{display:block}.search-result-item{padding:10px;cursor:pointer;border-bottom:1px solid #f0f0f0;border-radius:4px;transition:background-color .15s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover,.search-result-item.active{background-color:#f5f5f5}.search-result-item .result-name{font-weight:500;color:#333;display:block;font-size:13px}.search-result-item .result-details{font-size:11px;color:#666;margin-top:2px;display:block}.search-loading,.search-no-results{padding:12px;text-align:center;color:#666;font-size:13px}.threshold-slider-section{margin-top:12px;padding:10px 12px;background:#f0f4f8;border-radius:6px;border:1px solid #d0d8e0}.slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px}.slider-header span:first-child{font-weight:600;color:#4a5568}#threshold-label{color:#dc3545;font-weight:600}.threshold-slider{width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,#dc3545,#ffc107,#28a745);outline:none;-webkit-appearance:none;cursor:pointer}.threshold-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #4a5568;cursor:pointer;box-shadow:0 2px 4px #0003}.threshold-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #4a5568;cursor:pointer;box-shadow:0 2px 4px #0003}.slider-hints{display:flex;justify-content:space-between;margin-top:4px;font-size:10px;color:#718096}.pro-badge{display:inline-block;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;margin-left:8px;vertical-align:middle;text-transform:uppercase;letter-spacing:.5px}#clerk-auth,#clerk-auth .auth-buttons{display:flex;align-items:center}#clerk-auth .sign-in-button{padding:6px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.3);background:#ffffff26;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}#clerk-auth .sign-in-button:hover{background:#ffffff40}.layer-radio-hidden{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.layer-value{margin-top:8px;padding-top:8px;border-top:1px solid #eee}.layer-value-bar{position:relative;width:100%;height:12px;background:linear-gradient(to right,#22c55e,#f59e0b,#ef6868 66%,#ef4444);border-radius:6px;overflow:visible}.layer-value-marker{position:absolute;bottom:100%;width:12px;height:16px;background:#6366f1;border-radius:50% 50% 50% 0;transform:translate(-50%) rotate(-45deg);transform-origin:center center;transition:left .3s ease;z-index:2;box-shadow:0 1px 3px #0000004d;margin-bottom:-2px}.layer-value-marker:after{content:"";position:absolute;top:3px;left:3px;width:6px;height:6px;background:#fff6;border-radius:50%}.layer-value-bar.no-data{background:#e5e7eb}.layer-value-bar.no-data .layer-value-marker{display:none}.layer-concern-badge.low{background:#22c55e;color:#fff}.layer-concern-badge.medium{background:#f59e0b;color:#fff}.layer-concern-badge.high{background:#ef4444;color:#fff}.layers-header-fixed{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.layers-header-fixed>span{font-size:12px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px}.contrast-row{display:flex;align-items:flex-start;gap:12px;padding:10px 16px 14px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.contrast-row .contrast-label{font-size:11px;color:#666;white-space:nowrap;padding-top:4px}.view-mode-row{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.view-mode-label{font-size:12px;font-weight:600;color:#555}.view-mode-toggle{display:flex;background:#e0e0e0;border-radius:6px;padding:2px}.mode-btn{padding:6px 14px;font-size:12px;font-weight:600;background:transparent;border:none;border-radius:4px;cursor:pointer;color:#666;transition:all .2s ease}.mode-btn:hover:not(.active){color:#333;background:#ffffff80}.mode-btn.active{background:#fff;color:#333;box-shadow:0 1px 3px #00000026}#hotspot-mode-btn.active{background:#ef4444;color:#fff;box-shadow:0 1px 3px #ef444466}.redglass-layer{border-top:1px solid #e5e7eb;margin-top:8px;padding-top:8px}.redglass-layer .layer-item-header{background:linear-gradient(135deg,#ef44441a,#ef44440d)}.redglass-layer.active .layer-item-header{background:linear-gradient(135deg,#ef444433,#ef44441a)}.redglass-title{display:flex;align-items:center;gap:6px}.redglass-icon{color:#ef4444;font-size:14px}.redglass-subtitle{font-size:11px!important;color:#888!important;font-weight:400!important}.redglass-layer.disabled{opacity:.4;cursor:not-allowed}.redglass-layer.disabled .layer-item-header{pointer-events:none}.redglass-layer.disabled .layer-info-icon{pointer-events:auto;opacity:1}.contrast-slider-wrapper{flex:1;display:flex;flex-direction:column;gap:4px}.contrast-slider-wrapper input[type=range]{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:#d1d5db;border-radius:3px;cursor:pointer}.contrast-slider-wrapper input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#6366f1;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0000004d}.contrast-slider-wrapper input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#6366f1;border-radius:50%;cursor:pointer;border:none;box-shadow:0 1px 3px #0000004d}.contrast-labels{display:flex;justify-content:space-between;padding:0 2px}.contrast-labels span{font-size:10px;color:#888;font-weight:500}.contrast-info-icon{font-size:16px;color:#007bff;cursor:pointer;padding:4px;flex-shrink:0;margin-left:4px}.contrast-info-icon:hover{color:#0056b3}.toggle-all-btn{padding:4px 10px;border:1px solid #ddd;background:#fff;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s}.toggle-all-btn:hover{background:#f5f5f5;border-color:#ccc}.threshold-label{position:absolute;top:50%;transform:translate(-50%,-50%);font-size:8px;font-weight:600;color:#fff;text-shadow:0 0 2px rgba(0,0,0,.5);pointer-events:none;z-index:1}.legend-bar-container{margin-bottom:8px}.legend-bar{height:12px;border-radius:6px;background:linear-gradient(to right,#22c55e,#f59e0b,#ef4444);margin-bottom:4px}.legend-labels{display:flex;justify-content:space-between;font-size:11px;color:#666}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:24px;max-width:480px;max-height:85vh;overflow-y:auto}.modal-content h2{margin:0 0 12px;font-size:20px;color:#333}.modal-content p{margin:0 0 16px;font-size:14px;color:#555;line-height:1.6}.info-box{background:#f0f9ff;border-left:4px solid #3b82f6;padding:12px;border-radius:0 8px 8px 0;margin-bottom:16px}.info-box strong{display:block;font-size:12px;color:#1e40af;text-transform:uppercase;margin-bottom:6px}.info-box p{margin:0;font-size:13px;color:#334155}.layer-info-modal{max-width:520px}.layer-info-modal .layer-description{font-size:15px;color:#444;margin-bottom:20px}.layer-info-modal .info-box{background:#f8fafc;border-left-color:#64748b}.layer-info-modal .info-box strong{color:#334155}.threshold-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.threshold-item{text-align:center;padding:12px 8px;border-radius:8px}.threshold-item.low{background:#dcfce7}.threshold-item.medium{background:#fef3c7}.threshold-item.high{background:#fee2e2}.threshold-item .level{display:block;font-weight:600;font-size:12px;margin-bottom:4px}.threshold-item .range{display:block;font-size:11px;color:#555}.threshold-item .context{display:block;font-size:10px;color:#666;margin-top:6px;line-height:1.3;font-style:italic}.data-source{font-size:11px;color:#888;margin-bottom:16px}.modal-close{width:100%;padding:12px;background:#4a5568;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.modal-close:hover{background:#2d3748}.outside-bristol{background:#f0f4f8;border-radius:8px;padding:16px;text-align:center}.outside-bristol p{margin:0;color:#555;font-size:14px}.outside-bristol .hint{font-size:12px;color:#888;margin-top:6px}.outside-bristol.warning{background:#fef3c7}.outside-bristol.warning p{color:#92400e}.app-hidden{display:none!important}.auth-gate{position:fixed;inset:0;background:linear-gradient(135deg,#1e1b4b,#312e81,#4338ca);display:flex;align-items:center;justify-content:center;z-index:10000}.auth-gate-content{text-align:center;color:#fff;max-width:420px;padding:40px}.auth-logo h1{font-size:36px;font-weight:700;margin:0 0 8px}.auth-logo .pro-badge{font-size:14px;padding:4px 12px}.auth-tagline{font-size:16px;opacity:.9;margin:0 0 32px;line-height:1.5}.auth-features{background:#ffffff1a;border-radius:12px;padding:20px;margin-bottom:32px;text-align:left}.auth-feature{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:14px}.auth-feature:not(:last-child){border-bottom:1px solid rgba(255,255,255,.1)}.feature-icon{font-size:20px;width:32px;text-align:center}.auth-sign-in-button{width:100%;padding:16px 32px;font-size:16px;font-weight:600;background:#fff;color:#4338ca;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.auth-sign-in-button:hover{background:#f0f0ff;transform:translateY(-2px);box-shadow:0 4px 20px #0000004d}.auth-buttons-group{display:flex;flex-direction:column;gap:12px;width:100%}.auth-subscribe-button{width:100%;padding:16px 32px;font-size:16px;font-weight:600;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.auth-subscribe-button:hover{transform:translateY(-2px);box-shadow:0 4px 20px #10b98166}.auth-back-button{padding:10px 20px;font-size:14px;font-weight:500;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;transition:all .2s;margin-top:16px}.auth-back-button:hover{background:#ffffff4d}.pricing-container{background:#fff;border-radius:12px;padding:24px;max-width:800px;max-height:60vh;overflow-y:auto}.cl-rootBox,.cl-modalBackdrop,.cl-modal,.cl-drawer,.cl-drawerBackdrop,.cl-checkout,.cl-checkoutDrawer,[data-clerk-portal],[data-clerk-drawer],[data-clerk-checkout],div[class*=cl-drawer],div[class*=cl-checkout],div[class*=cl-overlay]{z-index:99999!important}body>div[style*="position: fixed"]{z-index:99998!important}.auth-signed-in-actions{margin-top:16px;display:flex;justify-content:center}.auth-hint{margin-top:24px;font-size:13px;opacity:.7}.auth-hint a{color:#fff;text-decoration:underline}.auth-hint a:hover{opacity:1}#header-auth,#header-auth .auth-buttons{display:flex;align-items:center}.legend-section{padding:12px;border-top:1px solid #e0e0e0;background:#fafafa}.legend-title{font-size:12px;font-weight:600;color:#555;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.legend-items{display:flex;flex-direction:column;gap:6px}.legend-item{display:flex;align-items:center;gap:10px;font-size:12px;color:#555}.legend-color{width:18px;height:18px;border-radius:3px;flex-shrink:0}.legend-divider{height:1px;background:#e0e0e0;margin:10px 0}
