html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, 
p, blockquote, pre, a, abbr, address, cite, code, del, dfn, em, 
img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, hr, 
dl, dt, dd, ol, ul, li, fieldset, form, label, legend, 
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figure, figcaption, hgroup, 
menu, footer, header, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	box-sizing:border-box;
}
body, html {
	width:100%;
	background:#FFF;
}
html, input, select, textarea {
	font-family: "Roboto", sans-serif;
	color:#4c4d4f;
	font-size:1em;
	line-height: 1.4em;
	font-weight: 400;
}
    

a:focus { 
	outline:0;  /* Enlève le pointille sur les liens (notamment visible sur les supports mobiles*/
}

div#global {
	position:relative;
	height:100%;
	background:#FFF /*url("../img/public/contenu_fond_bg.png") no-repeat bottom right*/;
}
.general_content {
	width:92%;
	max-width:1400px;
	padding:0;
	margin:0 auto;
	/*display:table;*/ /* enlever le 05/10/2023 car cela genait la gestion du overflow-x pour les tableaux (table dans le contenu) trop large*/
	/*display: inline-table;*/
	position:relative;
}


/* HEADER */

div#header_all {position:fixed;width:100%;z-index:100;min-height:156px;background:#FFF;}

div#header_top {position:relative; width:100%; margin:0; padding:0; display:table; background:var(--cg_rouge);}
div#header_top_menu {position:relative; width:100%; display:table; padding:10px 0;}
div#header_top_menu p {float:right;font-size:0.8em;}

.top_access {margin:0 10px; padding:0 0 0 50px;}

.top_access.rdv {background:url("../img/public/picto_lieu.svg") center left no-repeat;background-size: 40px;}
.top_access.contact {background:url("../img/public/picto_contact.svg") center left no-repeat;background-size: 40px;}
.top_access.postuler {background:url("../img/public/picto_recrutement.svg") center left no-repeat;background-size: 40px;}

.top_access a{text-decoration:none; display:table; color:#FFF;}
.top_access:hover a {color:var(--cg_bleufonce);}

.top_access.baseline {padding:0;margin:0 20% 0 0; text-transform: uppercase; color:#FFF;}

.top_access_txt1 {font-size:0.9em;}
.top_access_txt2 {font-size:1.3em;}
.top_access_txt3 {font-size:1.6em;}
.top_access_txt5 {font-size:1.4em;}
.top_access_txt4 {font-size:1.2em;}

div#header_cadre {position:relative; z-index:99; width:100%; min-height:70px;margin:0; padding:0; display:table; border-bottom:4px solid var(--cg_vert);}


div#header_all.header_scroll {position:fixed;width:100%;z-index:100;min-height:156px;background:#FFF;}

div#header_logo {position:absolute; width:292px; top:0; z-index:101;}

header {position:relative; float:right; display:table; padding:25px 0 0 0;margin:0; width:calc(100% - 300px);}

div#header_logo img { width:auto; max-width:100%;}


div#header_content {position:relative;width:100%;margin:0 auto;}


div#header_right {position:relative;width:100%;}


div#header_responsive {display:none;position:relative;float:right;width:110px;}



/* MENU */

div#header_nav{width:100%; margin:0; padding:0;}
div#header_nav_content {width:100%;}


div#menu_cadre {
	position:relative;
	float:right;
	width:100%;
}

div#menu{
	position:relative;
	width:100%;
	margin:0 auto;
}
div#menu ul, div#menu li { list-style:none;}
ul.menu_list{
	position:relative;
	margin:0;
	padding:0;
	width:100%;
	display:table;
}




ul.menu_list li{
	position:relative;
	list-style:none;
	float:right;
	font-size:1.05em;
}
ul.menu_list li.niveau1 {
	font-weight:400;
	text-align:center;
	margin:0;
	padding:0 1.5% 26px 1.5%;	
	color:var(--cg_rouge);
}

ul.menu_list li.niveau1:before {
    content: "";
    position: absolute;
    width: 40px;
	left:calc(50% - 20px);
    height: 3px;
    bottom: 25px;
	border-bottom:3px solid var(--cg_bleufonce);
	transform: scaleX(0);  
  	transition: transform 150ms ease-in-out;
}
ul.menu_list li.niveau1:hover:before {transform: scaleX(1);} /* apparition du border à partir du milieu */


