/*
Theme Name: Acelt
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:flex}
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"],
select,
textarea { margin: 0; border-radius: 0; width:100%;}
input,
textarea,
select,
button { 
    -moz-appearance: none; 
    -webkit-appearance: none;
    appearance: none;
    transition: all .2s ease; 
}
input[type="checkbox"]{ -moz-appearance: checkbox; -webkit-appearance: checkbox; appearance: checkbox; }
input[type="radio"]{ -moz-appearance: radio; -webkit-appearance: radio; appearance: radio; }
label{ }

input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="number"],
select,
textarea {
    background: #fff;
    border: 1px solid #333;
    color: #000;
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 100%;
    width: calc( 90% - 2px );
    outline: none;
    padding: 0.5rem 5%;
}
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: #8d001a; }
input[type="submit"],
button[type="submit"] {
    background: #8d001a;
    color: #fff;
    padding: .5rem 1rem;
    font-weight: 600;
    display: flex;
    border: none;
    cursor: pointer;
    font-size: 20px;
    justify-content: center;
    align-items: center;
}
input[type="submit"]:hover,
button[type="submit"]:hover { background: #000; }

/*WPCF7*/
div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing{
    border: 1px solid red;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output{ border-color: red; color:red; background: rgba(255,255,255,.7); font-size: 17px; }
.wpcf7 form .wpcf7-response-output{ border: 1px solid grey; }

/*SWIPER*/
.swiper-slide{  }
.swiper-pagination{  }
.swiper-pagination-bullet{  }
.swiper-pagination-bullet-active{  }
.swiper-button-next, .swiper-button-prev{  }
.swiper-button-prev{  }
.swiper-button-next{  }



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

/* 24 colonnes */
.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%; }

/*16 colonnes*/
.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){

    /* 24 colonnes */
    .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%; }

    /*16 colonnes*/
    .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.5%; }
    .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){

    /*24 colonnes*/
    .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%; }

    /*16 colonnes*/
    .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.5%; }
    .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: flex; } }
.onlymobile{ display: flex; }
@media (min-width: 1024px){ .onlymobile{ display: none; } }

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

