/* Dealer Locator */
.dealer_locator {
  margin: 65px 0;
}

.yNHHyP-marker-view {
  z-index: 1 !important;
}

#map {
  height: 80vh;
  transition: width 0.4s ease-in-out;
}

.header_wrapper {
  display: flex;
  margin-bottom: 15px;
}

.locator_header_dt {
  display: inline-block;
  align-self: flex-end;
  font-size: 35px;
  font-weight: 700;
  line-height: 1.00;
  font-family: Oswald, 'Lucida Grande', sans-serif;
}

.locator_header_mb {
  display: none;
}

.search_field {
  display: inline-block;
  align-self: flex-end;
  margin: 0 20px;
}

.user_input {
  border: none;
  border-bottom: 3px solid #c0c0c0;
  font-size: 18px;
  font-weight: 300;
  text-overflow: ellipsis;
  width: 400px;
  padding: 6px 0;
  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}

input {
  color: #000;
}

input:focus {
  border-bottom: 2px solid #000;
  outline: 0;
}

.hidden {
  display: none;
}

::-webkit-scrollbar {
  display: none;
}

.scroll {
  overflow-y: scroll;
}

.scroll_hide {
  overflow-y: hidden;
}

.output_parent {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
}

.map_wrapper {
  flex: 65%;
}

#load_overlay {
  display: none;
  position: absolute;
  align-items: center;
  justify-content: center;
}

.loading_icon {
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
}

.wave {
  width: 15px;
  height: 100px;
  background: linear-gradient(45deg, #48217a, #fff);
  margin: 10px;
  animation: wave 1s linear infinite;
  border-radius: 20px;
}

.wave:nth-child(2) {
  animation-delay: 0.1s;
}

.wave:nth-child(3) {
  animation-delay: 0.2s;
}

.wave:nth-child(4) {
  animation-delay: 0.3s;
}

.wave:nth-child(5) {
  animation-delay: 0.4s;
}

.wave:nth-child(6) {
  animation-delay: 0.5s;
}

.wave:nth-child(7) {
  animation-delay: 0.6s;
}

.wave:nth-child(8) {
  animation-delay: 0.7s;
}

.wave:nth-child(9) {
  animation-delay: 0.8s;
}

.wave:nth-child(10) {
  animation-delay: 0.9s;
}

@keyframes wave {
  0% {
    transform: scale(0);
  }

  50% {
    transform: scale(1);
  }

  100% {
    transform: scale(0);
  }
}


.map_fade {
  opacity: 0.3;
}



.side_panel {
  overflow-x: hidden;
  transition: all .2s ease-out;
  height: 80vh;
  background-color: #000000;
  color: #ffffff;
  min-width: 25%;
  max-width: 30%;
}

.productNameWrapper {
  margin: 15px;
  /* padding: 10px 0; */
}

.product_header {
  font-size: 1.17em;
  border-bottom: 2px solid #fff;
  text-transform: uppercase;
  font-weight: 700;
  padding-bottom: 10px;
  text-align: center;
}

.dealer_listing_item {
  cursor: pointer;
  line-height: 1.2;
}

.dealer_item_wrapper {
  display: flex;
  flex-direction: row;
  padding: 15px 15px 5px 0;
}

.dealer_item_pin {
  margin: 0 auto;
}

.dealer_col_left {
  width: 15%;
  display: flex;
  justify-content: center;
  /* margin-top: 5px; */
}

.dealer_col_right {
  width: 85%;


}

.dealer_panel_pin_wrapper {
  display: flex;
  justify-content: center;
}

.dealer_panel_pin {
  margin: 0 auto;
  font-size: 17px;
  color: #000;
  position: absolute;
  display: flex;
  align-content: center;
  align-items: center;
  z-index: 2;
  font-weight: 700;
}

.panel_pin_svg {
  width: 20px;
  position: absolute;
  z-index: 1;
}

.dealer_panel_name {
  font-weight: 700;
  text-transform: uppercase;
  /* font-size: 20px; */
}

.dealer_panel_name a {
  text-decoration: none;
  color: #ffffff;
}

.dealer_panel_name a:hover {
  transition: 0.3s;
  color: #d9d9d9;
  /* text-decoration-line: underline; */
}

.dealer_panel_address {}

.dealer_panel_phone a {
  text-decoration: none;
  color: #ffffff;
}

.dealer_panel_phone a:hover {
  transition: 0.3s;
  color: #d9d9d9;
}

.dealer_panel_directions_wrapper {
  padding-top: 10px;
}

.directions_fa {
  /* font-size: 20px; */
}

.dealer_panel_directions_link {
  text-decoration: underline;
}

.dealer_panel_directions_wrapper a {
  color: #ffffff;
}

.dealer_panel_directions_wrapper a:hover {
  transition: 0.3s;
  color: #d9d9d9;
  text-decoration-line: underline;
}

.gm-ui-hover-effect {
  display: none !important;
}

.info_name {
  text-transform: uppercase;
  font-weight: bold;
  margin: 5px 0;
  /* font-size: 15px; */
}

.info_phone {}

.info_website_btn {
  margin: 10px 0;
  padding: 10px 0;
  font-weight: bold;
  background: #000;
  text-align: center;
  border: #000 1px solid;
  color: #fff;
}

.info_website_btn:hover {
  background-color: #fff;
  color: #000;
  transition: 0.3s;
}

.info_website_a {
  text-decoration: none;
  text-transform: uppercase;
}


@media (max-width: 800px) {
  .user_input {
    width: 100%;
  }

  .output_parent {
    flex-direction: column;
  }

  .header_wrapper {
    display: block;
  }

  .locator_header_dt {
    display: none;
  }

  .locator_header_mb {
    display: block;
    font-size: 25px;
    font-weight: 700;
  }

  .search_field {
    margin: 10px 0;
    width: 100%;
  }

  #map {
    height: 65vh;
  }

  .side_panel {
    height: 100%;
    max-width: 100%;
    padding-bottom: 10px;
  }

  .map_wrapper,
  .side_panel {
    width: 100%;
  }

  .dealer_locator {
    margin: 10px 0;
  }

}


