/*
Theme Name: Espace Client Eurotrans
Version: 1.0
Theme URI: http://www.bonbay.fr/
Author: Bonbay
Author URI: http://www.bonbay.fr/
Text Domain:
*/

/*	Copyright: (c) 2013 Alexander "Alx" Agnarson
	License: GNU General Public License v3.0
	License URI: http://www.gnu.org/licenses/gpl-3.0.html*/


/*RESET*/
/*---------------------------------------------*/
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,sub,sup,tt,var,b,u,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,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}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}
ol,ul{list-style:none}
blockquote,q{quotes:none}
blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}
table{border-collapse:collapse;border-spacing:0}


/*  Base awesome
================================================== */
.fa { width: 1em; text-align: center; }


/*  Base formulaire
================================================== */
input, textarea, button, select, label { font-family: inherit; }
input,
textarea,
button,
select,
label { font-size: 1rem; }
input::-moz-focus-inner,
button::-moz-focus-inner{ border: 0; padding: 0; }
input[type="text"],
input[type="password"],
input[type="email"],
input[type="submit"],
input[type="tel"],
button,
select,
textarea { margin: 0; border-radius: 0; width:100%;}
input,
textarea,
select,
button { -moz-appearance: none; -webkit-appearance: none; -moz-transition: all .2s ease; -webkit-transition: all .2s ease; transition: all .2s ease; }
input[type="checkbox"] { -moz-appearance: checkbox; -webkit-appearance: checkbox; }
input[type="radio"] { -moz-appearance: radio; -webkit-appearance: radio; }
label{ font-weight: 600; color: #444; }

input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="number"],
select,
textarea {
    background: #f5eeed;
    border: 1px solid #fff;
    color: #000;
    display: block;
    max-width: 90%;
    outline: none;
    padding: .5rem 5%;
    margin: 1rem 0;
}
input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus { border-color: #666;  }
label .required { color: #d13931; }
input[type="submit"],
button[type="submit"] {
    background: #d13931;
    color: #fff;
    padding: .5rem 1rem;
    font-weight: 600;
    display: inline-block;
    border: none;
    cursor: pointer;
    font-size: 20px;
   /* max-width: 50%;*/
}
input[type="submit"]:hover,
button[type="submit"]:hover { background: #000; }

div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing{
    border: 1px solid #d13931;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output{ border: 1px solid #d13931; color: #d13931; }


/*
 * jQuery FlexSlider v2.0
 * http://www.woothemes.com/flexslider/
 *
 * Copyright 2012 WooThemes
 * Free to use under the GPLv2 license.
 * http://www.gnu.org/licenses/gpl-2.0.html
 *
 * Contributing author: Tyler Smith (@mbmufffin)
 *
* Browser Resets */
.flex-container a:active,
.flexslider a:active,
.flex-container a:focus,
.flexslider a:focus  {outline: none;}
.slides,
.flex-control-nav,
.flex-direction-nav {margin: 0; padding: 0; list-style: none;}

/* FlexSlider Necessary Styles
*********************************/
.flexslider {margin: auto; padding: 0;width:100%;display: block;}
.flexslider .slides > li {display: none; -webkit-backface-visibility: hidden; position:relative} /* Hide the slides before the JS is loaded. Avoids image jumping */
.flexslider .slides img {width: 100%; display: block; border: none;}
.flex-pauseplay span {text-transform: capitalize;}

/* Clearfix for the .slides element */
.slides:after {content: "."; display: block; clear: both; visibility: hidden; line-height: 0; height: 0;}
html[xmlns] .slides {display: block;}
* html .slides {height: 1%;}

/* No JavaScript Fallback */
/* If you are not using another script, such as Modernizr, make sure you
 * include js that eliminates this class on page load */
.no-js .slides > li:first-child {display: block;}


/* FlexSlider Default Theme
*********************************/
.flexslider {position: relative;  zoom: 1; }
.flex-viewport {max-height: 2000px; -webkit-transition: all 1s ease; -moz-transition: all 1s ease; transition: all 1s ease;}
.loading .flex-viewport {max-height: 300px;}
.flexslider .slides {zoom: 1;}


/* Direction Nav */
.flex-direction-nav {*height: 0;}
.flex-direction-nav a {
    width: 37px; 
    height: 49px;  
    display: block; 
    background: url('gfx/fleches.png') no-repeat 0 0; 
    position: absolute; 
    top: 50%;
    z-index: 5000; 
    cursor: pointer; 
    text-indent: -9999px;
}
.flex-direction-nav .flex-next{ background-position: 100% 0; right:-80px; }
.flex-direction-nav .flex-prev{ left:-80px; }
.flexslider:hover .flex-next{ opacity: 0.8; }
.flexslider:hover .flex-prev{ opacity: 0.8; }
.flexslider:hover .flex-next:hover, .flexslider:hover .flex-prev:hover { opacity: 1; }
.flex-direction-nav .flex-disabled{ cursor: default; }

/* Control Nav */
.flex-control-nav{ width: 100%; position: absolute; bottom: -30px; text-align: center; }
.flex-control-nav li{ margin: 0 6px; display: inline-block; zoom: 1; display: inline; }
.flex-control-paging{
    width: 50%; 
    position: absolute; 
    left: 25%;  
    bottom:0px; 
    text-align: center; 
    height: 9px;
}
.flex-control-paging li{ display: inline-block; margin: 0 6px; width: 60px; height: 9px; }
.flex-control-paging li a {
    width: 60px;
    height: 9px;
    display: inline-block;
    background: rgba(255,255,255,0.4);
    cursor: pointer;
    text-indent: -9999px;
}
.flex-control-paging li a:hover { background:#fff;}
.flex-control-paging li a.flex-active { background: #fff; cursor: default; }

.flex-control-thumbs {margin: 5px 0 0; position: static; overflow: hidden;}
.flex-control-thumbs li {width: 25%;   margin: 0;}
.flex-control-thumbs img {width: 100%; display: block; opacity: .7; cursor: pointer;}
.flex-control-thumbs img:hover {opacity: 1;}
.flex-control-thumbs .flex-active {opacity: 1; cursor: default;}

@media screen and (max-width: 860px) {
  .flex-direction-nav .flex-prev {opacity: 1; left: 0;}
  .flex-direction-nav .flex-next {opacity: 1; right: 0;}
}

a.flex-caption{ background: url(img/fleche-txt.png) no-repeat;  padding-left:25px; ; padding-right:15px; font-family: 'PT Sans Narrow', sans-serif; font-size: 18px; color:#000; display:block; width:auto; position:absolute; bottom: 0px; width: 60%; left:22%; text-decoration:none; height: 36px; }
div.flex-caption{ background: url(img/fleche-txt.png) no-repeat;  padding-left:25px; ; padding-right:15px; font-family: 'PT Sans Narrow', sans-serif; font-size: 18px; color:#000; display:block; width:auto; position:absolute; bottom: 0px; width: 60%; left:22%; text-decoration:none; height: 36px; }
.etiquette-slogan{padding-top: 5px;}
a.flex-caption:hover{background: url(../img/fleche-txt.png) no-repeat 5px 12px #e2003b;color:#fff;text-decoration:none;}


@media screen and (max-width: 480px) {
 a.flex-caption{ background: url(../img/fleche-txt.png); font-family: 'PT Sans Narrow', sans-serif; font-size: 18px; color:#000; display:block; width:auto; position:absolute; bottom: 0px; width: 60%; left:22%; text-decoration:none; height: 36px; }
a.flex-caption:hover{background: url(../img/fleche-txt.png) no-repeat 5px 5px #e2003b;color:#fff;text-decoration:none;}
}
.slider{ position: relative; }
.slider ul{ margin:0; padding:0;  }


/** GRID ***/
.row{
    display: flex;
    width: 100%;
    align-items: flex-start;
    justify-content: flex-start;
    flex-flow: row wrap;
}
.row.nowrap{ flex-flow: row nowrap; }
.row.flow-row{ flex-flow: row wrap; }

.middle{ align-items: center; }
.flex-end{ align-items: flex-end; }


@media (max-width: 767px){
      /*.row{ flex-flow: column wrap; }
      .row.nowrap{ flex-flow: column nowrap; }*/
}

    .spannomargin-1, .spannomargin-2, .spannomargin-3,
    .spannomargin-4, .spannomargin-5, .spannomargin-6,
    .spannomargin-7, .spannomargin-8, .spannomargin-9,
    .spannomargin-10, .spannomargin-11, .spannomargin-12,
    .spannomargin-13, .spannomargin-14, .spannomargin-15,
    .spannomargin-16, .spannomargin-17, .spannomargin-18,
    .spannomargin-19, .spannomargin-20, .spannomargin-21,
    .spannomargin-22, .spannomargin-23, .spannomargin-24{ width: 100%; }

    .span-1, 
    .span-2, 
    .span-3, 
    .span-4, 
    .span-5, 
    .span-6, 
    .span-7, 
    .span-8, 
    .span-9, 
    .span-10, 
    .span-11, 
    .span-12, 
    .span-13, 
    .span-14, 
    .span-15, 
    .span-16{ width: 100%; }

/* tablette portrait */
@media (min-width: 768px){
    .spannomargin-1{ width: 5%; }
    .spannomargin-2{ width: 5%; }
    .spannomargin-3{ width: 10%; }
    .spannomargin-4{ width: 15%; }
    .spannomargin-5{ width: 25%; }
    .spannomargin-6{ width: 25%; }
    .spannomargin-7{ width: 35%; }
    .spannomargin-8{ width: 40%; }
    .spannomargin-9{ width: 50%; }
    .spannomargin-10{ width: 50%; }
    .spannomargin-11{ width: 50%; }
    .spannomargin-12{ width: 50%; }
    .spannomargin-13{ width: 50%; }
    .spannomargin-14{ width: 50%; }
    .spannomargin-15{ width: 50%; }
    .spannomargin-16{ width: 60%; }
    .spannomargin-17{ width: 65%; }
    .spannomargin-18{ width: 75%; }
    .spannomargin-19{ width: 75%; }
    .spannomargin-20{ width: 85%; }
    .spannomargin-21{ width: 90%; }
    .spannomargin-22{ width: 95%; }
    .spannomargin-23{ width: 95%; }
    .spannomargin-24{ width: 100%; }


    .span-1{ width: 6.25%; }
    .span-2{ width: 12.5%; }
    .span-3{ width: 18.75%; }
    .span-4{ width: 25%; }
    .span-5{ width: 31.25%; }
    .span-6{ width: 37.5%; }
    .span-7{ width: 43.75%; }
    .span-8{ width: 50%; }
    .span-9{ width: 56.25%; }
    .span-10{ width: 62.25%; }
    .span-11{ width: 68.75%; }
    .span-12{ width: 75%; }
    .span-13{ width: 81.25%; }
    .span-14{ width: 87.5%; }
    .span-15{ width: 93.75%; }
    .span-16{ width: 100%; }


}
/* tablette paysage */
@media (min-width: 1024px){
    .spannomargin-1{ width: 4.16666667%; }
    .spannomargin-2{ width: 8.33333333%; }
    .spannomargin-3{ width: 12.5%; }
    .spannomargin-4{ width: 16.666666666667%; }
    .spannomargin-5{ width: 20%; }
    .spannomargin-6{ width: 25%; }
    .spannomargin-7{ width: 29.16666667%; }
    .spannomargin-8{ width: 33.333%; }
    .spannomargin-9{ width: 37.5%; }
    .spannomargin-10{ width: 41.66%; }
    .spannomargin-11{ width: 45.833333333333%; }
    .spannomargin-12{ width: 50%; }
    .spannomargin-13{ width: 54.166666666667%; }
    .spannomargin-14{ width: 58.3333333%; }
    .spannomargin-15{ width: 62.5%; }
    .spannomargin-16{ width: 66.666%; }
    .spannomargin-17{ width: 70.8266666%; }
    .spannomargin-18{ width: 75%; }
    .spannomargin-19{ width: 79.16%; }
    .spannomargin-20{ width: 83.32%; }
    .spannomargin-21{ width: 87.4866666%; }
    .spannomargin-22{ width: 91.6533333%; }
    .spannomargin-23{ width: 95.82%; }
    .spannomargin-24{ width: 100%; }
    .mille{ max-width: 960px; width: 100%; }

    .span-1{ width: 6.25%; }
    .span-2{ width: 12.5%; }
    .span-3{ width: 18.75%; }
    .span-4{ width: 25%; }
    .span-5{ width: 31.25%; }
    .span-6{ width: 37.5%; }
    .span-7{ width: 43.75%; }
    .span-8{ width: 50%; }
    .span-9{ width: 56.25%; }
    .span-10{ width: 62.25%; }
    .span-11{ width: 68.75%; }
    .span-12{ width: 75%; }
    .span-13{ width: 81.25%; }
    .span-14{ width: 87.5%; }
    .span-15{ width: 93.75%; }
    .span-16{ width: 100%; }

}
@media (min-width: 1280px){
    .mille{ max-width: 1080px; }
}
@media (min-width: 1480px){
    .mille{ max-width: 1440px; }
}

.nomobile{ display: none; }
@media (min-width: 1024px){ .nomobile{ display: block; } }
.onlymobile{ display: block; }
@media (min-width: 1024px){ .onlymobile{ display: none; } }

/*****************************************/

/*FONTS*/
    .montserrat{ font-family: 'Montserrat', sans-serif; }
    .gloock{ font-family: 'Gloock', serif; }
    .thin{ font-weight: 100; }
    .light{ font-weight: 300; }
    .regular{ font-weight: 400; }
    .medium{ font-weight: 500; }
    .semibold{ font-weight: 600; }
    .bold{ font-weight: 700; }
    .ultrabold{ font-weight: 900; }

/**/

img, iframe, video{ max-width: 100%; }
h1, h2, h3, h4, h5, h6{ font-family: 'Gloock', serif; }
h1{ font-size: 32px; }
h2{ font-size: 28px; }
h3{ font-size: 24px; }
h4{ font-size: 20px; }
.italique, i, em{ font-style: italic; }
.lowercase{ text-transform: lowercase; }
.uppercase{ text-transform: uppercase; }
.black, a.black{ color:#000; }
.white, a.white{ color: #fff; }
.grey, a.grey{ color: #7d7d7d; }
.red, a.red{ color:#d13931; }

strong, b{ font-weight: 700; }
.align-left, .alignleft{ text-align: left; justify-content: flex-start; }
.align-right, .alignright{ text-align: right; justify-content: flex-end; }
.align-center, .aligncenter{ text-align: center; justify-content: center; }

img.alignleft, img.align-left{ float: left; margin: 0 1em 1em 0 }
img.alignright, img.align-right{ float: right; margin: 0 0 1em 1em }
img.aligncenter, img.align-center{ float: none; margin: 0 auto 1em auto }

.justify{ text-align: justify; }

.button{
    display: block;
    width: auto;
    text-decoration: underline;
    font-size: 16px;
    text-align: center;
    transition: ease-in-out all 0.1s;
    cursor: pointer;
    background: white;
    text-decoration: none;
}
.button:hover{
    background: black!important;
    text-decoration: none;
}

a{ color: #000; text-decoration: none; cursor: pointer; }
a:hover{ color: #7d7d7d; text-decoration: underline; }
p{ margin: 10px 0; }
article ul{ margin: 1em 0; }
article ul li{ list-style-type: disc; margin-left: 2em; }

.gallery {
  display: flex;
  width: 100%;
  align-items: flex-start;
  flex-flow: row wrap;
}
.gallery-item{ margin: 0 1rem 1rem 0; }


.left{ float: left; }
.right{ float: right; }
.center{ margin: 0 auto; }

.relative{ position: relative; }
.absolute{ position: absolute; }

.error{ color: red; font-weight: bold; }

/*****/
/* base */

body{
    background: #fff;
    margin:0;
    padding:0;
    color:#000;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    font-size: 18px;
}
.conteneur{ max-width: 1920px; width: 100%; overflow-x: hidden; margin: 0 auto; }

header,  main, footer, .home_contenu{ width: 100%; }

a#logo{
    display: block;
    background: transparent url('gfx/logo.png') no-repeat center top / contain;
    max-width: 480px;
    width: 100%;
    height: 96px;
    margin: 3.4vw 0 0 0;
}
/*
.menu-toggle{ display: none; }
.nav-menu{ display: flex; }
nav{
    margin: 0;
    display: flex;
    width: auto;
}
nav ul{
    display: flex;
    flex-direction: row;
    width: 100%;
    align-items: flex-start;
}
nav ul li{
    list-style-type: none;
    display: inline-flex;
    text-align: center;
    background: transparent;
    transition: ease-in-out all 0.1s;
}
nav ul li a{
    font-size: 20px;
    display: block;
    color: black;
    text-decoration: none;
    line-height: 20px;
    padding: 10px;
    margin: 0 0px;
    width: auto;
    background: transparent;
    border: 0;
}
nav ul li:hover{ }
nav ul li:hover a, 
nav ul li.current-menu-item a{
    transition: ease-in-out all 0.1s;
    text-decoration: none;
    border-color: white;
    color: white;
}
nav ul li ul{
    position: absolute;
    top: 45px;
    left: 0;
    z-index: 5001;
    padding: 0;
    background: white;
    border: 1px solid #f6772b;
    display: none;
}
nav ul li:hover ul{ display: block;  }
nav ul li ul li{
    display: list-item;
}
nav ul li ul li a{
    color: #f6772b;
    border-bottom: 1px solid white;
    padding: 6px 14px;
    margin: 8px 10px;
}
nav ul li ul li a:hover{
    color: black;
    border-bottom: 1px solid black;
    text-decoration: none;
}*/
#home .conteneur{
    background: white url('gfx/home_fond.jpg') no-repeat right top / 50%;
}
.home_contenu .login{
    margin-top: 294px;
    margin-top: 14vw;
    margin-bottom: 400px;
    margin-bottom: 19vw;
}
.home_contenu h1{ font-size: 48px; margin-bottom: .75rem; }
.home_contenu h2{ font-size: 36px; }
.home_contenu h2 span{ position: relative; padding: 0 8px; margin: 0 -8px; z-index: 1; }
footer h2 span{ position: relative; padding: 0 5px; margin: 0 -5px; z-index: 1; }
.home_contenu h2 span::after, 
footer h2 span::after{
    content:' ';
    width: 100%;
    height: 22px;
    display: block;
    background:#f5eeed;
    position: absolute;
    bottom: -6px;
    left: 0;
    z-index: -1;
}
footer h2 span::after{ background: white; }
.home_contenu form input{ 
    height: 80px;
    line-height: 80px;
    padding: 30px 0;
    background:#f5eeed;
    border: 0px;
    text-align: center;
    font-size: 24px;
    color: black;
    margin: 0;
    max-width: 100%;
}
.home_contenu form input::placeholder{ color: black; }
.home_contenu form input[type="submit"]{
    height: 140px;
    color:#d13931;
    font-family: 'Gloock', serif; 
    font-size: 58px;
}
.home_contenu form input[type="submit"]:hover{ background:#f5eeed; color: black; }
.home_contenu form .sub::before{
    content: " ";
    display: block;
    background:#d13931;
    width: 1px;
    height: 80px;
    top: 30px;
    position: absolute;
}
footer{ 
    background: #f5eeed url('gfx/footer_fond.jpg') no-repeat right top / contain;
    height: 410px;
    padding: 132px 0 0 0;
    display: flex;
}
footer a.red.gloock{
    display: block;
    padding: 84px 0 0 0;
    font-size: 24px;
    background: transparent url('gfx/email.png') no-repeat center top;
}
footer a.red.gloock:hover{ text-decoration: none; color: black; }
footer h2{ margin: 36px 0 0 0; }
footer p.telephone{ font-size: 30px; letter-spacing: 3px; }
footer p.adresse{ font-size: 16px; letter-spacing: 2px; margin-top: 40px; }
footer p.suivez{ margin-top: 74px; }
footer p.suivez img{ margin: 0 0 0 1rem; }
footer p.suivez a:hover{ text-decoration: none; }
footer p.suivez a:hover img{ opacity: .75; }
footer p.copy{ font-size: 14px; margin: 120px 0 0 0; }
/*espace client*/
.message{ 
    color: white; 
    font-size: 1.1rem; 
    position: absolute; 
    bottom: -3rem; 
    left: 0; 
    z-index: 2;
    background: #7f0d0d;
    display: inline-block;
    padding: 1rem;
}
#home .conteneur.logged{ background: transparent;  }
.marginneg{ margin-right: -16.666666666667%; }
.bgred{
    height: 220px;
    height: 11.5vw;
    background: #fff url(gfx/header.png) no-repeat left top / contain;
}
.bgred h1{
    font-size: 2vw;
    margin: 3.2vw 0 0 0;
}
.bgred h2{ font-size: 2vw; margin: 1.2vw 0 0 0; }
.bgred h3{ font-size: 2vw; }
.bgred h3.white{ font-size: 1.1vw; margin-top: 4.5vw; }
.bgred h3 span{ font-size: .9vw; margin-right: 0; }
.logged header{ margin-bottom: 5vw; }
.bgred p{ font-size: .7vw; margin: 0.25vw 0 0 0; }
.bgred p a{ text-transform: uppercase; text-decoration: underline; }
.bgred a.logout{ text-transform: uppercase; text-decoration: underline; font-size: .7vw; font-weight: 300; margin: 1vw 1vw 0 0 }
.bgred a.logout:hover, .bgred p a:hover{ color: white; text-decoration: none; }
.row.steps{ justify-content: space-around; align-items: flex-end; position: relative; z-index: 2; margin-bottom: 5vw; }
.row.steps span.stepz{ 
    position: relative;
    display: flex;
    flex-flow: column wrap;
    justify-content: flex-end;
    align-items: center;
    width: 14.2856%;
    height: 282px;
    z-index: 3;
 }
.row.steps span.stepz img.icone{ opacity: .25; width: auto; margin-bottom: 50px; }
.row.steps span.stepz img.point{ filter: grayscale(100%) brightness( 190% ); }
.row.steps span.stepz.checked img.icone{ opacity: 1; }
.row.steps span.stepz.checked img.point{ filter: none; }
.row.steps span.stepz.checked::before{
    content: " ";
    display: block;
    width: 42px;
    height: 42px;
    background: transparent url('gfx/check.png') no-repeat center;
    position: absolute;
    z-index: 3;
    top: 30px;
    right: calc( 50% - 62px );
}
.row.steps span.stepz p{
    font-size: 19px;
    font-weight: 600;
    text-align: center;
    opacity: .25;
    margin: 40px auto 0 auto;
}
.row.steps span.stepz p span{ font-size: 18px; }
.row.steps span.stepz.checked p{ opacity: 1; }
.row.steps::after{
    content: " ";
    display: block;
}
.row.steps .completion{
    position: absolute;
    top: 168px;
    left: 0;
    z-index: 1;
    justify-content: space-around; 
    align-items: center;
}
.row.steps .completion span::before{ display:none }
.row.steps .completion span{ background: black; height: 10px; width: 7.1428%; opacity: .2; }
.row.steps .completion span.stepped{ opacity: 1; }
.row.steps .completion span:first-of-type{ border-radius: 5px 0 0 5px; }
.row.steps .completion span:last-of-type{ border-radius: 0 5px 5px 0; }
.row.steps .completion .zero, 
.row.steps .completion .cent{
    position: absolute;
    top: -30px;
    z-index: 2;
    font-size: 18px;
    font-weight: 800;
}
.row.steps .completion .zero{ left: 0; }
.row.steps .completion .cent{ right: 0; }
.bggrey{ background:#f5eeed; padding: 4vw 0 2vw 0; margin-bottom: 5vw; position: relative; }
.bggrey p{ margin: 1.5rem 0; }
.bggrey h3{ margin-bottom: 1.5rem; }
.bggrey::before{
    content: " ";
    display: block;
    width: 42px;
    height: 51px;
    background: transparent url('gfx/alert.png') no-repeat center;
    position: absolute;
    left: 11%;
    top: -7%;
    z-index: 2;
}
#page .conteneur{ background: white url(gfx/home_fond.jpg) no-repeat right top / 50%; }
#page h1{ margin: 0 0 5vw 0; }
#page .mrgcontent{
    padding: 5vw 0;
    margin: 5vw auto;
    background: white;
}
#page h3, #page h2, #page h4, #page p{ margin-bottom: 1rem; }
#page h1{ margin-bottom: 2vw; }


/**/
@media (min-width: 2px) and (max-width: 1023px){
/*
    .menu-toggle{
        width: 100%;
        padding: 5px 0;
        background: #fff;
        color: #8d001a;
        border:0;
        display: block;
        font-size: 24px;
        line-height: 32px;
        text-align: center;
    }
   .menu-toggle:active, .menu-toggle:focus, .menu-toggle:hover{
        text-decoration: none;
    }
    .nav-menu{ display: none; padding:0; margin:0; z-index: 10001; width: 100%; }
    .nav-menu.toggled-on{ display: flex; }
    nav ul{
        flex-direction: column;
    }
    nav ul li{
        list-style-type: none;
        display: inline-flex;
        text-align: center;
        background: transparent;
        transition: ease-in-out all 0.1s;
    }
    nav ul li a{
        font-size: 20px;
        display: block;
        color: #000;
        background: white;
        text-decoration: none;
        width: 96%;
        padding: 6px 2%;
        margin: 2px 0;
    }
    nav ul li a:hover{ color: #8d001a; }
    nav ul li ul{
        margin:0;
        padding:0;
    }
    nav ul li:hover ul{ }
    nav ul li:after{
        display: none;
    }
    nav ul li ul li{
        display: list-item;
    }
    nav ul li ul li a{
        color: #000;
    }
    nav ul li ul li a:hover{
        color: black;
        text-decoration: none;
    }
*/

a#logo{ width: 90%; margin: 1.5rem 5%; height: auto; min-height: 80px; }
#home .conteneur{ background: white; }
.home_contenu{ width: 90%; margin: 0 5%; }
.home_contenu h1 { font-size: 34px; }
.home_contenu h2 { font-size: 24px; }
.home_contenu h2 span {
    padding: 0 4px;
    margin: 0 -4px;
}
.home_contenu form input, 
.home_contenu form input[type="submit"]{
    height: 40px;
    line-height: 40px;
    padding: 20px 0;
    background: #f5eeed;
    border: 0px;
    text-align: center;
    font-size: 20px;
    margin-top: 1rem;
}
.home_contenu form input::placeholder{ font-size: 12px; }
.home_contenu form .sub::before{ height: 60px; top: 26px; }
.home_contenu form input[type="submit"]{ height: 80px; font-size: 20px; }
.home_contenu form .spannomargin-20{ width: 75%; }
.home_contenu form .spannomargin-4{ width: 25%; }
footer{ background-size: 25%; padding-top: 5rem; height: auto; margin-top: 3rem; }
footer h2{ font-size: 20px; }
footer p.telephone{ font-size: 24px; }
footer p.adresse{ margin-top: 20px;  }
footer p.suivez { margin-top: 30px; }
footer p.copy{ margin: 30px 0 20px 0; font-size: 11px; }
.logged header{ margin-bottom: 1rem; }
.bgred{ height: 11rem; background-color:#d13931; width: 90%; padding: 0 5%; position: relative; }
.bgred h1{ font-size: 1.1rem; margin-top: 1.25rem; text-align: right; }
.bgred h2{ font-size: 1rem; margin-top: .25rem; text-align: right; }
.bgred h3{ font-size: 1.5rem; margin-top: .75rem; text-align: right; }
.bgred h3 span{ font-size: 1rem; color: black; }
.bgred a.logout{ font-size: .75rem; position: absolute; left: 1rem; top: .75rem; z-index: 2; }
.bgred p.light a.devis{ font-size: .75rem; }
.bgred p.light{ text-align: right; margin-bottom: .5rem; }
.bgred h3.white{ font-size: 1rem; margin: .5rem 0; }
.row.steps{ flex-flow: column wrap; padding: 5rem 0; margin: 3rem 0; }
.row.steps span.stepz{ width: 100%; height: auto; margin-bottom: 3rem; background: white; padding: .5rem 0; }
.row.steps span.stepz img.icone{ margin-bottom: 0;  }
.row.steps span.stepz img.point{ display: none; }
.row.steps span.stepz p{ margin: .5rem auto 0rem auto; padding: 0; font-size: 16px; }
.row.steps .completion{
    flex-flow: column wrap;
    height: calc( 100% - 6rem );
    padding: 3rem 0;
    top: 0;
}
.row.steps .completion .zero{ width: 100%; text-align: center; top: .5rem; }
.row.steps .completion .cent{ width: 100%; text-align: center; top: auto; bottom: .5rem; }
.row.steps .completion span{ height: 7.1428%; width: 10px; }
.row.steps .completion span:first-of-type{ border-radius: 5px 5px 0 0; }
.row.steps .completion span:last-of-type{ border-radius: 0 0 5px 5px; }
.commentaire{ width: 90%; margin: 0 5%; }
.bggrey{ width: 80%; padding: 4rem 10% 2rem 10%; }
.bggrey h3{ font-size: 1.25rem; }
.bggrey p{ font-size: 1rem; line-height: 1.5rem; }
#page .mrgcontent{ width: 90%; padding: 3rem 5%; }




}
/**/
@media (min-width: 768px) and (max-width: 1023px){
    #home .conteneur { background: white url(gfx/home_fond.jpg) no-repeat right top / 45%; }
    .home_contenu .login{ margin: 0; }
    .bgred .spannomargin-10, .bgred .spannomargin-8{ width: 100%; }



}
/**/
@media (min-width: 1024px) and (max-width: 1279px) {
    .home_contenu h1{ font-size: 28px; }
    .home_contenu h2 { font-size: 22px; }
    .home_contenu form input {
        height: 40px;
        line-height: 40px;
        padding: 20px 0;
        font-size: 16px;
    }
    .home_contenu form input[type="submit"] { height: 80px; font-size: 28px; }
    .home_contenu form .sub::before { height: 40px; top: 20px; }
    .home_contenu .login { margin-top: 12vw; margin-bottom: 17vw; }
    .home_contenu h2 span { padding: 0px 4px; margin: 0 -4px; }
    footer{ background-position: 112% top; height: 320px; padding: 82px 0 0 0; }
    footer p.copy{ margin-top: 80px; font-size: 12px; }
    footer p.telephone{ font-size: 24px; }
    .message{ font-size: .8rem; bottom: -2rem; padding: .5rem; }
    .row.steps span.stepz.checked::before{ width: 21px; height: 21px; background-size: 100%; right: calc( 50% - 42px ); }
    .row.steps span.stepz img.icone{ max-width: 80%; }
    .row.steps span.stepz p { font-size: 14px; }
    .row.steps span.stepz p span{ font-size: 12px; }
    .row.steps span.stepz{ height: 272px; }


}
/**/
@media (min-width: 1280px) and (max-width: 1479px){
    .home_contenu h1{ font-size: 38px; }
    .home_contenu h2{ font-size: 30px; }
    .home_contenu form input {
        height: 60px;
        line-height: 60px;
        padding: 20px 0;
        font-size: 18px;
    }
    .home_contenu form input[type="submit"] { height: 100px; font-size: 28px; }
    .home_contenu form .sub::before{ top: 20px; height: 60px; }
    .home_contenu .login { margin-top: 12vw; margin-bottom: 17vw; }
    footer{ background-position: 110% top; }
    .message{ font-size: .9rem; bottom: -2rem; padding: .5rem; }
    .row.steps span.stepz p { font-size: 16px; }
    .row.steps span.stepz p span{ font-size: 14px; }
    .row.steps span.stepz{ height: 274px; }

}
/**/
@media (min-width: 1480px) and (max-width: 1599px){
    .home_contenu .login { margin-top: 12vw; margin-bottom: 17vw; }



    
}
/**/
@media (min-width: 1600px) and (max-width: 1799px){

}
/**/
@media (min-width: 1800px){

}
/**/
@media (min-width: 1900px){

}
/**/