/***** Mobile First *****/

/*Extra small devices (portrait phones, less than 576px)
No media query since this is the default in Bootstrap*/

@media (min-width: 375px) {
  .hero-carousel h1 {
    font-size: 32px;
  }
  .hero-carousel p {
    font-size: 16px;
  }
}

/*Small devices (landscape phones, 576px and up)*/
@media (min-width: 576px) {
}

/*Medium devices (tablets, 768px and up)*/
@media (min-width: 768px) {
  /***** Main Navigation *****/
  .sub-menu ul.first li a {
    padding: 10px 20px;
  }

  /***** Hero Carousel *****/
  .hero-carousel .main-img {
    /*height: calc(100vh - 115px);*/
  }
  .hero-carousel .text {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
  }
  .hero-carousel h1 {
    font-size: 55px;
    color: #fff;
  }
  .hero-carousel p {
    color: #fff;
  }
  .hero-carousel .slick-prev {
    left: 20px;
    background: url(../images/icons/slidearw_l.png) no-repeat center;
  }
  .hero-carousel .slick-next {
    right: 20px;
    background: url(../images/icons/slidearw_r.png) no-repeat center;
  }
  .hero-carousel .slick-prev,
  .hero-carousel .slick-next {
    z-index: 999;
    width: 22px;
    height: 34px;
  }
  .hero-carousel .slick-prev:before,
  .hero-carousel .slick-next:before {
    display: none;
  }

  /***** Products Carousel *****/
  .carousel-product .slick-prev,
  .carousel-product .slick-next {
    top: 40%;
  }
  .carousel-product .slick-prev,
  .carousel-support .slick-prev,
  .carousel-industries .slick-prev,
  .logo-grid .slick-prev {
    left: -15px;
    background: url(../images/icons/arrow_left.png) no-repeat center;
  }
  .carousel-product .slick-next,
  .carousel-support .slick-next,
  .carousel-industries .slick-next,
  .logo-grid .slick-next {
    right: -15px;
    background: url(../images/icons/arrow_right.png) no-repeat center;
  }

  /***** Cards *****/
  .two-column-card .card-title {
    font-size: 24px;
  }

  /***** Our Strategic Alliances *****/
  .logo-grid {
  }
  .logo-grid .logo-box {
    width: 25%;
  }

  /***** Services Include *****/
  ul.services-include li {
    width: 50%;
  }
}

/*Large devices (desktops, 992px and up)*/
@media (min-width: 992px) {
  h2 {
    font-size: 48px;
  }
  h3 {
    font-size: 40px;
  }
  h4 {
    font-size: 32px;
  }
  h5 {
    font-size: 24px;
  }
  h6 {
    font-size: 20px;
  }

  /***** Top Bar *****/
  .topbar {
    height: 35px;
  }

  /***** Main Navigation *****/
  .main-nav {
    height: 80px;
    padding: 0;
  }
  .main-nav .navbar-nav .nav-item {
    height: 80px;
    display: flex;
    align-items: center;
    border-bottom: 4px solid transparent;
  }
  .main-nav .navbar-nav .nav-item.active {
    border-bottom: 4px solid #ff3b3b;
  }
  .sub-menu .container {
    margin-left: calc(100% - 700px);
  }

  /***** Main Navigation *****/
  .navbar .menu:hover .dropdown-menu,
  .navbar .menu .dropdown-menu:hover {
    display: block;
    visibility: visible;
    opacity: 1;
    transition: visibility 0s, opacity 0.3s linear;
  }

  /***** Blocks *****/
  .block-overlap {
    position: absolute;
    top: -60px;
    left: 15px;
  }
  .block-overlap p.lead {
    font-size: 24px;
  }
  .block-overlap p {
    /*font-size: 20px;*/
  }

  /***** Blocks *****/
  .block-overlap {
    max-width: 600px;
  }
}

/*Extra large devices (large desktops, 1200px and up)*/
@media (min-width: 1200px) {
}

@media (min-width: 1400px) {
  .hero-carousel .slick-prev {
    left: 60px;
  }
  .hero-carousel .slick-next {
    right: 60px;
  }
  .carousel-product .slick-prev,
  .carousel-support .slick-prev,
  .carousel-industries .slick-prev,
  .logo-grid .slick-prev {
    left: -60px;
  }
  .carousel-product .slick-next,
  .carousel-support .slick-next,
  .carousel-industries .slick-next,
  .logo-grid .slick-next {
    right: -60px;
  }
}

/***** Non-Mobile First *****/

/*Large devices (desktops, less than 1200px)*/
@media (max-width: 1199.98px) {
}

/*Medium devices (tablets, less than 992px)*/
@media (max-width: 991.98px) {
  .navbar-light .navbar-toggler-icon {
    background-image: url(../images/icons/hamburger.png);
    background-size: inherit;
    background-position: right;
  }
}

/*Small devices (landscape phones, less than 768px)*/
@media (max-width: 767.98px) {
  .topbar p,
  .topbar a {
    font-size: 9px;
  }
  .navbar-light .navbar-brand img {
    max-width: 140px;
    height: auto;
  }
  /***** Hero Carousel *****/
  .hero-carousel figure {
    height: calc(100vh - 115px);
  }
  .hero-carousel .main-img {
    height: 40%;
  }
  .hero-carousel .text {
    height: 60%;
    background: #f5f5f5;
  }
}

/*Extra small devices (portrait phones, less than 576px)*/
@media (max-width: 575.98px) {
}

/*Extra large devices (large desktops)
No media query since the extra-large breakpoint has no upper bound on its width*/
