.map-filter-panel{position:absolute;top:20px;right:20px;width:320px;background:hsla(0,0%,100%,.98);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);padding:20px;z-index:10;max-height:calc(100vh - 40px);overflow-y:auto}@media(max-width:768px){.map-filter-panel{width:calc(100% - 40px);max-width:400px}}.map-filter-panel .filter-header{margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.map-filter-panel .filter-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.map-filter-panel .filter-section{margin-bottom:20px}.map-filter-panel .filter-section:last-of-type{margin-bottom:0}.map-filter-panel .filter-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:10px}.map-filter-panel .filter-label span{display:flex;align-items:center;gap:6px}.map-filter-panel .distance-slider{width:100%;height:6px;border-radius:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.map-filter-panel .distance-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #3b82f6;cursor:pointer;box-shadow:0 2px 8px rgba(59,130,246,.4);-webkit-transition:all .2s;transition:all .2s}.map-filter-panel .distance-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(59,130,246,.6)}.map-filter-panel .distance-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #3b82f6;cursor:pointer;box-shadow:0 2px 8px rgba(59,130,246,.4);-moz-transition:all .2s;transition:all .2s}.map-filter-panel .distance-slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(59,130,246,.6)}.map-filter-panel .distance-marks{display:flex;justify-content:space-between;margin-top:6px;font-size:.75rem;color:#6b7280}.map-filter-panel .filter-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;padding:10px;border-radius:8px;transition:background-color .2s}.map-filter-panel .filter-checkbox:hover{background-color:#f3f4f6}.map-filter-panel .filter-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6}.map-filter-panel .filter-checkbox span{font-size:.875rem;font-weight:500;color:#374151}.map-filter-panel .category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.map-filter-panel .category-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s;font-size:.75rem}.map-filter-panel .category-btn:hover{border-color:#3b82f6;background:#eff6ff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(59,130,246,.15)}.map-filter-panel .category-btn.active{border-color:#3b82f6;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:var(--color-text);box-shadow:0 4px 12px rgba(59,130,246,.3)}.map-filter-panel .category-btn.active .category-label{color:var(--color-text)}.map-filter-panel .category-btn .category-icon{font-size:1.5rem;line-height:1}.map-filter-panel .category-btn .category-label{font-weight:500;color:#374151;text-align:center;word-break:break-word}.map-filter-panel .map-style-toggle{display:grid;grid-template-columns:1fr;gap:8px}@media(min-width:480px){.map-filter-panel .map-style-toggle{grid-template-columns:repeat(2,1fr)}}.map-filter-panel .map-style-btn{border:1px solid #d1d5db;border-radius:10px;padding:10px 12px;text-align:left;background:#f9fafb;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:4px}.map-filter-panel .map-style-btn__label{font-weight:600;color:#111827;font-size:.9rem}.map-filter-panel .map-style-btn__description{font-size:.75rem;color:#6b7280;line-height:1.2}.map-filter-panel .map-style-btn:hover{border-color:#2563eb;box-shadow:0 4px 10px rgba(37,99,235,.2);transform:translateY(-2px)}.map-filter-panel .map-style-btn.active{border-color:#2563eb;background:linear-gradient(135deg,#1d4ed8,#38bdf8);color:var(--color-text);box-shadow:0 6px 14px rgba(30,64,175,.35)}.map-filter-panel .map-style-btn.active .map-style-btn__description,.map-filter-panel .map-style-btn.active .map-style-btn__label{color:var(--color-text)}.map-filter-panel .filter-footer{margin-top:20px;padding-top:15px;border-top:2px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.map-filter-panel .results-info{display:flex;align-items:baseline;gap:6px}.map-filter-panel .results-info .results-count{font-size:1.5rem;font-weight:700;color:#3b82f6}.map-filter-panel .results-info .results-text{font-size:.875rem;color:#6b7280}.map-filter-panel .reset-btn{padding:8px 16px;border:none;border-radius:8px;background:#ef4444;color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.map-filter-panel .reset-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px rgba(239,68,68,.3)}.map-filter-panel .reset-btn:active{transform:translateY(0)}.map-filter-panel::-webkit-scrollbar{width:6px}.map-filter-panel::-webkit-scrollbar-track{background:#f3f4f6;border-radius:3px}.map-filter-panel::-webkit-scrollbar-thumb{background:#9ca3af;border-radius:3px}.map-filter-panel::-webkit-scrollbar-thumb:hover{background:#6b7280}@media(prefers-color-scheme:dark){.map-filter-panel{background:rgba(31,41,55,.98)}.map-filter-panel .filter-header{border-bottom-color:#374151}.map-filter-panel .filter-header h3{color:var(--color-text)}.map-filter-panel .filter-label{color:#e5e7eb}.map-filter-panel .filter-checkbox:hover{background-color:#374151}.map-filter-panel .filter-checkbox span{color:#e5e7eb}.map-filter-panel .category-btn{background:#1f2937;border-color:#374151}.map-filter-panel .category-btn:hover{background:#374151}.map-filter-panel .category-btn .category-label{color:#e5e7eb}.map-filter-panel .filter-footer{border-top-color:#374151}.map-filter-panel .results-text{color:#9ca3af}.map-filter-panel .map-style-btn{background:#111827;border-color:#374151}.map-filter-panel .map-style-btn__label{color:var(--color-text)}.map-filter-panel .map-style-btn__description{color:#9ca3af}.map-filter-panel .map-style-btn:hover{background:#1f2937}.map-filter-panel .map-style-btn.active{background:linear-gradient(135deg,#312e81,#1e40af);border-color:rgba(0,0,0,0)}}.map-marker-popup{min-width:200px;padding:4px}.map-marker-popup h4{margin:0 0 8px;font-size:1rem;font-weight:600;color:#1f2937}.map-marker-popup p{margin:4px 0;font-size:.875rem;color:#6b7280}.map-marker-popup p:last-child{margin-bottom:0}.maplibregl-popup-close-button{height:1.5rem;width:1.5rem;font-size:1.25rem}.trailmap{position:fixed;top:70px;bottom:40px;right:0;display:flex;width:100vw}.trailmap aside{flex:.15}.trailmap aside .navSection{display:flex;flex-direction:column}.trailmap aside .navSection span{display:flex;justify-content:space-between;padding:.5rem 0 .5rem 2rem;border:1px solid #000;background:#2d3748;color:#e2e8f0;cursor:pointer}.trailmap aside .navSection span:hover{background:rgba(45,55,72,.8);font-weight:700}.trailmap aside .trailInfo{padding:1rem 0 1rem 2rem}.trailmap .mapContainer{flex:1}