/*
Theme Name: ODS
Author: Planète Communication
Author URI: https://www.planete-communication.fr
Version: 1
*/

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,
b, u, i, 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, figcaption, 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;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}






@font-face {
	font-display: swap;
	font-family: 'Poppins';
	font-style: normal;
	font-weight: 400;
	src: url('/wp-content/themes/ods/fonts/poppins-v21-latin-regular.woff2') format('woff2');
}

@import url("https://p.typekit.net/p.css?s=1&k=bnt1jde&ht=tk&f=349.351&a=84157111&app=typekit&e=css");

@font-face {
font-family:"good-times";
src:url("https://use.typekit.net/af/7d4e6e/000000000000000077359692/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff2"),url("https://use.typekit.net/af/7d4e6e/000000000000000077359692/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff"),url("https://use.typekit.net/af/7d4e6e/000000000000000077359692/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("opentype");
font-display:swap;font-style:normal;font-weight:700;font-stretch:normal;
}

@font-face {
font-family:"good-times";
src:url("https://use.typekit.net/af/427144/000000000000000077359695/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n9&v=3") format("woff2"),url("https://use.typekit.net/af/427144/000000000000000077359695/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n9&v=3") format("woff"),url("https://use.typekit.net/af/427144/000000000000000077359695/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n9&v=3") format("opentype");
font-display:swap;font-style:normal;font-weight:900;font-stretch:normal;
}





* {
	border: 0px;
	margin: 0px;
	padding: 0px;
	text-decoration: none;
}
body {
	background: #000000;
	font-family: 'Poppins', Arial, Helvetica, sans-serif;
	font-size: 16px;
	line-height: 120%;
	color: #000000;
	-webkit-font-smoothing: antialiased;
}
img {
	max-width: 100%;
	border: 0px;
	vertical-align: bottom;
}
h1, h2, h3, h4, h5, h6 {
	line-height: 120%;
	margin: 10px 0px;
	font-weight: bold;
}
h1 {
	font-size: 36px;
	margin: 0px 0px 30px 0px;
	text-align: center;
	font-weight: 300;
}
h2 {
	font-size: 26px;
}
h3 {
	font-size: 22px;
}
h4 {
	font-size: 20px;
}
h5 {
	font-size: 18px;
}
h6 {
	font-size: 16px;
}
a:focus {
	outline: none;
}
a {
	color: #000000;
  	text-decoration: underline;
}
p {
	margin: 10px 0px;
	line-height: 150%;
}
ul, ol {
	margin: 10px 0px 10px 20px;
}
ul ul, 
ol ol, 
ul ol, 
ol ul {
	margin: 0px 0px 0px 30px;
}
li {
  	line-height: 150%;
}
body:not(.home) .wp-block-table {
	overflow: initial;
}
body:not(.home) .wp-block-table td:empty:after {
	content: 'Empty cell';
	visibility: hidden;
	speak: none;
}
body:not(.home) .wp-block-table figcaption {
    font-style: italic;
    text-align: center;
    font-size: 13px;
    line-height: 1;
    margin-top: 20px;
}
table {
	border: 1px solid #cccccc;
	margin: 10px 0px;
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
}
table caption {
	color: #ccc;
	margin:5px 0;
	text-align:left;
}
th {
	border: 1px solid #ededed;
	background: #1c984c;
	color: #FFFFFF;
	font-weight: bold;
	padding: 8px;
}
td {
	border: 1px solid #ededed;
	padding: 8px;
}
#nested .smart-menu {
	display: none;
}
header #nested {
	position: relative;
	height: 60px;
	z-index: 2;
}
header #nested .firstLevel {
	height: 60px;
	margin: 0px;
	padding: 0px;
	list-style: none;
	text-align: center;
}
header #nested .firstLevel li {
	position: relative;
	display: inline-block;
	vertical-align: top;
	padding: 0px;
	height: 60px;
}
header #nested .firstLevel li a {
	display: block;
	height: 60px;
	line-height: 60px;
	color: #000000;
	padding: 0px 20px;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 14px;
	font-weight: bold;
}
header #nested .firstLevel li a span {
	display: block;
	height: 60px;
	line-height: 60px;
}
header #nested .firstLevel li ul {
	position: absolute;
	width: 260px;
	height: 0px;
	background: #FFFFFF;
	margin-left: -120px;
	margin-top: -20px;
	box-shadow: 0px 4px 10px -4px rgba(0, 0, 0, 0.3);
	left: 50%;
	top: auto;
	overflow: hidden;
	opacity: 0;
	transition: height 0ms ease 0ms, opacity 250ms ease 100ms, margin-top 250ms ease 100ms;
}
header #nested .firstLevel > li:hover > ul {
	height: auto;
	opacity: 1;
	margin-top: 0px;
	padding: 15px 10px;
}
header #nested .firstLevel li ul li {
	display: block;
	height: auto;
	border-bottom: 1px solid #ededed;
}
header #nested .firstLevel li ul li:last-child {
	border-bottom: none;
}
header #nested .firstLevel li ul li a {
	height: auto;
	padding: 10px 10px;
	line-height: 120%;
	font-size: 13px;
}
header #nested .firstLevel li ul li a span {
	display: inline !important;
	height: auto !important;
	line-height: 120% !important;
	border-bottom: none !important;
}
/* ---------- listes à puce ----------- */
body:not(.home) #wrapper ul {
	list-style-type: none;
}
body:not(.home) #wrapper ul li {
	position: relative;
}
body:not(.home) #wrapper ul li:before {
	content: '';
	width: 6px;
	height: 6px;
	background: #1c984c;
	position: absolute;
	border-radius: 50%;
	top: 8px;
	left: -20px;
	margin: auto;
}
#page {
	position: relative;
	min-width: initial;
	background: #FFFFFF;
	overflow: hidden;
}
header {
	position: fixed;
	width: 100%;
	height: 89px;
	z-index: 2;
	background: none;
	transition: 0.3s;
}
header.scrolled {
	box-shadow: 0 0 10px rgba(0,0,0,0.2);
}
header #headerInner {
	position: relative;
	width: 100%;
	height: 100%;
}
header #logo {
	position: relative;
}
header #logo a {
	position: relative;
	display: block;
}
header #headerBoxes {
	position: absolute;
    right: 100px;
    top: 30px;
	z-index: 3;
}
/* ----------------------
ZONE INTERIEURE (CONTENU)
-----------------------*/
#wrapper {
	position: relative;
	clear: both;
	background: #FFFFFF;
	z-index: 1;
}
#wrapperInner {
	position: relative;
	width: 90%;
	max-width: 1170px;
	margin: 0px auto;
	padding: 60px 0px 0px 0px;
}
#container {
	position: relative;
	margin: 0px 0px 60px 0px;
}
#contents {
	position: relative;
}
#contentsInner {
	position: relative;
}
footer {
	position: relative;
	clear: both;
	background: #000000;
	color: #FFFFFF;
	z-index: 1;
}
footer #footerInner {
	position: relative;
	width: 90%;
	max-width: 1170px;
	margin: 0px auto;
	padding: 80px 0px 70px 0px;
}
header #nested ul.firstLevel li ul li {
	transition: 0.4s;
}
header #nested ul.firstLevel li ul li:hover {
	background: #f7f7f7;
}
@media (min-width: 1100px) {
	header #nested ul.firstLevel > li:first-child > a {
		padding-left: 0;
	}
	header #nested ul.firstLevel > li:last-child > a {
		padding-right: 0;
	}  
}
#headerBoxes p {
	margin: 0;
	line-height: 1;
}
body.home #wrapperInner {
	padding: 0;
	width: 100%;
	max-width: 100%;
}
.grecaptcha-badge {
	visibility: hidden;
}
#container {
	margin: 0px 0px 100px 0px;
}
html, body {
	scroll-behavior: smooth;
}
iframe {
	max-width: 100%;
}
::-moz-selection {
	background-color: #1c984c;
	color: #FFFFFF;
}
::selection {
	background-color: #1c984c;
	color: #FFFFFF;
}
strong {
	font-weight: 700;
}
em {
	font-style: italic;
}


