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:#333333;
	font-size:1em;
	line-height: 1.6em;
}

.font_roboto{
	font-family: 'Roboto', 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_orange {color:#f3954a;}
.cg_bleu_clair {color:var(--cg_bleu_clair);}
.cg_bleu_fonce {color:var(--cg_bleu_fonce);}
.cg_gris_clair {color:var(--cg_gris_clair);}



/* HEADER */
div#header_cadre {position:relative; z-index:100; width:100%;margin:0; padding:0; display: table;}

div#header_top {position:relative; overflow: hidden; width:100%; background:#FFF; padding:15px 15px 10px 15px;}
div#header_top img { width:100%;}

div#logo_baseline { position: relative;  width: 188px; float: left;}
div#logo { width: 188px; height: 70px;  margin: 0;}
div#baseline { color: #878786; font-size: 12px;  margin: 0 0 0 5px;}
div#slogan { text-transform: uppercase; overflow: hidden; margin: 20px auto 0 auto; font-weight: bold; color: #3e3e3e; font-size: 1.6em; text-align: center; width: calc(100% - 520px);}
div#logo_bosch { position: relative; float: right; width:265px;  margin: 0;}

header {position:relative;display:table;background:#003e60;margin:0; width:100%;}

div#header_content {position:relative;width:100%;margin:0 auto;}


div#header_right {position:relative;}


div#header_responsive {display:none;position:relative;float:right;width:140px;}




div#header_cadre.header_scroll {position:fixed; top:0; 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#logo {width:120px;height:50px;}
div#header_cadre.header_scroll div#baseline {font-size: 8px;line-height:8px;}
div#header_cadre.header_scroll div#logo_bosch { width:180px;}
div#header_cadre.header_scroll div#slogan { font-size: 1.4em;}
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:3px 0;
	max-width:800px;
}

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:19px;
	width:100%;
	z-index:1000;
	animation: fadein 1s;
	-moz-animation: fadein 1s;
	-webkit-animation: fadein 1s;
	-o-animation: fadein 1s;
}

div#header_cadre.header_scroll #menu_list li ul {top:13px;}

/* 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:0.9em;
	font-weight: bold;
	margin:0 2%;
	text-transform:uppercase;
	color:#FFF;
	padding:0;
}
#menu_list li.niveau1 a {padding:7px 0}
#menu_list li.niveau2 a, #menu_list li.niveau3 a {padding:0;}



#menu_list li.niveau1:hover, #menu_list li.niveau1.hover {color:#00a6ff !important;}

div#header_cadre.header_scroll #menu_list li.niveau1 a {padding: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: 20px 0 0 0;
    margin: 3px 0 0 -20px;
    color: #FFF;    
}

div#header_cadre.header_scroll #menu_list li.niveau1:hover ul li ul { margin-top: 0; }

#menu_list li.niveau1 ul li {font-size: 0.9em;min-width: 250px;width: 100%;padding: 10px;line-height:1em;background: RGBA(50,50,50,0.9);display:table;}
#menu_list li ul li:hover {background: var(--cg_bleu_clair);}

#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 110px;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 {position:relative;margin:30px auto; padding:8px 20px;font-size:0.7em; background:#f7f7f7;}
.fil_ariane a {position:relative;width:100%; text-decoration: none; text-transform: uppercase;}
.fil_ariane a:hover { color:var(--cg_bleu_clair);}
.ariane_actif {color:var(--cg_bleu_clair);}
.ariane_classic {color:#303030;}



/* 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;}




/* FOOTER COLUMN */
div#footer_top {background:#003e60; color:#FFF; font-size:1em; padding:0 0 30px 0;}
.footer_top_column1 {position:relative; float:left; width:55%; padding:0 20px; max-width:400px;}
.footer_top_menu {position:relative; float:right; width:40%; padding:0 20px; max-width:280px;}
.footer_contact_logo {max-height:75px; margin: 30px 0 0 45px;}
.footer_contact_logo img {max-height:75px; filter: brightness(0) invert(1);}
.footer_contact_titre {font-size:1.3em; font-weight: bold; padding:15px 0 15px 50px;}
.footer_contact_tel {background:url(../img/public/footer_tel.png) center left no-repeat; padding:15px 0 15px 50px;}
.footer_contact_mail {background:url(../img/public/footer_email.png) center left no-repeat; padding:15px 0 15px 50px;}
.footer_contact_mail a {color: inherit;text-decoration: none;}
.footer_contact_adresse {background:url(../img/public/footer_adresse.png) center left no-repeat; padding:15px 0 15px 50px;min-height: 74px;}
.footer_contact_label {text-align: center;}
.footer_contact_label img {max-width:100%;}

.footer_top_menu {padding:20px 0 0 0;}

p.footer_menu_niveau1 {position:relative; margin:10px auto; text-transform: uppercase; font-size:1.2em; font-weight: bold;}
p.footer_menu_niveau2 {position:relative; margin:5px auto 0 auto; font-size:0.9em; }
p.footer_menu_niveau1 a, p.footer_menu_niveau2 a { color: inherit; text-decoration: none;}

/* FOOTER */

footer {width:100%;padding:0 0 80px 0;text-align:center;background:#000;}


div#footer_content {width:100%; padding:10px;font-size: 0.8em;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) {
	div#slogan { margin: 20px auto 0 auto; font-size: 1.4em;}
	
	/*#menu_list li.niveau1 {font-size: 1em;}*/
	
}


@media screen and (max-width : 1100px) {
	
	div#slogan { margin: 10px auto 0 auto; font-size: 1.2em;}
	
}
@media screen and (max-width : 1050px) {
}

@media screen and (max-width : 1000px) {
	
	
		
}
@media screen and (max-width : 959px) {
	
	div#slogan { margin: 5px auto 0 auto; font-size: 1em; width: calc(100% - 340px);}
	div#logo_baseline { position: relative;  width: 120px;}
	div#logo {width:120px;height:50px;}
	div#baseline {font-size: 8px;line-height:8px;}
	div#logo_bosch { width:180px;}
	
}
@media screen and (max-width : 900px) {
	
}
@media screen and (max-width : 850px) {
		
	
}

@media screen and (max-width : 800px) {
	
	div#header_cadre {background:#003e60;}
	div#header_top {float:right;width:calc(100% - 90px); padding:15px 30px 0 30px;}
	
	div#slogan {font-size: 0.8em; float:none; width:100%; margin:0 auto; padding:5px 0 0 0;}
	div#header_cadre.header_scroll div#header_top {padding:15px 30px;}
	div#header_cadre.header_scroll div#slogan {display:none;}
	
	div#header_right {display:none;}
	.menu_item_name {float:none !important;}
	header {float:left; width:80px;}
	div#header_responsive {display:block;padding: 7px 0 0 5px; width:80px;}
	div#header_cadre.header_scroll div#header_responsive {padding: 7px 0 0 5px;}
	
	
}
@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) {

	
}
@media screen and (max-width : 550px) {
	div#header_top {padding:15px 15px 7px 15px;}
	div#logo_baseline, div#header_cadre.header_scroll div#logo_baseline {width:60%;}
	div#logo_bosch, div#header_cadre.header_scroll div#logo_bosch {width:40%;}
	div#slogan {font-size: 0.6em;line-height: 1em;}
	
	.footer_top_column1, .footer_top_menu {position:relative; float:none; width:100%; padding:0 20px; max-width:none;}
	.footer_top_menu {max-width:280px; margin:20px auto;}
}

@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; padding:0;}
}

@media screen and (max-width : 450px) {	
	
}

@media screen and (max-width : 400px) {
	
	
	.menu_item_picto a.picto_menu_r {padding: 10px 20px 10px !important;}
	
	
}

@media screen and (max-width : 350px) {
	
}
@media screen and (max-width : 300px) {
	
}