﻿/***** 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 {

}

a:link, a:visited, a:active {text-decoration:none;}
a:hover {text-decoration:none;}


hr{border:#000 1px solid;}

/*--- HEADER STYLES ---------------------*/
header {}

.top-header{
	display: flex;
	justify-content: space-between;
	margin-left: 30px;
}
.top-header .icon-link{
	display: flex;
	line-height: 48px;
	font-size: 12px;
	color: #fff;
	margin-right: 30px;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-family: "Inter", sans-serif;
	font-weight: 300;
}
.top-header .icon-link:last-of-type{
	margin-right: 0;
}
.top-header .icon-link i{
	text-align: center;
	margin: 10px 0;
	width: 27px;
	line-height: 27px;
	font-size: 12px;
	color: #fff;
	background: #151515;
	-moz-border-radius: 100%;
	-o-border-radius: 100%;
	-webkit-border-radius: 100%;
	border-radius: 100%;
	margin-right: 20px;
}
.top-header > div{
	display: flex;
	flex-wrap: wrap;
}
.top-header .simple-link{
	position: relative;
	line-height: 48px;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-family: "Inter", sans-serif;
	font-weight: 700;
	color: #fff;
	padding: 0 30px;
	text-align: center;
	display: block;
	
}
.top-header .language-selector{
	position: relative;
	background: #fff;
}
.top-header .language-selector > ul{
	position: absolute;
	top: 100%;
	z-index: 700;
}
.top-header .language-selector a{
	position: relative;
	line-height: 48px;
	font-size: 12px;
	margin-right: 30px;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-family: "Inter", sans-serif;
	font-weight: 700;
	color: #151515;
	width: 150px;
	text-align: center;
	display: block;
	
}
.top-header .language-selector i{
	position: absolute;
	right: 0;
	left: 150px;
	top: 0;
	bottom: 0;
	line-height: 48px;
	border-left: solid 1px #cecece;
	text-align: center;
	display: block;
	width: 29px;
	
}
.top-header .language-selector > ul{
	background: #cecece;
	z-index: 400;
}
.top-header .language-selector > ul > li > a{
	margin: 0;
	width: 180px;
}
.header{padding-top: 30px;}
.header .logo{
	width: 31.4%;
	padding: 0 5.7%;
	box-sizing: border-box;
}
.header .logo img{
	max-width: 100%;
}
.hero{
	background: url("/siteart/hero-bg.jpg") top right;
	background-size: 2000px auto;
	color: #fff;
	position: relative;
	z-index: 400;
}


/*---BODY--------------------------------*/

.flex{display: flex;}
.flex-wrap{flex-wrap: wrap;}
.justify-between{justify-content: space-between;}
.align-center{align-items: center;}


.padding-vertical{padding: 100px 0;}
.wrapper-lg{
	padding: 0 2.8%;
	box-sizing: border-box;
}
.wrapper-md{
	padding: 0 5.7%;
	box-sizing: border-box;
}
.wrapper-sm{
	padding: 0 8.1%;
	box-sizing: border-box;
}


.col49{width: calc(50% - 40px);}
.col50{width: 50%;}
.col51{width: calc(50% + 40px);}
.col100{width: 100%;}



.bg-excavator{
	position: relative;
}
.bg-excavator:after{
	content: '';
	position: absolute;
	background: url("/siteart/cutout.png") top right no-repeat;
	background-size: 1111px auto;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 0;
	pointer-events: none;
	z-index: -1;
}


.bg-slant{
	position: relative;
}
.bg-slant:before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: -1;
}
.bg-slant-gray:before{
	clip-path: polygon(0% 10%, 100% 35%, 100% 100%, 0 100%);
	background: #f3f3f3;
}

.bg-slant-dark:before{
	clip-path: polygon(0% 82%, 100% 70%, 100% 100%, 0 100%);
	background: #151515;
}



