﻿/***** BEGIN RESET ***
header: font-family: industry, sans-serif;
body: font-family: neuzeit-grotesk, sans-serif;
**/

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;  
} 

hr {
    border: none;
    background: #3333331a;
    height: 1px;
    margin: 5% 0;
}


/*-------- COLORS --------

*/

/***** END RESET *****/
::-moz-selection {
    background: #ed2024; 
    color: #fff;
    text-shadow: none;
}
::selection {
    background: #ed2024;
    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: neuzeit-grotesk, sans-serif !important;
}

img {
    max-width: 100%;
}

p {
	font-family: neuzeit-grotesk, sans-serif;
	font-size: 16px;
	line-height: 1.25;
}

h1,h2,h3,h4,h5,h6 {
	letter-spacing: 1px;
	font-family: industry, sans-serif !important;
}

h2 {
    font-size: 36px;
    text-transform: uppercase;
}

a:link, a:visited, a:active {text-decoration:none;color: #000;
    font-weight: 600;
    transition: .3s all;}
a:hover {text-decoration:none;color: #ed2024;}



/*--- HEADER STYLES ---------------------*/
header {
    box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
	background: #fff;
}

.flex-head {
    justify-content: space-between;
    max-width: 90%;
    margin: 0 auto;
	padding: 10px 0;
	
    align-items: center;
}


.navigation {
   display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: right;
	gap: 30px;
}

.logo img {
    max-width: 100%;
    width: 110px;
}

.top-header a {
	font-size: 18px;
    font-weight: 900;
    text-transform: uppercase;
	margin-right: 20px;
}
a.head-mail {
    color: #000;
    margin-right: 20px;
}

a.head-phone {
	color: #ed2024;
	
}



/*---BODY--------------------------------*/

.grey-bg {
	background: #f1f1f1
}

.wid90 {
	width: 90%;
	margin: 0 auto;
}

#pad-xl {
	padding: 5% 0;
}

#pad-l {
	padding: 60px 0;
}

.flex-container {
	display: flex;
}

.center {
	text-align: center;
}

/*--HERO---*/
.hero {
	background: #000;
	    display: flex;
    justify-content: space-between;
	align-items: center;
}

.hero-text, .hero-img {
    flex: 1;
}

.hero-wrap {
    color: #fff;
    padding: 50px 0;
    margin-left: 10%;
}

.hero-wrap h1 span {
    font-family: neuzeit-grotesk, sans-serif !important;
    font-size: 28px;
    font-weight: 500;
	text-transform: none !important;
	padding-bottom: 10px;
	display: inline-block;
	line-height: 1 !important;
}

.hero-wrap h1 {
    font-size: 64px;
    line-height: 1;
    margin-bottom: 20px;
	text-transform: uppercase !important;
}

form.hero-search {
    display: flex;
    justify-content: space-between;
	    gap: 10px;
	margin-top: 30px;
}

.search-input {
    flex: 1;
    display: contents;
}

.search-input input {
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
    font-family: neuzeit-grotesk, sans-serif !important;
	border-radius: 3px;
	border: none;
	
}

.search-btn button {
    padding: 10px 30px;
    text-transform: uppercase;
    font-family: industry, sans-serif;
    box-sizing: border-box;
    border: none;
    border-radius: 3px;
	background: #ed2024;
	color: #fff;
	font-size: 14px;
	letter-spacing: 2px;
	font-weight:800;
	cursor: pointer;
}

.overlapimg {
    width: 50%;
	height: 250px;
}

.hero-half {
    flex: 1;
    text-align: center;
	    padding: 25px 0;
}

.hero-img {
    position: relative;
	height: 100%;
    width: 100%;
}


.hero-half img {
    max-width: 100%;
    width: 80%;
    margin: 0 auto;
    text-align: center;
}

/*---HOME PAGE--*/
.home-txt {
	width: 75%;
}

.home-txt h2 {
    font-size: 42px;
    line-height: 1;
    margin-bottom: 20px;
}

.home-txt h2 span {
    font-weight: 400;
}

.button-wrapper {
    display: flex;
    gap: 20px;
    margin-top: 30px;
}

.cat-slide {
	margin-top: 50px;
}
.cat {
    margin: 10px;
    background: #fff;
    border-bottom: 5px solid #ed2024;
	box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
	transition: .3s all;
}



.cat:hover {
	border-bottom: 5px solid #000;
}
.cat img {
    max-width: 100%;
    width: 100%;
}

.cat-txt {
    padding: 10px 0;
    width: 90%;
    margin: 0 auto;
    color: #000;
    text-transform: uppercase;
}

.cat-txt h3 {
    font-size: 16px;
	font-weight: 800;
	transition:.3s all;
}


.cat-txt span {
	font-weight: 500 !important;
}

.race-banner {
	background: linear-gradient(0deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0.5048144257703081) 100%), url("/siteart/bg-img.jpg") no-repeat;
	background-size: cover;
	background-position: center;
    padding: 4% 0;
	margin-bottom: -1px !important;
}