.slick-slider {
	display: block;
	box-sizing: border-box;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-touch-callout: none;
	-khtml-user-select: none;
	-ms-touch-action: pan-y;
	touch-action: pan-y;
	-webkit-tap-highlight-color: transparent;
}
.slick-list {
	position: relative;
	display: block;
	margin: 0;
	padding: 0;
	overflow: hidden;
}
.slick-list:focus {
	outline: none;
}
.slick-list.dragging {
	cursor: pointer;
	cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list {
	transform: translate3d(0, 0, 0);
}
.slick-track {
	position: relative;
	top: 0;
	left: 0;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.slick-track:before,
.slick-track:after {
	display: table;
	content: '';
}
.slick-track:after {
	clear: both;
}
.slick-loading .slick-track {
	visibility: hidden;
}
.slick-slide {
	display: none;
	float: left;
	height: 100%;
	min-height: 1px;
}
.slick-slide img {
	display: block;
}
.slick-slide.slick-loading img {
	display: none;
}
.slick-slide.dragging img {
	pointer-events: none;
}
.slick-initialized .slick-slide {
	display: block;
}
.slick-loading .slick-slide {
	visibility: hidden;
}
.slick-vertical .slick-slide {
	display: block;
	height: auto;
	border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
	display: none;
}




header.scrolled {
    background: #151921;
}
header #logo img {
    height: 67px;
}
header #headerBoxes {
	display: none;
}
header #nested ul.firstLevel li a {
	font-family: 'good-times';
	font-size: 14px;
}
header #nested ul.firstLevel > li > a {
	color: #FFFFFF;
}
header #headerInner {
    width: 90%;
    max-width: 1170px;
    margin: 0 auto;
}
header #nested ul.firstLevel li.pll-parent-menu-item ul {
	width: auto;
    padding: 0;
    margin-left: 0px;
    left: 12px;
}
header #nested ul.firstLevel li.pll-parent-menu-item ul li a {
	padding: 7px;
}
header #nested ul.firstLevel li.pll-parent-menu-item a span {
    display: flex;
    align-items: center;
    justify-content: center;
}
header #nested ul.firstLevel > li.pll-parent-menu-item > ul > li {
	padding: 0;
}
header #logo {
    position: absolute;
    top: 10px;
    left: 0;
}
header div #nested {
    position: absolute;
    right: 0;
    top: 15px;
}
header #nested ul.firstLevel > li.menu-item-has-children {
    margin-right: 10px;
}
header #nested ul.firstLevel > li:last-child.menu-item-has-children {
	padding-right: 20px;
}
header #nested ul.firstLevel > li.menu-item-has-children:after {
    content: '';
    display: inline-block;
    height: 0;
    width: 0;
    border-top: 5px solid #FFFFFF;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 28px;
}
header #nested ul.firstLevel > li {
    transition: 0.25s opacity;
}
header #nested ul.firstLevel:hover > li {
    opacity: 0.6;
}
header #nested ul.firstLevel:hover > li:hover {
    opacity: 1;
}
header #nested ul.firstLevel li ul li a {
    font-size: 13px;
    font-family: 'Poppins';
    font-weight: 400;
    text-transform: inherit;
    text-align: left;
}
header #nested ul.firstLevel li ul li ul {
	margin-left: 0px;
	height: auto;
	left: 100%;
	top: 10px;
	transition: 0.2s;
}
header #nested ul.firstLevel li ul li:hover ul {
    opacity: 1;
	top: 20px;
    box-shadow: 8px 8px 10px rgb(0 0 0 / 30%);
}
header #nested ul.firstLevel > li > ul > li,
header #nested ul.firstLevel > li > ul > li > ul > li {
	overflow: hidden;
}
header #nested ul.firstLevel > li > ul > li:hover,
header #nested ul.firstLevel > li > ul > li > ul > li:hover {
	overflow: visible;
}
header #nested .firstLevel > li:hover > ul,
header #nested .firstLevel > li > ul > li:hover > ul {
	padding: 15px 0px;
	overflow: visible;
}
header #nested ul.firstLevel > li > ul > li,
header #nested ul.firstLevel > li > ul > li > ul > li {
	padding: 0 10px;	
}




#video {
    position: relative;
	height: 100vh;
}
#video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
	pointer-events: none;
	filter: brightness(0.4);
}
#video .logo {
	position: absolute;
	z-index: 1;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    margin-top: 45px;
	max-width: 90%;
}
#video .logo img {
	height: 288px;
}
#video .logo p {
    margin: 35px auto 0;
    color: #FFFFFF;
    font-size: 19px;
    line-height: 1.6em;
    width: 890px;
    max-width: 90%;
}
#video .images {
	position: absolute;
	z-index: 2;
	top: 50%;
    transform: translateY(-50%);
}
#video .images.gauche {
	left: 20px;
}
#video .images.droite {
	right: 20px;
}
#video .images div img {
    border-radius: 25px;
	width: 140px;
	height: 120px;
	object-fit: cover;
}
#video .images div {
	position: relative;
	margin-bottom: 20px;
}
#video .images > div:last-child {
	margin-bottom: 0;
}
#video .images div span {
    visibility: hidden;
    opacity: 0;
    transition: 0.2s ease-in-out;
    position: absolute;
    background: #000000;
    color: #FFFFFF;
    width: 190px;
    border-radius: 5px;
    padding: 6px 10px;
    text-align: center;
    font-size: 13px;
    box-sizing: border-box;
	left: 110%;
    top: 50%;
    transform: translateY(-50%);
}
#video .images.droite div span {
	left: auto;
	right: 110%;
}
#video .images div:hover span {
	visibility: visible;
	opacity: 1;
}
#video .images div span:after {
    content: '';
    display: inline-block;
    height: 0;
    width: 0;
    border-top: 7px solid transparent;
    border-right: 7px solid #000000;
    border-bottom: 7px solid transparent;
    position: absolute;
    left: -7px;
    top: 0;
    bottom: 0;
    margin: auto;
}
#video .images.droite div span:after {
	left: auto;
	right: -7px;
	transform: rotate(180deg);
}




#products {
    background: #f7f7f7;
	padding-top: 170px;
	padding-bottom: 105px;
	margin-bottom: 105px;
}
#products .titres {
    padding: 0 50px;
    text-align: center;
	position: relative;
	margin-bottom: 150px;
}
#products .titres span.titre_gris,
#innovation .titres span.titre_gris,
#services > .container .titres span.titre_gris {
    position: absolute;
    bottom: 40px;
    left: 50px;
    right: 50px;
    text-align: center;
    font-family: 'good-times';
    font-size: 120px;
    font-weight: 900;
    color: transparent;
    -webkit-text-stroke: 1px #e9e9e9;
    pointer-events: none;
	display: block;
    line-height: 1;
	opacity: 0.5;
}
#products .titres h1,
#innovation .titres h2,
#services > .container .titres h2 {
	margin: 0;
	font-family: 'good-times';
	font-size: 65px;
	letter-spacing: 0.05em;
	position: relative;
	z-index: 1;
	text-shadow: 0px 8px rgb(0 0 0 / 6%);
}
#products .titres h2 {
    font-family: 'good-times';
    font-size: 25px;
    color: #1c984c;
    position: absolute;
    bottom: -70px;
    left: 50px;
    right: 50px;
	margin: 0;
}

