/* 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, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; list-style: none; text-decoration: none;}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
* {box-sizing: border-box;}

body {
	font-family: "Montserrat", sans-serif;
	font-size: 14px;
	line-height: 160%;
	background-color: #E7EAEB;
	color: #29201A;
}

main, header {
	margin: 0 auto;
	margin-bottom: 1rem;
	text-align: center;
	width: 90%;
	max-width: 900px;
	display: flex;
	flex-direction: column;
	align-items: center;
	background-color: white;
	border-radius: 10px;
	padding: 2rem;
}

header {
	height: 30vh;
	background-color: #0b2332;
	display: flex;
	justify-content: center; align-items: center;
	border-radius: 10px;
	color: white;
	background-image: url(header.jpg);
	background-size: cover;
	margin-top: 5rem;
}



hr {
	margin:  0;
	border: none;
	border-bottom: 1px solid #7B5832;
	opacity: 0.5;

}

img {
	width: 50%;
	margin-bottom: 8%;
	opacity: 0.5;
}


h1 {
	font-weight: 800;
	font-size: clamp(1.2rem, 5.5vw, 5rem); 
	line-height: 140%;
	position: relative;
}
sup {font-size: 14px; font-weight: 500; position: absolute; top:-8px; right: -12px;}

h2 {
	letter-spacing: 8px;
	text-transform: uppercase;
	font-weight: 400;
	font-size: 14px;
	line-height: 200%;

}

h3 {
	font-weight: 600;
	font-size: 1.1rem; 
	line-height: 150%;
	margin-bottom: 30px;
	width: 100%;
	color: #0b2332;
}

.services {
	width: 100%;
	background-color: #e8e5df;
	border-radius: 10px;
	padding: 2rem 1.5rem
}

.services ul
 {
	display: flex;
	flex-wrap: wrap;

	border-radius: 10px;
	padding: 2rem 1.5rem;
	gap: 5px;
	justify-content: center;
}

.services ul li {
	display: inline-block;
	background-color: rgba(255, 255, 255, 0.4);
	padding: 3px 6px; 
	border-radius: 5px;
	font-weight: 500;
	color: #4a4743;
	font-size: 12px;

}

.services2 {
	background-color: #173D55;
	margin-top: 10px;
}


.services2 ul li {
	display: inline-block;
	padding: 0;
	border-radius: 5px;
}

.services2 ul li:hover { background-color: transparent;}

.services2 ul li a{
	color: white;
	font-weight: bold;
	display: block;
	padding: 12px 24px;
	border: 3px solid white;
	border-radius: 5px;
	background-color: #173D55;
	transition: all linear 0.25s;
}

.services2 ul li a:hover {
	background-color: #0b2332;
}


.produit {
	background-color: rgb(204, 198, 188);
	display: flex;
	padding:  8% 5% 2% 5%;
	justify-content: center;
	align-items: center;
	border-radius: 10px;
	margin-bottom: 1rem;
	flex-wrap: wrap;
}

.produit img {
	width: 45%;
	opacity: 1;
	margin: 0;
}

.produit p {min-width: 100%; margin: 0;}


ul.contact {
	padding: 1rem 0;
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap:wrap;
}

ul.contact a {
	display: inline-block;
	padding: 5px 15px;
	background-color:#4a6575;
	border-radius: 5px;
	color: white;
	text-decoration: none;
	transition: all ease-in-out 300ms;
	font-weight: 500;
}

ul.contact a:hover {
	background-color: #173D55
}

p {
	margin: 2rem auto;
	width: 72%;	
	text-wrap: balance;
	color: #0a1e2a;
}

.legal {width: 100%; text-align: center; color: #999;}
.legal a{width: 100%; text-align: center; color: #555; font-weight: 500;}

strong {
	font-weight: 600;
}

.minilogo {
	width: 50px;
	opacity: 0.5;
}