:root{--map-bg:#eef3f8;--map-road-major:#f7b44a;--map-road-local:#f4f7fb;--map-water:#9fd3ff;--map-land:#d9ebc3;--map-charging-car:#e53935;--map-charging-truck:#8e24aa;--map-panel:rgba(255,255,255,0.92);--map-panel-text:#243447}.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 16px 32px rgba(32,52,72,.2),0 4px 10px rgba(32,52,72,.12);transition:transform .35s ease,box-shadow .35s ease}@media(hover:hover) and (pointer:fine){#map:hover{transform:translateY(-8px);box-shadow:0 22px 44px rgba(32,52,72,.24),0 8px 18px rgba(32,52,72,.14)}}.map-form{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:5000;display:flex;flex-wrap:wrap;gap:6px;background:var(--map-panel);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:#1a73e8;color:#fff;border:none;cursor:pointer}.map-form button:hover{background:#0b57d0}.map-legend{position:absolute;bottom:12px;left:12px;background:rgba(255,255,255,.96);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)}.map-legend .legend-road-major{background:var(--map-road-major)}.map-legend .legend-road-local{background:var(--map-road-local)}.map-legend .legend-water{background:var(--map-water)}.map-legend .legend-land{background:var(--map-land)}.map-legend .legend-charging-car{background:var(--map-charging-car)}.map-legend .legend-charging-truck{background:var(--map-charging-truck)}.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:var(--map-panel-text);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:absolute;top:10px;left:50%;transform:translateX(-50%);width:calc(100% - 20px);max-width:1080px;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,.75);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}}@media(prefers-color-scheme:dark){.map-status{color:#fff;background:rgba(0,0,0,.65)}.map-status-left,.map-status-center,.map-status-right{color:#fff}.map-form{background:rgba(30,30,30,.88);border:1px solid #444}.map-form input,.map-form select,.map-form button{background:#222;color:#fff;border:1px solid #555}.map-form button:hover{background:#0a84ff;color:#fff}.map-legend{background:rgba(20,24,31,.92);color:#f1f5f9;border:1px solid rgba(255,255,255,.16)}.map-legend .legend-title{color:#f8fafc}.map-legend span.legend-color{border:1px solid rgba(255,255,255,.45)}.charging-popup,.popup-title,.popup-table td{color:#fff}.charging-popup h3,.popup-title{color:#fff}.badge-mcs,.badge-power,.badge-dc{color:#fff}.modal-content{background:#222;color:#fff}.modal-content .close{color:#fff}.maplibregl-ctrl-bottom-right{background:rgba(0,0,0,.72);color:#fff}.maplibregl-ctrl-attrib a{color:#7cc1ff}}