#products .container_slick,
#galerie,
#secteurs_mobile_only {
	position: relative;
}
#products .container_slick .slick-prev, 
#products .container_slick .slick-next,
#galerie .slick-prev, 
#galerie .slick-next,
#secteurs_mobile_only .slick-prev, 
#secteurs_mobile_only .slick-next {
    position: absolute;
    top: 50%;
    margin-top: -30px;
    width: 60px;
    height: 60px;
    cursor: pointer;
    overflow: hidden;
    white-space: nowrap;
    text-indent: 10000px;
    outline: none !important;
}
#products .container_slick .slick-next,
#galerie .slick-next,
#secteurs_mobile_only .slick-next {
    right: 6px;
    background: url(/wp-content/themes/ods/images/black-arrow.svg) center center no-repeat, #FFFFFF;
}
#products .container_slick .slick-prev,
#galerie .slick-prev,
#secteurs_mobile_only .slick-prev {
    left: 6px;
    transform: rotate(180deg);
    z-index: 10;
    background: url(/wp-content/themes/ods/images/black-arrow.svg) center center no-repeat, #FFFFFF;
}
#products .container_slick .item {
	margin: 0 10px;
	position: relative;
}
#products .container_slick .item .image {
	margin-bottom: 10px;
	overflow: hidden;
    border-radius: 10px;
}
#products .container_slick .item img {
	width: 100%;
	height: 18vw;
	object-fit: cover;
	border-radius: 10px;
	transition: 0.3s;
}
#products .container_slick .item .fond_gris {
	background: #efefef;
	border-radius: 10px;
	padding: 32px 20px;
	transition: 0.3s;
	position: relative;
}
#products .container_slick .item .fond_gris span {
    display: block;
    line-height: 1.4em;
    font-family: 'good-times';
    font-size: 14px;
	transition: 0.2s ease-in-out;
}
#products .container_slick .item .fond_gris span.cate {
	margin-bottom: 5px;
	display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
#products .container_slick .item .fond_gris span.nom {
    padding-right: 85px;
}
#products .container_slick .item a {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
#products .container_slick .item:hover img {
	transform: scale(1.1);
}
#products .container_slick .item:hover .fond_gris {
	background: #000000;
}
#products .container_slick .item:hover .fond_gris span {
	color: #FFFFFF;
}
#products .container_slick .item .fond_gris:after {
    content: '+';
    width: 30px;
    height: 30px;
    background: #e8e8e8;
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    font-family: 'good-times';
    border-radius: 50%;
    right: 20px;
    bottom: 20px;
}






#edito {
    width: 90%;
    max-width: 1170px;
    margin: 0 auto 180px;
    display: flex;
	justify-content: space-between;
    align-items: center;
}
#edito > div {
	width: 48.5%;
}
#edito > div.gauche > p:first-child {
    margin: 0 0 20px 0;
    position: relative;
    padding-left: 20px;
	line-height: 1.5em;
	font-size: 16px;
    letter-spacing: 0.075em;
    text-transform: uppercase;
    background: url(/wp-content/themes/ods/images/forme-titre.svg) no-repeat left center;
	color: #000000;
}
#edito > div.gauche h2 {
	font-family: 'good-times';
    font-size: 25px;
    color: #1c984c;
    margin: 0 0 50px 0;
}
#edito > div.gauche p {
	font-size: 15px;
	line-height: 2em;
	margin: 0 0 15px 0;
	color: #777777;
}
#edito > div.gauche > a:last-child,
#innovation .container_flex .droite > a:last-child,
section.newsContainer .droite > a,
body.page_404 article a {
    font-size: 13px;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 0.3em;
    position: relative;
    padding: 8px 6px;
    text-indent: 0.3em;
    display: inline-block;
    margin-top: 10px;
}
#edito > div.gauche > a:last-child:before,
#innovation .container_flex .droite > a:last-child:before,
section.newsContainer .droite > a:before,
body.page_404 article a:before {
	content: '';
	width: 45%;
	height: 100%;
	background: #ededed;
	position: absolute;
	left: 0;
	bottom: 0;
	top: 0;
	transition: 0.2s ease-in-out;
	z-index: -1;
}
#edito > div.gauche > a:last-child:hover:before,
#innovation .container_flex .droite > a:last-child:hover:before,
section.newsContainer .droite > a:hover:before,
body.page_404 article a:hover:before {
	width: 100%;
}
#edito > div.droite img {
	border-radius: 16px;
	width: 100%;
	max-height: 330px;
	height: 25vw;
	object-fit: cover;
}
#edito > div.droite .chiffres {
    background: #f7f7f7;
    border-radius: 16px;
    box-shadow: 10px 10px 20px rgba(0,0,0,0.06);
	padding: 30px;
	display: flex;
	justify-content: space-between;
	position: relative;
    top: -80px;
    left: 50px;
}
#edito > div.droite .chiffres .item p {
	margin: 0;
}
#edito > div.droite .chiffres .item > p:first-child {
	font-size: 20px;
	line-height: 1;
	width: 110px;
	height: 110px;
	border: 2px solid #1c984c;
	border-radius: 50%;
	display: flex;
    align-items: center;
    justify-content: center;
	position: absolute;
    left: 0;
    top: 0;
	box-sizing: border-box;
}
#edito > div.droite .chiffres .item {
    position: relative;
    padding-left: 130px;
	min-height: 110px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}
#edito > div.droite .chiffres .item > p:nth-child(2) {
	font-size: 12px;
	margin-bottom: 15px;
}
#edito > div.droite .chiffres .item > p:nth-child(3) {
	font-size: 15px;
	line-height: 1.25em;
	max-width: 110px;
}
#edito > div.droite .chiffres > div:last-child {
	margin-right: -10px;
}
#edito > div.droite {
    margin-bottom: -60px;
}






#innovation {
    width: 90%;
    max-width: 1170px;
    margin: 0 auto 120px;
}
#innovation .titres {
    text-align: center;
    margin-bottom: 55px;
    position: relative;
}
#innovation .container_flex {
    display: flex;
    justify-content: space-between;
}
#innovation .container_flex .gauche {
	width: 34%;
	background: #f7f7f7;
	text-align: center;
	display: flex;
    align-items: center;
    justify-content: center;
}
#innovation .container_flex .droite {
	width: 58%;
}
#innovation .container_flex .gauche img {
    height: auto;
    width: 236px;
	max-height: 90%;
    object-fit: contain;
}
#innovation .container_flex .droite h2 {
	font-family: 'good-times';
    font-size: 25px;
    color: #1c984c;
    margin: 0 0 35px 0;
}
#innovation .container_flex .droite p {
	font-size: 15px;
	line-height: 2em;
	margin: 0 0 12px 0;
	color: #777777;
}
#innovation .container_flex .droite > a:last-child {
    margin-top: 25px;
}






#services {
    background: #f7f7f7;
    padding: 100px 0 100px 0;
}
#services > .container {
	width: 90%;
	max-width: 1170px;
	margin: 0 auto;
}
#services > .container .titres {
    margin-bottom: 65px;
    position: relative;
    text-align: right;
}
#services > .container .container_flex {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}
#services > .container .container_flex .item {
	background: linear-gradient(135deg, #1c984c, #92c63c);
	color: #FFFFFF;
	text-align: center;
	width: 31.5%;
	box-sizing: border-box;
    padding: 50px 60px;
}
#services > .container .container_flex > div:nth-child(2) {
	margin-top: 60px;
}
#services > .container .container_flex > div:nth-child(3) {
	margin-top: 120px;
}
#services > .container .container_flex .item h3 {
	font-family: 'good-times';
	font-size: 14px;
	margin: 20px 0px 25px 0px;
}
#services > .container .container_flex .item p {
	margin: 0;
	font-size: 15px;
	line-height: 2em;
}
#services > .container .titres span.best_features,
body:not(.home) #wrapperInner div#text > div#contact_box > div:first-child > p:first-child,
body:not(.home) p.sur-titre {
    display: block;
    line-height: 1;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.75em;
    color: #1c984c;
    position: relative;
    right: -14px;
	margin-bottom: 12px;
}
#services > .container .titres span.titre_gris {
    right: auto;
    left: 0;
}






#galerie {
    padding: 100px 0px;
}
#galerie .slick-slide {
	margin: 0 10px;
}
#galerie .slick-slide img {
	width: 100%;
	height: 18vw;
	object-fit: cover;
	border-radius: 10px;
}
body.home #container {
    margin: 0px;
}

footer {
	text-align: center;
}
footer a {
	color: #999999;
	text-decoration: none;
}
footer a:hover {
	text-decoration: underline;
}
footer #signature {
    font-size: 12px;
    color: #999999;
    padding: 0 5% 25px 5%;
}
footer .wp-block-spacer + p {
	text-transform: uppercase;
	font-size: 13px;
	letter-spacing: 0.4em;
	text-indent: 0.4em;
	margin-bottom: 30px;
}
footer .wp-widget-group__inner-blocks > .wp-block-image {
	margin-bottom: 55px;
}
footer .wp-block-columns {
	display: flex;
	justify-content: center;
	margin-bottom: 5px;
}
#page footer .wp-block-columns > div.wp-block-column {
    flex-grow: initial !important;
    flex-basis: initial !important;
}
footer .wp-block-columns > div.wp-block-column .wp-block-image {
    margin: 0 7px;
}
footer .wp-block-columns > div.wp-block-column .wp-block-image img {
	transition: 0.2s ease-in-out;
}
footer .wp-block-columns > div.wp-block-column .wp-block-image img:hover {
	opacity: 0.8;
}














