@charset "utf-8";
/***** BEGIN RESET *****/

* {

	border: 0;
	margin: 0;
	padding: 0;
}

body {
	-webkit-text-size-adjust: none;
	background: #fff;
	overflow-x: hidden;
	color: #003b68;
	line-height: 1 !important;
	font-family: 'Montserrat', sans-serif;
}

/*============================
ALL PAGES
============================*/
ol,
ul {
	list-style: none;
}

.clear {
	clear: both;
	height: 0px;
	margin: 0;
}

.wrap {
	width: 95%;
	margin: 0 auto;
	max-width: 1400px;
}

h1,
h2,
h3,
h4,
h5 {
	font-family: 'Montserrat', sans-serif;
	text-transform: uppercase;
	color: #003b68;
}

p {
	font-family: 'Montserrat', sans-serif;
}

/***** END RESET *****/

/*====================hover easing style

-webkit-transition: all .5s ease; 
-moz-transition: all .5s ease; 
-ms-transition: all .5s ease; 
-o-transition: all .5s ease; 
transition: all .5s ease;

======================================*/

/*============================
HEADER
============================*/

header {
	width: 100%;
	float: left;
	background: url("../siteart/wood.jpg");
	background-size: cover;
}

.tophead {
	width: 100%;
	float: left;
	background: #a80636;
	padding: 10px 2.5%;
	box-sizing: border-box;
}

.tophead h4 {
	color: #fff;
	font-size: 14px;
	text-align: center;
	font-weight: 700;
	width: 100%;
	float: left;
	line-height: 18px;
}

.tophead h4 a {
	color: #fff;
	text-decoration: none;
}

.middlehead {
	width: 100%;
	float: left;
	background: rgba(255, 255, 255, .70);
	border-bottom: 5px solid #003b68;
	z-index: 3;
	position: relative;
}

.middlehead * {
	box-sizing: content-box;
}

.mainlogo {
	width: 250px;
	float: left;
}

.mainlogo img {
	width: 100%;
	max-width: 225px;
	float: left;
	position: relative;
	z-index: 3;
	margin-bottom: -50px;
}

.middletop {
	width: calc(100% - 250px);
	float: right;
}

.middletop h4 {
	float: right;
	color: #003b68;
	font-size: 18px;
	width: calc(100% - 200px);
	text-align: center;
	max-width: 500px;
	padding: 19px 0;
}

.middletop img {
	width: 175px;
	float: right;
	padding-right: 20px;
	box-sizing: border-box;
}

.middlebottom {
	width: calc(100% - 250px);
	float: left;
}

.blueangle {
	width: 0;
	height: 0;
	float: left;
	border-bottom: 55px solid #003b68;
	border-left: 50px solid transparent;
}

/*============================
MAINIMG
============================*/

.mainimg {
	width: 100%;
	float: left;
	background: url("../siteart/Clement-MainframePhoto.jpg");
	background-size: cover;
	background-position: center center;
}

.mainimgoverlay {
	width: 100%;
	max-width: 700px;
	float: right;
	background: rgb(255, 255, 255);
	background: linear-gradient(-90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.6418942577030813) 43%, rgba(255, 255, 255, 0) 100%);
	padding: 80px 2.5%;
	box-sizing: border-box;
}

.ctas {
	width: 100%;
	max-width: 500px;
	float: right;
}

.ctabutton {
	width: 100%;
	float: right;
	box-shadow: 2px 2px 5px #000;
	margin: 10px 0;
}

#trailercta {
	background: url("../siteart/Clement-TrailerPictureTab.jpg");
	background-size: cover;
	background-position: center center;
}

#concta {
	background: url("../siteart/Clement-ConstructionPictureTab.jpg");
	background-size: cover;
	background-position: center center;
}

.ctabutton a {
	width: 100%;
	float: left;
	background: rgba(0, 59, 104, .60);
	padding: 80px 10px;
	box-sizing: border-box;
	-webkit-transition: all .5s ease;
	-moz-transition: all .5s ease;
	-ms-transition: all .5s ease;
	-o-transition: all .5s ease;
	transition: all .5s ease;
}

.ctabutton h2 {
	width: 100%;
	float: left;
	text-align: center;
	color: #fff;
	font-weight: 900;
	font-style: italic;
	font-size: 45px;
}

