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: 'Lato', sans-serif;
	color:#333333;
	font-size:1em;
}

.font_lato{
	font-family: 'Lato', sans-serif;
}
.font_roboto{
	font-family: 'Roboto Condensed', sans-serif;
}
.font_josefin{
	font-family: 'Josefin Sans', sans-serif;
}
    

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;*/
	position:relative;
}
.general_content1200 {
	width:92%;
	max-width:1200px;
	padding:0;
	margin:0 auto;
	display:table;
	position:relative;
}

/* CHARTE GRAPHIQUE COULEUR */
.cg_dore {color:#c1b467;}
.cg_bleu {color:#7ba5b3;}
.cg_blanc {color:#FFFFFF;}



/* HEADER */
div#header_cadre {position:absolute; z-index:99; width:100%;margin:0; padding:0;}

div#header_logo {position:absolute; width:209px;top:40px; left:8%; z-index:100;}
div#header_logo img { width:100%;}

header {position:relative;display:table;/*background:#7ba5b3;*/background:rgba(123,165,179,0.8);margin:80px 0 0 0; max-width:1280px; border-top-right-radius:0.5em; border-bottom-right-radius:0.5em; width:80%;}

div#header_content {position:relative;width:100%;margin:0 auto;}


div#header_right {position:relative; float:right; width:calc(100% - 380px); max-width: 800px;}


div#header_responsive {display:none;position:relative;float:right;width:140px;}
div#header_bottom {position:relative;display:table;float:left;width:calc(100% - 340px);}




div#header_cadre.header_scroll {position:fixed; top:0; background:#7ba5b3; border-bottom:1px solid #CCC;padding:0;}

div#header_cadre.header_scroll {
	-webkit-transition: all 0.5s ease; /* Safari et Chrome */
	-moz-transition: all 0.5s ease; /* Firefox */
	-ms-transition: all 0.5s ease; /* Internet Explorer 9 */
	-o-transition: all 0.5s ease; /* Opera */
	transition: all 0.5s ease;
}

div#header_cadre.header_scroll div#header_logo {width:70px;top:5px;}
div#header_cadre.header_scroll header {margin:0;}

/* 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%;
	padding:0;
}

div#header_cadre.header_scroll div#menu_cadre {padding:0;}

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;
}

#menu_list ul li{ position:relative;list-style:none;}


#menu_list li a {
	color: inherit;
	display:block;
	outline:0;
	text-decoration:none;
}

#menu_list li ul{
	position:absolute;
	display:none;
	top:0;
	width:100%;
	z-index:1000;
	animation: fadein 1s;
	-moz-animation: fadein 1s;
	-webkit-animation: fadein 1s;
	-o-animation: fadein 1s;
}

/* niveau 1 */
#menu_list li {
	margin:0;
	list-style-position:outside;
	width:auto;
	text-align:center;
	padding:0;
}

#menu_list li.niveau1{
	position:relative;
	float:left;	
	font-size:1.2em;
	font-weight: 400;
	margin:0 4%;
	text-transform:uppercase;
	color:#2c2c2c;
	padding:45px 0;
}

div#header_cadre.header_scroll #menu_list li.niveau1 {padding:25px 0;}


#menu_list li.niveau1 a {padding:10px 0 5px 0;}
#menu_list li.niveau2 a, #menu_list li.niveau3 a {padding:0;}



#menu_list li.niveau1:hover, #menu_list li.niveau1.hover {color:#FFF !important;background:url("../img/public/menu_hover.png") center no-repeat;}

div#header_cadre.header_scroll #menu_list li.niveau1 a {padding:3px 0 5px 0;}


#menu_list li.niveau1:hover ul li ul {display: none;}



/* niveau 2 */

#menu_list ul {display:none;}

#menu_list li ul li.niveau2 ul {top: 0px;}
#menu_list li.niveau1:hover ul {
    display: block;
    padding: 128px 0 0 0;
    margin: 0 0 0 -50px;
    color: #FFF;    
}
div#header_cadre.header_scroll #menu_list li.niveau1:hover ul.niveau1 {padding: 81px 0 0 0;}
div#header_cadre.header_scroll #menu_list li.niveau1:hover ul li ul { margin-top: 0; }

