*{padding:0;box-sizing:border-box}*,body{margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:320px;min-height:100vh}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.header{background:linear-gradient(135deg,#2d5016,#4a7c2f);color:white;padding:1rem 2rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.header-content h1{font-size:1.8rem;font-weight:700;margin-bottom:.25rem}.header-content p{font-size:.9rem;opacity:.9}.search-container{background:white;padding:1rem 2rem;border-bottom:1px solid #dee2e6;box-shadow:0 2px 4px rgba(0,0,0,.05)}.search-form{display:flex;gap:.75rem;max-width:600px;margin:0 auto}.search-input-wrapper{flex:1 1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#6b7280;pointer-events:none}.search-input{width:100%;padding:10px 40px;font-size:15px;border:2px solid #e5e7eb;border-radius:8px;transition:all .2s ease}.search-input:focus{outline:none;border-color:#4a7c2f;box-shadow:0 0 0 3px rgba(74,124,47,.1)}.search-input:disabled{background:#f9fafb;cursor:not-allowed}.search-clear{position:absolute;right:12px;background:none;border:none;color:#9ca3af;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.search-clear:hover{background:#f3f4f6;color:#374151}.search-button{padding:10px 24px;background:#4a7c2f;color:white;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.search-button:hover:not(:disabled){background:#3a6024;transform:translateY(-1px);box-shadow:0 2px 8px rgba(74,124,47,.3)}.search-button:disabled{background:#d1d5db;cursor:not-allowed;transform:none}.search-error{margin-top:.5rem;padding:8px 12px;background:#fef2f2;color:#991b1b;border-radius:6px;font-size:14px;text-align:center;max-width:600px;margin-left:auto;margin-right:auto}@media (max-width:768px){.search-container{padding:.75rem 1rem}.search-form{flex-direction:column;gap:.5rem}.search-button{width:100%}}.filters{display:flex;gap:.5rem;padding:1rem 2rem;background:#f8f9fa;border-bottom:1px solid #dee2e6;overflow-x:auto;flex-wrap:wrap}.filters button{padding:.5rem 1rem;border:2px solid #4a7c2f;background:white;color:#4a7c2f;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;font-size:.9rem}.filters button:hover{background:#f0f7ed;transform:translateY(-1px)}.filters button.active{background:#4a7c2f;color:white}.main-content{display:flex}.main-content,.map-container{flex:1 1;position:relative;overflow:hidden}.loading{color:#666}.error,.loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.2rem}.error{color:#dc3545}.custom-marker{background:transparent;border:none}.popup-content h3{margin-bottom:.5rem;color:#2d5016;font-size:1rem}.popup-content p{margin:.25rem 0;font-size:.85rem;color:#333}.detail-button{margin-top:.5rem;padding:.4rem .8rem;background:#4a7c2f;color:white;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:600;transition:background .2s}.detail-button:hover{background:#3a6024}.detail-panel{width:400px;background:white;border-left:1px solid #dee2e6;box-shadow:-2px 0 10px rgba(0,0,0,.1);overflow-y:auto;position:relative;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.close-button{position:absolute;top:1rem;right:1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:#666;transition:all .2s;z-index:10}.close-button:hover{background:#e9ecef;color:#000}.detail-content{padding:2rem;scroll-behavior:smooth}.detail-content h2{font-size:1.5rem;color:#2d5016;margin-bottom:1.5rem;padding-right:2rem}.detail-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e9ecef}.detail-section:last-child{border-bottom:none}.detail-section h3{font-size:.9rem;color:#6c757d;margin-bottom:.5rem;font-weight:600}.detail-section p{font-size:1rem;color:#333;margin:.25rem 0}.directions-link,.website-link{display:inline-block;margin-top:.5rem;padding:.5rem 1rem;background:#4a7c2f;color:white;text-decoration:none;border-radius:6px;font-weight:600;font-size:.9rem;transition:all .2s}.directions-link:hover,.website-link:hover{background:#3a6024;transform:translateY(-1px)}.coordinates{background:#f8f9fa;padding:1rem;border-radius:8px;border:1px solid #e9ecef}.stats{justify-content:space-between;padding:.75rem 2rem;background:#f8f9fa;border-top:1px solid #dee2e6;font-size:.9rem;color:#666;gap:2rem;flex-wrap:wrap}.stats,.stats-left{display:flex;align-items:center}.stats-left{gap:1rem}.clear-filter{padding:.25rem .75rem;border:1px solid #dc3545;background:white;color:#dc3545;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.clear-filter:hover{background:#dc3545;color:white}.legend{gap:1rem;flex-wrap:wrap}.legend,.legend-item{display:flex;align-items:center}.legend-item{gap:.4rem;font-size:.85rem;color:#666}.legend-dot{width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 1px 3px rgba(0,0,0,.3)}.near-me-button{position:fixed;bottom:80px;right:20px;z-index:1000;width:56px;height:56px;padding:0;background:white;color:#2563eb;border:2px solid #e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.15);transition:all .3s ease}.near-me-button:hover{background:#f8fafc;border-color:#2563eb;transform:scale(1.05);box-shadow:0 6px 16px rgba(0,0,0,.2)}.near-me-button:active{transform:scale(.95);background:#2563eb;color:white}.near-me-button:disabled{background:#f3f4f6;color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed;transform:none;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.filter-drawer-button{position:fixed;bottom:80px;left:20px;z-index:1000;padding:12px 20px;background:white;color:#1f2937;border:2px solid #e5e7eb;border-radius:25px;display:flex;align-items:center;gap:8px;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.15);transition:all .3s ease;font-weight:600;font-size:15px}.filter-drawer-button:hover{background:#f8fafc;border-color:#2563eb;transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.2)}.filter-drawer-button svg{flex-shrink:0}.filter-badge{background:#2563eb;color:white;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:700;min-width:20px;text-align:center}.filter-drawer-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1998;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.filter-drawer{position:fixed;bottom:0;left:0;right:0;background:white;border-radius:20px 20px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.2);z-index:1999;max-height:70vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s ease}.filter-drawer.open{transform:translateY(0)}.filter-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.filter-drawer-header h2{margin:0;font-size:20px;font-weight:700;color:#1f2937}.filter-drawer-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.filter-drawer-close:hover{background:#f3f4f6;color:#1f2937}.filter-drawer-content{flex:1 1;overflow-y:auto;padding:0 20px 20px}.filter-drawer-footer{padding:16px 20px;border-top:1px solid #e5e7eb;flex-shrink:0}.filter-section{margin-bottom:16px;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.filter-section.disabled{opacity:.5;background:#f9fafb}.filter-section-header{width:100%;padding:16px;background:white;border:none;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s ease;text-align:left}.filter-section-header:not(:disabled):hover{background:#f9fafb}.filter-section-header:disabled{cursor:not-allowed}.filter-section-title{font-weight:600;font-size:15px;color:#1f2937;display:flex;align-items:center;gap:4px}.filter-count{color:#2563eb;font-weight:700}.filter-section-arrow{color:#6b7280;font-size:12px;transition:transform .2s ease}.filter-section-content{padding:8px 16px 16px;background:#fafafa}.filter-option{display:flex;align-items:center;padding:10px 0;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;gap:12px}.filter-option.disabled{opacity:.5;cursor:not-allowed}.filter-option input[type=checkbox],.filter-option input[type=radio]{width:20px;height:20px;cursor:pointer;flex-shrink:0}.filter-option input[type=checkbox]:disabled,.filter-option input[type=radio]:disabled{cursor:not-allowed}.filter-option span{font-size:14px;color:#374151;display:flex;align-items:center;gap:8px}.filter-option .legend-dot{display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 1px 3px rgba(0,0,0,.3)}.clear-all-filters{width:100%;padding:12px;background:#ef4444;color:white;border:none;border-radius:8px;font-weight:600;font-size:15px;cursor:pointer;transition:all .2s ease}.clear-all-filters:hover{background:#dc2626;transform:translateY(-1px)}.clear-all-filters:active{transform:translateY(0)}@media (max-width:1024px){.detail-panel{width:350px}}@media (max-width:768px){.header{padding:.75rem 1rem}.header-content h1{font-size:1.4rem}.filters{padding:.75rem 1rem;gap:.4rem}.filters button{padding:.4rem .8rem;font-size:.8rem}.detail-panel{position:absolute;width:100%;height:100%;z-index:1000}.stats{padding:.5rem 1rem;font-size:.8rem}.legend{gap:.5rem}.legend-item{font-size:.75rem}.filter-drawer{max-height:80vh}.filter-drawer-button{bottom:70px;font-size:14px;padding:10px 16px}}@media (min-width:769px){.filter-drawer{left:auto;right:20px;max-width:400px;border-radius:20px;bottom:auto;top:50%;transform:translateY(-50%) translateX(500px);max-height:80vh}.filter-drawer.open{transform:translateY(-50%) translateX(0)}}.leaflet-popup-content-wrapper{border-radius:8px}.leaflet-popup-content{margin:12px;min-width:200px}.alerts-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;padding:16px;margin-bottom:24px;display:flex;gap:12px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-icon{font-size:28px;flex-shrink:0}.alert-content h3{margin:0 0 8px;color:#92400e;font-size:16px;font-weight:700}.alert-item{margin-bottom:12px}.alert-item:last-child{margin-bottom:0}.alert-item strong{color:#92400e;display:block;margin-bottom:4px}.alert-item p{margin:0 0 8px;color:#78350f;font-size:14px;line-height:1.5}.alert-item a{color:#b45309;font-weight:600;text-decoration:none;font-size:14px}.alert-item a:hover{text-decoration:underline}.info-badges{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 24px}.badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;white-space:nowrap}.fee-badge{background:linear-gradient(135deg,#10b981,#059669);color:white;box-shadow:0 2px 8px rgba(16,185,129,.3)}.distance-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);color:white;box-shadow:0 2px 8px rgba(59,130,246,.3)}.boundary-toggle{background:white;color:#4a7c2f;border:2px solid #4a7c2f;cursor:pointer;transition:all .2s ease}.boundary-toggle:hover{background:#f0f7ed;transform:translateY(-1px)}.boundary-toggle.active{background:linear-gradient(135deg,#4a7c2f,#3a6024);color:white;border-color:#4a7c2f;box-shadow:0 2px 8px rgba(74,124,47,.3)}.description-section{background:#f8fafc;padding:20px;border-radius:12px;margin-bottom:24px}.description-section p{line-height:1.7;color:#334155;font-size:15px;margin:0}.detail-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px;margin-bottom:20px}@media (max-width:768px){.detail-grid{grid-template-columns:1fr}}.hours-today{font-size:16px;font-weight:600;color:#2563eb;margin:0}.activities-tags{display:flex;flex-wrap:wrap;gap:8px}.activity-tag{background:#eff6ff;color:#1e40af;padding:6px 12px;border-radius:16px;font-size:13px;font-weight:500;border:1px solid #dbeafe}.action-links{display:flex;flex-direction:column;gap:12px;margin-top:24px}.action-button{display:block;text-align:center;padding:14px 24px;border-radius:8px;font-weight:600;font-size:15px;text-decoration:none;transition:all .2s ease}.action-button.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:white;box-shadow:0 4px 12px rgba(37,99,235,.3)}.action-button.primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(37,99,235,.4)}.action-button.secondary{background:white;color:#2563eb;border:2px solid #2563eb}.action-button.secondary:hover{background:#eff6ff;transform:translateY(-2px)}.coordinates-section{margin-top:24px;padding-top:16px;border-top:1px solid #e5e7eb}.coordinates-text{font-size:12px;color:#9ca3af;text-align:center;margin:0;font-family:Courier New,monospace}.detail-section h3{font-size:14px;font-weight:700;color:#1f2937;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.detail-section a{color:#2563eb;text-decoration:none;font-weight:500}.detail-section a:hover{text-decoration:underline}.detail-section{margin-bottom:20px}.detail-section:last-child{margin-bottom:0}.detail-section p{margin:0 0 8px;line-height:1.6}.detail-section p:last-child{margin-bottom:0}@media (max-width:768px){.detail-panel{width:100%;max-width:100%;right:0;left:0;border-radius:20px 20px 0 0;max-height:75vh}.alerts-banner{padding:12px}.alert-icon{font-size:24px}.info-badges{margin:12px 0 20px}.description-section{padding:16px;margin-bottom:20px}.action-links{margin-top:20px}.action-button{padding:12px 20px}}