*{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:16px}.layers-title{font-size:14px;font-weight:600;color:#666;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.layer-item{margin-bottom:10px;padding:14px;background:#f5f5f5;border:3px solid #ccc;border-radius:8px;cursor:pointer;transition:all .2s;position:relative;opacity:.6;min-height:85px}.layer-item:hover{border-color:#718096;background:#f7fafc;opacity:.85}.layer-item.active{border-color:#4a5568;background:#fff;box-shadow:0 3px 12px #4a556840;opacity:1}.layer-item-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.layer-checkbox-visual{width:24px;height:24px;border:3px solid #999;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}.layer-item.active .layer-checkbox-visual{background:#4a5568;border-color:#4a5568}.layer-item.active .layer-checkbox-visual:after{content:"✓";color:#fff;font-size:16px;font-weight:700}.layer-name{flex:1;font-size:14px;font-weight:600;color:#333}.layer-date{display:block;font-size:11px;color:#888;font-weight:400;margin-top:3px}.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{font-size:12px;color:#666;padding-left:30px;min-height:28px;opacity:0;pointer-events:none}.layer-item.has-data .layer-value{opacity:1;pointer-events:auto}.layer-value-row{display:flex;justify-content:space-between;align-items:baseline;margin-top:4px}.layer-value-amount{font-size:16px;font-weight:700;color:#333}.layer-value-unit{font-size:11px;color:#999;margin-left:4px}.layer-concern-badge{font-size:10px;padding:2px 6px;background:#28a745;color:#fff;border-radius:3px;font-weight:600}.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}.gps-button{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}.gps-button:hover{background:#ffffff4d}.gps-button.loading{animation:pulse 1s infinite}@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}