/* Additional Google Map styling changes*/

/* Dealer Marker number size */
.GMAMP-maps-pin-view {
  font-size: 16px !important;
}


.gm-svpc {
  display: none;
}

/* Hides the logo and tex options at the bottom of the map - remove if styling breaks elsewhere */
.gm-style>div:nth-child(14)>div:nth-child(1) {
  display: none;
}

.gm-style>div:nth-child(16) {
  display: none;
}

/* Hide Breadcrumb */
.breadcrumb {
  display: none;
}

/* Hero Banner */
#d2426966 .container-fluid {
  max-width: 100%;
  padding: 0px;
}

#d2426969 {
  background-image: url("@@tcm:74-2426964");
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;

  .border_banner_text_wrap {
    color: #fff;
    border-top: 10px #fff solid;
    border-bottom: 10px #fff solid;
    max-width: 40%;
    font-size: 1.8rem;
  }

  .border_banner_heading {
    font-weight: 500;
    line-height: 1.3;
    color: inherit;
    font-size: 18px;
  }



}

.cb_btn {
  position: absolute;
  right: 20%;
  text-align: right;
  font-family: Oswald, 'Lucida Grande', sans-serif;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 3rem;
  font-weight: 700;
  text-decoration: none;
}

.cb_btn a {
  padding: 0 10px;
}

.rd_btn {
  top: 45%;
}

.fd_btn {
  top: 55%;
}

.rd_btn a {
  color: #fff;
  background-color: #000;
  border: 1px solid #fff;

}

.fd_btn a {
  color: #000;
  background-color: #fff;
  border: 1px solid #000;
}

.rd_btn a:hover {
  transition: 0.3s;
  color: #000;
  background-color: #fff;
  border: 1px solid #000;
  text-decoration: none;

}

.fd_btn a:hover {
  transition: 0.3s;
  color: #fff;
  background-color: #000;
  border: 1px solid #fff;
  text-decoration: none;

}

/* Feature Banner */
#d2427046 {

  .border_banner_text_wrap {
    color: #fff;
    border-top: 10px #fff solid;
    border-bottom: 10px #fff solid;
    max-width: 40%;
    font-size: 1.8rem;
  }

  .border_banner_heading {
    font-weight: 500;
    line-height: 1.3;
    color: inherit;
    font-size: 18px;
  }

}

/* Products Block */
#d2426974 {
  .model_wrapper {
    margin-bottom: 20px;
  }

  .prod_table {
    width: 60%;
    margin: 2rem auto 1rem auto;
  }

  .model_wrapper {
    font-size: 18px;
  }

  .mod_header {
    border-bottom: 2px solid #000;
    font-weight: 700;
    margin-bottom: 20px;
  }

  .mod_prod {
    /* border-bottom: 1px solid #000; */
    padding: 2px 0;
    margin-bottom: 20px;

  }

  table {
    width: 100%;
  }

  td,
  th {
    padding: 5px;
  }

  tr:nth-child(2n) {
    background-color: #e7e7e9;
  }

  .carousel_heading {
    padding-top: 60px;
  }
}

/* Details Block */
#d2426976 {
  .model_wrapper {
    margin-bottom: 20px;

    @media (max-width: 900px) {
      margin-bottom: 30px;
    }
  }

  .flex_body_copy {
    padding: 0 30px;

    @media (max-width: 900px) {
      padding: 10px;
    }
  }
  .value_add_btn {
    margin: 20px 0;
    text-align: center;
    color: #fff;
    background-color: #000;
    border: 1px solid #000;
    padding: 10px 15px;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 18px;
    font-weight: 700;
  }

  .value_add_btn:hover {
    transition: 0.3s;
    color: #000;
    background-color: #fff;
    border: 1px solid #000;
  }

  .model_wrapper {
    font-size: 18px;
  }

  .mod_header {
    border-bottom: 2px solid #000;
    font-weight: 700;
    font-size: 35px;
  }

  .mod_prod {
    border-bottom: 1px solid #000;
    padding: 1px 0;
  }

  .mod_prod:hover {
    cursor: pointer;
    background-color: #000;
    color: #fff;
    transition: 0.3s;
  }

  .carousel_heading {
    padding-top: 60px;
  }

  .left_col {
    text-align: left;
  }

  .right_col {
    text-align: right;
  }

  table {
    width: 100%;
  }
}

@media screen and (max-width: 1236px) {
  .rd_btn {
    top: 42%;
  }

  .fd_btn {
    top: 60%;
  }
}

@media screen and (max-width: 700px) {
  .cb_btn {
    font-size: 2rem;
  }

  .rd_btn,
  .fd_btn {
    top: 103%;
  }

  .rd_btn {
    left: 0;
    right: 65%;
  }

  .fd_btn {
    left: 0;
    right: 5%;
  }


}

@media screen and (max-width: 400px) {
  .carousel_heading {
    font-size: 22px;
  }
}

/*  */
@media screen and (max-width: 900px) {
  #d2426969 {
    .border_banner_text_wrap {
      max-width: 90%;
      margin: auto;
      padding: 15px 0;
    }
  }

  #d2426974 {
    .prod_table {
      width: 100%;
    }
  }
}