.map-wrapper{position:relative;max-width:1200px;margin:40px auto 24px;padding:0}#map{position:relative;width:100%;height:600px;border-radius:12px;box-shadow:0 22px 45px rgba(0,0,0,.3),0 6px 14px rgba(0,0,0,.18);transition:transform .35s ease,box-shadow .35s ease}@media(hover:hover) and (pointer:fine){#map:hover{transform:translateY(-8px);box-shadow:0 34px 65px rgba(0,0,0,.45),0 12px 24px rgba(0,0,0,.25)}}.map-form{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:5000;display:flex;flex-wrap:wrap;gap:6px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);padding:10px 12px;border-radius:8px;box-shadow:0 8px 20px rgba(0,0,0,.25);font-family:inter,roboto,sans-serif}.map-form input,.map-form select,.map-form button{font-size:13px;padding:6px 8px;border-radius:4px;border:1px solid #ccc}.map-form button{background:#07c;color:#fff;border:none;cursor:pointer}.map-form button:hover{background:#005fa3}.map-legend{position:absolute;bottom:12px;left:12px;background:rgba(255,255,255,.94);padding:10px 14px;border-radius:6px;font-size:13px;line-height:1.4;box-shadow:0 2px 6px rgba(0,0,0,.25);z-index:4000}.map-legend .legend-title{font-size:12px;font-weight:700;margin-bottom:6px}.map-legend div{display:flex;align-items:center;margin-bottom:4px}.map-legend span.legend-color{width:12px;height:12px;margin-right:6px;border-radius:2px;border:1px solid rgba(0,0,0,.4)}.maplibregl-ctrl-bottom-right{position:absolute!important;bottom:6px;right:6px;z-index:3000;background:rgba(255,255,255,.85);font-size:10px;padding:3px 6px;border-radius:3px;color:#000;box-shadow:0 1px 3px rgba(0,0,0,.2)}.maplibregl-ctrl-attrib a{color:#06c;font-weight:500;text-decoration:none}.maplibregl-ctrl-attrib a:hover{text-decoration:underline}.map-status{margin-top:8px;font-size:13px;color:#333;text-align:center;font-family:inter,roboto,sans-serif}.modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9999}.modal-content{background:#fff;margin:15% auto;padding:20px;width:320px;border-radius:8px;text-align:center;box-shadow:0 4px 14px rgba(0,0,0,.3);position:relative;font-family:inter,sans-serif}.modal-content .close{position:absolute;top:6px;right:10px;font-size:20px;cursor:pointer}@media(max-width:900px){#map{height:480px;transform:none!important;box-shadow:0 12px 22px rgba(0,0,0,.25)}.map-form{position:static;transform:none;margin-bottom:10px;justify-content:center}}.charging-popup{font-family:inter,roboto,sans-serif;font-size:13px;line-height:1.4}.charging-popup h3{margin:0 0 6px;font-size:14px;font-weight:700}.charging-popup table{width:100%;border-collapse:collapse}.charging-popup td{padding:3px 0}.charging-popup td:first-child{color:#666;white-space:nowrap;padding-right:8px}.charging-popup td:last-child{text-align:right;font-weight:600}.popup-title{font-weight:700;margin-bottom:6px}.popup-badges{margin-bottom:8px}.badge{display:inline-block;padding:2px 6px;margin-right:4px;border-radius:4px;font-size:11px;font-weight:600}.badge-mcs{background:#1f77b4;color:#fff}.badge-power{background:#e67e22;color:#fff}.badge-dc{background:#2c3e50;color:#fff}.popup-table{width:100%;font-size:12px}.popup-table td:first-child{opacity:.7;padding-right:6px}.map-status{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-top:10px;padding:6px 12px;font-family:inter,roboto,sans-serif;font-size:13px;color:#333;background:rgba(255,255,255,.65);backdrop-filter:blur(4px);border-radius:8px}.map-status-left{text-align:left;opacity:.85}.map-status-center{text-align:center;font-weight:600}.map-status-right{text-align:right;opacity:.9}@media(max-width:700px){.map-status{grid-template-columns:1fr;row-gap:4px;text-align:center}.map-status-left,.map-status-center,.map-status-right{text-align:center}}