body:not(.home) header {
	background: #000000;
}
body.home div#chapterPicture {
	display: none;
}
body:not(.home) #chapterPicture {
	padding-top: 89px;
	height: 20vw;
	position: relative;
}
body:not(.home) #chapterPicture img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
body:not(.home) #chapterPicture .title_and_bc {
    position: absolute;
    top: 89px;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.3);
    color: #FFFFFF;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
	padding: 0 5%;
}
body:not(.home) #chapterPicture .title_and_bc h1 {
    font-family: 'good-times';
    font-size: 55px;
}
body:not(.home) #chapterPicture .widget_breadcrumb a {
    color: #FFFFFF;
    text-decoration: none;
}
body:not(.home) #chapterPicture .widget_breadcrumb a:hover {
	text-decoration: underline;
}
body:not(.home) #chapterPicture .widget_breadcrumb {
    font-size: 14px;
}
body:not(.home) #chapterPicture > .title_and_bc:first-child {
    background: #000000;
    border-top: 1px solid #4d4d4d;
}
body:not(.home) h2 {
	font-family: 'good-times';
    font-size: 22px;
    color: #1c984c;
	margin-bottom: 20px;
}
body:not(.home) .has-white-color h2 {
	color: #FFFFFF;
}
body:not(.home) h3 {
    font-size: 19px;
    padding-top: 3px;
    padding-left: 10px;
    border-left: 3px solid #1c984c;
	margin-bottom: 15px;
}

body:not(.home) #wrapperInner .wp-block-image {
    margin: 0;
}


/* --- Galeries --- */

body:not(.home) #wrapperInner figure.wp-block-gallery {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
	margin-right: -2%;
	margin-bottom: -2%;
	gap: 0;
}
body:not(.home) #wrapperInner figure.wp-block-gallery > figure {
	width: 23.5% !important;
	flex-grow: initial;
	margin: 0 2% 2% 0 !important;
}
body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(4),
body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(8),
body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(12),
body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(16),
body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(20),
body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(24),
body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(28) {
	margin-right: 0 !important;
}
body:not(.home) #wrapperInner .wp-block-column figure.wp-block-gallery > figure {
	width: 48% !important;
}
body:not(.home) #wrapperInner figure.wp-block-gallery > figure img {
    transition: 0.2s ease-in-out;
    width: 100% !important;
    max-height: 210px !important;
    flex: initial !important;
    height: 16vw !important;
	object-fit: cover;
}
body:not(.home) #wrapperInner figure.wp-block-gallery > figure img:hover {
	opacity: 0.8;
}

body:not(.home) #wrapperInner a.wp-block-button__link {
    background: none;
    font-size: 13px;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 0.3em;
    position: relative;
    padding: 8px 6px !important;
    text-indent: 0.3em;
    display: inline-block;
	color: #000000;
}
body:not(.home) #wrapperInner a.wp-block-button__link:before {
    content: '';
    width: 45%;
    height: 100%;
    background: #ededed;
    position: absolute;
    left: 0;
    bottom: 0;
    top: 0;
    transition: 0.2s ease-in-out;
    z-index: -1;
}
body:not(.home) #wrapperInner a.wp-block-button__link:hover:before {
	width: 100%;
}
body:not(.home) #wrapperInner p a,
body:not(.home) #wrapperInner li a {
	transition: 0.2s ease-in-out;
}
body:not(.home) #wrapperInner p a:hover,
body:not(.home) #wrapperInner li a:hover {
	color: #1c984c;
}
body:not(.home) #wrapperInner .wp-block-column > :first-child,
.wp-block-cover__inner-container > :first-child {
	margin-top: 0;
}
body:not(.home) #wrapperInner .wp-block-column > :last-child,
.wp-block-cover__inner-container > :last-child {
	margin-bottom: 0;
}
body:not(.home) .wp-block-cover .wp-block-cover__inner-container {
	max-width: 1170px;
}


body:not(.home) #wrapperInner .bouton-classique a.wp-block-button__link {
    background: linear-gradient(135deg, #1c984c, #92c63c);
    border-radius: 0;
    color: #FFFFFF;
	font-size: 14px;
    padding: 12px 15px !important;
	transition: 0.2s ease-in-out;
}
body:not(.home) #wrapperInner .bouton-classique a.wp-block-button__link:hover {
	box-shadow: 0 0 10px rgba(0,0,0,0.2);
}



/* à voir si ça fonctionne : */

body:not(.home) #wrapperInner {
	width: 100%;
	max-width: 100%;
}
body:not(.home) #wrapperInner div#text > *:not(.wp-block-cover):not(.wp-block-group),
body:not(.home) #wrapperInner div#text > figure,
body:not(.home) #wrapperInner div#text > ul,
body:not(.home) #wrapperInner div#text > .wp-block-group > .wp-block-group__inner-container,
body:not(.home) #wrapperInner div#text > p,
body.single-post #wrapperInner .pager {
	width: 90%;
	max-width: 1170px;
	margin-left: auto;
    margin-right: auto;
	box-sizing: border-box;
}
body:not(.home) #wrapperInner div#text > ul {
	padding-left: 20px;
}
body:not(.home) div #wrapperInner div#text > iframe:not(.wp-block-cover):not(.wp-block-group) {
    max-width: 100%;
    width: 100%;
	display: block;
    line-height: 1;
}
body:not(.home) #wrapperInner div#text > div.wpforms-container:not(.wp-block-cover):not(.wp-block-group) {
    max-width: 800px;
}

/* ----------------------------- */




body:not(.home) #wrapperInner figure.pleine-hauteur {
    height: 100%;
}
body:not(.home) #wrapperInner figure.pleine-hauteur img {
	height: 100%;
    width: 100%;
    object-fit: cover;
}
body:not(.home) #wrapperInner .wp-block-column iframe {
	width: 100%;
	height: 24vw;
    max-height: 320px;
}
body:not(.home) #wrapperInner div#text .wp-block-group__inner-container > div:last-child {
	margin-bottom: 0;
}




body.single-post #chapterPicture .title_and_bc h1 {
	font-size: 45px;
}
section.newsContainer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 55px;
    padding-bottom: 55px;
    border-bottom: 1px solid #efefef;
}
section.newsContainer .gauche {
    width: 33%;
}
section.newsContainer .gauche img {
	width: 100%;
	height: 270px;
	object-fit: cover;
}
section.newsContainer .droite {
    width: 62%;
}
section.newsContainer .droite time {
    display: block;
    line-height: 1;
    margin-bottom: 20px;
    font-size: 13px;
    font-style: italic;
}
section.newsContainer .droite > a {
    margin-top: 25px;
}
section.newsContainer .droite .description {
    line-height: 1.5em;
}
section.newsContainer .droite h2 {
    margin: 0 0 15px 0;
}
section.newsContainer .gauche .chapoPicture.empty {
    height: 270px;
    background: url(/wp-content/themes/ods/images/logo.png) no-repeat center center, #000000;
    background-size: auto 60%;
}

section.newsContainer.image_est_un_logo .gauche {
    border: 1px solid #d1d1d1;
	box-sizing: border-box;
}
section.newsContainer.image_est_un_logo .gauche img {
    object-fit: contain;
    height: auto;
    width: auto;
    max-width: 220px;
    max-height: 150px;
}
section.newsContainer.image_est_un_logo .gauche .chapoPicture {
    height: 270px;
    display: flex;
    align-items: center;
    justify-content: center;
}