#menu_list li.niveau1 ul li {font-size:13pt;min-width:180px;width:100%;/*line-height:40px;height:40px;*/padding:10px 10px;background: RGBA(193,180,103,1);display:table;}
#menu_list li ul li:hover {background: #363b44;}

#menu_list li.niveau1 li.niveau2:hover a {color: #FFF;}



/* niveau 3 */

div#menu li.niveau1:hover ul li ul{display:none; padding: 0;}
#menu_list li.niveau1:hover ul li:hover ul{display:block;margin:0 0 0 170px;background:#709525;}
div#menu li.niveau3 {min-width: 160px !important;}

/* gestion des couleurs de menu par ville */

#menu_list li.niveau1.menu-challans:hover { background:#062a78; color: #FFF;border:1px solid #FFF;}
#menu_list li.niveau1.menu-beauvoir-sur-mer:hover { background:#f47300; color: #FFF;border:1px solid #FFF;}
#menu_list li.niveau1.menu-noirmoutier:hover { background:#00a89e; color: #FFF;border:1px solid #FFF;}

#menu_list li.niveau1 ul li.niveau3 a { color:#FFF;}

#menu_list li.niveau1 ul li.niveau3 a { color:#FFF !important;}



/* MENU RESPONSIVE */
#menu_responsive {font-size:1em; font-weight:300;}