.heading-sm{
	font-family: "Inter", sans-serif;
	font-size: 18px;
	line-height: 24px;
	letter-spacing: 7px;
	text-transform: uppercase;
	font-weight: 500;
	margin-bottom: 10px;
}
.heading-sm.fr-text{
		font-size: 14px;
}
.heading{
	font-family: "Inter", sans-serif;
	font-size: 30px;
	line-height: 30px;
	text-transform: uppercase;
	font-weight: 900;
}
.heading-lg{
	font-family: "Inter", sans-serif;
	font-size: 72px;
	line-height: 72px;
	text-transform: uppercase;
	font-weight: 900;
}
.heading-xl{
	font-family: "Inter", sans-serif;
	font-size: 98px;
	line-height: 95px;
	text-transform: uppercase;
	font-weight: 300;
}
.heading-xl.fr-text{
	font-size: 85px;
	line-height: 100px;
}
.hero-text{
	padding: 13vw 0 15vw;
	max-width: 590px;
	width: 100%;
    background: url("/siteart/g-mark.png") 50% 40% no-repeat;
}
.light{
	font-weight: 300;
}

.bg-white p{
	font-size: 16px;
	line-height: 30px;
	font-weight: 300;
	letter-spacing: 0.5px;
	font-family: "Inter", sans-serif;
	margin-bottom: 30px;
}
.panel-dark{
	
    padding: 30px;
    background: #151515;
    color: #fff;
    border-radius: 0px 20px 20px;
}
.panel-light{
	
    padding: 30px;
    background: #f4f4f4;
    color: #151515;
    border-radius: 0px 20px 20px;
}



.map-box{display: flex;}
.map-box > div:first-child{width: calc(100% - 117px); position: relative;}
.map-box > div:first-child:before{
	left: 40px;
	top: 80px;
	bottom: 40px;
	right: 0;
	content: '';
	position: absolute;
	
	background: #151515;
	z-index: -1;
}
.map-box > div:first-child iframe{
    display: flex;
	-moz-border-top-right-radius: 20px;
	-moz-border-bottom-left-radius: 20px;
	-moz-border-bottom-right-radius: 20px;
	-o-border-top-right-radius: 20px;
	-o-border-bottom-left-radius: 20px;
	-o-border-bottom-right-radius: 20px;
	-webkit-border-top-right-radius: 20px;
	-webkit-border-bottom-left-radius: 20px;
	-webkit-border-bottom-right-radius: 20px;
	border-top-right-radius: 20px;
	border-bottom-left-radius: 20px;
	border-bottom-right-radius: 20px;
}
.map-box > div:last-child{
	margin-top: 80px;
	background: #151515;
	width: 117px;
	display: flex;
	align-items: center;
    flex-wrap: wrap;
    flex-direction: column;
	padding: 20px 0 0;
	
	
	-moz-border-top-right-radius: 20px;
	-o-border-top-right-radius: 20px;
	-webkit-border-top-right-radius: 20px;
	border-top-right-radius: 20px;
	
	
	-moz-border-bottom-right-radius: 20px;
	-o-border-bottom-right-radius: 20px;
	-webkit-border-bottom-right-radius: 20px;
	border-bottom-right-radius: 20px;
}
.map-box > div:last-child a{
	width: 75px;
	line-height: 75px;
	border: solid 1px #fff;
	text-align: center;
	color: #fff;
	font-size: 24px;
	-moz-border-radius: 100%;
	-o-border-radius: 100%;
	-webkit-border-radius: 100%;
	border-radius: 100%;
	margin-bottom: 20px;
	
}
.map-box .heading{margin-bottom: -4px;}
.map-box .map-contact-info{
	color: #fff;
	margin-left: 40px;
	padding: 30px 0 40px 30px;
	
	background: #151515;
	
	-moz-border-bottom-left-radius: 20px;
	-o-border-bottom-left-radius: 20px;
	-webkit-border-bottom-left-radius: 20px;
	border-bottom-left-radius: 20px;
}

.icon-list li{
	padding-left: 30px;
	position: relative;
}
.icon-list li i{
	position: absolute;
	top: 3px;
	left: 0;
}
.icon-list li a{	
	font-family: "Inter", sans-serif;
	font-size: 16px;
	line-height: 24px;
	color: #fff;
	font-weight: 300;
}

.copy-pad{
	padding: 20px 0 0 16.2%;
}





/*english*/
.cta{
	margin-top: 30px;
	float: left;
	padding: 0 30px;
	line-height: 50px;
	
	border: solid 1px #151515;
	color: #151515;
	text-transform: uppercase;
	font-family: "Inter", sans-serif;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 1px;
	display: block;
	
	-moz-border-radius: 90px;
	-o-border-radius: 90px;
	-webkit-border-radius: 90px;
	border-radius: 90px;
	max-width: 240px;
	width: 100%;
	box-sizing: border-box;
	
	
	-moz-transition: ease all 0.2s;
	-o-transition: ease all 0.2s;
	-webkit-transition: ease all 0.2s;
	transition: ease all 0.2s;
}
.cta.white{
	color: #fff;
	border-color: #fff;
}
.cta:hover{
	background: #151515 !important;
	color: #fff !important;
}
.cta.red:hover{
	filter:brightness(1.1);
}
.cta:before{
	content: '+';
	text-align: right;
	position: relative;
	float: right;}
