body {
	margin: 0;
	padding: 0;
	font-family: 'Noto Sans', sans-serif;
	font-size: 17px;
	font-weight: 400;
	line-height: 1.6em;
}

a {
	text-decoration: underline;
	color: inherit;
}

a:hover {
	color: #1a7676;
	transition: all .1s linear;
}

h2 {
	font-size: 27px;
	line-height: 1.3em;
	margin: 0;
	padding: 50px 0 17px 0;
	font-weight: 400;
	text-transform: uppercase;
	color:#1a7676;
}

p {
	margin: 0 0 9px 0;
}

.tel { text-decoration: none !important; }

a.anchor {
    display: block;
    position: relative;
    top: -65px;
    visibility: hidden;
}

/*******************/
/***** NAV-TOP *****/
/*******************/

#global-nav {
	border-bottom: none;
	box-shadow: none;
	position: fixed;
	width: 100%;
	height: 70px;
	top: 0;
	left: 0;
	transition: all .25s;
}

#global-nav.scrolled-nav {
	background-color: #fff;
	border-bottom: 1px solid #ccc;
	box-shadow: 0 1px 3px rgb(0 0 0 / 8%);
	z-index: 100;
}

#global-nav .navcontainer {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}

#global-nav .logo {
	margin: 17px 0 0 23px;
	opacity: 0;
	transition: opacity .25s;
}

#global-nav.scrolled-nav .logo {
	opacity: 1;
	display: block;
}

#global-nav .nav {
	margin: 22px 26px 0 0;
	padding: 0;
	font-size: 0.88em;
	font-weight: 700;
	line-height: 1em;
	color: #999;
	text-transform: uppercase;
	text-align: right;
}
#global-nav .nav a {
	text-decoration: none;
}
#global-nav .nav ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
#global-nav .nav ul li {
	display: inline-block;
	padding: 6px 20px;
}
#global-nav .nav .lang {
	font-size: 13px;
	font-weight: 400;
	padding: 6px 5px;
}
#global-nav .nav .lang.first {
	margin-left:35px;
}
#global-nav .nav .lang.actif {
	background-color: #1a7676;
	color: white;
}
#global-nav .nav .lang.actif a {
	color: inherit;
	text-decoration: inherit;
}

/******************/
/***** HEADER *****/
/******************/
#header {
	text-align: center;
	margin: 70px 0 70px 0;
}
#header img {
	margin: 0 auto;
}

#header .seperation-line {
	width: 150px;
	margin: 50px auto;
	border-bottom: 2px solid rgba(16, 118, 118, 0.5);
}

#header .chapo {
	max-width: 960px;
	margin: 0 auto;
	font-size: 20px;
	line-height: 35px;
}
#header .chapo .small {
	font-size: 0.8em;
}

/********************/
/***** CONTENT *****/
/******************/

.wrapper {
	max-width: 960px;
	margin: 0 auto;
}

.grey-block {
	background-color: #f1f1f1;
}
.grey-block.image-top {
	min-height: 160px;
	margin-top: -160px;
}
.grey-block.image-bottom {
	min-height: 160px;
	margin-bottom: -160px;
}

.image-block {
	width: calc(100% + 170px);
	margin: 0 0 0 -85px;
}

.image-block .item {
	height: 320px;
	width: 100%;
}
.image-block img {
	width: 100%;
	height: 320px;
	object-fit: cover;
}
.image-block.double {
	display: flex;
	flex-direction: row;
}
.image-block.double .item {
	width: 50%;
}

/**** PRODUCTS ****/
/*#products h2 { text-align: center; }*/

#products .box-warpper {
		width: calc(100% + 80px);
		margin-left: -40px;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
}

#products .box-warpper .box {
	background-color: #f0f0f0;
	width: calc(50% - 40px);
	margin: 20px;
	padding: 40px;
}

#products .box-warpper .box h3 {
	font-size: 27px;
	font-weight: normal;
	color: #1a7676;
}

#products .box-warpper .box .box-image {
	margin: 0 0 35px -4px;
}
#products .box-warpper .box .box-image img {
	max-height: 78px;
}
#products .box-warpper .box.b1 .box-image img {
	max-width: 78px;
}
#products .box-warpper .box.b2 .box-image img {
	max-width: 48px;
}
#products .box-warpper .box.b3 .box-image img {
	max-width: 80px; /*85*/
}
#products .box-warpper .box.b4 .box-image img {
	max-width: 50px;
}

#products ul {
	padding: 0;
  list-style-position: inside;
}

#products .certificate {
	display: flex;
	flex-direction: row;
}

#products .certificate .text {
	padding: 20px 0 0 35px;
	font-size: 1.05em;
}

#products .certificate .image.border {
    border: 1px solid black;
}

#products ul ul {
	padding: 0 0 0 20px;
  list-style-position: inside;
}

#contact .contact-box,
#agents .contact-box {
	width: calc(100% + 40px);
	margin-left: -20px;
	display: flex;
	flex-direction: row;
}
#contact .contact-box .item,
#agents .contact-box .item {
	width: calc(50% - 40px);
	margin: 20px;
}

#contact .contact-box .item .grey,
#agents .contact-box .item .grey {
	margin-top: 15px;
	font-size: 0.8em;
	color: #777;
}