.race-banner h2 {
    text-transform: uppercase;
    font-size: 44px;
    color: #fff;
    line-height: 1.25;
    margin-bottom: 20px;
}

.race-banner .wid90 {
    max-width: 900px;
    margin: 0 5%;
}

/*--CONTACT PAGE --*/

.black-bg {
	background: #000;
}
.sub-hero {
    padding: 80px 0;
    display: flex;
    align-items: center;
}

.sub-herotxt {
    width: 90%;
    margin: 0 auto;
    color: #fff;
    text-align: center;
}
.sub-herotxt h1 {
    font-size: 55px;
    text-transform: uppercase;
}

.flex-contact {
	gap: 70px;
}
.flex-contactform {
    flex: 2;
    gap: 70px;
}

.flex-contactinfo {
	flex: 1;
}

.contact-info p {
    margin-top: 15px;
}

.contact-info a {
    margin-top: 15px;
    display: inline-block;
    color: #000;
    font-weight: 600;
	transition: .3s all;
}

.contact-info a:hover {
	color: #ed2024;
}

.red-txt {
	color: #ed2024;
}

.contact-info ul {
  margin-left: 20px;
    line-height: 1.5;
}

/*---RACING PAGE----*/
.bgr-section {
	margin-bottom: 20px;
}
.race-page {
	background: #000;
}
.racing-nav {
	margin: 30px auto;
	width: 90%;
	gap: 20px;
	justify-content: space-between;
}

.racing-nav a {
	flex: 1;
}

.flex-crew {
	gap: 60px;
}

.team-img img {
	max-width: 100%;
	
}
.team-name {margin: 20px 0;}

.news-story {
	flex-basis: 45%;
    background: #fff;

}

#blog-title {
    font-size: 28px;
    color: #ed2024;
}


.gallery-img {
	gap: 15px;
    flex-wrap: wrap;
    justify-content: space-between;
}
.gallery-img img {
    max-width: 100%;
    width: 100%;
}

.gallery-img a {
    flex-basis: 19%;
}

.video-wrap {
       width: 32%;
    position: relative;
    padding-bottom: 16.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}
