﻿/***** 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; } 
/***** END RESET *****/
::-moz-selection { background: #222;  color: #fff; text-shadow: none; } 
::selection { background: #222; color: #fff; text-shadow: none; }
/* Clearfix */
.cf:before, .cf:after { content: " "; display: table; } .cf:after { clear: both; } .cf { *zoom: 1; }

/*-------- BODY STYLES --------*/
body {

}

a:link, a:visited, a:active { text-decoration: none; } a:hover { text-decoration: none; }
hr { border:#000 1px solid; }

/*--- HEADER STYLES ---------------------*/
header {  }

.header { 
	width: 100%; position: relative; z-index: 1004; margin-bottom: -135px; 
	display: flex; flex-wrap: wrap; justify-content: center; align-items: center; row-gap: 20px; 
}
.topheader {
	display: flex; justify-content: space-between; align-items: stretch; 
	background: rgba(0, 0, 0, .6); width: 100%; height: 50px; padding: 0 20px; box-sizing: border-box; 
}
.topheader-left, .topheader-right { display: flex; align-items: stretch; height: 100%; }
.topheader-left { justify-content: flex-start; column-gap: 20px; }
.topheader-right { justify-content: flex-end; }
.topheader a { min-width: 50px; height: 100%; justify-content: center; }
.topheader a.listed { padding: 0 16px; }
.header-logo-div { position: relative; display: flex; justify-content: center; align-items: center; }
.header-logo { 
	position: relative; display: flex; justify-content: center; align-items: center; 
	filter: drop-shadow(0 2px 8px #000);
}
.header-logo img { object-fit: contain; object-position: 0% 50%; height: 65px; max-width: 78vw; }
.nav-div { 
	display: flex; justify-content: flex-end; align-items: center; width: calc(90% - 300px); 
}

/* Site Colors:
							--> Yellow: #fbb900; <--
	Hover Orange: #ff7700;
	Med Gray: #474747;
	Not-Black: #222222;
*/
/*---BODY--------------------------------*/
.bg-yellow { background: #fbb900; }

.txt-bold { font-weight: 700!important; }
.txt-default, .content-sect p:not(.listed):not(.listed-title) {
	font-family: 'titillium-web', sans-serif; font-size: 16px; color: #fff; 
}

.title { font-family: 'titillium-web', sans-serif; font-weight: 700; color: #fff; text-align: left; }
h1.title, .h1.title { font-size: 70px; line-height: 74px; }
h2.title { font-size: 40px; line-height: 44px; }
h3.title, .h3, h2.h3 { font-size: 30px; line-height: 34px; }
h4.title { font-size: 24px; line-height: 28px; }
.subtitle { 
	font-family: 'titillium-web', sans-serif; color: #fbb900!important; 
	font-size: 26px!important; line-height: 30px!important; font-weight: 600!important; text-align: left; 
}

/* Links / Buttons / CTAs / <a> */

.btnclass {
	display: flex; justify-content: center; align-items: center; 
	font-family: 'titillium-web', sans-serif; font-size: 18px; font-weight: 700; text-align: center; 
	color: #000; background: #fbb900; border: 1px solid #fbb900; 
	border-radius: 8px; box-shadow: 0px 1px 6px rgba(0, 0, 0, .5); 
	padding: 6px 22px; box-sizing: border-box; transition: .35s ease all;
}
.btnclass.btn-notblack, .btn-notblack { background: #222; border: 1px solid #222; color: #fff; }
.btnclass:hover { background: #ff7700; border: 1px solid #ff7700; color: #000; }
.btnclass.btn-notblack:hover, .btn-notblack:hover { 
	background: #ff7700; border: 1px solid #222; color: #000; box-shadow: none; 
}

.listed {
	display: flex; justify-content: flex-start; align-items: center; transition: .35s ease all; 
	font-family: 'titillium-web', sans-serif; font-size: 16px; font-weight: 600; color: #fff; 
}
.listed i { color: #fbb900; width: 24px; text-align: center; margin-right: 6px; }
a.listed:hover { color: #fbb900; }

.listed-title {
	display: flex; justify-content: flex-start; align-items: center; transition: .35s ease all; 
	font-family: 'titillium-web', sans-serif; font-size: 16px; font-weight: 600; color: #fff; 
}
a.listed-title:hover { color: #fbb900; }

.icon-link {
	display: flex; justify-content: center; align-items: center; width: 50px; height: 50px; 
	text-align: center; padding: 0; box-sizing: border-box; color: #fff; transition: .35s ease all; 
}
a.icon-link:hover { color: #fbb900; }

.invisilink { 
	font-family: inherit; font-size: inherit; font-weight: inherit; line-height: inherit; color: inherit; 
}
a.invisilink:hover { cursor: pointer; text-decoration: underline; color: #fbb900; }


/* Sections / Content Holders */

.content-sect { 
	display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; align-content: center; 
	column-gap: 20px; row-gap: 20px; padding: 80px min(5%, 120px); box-sizing: border-box; position: relative; 
}
.content-sect.center-style { justify-content: center; }
.content-sect.center-style .title, .content-sect.center-style .subtitle, .content-sect.center-style p { text-align: center; }
.content-sect .title, .content-sect p:not(.listed):not(.listed-title) { width: 100%; }

.sidelined-sect {
	display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; width: 100%;
	column-gap: 20px; row-gap: 20px; padding: 20px 0 32px 40px; box-sizing: border-box; position: relative; 
}
.sidelined-sect:before {
	position: absolute; z-index: 1; content: ""; top: 0; left: 0; width: 8px; height: 100%; background: #fbb900; 
}

.mission { 
	width: 100%; display: flex; justify-content: flex-start; align-items: center; min-height: 450px; 
	background: #222; background-image: url('/siteart/mission1.jpg'); 
	background-size: cover; background-position: center; background-repeat: no-repeat; 
	position: relative; 
}
.mission:after { 
	position: absolute; content: ""; z-index: 2; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, .75); 
}
.mission .content-sect { width: min(70%, 1200px); position: relative; z-index: 3; }
.mission .content-sect .title, .mission .content-sect .subtitle, .mission .content-sect p { text-shadow: 0 0 8px #000; }
.mission .content-sect .sidelined-sect:before { box-shadow: 0 0 8px #000; }

.lg-cta-sect {
	width: 100%; display: flex; justify-content: center; align-items: stretch; background: #474747; column-gap: 100px; 
	row-gap: 40px; padding: 40px 5%; box-sizing: border-box; 
}
.lg-cta-sect .ctas-holder {
	display: flex; justify-content: stretch; align-items: stretch; column-gap: 20px; row-gap: 16px; width: min(45%, 1150px); 
}
.lg-cta {
	display: flex; justify-content: center; align-items: center; border-radius: 40px; border: 1px solid #222; 
	position: relative; width: 50%; min-height: 320px; background: #ff7700; padding: 20px; box-sizing: border-box; 
}
.lg-cta img {
	position: absolute; z-index: 1; object-fit: cover; object-position: center; width: 100%; height: 100%; border-radius: 40px; 
	border: 1px solid #222; filter: brightness(.8); transition: .5s ease all; 
}
.lg-cta span {
	font-family: 'titillium-web', sans-serif; font-size: 24px; color: #fff; text-align: center; font-weight: 700; 
	position: relative; z-index: 3; text-shadow: 0 0 6px #000; transition: .5s ease all; 
}
a.lg-cta:hover img { filter: none; opacity: .25; }
a.lg-cta:hover span { text-shadow: 0 0 12px #ff7700; color: #000; }
.lg-cta-sect .content-sect { width: min(50%, 750px); padding: 40px 0; }

.inv-sect {
	width: 100%; background: #474747; padding: 40px; box-sizing: border-box; 
	display: flex; justify-content: center; align-items: flex-start; column-gap: 100px; row-gap: 40px; 
}
.inv-sect > .content-sect { width: min(45%, 520px); padding: 0; }
.inv-sect > .content-sect .sidelined-sect { padding-right: 0; }
.inv-sect .search-sect { width: min(50%, 820px); }
.search-sect {
	display: flex; flex-wrap: wrap; align-items: flex-start; align-content: flex-start; max-width: 820px; 
	border-top-left-radius: 24px; border-top-right-radius: 24px; border: 1px solid #000; 
}
.search-tab { 
	width: 50%; padding: 12px 20px; box-sizing: border-box; cursor: pointer; 
	font-family: 'titillium-web', sans-serif; font-size: 24px; text-transform: uppercase; text-align: center; font-weight: 700; 
}
.att-tab { border-top-left-radius: 24px; background: #222; color: #fff; }
.part-tab { border-top-right-radius: 24px; background: #fbb900; color: #000; }
.search-content { /* holds the toggled elements */
	display: flex; justify-content: stretch; align-items: flex-start; width: 100%; 
}
#searchAttachments { background: #222; }
#searchAttachments .title { color: #fff; }
#searchParts { background: #fbb900; }
#searchParts .title { color: #000; }
.search-toggled { 
	display: flex; flex-direction: column; align-items: center; justify-content: flex-start; 
	width: 100%; position: relative; padding: 18px 40px 24px 40px; box-sizing: border-box; 
}
.search-toggled .content-sect { 
	width: 100%; justify-content: space-between; padding: 0; row-gap: 12px; column-gap: 24px; margin-bottom: 24px; 
}
.search-toggled .content-sect .title { width: unset; }
.search-toggled form {
	display: flex; flex-direction: column; align-items: center; width: min(80%, 550px); row-gap: 8px; 
}
.search-toggled form input:not([type="submit"]), .search-toggled form select { 
	font-family: 'titillium-web', sans-serif; font-size: 16px; font-weight: 700; 
	display: flex; width: 100%; border: 1px solid #000; border-radius: 0; 
	padding: 8px 12px; box-sizing: border-box; 
}
.search-toggled form select { 
	border: none; border-right: 6px solid #fff; outline: 1px solid #000; 
	width: calc(100% - 2px); color: rgba(0, 0, 0, .65); padding: 8px 11px; 
}
.search-toggled form .optionclass { color: #222; }
.search-toggled form input[type="submit"] { 
	width: 100%; border-radius: 0; box-shadow: none; cursor: pointer; 
}

/* Homepage - default.htm */
.hero {
	width: 100%; height: min(1050px, max(600px, 100vh)); 
	background: #222; background-image: url('/siteart/homepage1.jpg?v=1.1'); 
	background-size: cover; background-position: 80% 90%; background-repeat: no-repeat; 
	display: flex; justify-content: center; align-items: center; position: relative; 
}
.hero:after { 
	position: absolute; content: ""; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, .2);  
}
.hero-overlay { position: relative; z-index: 2; column-gap: 30px; }
.hero-overlay .title, .hero-overlay .subtitle, .hero-overlay p { 
	text-align: center; text-shadow: 1px 1px 4px rgba(0, 0, 0, .5), 0 0 12px #000; 
}

/* Subpages */
.subhero { 
	width: 100%; display: flex; justify-content: center; align-items: center; 
	position: relative; min-height: 400px; padding: 140px 5% 24px 5%; box-sizing: border-box; margin: 0 auto; 
	background: #222; background-image: url('/siteart/thankyoupage.jpg'); 
	background-size: cover; background-position: center; background-repeat: no-repeat; 
}
.subhero:after {
	position: absolute; content: ""; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, .5); 
}
.subhero * { position: relative; z-index: 3; }
.subhero .title, .subhero h1, .subhero p { color: #fff!important; text-shadow: 0 0 10px #000; text-align: center; }
.subhero p { max-width: 650px; }

.subpages {
	width: 100%; margin: 0 auto; display: flex; justify-content: center; align-items: stretch; box-sizing: border-box; 
	background: #474747; border-bottom: 1px solid #000; 
}

/* contact-us.htm */
.contactpage { flex-wrap: wrap; }
.contactpage .content-sect { padding: 60px; }
.contactpage .form-div { width: 600px; padding: 0 0 80px 0; }
#location { width: min(1400px, calc(100% - 600px)); }
.map-sect { 
	display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; background: #474747; 
	
}
.map-sect .map-div { width: 100%; }
.map-div { display: flex; justify-content: center; align-items: stretch; }
.map-div iframe { width: 100%; min-height: 380px; }
.map-sect .content-sect { width: 100%; }
.map-sect .content-sect .sidelined-sect { row-gap: 4px; }
.map-sect .content-sect .sidelined-sect .listed-title { font-size: 20px; width: 170px; }

/* sell-us-your-parts.htm */
.sellpage {  }

.sellpage .form-div, .requestpage .form-div { padding-top: 0; }
.sellpage .content-sect, .requestpage .content-sect { align-items: center; }
.sellpage .content-sect p, .requestpage .content-sect p { text-align: center; }

/* request-parts.htm */
.requestpage {  }

/* thank-you.htm */
.thankyoupage {  }

/*--------FORM STYLES--------------------*/
.form-div { 
	width: 100%; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; 
	padding: 80px 5%; box-sizing: border-box; background: #222; 
}
.form-div .content-sect, .form-div form { width: 100%; }
.form-div .content-sect { padding: 60px; justify-content: flex-start; }
.form-div form { 
	display: flex; flex-direction: column; align-items: center; margin: 0; position: relative; 
	padding: 0 60px; box-sizing: border-box; 
}

.form-div form .formrow { display: flex; justify-content: center; width: 100%; }

.form-div .subtitle { 
	width: 100%; max-width: 750px; text-align: left; margin-top: 20px; 
}

.form-div .item-inf {
	display: flex; flex-direction: column; align-items: center; 
	width: 100%; margin: 12px 0; 
}
.item-inf .subtitle { 
	width: 100%; max-width: 750px; margin-top: 0; text-align: left; 
	display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; 
}
.item-inf .subtitle span { display: flex; align-items: center; }

.form-div form .formrow-captcha { display: flex; flex-direction: column; align-items: center; width: 100%; }

.form-div form label { 
	margin: 7px 0; box-sizing: border-box; color: #000; font-family: 'titillium-web', sans-serif; font-size: 15px; 
}
.form-div form input[type="text"], .form-div form input[type="email"], .form-div form textarea, .form-div form #CaptchaAnswer { 
	width: 100%; max-width: 750px; margin: 10px 0; padding: 16px; box-sizing: border-box; 
	font-family: 'titillium-web', sans-serif; font-size: 17px; line-height: 1.4; color: #000; 
	border: 1px solid #000; background: #eee; 
}
.form-div form input[type="text"]:focus, .form-div form input[type="email"]:focus, .form-div form textarea:focus, .form-div form #CaptchaAnswer:focus { border-color: #000; }
.form-div form textarea { height: 120px; }
.form-div form a:not(.invisilink) { margin: 20px 0 0 0; cursor: pointer; }
.form-div form a.btn-add-machine { margin: 12px 0 32px 0!important; }
.form-div form .CaptchaMessagePanel { font-family: 'titillium-web', sans-serif!important; color: #fff!important; }
.form-div form #CaptchaAnswer { width: 250px; }
.form-div form div.CaptchaWhatsThisPanel a { 
	font-family: 'titillium-web', sans-serif!important; padding: 12px 20px; box-sizing: border-box; background: #fff; 
}
.form-div form div.CaptchaWhatsThisPanel a:hover { text-decoration: underline; }
form button[type="submit"] { cursor: pointer; }

/*-------- FOOTER STYLES ----------------*/
footer {  }

.footer { 
	width: 100%; background: #222; position: relative; padding: 40px 5% 20px; box-sizing: border-box; 
	display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-start; row-gap: 24px; 
}
.foot-col { 
	display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; width: calc(50% - 250px); 
}
.foot-logo-div { align-items: center; width: 250px; }
.foot-logo img { object-fit: contain; object-position: 50% 0%; max-width: min(100%, 87vw); height: 56px; }
.foot-col a:not(.listed) {
	font-family: 'titillium-web', sans-serif; font-size: 15px; line-height: 32px; color: #fff; font-weight: 600; 
	padding: 0 12px; box-sizing: border-box; transition: .35s ease all; 
	display: flex; justify-content: center; align-items: center; 
}
.foot-col a:not(.listed):hover { color: #fbb900; }
.foot-soc { align-items: flex-end; }
.foot-soc-holder { 
	display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; 
}
.foot-soc .listed { height: 50px; }
.foot-foot { width: 100%; display: flex; justify-content: center; align-items: center; }
.foot-foot p { text-align: center; color: #fff; font-size: 14px; }

/*----INVENTORY STYLES - KEEP AT BOTTOM OF CSS----*/
.inv-foot-spacer { width: 100%; height: 80px; background: #222; }

/*---------- RESPONSIVE STYLES ----------*/

@media only screen and (min-width: 2000px) {
	
}

@media only screen and (max-width: 1400px) {
	.contactpage .form-div { width: 500px; }
	#location { width: calc(100% - 500px); }
}

@media only screen and (max-width: 1380px) {
	.header { justify-content: space-between; }
	.topheader-left { column-gap: 4px; }
	.header-logo-div { margin-left: min(5%, 40px); }
	.nav-div { margin-right: min(calc(5% - 20px), 20px); width: unset; }
}

@media only screen and (min-width: 1271px) {
	.show1270 { display: none!important; }
}

@media only screen and (max-width: 1270px) {
	h1.title { font-size: 60px; line-height: 64px; }
}

@media only screen and (max-width: 1250px) {
	.inv-sect { column-gap: 80px; }
	.search-toggled { padding-left: 24px; padding-right: 24px; }
	.search-tab { font-size: 21px; padding-top: 10px; padding-bottom: 10px; }
	.search-toggled form { width: min(100%, 550px); }
	.lg-cta-sect { column-gap: 60px; }
}

/* switch to mobile nav at 1220px */

@media only screen and (max-width: 1200px) {
	.header { margin-bottom: -130px; }
	.header-logo img { height: 60px; }
	h2.title { font-size: 36px; line-height: 40px; }
	h3.title, .h3, h2.h3 { font-size: 28px; line-height: 32px; }
}

@media only screen and (max-width: 1150px) {
	h1.title { font-size: 54px; line-height: 58px; }
	.inv-sect { flex-direction: column; align-items: center; }
	.inv-sect > .content-sect { width: 100%; }
	.inv-sect .search-sect { width: 100%; }
	.hero { height: min(750px, max(600px, 100vh)); }
	.contactpage { flex-direction: column-reverse; }
	.contactpage .form-div { width: 100%; }
	#location { width: 100%; }
	.footer { row-gap: 32px; }
	.foot-logo-div { order: 1; width: 100%; }
	.foot-nav { order: 2; width: 50%; }
	.foot-soc { order: 3; width: 50%; }
	.foot-foot { order: 4; }
}

@media only screen and (max-width: 1100px) {
	.mission .content-sect { width: 90%; }
}

@media only screen and (max-width: 1080px) {
	.hide1080 { display: none!important; }
	.hero { height: min(700px, max(550px, 100vh)); }
	.subhero { min-height: 300px; }
	.sidelined-sect { padding-top: 16px; padding-bottom: 24px; }
	.lg-cta-sect { column-gap: 50px; padding-left: min(5%, 30px); padding-right: min(5%, 30px); }
	.lg-cta-sect .ctas-holder { width: 50%; column-gap: 16px; }
	.lg-cta { min-height: 280px; }
	.lg-cta span { font-size: 20px; }
	.lg-cta-sect .content-sect { width: 50%; padding: 0; }
}

@media only screen and (max-width: 960px) {
	.hide960 { display: none!important; }
}

@media only screen and (max-width: 900px) {
	.subtitle { font-size: 22px!important; }
	.lg-cta-sect { flex-direction: column-reverse; }
	.lg-cta-sect .ctas-holder, .lg-cta-sect .content-sect { width: 100%; }
	.lg-cta-sect .lg-cta { min-height: 200px; }
	.lg-cta, .lg-cta img { border-radius: 24px; }
}

@media only screen and (min-width: 801px) {
	.inv-foot-spacer { display: none!important; }
}

@media only screen and (max-width: 800px) {
	.mission .content-sect { width: 100%; }
	.hero { height: min(650px, max(550px, 100vh)); }
	.item-inf input { width: 100%!important; }
}

/* switch to final mobile header */
@media only screen and (max-width: 750px) {
	.hide750 { display: none!important; }
	.hidespan750 i { margin-right: 0!important; }
	.hidespan750 span { display: none!important; }
	.header { 
		background-image: linear-gradient(0deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.5) 36px, rgba(0,0,0,1) 80px, rgba(0,0,0,1) 100%); 
		margin-bottom: -128px; padding-top: 12px; row-gap: 12px; 
	}
	.header-logo-div { order: 1; width: 100%; margin-left: auto; margin-right: auto; }
	.header-logo img { height: 54px; }
	.topheader { order: 2; background: none; padding: 0; width: unset; justify-content: flex-start; }
	.topheader-left { column-gap: 0; flex-direction: row-reverse; }
	.topheader-right { flex-direction: row-reverse; }
	.topheader a { border-radius: 8px; }
	.topheader a.listed { padding: 0 12px; }
	.topheader a i { color: #fbb900; }
	.topheader a:hover { background: rgba(0, 0, 0, .65); }
	.topheader .hidespan750 { padding: 0!important; }
	.nav-div { order: 3; margin-right: 0; }
	h1.title { font-size: 48px; line-height: 52px; }
	.sidelined-sect { padding-top: 12px; padding-bottom: 16px; }
	.hero { align-items: flex-end; }
	.form-div .content-sect, .form-div form { padding-left: 0; padding-right: 0; }
	.contactpage .form-div .content-sect, .contactpage .form-div form { padding-left: 5%; padding-right: 5%; }
}

@media only screen and (max-width: 700px) {
	h3.title, .h3, h2.h3 { font-size: 24px; line-height: 28px; }
	.search-tab { font-size: 18px; }
}

@media only screen and (max-width: 650px) {
	.footer { flex-direction: column; row-gap: 40px; }
	.foot-col a { text-align: center; min-height: 42px; }
	.foot-nav, .foot-soc, .foot-soc-holder { width: 100%; align-items: center; }
	.foot-soc-holder { row-gap: 6px; }
}

/* padding l/r 5% (if not already) */
@media only screen and (max-width: 600px) {
	.hide600 { display: none!important; }
	h1.title { font-size: 40px; line-height: 44px; }
	.subtitle { font-size: 18px!important; }
	.btnclass { width: 100%; }
	.sidelined-sect { padding: 0; }
	.sidelined-sect:before { display: none!important; }
	.inv-sect { padding-left: 5%; padding-right: 5%; }
	.contactpage .content-sect { padding-left: 5%; padding-right: 5%; }
}

@media only screen and (max-width: 540px) {
	.map-sect .content-sect .sidelined-sect { flex-direction: column; align-items: flex-start; row-gap: 12px; }
	.map-sect .content-sect .sidelined-sect .listed-title { width: unset; }
	.map-sect .content-sect .sidelined-sect p.spacer { height: 12px; }
}

@media only screen and (max-width: 500px) {
	.ctas-holder { flex-direction: column; justify-content: stretch; }
	.lg-cta { width: 100%; min-height: 150px!important; }
}

@media only screen and (max-width: 400px) {
	.hide400 { display: none!important; }
	.hidespan400 i { margin-right: 0!important; }
	.hidespan400 span { display: none!important; }
	.topheader .hidespan400 { padding: 0!important; }
}

@media only screen and (max-width: 250px) {
	.hide250 { display: none!important; }
	.nav-div { width: 100%; }
}