#contact .persons-box,
#agents .persons-box{
	background-color: white;
	display: flex;
	flex-direction: row;
	margin: 35px 0;
}

#agents .persons-box{
	background-color: #f1f1f1;
}

#contact .persons-box .portrait,
#agents .persons-box .portrait { width: 30%; }

#contact .persons-box .portrait img,
#agents .persons-box .portrait img { max-width: 300px; width: 100%; height: auto; }

#contact .persons-box .contact,
#agents .persons-box .contact { width: 70%; padding: 70px; display: flex; flex-direction: row; }

#contact .persons-box .contact .item,
#agents .persons-box .contact .item { align-self: center; }

#contact .persons-box .contact .item .name,
#agents .persons-box .contact .item .name { font-size: 1.25em; margin: 0 0 10px 0; }

#footer { text-align: center; }

#footer div img { margin: 0 auto; }

/********************/
/***** HELPERS *****/
/******************/

.pb50 { padding-bottom: 50px; }
.pb70 { padding-bottom: 70px; }
.pb75 { padding-bottom: 75px; }
.pb100 { padding-bottom: 100px; }
.mt35 { margin-top: 35px; }
.mb35 { margin-bottom: 35px; }
.mt35 { margin-top: 35px; }
.mt70 { margin-top: 70px; }
.mb70 {	margin-bottom: 70px; }
.mt100{ margin-top: 100px; }
.pt35 { padding-top: 35px; }
.pt50 { padding-top: 50px; }

/*******************************/
/***** RESPONSIVE VERSIONS *****/
/******************************/


@media only screen and (max-width: 1200px) {
		.image-block { width: calc(100% + 300px);	margin: 0 0 0 -150px;	}
		#global-nav .nav ul li { padding: 6px 15px;	}
}

@media only screen and (max-width: 1024px) {
		#header .chapo { max-width: unset; width: 100%; padding: 0 50px; }
		.wrapper { max-width: unset; width: 100%; }
		.image-block { width: 100%;	margin: 0; }
		section { padding: 0 75px; }
		#contact .persons-box .contact,
		#agents .persons-box .contact { padding: 50px; }
}

@media only screen and (max-width: 768px) {
		#header .chapo { max-width: unset; width: 100%; padding: 0 25px; }
		section { padding: 0 50px; }
		#global-nav .nav ul li {  padding: 6px 10px; }
		#global-nav .nav .lang.first {	margin-left:20px;	}
		.image-block.double { flex-direction: column; }
		.image-block.double .item { width: 100%;  height: 30vh; margin: 0 auto; padding: 0 50px; overflow: hidden; }
		.image-block.double .item { width: 100%;  height: 30vh; object-fit: cover; }
		.image-block .item { width: 100%;  height: 30vh; }
		.image-block .item img { width: 100%;  height: 30vh; object-fit: cover; }
}

@media only screen and (max-width: 767px) { /* < ipad */
		#global-nav.scrolled-nav {
			background-color: unset;
			border-bottom: none;
			box-shadow: none;
		}
		#global-nav.scrolled-nav .logo,
		#global-nav .logo {
			display: none;
		}
		#global-nav .nav ul li {
			display: none;
		}
		#global-nav .nav ul li.lang {
			display: inline-block;
		}
		#global-nav { position: absolute; top:0; left: 0; }
		#global-nav .navcontainer {
			display: flex;
			flex-direction: row;
			justify-content: center;
		}
		section { padding: 0 25px; }
		#header .chapo { margin-top: 50px; padding: 0; font-size: 17px; line-height: 28px; }
		#header { margin-top: 50px; }
		#header .seperation-line { display: none; }
		h2 {
    font-size: 24px;

    padding: 30px 0 10px 0;

}
.pt35 { padding-top: 0; }
.pb100 { padding-bottom: 25px; }
.image-block.double .item { padding: 0; }
body {

    font-size: 16px;
    line-height: 1.5em;
}
.image-block .item,
.image-block .item img { height: 35vh; }

#products .box-warpper {
    width: 100%;
    margin-left: 0;
    flex-direction: column;
	font-size: 0.9em;
}
#products .box-warpper .box {
    width: 100%;
    margin: 0 0 20px;
		padding: 30px;
}
#products .certificate .text {
	padding: 10px 0 0 15px;
	font-size: 0.95em;
}

#contact .contact-box,
#agents .contact-box {
    width: 100%;
    margin-left: 0;
    flex-direction: column;
}

#contact .contact-box .item,
#agents .contact-box .item {
    width: 100%;
    margin: 0;
	font-size: 0.9em;
}

p {
    margin: 0 0 4px 0;
}

#contact .contact-box .item .grey,
#agents .contact-box .item .grey {
    margin: 5px 0 15px 0;
}

#contact .persons-box,
#agents .persons-box {

    margin: 5px 0 20px 0;
}

#contact .persons-box .contact,
#agents .persons-box .contact {
    padding: 10px;
    font-size: 0.8em;
}

#contact .persons-box .contact .item .name,
#agents .persons-box .contact .item .name {
    margin: 0 0 2px 0;
}

.hide-on-mobile { display: none; }

}


#agents h3 {
	font-size: 19px;
	font-weight: bold;
	color: #1a7676;
	text-transform: uppercase;
	margin: 35px 0 5px 0;
}

