﻿/***** BEGIN RESET *****/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
    background: transparent;
    border: 0;
    margin: 0;
    padding: 0;
}
ol, ul {
    list-style: none;
}
table {
    border-collapse: collapse;
    width: 100%;
}
td {
    vertical-align: top;
}
/* Make HTML 5 elements display block-level for consistent styling */
header, nav, article, footer, address {
    display: block;
}
/*-------- COLORS --------

*/
/***** END RESET *****/ ::-moz-selection {
    background: #000;
    color: #fff;
    text-shadow: none;
}
::selection {
    background: #000;
    color: #fff;
    text-shadow: none;
}
/* Clearfix */
.cf:before, .cf:after {
    content: " ";
    display: table;
}
.cf:after {
    clear: both;
}
.cf {
    *zoom: 1;
}
/*-------- BODY STYLES --------*/
body {
    font-family: forma-djr-micro, sans-serif !important;
}
h1, h2, h3, h4, h5, h6 {
    font-family: objektiv-mk2, sans-serif !important;
}
p {
    font-family: forma-djr-micro, sans-serif !important;
    font-size: 16px;
    line-height: 1.5;
}
a:link, a:visited, a:active {
    text-decoration: none;
}
a:hover {
    text-decoration: none;
}
hr {
    border: none;
    height: 1px;
    background: #e8e8e8;
}
/*--- HEADER STYLES ---------------------*/
header {
    box-shadow: rgba(0, 0, 0, 0.05) 0px 1px 2px 0px;
    position: relative;
    z-index: 9;
}
.wid90.flex-container.flex-head {
    align-items: center;
    justify-content: space-between;
}
.search-head {
    max-width: 220px;
    width: 100%;
    text-align: right;
    box-sizing: border-box;
}
.search-head i {
    line-height: 2;
}
.nav-wrap {
    flex: 1;
    text-align: center;
}
.logo{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-content: center;
    padding-bottom: 17px;
    padding-top: 11px;
}
.logo a {
    display: flex;
    padding: 5px 0;
}
.main-logo img {
    max-width: 100%;
    width: 220px;
}
.flex-logos {
    display: flex;
    align-items: flex-end;
}
.small-logo {
    display: inline-flex;
    align-items: flex-end;
    gap: 5px;
    color: #000;
    font-size: 14px !important;
    padding-bottom: 10px;
}
.small-logo img {
    max-width: 100%;
    width: 130px;
}
.small-logo p {
    font-size: 14px;
}
/*---header search---*/
.search-container {
    position: relative;
    display: inline-block;
    margin: 4px 2px;
    height: 50px;
    width: 50px;
    vertical-align: bottom;
}
.mglass {
    display: inline-block;
    cursor: pointer
}
.searchbutton {
    font-size: 22px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0;
    display: block !important;
}
.search:focus + .searchbutton {
    transition-duration: 0.4s;
    -moz-transition-duration: 0.4s;
    -webkit-transition-duration: 0.4s;
    -o-transition-duration: 0.4s;
    background-color: white;
    color: black;
}
input.search {
    position: absolute; /* Button width-1px (Not 50px/100% because that will sometimes show a 1px line between the search box and button) */ background-color: white !important;
    outline: none !important;
    border: none !important;
    padding: 0 !important;
    width: 0 !important;
    height: 100% !important;
    z-index: 10 !important;
    transition-duration: 0.4s !important;
    -moz-transition-duration: 0.4s !important;
    -webkit-transition-duration: 0.4s !important;
    -o-transition-duration: 0.4s !important;
}
.search:focus {
    width: 220px !important;
    letter-spacing: 1px !important;
    font-family: forma-djr-micro, sans-serif !important !important;
    flex: 1 !important;
    padding: 0 15px !important;
    box-sizing: border-box !important;
    border: none !important;
    line-height: 1.5 !important;
    border: 1px solid #eee !important;
}
.expandright {
    left: auto;
    right: 49px; /* Button width-1px */
}
.expandright:focus {
    padding: 0 0 0 16px;
}
.newsbanner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 20px 5% 20px 5%;
    align-items: center;
    border-bottom: solid 2px #df312d;
}
.newstext {
    width: 75%;
}
.newstext h2 {
    text-transform: uppercase;
    font-weight: 900;
    font-style: italic;
    font-size: 20px;
    margin-bottom: 0px;
    transition: .3s all;
    line-height: 20px;
    color: #df312d;
}
form.head-search {
    display: inline-flex;
    width: 100%;
}
/*---BODY--------------------------------*/
.black-bg {
    background: #111111;
}
.off-white {
    background: #fafafa;
}
.wid90 {
    width: 95%;
    margin: 0 auto;
}
.small-page-wid {
    max-width: 1200px;
}
.flex-container {
    display: flex;
}
.grid-container {
    display: grid;
}
.center {
    text-align: center;
}
#pad-l {
    padding-top: 40px;
    padding-bottom: 40px;
}
#pad-xl {
    padding-top: 80px;
    padding-bottom: 80px;
}
.relative {
    position: relative;
}
/*--------HOME STYLES--------------------*/
.hero-hold {
    position: relative;
}
.hero {
    position: relative;
}
.slideshow img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: center;
}
.hero-wrap {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .15);
    z-index: 1;
    color: #fff;
}
.slideshow .slick-slide {
    height: 65vh;
    max-height: 650px;
    min-height: 500px;
}
.hero ul.slick-dots {
    position: absolute;
    top: 85%;
    z-index: 9999;
    width: auto !important;
    position-area: center;
    display: flex;
    gap: 10px;
}
.slideshow {
    margin-bottom: 0 !important;
}
.hero ul.slick-dots li {
    height: auto;
    width: auto;
    transition: .3s all;
}
.hero ul.slick-dots li button {
    border: none;
    background: rgba(255, 255, 255, 0.3);
    height: 20px;
    width: 20px;
    transition: .3s all;
    color: transparent;
    border-radius: 2px;
}
.hero li.slick-active {
    background: rgba(255, 255, 255, 0.75) !important;
}
.hero ul.slick-dots li button:hover {
    background: rgba(255, 255, 255, 0.75);
}
.hero-txt {
    left: 50%;
    transform: translate(-50%, -50%);
    position: absolute;
    width: 90%;
    margin: 0 auto;
    text-align: right;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    gap: 30px;
    top: 75%;
}
.hero-txt h1 {
    line-height: 1.15;
    text-shadow: 2px 4px 3px rgba(0, 0, 0, 0.3);
    font-size: 36px;
    color: #fff;
    text-transform: uppercase;
    font-weight: 900;
    font-style: italic;
}
.hero-txt h1 span{
    font-size: 20px;
    color: #df312d;
}
.mobile-search-hero {
    display: none;
}
.search-bar {
    background: rgba(241, 241, 241, 0.75);
    width: 50%;
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 25px;
    box-sizing: border-box;
    display: flex;
}
.search-wrap {
    box-sizing: border-box;
    width: 100%;
}
form.hero-search {
    display: flex;
    border: 1px solid #e8e8e8;
}
.hero-search input[type="text"], .head-search input[type="text"]:not([class^="Mui"]) {
    background: #fafafa !important;
    letter-spacing: .5px;
    font-family: forma-djr-micro, sans-serif !important;
    flex: 1;
    padding: 8px 8px !important;
    box-sizing: border-box !important;
    border: none !important;
    line-height:  !important;
    font-size: 13px !important;
    height: auto !important;
    width: auto !important;
}
.home-txt h2, .sub-pg h2 {
    font-size: 28px;
    margin-bottom: 10px;
    text-transform: uppercase;
    font-weight: 900;
    font-style: italic;
}
section.sub-pg{
    padding-top:20px;

}
.home-section {
    overflow: hidden !important;
}
.sub-hero .hero-txt {
    top: 50% !important;
    display: block !important;
    text-align: left !important;
}
.sub-hero .hero-txt h1 {
    font-size: 48px !important;
}
.fullcenter {
    width: 100%;
    display: flex;
    justify-content: center;
}
.newsform {
    width: 100%;
}
.halfformfields {
    width: 49%;
    height: 40px;
    padding: 2px 10px;
    box-sizing: border-box;
    margin: 5px 0px;
}
.fullformfields {
    width: 98.25%;
    height: 40px;
    padding: 2px 10px;
    box-sizing: border-box;
    margin: 5px 0px;
}
.CaptchaWhatsThisPanel a {
    color: #000;
}
/*---CAT SLIDE--*/
.cat-wrap {
    margin-left: 5% !important;
    padding-top: 30px;
    margin-right: -5% !important;
    overflow: hidden !important;
}
a.cat {
    box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 8px;
    background: #fff;
    text-align: center;
    padding: 30px;
    box-sizing: border-box;
    margin: 10px;
    color: #000;
}
.cat h3 {
    font-size: 16px;
    margin-top: 20px;
}
.cat img {
    max-width: 190px;
    width: 100%;
    margin: 0 auto;
}
span.slide-btn {
    display: flex;
    gap: 10px;
    position: absolute;
    top: 5%;
    right: 0;
}
#white-bottom {
    background: #fff;
    padding: 40px 0 !important;
}
.home-section .flex-container {
    gap: 5%;
    align-items: center;
}
.home-img, .home-txt {
    flex-basis: 50%;
}
.home-img img {
    max-width: 100%;
    width: 100%;
}
.brand img {
    max-width: 180px;
    width: 100%;
    margin: 0 auto;
}
/*---SERVICE WRAP---*/
.service-wrap {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}
.service-wrap a {
    color: #000;
}
.service-img {
    height: 250px;
    position: relative;
}
.service-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.service-txt {
    width: 95%;
    margin: 0 auto;
    padding: 15px 0;
}
.service-txt h2 {
    text-transform: uppercase;
    font-weight: 900;
    font-style: italic;
    font-size: 18px;
    margin-bottom: 10px;
    transition: .3s all;
}
.service-img button.circle-btn {
    position: absolute;
    right: 5%;
    top: 5%;
    background: rgb(255 255 255 / 80%);
    transition: .3s all;
}
.service-wrap a:hover button.circle-btn {
    background: #fff;
}
.service-wrap a:hover .service-txt h2 {
    color: #df312d;
}
/*---CONTACT---*/
.sub-hero {
    max-height: 400px !important;
    min-height: 300px;
}
.sub-hero .hero-txt {
    padding: 5% 0 !important;
}
.sub-hero p {
    color: #fff;
    text-shadow: 2px 4px 3px rgba(0, 0, 0, 0.3);
    margin-top: 20px;
    letter-spacing: 1px;
    max-width: 950px;
}
.contact-hero {
    background: linear-gradient(207deg, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0.35) 100%), url("/siteart/contact-hero.jpg") no-repeat;
    background-size: cover;
    background-position: center 75%;
    height: 50vh;
    display: flex;
    align-items: center;
}
.locations {
    width: 100%;
}
.locations section {
    display: none;
    padding: 20px 0 0;
    border-top: 1px solid #eee;
}
.locations label {
    display: inline-block;
    margin: 0 0 -1px;
    padding: 15px 25px;
    font-weight: 600;
    text-align: center;
    border-radius: 5px 5px 0 0;
    color: #bbb;
    border: 3px solid transparent;
    letter-spacing: 1px;
}
.locations label:before {
    font-family: fontawesome;
    font-weight: normal;
    margin-right: 10px;
}
.locations label:hover {
    color: #888;
    cursor: pointer;
}
.locations input:checked + label {
    color: #818181;
    border: 1px solid #eee;
    border-top: 3px solid #df312d;
    border-bottom: 3px solid #fff;
}
#tab1:checked ~ #content1, #tab2:checked ~ #content2, #tab3:checked ~ #content3, #tab4:checked ~ #content4 {
    display: block;
}
/*---hydraulic---*/
.hydraulic-hero{
    
    background-position: center 28%;
    
    display: flex;
    align-items: center;
}
.hydraulic-img img{
        object-position: center 86%;
}
.hydraulic-ends img{
    width: 100%;
    height: 176px;
    max-width: 178px;
    object-fit: contain;
}
.hydraulic-head{
    line-height: 91px;
}
.hero-txt.hydraulic-head h1{
    color: #000;
    line-height: 81px;
    text-align: center;
    font-style: normal;
}
.hero-txt h1 span {
    font-size: 48px;
    color: #df312d;
    font-weight: lighter;
}
.parts-info>h2{
    line-height: 30px;
}
.hydraulic-head h2 span{
    font-weight: 900;
}
.hero-txt.hydraulic-head h2{
    text-align: center;
    text-transform: capitalize;
    font-weight: lighter;
    font-style: normal;
    line-height: 35px;
}
.wid1200{
    max-width: 1200px;
    padding-bottom: 20px;
}
.pad-bot-hyd{
    
    text-align: center;
    width: 35%;
}
#pad-2 hr{
    width: 80%;
}
.hyd-h2 {
    text-transform: capitalize !important;
    font-weight: 700 !important;
    font-style: normal !important;
}
#pad-2{
    padding-top: 0;
    padding-bottom: 40px;
}
.hydraulic-box{
    max-width: 1366px;
}
.hydraulic-ouside{
    padding-bottom: 20px;
}
.hydraulic-ouside2{
    padding-bottom: 40px;
}
.hydraulic-box .service-img{
    height: 419px;
    width: 100%;
    max-width: 562px;
    position: relative;
}
.hyd-phone-wrap{
    text-align: center;
}
.hyd-phone{
    padding: 10px 15px!important;
}

