﻿/***** 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 --------*/

.red {
	color: #D61C24;
}

.red-2 {color:#F39B9E;}

.wht {
	color: #ffffff;
}

/***** 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 {
	background-color: #222222;
}
.home-body {
    background-color: #222222;
}

a:link, a:visited, a:active {text-decoration:none;}
a:hover {text-decoration:none;}


hr{border:#000 1px solid;}



.mvb-med {
	font-family: "margin-mvb", sans-serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: 1px;
}
.dharma-bold {
	font-family: "dharma-gothic-m", sans-serif;
	font-weight: 700;
	font-style: normal;
	text-transform: uppercase;
	letter-spacing: 1px;
}
p.dharma-bold {
	letter-spacing: 1px;
}


.wid75 {
	width: 75%;
	margin: 0 auto
}
.wid80 {
	width: 80%;
	margin: 0 auto
}
.wid85 {
	width: 85%;
	margin: 0 auto
}
.caps {
	text-transform: uppercase;
}


/*--- HEADER STYLES ---------------------*/
header {}
.head {
    background-color: #222222;
}
.head .wid85 {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 20px 0 16px;
}
section.header {
    z-index: 10;
    position: absolute;
    width: 100%;
}
section.header2 {
    z-index: 10;
    width: 100%;
}


/*---BODY--------------------------------*/

.flex-container {
	display: flex;
	align-items: center;
}

.center {
	text-align: center;
}
.logo img {
    max-width: 350px;
    width: 100%;
}
.contact-top a {
    background-color: #D61C24;
    padding: 10px;
}
.contact-top a {
    background-color: #D61C24;
    padding: 10px;
    transition: all .3s ease-in-out;
}
.contact-top a:hover {
    padding: 10px 15px;
}
.head-right {
    gap: 5px;
}
.hero-container {
	background-image: url("../siteart/hero.png");
	width: 100%;
    display: inline-flex;
    height: 800px;
    background-size: cover;
    background-repeat: no-repeat;
	align-items: center;
    justify-content: flex-start;
	flex-direction: column;
	position: relative;
	padding-top: 150px;
    gap: 110px;
}
.hero-logo {
	filter: brightness(100%); 
/*	filter: grayscale(70%);*/
	top: -160px;
    bottom: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}
.hero-logo img {
    max-width: 1200px;
    width: 100%;
}
.hero-txt {
    display: flex;
    flex-direction: column;
    align-items: center;
	margin: 5%;
}
.hero-txt h1 {
    text-align: center;
    font-size: 125px;
	text-shadow: 5px 5px 5px #222;
}
.hero-txt h2 {
	text-shadow: 5px 5px 5px #222;
}
.hero-btn {
    display: flex;
    gap: 25px;
}
.hero-btn a {
    background-color: #D61C24;
    padding: 10px 30px;
    margin: 40px auto;
    transition: .3s;
}
.hero-btn a:hover {
	background-color: #be181f;
}
.lower {
    font-size: 40px;
    text-align: center;
}
.lower i {
    transition: .3s;
}
.lower i:hover {
    margin-top: 10px;
}

.services-container {
    display: flex;
    gap: 10px;
	margin-top: 100px;
	flex-direction: column;
}
.ctas-container {
    display: flex;
	gap: 10px;
	flex: 5;
}
.serv-col {
    flex: 1;
}

.serv-col.col1 {
    background-color: #D61C24;
	padding: 2vw;
	align-content: center;
	flex: 2;
}
.serv-col.col1 h3 {
	font-size: 75px;
    letter-spacing: 1px;
	text-align: center;
}
.serv-col.col2 {
	flex: 3;
}
.serv-col.col3 {
	flex: 3;
}
.marg-b {
	margin-bottom: 10px;
}
.serv-box {
	position: relative;
}
.box-img img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: flex;
    filter: brightness(65%);
    transition: 0.3s;
}
.serv-box:hover img {
    filter: brightness(45%);
}
.serv-box:hover i{
	background-color: #be181f;
}
.box-txt {
    position: absolute;
    bottom: 0;
    left: 0;
}
.box-txt p {
	margin: 25px;
    font-size: 55px;
}
.box-icon {
    position: absolute;
    bottom: 0;
    right: 0;
}
.box-icon i {
    font-size: 20px;
    padding: 15px;
    background-color: #D61C24;
}