.pager {
    text-align: center;
}
.pager > a, 
.pager > span {
    margin: 0 2px;
    background: #ededed;
    padding: 3px 10px;
    width: 30px;
    height: 30px;
    display: inline-block;
    box-sizing: border-box;
    text-decoration: none;
    line-height: 25px;
}
.pager > a.next,
.pager > a.prev {
    width: auto;
}
.pager.detail_actu > a {
    width: 160px;
    padding: 7px 10px;
    height: auto;
    margin: 0 6px;
}



body.contact #container {
    margin: 0px;
}
.wp-block-columns.just-content-flex-start {
	gap: 15px;
}
#wrapperInner .wp-block-columns.just-content-flex-start > div {
	flex-basis: initial;
    flex-grow: initial;
}
#wrapperInner .wp-block-columns.just-content-flex-start img {
	transition: 0.2s ease-in-out;
}
#wrapperInner .wp-block-columns.just-content-flex-start img:hover {
	opacity: 0.8;
}


.wp-block-columns.gap10 {
	gap: 10px;
}
.wp-block-columns.gap20 {
	gap: 20px;
}
.wp-block-columns.gap30 {
	gap: 30px;
}
.wp-block-columns.gap40 {
	gap: 40px;
}
.wp-block-columns.gap50 {
	gap: 50px;
}

.wpforms-container ul li:before {
	display: none;
}

form.wpforms-form {
	position: relative;
}
div div.wpforms-container-full .wpforms-form .wpforms-submit-container {
    position: absolute;
    right: 0;
    bottom: 10px;
}
div div.wpforms-container-full .wpforms-form input[type=submit],
div div div.wpforms-container-full .wpforms-form button[type=submit],
div.wpforms-container-full .wpforms-form .wpforms-page-button {
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 0.3em;
    position: relative;
    text-indent: 0.3em;
    display: inline-block;
	background: linear-gradient(135deg, #1c984c, #92c63c);
    border-radius: 0;
    color: #FFFFFF;
    font-size: 14px;
    padding: 12px 15px !important;
    transition: 0.2s ease-in-out;
	border: none !important;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
}
div div.wpforms-container-full .wpforms-form input[type=submit]:hover,
div div div.wpforms-container-full .wpforms-form button[type=submit]:hover,
div.wpforms-container-full .wpforms-form .wpforms-page-button:hover {
	box-shadow: 0 0 10px rgba(0,0,0,0.2);
}




body.page_404 #chapterPicture > .title_and_bc:first-child {
    background: #FFFFFF;
    color: #000000;
    position: relative;
    top: 0;
    border: none;
    padding-top: 50px;
}
body.page_404 #chapterPicture .widget_breadcrumb {
	display: none;
}
body.page_404 #chapterPicture {
	height: auto !important;
}
body.page_404 article {
	text-align: center;
}
body.page_404 #wrapperInner {
	padding-top: 30px;
}
body.page_404 #container {
    margin: 0px 0px 60px 0px;
}


body:not(.home) #wrapperInner div#text > div#contact_box {
    max-width: 900px;
	padding: 35px 50px;
	margin-bottom: 0;
}
body:not(.home) #wrapperInner div#text > div#contact_box > div:first-child > p:first-child,
body:not(.home) p.sur-titre {
    right: 0;
    letter-spacing: 0.5em;
    font-size: 15px;
}
body:not(.home) #wrapperInner div#text > div#contact_box > div:first-child > p:last-child {
	font-family: 'good-times';
    font-size: 24px;
    margin-bottom: -10px;
	line-height: 1.3em;
}
body:not(.home) #wrapperInner div#text .wp-block-group__inner-container {
    padding: 70px 0px;
}
body:not(.home) #wrapperInner p {
	line-height: 1.75em;
	margin: 0 0 15px 0;
}
body:not(.home) #wrapperInner figure + *,
body:not(.home) #wrapperInner .wp-block-image + p {
    margin-top: 20px;
}

body:not(.home) #wrapperInner div#text .slick > .wp-block-group__inner-container {
	padding: 10px 0 40px 0;
	position: relative;
}
body:not(.home) #wrapperInner div#text .slick-slide .wp-block-group__inner-container {
    padding: 0;
	width: 90%;
	margin: 0 auto;
}
body:not(.home) #wrapperInner div#text .slick-slide figure {
	width: 100%;
}

body:not(.home) .slick-prev,
body:not(.home) .slick-next {
    position: absolute;
    bottom: -40px;
    width: 54px;
    height: 54px;
    cursor: pointer;
    overflow: hidden;
    white-space: nowrap;
    text-indent: 10000px;
    outline: none !important;
    border: 1px solid #5f5f5f;
    border-radius: 50%;
}
body:not(.home) .slick-prev {
    left: 50%;
	margin-left: -65px;
    transform: rotate(180deg);
    z-index: 10;
    background: url(/wp-content/themes/ods/images/black-arrow.svg) center center no-repeat, #FFFFFF;
}
body:not(.home) .slick-next {
    right: 50%;
	margin-right: -65px;
    background: url(/wp-content/themes/ods/images/black-arrow.svg) center center no-repeat, #FFFFFF;
}
body:not(.home) #wrapperInner div#text .slick-slide .wp-block-group__inner-container img {
    width: 100%;
    height: 350px;
    object-fit: cover;
}

.wp-block-cover {
	overflow: hidden;
}
.wp-block-cover img {
    transition: transform 0.4s ease-out;
}
.wp-block-cover.is_hovered img {
	transform: scale(1.1);
}

.wp-block-columns.pleine-hauteur > div > figure,
.wp-block-columns.pleine-hauteur > div > figure img {
	height: 100%;
}
.wp-block-columns.pleine-hauteur > div > figure img {
	object-fit: cover;
}

.wp-block-group__inner-container > .wp-block-cover h2 {
    max-width: 740px;
    margin: 0 auto;
}

div .wp-block-image figcaption {
    margin-top: 15px;
    text-align: center;
    font-style: italic;
    font-size: 15px;
}



#secteurs_mobile_only {
	display: none;
}





































@media (min-width: 1000px) and (max-width: 1590px) and (max-height: 720px) {
	header #headerInner {
		max-width: 980px;
	}
	header #nested ul.firstLevel li a {
		font-size: 13px;
		padding: 0px 15px;
	}
}
@media (min-width: 1000px) and (max-width: 1400px) and (max-height: 720px) {
	header #nested ul.firstLevel li a {
		font-size: 12px;
		padding: 0px 12px;
	}
	header #headerInner {
		max-width: 890px;
	}
}
@media (min-width: 1000px) and (max-width: 1200px) and (min-height: 720px) and (max-height: 910px) {
	header #headerInner {
		max-width: 980px;
	}
	header #nested ul.firstLevel li a {
		font-size: 13px;
		padding: 0px 15px;
	}
}
@media (min-width: 1000px) and (max-height: 720px) {
	#video .images div img {
		border-radius: 15px;
		width: 115px;
		height: 100%;
	}
	#video .images div {
		height: calc(20% - 20px);
	}
	#video .images {
		top: 20px;
		transform: none;
		bottom: 0px;
	}
}
@media (min-width: 1000px) and (max-width: 1310px) and (max-height: 720px) {
	#video .images div img {
		border-radius: 15px;
		width: 115px;
		height: 100%;
	}
	#video .images div {
		height: calc(20% - 20px);
	}
	#video .images {
		top: 100px;
		transform: none;
		bottom: 0px;
	}
}
@media (min-width: 1000px) and (max-width: 1580px) and (min-height: 720px) and (max-height: 910px) {
	#video .images div img {
		border-radius: 15px;
		width: 185px;
		height: 100%;
	}
	#video .images div {
		height: calc(20% - 20px);
	}
	#video .images {
		top: 100px;
		transform: none;
		bottom: 0px;
	}
}
@media (min-width: 1000px) and (min-height: 720px) and (max-width: 1310px) {
	#video .logo img {
		height: 200px;
	}
	#video .logo p {
		font-size: 18px;
		max-width: 490px;
	}
}
@media (min-width: 1000px) and (max-height: 720px) and (max-width: 1250px) {
	#video .logo img {
		height: 200px;
	}
	#video .logo p {
		font-size: 18px;
		max-width: 490px;
	}
}
@media (max-width: 1050px) {
	#video {
		height: 56vw;
	}
	body.home #wrapper,
	body:not(.home) #chapterPicture {
		margin-top: 80px;
		padding: 0;
	}
	body:not(.home) #chapterPicture .title_and_bc {
		top: 0;
	}
	header {
		height: 80px;
		background: #000000;
	}
	header #headerInner {
		max-width: 100%;
		width: 100%;
	}
	header #logo img {
		height: 56px;
	}
	header #logo {
		z-index: 3;
		top: 12px;
		left: 20px;
	}
	header #headerBoxes ul > li {
		margin-right: 20px;
		line-height: 1;
	}
	header #headerBoxes ul > li:last-child {
		margin-right: 0px;
	}
	header #headerBoxes ul > li a {
		display: block;
		line-height: 1;
	}
	header #headerBoxes {
		display: block;
		z-index: 1;
	}
}
@media (min-width: 1000px) and (max-width: 1450px) {
	header #nested ul.firstLevel li ul li ul li ul {
		display: none;
	}
}
@media (min-width: 1000px) and (min-height: 910px) and (max-width: 1190px) {
	header #nested ul.firstLevel li a {
		font-size: 13px;
		padding: 0px 15px;
	}
}