.ctabutton h3 {
	width: 100%;
	float: left;
	text-align: center;
	font-weight: 700;
	font-size: 35px;
	color: #a80636;
	-webkit-transition: all .5s ease;
	-moz-transition: all .5s ease;
	-ms-transition: all .5s ease;
	-o-transition: all .5s ease;
	transition: all .5s ease;
}


.ctabutton a:hover {
	background: rgba(168, 6, 54, .60)
}

.ctabutton a:hover h3 {
	color: #003b68
}

.scrolls {
	width: 100%;
	float: left;
	z-index: 2;
	margin-top: -30px;
	position: relative;
}

.scrolls img {
	width: 100%;
	float: left;
}

.scrolling-wrap {
	width: 100%;
	height: 90px;
	overflow: hidden;
	background: #003b68
}

.scrolling {
	width: 100%;
	height: 92px;
}

/*============================
WELCOME
============================*/

.welcome {
	width: 100%;
	float: left;
	background: url("../siteart/wood.jpg");
	background-size: cover;
	background-attachment: fixed;
	position: relative;
	z-index: 1;
	display: flex;
}

.welcome {}

.welcome * {
	text-align: left !important;
}

.slick-list,
.slick-list * {
	height: 100%;
	object-fit: cover;
}

.vertical-center-4 {
	width: 50% !important;
}

.welcomeoverlay {
	width: 50%;
	float: right;
	background: white;
	padding: 90px 80px 50px;
	box-sizing: border-box;
}

.welcome h3 {
	width: 100%;
	float: left;
	text-align: center;
	color: #fff;
	font-weight: 500;
	font-size: 24px;
	letter-spacing: 10px;
}

.welcome h1 {
	width: 100%;
	float: left;
	color: #003b68;
	font-size: 55px;
	text-align: center;
	margin: 5px 0;
	font-weight: 900;
	font-style: italic;
}

.barwrap {
	width: 100%;
	float: left;
	margin-bottom: 30px;
}

.redbar {
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
	display: block;
	background: #a80636;
	height: 5px;
	margin-left: 0;
}

.welcome p {
	width: 100%;
	float: left;
	text-align: center;
	color: #003b68;
	font-size: 18px;
	line-height: 32px;
	margin-bottom: 30px;
}

.redbutton {
	width: 100%;
	float: left;
}

.redbutton a {
	width: 100%;
	max-width: 300px;
	margin: 0 auto;
	display: block;
	padding: 10px 5px;
	box-sizing: border-box;
	text-align: center;
	color: #fff;
	text-decoration: none;
	font-weight: 700;
	font-size: 14px;
	text-transform: uppercase;
	background: #a80636;
	text-align: center !important;
	float: left;
}

.redbutton a:hover {
	background: #003b68
}

/*============================
MAP
============================*/

.mapleft {
	width: 33.33%;
	float: left;
	background: #003b68;
	padding: 40px;
	box-sizing: border-box;
	height: 400px;
}

.mapleft h2 {
	width: 100%;
	float: left;
	color: #fff;
	;
	border-bottom: 1px solid #fff;
	text-align: center;
	font-size: 25px;
	padding-bottom: 20px;
	margin-bottom: 20px;
}

.mapleft p {
	width: 100%;
	float: left;
	text-align: center;
	color: #fff;
	text-transform: uppercase;
	font-size: 16px;
	line-height: 30px;
}

.mapleft p a {
	color: #fff;
	text-decoration: underline;
	font-weight: bold;
}

.mapright {
	width: 66.66%;
	float: left;
	height: 400px;
}

/*============================
FOOTER
============================*/
.myfooter {
	width: 100%;
	float: left;
	background: url("../siteart/wood.jpg");
	background-size: cover;
	border-top: 5px solid #a80636
}

.footeroverlay {
	width: 100%;
	float: left;
	background: rgba(255, 255, 255, .70);
}

.footnav {
	width: 100%;
	float: left;
	border-bottom: 1px solid #003b68;
}

.footwrap {
	width: 95%;
	margin: 0 auto;
	max-width: 900px;
	DISPLAY: FLEX;
	JUSTIFY-CONTENT: CENTER;
}

.footnav ul {
	float: left;
}

.footnav ul li {
	float: left;
}

.footnav ul li a {
	float: left;
	color: #003b68;
	font-size: 16px;
	text-transform: uppercase;
	font-weight: 700;
	padding: 30px 39px;
	text-decoration: none;
}

.footnav ul li a:hover {
	background: #a80636;
	color: #fff;
}

