/* Map Styles */

.wdt-google-map-wrapper { display: flex; flex-wrap: wrap; }

.wdt-google-map { height: 500px; width: 100%; }
.wdt-google-map .gm-style img { border-radius:var(--wdtRadius_Zero);object-fit: contain; object-position: center; }
.wdt-google-map .gm-style .gm-style-iw-t:after { content: none; }

.wdt-google-map .gm-style .gm-style-iw-c { background: var(--wdtPrimaryColor); overflow: visible; padding: 0 !important; transform: translate3d(-50%, -110%, 0) !important;}
.wdt-google-map .gm-style .gm-style-iw-c:after { background-color: inherit; background-image: inherit; content: ""; height: 15px; position: absolute; left: 50%; top: 100%; width: 15px; z-index: 1; box-shadow: -2px 2px 2px 0 rgba(var(--wdt-elementor-color-secondary-rgb),0.4); transform: translate(-50%,-50%) rotate(-45deg);

    -webkit-mask-image: linear-gradient(45deg,rgb(255, 255, 255) 50%,rgba(255,255,255,0) 51%,rgba(255,255,255,0) 100%);
    mask-image: linear-gradient(45deg,rgb(255, 255, 255) 50%,rgba(255,255,255,0) 51%,rgba(255,255,255,0) 100%);

}

.wdt-google-map .gm-style .gm-style-iw-d { overflow: auto !important; }

.wdt-google-map .gm-style .gm-style-iw-c button.gm-ui-hover-effect {
    border-radius:var(--wdtRadius_Zero);
    position: absolute ! important;
    right: -12px;
    top: -12px;
    background-color:var(--wdtSecondaryColor) ! important;
    height: 24px ! important;
    width: 24px ! important;
    opacity: 0;
    transition: var(--wdtBaseTransition);
  }
.wdt-google-map .gm-style .gm-style-iw-c button.gm-ui-hover-effect > span {
    height: 100% !important;
    margin: 0 !important;
    width: 100% !important;
    transition: var(--wdtBaseTransition);
    background-color: var(--wdtAccentTxtColor);
    mask-size: 20px;
    mask-position: center;
}

.wdt-google-map .gm-style .gm-style-iw-c:hover button.gm-ui-hover-effect { opacity: 1; visibility: visible; }
.wdt-google-map .gm-style .gm-style-iw-c button.gm-ui-hover-effect:hover span{ transform: rotateY(180deg); }

.wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-title { color: var(--wdt-elementor-color-primary); font-family: var(--wdt-elementor-typo-primary-font-family); font-size: clamp(1.125rem, 1.0003rem + 0.4164vw, 1.5rem); /* 24 -18 */ font-weight: var(--wdt-elementor-typo-primary-font-weight); margin-bottom: 8px; }
.wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-desc > *:last-child { margin-bottom: 0; }
.wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-desc p { margin-top: 0; font-size: var(--wdtFontSize_Base); font-family: var(--wdtFontTypo_Base); margin-bottom: 10px !important; display: flex; }
.wdt-dark-bg .wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-title{color: var(--wdtAccentTxtColor);}


.wdt-google-map-wrapper .wdt-google-map { flex: 1 1 400px; }
.wdt-google-map-wrapper .wdt-google-map-marker-content-wrapper { flex: 1 1 0; }
.wdt-google-map-wrapper .wdt-google-map-marker-content-selection { border: 1px solid rgba(var(--wdt-elementor-color-secondary-rgb), 0.15); background: var(--wdt-elementor-color-white); font-family: inherit; font-size: inherit; padding: 10px; width: 100%; }

.wdt-google-map-marker-content-wrapper { background-color: rgba(var(--wdt-elementor-color-secondary-rgb),0.05); padding: 1.5em; width: 100%; }
.wdt-google-map-marker-content-wrapper .wdt-google-map-marker-content-selection ~ .wdt-google-map-marker-content-item { margin-top: 1.5rem; }
.wdt-google-map-marker-content-wrapper .wdt-google-map-marker-content-item:empty { display: none; }
.wdt-google-map-marker-content-wrapper .wdt-google-map-marker-content-item p { margin-top: 0; }
.wdt-google-map-marker-content-wrapper .wdt-google-map-marker-content-item > *:last-child { margin-bottom: 0; }


.wdt-google-map .gm-style div[role="button"] { padding: 0; opacity: 0; transform: translateY(-10px); }

.wdt-google-map .gm-style .gm-style-iw-tc::after { background: transparent;}

.gm-style-iw-ch{display: none;}
.wdt-google-map-info-container{
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    padding-right: 14px;
    column-gap: 14px;
    max-width: 400px;
    width: 100%;
}
.wdt-google-map .gm-style .gm-style-iw-c:has(> .gm-style-iw-d .wdt-google-map-info-container .wdt-google-map-info-window-image) {
    padding: 0px !important;
    border-radius: 0px;
    box-shadow: none;
}
.wdt-google-map-info-container .wdt-google-map-info-image > img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-desc p > a { color: var(--wdtAccentTxtColor); }
.wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-desc p > a:hover { color: var(--wdtSecondaryColor); }
.wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-desc p:last-child { margin-bottom: 0 !important; }
.wdt-google-map .gm-style .gm-style-iw-c .wdt-google-map-info-desc p img {
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1);
    width: 1.1em;
    height: 1.1em;
    margin-right: 8px;
    margin-bottom: 0;
    position: relative;
    top: 2px;
}
.wdt-google-map-info-content-wrapper { padding:14px 0; display: flex; flex-direction: column; justify-content: center; }


/* Marker Animations */

/* Soft Beat */
#wdtMarkerLayerSoftBeat > div { -webkit-animation: wdt-soft-beat 0.8s cubic-bezier(0.390, 0.575, 0.565, 1.000) infinite alternate; animation: wdt-soft-beat 0.8s cubic-bezier(0.390, 0.575, 0.565, 1.000) infinite alternate; }

@-webkit-keyframes wdt-soft-beat {
    0% { -webkit-transform: scale(0.66); transform: scale(0.66); }
    100% {-webkit-transform: scale(0.99); transform: scale(0.99); }
}
@keyframes wdt-soft-beat {
    0% { -webkit-transform: scale(0.66); transform: scale(0.66); }
    100% {-webkit-transform: scale(0.99); transform: scale(0.99); }
}

@media (max-width:1024px) {
    .wdt-google-map .gm-style .gm-style-iw-c button.gm-ui-hover-effect{opacity: 1; visibility: visible;}
}
@media (max-width:479px) { 
    .wdt-google-map-info-container { grid-template-columns: 1fr; padding: 15px; }
    .wdt-google-map-info-container .wdt-google-map-info-image > img{max-height: 100px;}
}