/* ------- Passage à menu burger ------- */

@media (max-width: 1050px) {
	header #nested ul.firstLevel > li.pll-parent-menu-item {
		display: none;
	}
	header #headerBoxes ul {
		margin: 0;
		display: flex;
	}
	header div #nested {
		width: 40px;
		height: 40px;
		top: 20px;
		right: 20px;
	}
	header div #nested .contentSmart {
		width: 100%;
		height: 100%;
		cursor: pointer;
		z-index: 1;
		position: relative;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
	}
	header #nested .firstLevel {
		text-align: left;
		background: #000000;
		width: 100%;
		position: fixed;
		right: -100%;
		transition: 0.7s;
		opacity: 0.3;
		top: 0;
		height: auto;
		bottom: 0;
		padding-top: 40px;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		text-align: center;
	}
	body.menu_open header #nested .firstLevel {
		right: 0;
		opacity: 0.9;
	}
	header #nested ul.firstLevel:hover > li {
		opacity: 1;
	}
	header div #nested .contentSmart span {
		width: 25px;
		height: 2px;
		background: #FFFFFF;
		display: block;
		border-radius: 3px;
		position: relative;
		top: 0;
		transition: 0.5s;
	}
	header div #nested .contentSmart > span:nth-child(2) {
		margin: 6px 0px;
	}
	body.menu_open header div #nested .contentSmart > span:nth-child(1) {
		transform: rotate(45deg);
		top: 8px;
	}
	body.menu_open header div #nested .contentSmart > span:nth-child(2) {
		opacity: 0;
	}
	body.menu_open header div #nested .contentSmart > span:nth-child(3) {
		transform: rotate(-45deg);
		top: -8px;
	}
	header #nested ul.firstLevel li a {
		font-size: 18px;
		height: auto;
		line-height: 1;
	}
	header #nested .firstLevel li a span {
		line-height: 1.3em;
		height: auto;
	}
	header #nested ul.firstLevel > li.menu-item-has-children {
		margin-right: 0;
	}
	header #nested .firstLevel li {
		height: auto;
	}
	header #nested ul.firstLevel > li {
		margin: 0 0 30px 0;
		max-width: 400px;
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	header #nested ul.firstLevel > li:nth-last-child(2) {
		margin-bottom: 0;
	}
	header #nested ul.firstLevel > li.menu-item-has-children:after {
		display: none;
	}
	header #nested ul.firstLevel > li.menu-item-has-children > a {
		position: relative;
	}
	header #nested ul.firstLevel > li.menu-item-has-children > a:after {
		content: '';
		display: inline-block;
		height: 0;
		width: 0;
		border-top: 5px solid #FFFFFF;
		border-right: 5px solid transparent;
		border-left: 5px solid transparent;
		pointer-events: none;
		position: absolute;
		right: -11px;
		top: 10px;
	}
	header #nested .firstLevel li a {
		color: #FFFFFF;
	}
	header #nested .firstLevel li ul,
	header #nested .firstLevel > li:hover > ul {
		position: relative;
		height: auto;
		opacity: 1;
		background: none;
		box-shadow: none;
		margin: 15px 0 0 0;
		padding: 0;
		left: 0;
		width: auto;
	}
	header #nested ul.firstLevel > li > ul > li, 
	header #nested ul.firstLevel > li > ul > li > ul > li {
		padding: 0 0 5px 0;
		margin: 0 0 5px 0;
	}
	header #nested ul.firstLevel > li > ul > li:last-child, 
	header #nested ul.firstLevel > li > ul > li > ul > li:last-child {
		margin: 0;
		padding: 0;
	}
	header #nested ul.firstLevel li ul li a {
		font-family: 'good-times';
		text-align: center;
	}
	header #nested .firstLevel li ul li {
		border-bottom: 1px solid #6b6b6b;
	}
	/*header #nested ul.firstLevel > li.menu-item-has-children > a {
		pointer-events: none;
	}*/
	body.menu_open {
		overflow: hidden;
	}
	header #nested .firstLevel li ul {
		display: none;
	}

	header #nested ul.firstLevel > li.menu-item-has-children.sous_menu_open > ul {
		display: block;
	}
	header #nested ul.firstLevel > li.menu-item-has-children.sous_menu_open > a:after {
		transform: rotate(180deg);
	}
	header #nested ul.firstLevel > li.menu-item-has-children.sous_menu_open > a {
		color: #1c984c;
	}
	header #nested ul.firstLevel li ul li:hover {
		background: none;
	}
}