ul.menu_list ul{
	position:relative;
	display:none;
	padding:0;
	margin:-1px 0 0 0;
}
#menu_list li.sousmenu_visible:hover ul {   
	position: absolute;
	background: var(--cg_rouge);
	border-left: 4px solid var(--cg_blanc);
	border-right: 4px solid var(--cg_blanc);
	border-bottom: 4px solid var(--cg_blanc);
	color:#FFF;
	left: -50px;
	margin: 0;
	display: inline-block;
	z-index: 200;
	top: 61px;
	width:230px;
}
ul.menu_list li.niveau2 {
	width:100%;
}


ul.menu_list li.niveau1 a{
	text-decoration:none;
	color:var(--cg_rouge);
	display:block;
}
ul.menu_list li.niveau1 a.menu-no-click {pointer-events: none;}
ul.menu_list li.niveau1 a {	
	padding:8px 0 5px 0;		
}
/*ul.menu_list li.niveau2 a{
	padding:8px 10px 8px 2px;
	color:#002e62;
}*/
ul.menu_list li.niveau1:hover{
	color: var(--cg_bleufonce);
}
ul.menu_list li:hover a {
	color:var(--cg_bleufonce);
	width:100%;
	height:100%;
}
div#menu ul.menu_list li.niveau2 a {color:#FFF !important;font-size:0.9em !important;padding: 5px 0 5px 20px;border-top: 1px solid var(--cg_blanc); text-align:left; background:url(../img/public/pagination_next.png) 5px 6px no-repeat;}
div#menu ul.menu_list li.niveau2:hover {
	background:var(--cg_bleufonce);
}
div#menu ul.menu_list li.niveau2:hover a {color:var(--cg_blanc) !important;background:url(../img/public/pagination_next.png) 7px 6px no-repeat;}


/* aspect menu au scroll */





/* MENU RESPONSIVE */

#menu_responsive {font-size:1em; font-weight:300;}

.header_scroll .menu_item_name {color: var(--cg_rouge);}
.header_scroll .menu_item_picto a.picto_menu_r::before, .header_scroll .menu_item_picto a.picto_menu_r::after, .header_scroll .menu_item_picto a.picto_menu_r span { background:var(--cg_rouge);}

#header_coord_r {
	padding:0 10px 15px 20px;
	margin:15px 0 0 0;
}

#header_coord_r p { padding:5px 0 5px 40px;margin:5px 0;width: 100%;}
#header_coord_r p.header_coord_nom {padding:5px 0 5px 0;}
#header_coord_r a { color:inherit; text-decoration:none;}

.menu_list_r .mm-navbar.menu_r_titre {
	padding:0 10px !important;
	border-bottom-style:none;
}
.menu_list_r li.niveau1 {font-size:0.9em;padding:5px 0 5px 0;color:#243746;}
#menu_responsive li.niveau2, #menu_responsive li.niveau3, #menu_responsive li.niveau4 {font-size:0.9em;padding:10px 0;}
.menu_list_r li.niveau1:hover, .mm-listview li:hover {background:#e4e3e3;}

#header_social_r:hover, #header_coord_r:hover {background:none;}


.menu_avec_picto {position:relative;width:100%;overflow:hidden; padding:10px 0 10px 50px;}

p.header_coord_adresse {font-size:0.9em;
	background:url(../img/public/footer_adresse.png) left center no-repeat;
	background-size:26px;color:#243746;
}
p.header_coord_tel {font-size:0.9em;
	background:url(../img/public/footer_tel.png) left center no-repeat;
	background-size:26px;color:#243746;
}
p.header_coord_mobile {font-size:0.9em;
	background:url(../img/public/footer_tel.png) left center no-repeat;
	background-size:26px;color:#243746;
}
p.header_coord_mail {font-size:0.9em;
	background:url(../img/public/footer_email.png) left center no-repeat;
	background-size:26px;color:#243746;
}

#header_social_r {
	overflow:hidden;
	padding:0 10px 15px 20px;
	margin:15px 0;
}

div#header_social {
	position:relative;
	float:right;
}
p.header_social_img {
	float:left;
	width:26px;
	height:26px;
	margin: 0 14px 0 0;
	padding:0;
}
p.header_social_img img {	
	filter: grayscale(1);
	-webkit-filter: grayscale(1); /* Safari 6.0 - 9.0 */
	-moz-filter: grayscale(1);
    -o-filter: grayscale(1);
    -ms-filter: grayscale(1);
}
p.header_social_img img:hover {
	filter: grayscale(0);
	-webkit-filter: grayscale(0); /* Safari 6.0 - 9.0 */
	-moz-filter: grayscale(0);
    -o-filter: grayscale(0);
    -ms-filter: grayscale(0);
}