.cat-container {
    margin: 150px auto;
    text-align: center;
}
.cat-container h3 {
    font-size: 60px;
	margin-bottom: 20px;
}
.categories {
    display: flex;
    justify-content: center;
}
.cat-col {
    width: 100%;
}
.cat-col p {
    background-color: #D61C24;
    padding: 20px;
    margin: 10px 5px;
    font-size: 20px;
    transition: .3s;
}
.cat-col p:hover {
    background-color: #be181f;
}

.distributors-container {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 50px auto 0;
    gap: 20px;
}
.distributor img {
    max-width: 200px;
    width: 100%;
	filter: brightness(70%);
}
.distributor h4 {
    font-size: 60px;
    filter: brightness(65%);
}

.about-container {
    display: flex;
}
.about-para {
    background-color: #444444;
    background-image: url(https://www.transparenttextures.com/patterns/concrete-wall.png);
    padding: 100px 0;
	width: 66.6666%;
}
.about-title h1,
.about-title h3 {
    font-size: 60px;
	margin-bottom: 25px;
	text-shadow: 1px 1px 3px #222;
}

.about-highlights {
    background-color: #D61C24;
    align-content: center;
    width: 33.3333%;
}
.highlight {
    display: flex;
    align-items: center;
    margin: 30px 0;
    gap: 10px;
}
.highlight h5 {
    font-size: 35px;
    letter-spacing: 0.5px;
}
.highlight i {
    font-size: 35px;
    margin: 10px;
}

.contact-aside {
    display: flex;
    justify-content: space-between;
    align-items: center;
	padding: 100px 0;
}
.con-icon a {
    display: flex;
    align-items: center;
    gap: 20px;
}
.con-col p {
    font-size: 20px;
}
.con-col p.mvb-med.red {
    margin-bottom: 15px;
}
.con-col h3 {
    font-size: 60px;
}
.con-icon {
    display: flex;
    align-items: center;
    gap: 20px;
    margin: 20px 0;
}
.con-icon i {
    font-size: 25px;
}
.col-det {
    flex: 1;
}
.col-map {
    flex: 2;
}


.subpage-wrap p {
    margin: 25px auto 100px;
}
.shop-gallery {
    display: grid;
    grid-template-columns: 1fr; 
    gap: 20px;
    margin-top: 30px;
}

.shop {
    width: 100%;
}

.shop img {
    width: 100%;
    height: auto;
    display: block;
}


/*--------FORM STYLES--------------------*/

.sub-wrapper {
    background-color: #222222;
}
.margin-container {
    padding: 100px 0;
}
.form-wrapper {
    background: #222222;
	margin-top: 25px;
}
.contact-title h1 {
    font-size: 60px;
}
.flex-row {
    display: flex;
    gap: 10px;
}
.flex-form input[type="text"] {
    background-color: #F2F2F2;
    font-family: "margin-mvb", sans-serif;
    font-size: 18px;
    text-transform: capitalize;
    padding: 18px;
    margin: 5px 0;
	border: none;
}

.CaptchaWhatsThisPanel a {
    color: #eb1a23;
}
.submit-button {
    text-align: center;
    border: none;
    font-family: "margin-mvb", sans-serif;
}
input.submit-button.red-btn {
    transition: all .3s ease-in-out;
}
input.submit-button.red-btn:hover {
    padding: 15px 20px;
    letter-spacing: 1.5px;
}
textarea.triplex-light {
    background-color: #F2F2F2;
    font-family: "margin-mvb", sans-serif;
    font-size: 18px;
    text-transform: capitalize;
    padding: 18px;
    margin: 5px 0;
	border: none;
}

.CaptchaMessagePanel {
	font-family: "margin-mvb", sans-serif;
	color: #ffffff;
	font-weight: 400!important;
}
.CaptchaWhatsThisPanel {
	font-family: "margin-mvb", sans-serif;
}

input.submit-button {
    background-color: #eb1a23;
    color: #ffffff;
	padding: 10px 30px;
    font-size: 16px;
}

.hero-btn.thankyou-btn a {
	margin: 40px 0!important;
}



/*-------- FOOTER STYLES ----------------*/
footer{
	background-color: #000000;
}
.wid85.foot {
    display: flex;
	align-items: center;
    justify-content: space-between;
	padding: 50px 0;
	gap: 20px;
}
.foot-menu ul {
    display: flex;
    gap: 25px;
}
.foot-menu a {
    color: #ffffff;
}





/*----INVENTORY STYLES - KEEP AT BOTTOM OF CSS----*/

.inv-wrap {
    width: 85%;
    margin: 100px auto;
}




/*---------- RESPONSIVE STYLES ----------*/

@media only screen and (min-width: 768px) {
	.shop-gallery {
        grid-template-columns: repeat(2, 1fr);
    }
}


@media only screen and (max-width: 1610px) {
	.serv-col.col1 h3 {
    	font-size: 65px;
	}
}
@media only screen and (max-width: 1250px) {
	.serv-col.col1 h3 {
		font-size: 40px;
	}
	.box-txt p {
		font-size: 32px
	}
	.cat-container h3 {
		font-size: 40px;
	}
	.about-title h3,
	.about-title h3 {
		font-size: 40px;
	}
	.con-col h3 {
		font-size: 40px;
	}
	.distributor h4 {
		font-size: 30px;
	}
	p.mvb-med {
		font-size: 14px;
	}
	.foot-menu ul li a {
		font-size: 14px;
	}
}
@media only screen and (max-width: 1150px) {
	.wid85.foot {
		flex-direction: column;
		gap: 20px;
	}
}

@media (min-width: 1024px) {
    .shop-gallery {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media only screen and (max-width: 1000px) {
	.hero-txt h1 {
		font-size: 75px;
		margin: 5%;
	}
	.hero-txt h2 {
		font-size: 18px;
	}
	.hero-container {
		height: 500px;
	}
	.logo img {
		max-width: 200px;
	}
}
@media only screen and (max-width: 900px) {
	.services-container {
		flex-direction: column;
	}
	.serv-col.col1 {
		padding: 8%;
		text-align: center;
	}
	.about-container {
		flex-direction: column;
	}
	.about-para {
		width: 100%
	}
	.about-highlights {
		width: 100%;
	}
	.about-highlights .wid85 {
		display: flex;
		justify-content: space-between;
		gap: 15px;
	}
	.highlight h5 {
		font-size: 25px;
	}
	.highlight i {
		font-size: 25px;
	}
	.categories {
		flex-direction: column;
		gap: 10px;
	}
	.cat-col {
		display: flex;
		flex-direction: column;
		gap: 10px;
	}
	.cat-col p {
		margin: 0;
	}
	.contact-aside {
		flex-direction: column;
		gap: 25px;
	    padding: 100px 0 0 0;
	}
	.contact-aside.wid85 {
    	width: 100%;
	}
	.col-map {
		width: 100%;
	}
	.foot-menu ul {
		flex-direction: column;
		align-items: center;
		gap: 20px;
	}
	
}
@media only screen and (max-width: 650px) {
	.ctas-container {
		flex-direction: column;
	}
	.about-highlights .wid85 {
		flex-direction: column;
		align-items: center;
	}
	.highlight h5 br {display: none;}
	.highlight {margin: 5px 0;}
	.about-highlights .wid85 {margin: 5% auto;}
	.hero-txt h1 {
        font-size: 45px;
    }
	.hero-txt h2 {
        font-size: 18px;
        text-align: center;
        margin: 5%;
    }
	.flex-row {
		flex-direction: column;
		gap: 0;
	}
	.flex-form input[type="text"] {
		font-size: 15px;
		padding: 18px 0 18px 18px;
	}
}
@media only screen and (max-width: 550px) {
	.contact-top a {
		background-color: transparent;
	}
	.head-right {
		gap: 0;
	}
	.logo img {
        max-width: 180px;
    }
	.hero-btn {
		flex-direction: column;
        margin: 5%;
	}
	.hero-btn a {
		margin: 0;
	}
	.hero-btn.thankyou-btn a {
		margin: 0 !important;
	}
}