.footlogo {
	width: 100%;
	float: left;
}

.footlogo img {
	width: 95%;
	margin: 0 auto;
	display: block;
	max-width: 200px;
	margin-bottom: -40px;
	position: relative;
	z-index: 2;
	margin-top: 10px;
}

.bottomfoot {
	width: 100%;
	float: left;
	background: #003b68;
	padding: 20px 2.5%;
	box-sizing: border-box;
}

.bottomfoot p {
	width: 50%;
	float: left;
	color: #fff;
	text-transform: uppercase;
	font-size: 10px;
	letter-spacing: 2px;
	font-weight: 600;
}


/*============================
SLIDESHOW
============================*/
.slide-contain {
	width: 100%;
	float: left;
}

.cycle-slideshow {
	width: 100%;
	overflow: hidden;
	float: left;
	display: block;
}

.cycle-slideshow img {
	display: block;
	width: 100%;
	float: left
}

/* pager */
.pager {
	text-align: center;
	width: 100%;
	margin: -50px 0 -2px;
	position: relative;
	z-index: 999;
	float: left;
}

.pager span {
	font-family: arial;
	font-size: 50px;
	width: 16px;
	height: 16px;
	display: inline-block;
	color: rgba(255, 255, 255, 0.8);
	cursor: pointer;
}

.pager span.cycle-pager-active {
	color: #000;
}

.pager>* {
	cursor: pointer;
}


/*============================
SUB PAGES
============================*/

.submain {
	width: 100%;
	float: left;
	background: #fff;
	padding: 50px 0;
}

.submain.dot th,
.submain.dot td {
	padding: 15px;
}

.subtitles {
	width: 100%;
	float: left;
	position: relative;
	z-index: 2;
}

.subtitles h1 {
	width: 100%;
	float: left;
	background: #ededed;
	padding: 30px 2.5% 25px;
	box-sizing: border-box;
	text-algin: center;
	color: #a80636;
	font-size: 50px;
	text-align: center;
	font-weight: 900;
	font-style: italic;
}

.subtitles img {
	width: 100%;
	float: left;
}

.conmap {
	width: 100%;
	float: left;
	margin-top: -20px;
	position: relative;
	z-index: 1;
}

/*==================================
FORMS
==================================*/

#quotes {
	width: 100%;
	display: block;
	margin: 20px auto;
	font-size: 16px;
	color: #000;
}

#quotes tbody {
	width: 100%;
	float: left;
}

#quotes tr {
	width: 50%;
	float: left;
	padding: 7px;
	box-sizing: border-box;
}


#quotes td {
	width: 100%;
	float: left;
	font-size: 14px;
}

#quotes td p {
	font-size: 14px;
}


.fulltd2 {
	width: 100% !important;
	float: none !important;
	max-width: 500px !important;
	display: block !important;
	margin: 0 auto !important;
}



#quotes input {
	padding: 12px 10px;
	box-sizing: border-box;
	background: #fff;
	border: 1px solid #B4B4B4;
	font-weight: 300;
	color: #000;
	font-size: 12px;
}

#quotes textarea {
	padding: 12px 10px;
	border: 1px solid #b4b4b4;
	font-weight: 300;
	color: #000;
	font-size: 12px;
	background: #fff;
	box-sizing: border-box;
}

#quotes .CaptchaMessagePanel {
	color: #000;
}

#quotes .CaptchaWhatsThisPanel a {
	color: #000;
}


/* selects have similar styles to input & textarea fields, but with no padding. Text in a dropdown select is positioned differently */
#quotes select {
	padding: 12px 10px;
	box-sizing: border-box;
	background: #fff;
	border: 1px solid #B4B4B4;
	font-weight: 300;
	color: #000;
	font-size: 12px;
	width: 100%;
}

#quotes input {
	width: 100%;
}

#quotes input.larger {
	width: 100%;
}

#quotes textarea {
	width: 100%;
	height: 85px;
}


#quotes input.checkbox {
	padding: 0;
	border: 0;
	margin: 5px 10px 5px 0;
	width: 13px;
	height: 13px;
	display: inline;
	background-color: #fff;
}

#quotes p {
	text-align: left;

	width: auto;
}

#quotes input.radio {
	padding: 0;
	border: 0;
	margin: 0 3px 0 15px;
	width: 15px;
	height: 15px;
	display: inline;
}

#quotes input.radio:focus,
#quotes input.checkbox:focus {
	background: none;
	border: 0;
	outline-style: none;
}


