.map_wrapper{
  max-width:1440px;
  margin:auto;
  position:relative;}


* {
  box-sizing: border-box;
}

.sidebar {
  position: absolute;
  width: 30%;
  height: 800px;    
  top: auto;
  margin-right:20px;
  left: 0;
  overflow: hidden;
  border: 1px solid #4F5552;
  border-radius: 30px 30px 0 0;   
  border-bottom:none;
}

.map {
  position: absolute;
  left: 33.3333%;
  width: 65%;
  height:800px;
  top: 0;
  bottom: 0;
  border-radius:30px;
}

h1 {
  font-size: 22px;
  margin: 0 0 0 -2px;
  font-weight: 400;
  line-height: 20px;
  padding: 20px 2px;
}

a {
  color: #404040;
  text-decoration: none;
  transition: none!important;}
}

a:hover {
  color: #101010;
}

.heading {
  background: #fff;
  border-bottom: 1px solid #eee;
  min-height: 60px;
  line-height: 60px;
  padding: 0 40px;
  background-color: #538a30;
  color: #fff;
  text-transform: capitalize;
}

.listings {
  height: 100%;
  overflow: auto;
  padding-bottom: 60px;
}

.listings .item {
  display: block;
  border-bottom: 1px solid #4F5552;
  padding: 32px 32px 32px 40px;
  text-transform: capitalize;
}

.listings .item div{
  font-weight: 500;
  font-size: 17px;
  line-height: 140%;
  letter-spacing: 0%;
}

.listings .item:last-child {
  border-bottom: none;
}

.listings .item .title {
  display: block;
  font-weight: 700;
  text-transform: capitalize!important;
  font-size: 18px;
  line-height: 130%;
  letter-spacing: 0%;
}

.listings .item .title small {
  font-weight: 400;
  text-transform: capitalize;
}

.listings .item.active .title,
.listings .item .title:hover {
  color: #8cc63f;
}

.listings .item.active, .listings .item:hover, .listings .item:active, .listings .item .title:active {
  background-color: #F8F8F8;
}

::-webkit-scrollbar {
  width: 3px;
  height: 3px;
  border-left: 0;
  background: rgb(0 0 0 / 10%);
}

::-webkit-scrollbar-track {
  background: none;
}

::-webkit-scrollbar-thumb {
  background: #00853e;
  border-radius: 0;
}

.marker {
  border: none;
  cursor: pointer;
  height: 37px;
  width: 23px;
  background-image: url('https://content.mcc-hvac.com/hubfs/marker.svg');
}

.user-icon {
  width: 20px;
  height: 20px;
  background-color: red;
  border-radius: 50%;
}


/* Marker tweaks */
.mapboxgl-popup {
  padding-bottom: 50px;
}

.mapboxgl-popup-close-button {
  display: none;
}

.mapboxgl-popup-content {

  padding: 0;
  width: 400px;
}

.mapboxgl-popup-content h3 {
  background: #538A30;
  color: #fff;
  margin: 0;
  padding: 10px;
  border-radius: 3px;
  font-weight: 700;
  margin-top: -15px;
  font-size:20px;
}

.mapboxgl-popup-content h4 {
  margin: 0;
  padding: 10px;
  font-weight: 400;
}

.mapboxgl-popup-content div {
  padding: 10px;
}

.mapboxgl-popup-anchor-top > .mapboxgl-popup-content {
  margin-top: 15px;
}

.mapboxgl-popup-anchor-top > .mapboxgl-popup-tip {
  border-bottom-color: #91c949;
}

.mapboxgl-ctrl-geocoder, .mapboxgl-ctrl-geocoder .mapboxgl-ctrl-geocoder--input, #geocoder, .geocoder {
  width:100%!important;
  margin:0 auto;
  max-width:none!important;}

.mapboxgl-ctrl-geocoder{
  background-color:transparent!important;}