.header_scroll .menu_item_name {color: #FFF;}
.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:#FFF;}

#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_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;}


/* FIL ARIANE */
.fil_ariane_cadre {position: relative;width:100%; padding:10px; background:var(--cg_gris_clair);}
.fil_ariane {position:relative;margin:0 auto; padding:10px 20px;font-size:0.7em; display: flex; flex-wrap: nowrap; overflow-x: auto;}
.fil_ariane a {position:relative; display: table; flex: none; text-decoration: none; text-transform: uppercase;}
.fil_ariane a:hover { color:#7ba5b3;}
.ariane_actif {color:#7ba5b3;}
.ariane_classic {color:#303030;}
.ariane_sep {padding:0 5px;}



/* BOTTOM */
div#bottom_sep {position:relative;margin:0;padding:0;width:100%;height:150px;background:#FFF url(../img/public/bottom_sep.png) center bottom no-repeat;background-size:100%;}
div#bottom {position:relative;width:100%;background:#b1b6b4;}
div#bottom_cadre {position:relative;overflow:hidden;width:calc(100% - 150px);margin:-100px auto 0 auto;}


/* 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;}



/* BOTTOM */

div#bottom {
	posiion:relative;
	width:100%;
	padding:30px 0;
	background: #FFF;
}

div#bottom_content {
	max-width:1200px;
	display:grid;
	grid-template-columns:repeat(3, 1fr); grid-gap: 10%;
}
.bottom_logo {grid-column:span 1;}
.bottom_coord {grid-column:span 1;}
.bottom_service {grid-column:span 1; padding:30px 0 0 0;}

.bottom_logo img {width:100%; max-width:209px;}

.bottom_coord_titre {font-size:1.8em; text-transform: uppercase; margin:30px 0 20px 55px;}
.bottom_coord_tel {background:url("../img/public/footer_tel.png") left center no-repeat; padding:15px 0 15px 55px;font-size:1.2em;}
.bottom_coord_adresse {background:url("../img/public/footer_adresse.png") left center no-repeat; padding:15px 0 15px 55px;}

p.footer_menu_niveau1 {position:relative; margin:10px auto; text-transform: uppercase; font-size:1.1em; font-weight: bold;}
p.footer_menu_niveau2 {position:relative; margin:5px auto 0 auto; font-size:1em; }
p.footer_menu_niveau1 a, p.footer_menu_niveau2 a { color: inherit; text-decoration: none;}

/* FOOTER */

footer {width:100%;padding:0;text-align:center;background:#000;}


div#footer_content {width:100%; padding:10px; font-size: 0.9em; line-height: 1.6em;color:#FFF;}

footer a {color:inherit;text-decoration:none;}
footer a:hover {text-decoration:underline;}

.footer_baseline {position:relative; background:url("../img/public/footer_baseline_bg.png") center repeat-x; padding:50px 100px; display:table; font-size:1.2em;}
.footer_baseline_content {position:relative; background:#243746; padding: 0 15px;}
.footer_sep {font-weight: bold;}

@media screen and (max-width : 1600px) {
	
}
@media screen and (max-width : 1450px) {
	
}
@media screen and (max-width : 1350px) {
	#menu_list li.niveau1 {margin:0 3%;}
	
}

@media screen and (max-width : 1280px) {
	
	#menu_list li.niveau1 {font-size: 1em;margin: 0 2.5%;}
	#menu_list li.niveau1:hover ul.niveau1 {padding: 124px 0 0 0;}
	div#header_cadre.header_scroll #menu_list li.niveau1:hover ul.niveau1 {padding: 77px 0 0 0;}
}


@media screen and (max-width : 1100px) {
	
	div#header_logo { width:150px;top:10px;}
	header {margin:50px 0 0 0;}
	div#header_right { width: calc(100% - 270px); }
	
	#menu_list li.niveau1 {padding:20px 0;}
	#menu_list li.niveau1:hover ul.niveau1 {padding: 74px 0 0 0;}
	#menu_list li.niveau1:hover ul.niveau1 li {font-size:0.95em;}

}
@media screen and (max-width : 1050px) {
}

@media screen and (max-width : 1000px) {
		
}
@media screen and (max-width : 959px) {
	div#header_logo { width:120px;top:7px;}
	header {margin:30px 0 0 0;}
	div#header_right { width: calc(100% - 220px); }
	
	
	div#bottom_content {grid-template-columns:repeat(2, 1fr); grid-gap: 10%;
	}
	.bottom_logo {display:none;}
	.bottom_coord {grid-column:span 1; padding:0 0 30px 0;}
	.bottom_service {grid-column:span 1; padding:30px 0 30px 0;}
}
@media screen and (max-width : 900px) {
	div#header_logo {left:4%;}
	div#header_right { width: calc(100% - 190px); }
	#menu_list li.niveau1 {margin:0 2%;}
}
@media screen and (max-width : 850px) {
	
}

@media screen and (max-width : 800px) {

	div#header_responsive {display:block;padding: 6px 0 0 0;}
	div#header_cadre.header_scroll div#header_responsive {padding: 5px 0 0 0;}
	div#header_right {display:none;}
	div#header_logo { width:100px;top:10px;}
	header {width:350px;}
	div#header_cadre.header_scroll header {width: 100%; padding:10px 0;}
  	div#header_cadre.header_scroll div#header_logo {width:65px;}
	
}
@media screen and (max-width : 700px) { 
	
}
@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#bottom_content {max-width:290px;}
	.bottom_coord {grid-column:span 2; padding:20px 0;}
	.bottom_service {grid-column:span 2; padding:0 0 20px 0;}
	
}
@media screen and (max-width : 550px) {
	header {width: 220px;}
	div#header_responsive{ width: 80px;}
	.menu_item_name {display:none;}
	
}

@media screen and (max-width : 500px) {
	
	div#page_context {font-size:0.6em;}
	.context_title {margin: 2px 10px 0 0;}
	
}

@media screen and (max-width : 480px) {	
	
	footer {font-size:0.8em;}
}

@media screen and (max-width : 450px) {	
	
}

@media screen and (max-width : 400px) {
	
	header {width:250px;}
	
	.menu_item_picto a.picto_menu_r {padding: 10px 20px 10px !important;}
	
	
}

@media screen and (max-width : 350px) {
	
}
@media screen and (max-width : 300px) {
	
}