#ctas {
	position: relative;
}
#ctas:before {
	content: '';
	position: absolute;
	background: #fff;
	top: 50%;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 0;
}
#ctas .flex{gap: 40px; position: relative;}
.cta.red:before{
	content: none;	
}

.cta.red{
    font-size: 24px;
    margin: 0;
	line-height: 90px;
	font-weight: 900;
	max-width: 33.33333%;
	padding: 0 40px;
	
	color: #fff;
	background: #e11218 !important;
	border: none;
}
.cta.red + .cta.red{
	background: #b9171c !important;
}
.cta.red + .cta.red + .cta.red{
	background: #97080c !important;
}

.cta.red i{
	float: right;
	line-height: 90px;
}

/*--------FORM STYLES--------------------*/

.custom-form input{
	padding: 10px;
	margin-bottom: 10px;
	font-family: "Inter", sans-serif;
	font-weight: 400;
	font-size: 14px;
	letter-spacing: 1px;
	color: #151515;
	line-height: 24px;
	resize: none;
	outline: none;
	border: none;
	background: #f3f3f3;
	box-sizing: border-box;
	width: 100%;
	
	-moz-border-radius: 10px;
	-o-border-radius: 10px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}
.custom-form .flex{
	gap: 10px;
}
.custom-form textarea{
	-moz-border-radius: 10px;
	-o-border-radius: 10px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	width: 100%;
	box-sizing: border-box;
	padding: 10px;
	font-family: "Inter", sans-serif;
	font-weight: 400;
	font-size: 14px;
	letter-spacing: 1px;
	color: #151515;
	line-height: 24px;
	resize: none;
	margin-bottom: 10px;
	outline: none;
	border: none;
	background: #f3f3f3;
}

.CaptchaPanel{
	text-align: left !important;
	font-family: "Inter", sans-serif;
}
.CaptchaPanel, .CaptchaAnswerPanel, .CaptchaImagePanel, .CaptchaMessagePanel{
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.CaptchaWhatsThisPanel a{
	color: #151515 !important;
}
button.cta{
	background: unset;
	cursor: pointer;
}


/*-------- FOOTER STYLES ----------------*/
footer{}

.footer{
	background: #151515;
	color: #fff;
	padding: 100px 0;
}
.footer .foot-nav {
	width: 71%;
}
.footer .foot-nav p, .footer .foot-nav p a {
	font-weight: 300;
	font-size: 12px;
	line-height: 24px;
	text-transform: uppercase;
	color: #fff;
	letter-spacing: 2px;
	font-family: 'Inter', sans-serif;
	
}
.footer .foot-nav ul{
	margin-bottom: 30px;
	margin-right: 6.3%;
	background: #fff;
	color: #151515;
	display: flex;
    justify-content: space-around;
	
	-moz-border-radius: 90px;
	-o-border-radius: 90px;
	-webkit-border-radius: 90px;
	border-radius: 90px;
	box-sizing: border-box;
}
.footer .foot-nav ul li a{
	color: #151515;
	line-height: 50px;
	display: block;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-weight: 500;
	font-family: 'Inter', sans-serif;

}
.footer .foot-logo{
    width: 29%;
	text-align: center;
}
.footer .foot-logo img{
	max-width: 100%;
	margin-bottom: 45px;
}

/*---------- RESPONSIVE STYLES ----------*/

@media only screen and (max-width: 1660px) {
	.bg-excavator:after, .hero{
		background-position: right center;
	}
	
}
@media only screen and (max-width: 1439px) {
	.col51 .col50{
		width: 100%;
	}
	.col51 .col50:first-of-type{
		margin-bottom: 20px;
	}
	
}
@media only screen and (max-width: 1279px) {
	
		.header .logo{	
    	width: 300px;
	}
	.hero{
		background-position: center center;
	}
	
	.bg-excavator:after{
		content: none;
	}
	.top-header{
		justify-content: flex-end;
	}
	.header > .wrapper-lg > .flex{justify-content: space-between;;}

	#ctas .flex{flex-wrap: wrap; gap: 20px;}
	#ctas .cta.red{width: 100%; max-width: unset; line-height: 70px; font-size: 24px;}
	#ctas:before{
    	top: calc(100% - 35px);
	}
	.cta.red i{
		line-height: 70px;
	}
	
	.col51, .col49{width: 100%;}
	.col51 .col50{width: 50%;}
	.copy-pad{
		padding: 100px 0 0 40px;
	}
	
	
	.hero-text {
		max-width: 100%;
		text-align: center;
	}
}