@media screen and (max-width: 650px) {
    .locations label:before {
        margin: 0;
        font-size: 16px;
    }
}
@media screen and (max-width: 400px) {
    .locations label {
        padding: 15px;
    }
}
.loc {
    display: flex;
    width: 100%;
    background: #fafafa;
    box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 8px;
    border-radius: 5px;
    overflow: hidden;
}
.loc .col1 {
    justify-content: flex-start;
    flex-basis: 30%;
    padding: 40px 0;
}
.loc .wid90 {
    width: 80%;
    flex: 1;
}
.loc h3.red-text {
    color: #df312d;
    text-transform: uppercase;
    font-weight: 900;
    letter-spacing: 1px;
    font-size: 32px;
    font-style: italic;
    margin-bottom: 10px;
}
.loc h4, .hours .title h4 {
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 10px;
    letter-spacing: 1px;
    font-size: 15px;
}
.odd span:first-of-type, .even span:first-of-type {
    font-weight: 600;
}
.loc span i {
    margin-right: 5px;
    color: #757575;
}
.even {
    background: #fafafa;
}
.odd {
    background: #fff;
}
.loc a {
    color: #000;
    padding-bottom: 5px;
}
.loc .col2 {
    justify-content: flex-start;
    flex-basis: 70%;
    position: relative;
    flex: 1;
}
.loc .col2 iframe {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    height: 100%;
    width: 100%;
}
.loc .col2 .col2-2 {
    display: inline-block;
    vertical-align: top;
    width: 45%
}
.loc .col1 p {
    margin-bottom: 15px;
}
/* Underline From Left */
.hvr-underline-from-left, .loc a {
    display: inline-block;
    vertical-align: middle;
    -webkit-transform: perspective(1px) translateZ(0);
    transform: perspective(1px) translateZ(0);
    box-shadow: 0 0 1px rgba(0, 0, 0, 0);
    position: relative;
    overflow: hidden;
}
.hvr-underline-from-left:before, .loc a:before {
    content: "";
    position: absolute;
    z-index: -1;
    left: 0;
    right: 100%;
    bottom: 0;
    background: rgba(0, 0, 0, 0.10);
    height: 2px;
    -webkit-transition-property: right;
    transition-property: right;
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
}
.hvr-underline-from-left:hover:before, .hvr-underline-from-left:focus:before, .hvr-underline-from-left:active:before, .loc a:hover:before, .loc a:focus:before, .loc a:active:before {
    right: 0;
}
.hours .odd, .hours .even {
    display: flex;
    justify-content: space-between;
    padding: 8px;
    font-family: forma-djr-micro, sans-serif !important;
    font-size: 15px;
    line-height: 1.5;
    border-bottom: 1px solid #ddd;
}
/*--------ABOUT STYLES--------------------*/
.about-hero {
    background: linear-gradient(207deg, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0.35) 100%), url("/siteart/about-hero.jpg") no-repeat;
    background-size: cover;
    background-position: center 95%;
    height: 50vh;
    display: flex;
    align-items: center;
}
/*--------Parts & Service STYLES--------------------*/
.service-hero {
    background: linear-gradient(207deg, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0.35) 100%), url("/siteart/parts-service.jpg") no-repeat;
    background-size: cover;
    background-position: center 45%;
    height: 50vh;
    display: flex;
    align-items: center;
}
.flex-page.flex-border {
    flex-direction: row;
    gap: 5rem;
    align-items: baseline;
}
.flex-page.flex-border:before {
    content: "";
    border: 1px solid #e8e8e8;
    align-self: stretch;
}
.parts-info {
    order: -1;
}
.half-page {
    flex-basis: 50%;
}
.half-page ul {
    list-style: disc;
    padding-inline-start: 20px;
    display: flex;
    gap: 10%;
    flex-wrap: wrap;
}
.half-page ul li {
    margin-bottom: 10px;
}
.half-page ul span {
    flex-basis: 45%;
}
span.txt-icon {
    opacity: .2;
    margin-right: 10px;
}
/*---SHOWROOM---*/
.grid-showrooms {
    margin-top: 30px;
    px;
    grid-template-columns: repeat(5, 1fr);
    gap: 30px;
}
.grid-showrooms .brand {
    box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 8px;
    background: #fff;
    text-align: center;
    padding: 30px;
    box-sizing: border-box;
    color: #000;
}
/*--------BUTTON STYLES--------------------*/
button {
    cursor: pointer;
}
button.round-red {
    background: #df312d;
    border: 1px solid #df312d;
    border-radius: 90px;
    padding: 15px 20px;
    min-width: 150px;
    color: #fff;
    font-family: objektiv-mk2, sans-serif !important;
    font-size: 14px;
    transition: .3s all;
    letter-spacing: 1px;
}
button.round-red:hover {
    background: #a31c19;
    border: 1px solid #a31c19;
}
.nav-round-red {
    background: #df312d;
    border: 1px solid #df312d;
    border-radius: 90px;
    padding: 0 5px;
    min-width: 150px;
    color: white !important;
    font-family: objektiv-mk2, sans-serif !important;
    font-size: 14px;
    transition: .3s all;
    letter-spacing: 1px;
}
.nav-round-red:hover {
    background: #a31c19;
    border: 1px solid #a31c19;
    color: white;
}
.nav-red-item{
    max-width: 155px;
    line-height: 14px!important;
    color: #df312d!important;
    padding-right: 21px !important;
    display: inline-grid !important;
}
.nav-red-item>span{
    font-weight: 200;
    color: #000;
    margin-bottom: 0;
    font-size: 12px;
}
.nav-red-item:hover{
    color: #a31c19 !important;;
}
.nav-red-background {
    background: #df312d;
    color: white !important;
    font-family: objektiv-mk2, sans-serif !important;
    transition: .3s all;
}
.nav-red-background:hover {
    background: #df312d;
    color: #484848 !important;
}
button.search-btn {
    background: #fafafa;
    padding: 8px;
    box-sizing: border-box;
    border: none;
    color: #df312d;
    font-size: 16px
}
span.slide-btn button, .circle-btn {
    border: 1px solid #bbbbbb;
    height: 40px;
    width: 40px;
    border-radius: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
}
span.slide-btn button i, .circle-btn {
    color: rgb(0 0 0 / 25%);
}
.submitform {
    background: #df312d;
    border: 1px solid #df312d;
    border-radius: 90px;
    padding: 15px 20px;
    min-width: 150px;
    color: #fff;
    font-family: objektiv-mk2, sans-serif !important;
    font-size: 14px;
    transition: .3s all;
    letter-spacing: 1px;
}
.submitform:hover {
    background: #a31c19;
    border: 1px solid #a31c19;
}
.email-round-red {
    background: #df312d;
    border: 1px solid #df312d;
    border-radius: 90px;
    padding: 15px 20px;
    min-width: 150px;
    color: #fff;
    font-family: objektiv-mk2, sans-serif !important;
    font-size: 14px;
    transition: .3s all;
    letter-spacing: 1px;
    position: absolute;
    bottom: 20px;
    left: 20px;
}
.email-round-red-sm {
    background: #df312d;
    border: 1px solid #df312d;
    border-radius: 90px;
    padding: 15px 20px;
    min-width: 150px;
    color: #fff;
    font-family: objektiv-mk2, sans-serif !important;
    font-size: 14px;
    transition: .3s all;
    letter-spacing: 1px;
    position: absolute;
    bottom: 68px;
    left: 20px;
}
button.email-round-red:hover {
    background: #a31c19;
    border: 1px solid #a31c19;
}
/*-------- FOOTER STYLES ----------------*/
footer {}
.flex-footer {
    justify-content: space-between;
}
.foot-col {
    flex: 1;
}
.foot-col, .foot-col a {
    color: #fff
}
a.foot-logo {
    display: inline-block;
    margin-bottom: 20px;
}
span.tristate-hold {
    display: flex;
    align-items: flex-start;
}
.tristate-hold p {
    font-weight: 900;
    line-height: 1;
    margin-right: 10px;
}
.foot-logo img {
    width: 100%;
    max-width: 200px;
}
.tristate-hold img {
    filter: brightness(0) invert(1);
    width: 100%;
    max-width: 160px;
}
span.foot-title {
    font-family: objektiv-mk2, sans-serif !important;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
    font-style: italic;
    font-size: 14px;
    margin-bottom: 10px;
    display: block;
}
.foot-col ul {
    display: flex;
    gap: 3rem;
}
.foot-col ul span {
    width: 100%;
}
.foot-col ul li {
    flex: 1;
}
.foot-col ul li a {
    font-size: 15px;
    line-height: 2;
}
/*----INVENTORY STYLES - KEEP AT BOTTOM OF CSS----*/
.inv-sub {
    background: url(/siteart/contact-hero.jpg) no-repeat;
    background-size: cover;
    background-position: 35% 65%;
    height: 20vh;
    max-height: 160px;
}
.listing-top-right a, .lower-detail-data-left button, .send-email-btn, .media-buttons a, .media-buttons button, .faceted-search, .listing-dealer-info a, .view-listing-details-link, .main-detail-data .contact-options a, .fin-calc-btn-mobile, .selected-facet, .page-nav, .apply-button, .back-button, .calculator-btn, .mobile-done-button, .list-content .list-error-container .info button:not(.login-button) {
    -moz-border-radius: 90px !important;
    -o-border-radius: 90px !important;
    -webkit-border-radius: 90px !important;
    border-radius: 90px !important;
}
.faceted-search-content .faceted-section-box .faceted-option-checkbox-container label input {
    margin: 2px 3px 3px 4px;
}
.faceted-text-input-searchType .search-type input[type=checkbox], .faceted-text-input-searchType .search-type input[type=radio] {
    margin: 0px 3px 0px 6px;
}
.bread-crumbs-heading .return-links .return-links-link span, #no-compare-listings, .bread-crumbs-heading .return-links .return-links-link i {
    color: #df312d !important;
}
.hosted-content .attachment-search .search-checkboxes label .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-bottom: 0px !important;
}
.view-listing-details-link, .selected-facet, .view-listing-details-link, .buy-now-link, .check-availability-link, .email-seller-link, .offer-btn, .buy-btn, .dealer-phone-mobile, .offer-btn-mobile, .send-email-btn-mobile, .send-wholesale-email-btn-mobile, .fin-calc-btn-mobile, .mobile-breadcrumb, .main-detail-data .contact-options a, button.g-recaptcha.button, .page-nav, .apply-button, .mobile-done-button, .dealer-btns-bottom a, .list-content .list-error-container .info button:not(.login-button) {
    background: #df312d !important;
}
.selected-facet, .dealer-phone-mobile, .offer-btn, .offer-btn-mobile, .fin-calc-btn-mobile, .send-wholesale-email-btn-mobile, .send-email-btn-mobile, .buy-now-link, .view-listing-details-link, .main-detail-data .contact-options a, button.g-recaptcha.button, .page-nav, .apply-button, .mobile-done-button, .list-content .list-error-container .info button:not(.login-button) {
    border: solid 1px #df312d !important;
    transition: ease all 0.2s !important;
}
.selected-facet:hover, .dealer-phone-mobile:hover, .offer-btn:hover, .offer-btn-mobile:hover, .fin-calc-btn-mobile:hover, .send-wholesale-email-btn-mobile:hover, .send-email-btn-mobile:hover, .buy-now-link:hover, .view-listing-details-link:hover, .main-detail-data .contact-options a:hover, button.g-recaptcha.button:hover, .page-nav:hover, .apply-button:hover, .mobile-done-button:hover, .dealer-btns-bottom a:hover, .list-content .list-error-container .info button:not(.login-button):hover {
    background: #a31c19 !important;
    color: #fff !important;
    border-color: #a31c19 !important;
}
.check-availability-link, .email-seller-link, .video-chat-link, .faceted-search, .faceted-show-all-btn, .cs-btns a, .calculator-btn {
    background: #000 !important;
    border: solid 1px #000 !important;
    transition: ease all 0.2s !important;
}
.check-availability-link:hover, .email-seller-link:hover, .video-chat-link:hover, .faceted-search:hover, .faceted-show-all-btn:hover, .cs-btns a:hover, .calculator-btn:hover {
    background: #333 !important;
    color: #fff !important;
    border-color: #333;
}
.list-content .list-title .list-listings-count, .list-content .list-main-section .list-container .list-listing .listing-top .listing-top-left .listing-main-stats .price, #parts-content .parts-top-section .parts-title-and-breadcrumbs .parts-title .parts-listings-count, #inv .error-message, #inv .info, .detail-content .detail-main-body .main-detail-data .detail-price, .detail-content .search-results, .list-content .list-top-section .listing-option-bar .list-listings-count, .detail-price, .compare-price, .compare-title {
    color: #000 !important;
}
.list-content .list-error-container .info .selected-facet {
    background-color: transparent !important;
    border: none !important;
}
.list-content .list-error-container .info .selected-facet button, .list-content .list-error-container .info .selected-facet button:hover {
    padding: 5px !important;
    background-color: transparent !important;
    color: #000 !important;
    font-size: 14px !important;
    border: none !important;
}
/*---------- RESPONSIVE STYLES ----------*/
@media only screen and (max-width:1600px) {
    .main-logo img {
        width: 200px;
    }
    .search-head {
        max-width: 200px;
    }
}
@media only screen and (max-width:1500px) {
    .main-logo img {
        width: 148px;
    }
    .search-head {
        max-width: 175px;
    }
    .small-logo img {
        width: 90px;
    }
    .primary ul li li a {
        font-size: 12px !important;
        font-weight: 550 !important;
    }

  
}
@media only screen and (max-width:1450px) {
    .grid-showrooms {
        grid-template-columns: repeat(4, 1fr);
    }
}
@media only screen and (max-width:1400px) {
    .loc .col1 {
        flex-basis: 40%;
    }
    .loc .col2 {
        flex: 1;
    }
    nav.primary ul li{
        padding-right: 12px;
    }
    .nav-red-item>span{
        font-size: 10px;
    }
}
@media only screen and (max-width:1300px) {
    nav.primary ul li{
        padding-right: 0px;
    }
   
    .nav-round-red{
        min-width: 127px !important;
        font-size: 10px !important;
    }
    .nav-red-item{
        padding-right: 7px !important;
    }
    .nav-wrap{
        padding-right: 11px;
        padding-left: 9px;

    }

}
@media only screen and (max-width:1275px) {
    .search-head {
        order: -1;
        flex-basis: 100%;
        max-width: 100%;
        padding: 8px 0px;
        background: #fafafa;
    }
    .search-wrap {
        width: 90%;
        margin: 0 auto;
    }
    .flex-head {
        flex-wrap: wrap;
        width: 100%;
    }
    .nav-wrap {
        margin-right: 5%;
        text-align: right;
    }
    .logo {
        margin-left: 5%;
    }
    .flex-page.flex-border {
        gap: 3rem;
    }
    .hero-search input[type="text"], .hero-search button, .hero-search input[type="text"]:not([class^="Mui"]) {
        background: #fff !important;
    }
}
@media screen and (max-width: 1150px) {
    .logo img {
        max-width: 200px;
    }
    .grid-showrooms {
        grid-template-columns: repeat(3, 1fr);
    }
    .search-container {
        display: block;
        width: 90%;
        margin: 0 auto;
    }
    .search-head i {
        line-height: 2.5;
        padding: 0 15px;
    }
    .search, .mglass {
        background: #fafafa;
    }
    .search:focus {
        width: 90%;
        background: #fff;
        box-sizing: border-box;
    }
    .home-section .flex-container {
        flex-wrap: wrap;
    }
    .home-img {
        display: none;
    }
    .home-txt, .home-txt {
        max-width: 100%;
        flex-basis: 100%;
    }
    span.slide-btn {
        margin-top: 20px;
        position: unset !important;
    }
    .loc {
        flex-wrap: wrap;
    }
    .loc .col1, .loc .col2 {
        flex-basis: 50%;
    }
    .search-head {
        padding: 10px 0;
    }
    .flex-page.flex-border {
        flex-wrap: wrap;
        gap: 0;
    }
    .half-page {
        flex-basis: 100%;
    }
    .parts-info {
        padding-bottom: 60px;
    }
    .service-info {
        padding-top: 60px;
        border-top: 1px solid #e8e8e8;
    }
    .hero-txt {
        flex-wrap: wrap;
        top: 70%;
    }
    .hero-title, span.hero-btn {
        flex-basis: 100%;
    }
    .email-round-red {
        bottom: 68px;
    }
    .nav-red-item{
        display: block !important;
        line-height: normal;
        max-width: none;
    }
    .nav-red-item>span{
        font-size: 10px;
        padding-top: 19px ;
    }
    .hyd-mobile{
        padding-bottom: 14px;
    }
    .grid-mobile{
        grid-template-columns: repeat(3, 1fr);
        width: 68%;
        max-width: 1200px;
        gap: 3px;
    }
        
}
@media screen and (max-width: 950px) {
    .flex-footer {
        flex-wrap: wrap;
        gap: 50px;
    }
    .foot-col:first-of-type {
        flex-basis: 100%;
    }
    .service-wrap {
        grid-template-columns: repeat(1, 1fr);
        gap: 30px;
    }
    .loc .col1 {
        flex-basis: 100%;
    }
    .loc .col2 {
        height: 250px;
    }
    .loc .wid90 {
        width: 90%;
    }
    .hero {
        align-items: flex-start;
    }
    .search-bar {
        width: 100%;
    }

     .grid-mobile{
        grid-template-columns: repeat(3, 1fr);
        width: 90%;
        height: 181px;
        gap: 10px;
        overflow: hidden;
        padding-left: 10px;
        padding-right: 10px;
        box-sizing: border-box;
        margin-bottom: 31px;
    }

    #pad-2{
        padding-bottom: 0;
    }
}
@media screen and (max-width: 900px) {
    .loc h3.red-text {
        font-size: 22px
    }
    .cat-wrap {
        margin: 0 auto;
        width: 90%;
    }
   
    
}
@media only screen and (max-width: 880px) {
    .sub-hero .hero-txt h1 {
        font-size: 36px !important;
    }
    .grid-mobile{
        height: 140px;
    }

}
@media only screen and (max-width:820px) {
    .newsbanner {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        padding: 15px 5%;
        align-items: center;
    }
    .newstext {
        width: 100%;
        text-align: center;
    }
    .newstext h2 {
        margin-bottom: 10px;
    }
    .newstext p {
        line-height: 16px;
        margin-bottom: 10px;
    }
}
@media only screen and (max-width:776px) {
    .locations label {
        width: 49%;
        box-sizing: border-box;
    }
    .sub-pg h2 {
        font-size: 22px !important;
    }
    .email-round-red {
        display: none;
    }
}
@media only screen and (min-width:777px) {
    .email-round-red-sm {
        display: none;
    }
}
@media only screen and (max-width:768px) {
    .foot-col {
        flex-basis: 100%;
    }
    .hero-txt h1 {
        font-size: 36px;
    }
    .grid-showrooms {
        grid-template-columns: repeat(2, 1fr);
    }
    .slideshow .slick-slide {
        height: 40vh;
        min-height: 300px;
    }
    .hero-txt .hero-title {
        transform: translate(0%, -100%);
    }
    .hero-txt .hero-btn {
        transform: translate(0%, -100%);
    }
    .email-round-red-sm {
        bottom: 60px;
    }
}
@media only screen and (max-width:650px) {
    .half-page ul span {
        flex-basis: 100%;
    }
    .search-bar {
        display: none;
    }
    .mobile-search-hero {
        display: block;
        padding: 25px;
        box-sizing: border-box;
        background: #222;
    }
}
@media only screen and (max-width:550px) {
    .slideshow .slick-slide {
        height: 25vh
    }
    .hero-txt {
        display: none !important;
    }
    .halfformfields {
        width: 98.25%;
    }
    .email-round-red-sm {
        display: none;
    }
}
@media only screen and (max-width:500px) {
    .inv-sub {
        display: none !important;
    }
    .hero-txt h1, .sub-hero .hero-txt h1 {
        font-size: 28px !important;
        line-height: 30px;
    }
    .hydraulic-head h1>span{
        font-size: 28px;
        line-height: 48px;
       
    }
    ul.inv-list {
        flex-wrap: wrap;
        gap: 0;
    }
    ul.inv-list span {
        flex-basis: 100%;
    }
    .search.expandright {
        max-width: 200px !important;
    }
    .locations label {
        width: 100%;
    }
    .loc h3.red-text {
        font-size: 28px;
    }
    .sub-hero {
        max-height: 400px !important;
        min-height: 206px;
    }
    .grid-showrooms {
        grid-template-columns: repeat(1, 1fr);
    }
}
@media only screen and (max-width:400px) {
    .logo, .nav-wrap {
        flex-basis: 100%;
        margin: 0;
        text-align: center;
    }
    .flex-head {
        justify-content: center;
    }
    .flex-logos {
        justify-content: center;
        padding: 15px 0;
        flex-wrap: wrap;
    }
    .nav-wrap {
        border-top: 1px solid #eee;
    }
    #pad-2{
        padding-top: 0;
        
    }
}