@charset "UTF-8";

.hero {
  margin-bottom: 20px;
  margin-top: -20px;
}

.hero .container {
  padding: 0;
}

@media (min-width: 768px) {
  .hero .container {
    padding-right: 15px;
    padding-left: 15px;
  }
}

.hero-slide {
  overflow: hidden;
  height: 300px;
}

@media (min-width: 1200px) {
  .hero-slide {
    height: 400px;
  }
}

@media (min-width: 992px) {
  .hero-slide {
    height: 330px;
  }
}

.hero1 {
  background: transparent url(/images/header-image.png) no-repeat;
  background-size: cover;
  padding: 40px 40px 20px 40px;
}

.hero1 .btn-hero {
  display: block;
}

@media (min-width: 992px) {
  .hero1 {
    background-size: 100%;
    padding-top: 134px;
    padding-left: 97px;
  }

  .hero1 .btn-hero {
    display: inline-block;
  }
}

@media (min-width: 768px) {
  .hero1 {
    padding-top: 57px;
    padding-left: 97px;
    display: inline-block;
  }

  .hero1 .btn-hero {
    display: inline-block;
  }
}

.hero1 h1 {
  font-size: 2.571em;
  margin-bottom: 24px;
  letter-spacing: -0.5px;
}

@media (min-width: 992px) {
  .hero1 h1 {
    width: 460px;
  }
}

.hero2 {
  background: transparent url(/images/header-image2.jpg) no-repeat;
  background-size: cover;
  padding: 40px 40px 20px 40px;
}

.hero2 .btn-hero {
  display: block;
}

@media (min-width: 992px) {
  .hero2 {
    background-size: 100%;
    padding-top: 134px;
    padding-left: 97px;
  }

  .hero2 .btn-hero {
    display: inline-block;
  }
}

@media (min-width: 768px) {
  .hero2 {
    padding-top: 57px;
    padding-left: 97px;
    display: inline-block;
  }

  .hero2 .btn-hero {
    display: inline-block;
  }
}

.hero2 h1 {
  font-size: 2.571em;
  margin-bottom: 24px;
  letter-spacing: -0.5px;
}

@media (min-width: 992px) {
  .hero2 h1 {
    width: 460px;
  }
}

.hero3 {
  background: transparent url(/images/header-image3.jpg) no-repeat center center;
  background-size: cover;
  padding: 40px 40px 20px 40px;
}

.hero3 .btn-hero {
  display: block;
}

@media (min-width: 992px) {
  .hero3 {
    background-size: 100%;
    padding-top: 134px;
    padding-left: 97px;
  }

  .hero3 .btn-hero {
    display: inline-block;
  }
}

@media (min-width: 768px) {
  .hero3 {
    padding-top: 57px;
    padding-left: 97px;
    display: inline-block;
  }

  .hero3 .btn-hero {
    display: inline-block;
  }
}

.hero3 h1 {
  font-size: 2.571em;
  margin-bottom: 24px;
  letter-spacing: -0.5px;
}

@media (min-width: 992px) {
  .hero3 h1 {
    width: 460px;
  }
}

@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .hero1 {
    background-image: url(/images/header-image@2x.png);
  }
}

.btn-hero {
  background-color: #fff;
  font-weight: 600;
  color: #263b5e;
  padding: 20px 48px 19px;
  text-align: center;
  font-size: 1.143em;
  letter-spacing: -0.5px;
  line-height: 14px;
}

.btn-hero:hover {
  background: #e6e5e5;
}

/** slick **/

.slick-dots {
  position: absolute;
  bottom: 46%;
  right: 0;
  display: none;
  width: 40px;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}

@media (min-width: 992px) {
  .slick-dots {
    bottom: 24%;
    display: block;
  }
}

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 5px 8px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 10px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  opacity: 1;
}

.slick-dots li button:before {
  font-size: 25px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: '\2022';
  text-align: center;
  opacity: .40;
  color: #fff;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
}

.slick-dots li.slick-active button:before {
  opacity: 1;
  font-size: 40px;
  color: #fff;
}

.slick-arrow {
  position: absolute;
  top: 44%;
  background: #263b5e;
  height: 32px;
  width: 32px;
  text-align: center;
  color: #fff;
  z-index: 1;
  border: 0;
  border-radius: 8px;
}

.slick-arrow.prev {
  left: -16px;
}

.slick-arrow.next {
  right: -16px;
}

.slick-arrow:hover {
  background: #0060ff;
}

.image-slider .slick-slide img {
  display: inline-block;
}

.image-slider .slick-slide {
  text-align: center;
}

/** Services **/

.services {
  margin-bottom: 39px;
}

.services .service {
  margin: 0 auto;
  width: 100%;
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
}

@media (min-width: 768px) {
  .services .service {
    float: left;
    margin-right: 20px;
    width: 212px;
  }
}

@media (min-width: 992px) {
  .services .service {
    width: 172px;
  }
}

@media (min-width: 1200px) {
  .services .service {
    width: 212px;
  }
}

.services .service a {
  background-size: cover;
}

@media (min-width: 768px) {
  .services .service a {
    background-size: auto auto;
  }
}

@media (min-width: 768px) {
  .services .service:last-child {
    margin-right: 0;
  }
}

.services .service .service-title {
  -webkit-transition: all .2s ease;
  transition: all .2s ease;
  position: absolute;
  bottom: -70px;
  z-index: 99;
  padding: 0 16px;
  font-weight: 500;
  letter-spacing: -0.5px;
  font-size: 1.143em;
  line-height: 1.5;
}

.services .service .service-overlay {
  -webkit-transition: all .2s ease;
  transition: all .2s ease;
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0)), to(black));
  background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0), black);
  opacity: 0;
  height: 100%;
  width: 100%;
  position: absolute;
}

.services .service:hover .service-overlay {
  opacity: 0.7;
  border-bottom: 4px solid #0060ff;
}

.services .service:hover .service-title {
  bottom: 21px;
}

.services a {
  display: block;
  color: #fff;
  height: 240px;
}

.service-1 {
  background: transparent url(/images/tile-machining-services.jpg) no-repeat;
}

.service-2 {
  background: transparent url(/images/tile-manufacturing-services.jpg) no-repeat;
}

.service-3 {
  background: transparent url(/images/tile-recondition-services.jpg) no-repeat;
}

.service-4 {
  background: transparent url(/images/tile-rebonding-services.jpg) no-repeat;
}

.service-5 {
  background: transparent url(/images/tile-brake-services.jpg) no-repeat;
}

/** Tech Corner **/

.tech-corner-img {
  float: right;
  padding-left: 36px;
  max-width: 230px;
}

.more-tech-media {
  display: table-cell;
  padding-right: 24px;
  width: 120px;
}

.more-tech-media .more-tech-img {
  width: 120px;
  height: 120px;
  overflow: hidden;
}

.more-tech-text {
  display: table-cell;
  padding-top: 23px;
  font-size: 1.143em;
  vertical-align: top;
  color: #fff;
}

.card .card-body .more-tech-text a {
  color: #657185;
  font-size: 1em;
  text-transform: underline;
}