@media only screen and (max-width:767px) {

	.heading{
		
    	font-size: 20px;
		line-height: 22px;
	}
	.heading-sm{
    	font-size: 14px;
    	line-height: 1.5;
    	margin-bottom: 5px;
	}

	.heading-sm.fr-text{
			font-size: 14px;
	}
	.heading-lg{
    	font-size: 10vw;
    	line-height: 1.3;
	}
	.heading-xl{
		font-size: 13.7vw;
    	line-height: 1;
	}

	.heading-xl.fr-text{
		font-size: 12vw;
    	line-height: 1;
	}
	
	.footer > .wrapper-sm > .flex{
    	flex-direction: column-reverse;
	}
	.footer .foot-nav, .footer .foot-logo{
		width: 100%;
		text-align: center;
	}
	.map-box{
		flex-wrap: wrap;
	}
	.map-box > div{
		width: 100% !important;
	}
	.map-box > div:first-of-type iframe{    
		-moz-border-bottom-left-radius: 0;
    	-moz-border-bottom-right-radius: 0;
		-o-border-bottom-left-radius: 0;
    	-o-border-bottom-right-radius: 0;
		-webkit-border-bottom-left-radius: 0;
    	-webkit-border-bottom-right-radius: 0;
		border-bottom-left-radius: 0;
    	border-bottom-right-radius: 0;
	}
	.col51 .col50{width: 100%;}
	.map-box .map-contact-info{
		padding-bottom: 30px;
		
		margin-left: 0;
    	-moz-border-bottom-left-radius: 0;
    	-o-border-bottom-left-radius: 0;
    	-webkit-border-bottom-left-radius: 0;
    	border-bottom-left-radius: 0;
	}
	.map-box > div:last-child{
		flex-direction: row;
		width: 100%;
		margin: 0;
		margin-left: 0;
		padding: 0 30px 20px;
		
		-moz-border-top-right-radius: 0;
		-o-border-top-right-radius: 0;
		-webkit-border-top-right-radius: 0;
		border-top-right-radius: 0;
    	-moz-border-bottom-left-radius: 20px;
    	-o-border-bottom-left-radius: 20px;
    	-webkit-border-bottom-left-radius: 20px;
    	border-bottom-left-radius: 20px;
		
	}
	.map-box > div:last-child a{
		margin-right: 20px;
		width: 50px;
		line-height: 50px;
	}
	.map-box > div:last-child a:last-of-type{
		margin-right: 0px;
	}
}


@media only screen and (min-width: 481px) {
	.show-xs{
		display: none;
	}
}
@media only screen and (max-width: 480px) {
	
	.hide-xs{
		display: none;
	}
	.custom-form .flex{flex-wrap: wrap; gap: 0;}
	#ctas .cta.red{
		
    	font-size: 16px;
	}
	.header .logo{	
    	width: 240px;
	}
	.hero-text {
		padding: 14vh 0 16vh;
	}
	.top-header{
		margin: 0;
	}
	.top-header > div{
    	width: 100%;
	}
	.top-header .simple-link{padding: 0;}
	.top-header > div > a, .top-header > div .language-selector{
    	width: 50%;
		margin: 0;
		box-sizing: border-box;
	}
	.top-header > div .language-selector a{
    	width: 75%;
	}
	.top-header > div .language-selector ul{
    	width: 100%;
	}

	.top-header .language-selector > ul > li > a{
		width: unset;
	}
	.top-header > div .language-selector a i{
    	width: 33.33333%;
    	left: 100%;
    	box-sizing: border-box;
	}
	
	
	.hero .heading-sm{
    	font-size: 12px;
    	letter-spacing: 2.5px;
		font-weight: 300;
	}
.hero .heading-sm.fr-text{
		font-size: 12px;
}
	
	
}