@media (max-width: 1300px) {
	#products .titres h1 {
		font-size: 5vw;
	}
}
@media (max-width: 1000px) {
	#video .logo img {
		height: 180px;
	}
	#video .logo p {
		font-size: 18px;
		max-width: 490px;
	}
	#video .logo {
		margin-top: 0;
	}
	#products .titres h1, 
	#innovation .titres h2, 
	#services > .container .titres h2 {
		font-size: 42px;
	}
	#products .titres h2 {
		font-size: 20px;
		position: relative;
		left: 0;
		right: 0;
		bottom: 0;
		margin-top: 25px;
	}
	#products .titres span.titre_gris, 
	#innovation .titres span.titre_gris, 
	#services > .container .titres span.titre_gris {
		display: none;
	}
	#products {
		padding-top: 80px;
		padding-bottom: 80px;
		margin-bottom: 80px;
	}
	#products .titres {
		padding: 0 5%;
		margin-bottom: 80px;
	}
}
@media (max-width: 910px) {
	#products .container_slick .item .fond_gris span {
		font-size: 12px;
	}
}
@media (max-width: 1090px) {
	#products .container_slick .item img {
		height: 30vw;
	}
}
@media (max-width: 800px) {
	#products .container_slick .item img {
		height: 45vw;
	}
	#products .container_slick .item .fond_gris span {
		font-size: 13px;
	}
}
@media (max-width: 750px) {
	#video .logo img {
		height: 140px;
	}
	#video .logo p {
		font-size: 16px;
		max-width: 440px;
	}
}
@media (max-width: 620px) {
	#video .logo img {
		height: 110px;
	}
	#video .logo p {
		font-size: 15px;
		max-width: 410px;
		margin-top: 25px;
	}
}
@media (max-width: 1050px) {
	#video .images {
		display: none;
	}
	#secteurs_mobile_only {
		display: flex;
		width: 90%;
		margin: 80px auto 140px;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	#secteurs_mobile_only .slick-slide {
		box-sizing: border-box;
    	padding: 0 15px;
	}
	#secteurs_mobile_only .slick-slide span.tooltip {
		background: #000000;
		WIDTH: 100%;
		display: block;
		margin: 10px 0 0 0;
		color: #FFFFFF;
		text-align: center;
		padding: 10px;
		box-sizing: border-box;
		font-size: 13px;
		border-radius: 7px;
	}
	#secteurs_mobile_only .slick-slide img {
		width: 100%;
		height: 16vw;
		object-fit: cover;
		border-radius: 7px;
	}
	#secteurs_mobile_only .slick-prev,
	#secteurs_mobile_only .slick-next {
		box-shadow: 0 0 10px rgb(0 0 0 / 20%);
		top: auto;
		bottom: -100px;
		margin: auto;
	}
	#secteurs_mobile_only .slick-prev {
		right: 100px;
		left: 0;
	}
	#secteurs_mobile_only .slick-next {
		right: 0;
		left: 100px;
	}
}
@media (max-width: 900px) {
	#secteurs_mobile_only .slick-slide img {
		height: 20vw;
	}
}
@media (max-width: 800px) {
	#secteurs_mobile_only .slick-slide span.tooltip {
		font-size: 12px;
	}
}
@media (max-width: 750px) {
	#secteurs_mobile_only .slick-slide img {
		height: 30vw;
	}
}
@media (max-width: 1350px) {
	#edito > div.gauche {
		width: 40%;
	}
	#edito > div.droite {
		width: 54%;
	}
	#edito {
		padding-right: 60px;
		box-sizing: border-box;
	}
}
@media (max-width: 1200px) {
	#edito > div.droite .chiffres .item > p:first-child {
		width: 80px;
		height: 80px;
		font-size: 18px;
	}
	#edito > div.droite .chiffres .item {
		padding-left: 100px;
		min-height: 80px;
	}
	#edito > div.droite .chiffres .item > p:nth-child(3) {
		font-size: 13px;
		max-width: 100px;
	}
}
@media (max-width: 1050px) {
	#edito {
		flex-direction: column;
		padding-right: 0;
		padding-top: 40px;
	}
	#edito > div.gauche h2 {
		margin-bottom: 25px;
	}
	#edito > div.gauche {
		width: 100%;
		display: flex;
		flex-direction: column;
		align-items: center;
		text-align: center;
	}
	#edito > div.droite {
		width: 100%;
		display: flex;
		justify-content: space-between;
		margin: 60px 0 0 0;
	}
	#edito > div.droite .chiffres {
		top: 0;
    	left: 0;
		justify-content: center;
	}
	#edito > div.droite .chiffres .item {
		padding-left: 0;
		min-height: initial;
		align-items: center;
		text-align: center;
	}
	#edito > div.droite > div {
		width: 48%;
		box-sizing: border-box;
	}
	#edito > div.droite .chiffres .item > p:first-child {
		position: relative;
		margin-bottom: 20px;
	}
	#edito > div.droite .chiffres > div:first-child {
		margin-right: 40px;
	}
	#edito > div.droite img {
		height: auto;
		max-height: initial;
	}
}
@media (max-width: 940px) {
	#edito > div.droite img {
		height: 26vw;
	}
}
@media (max-width: 880px) {
	#edito > div.droite img {
		height: 28vw;
	}
}
@media (max-width: 800px) {
	#edito > div.droite img {
		height: 30vw;
	}
}
@media (max-width: 750px) {
	#edito > div.droite img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	#edito > div.droite .chiffres {
		width: 100%;
		padding: 50px;
		background: rgba(255,255,255,0.8);
	}
	#edito > div.droite {
		position: relative;
	}
	#edito > div.droite > div.image {
		width: 100%;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	}
}
@media (max-width: 1000px) {
	#edito {
		margin-bottom: 100px;
	}
}
@media (max-width: 750px) {
	#innovation .container_flex {
		position: relative;
	}
	#innovation .container_flex .gauche {
		position: absolute;
		width: 100%;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		background: none;
	}
	#innovation .container_flex .droite {
		position: relative;
		width: 100%;
		background: rgba(0,0,0,0.7);
		padding: 50px;
		text-align: center;
	}
	#innovation .container_flex .droite p {
		color: #FFFFFF;
	}
	#innovation .container_flex .droite > a:last-child {
		color: #FFFFFF;
	}
	#innovation .container_flex .droite > a:last-child:before {
		background: #000000;
	}
}
@media (max-width: 910px) {
	#innovation .container_flex .gauche img {
		width: 200px;
	}
}
@media (max-width: 970px) {
	#services > .container .container_flex .item {
		padding: 40px 30px;
	}
	#services > .container .container_flex > div:nth-child(2) {
		margin-top: 40px;
	}
	#services > .container .container_flex > div:nth-child(3) {
		margin-top: 80px;
	}
	#services > .container .container_flex .item h3 {
		font-size: 13px;
	}
	#services > .container .container_flex .item p {
		font-size: 14px;
		line-height: 1.8em;
	}
	#services > .container .titres {
		margin-bottom: 20px;
	}
	#services {
		padding: 70px 0;
	}
}
@media (max-width: 760px) {
	#services > .container .container_flex .item {
		padding: 35px 20px;
	}
	#galerie {
		padding: 70px 0px;
	}
}
@media (max-width: 690px) {
	#services > .container .container_flex {
		flex-direction: column;
	}
	#services > .container .container_flex .item {
		width: 100%;
		padding: 30px;
	}
	#services > .container .container_flex > div:nth-child(2),
	#services > .container .container_flex > div:nth-child(3) {
		margin-top: 25px;
	}
	#services > .container .titres {
		margin-bottom: 60px;
		text-align: center;
	}
	#services > .container .titres span.best_features {
		right: 0;
	}
	#services > .container .container_flex .item h3 {
		font-size: 14px;
		margin-bottom: 10px;
	}
}
@media (max-width: 930px) {
	#galerie .slick-slide img {
		height: 24vw;
	}
	.wp-block-spacer {
		max-height: 70px;
	}
	#container {
		margin: 0px 0px 70px 0px;
	}
}
@media (max-width: 750px) {
	#galerie .slick-slide img {
		height: 36vw;
	}
}
@media (max-width: 1350px) {
	body:not(.home) #chapterPicture .title_and_bc h1 {
		font-size: 48px;
	}
}
@media (max-width: 1200px) {
	body:not(.home) #chapterPicture .title_and_bc h1 {
		font-size: 48px;
	}
	body:not(.home) #chapterPicture {
		height: 25vw;
	}
}
@media (max-width: 1050px) {
	body:not(.home) #chapterPicture {
		height: auto;
	}
	body:not(.home) #chapterPicture img {
		position: absolute;
		top: 0;
		left: 0;
	}
	body:not(.home):not(.page_404) #chapterPicture .title_and_bc {
		position: relative;
		padding: 5%;
	}
	body:not(.home) #chapterPicture .title_and_bc h1 {
		font-size: 42px;
	}
}
@media (max-width: 1160px) {
	.trois_blocs_verts > div {
		padding: 30px !important;
	}
	body:not(.home) h2 {
		font-size: 20px;
	}
}
@media (max-width: 781px) {
	body:not(.home) #wrapperInner div#text > div#contact_box {
		text-align: center;
	}
	body:not(.home) #wrapperInner div#text > div#contact_box > div:last-child > div:last-child {
		justify-content: center;
	}
	body:not(.home) #wrapperInner div#text .wp-block-group__inner-container {
		padding: 50px 0px;
	}
	div div .wp-block-columns:not(.is-not-stacked-on-mobile).icone_rs > div {
		flex-basis: initial !important;
	}
	body:not(.home) div #wrapperInner div#text > iframe[src*="maps"] {
		height: 50vw;
	}
	footer .wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column.wp-container-12.wp-block-column {
		flex-basis: initial !important;
	}
	.cache-sur-mobile {
		display: none;
	}
	body:not(.home) #wrapperInner .wp-block-column iframe {
		height: 50vw;
		max-height: initial;
	}
}
@media (max-width: 890px) {
	div div.wpforms-container-full .wpforms-form .wpforms-submit-container {
		position: relative;
		bottom: 0;
		margin-top: 10px;
		text-align: center;
	}
}
@media (max-width: 880px) {
	section.newsContainer {
		position: relative;
		padding-bottom: 0;
		margin-bottom: 5%;
	}
	section.newsContainer .gauche {
		width: 100%;
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		right: 0;
	}
	section.newsContainer .gauche * {
		width: 100%;
		height: 100%;
	}
	section.newsContainer .gauche .chapoPicture.empty,
	section.newsContainer .gauche img {
		height: 100%;
	}
	section.newsContainer .droite {
		width: 100%;
		position: relative;
		color: #FFFFFF;
		text-align: center;
		padding: 50px;
		background: rgba(0,0,0,0.7);
	}
	section.newsContainer .droite > a:before {
		display: none;
	}
	section.newsContainer .droite > a {
		margin-top: 20px;
		background: linear-gradient(135deg, #1c984c, #92c63c);
		border-radius: 0;
		color: #FFFFFF;
		font-size: 14px;
		padding: 12px 15px !important;
		transition: 0.2s ease-in-out;
	}
}
@media (max-width: 1080px) {
	#products .titres span.titre_gris {
		font-size: 100px;
	}
}






































