#quotes input.button,
#quotes input.button:focus {
	width: 300px;
	margin: 0;
	padding: 20px 5px;
	background: #003b68;
	font-weight: 600;
	font-size: 14px;
	text-transform: uppercase;
	border-radius: 0px;
	border-bottom: none !important;
	line-height: 14px;
	text-align: center;
	border: 0 !important;
	color: #fff;
	margin-top: 10px;
}

#quotes input.button:hover {
	background: #a80636;
}

#quotes label.basic {
	color: #212121;
	font-size: 13px;
	text-align: left;
}

#quotes label.checkbox {
	/*  color:#212121;*/
	font-size: 13px;
	text-align: left;
	display: inline;
	padding: 0;
}

#quotes .fulltd {
	width: 100% !important;
	margin-right: 0;
}



/*==============================================
================================================
RESPONSIVE
================================================
==============================================*/

@media screen and (max-width: 1200px) {

	.welcome {
		flex-direction: column
	}

	.welcomeoverlay {
		width: 100%;
		padding: 40px;
	}

	.slick-slide img {
		width: 100%
	}

	.slick-initialized .slick-slide {
		/* width: 100% !important; */
	}

	.slick-initialized .slick-slide>div {
		width: 100%
	}

	.vertical-center-4 {
		width: 100% !important;
		height: 320px;
	}

	.mapleft {
		width: 100%;
		height: auto;
	}

	.mapright {
		width: 100%;
	}
}

@media screen and (max-width: 1100px) {

	.middletop {
		display: none;
	}

	.middleright {
		width: 100%;
	}

	.blueangle {
		display: none;
	}

	.mainlogo {
		width: 100%;
		transform: translateX(-50%);
		right: -50%;
		position: relative;
		width: 280px;
	}

	.mainlogo img {
		float: none;
		margin: 0 auto;
		display: block;
		margin-bottom: -50px;
		/* transform: translateX(-50%); */
		/* left: 50%; */
		/* position: relative; */
	}

	.scrolls img {
		width: 200%;
	}

	.scrolls {
		overflow-x: hidden;
	}

	.middlehead {
		border-bottom: none;
	}
}

@media screen and (max-width: 950px) {
	.footwrap {
		max-width: 600px;
	}

	.footnav ul li a {
		font-size: 14px;
		padding: 25px 11px;
	}
}

@media screen and (max-width: 900px) {
	.welcome h1 {
		font-size: 40px;
	}
}

@media screen and (max-width: 650px) {
	.footwrap {
		max-width: 600px;
	}

	.footnav ul li {
		width: 50%;
	}

	.footnav ul li a {
		width: 100%;
		float: left;
		text-align: center;
		padding: 20px 5px;
		box-sizing: border-box;
	}

	.bottomfoot p {
		width: 100%;
		text-align: center !important;
		padding: 5px 0;
	}

	.bottomfoot {
		padding-top: 50px;
	}

	.subtitles h1 {
		font-size: 35px;
	}

	#quotes tr {
		width: 100%;
	}
}

@media screen and (max-width: 500px) {
	.ctabutton h2 {
		font-size: 35px;
	}

	.ctabutton h3 {
		font-size: 25px;
	}

	.ctabutton a {
		padding: 50px 10px;
	}

	.mainimgoverlay {
		padding: 40px 2.5% 60px;
	}

	.welcome h1 {
		font-size: 35px;
	}

	.welcome h3 {
		font-size: 20px;
	}

	.tophead h4 {
		font-size: 12px;
		font-weight: 600;
	}

	.mainlogo img {
		margin-bottom: -20px;
	}

	.footnav ul li {
		width: 100%;
	}
}

@media screen and (max-width: 400px) {
	.mainlogo img {
		margin-bottom: -0;
		max-width: 200px;
	}
}

/* DivTable.com */
.divTable {
	display: table;
	width: 100%;
}

.divTableRow {
	display: table-row;
}

.divTableHeading {
	background-color: #EEE;
	display: table-header-group;
}

.divTableCell,
.divTableHead {
	border: 1px solid #999999;
	display: table-cell;
	padding: 3px 10px;
}

.divTableHeading {
	background-color: #EEE;
	display: table-header-group;
	font-weight: bold;
}

.divTableFoot {
	background-color: #EEE;
	display: table-footer-group;
	font-weight: bold;
}

.divTableBody {
	display: table-row-group;
}