:root{--map-bg:#eef3f8;--map-charging-car:#e53935;--map-charging-truck:#8e24aa;--map-panel:rgba(255,255,255,0.92);--map-panel-dark:rgba(18,18,18,0.90);--map-text:#243447;--map-surface:rgba(255,255,255,0.94);--map-surface-strong:rgba(20,20,20,0.88);--map-border:rgba(255,255,255,0.10);--map-shadow:0 14px 30px rgba(0,0,0,0.18),
    0 4px 10px rgba(0,0,0,0.10);--map-radius:14px}.map-wrapper{position:relative;max-width:1200px;margin:clamp(24px,4vw,40px)auto 18px}.map-shell{position:relative}#map{width:100%;height:clamp(500px,70vh,700px);border-radius:var(--map-radius);overflow:hidden;box-shadow:var(--map-shadow);background:var(--map-bg)}.leaflet-control-zoom{border:none!important;box-shadow:0 4px 10px rgba(0,0,0,.2)!important}.leaflet-control-zoom a{width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important;font-weight:700;border:none!important}.map-form{position:absolute;top:10px;left:10px;right:10px;transform:none;z-index:5000;display:grid;grid-template-columns:minmax(0,1.3fr)minmax(0,1.3fr)minmax(0,.8fr)minmax(0,.8fr)auto auto;align-items:end;gap:8px;max-width:900px;padding:10px;border-radius:10px;background:var(--map-surface-strong);backdrop-filter:blur(8px);box-shadow:0 10px 24px rgba(0,0,0,.28)}.map-field{display:flex;flex-direction:column;gap:4px;color:#fff;font-size:12px;font-weight:500}.map-field-wide{min-width:0}.map-form input,.map-form select,.map-submit,.map-reset{min-height:40px;border-radius:7px;border:1px solid var(--map-border);font-size:14px;padding:0 10px}.map-form input,.map-form select{background:rgba(255,255,255,8%);color:#fff}.map-form input::placeholder{color:rgba(255,255,255,.55)}.map-submit{background:#1a73e8;color:#fff;border:none;padding-inline:14px;font-weight:600;cursor:pointer;transition:transform .15s ease,background .15s ease}.map-reset{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.3);padding-inline:14px;font-weight:600;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease}.map-submit:hover{background:#0b57d0;transform:translateY(-1px)}.map-reset:hover{background:rgba(255,255,255,.24);border-color:rgba(255,255,255,.5);transform:translateY(-1px)}.map-legend{position:absolute;left:10px;bottom:10px;z-index:4000;background:var(--map-surface-strong);backdrop-filter:blur(8px);color:#fff;padding:10px 12px;border-radius:10px;box-shadow:0 6px 18px rgba(0,0,0,.25)}.legend-title{font-size:11px;font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.mobile-map-legend,.mobile-status-toggle{display:none}.map-legend div{display:flex;align-items:center;gap:6px;margin-bottom:5px;font-size:13px}.legend-filter-btn{width:100%;display:flex;align-items:center;gap:6px;margin-bottom:5px;font-size:13px;color:#fff;background:0 0;border:1px solid transparent;border-radius:8px;padding:4px 6px;text-align:left;cursor:pointer;transition:background .15s ease,border-color .15s ease,opacity .15s ease}.legend-filter-btn:hover{background:rgba(255,255,255,8%)}.legend-filter-btn.is-active{border-color:rgba(255,255,255,.24);background:rgba(255,255,255,.12)}.legend-filter-btn:not(.is-active){opacity:.58}.legend-filter-all{margin-bottom:7px}.legend-color{width:11px;height:11px;border-radius:4px}.legend-charging-car{background:var(--map-charging-car)}.legend-charging-truck{background:var(--map-charging-truck)}.legend-charging-all{background:linear-gradient(90deg,var(--map-charging-car) 0%,var(--map-charging-truck) 100%)}.legend-section{display:flex;flex-direction:column;align-items:flex-start;gap:3px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}.legend-section-title{font-size:12px;font-weight:700;letter-spacing:.01em;line-height:1.25}.legend-section-row{display:block;width:100%;margin:0;font-size:12px;line-height:1.25;opacity:.94}.legend-section-note{display:block;margin-top:2px;font-size:10px;line-height:1.3;opacity:.68}.legend-lkw-realized{background:#22c55e}.legend-lkw-probable{background:#f59e0b}.legend-lkw-planned{background:#60a5fa}.map-status{display:grid;grid-template-columns:minmax(0,1fr)minmax(0,1.2fr)minmax(0,1fr);gap:12px 16px;margin-top:14px;padding:16px 20px 14px;border-radius:var(--map-radius);background:var(--map-surface);backdrop-filter:blur(10px);box-shadow:0 3px 12px rgba(0,0,0,.12);color:var(--map-text)}.map-status-left,.map-status-center,.map-status-right{min-width:0}.map-status-left{display:flex;flex-direction:column;gap:4px}.map-status-center{text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.map-status-center strong{display:block;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;line-height:1}.map-status-mobile-compact{display:none}.map-status-mobile-toggle{min-height:30px;border-radius:999px;border:1px solid rgba(36,52,71,.22);background:rgba(255,255,255,.72);color:#1d2f44;font-size:12px;font-weight:600;padding:0 12px;cursor:pointer}.map-status-right{display:flex;justify-content:flex-end;align-items:center;gap:12px;flex-wrap:wrap;font-size:15px;font-weight:600}.map-cluster-toggle{min-height:30px;border-radius:999px;border:1px solid rgba(36,52,71,.22);background:rgba(255,255,255,.72);color:#1d2f44;font-size:12px;font-weight:600;padding:0 10px;cursor:pointer;transition:background .15s ease,transform .15s ease}.map-cluster-toggle:hover{background:rgba(255,255,255,.94);transform:translateY(-1px)}.map-status-kicker,.map-status-label{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;opacity:.68}.map-status-note{grid-column:1/-1;margin:0;font-size:12px;line-height:1.4;opacity:.72}.map-status [hidden]{display:none!important}.map-status-ratio{grid-column:1/-1;display:flex;align-items:center;gap:5px;margin:2px 0 0;padding:5px 8px;border-radius:6px;background:rgba(255,255,255,5%);border:1px solid rgba(255,255,255,8%);font-size:12px;font-weight:600;letter-spacing:.02em;opacity:.82}.map-status-route{grid-column:1/-1;display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;margin:2px 0 0;padding:6px 8px;border-radius:6px;background:rgba(255,255,255,6%);border:1px solid rgba(255,255,255,.1);font-size:12px;line-height:1.35;font-weight:600}.map-status-route strong{font-size:12px;text-transform:uppercase;letter-spacing:.03em;opacity:.86}.map-status-mobile-filters{grid-column:1/-1;display:none;gap:6px;margin-top:2px}.map-status-mobile-filters .legend-filter-btn{margin-bottom:0;justify-content:center;color:#1d2f44;border-color:rgba(36,52,71,.22);background:rgba(255,255,255,.72);min-height:30px;padding:0 12px}.map-status-mobile-filters .legend-filter-btn.is-active{border-color:rgba(36,52,71,.36);background:rgba(255,255,255,.92)}.map-status-ratio-icon{font-size:13px;line-height:1}.map-privacy-note{margin-top:2px;font-size:11px;opacity:.64}.map-data-meta{display:flex;flex-direction:column;align-items:flex-start;gap:2px;margin-top:6px;font-size:10px;line-height:1.35;opacity:.62}.map-data-meta-title{font-weight:700;letter-spacing:.02em;text-transform:uppercase}.map-data-meta-line{max-width:100%}.map-data-meta strong{font-weight:700}.leaflet-popup-content-wrapper{border-radius:14px}.leaflet-popup-content{margin:14px;min-width:240px;font-size:14px;line-height:1.5}.popup-title{font-size:16px;font-weight:700;margin-bottom:10px}.popup-table{width:100%}.popup-table td{padding:4px 0}.popup-table td:first-child{opacity:.75}.badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:700;color:#fff}.badge-mcs{background:#1976d2}.badge-power{background:#ef6c00}.badge-dc{background:#37474f}.route-station-highlight{filter:drop-shadow(0 0 6px rgba(21,101,192,.28));animation:routeStationPulse 1.6s ease-in-out 3}.route-station-hub-highlight{filter:drop-shadow(0 0 10px rgba(255,179,0,.58));animation:routeStationHubPulse 1.4s ease-in-out 4}@keyframes routeStationPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes routeStationHubPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.14);opacity:.86}}.leaflet-control-attribution{background:rgba(255,255,255,.86)!important;border-radius:8px!important;padding:2px 8px!important;font-size:11px!important}@media(max-width:900px){#map{height:clamp(420px,62vh,560px)}.map-form{position:static;margin:0 0 10px;width:100%;max-width:none;grid-template-columns:1fr 1fr;padding:10px}.map-field{width:100%}.map-field-wide{grid-column:1/-1}.map-form input,.map-form select,.map-submit,.map-reset{width:100%}.map-submit,.map-reset{grid-column:1/-1}.map-status{grid-template-columns:1fr;text-align:center}.map-status-left,.map-status-center,.map-status-right{width:100%;justify-content:center}.map-cluster-toggle{min-height:28px;font-size:11px}.map-status-center strong{font-size:clamp(1.5rem,7vw,2rem)}.map-status-ratio{justify-content:center;text-align:center}.map-status-route{justify-content:center;text-align:center}.map-legend{left:8px;right:8px;bottom:8px;max-width:none;padding:8px 10px}.legend-section-title{font-size:11px}.legend-section-row{font-size:11px}.legend-section-note{font-size:9px}.map-data-meta{font-size:9px}}@media(hover:hover) and (pointer:fine){.map-legend{position:absolute;left:16px;bottom:16px;width:auto;height:auto;min-height:unset;padding:1rem;border-radius:18px;z-index:1000}.mobile-map-legend,.mobile-status-toggle{display:none!important}}@media(max-width:768px),(hover:none) and (pointer:coarse){.map-legend{display:none!important}.mobile-map-legend{position:absolute;left:max(12px,env(safe-area-inset-left));bottom:max(12px,env(safe-area-inset-bottom));z-index:1001;display:block}.mobile-legend-button{background:rgba(20,20,20,.92);border:1px solid rgba(255,255,255,.12);border-radius:999px;color:#fff;padding:.7rem 1rem;min-height:44px;font-size:.95rem;backdrop-filter:blur(12px);cursor:pointer}.mobile-legend-content{margin-top:.5rem;background:rgba(20,20,20,.95);border-radius:16px;padding:.75rem;min-width:180px;display:flex;flex-direction:column;gap:.55rem;box-shadow:0 6px 18px rgba(0,0,0,.25);overscroll-behavior:contain}.mobile-legend-content[hidden]{display:none}.mobile-legend-group{display:flex;flex-direction:column;gap:.45rem}.mobile-legend-germany-group{padding-top:.1rem;border-top:1px solid rgba(255,255,255,8%)}.mobile-legend-group-title{color:rgba(255,255,255,.78);font-size:.74rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.legend-item{display:flex;align-items:center;gap:.6rem;color:#fff;font-size:.9rem;line-height:1.25}.mobile-legend-emoji{width:12px;display:inline-flex;justify-content:center;flex:0 0 12px}.dot{width:12px;height:12px;border-radius:999px;display:inline-block}.dot.all{background:#ff4081}.dot.car{background:#d84343}.dot.truck{background:#8e24aa}.map-status{gap:8px;margin-top:10px;padding:calc(10px + env(safe-area-inset-top))calc(12px + env(safe-area-inset-right))calc(10px + env(safe-area-inset-bottom))calc(12px + env(safe-area-inset-left));text-align:left}.map-status-left,.map-status-center{display:none}.map-status-mobile-compact{grid-column:1/-1;display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:12px;font-weight:600}.map-status-mobile-compact strong{font-size:14px;line-height:1.1}.map-status-mobile-compact>div:last-of-type{font-size:11px;font-weight:600;opacity:.82}.map-status-mobile-toggle{margin-top:2px;padding:0 10px;min-height:44px}.map-status-right{flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:6px;font-size:13px}.map-status-route{align-items:flex-start;justify-content:flex-start;gap:6px 10px}.status-fuel-line{display:none}.map-status-mobile-filters{display:flex;flex-wrap:wrap;gap:6px}.map-status-mobile-filters .legend-filter-btn{min-height:44px}.map-cluster-toggle{min-height:44px}.map-status-mobile-detail{overflow:hidden;max-height:180px;opacity:1;transition:max-height .22s ease,opacity .18s ease,margin .18s ease,padding .18s ease}.map-status-mobile-suppressed{display:none!important}.map-status.is-mobile-collapsed .map-status-mobile-detail{max-height:0;opacity:0;margin-top:0!important;margin-bottom:0!important;padding-top:0!important;padding-bottom:0!important;border-width:0!important;pointer-events:none}.map-status:not(.is-mobile-collapsed){overscroll-behavior:contain}}@media(hover:none) and (pointer:coarse) and (orientation:landscape){.mobile-map-legend{transform:scale(.9);transform-origin:left bottom;bottom:56px}.mobile-legend-content{max-height:45vh;overflow-y:auto;padding:.65rem;gap:.45rem}.stats-card{max-height:120px;overflow-y:auto}.map-status-mobile-detail{max-height:45vh;overflow-y:auto}}@media(prefers-reduced-motion:reduce){.map-status-mobile-detail,.mobile-legend-content,.map-cluster-toggle,.legend-filter-btn,.map-submit,.map-reset{transition:none!important}.route-station-highlight{animation:none!important}}@media(prefers-color-scheme:dark){.map-status{background:var(--map-surface-strong);color:#fff}.leaflet-control-attribution{background:rgba(20,20,20,.86)!important;color:#fff!important}.leaflet-control-attribution a{color:#64b5f6!important}.leaflet-popup-content-wrapper{background:#1e1e1e;color:#fff}.map-form input,.map-form select{background:rgba(255,255,255,.1)}.map-cluster-toggle{border-color:rgba(255,255,255,.24);background:rgba(0,0,0,.24);color:#fff}.map-cluster-toggle:hover{background:rgba(255,255,255,.16)}.map-status-ratio{background:rgba(255,255,255,6%);border-color:rgba(255,255,255,.12);color:#fff}.map-status-mobile-toggle{border-color:rgba(255,255,255,.24);background:rgba(0,0,0,.24);color:#fff}.map-status-mobile-filters .legend-filter-btn{border-color:rgba(255,255,255,.24);background:rgba(0,0,0,.24);color:#fff}.map-status-mobile-filters .legend-filter-btn.is-active{border-color:rgba(255,255,255,.42);background:rgba(255,255,255,.18)}}