.mapboxgl-ctrl-geocoder--input{
  background-color:#ffffff!important;}

.mapboxgl-ctrl-geocoder, .mapboxgl-ctrl-geocoder .suggestions {
  box-shadow: none!important;}

.pwr-cta--custom-01 .hs-submit, .pwr-cta--custom-01 [class*=cta_button]:not(.pwr-cta):not(.pwr-cta--hubspot-style) {
  box-shadow: none!important;
}

@media (max-width: 1028px) {
  .mapboxgl-ctrl-geocoder {
    width: 100%!important;
    max-width:none!important;}
  .mapboxgl-ctrl-geocoder--icon-search {
    display:none!important;
  }
  .sidebar{
    position:relative;
    width:100%;}
  #map{
    position:relative;
    margin-top:20px;
    width: calc(100% + 80px);
    left: -40px;
    border-radius:0;}
  .mapboxgl-ctrl-geocoder--icon-search {
    top: 19px;
    right: 23px;
    left:unset!important;}
}
@media (min-width: 1028px) {
  .mapboxgl-ctrl-geocoder--icon-search {
    display:none!important;
  }
}





/* Additional CSS */
.map_wrapper .sidebar .toggle_button{
  line-height: normal;
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  row-gap: 12px;
}
.map_wrapper .sidebar .toggle_button label{
  cursor:pointer;
}
.map_wrapper .sidebar .toggle_button input{
  position:relative;
  left:auto;
}
input.mapboxgl-ctrl-geocoder--input{
  height:45px !important;
  padding-left:58px !important;
  padding-top:10.5px !important;
  padding-bottom:10.5px !important;
}
.map_wrapper .sidebar .mapboxgl-ctrl-geocoder button:not(.mapboxgl-ctrl-geocoder--button){
  background: linear-gradient(180deg, #538A30 -42.59%, #2D302C 77.48%);
  width:38px;
  height:38px;
  position:absolute;
  top:3.5px;
  left:4px;
  border:none;
  border-radius:50%;
  cursor:pointer;
}
.map_wrapper .sidebar .mapboxgl-ctrl-geocoder button.mapboxgl-ctrl-geocoder--button{
  top:12px;
  background:none;
}
.map_wrapper .sidebar .listings button.pwr-cta_button,
.map_wrapper .sidebar button#use-my-location{
  margin-top:16px;
  background: linear-gradient(179.1deg, #538A30 -70.33%, #2D302C 99.22%);
  padding:10px 60.5px 12px;
  width: 100%;
  cursor:pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  font-weight: 500;
}
.map_wrapper .sidebar .listings button.pwr-cta_button::before,
.map_wrapper .sidebar button#use-my-location::before{
  display:none;
}
.mapboxgl-ctrl-geocoder .mapboxgl-ctrl-geocoder--pin-right .mapboxgl-ctrl-geocoder--icon{
  top:12px;
}
.map_wrapper .sidebar input.mapboxgl-ctrl-geocoder--input{
  border:none !important;
  box-shadow: 3px 4px 9px 14.49px rgb(0 0 0 / 14%) inset;
}
.map_wrapper .sidebar .mapboxgl-ctrl-geocoder ul.suggestions.force-hide {
  display: none !important;
}
.map_wrapper .sidebar .listings button.pwr-cta_button{
  cursor:pointer;
}
.map_wrapper .sidebar .listings .item button.pwr-cta_button{
  width:auto;
}

@media(max-width:767px){
  body .map_wrapper .sidebar .listings .item button.pwr-cta_button,
  .map_wrapper .sidebar button#use-my-location{
    padding-left:10.5px;
    padding-right:10.5px;
    font-size:14px;
    gap:12px;
  }
  body .map_wrapper .sidebar .mapboxgl-ctrl-geocoder {
    min-width: auto;
  }
  body .map_wrapper .sidebar .heading{
    padding:0 20px;
  }
  body .listings .item{
    padding:20px;
  }
  .map_wrapper .sidebar .mapboxgl-ctrl-geocoder button.mapboxgl-ctrl-geocoder--button{
    top:6px;
  }
}