/* MIDDLE */
div#middle {padding:156px 0 0 0; /*padding:0;*/ overflow: hidden;}
div#middle_content {
	margin:0 auto;
	padding:0 0 0 0;
}
.contenu {
    position: relative;
    margin: 0 auto;
    overflow: hidden;
}

div#page_context {position:relative; margin:20px auto; padding:30px 0; background:url(../img/public/context_title_background.jpg) center no-repeat;}
div#page_context a {text-decoration:none; color:inherit;}
.context_title {color:#023247; font-size:1.4em; font-weight: bold; text-transform: uppercase; float:left; margin:4px 10px 0 0;}
div#page_context p.context_sstitle {color:#FFF; font-size:1.6em; font-weight: bold; text-transform: uppercase; float:left;}


.h1_cadre {position:relative;width:100%;padding:10px 0 20px 0;margin:0 0 50px 0;background:var(--cg_rouge);color:#FFF;text-align:right;}


/* FIL ARIANE */
.fil_ariane {position:relative;margin:0 auto; padding:8px 20px 5px 20px;font-size:0.9em;text-align:left;background:var(--cg_vert);}
.fil_ariane a {position:relative;width:100%; text-decoration: none; color:var(--cg_blanc);}
.fil_ariane a:hover { color:var(--cg_rouge);}
.ariane_actif {color:var(--cg_bleufonce) !important;}
.ariane_classic {color:var(--cg_blanc);}
.ariane_sep {color:var(--cg_blanc);}




/* GOOGLE MAP */
div#map_titre {color:#FFF;font-size:1.4em;margin:15px auto;width:100%;text-align:center;}
div#map {
	position:relative;
	height:400px;
	width:100%;
	z-index:1;
}

div#gm_infobulle {
	width:200px;
	overflow:hidden;
	text-align:center;
}
.gm_nom {
	font-size:1.2em;
	margin:5px 0;
	font-weight:500;
}

/*div#gm_infobulle img { width:100%;}*/

.gm_tel {font-size:1.3em;font-weight:600;}


/* FOOTER */

footer {width:100%;padding:0;margin:50px auto 0 auto;}

div#footer_top {position:relative; width:100%; padding:35px 0; margin:0 auto; background:var(--cg_bleufonce);}

div#footer_top_content {display:grid;grid-template-columns:repeat(4, 1fr);grid-column-gap: 30px; grid-row-gap: 30px;}
.footer_top_column {grid-column:span 1;}