.video-wrap iframe,.video-wrap object,.video-wrap embed {
    border: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


.flex-news {
    gap: 30px;
	    padding: 30px 0;
}

.text-wrap {
    padding: 30px;
	    text-align: left;
}

p.news-date {
    margin-bottom: 20px;
    font-style: italic;
    color: #818181;
}

.news-img {
    display: inline-block;
}


.news-img img {
    margin: 30px auto 0;
    max-width: 100%;
}

.wrap {
    padding: 20px;
    background: #fff;
    display: inline-block;
}

.white-bg {
    background: #fff;
    padding: 4% 0;
}

.flex-sponsors {
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}

.sponsor {
    /* flex: 1; */
    flex-basis: 18%;
}

.sponsor img {
    max-width: 100%;
    width: 100%;
}
/*-- ACCORDION ---*/


.accordion {
	background: transparent;
    color: #444;
    cursor: pointer;
    padding: 22px 0;
    font-size: 18px;
    width: 100%;
    text-align: left;
    border: none;
    outline: none;
    transition: 0.4s;
    border-bottom: 1px solid #a5a5a5;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Add a background color to the button if it is clicked on (add the .active class with JS), and when you move the mouse over it (hover) */
.active, .accordion:hover {
}


/* Style the accordion panel. Note: hidden by default */
.panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.2s ease-out;
}



.accordion:after {
  content: '+'; /* Unicode character for "plus" sign (+) */
  font-size: 28px;
  color: #000;
  float: right;
  margin-left: 5px;
}

.active:after {
  content: "-";
	 font-size: 28px;
  color: #000;
  float: right;
  margin-left: 5px;/* Unicode character for "minus" sign (-) */
}

/*--------BUTTON STYLES--------------------*/

button.black-btn, button.red-btn,.submit-btn {
	padding: 15px 0;
    text-transform: uppercase;
    font-family: industry, sans-serif;
    box-sizing: border-box;
    border: none;
    border-radius: 3px;
	 font-size: 14px;
    letter-spacing: 2px;
    font-weight: 800;
    max-width: 100%;
    cursor: pointer;
    width: 200px;
	transition: .3s all;
}
button.red-btn,.submit-btn {
    
    background: #ed2024;
    color: #fff;
   
}

button.red-btn:hover, .submit-btn:hover, button.black-btn:hover {
	box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}

button.black-btn {
	background: #000;
	color: #fff;
}

button.race-btn {
    flex: 1;
    width: 100%;
    padding: 10px;
    border: none;
    background: #ed2024;
    font-family: industry, sans-serif;
    border-radius: 5px;
    font-size: 18px;
    text-transform: uppercase;
    font-weight: 500;
    color: #fff;
    cursor: pointer;
    transition: .3s all;
}

button.race-btn:hover {
    box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
    background: #fff;
    color: #ed2024;
}

.thank-page {
    justify-content: center;
	max-width: 700px;
	margin: 0 auto;
	width: 90%;
}

.thank-page a {
    flex: 1;
}

.thank-page button {
   width: 100%;
}
/*-------- FOOTER STYLES ----------------*/
footer{
	background: #000;
}

.flex-footer {
    justify-content: space-between;
    width: 90%;
    margin: 0 auto;
    padding: 40px 0;gap: 30px;
}

p.foottitle {
    font-family: industry, sans-serif;
    text-transform: uppercase;
    font-weight: 900 !important;
    font-style: italic;
    font-size: 18px;
	color: #fff !important;
    margin-bottom: 15px;
	
}

.foot-col a,.foot-col p, .foot-col ul li {
    color: #eeeeee;
	line-height: 1.5;
    text-transform: uppercase;
	font-weight: 400;
}

ul.foot-nav,.foot-col ul li {
    line-height: 2;
}

.foot-col a:hover {
	color: #bababa !important;
}

a.red-link {
    color: #ed2024 !important;
    font-weight: 600;
    font-family: industry, sans-serif;
    letter-spacing: 1px;
    margin-top: 30px;
    display: inline-block;
}

a.red-link:hover {
	color: #fff !important;
}
/*----INVENTORY STYLES - KEEP AT BOTTOM OF CSS----*/


.list-top-section .list-title .list-title-text,.list-content .price-container .price{
	
    font-family: industry, sans-serif !important;
	text-transform: uppercase !important;
}

.list-top-section .list-title .list-listings-count {
	 color: #ed2024 !important;
}

.view-listing-details-link:hover {
	background: #f1f1f1 !important;
	 color: #ed2024 !important;
}

.view-listing-details-link,.faceted-search-content .selected-facets-container .selected-facet {
	background: #ed2024 !important;
}

.view-listing-details-link {
	font-weight: normal !important;
	color: #fff !important;
}

.detail__specs-label, .detail__specs-label_showroom {
	background: #fff !important;
}
/*---------- RESPONSIVE STYLES ----------*/

@media only screen and (max-width: 1500px) {
	.hero-half {
		margin: 0 30px;
	}
	
	.hero-half img {
		width: 100%;
	}
	
	.hero-wrap h1 {
    font-size: 54px;
	}
	
}


@media only screen and (max-width: 1340px) {
.gallery-img a {
        flex-basis: 22%;
}
	.video-wrap {
		    flex: 1;
	}
}

@media only screen and (max-width: 1200px) {
	.hero-wrap h1 {
    font-size: 42px;
}
	
	.flex-crew {
		flex-wrap: wrap;
		justify-content: center;
		gap: 30px;
	}
	
	.sponsor {
    flex-basis: 23%;
}
	.home-txt {
		width: 100%;
	}
	
	.flex-footer,.flex-contact{
		flex-wrap: wrap;
	}
	
	.flex-contactform,.flex-contactinfo {
		flex-basis: 100%;
	}
	.foot-col{
		flex-grow: 1;
	}
}



@media only screen and (max-width: 970px) {
	.hero-half {
		display: none;
	}
	.hero-wrap {
		width: 90%;
		margin: 0 auto;
	}
	
	.gallery-img a {
        flex-basis: 30%;
}
	
	.racing-nav {
    margin: 15px auto;
    width: 95%;
    gap: 15px;
		font-size: 16px;
	}
	.flex-news,.racing-nav {
		flex-wrap: wrap;
	}
	
	.news-story {
		flex-basis: 100%;
	}
	
	.racing-nav a {
    flex: 1;
    flex-basis: 26%;font-size: 16px;
}
	
	button.race-btn {
		font-size: 16px;
	}
	
}


@media only screen and (max-width: 900px) {
	.video-wrap {
		padding: 28% 0;
		flex-basis: 100%;
	}
	
		.sponsor {
    flex-basis: 30%;
	}
	
	.race-banner .wid90 {
		max-width: 90%;
		margin: 0 auto!important;
	}
	
	.race-banner h2 {
		font-size: 32px;
	}
}

@media only screen and (max-width: 715px) {
	.foot-col{
		flex-basis: 100%;
	}
}
	
	
@media only screen and (max-width: 600px) {

	.gallery-img a {
        flex-basis: 45%;
		flex-grow: 1;
	}
	
		.sponsor {
    flex-basis: 45%;
}
	
	.race-banner {
		padding: 30px 0;
	}
	
	#pad-xl {
		padding: 40px 0;
	}
	
	.button-wrapper a {
    flex: 1;
}
	.button-wrapper button {
		width: 100%;
	}
	
}

@media only screen and (max-width: 510px) {
	.racing-nav a {
    flex-basis: 33%
}
	.gallery-img a
	{
		flex-basis: 100%;
	}
	
	.top-header a {
    font-size: 16px;
		margin-right: 0px;
	}
	
	
	.top-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
		gap: 10px;
}
	a.head-phone {
		flex-basis: 100%;
	}
}


@media only screen and (max-width: 330px) {
	.racing-nav a {
    flex-basis: 100%
}
}

