.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{top:auto;bottom:0;left:0;right:0;width:100%;max-width:100%;border-radius:16px 16px 0 0;max-height:75vh;transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 32px rgba(232,160,32,.1)}.map-filter-panel--open{transform:translateY(0)}}.map-filter-panel .filter-header{margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.map-filter-panel .filter-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.map-filter-panel .filter-close-btn{display:none;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:#f3f4f6;color:#374151;font-size:1.1rem;cursor:pointer;transition:background .2s}.map-filter-panel .filter-close-btn:hover{background:#e5e7eb}@media(max-width:768px){.map-filter-panel .filter-close-btn{display:flex}}.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,#E8A020,#4A6741);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 #e8a020;cursor:pointer;box-shadow:0 2px 8px rgba(232,160,32,.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(232,160,32,.6)}.map-filter-panel .distance-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #e8a020;cursor:pointer;box-shadow:0 2px 8px rgba(232,160,32,.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(232,160,32,.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:#e8a020;background:rgba(232,160,32,.08);transform:translateY(-2px);box-shadow:0 4px 12px rgba(232,160,32,.2)}.map-filter-panel .category-btn.active{border-color:#e8a020;background:linear-gradient(135deg,#2B2420,#E8A020);color:#f5f2ec;box-shadow:0 4px 12px rgba(232,160,32,.35)}.map-filter-panel .category-btn.active .category-label{color:#f5f2ec}.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:#e8a020;box-shadow:0 4px 10px rgba(232,160,32,.25);transform:translateY(-2px)}.map-filter-panel .map-style-btn.active{border-color:#e8a020;background:linear-gradient(135deg,#2B2420,#4A6741);color:#f5f2ec;box-shadow:0 6px 14px rgba(43,36,32,.4)}.map-filter-panel .map-style-btn.active .map-style-btn__description,.map-filter-panel .map-style-btn.active .map-style-btn__label{color:#f5f2ec}.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:#e8a020}.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:#e8a020;color:#0f1512;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.map-filter-panel .reset-btn:hover{background:#f0b030;transform:translateY(-1px);box-shadow:0 4px 12px rgba(232,160,32,.35)}.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}.map-filter-fab{display:none}@media(max-width:768px){.map-filter-fab{display:flex;align-items:center;justify-content:center;position:absolute;bottom:88px;right:16px;width:52px;height:52px;border-radius:50%;border:none;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;font-size:1.35rem;box-shadow:0 4px 16px rgba(59,130,246,.45);cursor:pointer;z-index:11;transition:transform .2s,box-shadow .2s}.map-filter-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(232,160,32,.5)}.map-filter-fab--active{background:linear-gradient(135deg,#2B2420,#0F1512);box-shadow:0 4px 16px rgba(0,0,0,.3)}}@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-page{display:flex;flex-direction:column;height:calc(100svh - 64px);overflow:hidden;background:var(--color-bg)}.trailmap-page__map{flex:1;position:relative;min-height:0}.trailmap-page__map .mapboxgl-map,.trailmap-page__map .maplibregl-map{position:absolute;inset:0;width:100%!important;height:100%!important}.trailmap-page__map .mapboxgl-ctrl-group,.trailmap-page__map .maplibregl-ctrl-group{background:color-mix(in srgb,var(--color-bg-elevated) 92%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:.65rem;box-shadow:0 4px 16px rgba(0,0,0,.12);overflow:hidden}.trailmap-page__map .mapboxgl-ctrl-group button,.trailmap-page__map .maplibregl-ctrl-group button{width:36px;height:36px;border:none;border-bottom:1px solid var(--color-border)}.trailmap-page__map .mapboxgl-ctrl-group button:last-child,.trailmap-page__map .maplibregl-ctrl-group button:last-child{border-bottom:none}.trailmap-page__map .mapboxgl-ctrl-group button:hover,.trailmap-page__map .maplibregl-ctrl-group button:hover{background:var(--color-primary-soft)}.trailmap-page__map .mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active,.trailmap-page__map .mapboxgl-ctrl-geolocate.maplibregl-ctrl-geolocate-active,.trailmap-page__map .maplibregl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active,.trailmap-page__map .maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active{color:#cc5f2f}.trailmap-page__map .mapboxgl-ctrl-attrib,.trailmap-page__map .maplibregl-ctrl-attrib{background:color-mix(in srgb,var(--color-bg) 80%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-size:.62rem;border-radius:.4rem 0 0 0}@media(max-width:768px){.trailmap-page{height:calc(100svh - 64px);height:calc(100dvh - 64px)}}