.locations-map-wrapper{z-index:1;background:#f8fafc;border-radius:24px;width:100%;height:500px;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d,0 10px 15px -3px #00000014}.map-loading{color:#64748b;justify-content:center;align-items:center;height:100%;font-family:Mundial,system-ui,sans-serif;display:flex}.leaflet-container{font-family:Mundial,system-ui,sans-serif}.leaflet-popup-content-wrapper{border-radius:12px;padding:0}.leaflet-popup-content{margin:0;padding:12px 16px;font-family:Mundial,system-ui,sans-serif}.leaflet-popup-content-custom h4{color:#1a1a1a;margin:0 0 4px;font-size:14px;font-weight:600}.leaflet-popup-content-custom p{color:#64748b;margin:0;font-size:12px}.custom-marker{background:0 0!important;border:none!important}.marker-container{flex-direction:column;align-items:center;display:flex;position:relative}.marker-pin{background:#9cc93d;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;width:25px;height:25px;display:flex;position:relative;transform:rotate(-45deg);box-shadow:0 3px 8px #00000040}.marker-pin svg{color:#fff;transform:rotate(45deg)}.custom-marker:hover .marker-pin{transform:rotate(-45deg)scale(1.1);box-shadow:0 4px 12px #0000004d}.city-popup{z-index:1000;background:#fff;border-radius:16px;width:300px;max-height:450px;padding:20px;animation:.3s slideIn;position:absolute;top:20px;right:20px;overflow-y:auto;box-shadow:0 20px 50px #00000026}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.popup-close{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.popup-close:hover{color:#1a1a1a;background:#e2e8f0}.popup-header{align-items:flex-start;gap:12px;margin-bottom:16px;padding-right:20px;display:flex}.popup-icon{color:#fff;background:#9cc93d;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.popup-city{letter-spacing:.5px;text-transform:uppercase;color:#9cc93d;margin-bottom:4px;font-family:Mundial,system-ui,sans-serif;font-size:11px;font-weight:600;display:block}.popup-title{color:#1a1a1a;margin:0;font-family:Mundial,system-ui,sans-serif;font-size:16px;font-weight:700;line-height:1.3}.location-popup{width:280px}.popup-location-details{border-bottom:1px solid #f1f5f9;margin-bottom:16px;padding-bottom:16px}.location-address-full{color:#64748b;margin-bottom:12px;font-size:14px;line-height:1.5}.location-type-badge{text-transform:uppercase;letter-spacing:.5px;color:#64748b;background:#f1f5f9;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.popup-directions-btn{color:#fff;background:#1a1a1a;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-family:Mundial,system-ui,sans-serif;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.popup-directions-btn:hover{background:#9cc93d}@media (max-width:767px){.locations-map-wrapper{border-radius:16px;height:450px}.marker-pin{width:22px;height:22px}.city-popup{width:calc(100% - 40px);max-width:320px;max-height:350px;animation:.3s slideUp;position:fixed;inset:auto auto 20px 50%;transform:translate(-50%)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}}@media (prefers-reduced-motion:reduce){.popup-close,.popup-directions-btn{transition:none}.city-popup{animation:none}}