/* ---------------------------- VERSION MOBILE ---------------------------- */

@media (max-width: 500px) {
	header {
		height: 60px;
	}
	body.home #wrapper, body:not(.home) #chapterPicture {
		margin-top: 60px;
	}
	header div #nested {
		top: 10px;
		right: 10px;
	}
	header div #nested .contentSmart span {
		width: 22px;
	}
	header div #nested .contentSmart > span:nth-child(2) {
		margin: 5px 0px;
	}
	header #headerBoxes ul > li a img {
		height: 16px;
	}
	header #headerBoxes ul > li {
		margin-right: 15px;
	}
	header #logo img {
		height: 36px;
	}
	header #headerBoxes {
		top: 23px;
	}
	body.menu_open header div #nested .contentSmart > span:nth-child(3) {
		top: -6px;
	}
	body.menu_open header div #nested .contentSmart > span:nth-child(1) {
		top: 8px;
	}
	header #nested ul.firstLevel > li {
		max-width: 80vw;
	}
	header #nested ul.firstLevel li a {
		font-size: 15px;
	}
	header #nested ul.firstLevel > li.menu-item-has-children > a:after {
		right: -5px;
		top: 8px;
	}
	#video .logo img {
		height: 16vw;
	}
	#video .logo p {
		width: auto;
		font-size: 13px;
	}
	#video .logo {
		left: 0;
		top: 0;
		transform: none;
		right: 0;
		bottom: 0;
		max-width: 100%;
		padding: 10px 5%;
		box-sizing: border-box;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
	header #nested ul.firstLevel li ul li a {
		font-size: 12px;
	}
	#products .titres h1, 
	#innovation .titres h2, 
	#services > .container .titres h2 {
		font-size: 32px;
	}
	#products .titres h2 {
		font-size: 18px;
		margin-top: 20px;
	}
	#products .titres {
		margin-bottom: 60px;
	}
	#products {
		padding-top: 60px;
		padding-bottom: 25px;
		margin-bottom: 40px;
	}
	#products .container_slick .slick-prev, 
	#products .container_slick .slick-next, 
	#galerie .slick-prev, 
	#galerie .slick-next, 
	#secteurs_mobile_only .slick-prev, 
	#secteurs_mobile_only .slick-next {
		margin-top: -20px;
		width: 40px;
		height: 40px;
		background-size: 6px !important;
	}
	#products .container_slick .item img {
		height: 70vw;
	}
	#products .container_slick .item .fond_gris {
		padding: 20px;
		transition: 0.15s;
	}
	#products .container_slick .item:hover img {
		transform: none;
	}
	#products .container_slick .slick-prev, #products .container_slick .slick-next {
		bottom: 95px;
		top: 0;
		margin: auto;
	}
	#products .container_slick .slick-next {
		right: 9px;
	}
	#products .container_slick .slick-prev {
		left: 9px;
	}
	#secteurs_mobile_only {
		margin: 0px auto 110px;
	}
	#secteurs_mobile_only .slick-slide {
		padding: 0 10px;
	}
	#secteurs_mobile_only .slick-slide span.tooltip {
		line-height: 1.5em;
	}
	#secteurs_mobile_only .slick-slide span.tooltip {
		line-height: 1.5em;
		height: 75px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	#secteurs_mobile_only .slick-prev {
		right: 60px;
	}
	#secteurs_mobile_only .slick-next {
		left: 60px;
	}
	#secteurs_mobile_only .slick-prev, #secteurs_mobile_only .slick-next {
		bottom: -70px;
	}
	#edito {
		padding-top: 30px;
		margin-bottom: 70px;
	}
	#edito > div.gauche h2 {
		font-size: 18px;
	}
	#edito > div.gauche > p:first-child {
		font-size: 14px;
	}
	#edito > div.gauche p {
		line-height: 1.8em;
	}
	#innovation .titres {
		margin-bottom: 30px;
	}
	#innovation .container_flex .droite {
		padding: 30px;
	}
	#innovation .container_flex .droite h2 {
		font-size: 18px;
		margin: 0 0 25px 0;
	}
	#innovation .container_flex .droite p {
		line-height: 1.8em;
		margin: 0 0 8px 0;
	}
	#innovation {
		margin-bottom: 65px;
	}
	#services > .container .titres span.best_features {
		font-size: 14px;
	}
	#services {
		padding: 60px 0;
	}
	#services > .container .titres {
		margin-bottom: 35px;
	}
	#services > .container .container_flex .item p {
		font-size: 15px;
	}
	#galerie {
		padding: 60px 0px;
	}
	footer #footerInner {
		padding: 65px 0px 55px 0px;
	}
	footer .wp-block-columns > div.wp-block-column .wp-block-image img {
		width: 32px;
	}
	body {
		font-size: 15px;
	}
	#products .container_slick {
		position: relative;
		width: 90%;
		margin: 0 auto;
	}
	body:not(.home) #chapterPicture .title_and_bc h1 {
		font-size: 32px;
		margin-bottom: 20px;
	}
	body:not(.home) #chapterPicture .widget_breadcrumb {
		font-size: 13px;
	}
	body:not(.home):not(.page_404) #chapterPicture .title_and_bc {
		padding: 35px 5%;
	}
	body:not(.home) #wrapperInner {
		padding-top: 45px;
	}
	body:not(.home) h2,
	body:not(.home) #wrapperInner div#text > div#contact_box > div:first-child > p:last-child {
		font-size: 18px;
	}
	.wp-block-spacer {
		max-height: 50px;
	}
	body:not(.home) #wrapperInner p + .wp-block-spacer {
		margin-top: -15px;
	}
	body:not(.home) #wrapperInner div#text > div#contact_box > div:first-child > p:first-child {
		margin-bottom: 18px;
	}
	#container {
		margin: 0px 0px 60px 0px;
	}
	body:not(.home) h3 {
		font-size: 15px;
		margin-bottom: 10px;
	}
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure {
		width: 48% !important;
		margin: 0 4% 4% 0 !important;
	}
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(2),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(4),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(6),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(8),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(10),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(12),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(14),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(16),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(18),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(20),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(22),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(24),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(26),
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure:nth-child(28) {
		margin-right: 0 !important;
	}
	body:not(.home) #wrapperInner figure.wp-block-gallery > figure img {
		height: 30vw !important;
	}
	body:not(.home) #wrapperInner .bouton-classique a.wp-block-button__link,
	section.newsContainer .droite > a {
		font-size: 12px;
	}
	.pager > a, .pager > span {
		font-size: 13px;
	}
	body.page_404 div#wrapperInner {
		padding-top: 0;
	}
	#wrapperInner .wp-block-columns.icone_rs img {
		width: 40px;
	}
	td {
		font-size: 14px;
	}


}





@media (max-width: 390px) {
	#video .logo img {
		height: 60px;
	}
	#video {
		height: 225px;
	}
}
@media (max-width: 320px) {
	#secteurs_mobile_only .slick-slide img {
		height: 55vw;
	}
	#edito > div.droite .chiffres > div:first-child {
		margin-right: 25px;
	}
	#secteurs_mobile_only .slick-slide span.tooltip {
		height: 64px;
	}
}
@media (max-width: 370px) {
	#edito > div.droite .chiffres {
		padding: 35px;
	}
}
@media (max-width: 350px) {
	#products .titres h1, 
	#innovation .titres h2, 
	#services > .container .titres h2 {
		font-size: 28px;
	}
}




body:not(.home) #wrapperInner .wp-block-column .wp-block-cover {
	padding: 30px;
}