.footer_logo img {width:100%; max-width:250px;}
.footer_coord {color:#FFF; font-size:1.2em;}
.footer_coord p { padding:5px 0 5px 50px;}
.footer_coord_adresse {font-size:0.9em;margin:15px 0 0 0; background:url('../img/public/footer_adresse_blanc.png') left center no-repeat;}
.footer_coord_tel {margin:15px 0 0 0; background:url('../img/public/footer_tel_blanc.png') left center no-repeat;}
.footer_coord_horaire {font-size:0.8em;margin:15px 0 0 0; background:url('../img/public/footer_horaire_blanc.png') left center no-repeat;}

.footer_sitemap_service, .footer_sitemap {padding:15px 0 0 0;}

.footer_menu_item {text-align:left; color:var(--cg_blanc);}
.footer_menu_niveau1 { font-size:1.1em; margin:15px 0 0 0; font-weight:bold;}
.footer_menu_niveau2 { font-size:0.9em; margin:3px 0;padding: 0 0 0 20px; background:url(../img/public/puce.svg) top left no-repeat; background-size:25px;}


.footer_menu_niveau1 a:after {border-bottom:4px solid var(--cg_blanc);}

.footer_menu_niveau2 a:after {border-bottom:2px solid var(--cg_blanc);}

.footer_menu_niveau1 a:after, .footer_menu_niveau2 a:after {
    content: "";
    position: relative;
    width: 50%;
	left:0;
	height:2px;
	transform: scaleX(0);  
  	transition: transform 150ms ease-in-out;
	display:table;
	border-bottom:3px solid var(--cg_vert);
	
}
.footer_menu_niveau1 a:hover:after, .footer_menu_niveau2 a:hover:after {transform: scaleX(1);} /* apparition du border à partir du milieu */


.footer_menu_item a {color:inherit; display:table; text-decoration:none;}




div#footer_legal {width:100%; padding:10px 60px; margin:0;font-size: 0.9em;color:#FFF;background: var(--cg_vert);}
div#footer_legal_link {position:relative;overflow: hidden; text-align: center;}
div#footer_legal_link a {color:#FFF; text-decoration:none;}

@media screen and (max-width : 1600px) {
}
@media screen and (max-width : 1400px) {
	.top_access.baseline {margin: 0 10% 0 0;}
	.top_access_txt2 {font-size: 1.1em;}
}
@media screen and (max-width : 1300px) {
	.top_access.baseline {display:none;}
}
@media screen and (max-width : 1300px) {
	.footer_top_column {grid-column:span 2;}
	div#footer_top .general_content {max-width: 700px;}
}
@media screen and (max-width : 1100px) {
	div#header_all, div#header_all.header_scroll {min-height:127px;}
	div#middle {padding:127px 0 0 0;}
	div#header_logo, .header_scroll div#header_logo { width: 240px;}
	header, .header_scroll header {width: calc(100% - 250px);padding:10px 0 0 0;}
	div#header_cadre {min-height: 60px;}
	
	ul.menu_list li.niveau1 {padding: 0 1.5% 10px 1.5%;}
	ul.menu_list li.niveau1::before {bottom: 10px;}
	
	#menu_list li.sousmenu_visible:hover ul {top: 45px;}
	
}
@media screen and (max-width : 1000px) {	
	
	div#header_responsive {display:block;padding: 0;}
	div#header_right {display:none;}	
	
}
@media screen and (max-width : 959px) {		
}
@media screen and (max-width : 900px) {			
	
	div#footer_legal_logo, div#footer_legal_link {float:none; margin:0 auto; width:100%;text-align: center;}
}
@media screen and (max-width : 800px) {	
	div#header_logo, .header_scroll div#header_logo {width: 118px; top: 67px;}
	.fil_ariane {padding: 5px 0; font-size:0.9em;}
}
@media screen and (max-width : 650px) {	
	
	.contenu {margin: 0 auto;}
	div#page_context {padding:20px 0;margin: 20px auto 0 auto; font-size:0.8em;}
	
}
@media screen and (max-width : 600px) {
	div#header_social {display:none;}
	.top_access {margin: 0 5px;}
	.top_access_txt {display:none;}
	.top_access_txt5 {font-size: 1.2em;}
	.top_access.rdv, .top_access.contact, .top_access.postuler {background-size: 27px;}
	.top_access.rdv {max-width: 130px; line-height:1.1em;padding:0 0 0 36px;}
	.top_access.contact {padding:3px 0 2px 36px;}
	.top_access.postuler {padding:3px 0 4px 36px;}
	div#header_logo, .header_scroll div#header_logo {top: 49px;}
	div#header_all, div#header_all.header_scroll {min-height: 113px;}
	div#middle {padding:113px 0 0 0;}
  
}
@media screen and (max-width : 550px) {	
	.menu_item_name {display:none;}	
	div#header_responsive {width: 70px;}
	
	div#footer_top_content {grid-row-gap: 0;}
	.footer_top_column {grid-column:span 4;}
	div#footer_top .general_content {max-width: 250px;}
	.footer_sitemap { padding: 0;}
}
@media screen and (max-width : 515px) {
}
@media screen and (max-width : 500px) {		
	div#page_context {font-size:0.6em;}
	.context_title {margin: 2px 10px 0 0;}	
	
	div#footer_legal a {float:none;margin:10px auto;width: 100%;}
}
@media screen and (max-width : 450px) {		
	
	.top_access_txt5 {font-size: 1.1em;}
	.top_access_txt2 {font-size: 1em;}
	.top_access.rdv, .top_access.contact, .top_access.postuler {background-size: 22px;}
	.top_access.rdv {max-width:102px; line-height:1em; padding:0 0 0 29px;}
	.top_access.contact {padding:3px 0 2px 29px;}
	.top_access.postuler {padding:1px 0 4px 29px;}
	footer {font-size:0.8em;}
	div#header_top_menu {padding: 10px 0 9px 0;}
	div#header_logo, .header_scroll div#header_logo { top: 47px; }
	div#header_all, div#header_all.header_scroll {min-height: 110px;}
	div#middle {padding:110px 0 0 0;}
}
@media screen and (max-width : 400px) {		
}
@media screen and (max-width : 380px) {	
	.top_access.postuler {display:none;}
}