/*FONTS*/
    .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{ }
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: #525252; }
.lightgrey, a.lightgrey{ color: #b4b6b7; }
.red, a.red{ color:#ef3f23; }

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:#525252; text-decoration: none; cursor: pointer; }
a:hover{ color:#525252; 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: "Poppins", sans-serif;
    font-weight: 400;
    font-size: 18px;
}
.conteneur{ max-width: 1920px; margin: 0 auto; }

header,  main, footer, .home_contenu{ width: 100%; }
header.row{ height: 240px; align-items: center; }
a#logo{
    display: block;
    background: transparent url('gfx/logo.svg') no-repeat center top / 100%;
    max-width: 284px;
    width: 60%;
    height: 3.25vw;
    margin: 0 auto 2.1vw auto;
    position: relative;
}
a#logo span{
    position: absolute;
    bottom: -40px;
    bottom: -2.1vw;
    left: -12.5%;
    font-size: 14px;
    font-size: .725vw;
    color:#a7a9ab;
    width: 125%;
}
.menu-toggle{ display: none; }
.nav-menu{ display: flex; }
#menu-menu-principal{
    position: relative;
    height: 46px;
    margin: 0 0 26px 0;
}
#menu-menu-principal::after{
	content: " ";
    width: 24.5%;
    height: 46px;
    background: #ef3f23;
    position: absolute;
    left: 75.5%;
    top: 0;
    z-index: -1;
}
nav{
    margin: 0;
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
    width: auto;
}
.menu-menu-principal-container{
    display: flex;
    width: 100%;
    position: relative;
}
nav ul{
    display: flex;
    flex-direction: row;
    width: 100%;
    align-items: flex-start;
}
nav ul li{
    list-style-type: none;
    position: relative;
    display: inline-flex;
    text-align: center;
    background: transparent;
    transition: ease-in-out all 0.1s;
    margin: 0 20px;
    margin: 0 1vw;
}
nav ul li a{
    font-size: .935vw;
    display: flex;
    color: #3f3f3f;
    text-decoration: none;
    text-transform: uppercase;
    line-height: 50px;
    padding: 0;
    font-weight: 600;
    margin: 0 ;
    width: auto;
    background: transparent;
    border: 0;
    border-bottom: 2px solid transparent;
}
nav ul li a:hover, 
nav ul li.current-menu-item a, 
nav ul > li.current-menu-parent > a{
    transition: ease-in-out all 0.1s;
    text-decoration: none;
    color: #3f3f3f;
    border-color:#ef3f23;
}
nav > div > ul > li:last-child > a{ color: white; }
nav ul li ul{
    position: absolute;
    top: 45px;
    left: 0;
    width: 350%;
    z-index: 5001;
    background: white;
    border: 1px solid #b4b6b7;
    display: none;
    padding: 1.25rem 0;
}
nav ul li:hover ul{ display: flex; flex-flow: column wrap;  }
nav ul li ul li{
    display: list-item;
    width: 100%;
    margin: 0 0 0 2rem;
}
nav ul li ul li a{
    color: #3f3f3f;
    font-size: 16px;
    font-size: .825vw;
    line-height: 1.65vw;
    padding: 0;
    margin: 0;
}
nav ul li ul li a:hover, nav ul li ul li.current-menu-item a{
    color:#ef3f23;
    border-color: transparent;
    text-decoration: none;
}
/*home*/
.swiper-diapo img{ filter:grayscale(100%); opacity: .6; display: flex; }
.swiper-diapo .swiper-slide{ background: white; }
.homediapo{ padding: 100px 0 0 0; }
.homediapo::before{ 
    content: " ";
    position: absolute;
    width: 75%;
    left: -16.666666666667%;
    height: 100%;
    top: 0;
    bottom: 0;
    background:#ef3f23;
    z-index: 10;
    mix-blend-mode: multiply;
}
.diapo-titres{ left: 16.666666666667%; top: 50%; z-index: 20; }
.homediapo h1{ font-size: 36px; }
.homediapo p{ font-size: 18px; margin: .5rem 0 0 0; }
.troisblocs{
    margin: 3rem 0;
    align-items: stretch;
    padding: 0 0 20px 0;
}
.troisblocs h2, .troisblocs .zone-texte h2{ 
    padding: 52px 0 0 0; 
    position: relative; 
    font-size: 30px; 
    line-height: 36px; 
    color:#525252; 
    min-height: 72px;
    margin: 0 0 2rem 0;
    text-transform: none;
}
.troisblocs .zone-texte h2::after{ display: none; }
.nb3bloc1 h2::before, .nb3bloc1.zone-texte h2::before{
    content: " ";
    width: 40px;
    height: 52px;
    background: transparent url('gfx/bloc1.png') no-repeat 0 0;
    position: absolute;
    left: -52px;
    top: 0;
}
.nb3bloc2 h2::before, .nb3bloc2.zone-texte h2::before{
    content: " ";
    width: 60px;
    height: 38px;
    background: transparent url('gfx/bloc2.png') no-repeat 0 0;
    position: absolute;
    left: -52px;
    top: 0;
}
.nb3bloc3 h2::before, .nb3bloc3.zone-texte h2::before{
    content: " ";
    width: 34px;
    height: 48px;
    background: transparent url('gfx/bloc3.png') no-repeat 0 0;
    position: absolute;
    left: -52px;
    top: 0;
}
.troisblocs p{ 
    font-size: 17px; 
    line-height: 24px; 
    color:#525252; 
    margin: 0 0 62px 0;
}
.btn{
    display: block;
    width: 100%;
    text-align: right;
    font-size: 14px;
    font-weight: 500;
    color:#ef3f23;
    position: absolute;
    bottom: 0;
    left: 0;
}
.btn::before{
    content: " ";
    display: block;
    position: absolute;
    left: 0;
    top: 50%;
    width: 70%;
    height: 1px;
    background:#ef3f23;
}
.btn:hover{
    color: black;
    text-decoration: none;
    transition: ease-in-out all .1s;
}
.btn:hover::before{ background: black; }
.troisblocs .spannomargin-6{ 
    display: flex;
    flex-flow: column wrap;
    align-items: flex-start; 
    justify-content: stretch;
    position: relative;
}
.bloctitrerouge{
    margin: 3rem 0;
    padding: 220px 0 50px 0;
    min-height: 370px;
}
.bloctitrerouge::before{
    content: " ";
    background: transparent url('gfx/home-illustration.jpg') no-repeat 0 0 / 100%;
    width: 40.5%;
    max-width: 770px;
    height: 638px;
    position: absolute;
    left: 44px;
    top: 0;
    z-index: -1;
}
.bloctitrerouge h2{ font-size: 48px; margin: 0 0 3rem 0; }
.bloctitrerouge p{ font-size: 17px; line-height: 30px; margin: 0 0 6rem 0; }
.clients .row.middle{ padding: 120px 0; border: 1px solid #ef3f23; margin: 140px 0;}
.clients h2{ font-size: 48px; }
.clients .swiper-pagination{ bottom: -2.5rem; }
.clients .swiper-pagination .swiper-pagination-bullet{ 
    width: 18px;
    height: 18px;
    background:#cdcccc;
    opacity: 1;
}
.clients .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active{
    background:#ef3f23;
}
footer.row{ 
    height: 420px; 
    background: transparent url('gfx/footer.jpg') no-repeat center / 100%; 
    margin-top: 100px;
    align-items: stretch;
}
.menu-footer-container{ display: flex; width: 100%; }
.footer-menu{ 
    display: flex; 
    flex-flow: column wrap; 
    justify-content: flex-start; 
    align-items: flex-start;
    margin: 100px auto 0 auto;
}
.footer-menu li a{ 
    text-transform: uppercase; 
    color: black;
    font-size: 18px;
    line-height: 22px;
    font-weight: 600;
}
.footer-menu li a:hover{
    text-decoration: none;
    color: #525252;
}
.footer-menu li { margin: 6px 0; line-height: 22px; }
footer a#logo{
    margin: 100px auto 0 auto;
    height: 60px;
}
footer a#logo span{ font-size: 14px; }
.bgred::after{
    content: " ";
    position: absolute;
    width: 100%;
    right: -25%;
    top: -100px;
    bottom: -30px;
    background:#ef3f23;
    z-index: 1;
    mix-blend-mode: multiply;
}
.bgred > *{ position: relative; z-index: 2; }
p.copyright{ line-height: 60px; margin: 26px auto; font-size: 14px; }
footer p.avotre{ margin: 100px 0 0 37%; font-size:18px; font-weight: 600;  }
footer a.tel{ font-size: 30px; font-weight: 600; margin-left: 37%; transition: ease-in-out all .2s; }
footer a.tel:hover{ text-decoration: none; color: black; transition: ease-in-out all .2s; }
footer a.btn-contact{
    font-size: 30px; 
    font-weight: 600;
    text-align: center;
    border: 1px solid black;
    color: white;
    display: block;
    width: 100%;
    line-height: 86px;
    margin: 46px 0 0 0;
    background: transparent url('gfx/fleche.png') no-repeat 92% center;
    transition: ease-in-out all .2s;
}
footer a.btn-contact:hover{
    text-decoration: none;
    background-color:#fff;
    color:#ef3f23;
    transition: ease-in-out all .2s;
}
/* page */
.bandeau img{
    filter: grayscale(100%);
    opacity: .75;
    display: flex;
}
.bandeau{ padding-top: 100px; margin-bottom: 2rem; }
.bandeau::before{
    content: " ";
    position: absolute;
    width: 75%;
    left: -16.666666666667%;
    height: 100%;
    top: 0;
    bottom: 0;
    background: #ef3f23;
    z-index: 1;
    mix-blend-mode: multiply;
}
.in-bandeau{
    position: absolute;
    z-index: 2;
    top: 0;
    left: 8.33333333%;
    bottom: 0;
    display: flex;
    flex-flow: column wrap;
    justify-content: center;
    width: 48%;
}
.in-bandeau a:hover{ color: white; }
p.bread{ text-transform: uppercase; font-size: 14px; }
p.bread a:hover{ text-decoration:none; }
.in-bandeau h1{ font-size: 36px; line-height: 42px; }
.zone-texte p{ color: #525252; font-size: 17px; line-height: 28px; margin: .5rem 0 1rem 0; }
#page .texteseul .zone-texte p, #page .texteimage{ text-align: justify; }
.zone-texte ul li{ color: #525252; font-size: 17px; line-height: 28px; margin: 0 0 .25rem 1.5rem; }
.zone-texte ul{ margin: 2rem 0; }
.zone-texte ul li::marker{ color: #ef3f23; }
.zone-texte h2{ 
    color: #525252; 
    font-weight: 600; 
    font-size: 30px; 
    line-height: 38px;
    margin: 0 0 2rem 0;
    padding: 0 0 1.5rem 4.5rem;
    position: relative;
    text-transform: uppercase;
}
.zone-texte h2::before{
    content: " ";
    display: block;
    background: transparent url('gfx/h2.png') no-repeat 0 0;
    width: 41px;
    height: 26px;
    position: absolute;
    top: 6px;
    left: 0;
}
.zone-texte h2::after{
    content: " ";
    display: block;
    width: 120px;
    height: 1px;
    position: absolute;
    left: 0;
    bottom: 0;
    background:#ef3f23;
}
.zone-texte h3{ color: #ef3f23; font-weight: 600; font-size: 24px; margin-bottom: 1rem; }
.zone-texte h4{ color: #525252;  font-weight: 600; font-size: 20px; margin-bottom: 1rem; }
.zone-texte a{ color: #ef3f23; }
#page .troisblocs .spannomargin-6.zone-texte, 
#page .bloctitrerouge .spannomargin-13.zone-texte{
    position: relative;
}
#page .bloctitrerouge .spannomargin-13.zone-texte{ padding-bottom: 2rem; }
#page .troisblocs .spannomargin-6.zone-texte::after, 
#page .bloctitrerouge .spannomargin-13.zone-texte::after{
    content: " ";
    display: block;
    width: 75%;
    max-width: 240px;
    height: 1px;
    position: absolute;
    left: 0;
    bottom: 0;
    background:#ef3f23;
}
#page .texteseul{ margin: 4rem 0; }
#page .troisblocs{ margin: 4rem 0; }
#page .troisblocs.avectitre{ margin: 2rem 0 4rem 0; }
#page .titre3blocs{ margin: 2rem 0 0 0; }
#page .bloctitrerouge{ margin: 0 0 4rem 0; }
#page .texteimage{ margin: 4rem 0 8rem 0; }
#page footer.row{ margin-top: 140px; }
.autour-image{ width: 100%; position: relative; }
.autour-image img{ display: flex; }
.autour-image::before{
    content: " ";
    position: absolute;
    width: 60%;
    height: 72px;
    left: -10%;
    bottom: -40px;
    background:#ef3f23;
    z-index: 1;
    mix-blend-mode: multiply;
}
.zone-texte.texteimage-titre{ margin: 0 0 2rem 0; }
#page .pagenb22 .bloctitrerouge::before{
    background-image: url('gfx/apropos-illustration.jpg');
}
#page .pagenb17 .bloctitrerouge::before{
    background-image: url('gfx/routemanager-illustration.jpg');
}
#page .pagenb13 .bloctitrerouge::before{
    background-image: url('gfx/surmesure-illustration.jpg');
} 
#page .pagenb11 .bloctitrerouge::before{
    background-image: url('gfx/digitallearning-illustration.jpg');
} 
#page .pagenb9 .bloctitrerouge::before{
    background-image: url('gfx/accompagnement-illustration.jpg');
}
#page .pagenb15 .bloctitrerouge::before{
    background-image: url('gfx/expert-illustration.jpg');
}
#page .pagenb13 .bloctitrerouge .spannomargin-13.zone-texte::after{ display: none; }
#page .bloctitrerouge .spannomargin-13.zone-texte a.btn{ max-width: 50%; }
#page .bloctitrerouge .spannomargin-13.zone-texte a.btn::before{ max-width: 50%; }
/*CONTACT*/
.wpcf7{
    background:#f1ecec;
    padding: 70px 8.5% 70px 12.5%;
    position: relative;
    margin: 0 0 100px 0;
}
.wpcf7 input[type="text"], .wpcf7 input[type="email"], 
.wpcf7 input[type="tel"], .wpcf7 textarea{
    background:#f1ecec;
    line-height: 44px;
    margin: 0 0 1rem 0;
    padding: 0;
    border: 0px;
    border-bottom: 1px solid #bab6b8;
    font-size: 17px;
    color:#525252;
    width: 100%;
}
.wpcf7 textarea{
    padding: 1rem 0;
    line-height: 24px;
    margin-bottom: 2rem;
}
.wpcf7 input[type="text"]::placeholder, .wpcf7 input[type="email"]::placeholder, 
.wpcf7 input[type="tel"]::placeholder, .wpcf7 textarea::placeholder{ color:#525252; }
.wpcf7-form-control-wrap{ width: 100%; }
.wpcf7-list-item-label, .wpcf7 span.italique{ font-style: italic; font-size: 14px; color:#777777; }
.wpcf7 span.italique{ display: block; margin: 1rem 0 1rem 0; }
.wpcf7 label{ display: flex; flex-flow: row nowrap; align-items: flex-start; justify-content: flex-start; }
.wpcf7-list-item{ margin: 0; }
.wpcf7 input[type="checkbox"]{ margin-right: 1rem; }
.wpcf7 input[type="submit"].wpcf7-submit{
    position: absolute;
    bottom: -44px;
    right: -12%;
    width: 50%;
    background: #ef3f23 url('gfx/trait-contact.png') no-repeat 15% center / 25%;
    opacity: 1;
    mix-blend-mode: multiply;
    text-align: right;
    font-size: 18px;
    font-weight: 600;
    line-height: 90px;
    padding: 0 3rem;
    text-transform: uppercase;
}
.wpcf7 input[type="submit"].wpcf7-submit:hover{
    background-color:#3f3f3f;
}
.wpcf7-spinner{ margin: 0; position: absolute; bottom: 1rem; left: 1rem; }
.contact .tel{ font-size: 24px; margin-top: 1rem; display: block; }
.contact .tel:hover{ text-decoration:none; }
.contact .logocontact{ margin-top: 5rem; }








/**/
@media (min-width: 2px) and (max-width: 1023px){
    .mille{ width: 100%; }
    .conteneur{ width: 100%; overflow-x: hidden; }
    header.row{ height: auto; padding: 2rem 0 2.5rem 0; }
    header .span-2{ width: 5%; }
    header .span-4{ width: 55%; }
    header .span-10{ width: 40%; }
    a#logo{ width: 100%; height: 3.5rem; }
    a#logo span{ 
		font-size: .7rem;
		bottom: -1.9rem;
        text-align: left;
        margin-left: 23vw;
        width: 100%;
		color:#808283;
	}
	a#logo span b{ display: inline-block; width: 100%; }
    .menu-toggle{
        width: 80%;
        padding: 0;
        background: #fff;
        color: #ef3f23;
        border:0;
        display: block;
        font-size: 4rem;
        line-height: 4rem;
        margin-top: -2rem;
        text-align: right;
    }
   .menu-toggle:active, .menu-toggle:focus, .menu-toggle:hover{
        text-decoration: none;
    }
    #menu-menu-principal.nav-menu{
        position: absolute;
        background: white;
        height: auto;
        display: none; 
        padding:0; 
        margin:0; 
        z-index: 10001; 
        width: 250%;
        right: 0;
        top: 3rem;
        box-shadow: 0 10px 10px rgba(0,0,0,.2);
     }
    #menu-menu-principal.nav-menu.toggled-on{ display: flex; }
    nav ul{
        flex-direction: column;
    }
    nav ul li{
        list-style-type: none;
        display: flex;
        flex-flow: column wrap;
        text-align: left;
        align-items: flex-start;
        justify-content: flex-start;
        transition: ease-in-out all 0.1s;
        margin: 0;
        padding: 0 1.5rem;
        width: calc(100% - 3rem);
    }
    nav ul li a{
        font-size: 1.2rem;
        display: block;
        text-decoration: none;
        width: 100%;
        padding: 0;
        margin: 0;
    }
    nav ul li a:hover{ }
    
    nav ul li ul{
        margin:0;
        padding: 1rem 0;
        position: relative;
        left: auto;
        top: auto;
        width: 100%;
        border: 0px;
    }
    nav ul li:hover ul{ }
    nav ul li ul li{
        display: list-item;
        margin: 0;
        padding: 0 .5rem;
    }
    nav ul li ul li a{ font-size: 1rem; line-height:2.5rem; }
    nav ul li ul li a:hover{ }
    #menu-menu-principal::after{
        left: 0;
        top: auto;
        bottom: 0;
        width: 50%;
    }
    .homediapo h1{ font-size: 1.1rem; }
    .homediapo p{ font-size: .9rem; }
    .diapo-titres{ left: 1rem; top: auto; bottom: 1rem; }
    .homediapo::before{ left: 0;  }
    .homediapo { padding: 50px 0 0 0; }
    .troisblocs{ width: 80%; margin: 2rem 10%; }
    .troisblocs h2, .troisblocs .zone-texte h2 {
        padding: 22px 0 0 0;
        font-size: 24px;
        line-height: 30px;
        min-height: 42px;
        margin-bottom: 1.5rem;
    }
    .troisblocs p {
        font-size: 14px;
        line-height: 20px;
        margin: 0 0 42px 0;
    }
    .nb3bloc1 h2::before, .nb3bloc1.zone-texte h2::before{
        width: 22px;
        height: 32px;
        background-size: 100%;
        left: -30px;
    }
    .nb3bloc2 h2::before, .nb3bloc2.zone-texte h2::before{
        width: 36px;
        height: 32px;
        background-size: 100%;
        left: -40px;
    }
    .nb3bloc3 h2::before, .nb3bloc3.zone-texte h2::before{
        width: 22px;
        height: 32px;
        background-size: 100%;
        left: -30px;
    }
    .bloctitrerouge{
        width: 80%;
        padding: 120px 10% 0px 10%;
        min-height: auto;
    }
    .bloctitrerouge h2 { font-size: 30px; line-height: 36px; margin-bottom: 2rem; }
    .bloctitrerouge p {
        font-size: 14px;
        line-height: 20px;
        margin: 0 0 3rem 0;
    }
    .bloctitrerouge::before {
        width: 38.5%;
        height: 208px;
    }
    .btn::before{ width: 50%; }
    .clients .row.middle {
        padding: 1rem 10% 3rem 10%;
        width: 80%;
        border: 1px solid #ef3f23;
        margin: 3rem 0;
        border-left: 0px;
        border-right: 0px;
    }
    .clients h2 { font-size: 28px; line-height: 32px; margin-bottom: 1rem; }
    .swiper-clients .swiper-slide{ text-align: center; }
    footer.row {
        height: auto;
        background-size: cover;
        margin-top: 0;
        width: 80%;
        padding: 0 10%;
    }
    footer a#logo {
        margin: 2rem auto 1rem auto;
        height: 60px;
        width: 220px;
    }
    footer a#logo span { font-size: 9px; }
    .footer-menu{ margin: 2rem auto 0 auto; }
    footer p.avotre { margin: 3rem 0 0 37%; font-size: 18px; }
    footer a.btn-contact {
        font-size: 24px;
        background-size: 3rem;
        line-height: 66px;
        margin: 16px 0 0 0;
    }
    .bgred::after {
        top: 20px;
        bottom: -20px;
    }
    footer a.tel { font-size: 26px; }
    .footer-menu li a {
        font-size: 14px;
        line-height: 20px;
    }
    .footer-menu li {
        margin: 4px 0;
        line-height: 20px;
    }
    p.copyright {
        line-height: 20px;
        font-size: 12px;
    }

    .bandeau{ padding-top: 50px; }
    .in-bandeau{
        width: 80%;
        left: 10%;
    }
    .in-bandeau h1 {
        font-size: 22px;
        line-height: 26px;
    }
    p.bread { font-size: 10px; margin: 0; }
    .in-bandeau p.white{ font-size: 12px; }
    .bandeau img{ width: 250%; max-width: 250%; }
    #page .texteseul {
        margin: 2rem 0;
        width: 80%;
        padding: 0 10%;
    }
    .bandeau::before{ left: 0; width: 80%; }
    .zone-texte p {
        font-size: 16px;
        line-height: 24px;
    }
    #page .troisblocs { margin: 2rem 10%; }
    .zone-texte ul{ margin: 1rem 0; }
    .zone-texte ul li{ font-size: 16px; line-height: 24px; }
    .troisblocs .spannomargin-6{ margin-bottom: 2rem; padding-bottom: 1rem; }
    .zone-texte h2{ font-size: 24px; line-height: 30px; padding-left: 3.5rem; }
    .zone-texte h3{ font-size: 21px; }
    .zone-texte h4 { font-size: 18px; }
    #page footer.row{ margin-top: 3rem; }
    #page .texteimage { margin: 2rem 10% 4rem 10%; width: 80%; }
    .autour-image { margin-bottom: 4.5rem; }
    #page .bloctitrerouge .spannomargin-13.zone-texte a.btn { max-width: 100%; }
    #page .bloctitrerouge .spannomargin-13.zone-texte a.btn::before{ max-width: 30%; }
    #page .troisblocs.avectitre { margin: 2rem 10% 4rem 10%; }
    #page .titre3blocs{ margin: 2rem 10% 0 10%; width: 80%; }
    .contact .logocontact{ max-width: 140px; margin-top: 2rem; }
    .row.formulaire{ margin: 0 10% 0 10%; width: 80%; }
    .wpcf7{
        padding: 2rem 10% 4rem 10%;
        margin: 2rem 0;
    }
    .wpcf7-list-item-label, .wpcf7 span.italique { font-size: 12px; }
    .wpcf7 input[type="submit"].wpcf7-submit{ right: 5%; width: 90%; font-size: 15px; background-size: 5%; background-position: 5% center; }



}
/**/
@media (min-width: 768px) and (max-width: 1023px){
    a#logo{ height: 4rem; }
    a#logo span { font-size: .7rem; margin-left: 16vw; bottom: -2.2rem; }
    #menu-menu-principal.nav-menu{ width: 125%; }
    .homediapo::before{ left: -16.666666666667%; }
    .diapo-titres{ left: 10%; bottom: 2rem; }
    .homediapo h1 { font-size: 1.6rem; }
    .homediapo p { font-size: 1.2rem; }
    .bloctitrerouge::before{ height: 320px; }
    .btn::before {  width: 40%; }
    footer .spannomargin-8.bgred{ width: 35%; }
    footer a#logo{ margin: 2rem 0 1rem 0; }
    .footer-menu li, .footer-menu li a {
        font-size: 10px;
        line-height: 12px;
    }
    .homediapo{ margin-bottom: 4rem; }
    .bandeau img {
        width: 150%;
        max-width: 150%;
    }
    .bandeau::before{ left: -16.666666666667%; }
    .in-bandeau{
        left: 8.33333333%;
        width: 48%;
    }
    .in-bandeau h1 {
        font-size: 26px;
        line-height: 32px;
    }
    .in-bandeau p.white {
        font-size: 14px;
    }
    #page .texteseul {
        margin: 2rem 0;
        width: 100%;
        padding: 0;
    }
    #page .texteseul .spannomargin-16{ width: 70%; }
    #page .troisblocs {
        margin: 2rem 5%;
        width: 90%;
    }
    .troisblocs h2, .troisblocs .zone-texte h2 {
        font-size: 20px;
        line-height: 28px;
    }
    #page .troisblocs.avectitre {
        margin: 2rem 5%;
        width: 90%;
    }
    #page .titre3blocs{
        margin: 2rem 5% 0 5%;
        width: 90%;
    }
    .row.formulaire {
        margin: 0 0 3rem 5%;
        width: 95%;
    }
    .row.formulaire .spannomargin-4{  width: 30%; }
    .row.formulaire .spannomargin-16{ width: 50%; }







}
/**/
@media (min-width: 1024px) and (max-width: 1279px) {

    header.row { height: 140px; }
    nav ul li ul{ padding: .75rem 0; }
    .homediapo { padding: 60px 0 0 0; }
    .diapo-titres{ top: 45%; }
    .homediapo h1 { font-size: 26px; line-height: 32px; }
    .homediapo p { font-size: 14px; margin: .25rem 0 0 0; }
    .troisblocs h2 {
        padding: 52px 0 0 0;
        font-size: 20px;
        line-height: 26px;
        min-height: 52px;
    }
    .troisblocs p {
        font-size: 12px;
        line-height: 18px;
        margin: 0 0 42px 0;
    }
    .btn{ font-size: 12px; }
    .btn::before{ width: 65%; }
    .bloctitrerouge h2 { font-size: 28px; margin: 0 0 2rem 2rem; }
    .bloctitrerouge p {
        font-size: 14px;
        line-height: 24px;
        margin: 0 0 4rem 0;
    }
    .bloctitrerouge {
        margin: 3rem 0;
        padding: 110px 0 10px 0;
        min-height: 220px;
    }
    .bloctitrerouge::before {
        width: 37.5%;
        height: 338px;
        left: 4px;
        top: 0;
    }
    .clients .row.middle{ padding: 60px 0; margin: 70px 0; }
    .clients h2{ font-size: 28px; }
    footer a#logo{ width: 50%; margin: 70px auto 0 auto; height: 36px; }
    footer a#logo span{ font-size: 8px; }
    .footer-menu li a{ font-size: 10px; line-height: 16px; }
    .footer-menu li{ margin: 0; line-height: 20px; }
    footer a.btn-contact {
        font-size: 20px;
        line-height: 66px;
        margin: 26px 0 0 0;
        background-size: 20%;
    }
    footer p.avotre{ font-size: 14px; margin-top: 70px; }
    footer a.tel { font-size: 22px; }
    footer.row { height: 280px; margin-top: 40px; }
    .bgred::after { top: -40px;  bottom: -20px; }
    p.copyright {
        line-height: 20px;
        margin: 26px auto;
        font-size: 10px;
    }
    .footer-menu{ margin-top: 70px; }
    .in-bandeau h1 { font-size: 24px; line-height: 28px; }
    p.bread { font-size: 10px; margin: 4px 0; }
    .in-bandeau p.white{ font-size: 12px; margin: 4px 0; }
    .bandeau { padding-top: 60px; }
    .zone-texte p { font-size: 12px; line-height: 20px; margin: .5rem 0 1rem 0; }
    #page .texteseul, 
    #page .troisblocs { margin: 2rem 0; }
    #page .bloctitrerouge { margin: 0 0 2rem 0; }
    #page .troisblocs.avectitre{ margin: 0 0 2rem 0; }
    #page .texteimage { margin: 2rem 0 4rem 0; }
    .troisblocs h2, .troisblocs .zone-texte h2 {
        padding: 42px 0 0 0;
        font-size: 18px;
        line-height: 22px;
        margin-bottom: 1rem;
        min-height: 44px;
    }
    .zone-texte ul{ margin: 1rem 0; }
    .zone-texte ul li {
        font-size: 12px;
        line-height: 20px;
        margin: 0 0 .25rem 1.5rem;
    }
    .zone-texte h2{ font-size: 18px; line-height: 22px; padding: 0 0 1.5rem 3.5rem; }
    .zone-texte h2::before{ top: -4px; }
    .zone-texte h3{ font-size: 16px; }
    .zone-texte h4{ font-size: 14px; }
    #page footer.row { margin-top: 100px; }
    #page .bloctitrerouge .spannomargin-13.zone-texte a.btn::before { max-width: 35%; }
    .contact .tel { font-size: 18px; margin-top: .5rem; }
    .wpcf7 { padding: 50px 8.5% 50px 12.5%; }
    .wpcf7 input[type="text"], .wpcf7 input[type="email"], 
    .wpcf7 input[type="tel"], .wpcf7 textarea{ font-size: 14px; }
    .wpcf7-list-item-label, .wpcf7 span.italique{ font-size: 11px; }
    .wpcf7 input[type="submit"].wpcf7-submit{ font-size: 14px; background-position: 10% center; background-size: 15%; }




}
/**/
@media (min-width: 1280px) and (max-width: 1479px){
    header.row { height: 180px; }
    .homediapo h1 { font-size: 26px; }
    .homediapo p { font-size: 14px; }
    .homediapo { padding: 60px 0 0 0; }
    .diapo-titres{ top: 45%; }
    .troisblocs h2{ font-size: 22px; line-height: 30px; }
    .troisblocs p {
        font-size: 14px;
        line-height: 20px;
        margin: 0 0 52px 0;
    }
    .btn{ font-size: 12px; }
    .bloctitrerouge h2 { font-size: 34px; margin-bottom: 2rem; margin-left: 2rem; }
    .bloctitrerouge p {
        font-size: 14px;
        line-height: 24px;
        margin: 0 0 4rem 0;
    }
    .bloctitrerouge { padding: 150px 0 50px 0; min-height: 280px; }
    .bloctitrerouge::before{ left: 24px; }
    .clients .row.middle{ padding: 80px 0; margin: 80px 0; }
    .clients h2 { font-size: 32px; }
    footer a#logo{ width: 56%; margin-top: 80px; height: 44px; }
    footer a#logo span{ font-size: 10px; }
    .footer-menu li a { font-size: 14px; line-height: 16px; }
    .footer-menu li { line-height: 16px; }
    .footer-menu{ line-height: 16px; margin-top: 80px; }
    footer p.avotre{ font-size: 16px; margin-top: 80px; }
    footer a.tel { font-size: 26px; }
    footer a.btn-contact {
        font-size: 24px;
        background-size: 20%;
        line-height: 66px;
        margin: 26px 0 0 0;
    }
    footer.row { height: 310px; }
    .bgred::after {
        right: -25%;
        top: -60px;
        bottom: -20px;
    }
    p.copyright {
        line-height: 40px;
        margin: 26px auto;
        font-size: 12px;
    }
    p.bread{ font-size: 12px; }
    .in-bandeau h1{ font-size: 26px; line-height: 32px; }
    .bandeau { padding-top: 80px; }
    .bandeau p.white{ font-size: 14px; }

   .zone-texte p { font-size: 14px; line-height: 24px; margin: .5rem 0 1rem 0; }
    #page .texteseul, 
    #page .troisblocs { margin: 3rem 0; }
    #page .bloctitrerouge { margin: 0 0 3rem 0; }
    #page .troisblocs.avectitre{ margin: 0 0 3rem 0; }
    #page .texteimage { margin: 3rem 0 6rem 0; }
    .troisblocs h2, .troisblocs .zone-texte h2 {
        padding: 42px 0 0 0;
        font-size: 20px;
        line-height: 26px;
        margin-bottom: 1rem;
        min-height: 44px;
    }
    .zone-texte ul{ margin: 1.5rem 0; }
    .zone-texte ul li {
        font-size: 14px;
        line-height: 24px;
        margin: 0 0 .25rem 1.5rem;
    }
    .zone-texte h2{ font-size: 20px; line-height: 26px; padding: 0 0 1.5rem 3.5rem; }
    .zone-texte h2::before{ top: -4px; }
    .zone-texte h3{ font-size: 18px; }
    .zone-texte h4{ font-size: 16px; }
    #page footer.row { margin-top: 100px; }
    #page .bloctitrerouge .spannomargin-13.zone-texte a.btn::before { max-width: 35%; }
    .contact .tel { font-size: 20px; margin-top: .5rem; }
    .wpcf7 { padding: 50px 8.5% 50px 12.5%; }
    .wpcf7 input[type="text"], .wpcf7 input[type="email"], 
    .wpcf7 input[type="tel"], .wpcf7 textarea{ font-size: 16px; }
    .wpcf7-list-item-label, .wpcf7 span.italique{ font-size: 12px; }
    .wpcf7 input[type="submit"].wpcf7-submit{ font-size: 14px; background-position: 10% center; background-size: 20%; }






}
/**/
@media (min-width: 1480px) and (max-width: 1599px){

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

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

}
/**/
@media (min-width: 1900px){
    a#logo{
        margin: 0 auto 40px auto;
        height: 60px;
    }
    a#logo span{
        bottom: -40px;
        font-size: 14px;
    } 
    nav ul li{ margin: 0 20px; }
    nav ul li a{
        font-size: 18px;
        line-height: 50px;
        padding: 0;
    }
    nav ul li ul li a{
        font-size: 16px;
        line-height: 32px;
    }
}
/**/