/* ==========================================================================
  Locator
============================================================================= */
/* Global */
/* .nesthub-locator { --header-height: 235px; } */

main.no-hero, body.no-hero main { border-top: 0; }

/* Content
================================================== */
.locator-content { background: #f2f2f2; align-self: stretch; overflow: scroll; position: relative!important; }
.locator-content .display-1 { margin: 0 0 25px; font-size: 26px; font-weight: bold; text-align: left!important; }
.locator-content .display-2 { margin: 0 0 10px; font-weight: 600; font-size: 16px; }
.locator-content .sr-only { font-size: 15px; opacity: 0; }
.locator-content .btn { height: 30px; line-height: 30px; min-height: 30px; min-width: 137px; font-size: 14px; text-transform: none; font-weight: bold; padding: 0 15px; }


/* Search */
.locator-search { padding: 50px 25px 25px; position: relative;  }
.locator-search::before { content: ''; width: 100%; opacity: 0; height: 8px; background: rgba(var(--accent-rgb),.3); position: absolute; bottom: -8px; left: 0; z-index: 0;  transition: .4s; }
.locator-search::after { content: ''; width: 100%; opacity: 0; height: 8px; background: var(--accent); position: absolute; bottom: -8px; left: 0; z-index: 0; transition: .4s; animation-duration: 2s; animation-name: loading; animation-fill-mode: both; animation-iteration-count: infinite; }
.locator-search.loading-spinner::before { opacity: 1; }
.locator-search.loading-spinner::after { opacity: 1; }
.locator-search__icon { display: none; font-size: 30px; color: var(--primary); }
.locator-search__keyword { display: flex; align-items: center; padding: 15px 0 15px 5px; height: 50px; width: 100%; max-width: 100%; margin: 0; background: #fff; border-radius: 4px; border: 1px solid #999; }
.locator-search__keyword input { font-size: 16px; border: 0!important; outline: none!important; flex: 1 1 auto; padding: 10px; background: #fff!important; text-align: left; }
.locator-search__keyword input:focus-within, .locator-search__keyword input:active, .locator-search__keyword input:focus, .locator-search__keyword input:focus-visible, .locator-search__keyword input:target { background: #fff!important; }
.locator-search__keyword button { height: 49px; width: 49px; display: flex; align-items: center; justify-content: center; border: 0; background: none; transition: .4s; }
.locator-search__keyword button:hover i { color: var(--primary); }
.locator-search__keyword button i { color: #000; font-size: 25px; transition: .4s; position: relative; transform: rotateY(180deg); }
.locator-search__tags { display: flex; flex-wrap: wrap; grid-gap: 12px; margin: 25px 0 0; font-size: 16px; }
.locator-search__tags::before { content: 'Filter by services'; font-size: 16px; font-weight: 600; flex: 1 0 100%; line-height: 1; }
.locator-search__form-check { display: flex; flex: 0 0 auto; height: 40px; padding: 0 20px 0 10px; border-radius: 20px; box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.05); background: #fff; align-items: center; }
.locator-search__form-check-input { -webkit-appearance: initial; }
.locator-search__form-check-input::before { content: '\f00c'; color: #fff; height: 20px; width: 20px; font-size: 12px; border: 1px solid #999; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: "Font Awesome 6 Pro"; font-style: normal; font-weight: 600; -webkit-font-smoothing: antialiased; -webkit-transition: 0.3s; -o-transition: 0.3s; transition: 0.3s; }
.locator-search__form-check-input:hover::before { background: rgba(var(--primary-rgb),.4); }
.locator-search__form-check-input:checked::before { color: #fff; background: var(--primary); border-color: var(--primary); }
.locator-search__form-check-label { font-size: 16px; font-weight: 400; margin: 0 0 0 10px!important; line-height: 1.1; }
@media (min-width: 992px) {
  .locator-search { padding-left: 6vw; }
}
@media (min-width: 1112px) {
  .locator-search { padding-left: 75px; }
}

/* List */
.locator-list { padding: 5px 25px 25px; position: relative; }
.locator-list__empty { font-size: 18px; letter-spacing: .05em; font-weight: bold; margin-top: 70px; }
.locator-list__item { text-align: left; background: #fff; border-radius: 8px; padding: 25px 30px 30px; margin-bottom: 20px; line-height: 1.11em; box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.05); }
.locator-list__header { display: flex; flex-wrap: wrap; grid-gap: 20px; margin-bottom: 25px; flex-direction: row-reverse; justify-content: space-between; }
.locator-list__details { display: flex; grid-gap: 10px 20px; justify-content: space-between; }
.locator-list__contact-address { display: none; }
.locator-list__taglist { display: flex; flex-wrap: wrap; grid-gap: 10px 12px; }
.locator-list__tag { font-size: 14px; font-weight: bold; color: var(--gray-md); }
.locator-list__name { font-size: 20px; font-weight: 600; margin: 0 auto 20px 0; }
.locator-list__btn-list { display: flex; flex-direction: column; grid-gap: 10px; margin-top: auto; margin-left: auto; padding-top: 10px; justify-content: flex-end; }

/* Contact Info */
.locator__contact-item { padding-left: 30px; position: relative; font-size: 14px; }
.locator__contact-item a:not(:hover) { color: var(--body-text); }
.locator__contact-item ~ .locator__contact-item { margin-top: 20px; }
.locator__contact-icon { position: absolute; top: 0; left: 0; color: var(--gray-md); font-size: 20px; }

@media (min-width: 992px) {
  .locator-list { padding-left: 6vw; }
  .nesthub-locator { display: flex!important; position: relative!important; height: calc(100vh - var(--header-height)); }
  .locator-content { flex: 0 0 50%; }
}
@media (min-width: 1112px) {
  .locator-list { padding-left: 75px; }
  .locator-content { flex: 0 0 556px; }
}
@media (min-width: 1310px) {
  .locator-list__header { flex-wrap: nowrap; }
  .locator-list__name { flex: 1 1 35%; align-self: center; }
  .locator-list__taglist { flex: 1 1 65%; align-self: flex-start; }
}
@media (max-width: 500px) {
  .locator-content { overflow: hidden; }
}
@media (max-width: 500px) {
  .locator-list { padding: 25px 20px; }
}
@media (max-width: 449px) {
  .locator-list__btn-list .btn { flex: 1 1 100%; }
}

@-webkit-keyframes loading {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

@keyframes loading {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}


/* Details */
.locator-details { position: relative; top: 0; left: 0; width: 100%; bottom: 40px; display: none; padding: 50px 25px; font-size: 14px; line-height: 1.33em; z-index: 9; }
/* .locator-details { position: absolute; top: 0; left: 0; width: 100%; bottom: 40px; display: none; padding: 50px 25px; font-size: 14px; line-height: 1.33em; z-index: 9; } */
.locator-details h4 { color: var(--body-text); font-size: 14px; font-weight: bold; margin: 25px 0 10px; line-height: 1.38em; }
.locator-details h5 { color: var(--body-text); font-size: 16px; font-weight: bold; margin: 25px 0 5px; }
.locator-details::after { content: ''; display: block; height: 50px; }
.locator-details__panel { text-align: left; position: relative; background: #fff; border-radius: 8px; padding: 35px 24px; box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.05);  }
.locator-details__close { position: absolute; top: 65px; font-size: 25px; right: 45px; color: var(--body-text); transition: 0.5s; z-index: 2; }
.locator-details__close i::before { content: '\f00d'; }
.locator-details__close:hover { color: var(--accent); }
.locator-details__name { font-size: 20px; font-weight: 600; margin: 0 0 15px; }
.locator-details__contact-info { display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between; }
.locator-details__contact-info .locator-list__contact-address { display: block; }
.locator-details__contact-info .btn { margin-top: 15px; }
.locator-details__contact-details h4 { margin-bottom: 20px; }
.locator-details__contact-details .locator__contact-item:last-of-type { margin-bottom: 5px; }
.locator-details__hours { font-size: 14px; }
.locator-details__hours th { padding: 3px 20px 3px 0; font-weight: 400; vertical-align: top; }
.locator-details__hours td { padding: 3px; }
.locator-details__form .ion-form-group { margin-bottom: 10px; }
.locator-details__form input, .locator-details__form textarea { border: 1px solid #999!important; background: #fff; border-radius: 4px!important; box-shadow: none; padding: 10px 14px!important; }
.locator-details__form input:not([type="checkbox"]) { height: 50px; }
.locator-details__form textarea { height: 150px!important; padding-top: 17px; }
.locator-details__form button { background: var(--primary); color: #fff!important; border-color: var(--primary); padding: 0 15px; font-size: 14px; display: block; font-weight: bold; border-radius: 4px; height: 38px; line-height: 30px; width: 150px; margin-left: auto; margin-right: auto; transition: .5s; }
.locator-details__form button:hover { background: #fff; }
.locator-details__form .ion-form-group-checkbox { display: flex; flex-wrap: wrap; grid-gap: 10px; padding-bottom: 5px; }
.locator-details__form .ion-form-group-checkbox label:first-child { flex: 1 1 100%; padding-top: 5px; }
.locator-details__form .ion-form-group-checkbox label:has(span) { font-weight: 400; flex: 1 1 48%; font-size: 14px; line-height: 1; height: auto; margin: 0; display: flex; align-items: center; }

.locator-details__form .ion-form-group-radio label, .locator-details__form .ion-form-group-checkbox label { display: block; color: inherit; }
.locator-details__form .ion-form-group-radio label:not(:first-child), .locator-details__form .ion-form-group-checkbox label:not(:first-child) { width: 50%; display: inline-block; }
.locator-details__form .ion-form-group-radio input, .locator-details__form .ion-form-group-checkbox input { position: absolute; opacity: 0; cursor: pointer; height: 0; width: 0; }
.locator-details__form .ion-form-group-radio span, .locator-details__form .ion-form-group-checkbox span { display: flex; padding-left: 30px; min-height: 20px; align-items: center; position: relative; font-size: 14px; }
.locator-details__form .ion-form-group-radio span::before, .locator-details__form .ion-form-group-checkbox span::before { content: ''; position: absolute; left: 0; top: 0px; height: 20px; width: 20px; background: #fff; border: 1px solid #999; border-radius: 4px; display: block; transition: 0.3s; }
.locator-details__form .ion-form-group-radio span::after, .locator-details__form .ion-form-group-checkbox span::after { content: '\f00c'; color: #fff; font-size: 13px; position: absolute; left: 4px; top: -1px; font-family: "Font Awesome 6 Pro"; font-style: normal; font-weight: 600; line-height: 23px; -webkit-font-smoothing: antialiased; transition: 0.3s; }
.locator-details__form .ion-form-group-radio input:hover span::after, .locator-details__form .ion-form-group-checkbox input:hover span::before { color: rgba(var(--primary-rgb), 0.4); transition: 0.3s; }
.locator-details__form .ion-form-group-radio input:checked ~ span::after, .locator-details__form .ion-form-group-checkbox input:checked ~ span::before { background-color: var(--primary); border-color: var(--primary); transition: 0.3s; }


#locatorForm { display: block!important; }
#locatorForm:has(.ion-form-success) .ion-form, .ion-form-success ~ .ion-form-success { display: none!important; }
.recaptcha-message { display: none; color: #fff; padding: 10px; text-align: center; border-radius: 4px; }
@media (min-width: 992px) {
  .locator-details { padding-left: 6vw; }
}
@media (min-width: 1112px) {
  .locator-details { padding-left: 75px; }
}
@media (min-width: 400px) {
  .locator-details__form .ion-form { display: flex; flex-wrap: wrap; grid-gap: 15px; justify-content: center; }
  .locator-details__form .ion-form-group { flex: 1 1 100%; margin: 0; }
  .locator-details__form .ion-form-group-textarea, .locator-details__form .ion-form-group-checkbox, .locator-details__form input:has([name*="address"]) { flex-basis: 100%; }
}
@media (min-width: 400px) and (max-width: 991px) {
  .locator-details__form .ion-form-group:not(.ion-form-group-textarea) { flex-basis: calc(50% - 5px); }
}
@media (min-width: 650px) and (max-width: 991px) {
  .locator-details__panel { display: grid; grid-template-columns: 1fr 1fr; grid-column-gap: 30px; grid-template-areas:  "Logo Logo" "Contact-Info Contact-Form" "Services Services"; }
  .locator-details__logo { grid-area: Logo; }
  .locator-details__contact-info { grid-area: Contact-Info; }
  .locator-details__contact-form { grid-area: Contact-Form; }
  .locator-details__services { grid-area: Services; }
}
@media (max-width: 991px) {
  .locator-details { position: relative; }
  .locator-details__panel { padding: 45px 30px; }
}
@media (max-width: 500px) {
  .locator-details { padding: 25px 20px; }
  .locator-details__close { top: 35px; right: 30px; }
}
@media (max-width: 399px) {
  .locator-details__contact-form .ion-form-success { text-align: center; }
}

/* Send Message - only show contact form */
.locator-details.form-only .locator-details__contact-form { width: 465px; margin: 0 auto; max-width: 100%; }
.locator-details.form-only .locator-details__hours,
.locator-details.form-only .locator-details__services,
.locator-details.form-only .locator-details__contact-info { display: none; }
.locator-details.form-only .locator-details__panel { grid-template-columns: 1fr; grid-template-areas:  "Logo" "Contact-Form"; }
.locator-details.form-only .locator-details__contact-form:has(.ion-form-success) > h4 { display: none; }
.locator-details.form-only .locator-details__contact-form .ion-form-success { text-align: center; padding: 40px 0; }

/* Floating Form Labels */
.locator-details__form .ion-form .ion-form-group { position: relative; }
.locator-details__form .ion-form .ion-form-group:not(.ion-form-group-checkbox):not(.ion-form-group-radio) label { color: #999; font-weight: 400; margin: 0; position: absolute; font-size: 14px; bottom: 6px; left: 0; z-index: 2; height: 100%; padding: 1.5em 0 0 15px; overflow: hidden; text-align: start; -o-text-overflow: ellipsis; text-overflow: ellipsis; -webkit-text-overflow: ellipsis; white-space: nowrap; pointer-events: none; border: var(--bs-border-width) solid transparent; -webkit-transform-origin: 0 0; -ms-transform-origin: 0 0; transform-origin: 0 0; -webkit-transition: opacity 0.1s ease-in-out, -webkit-transform 0.1s ease-in-out; transition: opacity 0.1s ease-in-out, -webkit-transform 0.1s ease-in-out; -o-transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out; transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out; transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out, -webkit-transform 0.1s ease-in-out; }
.locator-details__form .ion-form-group ::-webkit-input-placeholder, .locator-details__form .ion-form-group select:invalid, .locator-details__form .ion-form-group label:not(.float-label) + select:not(:focus) { color: transparent!important; }
.locator-details__form .ion-form .ion-form-group:not(.ion-form-group-checkbox):not(.ion-form-group-radio):has(input:focus) label, .locator-details__form .ion-form .ion-form-group:has(textarea:focus) label, .locator-details__form .ion-form .ion-form-group:has(select:focus) label, .locator-details__form .float-label { -webkit-transform: translateY(-.8em) scale(.85); -ms-transform: translateY(-.8em) scale(.85); -moz-transform: translateY(-.8em) scale(.85); transform: translateY(-.8em) scale(.85); opacity: 1; }
.locator-details__form .ion-form-group-dropdown:has(.float-label) select:not(:focus), .float-label + select { color: var(--body-text)!important; }
.locator-details__form .ion-form-group-dropdown label { left: -1px!important; }
.float-label { -webkit-transform: translateY(-.8em) scale(.85); -ms-transform: translateY(-.8em) scale(.85); -moz-transform: translateY(-.8em) scale(.85); transform: translateY(-.8em) scale(.85); opacity: 1; }


/* Map
================================================== */
.locator-map { background: #9fd39f; flex: 1 1 auto; }
.locator-map--mobile { margin: 40px 0 20px; }
.locator-map .mapboxgl-popup-content { background: var(--dark); color: #fff; font-size: 15px; padding: 10px 20px 10px; border-radius: 10px; font-weight: bold; letter-spacing: .05em; display: flex; align-items: center; }
/* .locator-map .mapboxgl-popup-content::before { content: ''; background-image: url('https://pmi-resources.nesthub.com/images/pmi-icon.png'); background-size: contain; height: 50px; width: 52px; display: block; margin-right: 10px; background-repeat: no-repeat; } */
.locator-map .mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip, .locator-map .mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-tip, .locator-map .mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-tip { border-top-color: var(--dark); }
.locator-map .mapboxgl-popup-anchor-right .mapboxgl-popup-tip { border-left-color: var(--dark); }
.locator-map .mapboxgl-popup-anchor-left .mapboxgl-popup-tip { border-right-color: var(--dark); }
.locator-map .mapboxgl-popup-anchor-top .mapboxgl-popup-tip, .locator-map .mapboxgl-popup-anchor-top-left .mapboxgl-popup-tip, .locator-map .mapboxgl-popup-anchor-top-right .mapboxgl-popup-tip { border-bottom-color: var(--dark); }
.locator-map .mapboxgl-popup-close-button { color: #fff; }
@media (min-width: 992px) {
  .locator-map { height: 100vh; height: calc(100vh - var(--header-height)); }
}
@media (max-width: 991px) {
  .locator-map--mobile { height: 50vh; }
}

#geocoder { flex: 1 1 auto; text-align: left; z-index: 1; }
.mapboxgl-ctrl-geocoder { min-width: unset; max-width: 100%; background: none!important; }
.mapboxgl-ctrl-geocoder--input, input.mapboxgl-ctrl-geocoder--input, input.mapboxgl-ctrl-geocoder--input:focus { width: 100%!important; background: none!important; }
.mapboxgl-ctrl-geocoder--icon-search { display: none!important; }
.mapboxgl-ctrl-geocoder { box-shadow: none!important; width: 100%!important; }
.mapboxgl-ctrl-geocoder .mapboxgl-ctrl-geocoder--pin-right button { top: 50%; transform: translateY(-50%); background: none!important; color: var(--gray-dark); }
.mapboxgl-ctrl-geocoder .mapboxgl-ctrl-geocoder--pin-right button:hover { color: var(--primary); }
.mapboxgl-ctrl-geocoder--icon-close { color: inherit; height: 23px!important; margin: 0!important; }


#geocoder {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
  -webkit-animation-duration: 1.10s;
  animation-duration: 1.10s;
  animation-delay: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
