*{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}.location-coords{font-size:11px;color:#666;margin-bottom:12px}.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}.layer-help-btn{font-size:10px;color:#4b5563;background:#f3f4f6;cursor:pointer;padding:3px 6px;border-radius:4px;flex-shrink:0;border:none;font-weight:600;transition:background .2s;white-space:nowrap}.layer-help-btn:hover{background:#e5e7eb;color:#1f2937}.layer-help-btn:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.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}.sightings-section{padding:12px 16px;border-bottom:1px solid #e0e0e0}.sightings-toggle{padding:12px;background:#f0fdf4;border:2px solid #22c55e;border-radius:8px;cursor:pointer;transition:all .2s}.sightings-toggle:hover{background:#dcfce7}.sightings-toggle.inactive{background:#f5f5f5;border-color:#ccc;opacity:.7}.sightings-toggle.inactive .layer-checkbox-visual{background:#fff;border-color:#999}.sightings-toggle.inactive .layer-checkbox-visual:after{content:""}.sightings-toggle-header{display:flex;align-items:center;gap:10px}.sightings-toggle .layer-checkbox-visual{background:#22c55e;border-color:#22c55e}.sightings-toggle .layer-checkbox-visual:after{content:"✓";color:#fff;font-size:16px;font-weight:700}.sightings-toggle-info{flex:1}.sightings-toggle-name{font-size:14px;font-weight:600;color:#166534;display:block}.sightings-toggle.inactive .sightings-toggle-name{color:#666}.sightings-count{font-size:11px;color:#15803d}.sightings-toggle.inactive .sightings-count{color:#888}.sightings-legend{display:flex;gap:16px;margin-top:8px;padding-left:34px}.sighting-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#666}.sighting-dot{width:10px;height:10px;border-radius:50%}.sighting-dot.existing{background:#22c55e}.sighting-dot.potential{background:transparent;border:2px solid #f97316}.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}.intervention-card{background:#f8f9fa;border-radius:8px;padding:12px;margin-bottom:10px;border-left:4px solid #f59e0b}.intervention-title{font-weight:600;margin-bottom:4px;color:#333}.intervention-desc{font-size:13px;color:#666;margin-bottom:6px}.intervention-meta{display:flex;gap:8px;font-size:11px}.effort-badge,.impact-badge{padding:2px 6px;border-radius:4px;font-weight:500}.effort-low{background:#d1fae5;color:#065f46}.effort-medium{background:#fef3c7;color:#92400e}.effort-high{background:#fee2e2;color:#991b1b}.effort-very_high{background:#fecaca;color:#7f1d1d}.effort-planning{background:#e0e7ff;color:#3730a3}.impact-low{background:#e5e7eb;color:#374151}.impact-medium{background:#dbeafe;color:#1e40af}.impact-high{background:#d1fae5;color:#065f46}.impact-very_high{background:#a7f3d0;color:#047857}.impact-maintenance{background:#f3f4f6;color:#6b7280}.impact-safety{background:#fef3c7;color:#92400e}.impact-community{background:#ede9fe;color:#5b21b6}.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}}.explorer-auth{display:flex;align-items:center}.explorer-auth .auth-button{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:16px;border:none;background:#fff3;color:#fff;cursor:pointer;font-size:13px;transition:background .2s}.explorer-auth .auth-button:hover{background:#ffffff4d}.contribution-fab{position:fixed;bottom:80px;right:380px;z-index:1001;width:56px;height:56px;border-radius:28px;border:none;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #22c55e66;transition:transform .2s,box-shadow .2s}.contribution-fab:hover{transform:scale(1.1);box-shadow:0 6px 16px #22c55e80}.contribution-fab:disabled{background:#9ca3af;cursor:not-allowed;box-shadow:none}.contribution-fab:disabled:hover{transform:none}@media(max-width:768px){.contribution-fab{right:20px;bottom:calc(50vh + 20px)}}.contribution-modal{position:fixed;inset:0;background:#00000080;display:none;align-items:center;justify-content:center;z-index:10000;padding:20px}.contribution-modal-content{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:100%;max-height:85vh;overflow-y:auto}.contribution-modal h2{margin:0 0 8px;font-size:20px;display:flex;align-items:center;gap:8px}.contribution-modal .location-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:#666;background:#f3f4f6;padding:4px 8px;border-radius:4px;margin-bottom:16px}.contribution-type-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.contribution-type-btn{padding:16px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;text-align:center;transition:all .2s}.contribution-type-btn:hover{border-color:#22c55e;background:#f0fdf4}.contribution-type-btn.selected{border-color:#22c55e;background:#dcfce7}.contribution-type-btn .icon{font-size:24px;margin-bottom:8px}.contribution-type-btn .label{font-weight:600;font-size:14px}.contribution-type-btn .desc{font-size:11px;color:#666;margin-top:4px}.concern-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px;padding:12px;background:#f8fafc;border-radius:8px}.concern-item{display:flex;align-items:center;gap:6px;font-size:12px}.concern-dot{width:8px;height:8px;border-radius:50%}.intervention-section{margin-bottom:16px}.intervention-section-title{font-size:12px;font-weight:600;color:#666;margin-bottom:8px;text-transform:uppercase}.intervention-list{max-height:200px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:8px}.intervention-option{padding:12px;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background .2s}.intervention-option:last-child{border-bottom:none}.intervention-option:hover{background:#f8fafc}.intervention-option.selected{background:#dcfce7}.intervention-option.recommended{border-left:3px solid #22c55e}.intervention-option-title{font-weight:600;font-size:14px;margin-bottom:2px}.intervention-option-meta{font-size:11px;color:#666}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:#333;margin-bottom:6px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.form-group textarea{resize:vertical;min-height:80px}.photo-upload-zone{border:2px dashed #d1d5db;border-radius:8px;padding:24px;text-align:center;cursor:pointer;transition:all .2s}.photo-upload-zone:hover{border-color:#22c55e;background:#f0fdf4}.photo-upload-zone.has-photo{border-style:solid;border-color:#22c55e}.photo-preview{max-width:100%;max-height:200px;border-radius:6px}.submit-btn{width:100%;padding:12px;border:none;border-radius:6px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.submit-btn:hover{transform:translateY(-1px)}.submit-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.cancel-btn{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#666;font-size:14px;cursor:pointer;margin-top:8px}.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}.edit-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}.edit-modal-overlay.active{opacity:1;visibility:visible}.edit-modal{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.edit-modal-header{padding:16px 20px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.edit-modal-header h3{margin:0;font-size:18px;color:#111}.edit-modal-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px}.edit-modal-body{padding:20px}.edit-modal-images{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.edit-modal-image{position:relative;width:80px;height:80px}.edit-modal-image img{width:100%;height:100%;object-fit:cover;border-radius:8px}.edit-modal-image .delete-image-btn{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:#ef4444;color:#fff;border:2px solid white;font-size:14px;line-height:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.add-image-btn{width:80px;height:80px;border:2px dashed #ccc;border-radius:8px;background:#f9fafb;color:#666;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center}.add-image-btn:hover{border-color:#10b981;color:#10b981}.edit-modal-field{margin-bottom:16px}.edit-modal-field label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.edit-modal-field textarea,.edit-modal-field select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit}.edit-modal-field textarea{resize:vertical;min-height:80px}.edit-modal-footer{padding:16px 20px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:space-between}.edit-modal-footer .delete-btn{background:#fee2e2;color:#dc2626;border:none;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.edit-modal-footer .delete-btn:hover{background:#fecaca}.edit-modal-footer .save-btn{background:#10b981;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;margin-left:auto}.edit-modal-footer .save-btn:hover{background:#059669}.popup-image-gallery{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}.popup-image-gallery img{width:60px;height:60px;object-fit:cover;border-radius:4px;cursor:pointer}#intervention-details{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px;margin-bottom:16px}#selected-intervention-title{font-weight:600;margin-bottom:4px}#selected-intervention-desc{font-size:13px;color:#64748b;margin-bottom:8px}#selected-intervention-meta{display:flex;gap:8px;margin-bottom:12px}#site-requirements{background:#fffbeb;border-radius:6px;padding:10px;margin-top:8px}#site-requirements strong{display:block;font-size:11px;color:#92400e;text-transform:uppercase;margin-bottom:4px}#site-requirements-text{font-size:12px;color:#78350f;line-height:1.4}.sightings-info-icon{font-size:14px;color:#15803d;cursor:pointer;padding:2px 4px}.sightings-info-icon:hover{color:#166534}
