/*
Theme Name: Bonbay
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; }
.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.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){

    /*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.833333333333%; }
    .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.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: 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; }

    .momo{
        font-family: "Momo Trust Display", sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .poppins{
        font-family: "Poppins", sans-serif;
        font-style: normal;
    }



/**/

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: #a9a69a; }
.blue, a.blue{ color:#193846; }

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: #193846; text-decoration: none; cursor: pointer; }
a:hover{ color: #959393; 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; }

.flex{ display: flex; }

.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:#193846;
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    font-size: 18px;
}
.conteneur{ max-width: 1816px; margin: 0 auto; }

header,  main, footer, .home_contenu{ width: 100%; }
header{ margin-top: 48px; position: relative; }
header::before{ 
    content: " ";
    width: 46px;
    height: 74px;
    background: transparent url('gfx/rectangle.png') no-repeat 0 0;
    position: absolute;
    left: 0;
    top: -36px;
}
.bgblue{ background-color:#193846; }
header > .row > div.bgblue{ min-height: 196px; }
header .titre{
    margin: 60px 0 0 30px;
    font-size: 30px;
}
.btn-contact{
    background:#b0aea4 url('gfx/fleche-bleu.png') no-repeat 90% center;
    width: max-content;
    padding: 0 86px 0 58px;
    display: block;
    text-align: center;
    line-height: 54px;
    font-family: "Momo Trust Display", sans-serif;
    font-size: 18px;
    transition: ease-in-out all .2s;
}
.btn-contact:hover{
    color: white;
    text-decoration: none;
    transition: ease-in-out all .2s;
}
header .btn-contact{
    position: absolute;
    bottom: 0;
    right: -5%;
    width: 25%;
    padding: 0;
}
a#logo{
    display: block;
    background: transparent url('gfx/logo.png') no-repeat center;
    width: 100%;
    height: 100px;
    margin: 30px 0 0 0;
}
.menu-toggle{ display: none; }
.nav-menu{ display: flex; }
nav{
    margin: 0;
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    justify-content: flex-start;
    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;
    justify-content: space-evenly;
    margin-top: 60px;
}
nav ul li{
    list-style-type: none;
    display: inline-flex;
    text-align: left;
    background: transparent;
    transition: ease-in-out all 0.1s;
}
nav ul li a{
    font-size: 16px;
    max-width: 140px;
    display: flex;
    color: #b7b4a9;
    text-decoration: none;
    line-height: 20px;
    padding: 0px;
    margin: 0 0px;
    width: auto;
    background: transparent;
    border: 0;
}
nav ul li.menu-item-95 a{
    max-width: 100px;
}
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: flex; flex-flow: column wrap;  }
nav ul li ul li{
    display: list-item;
}
nav ul li ul li a{
    color: #f6772b;
    padding: 0;
    margin: 0;
}
nav ul li ul li a:hover{
    color: black;
    text-decoration: none;
}*/

.bggrey{
    background-color:#e5e3db;
}
.btn-contact.bgblue{
    background:#193846 url('gfx/fleche.png') no-repeat 90% center;
    color: white;
}
.btn-contact.bgblue:hover{
    color:#a9a69a;
}
h1{
    font-size: 48px;
    margin: -116px 0 0 0;
    position: relative;
    z-index: 10;
}
h1 span{
    color:#193846 ;
}
.zone-texte h2{
    font-family: "Momo Trust Display", sans-serif;
    color:#a9a69a;
    font-size: 40px;
    padding-bottom: 2rem;
    position: relative;
}
.zone-texte h2::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    bottom: 0;
    left: -64px;
}
.zone-texte p{
    font-size: 15px;
    line-height: 24px;
    text-align: justify;
}
.presentation img{ margin-top: 100px; }
.bloc-thierry{ padding: 54px 0; position: relative; z-index: 2; margin: -120px 0 0 0;  }
.bloc-thierry p{ font-size: 15px; line-height: 24px; }
.bloc-thierry::before{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    top: -12px;
    right: 20px;
}
.bggrey{
    padding: 156px 0 180px 0;
}
.bggrey.mrgtneg{
    margin-top: -150px;
    padding: 346px 0 180px 0;
}
.bggrey h2{ font-size: 40px; padding-bottom: 1.5rem; position: relative; max-width: 90%; }
.bggrey h2::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    bottom: 0;
    left: -64px;
}
.bggrey h2 span{
    color:#a9a69a;
}
.bggrey .zone-texte p{ max-width: 75%; }
.bggrey img{ margin-bottom: 30px; max-width: 80%; }
.bggrey .bloc2 h2, 
.bggrey .bloc2 p{ margin-left: 20%; }
.contact .row.bordure{
    padding: 84px 0;
    border: 10px solid #a9a69a;
    align-items: center;
}
.contact .row{
    padding: 84px 0;
    align-items: center;
}
.contact .row p{
    font-family: "Momo Trust Display", sans-serif;
    color:#a9a69a;
    font-size: 30px;
    line-height: 30px;
    margin: 0;
}
.contact .row p span{
    font-size: 20px;
    color:#193846;
    font-family: "Poppins", sans-serif;
}
.contact.contact1{ position: relative; margin: -60px 0 0 0; z-index: 2; }
.troisblocs h2{
    font-size: 40px;
    margin: 110px 0 70px 0;
}
.troisblocs h3{
    padding-top: 54px;
    min-height: 70px;
    position: relative;
    font-size: 24px;
}
.troisblocs p{
    font-size: 15px;
    line-height: 24px;
    min-height: 90px;
    margin: 0;
    position: relative;
}
.troisblocs1::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    bottom: -90px;
    left: -64px;
}
.troisblocs2::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    top: -10px;
    left: -64px;
    transform: scale(1, -1);
}
.troisblocs3::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    bottom: -90px;
    right: -64px;
    transform: scale(-1, 1);
}
.contact.contact3{ position: relative; margin: -60px 0 60px 0; z-index: 2; }
.chiffres h2{
    font-size: 40px;
    margin: 30px 0 70px 0;
}
.chiffres h3{ font-size: 15px; }
.chiffres h3 b{ 
    font-family: "Momo Trust Display", sans-serif;
    font-size: 60px;
}
.chiffres img{
    margin: 20px auto 180px auto;
}
.reengeneering h2{
    font-family: "Momo Trust Display", sans-serif;
    font-size: 40px;
    position: relative;
}
.reengeneering h2::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    top: 110px;
    left: -64px;
}
.reengeneering h2 span{ 
    color:#a9a69a; 
    max-width: 80%;  
    display: inline-block; 
}
.reengeneering h2 span.small{
    font-size: 15px;
    line-height: 24px;
    display: inline-block;
    color:#193846;
    font-family: "Poppins", sans-serif;
    margin-top: 1rem;
}
.swiper-button-next:after, 
.swiper-button-prev:after{color:#a9a69a; }
.reengeneering{
     position: relative;
}
.reengeneering::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    bottom: 2%;
    right: 17.5%;
    transform: scale(-1, 1);
}
.reengeneering p{
    font-family: "Momo Trust Display", sans-serif;
    font-size: 30px;
    position: relative;
    color:#a9a69a;
    margin: 130px 0 0 20px;
}
.reengeneering p span{ color:#193846; }
.btn-contact.white{
    background: transparent url('gfx/fleche.png') no-repeat 90% center;
    border: 1px solid #193846;
    color:#193846;
}
.btn-contact.white:hover{ border: 1px solid #a9a69a; color:#a9a69a; }
.bgimage{
    background:#193846 url('gfx/fond-bleu.jpg') no-repeat center / cover;
    padding: 62px 0 140px 0;
    margin-top: 84px;
}
.pontons h2{ font-size: 40px; padding: 40px 0; position: relative; }
.pontons h2::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    top: 0px;
    left: 19%;
    transform: scale(1, -1);
}
.pontons h3{ 
    font-family: "Momo Trust Display", sans-serif;
    font-size: 24px;
    position: relative;
    margin: 38px 0 0 0;
}
.pontons h3::before{
    content: '>';
    color:#a9a69a;
    position: absolute;
    left: -30px;
    font-size: 30px;
}
.pontons p{ font-size: 15px; line-height: 24px; }
.btn-contact.brdgrey{
    color:#a9a69a;
    background: transparent url('gfx/fleche.png') no-repeat 90% center;
    border: 1px solid #a9a69a;
}
.btn-contact.brdgrey:hover{ color: white; border-color: white; }
.pontons .btn-contact{ margin-top: 3rem; }
.pontons .row.relative::after{
    content: " ";
    display: block;
    width: 39px;
    height: 38px;
    background: transparent url('gfx/truc.png') no-repeat 0 0;
    position: absolute;
    top: -10px;
    right: 19%;
    transform: scale(-1, 1);
    z-index: 100;
}
.contact.contact4{ margin: -10px 0 90px 0; }
.equipements h2{ font-size: 40px; margin-bottom: 40px; }
.equipements h3{ font-size: 14px; font-family: "poppins", sans-serif; min-height: 120px;  position: relative; padding: 40px 0 0 0;}
.equipements h3 b{ font-size: 24px; font-family: "Momo Trust Display", sans-serif; display: inline-block; width: 100%;}
.equipements h3::after{
    content: " ";
    display: block;
    width: 28px;
    height: 28px;
    background: transparent url(gfx/truc.png) no-repeat 0 0 / contain;
    position: absolute;
    bottom: 2%;
    right: 17.5%;
}
.equipements .equipement1 h3::after{ bottom: 0; left: -28px; }
.equipements .equipement2 h3::after{ bottom: auto; top: 0; left: -28px; transform: scale(1, -1);}
.equipements .equipement3 h3::after{ bottom: 0; left: auto; right: -28px; transform: scale(-1, 1);}
.equipements .equipement4 h3::after{ bottom: auto; top: 0; left: auto; right: -28px; transform: scale(-1,-1);}
.btn-contact.brdblue{ 
    background: transparent url('gfx/fleche.png') no-repeat 90% center;
    color:#193846;
    border: 1px solid #193846;
}
.btn-contact.brdblue:hover{ color:#a9a69a; }
.equipements .btn-contact{ margin: 2rem auto; }
.formcontact h2 span{
    color:#193846;
}
.formcontact img{ max-width: 200%; margin-left: -100%; }


input[type="text"], 
input[type="email"], input[type="tel"], 
input[type="number"], select{
    line-height: 50px;
    padding: 0 1rem;
    border: 0px;
    width: calc(100% - 2rem - 2px);
    font-size: 17px;
    color:#193846;
    margin: 0 0 20px 0;
    border-radius: 10px;
}
textarea{
    line-height: 20px;
    padding: 1rem;
    border: 0px;
    width: calc(100% - 2rem - 2px);
    font-size: 17px;
    color:#193846;
    margin: 0 0 20px 0;
    border-radius: 10px;
}
input[type="text"]::placeholder, 
input[type="email"]::placeholder, input[type="tel"]::placeholder, 
input[type="number"]::placeholder, select::placeholder, textarea::placeholder{
    color:#193846;
}
input[type="submit"]{
    background: #193846 url(gfx/fleche.png) no-repeat 90% center;
    width: max-content;
    padding: 0 110px;
    display: block;
    color: white;
    text-align: center;
    line-height: 54px;
    font-family: "Momo Trust Display", sans-serif;
    font-size: 18px;
    transition: ease-in-out all .2s;
    margin: 1rem auto;
}
input[type="submit"]:hover{
    background: #fff url(gfx/fleche.png) no-repeat 90% center;
    color: #193846;
}
.bggrey.nopad{ padding-bottom: 80px; }



footer .bgblue{  
    padding: 100px 0 80px 0;
    position: relative;
}
footer .bgblue::before{
    content: " ";
    width: 46px;
    height: 74px;
    background: transparent url('gfx/rectangle.png') no-repeat 0 0;
    position: absolute;
    left: 0;
    top: -36px;
}
footer p.adresse{
    margin-top: 40px;
    font-size: 16px;
}
footer a.tel{ font-weight: 700; }
.row.baseline{ align-items: flex-end; }
footer .coordonnees p.grey{ margin: 0; }
footer .coordonnees img{ margin-left: 1rem; }
footer #logo{ margin-top: 180px; }
.copyright p{ font-size: 12px; margin: 1rem 0; }





/**/
@media (min-width: 2px) and (max-width: 1023px){
    header .titre {
        margin: 50px 0 0 30px;
    }
    header > .row > div.bgblue{ min-height: auto; }
    .menu-toggle{
        width: 25%;
        margin-left: 75%;
        padding: 0;
        background: #fff;
        color: #193846;
        border:0;
        display: block;
        font-size: 4rem;
        line-height: 4rem;
        text-align: center;
    }
    header .btn-contact{
        position: relative;
        bottom: auto;
        right: auto;
        width: 75%;
    }
    .btn-contact{
        padding: 0 56px 0 28px;
        margin: 0 auto;
    }
   .menu-toggle:active, .menu-toggle:focus, .menu-toggle:hover{
        text-decoration: none;
    }
    .nav-menu{ 
        background: white;
        display: none; 
        flex-flow: column wrap;
        padding: 1rem 0; 
        margin:0; 
        z-index: 10001; 
        width: 100%;
        position: absolute;
        left: 0;
        top: 0;
     }
    .nav-menu.toggled-on{ display: flex; }
    nav ul{
        flex-direction: column;
    }
    nav ul li{
        list-style-type: none;
        display: flex;
        flex-flow: row wrap;
        align-items: center;
        justify-content: center;
        width: 90%;
        padding: 0;
        margin: .5rem 5%;
        text-align: center;
        transition: ease-in-out all 0.1s;
    }
    nav ul li a, nav ul li.menu-item-95 a{
        font-size: 1.3rem;
        max-width:none;
        display: block;
        color:#193846;
        background: white;
        text-decoration: none;
        width: 100%;
        padding: 0;
        margin: 0;
    }
    nav ul li a br{ display: none; }
    header a#logo{
        position: absolute;
        top: -102px;
        right: 0;
        width: 32%;
        background-size: 100%;
    }
    h1 {
        font-size: 26px;
        margin: -66px 0 0 5%;
        position: relative;
        z-index: 10;
    }
    .presentation img {
        margin-top: 60px; margin-bottom: 2rem;
    }
    .presentation{ width: 80%; padding: 0 10%; }
    .bloc-thierry{
        width: 80%; padding: 34px 10%;
        margin: 1rem 0 0 0;
    }
    .bggrey.mrgtneg {
        margin-top: 0px;
        padding: 34px 10%;
        width: 80%;
    }
    body h2{ font-size: 1.5rem!important; }
    .bggrey .zone-texte p{ max-width: 80%; }
    .contact.contact1{ margin: 0; }
    .contact .row.bordure {
        padding: 44px 5%;
        width: 80%;
        margin: 0 auto;
    }
    .contact .row p { font-size: 22px; line-height: 24px; margin-bottom: 1rem; }
    .contact .row p span { font-size: 16px; }
    .troisblocs h2{ margin: 4rem 0 0 0; }
    .troisblocs{
        padding: 0 10%;
        width: 80%;
    }
    .contact .row.nobordure {
        padding: 44px 5%;
        width: 80%;
        margin: 0 auto;
    }
    .bggrey{
        padding: 3rem 10%;
        width: 80%;
    }
    .contact.contact3{ margin: 2rem auto; }
    .chiffres h2{ margin: 3rem 0 1rem 0; }
    .chiffres h3{ margin-bottom: 2rem; }
    .chiffres img {
        margin: 20px auto 80px auto;
    }
    .reengeneering, .equipements{
        padding: 0 10%;
        width: 80%;
    }
    .reengeneering p{ margin: 2rem 0; font-size: 20px; }
    .bgimage{
        padding: 42px 10% 60px 10%; width: 80%;
    }
    .troisblocs3::after{ right: 0; }
    footer .bgblue {
        padding: 4rem 10%;
         width: 80%;
    }
    footer #logo { margin-top: 3rem; }
    .copyright p{
        width: 80%;
        margin: 1rem 10%;
    }








}
/**/
@media (min-width: 768px) and (max-width: 1023px){

    header a#logo{ position: relative; right: auto; top: auto; width: 80%; margin-left: 10%; }
    header .titre { margin: 50px 0 0 5%; font-size: 18px; }
    header > .row > div.bgblue { min-height: 146px; }
    header .btn-contact{ margin-left: 25%; }
    h1 {
        font-size: 30px;
        margin: -76px 0 0 5%;
    }
    .bloc-thierry {
        width: 150%;
        padding: 34px 0%;
        margin: 1rem 0 0 -25%;
    }
    .bggrey.mrgtneg {
        margin-top: 0px;
        padding: 34px 0;
        width: 100%;
    }
    .bggrey .span-2{ width: 5%; }
    .bggrey .span-4{ width: 45%; }
    .bggrey .span-4.bloc2{ width: 90%; margin-top: 2rem; }
    .troisblocs{ width: 100%; padding: 0; }
    .troisblocs p{ min-height: 140px; }
    .troisblocs h3{ min-height: 100px; }
    .bggrey img{ margin-top: 7rem; }
    .reengeneering, .equipements{ padding: 0; width: 100%;}
    .reengeneering .spannomargin-8{ margin-left: 10%; }
    .reengeneering .spannomargin-6{ margin-left: 10%; }
    .bgimage{
        padding: 42px 0% 60px 0%;
        width: 100%;
    }
    .pontons .spannomargin-2{ width: 5%; }
    .pontons .spannomargin-10{ width: 45%; }
    .equipements .spannomargin-1{ width: 2.5%; }
    .equipements .spannomargin-4{ width: 20%; }
    .bggrey.nopad{ width: 100%; padding: 3rem 0; }
    .formcontact .spannomargin-8{ width: 25%; }
    .wpcf7 .spannomargin-11{ width: 47.5%; }
    footer .bgblue{
        width: 60%;
        padding: 3rem 0;
    }
    footer p.adresse{ font-size: 14px; }
    footer .coordonnees p.grey{ font-size: 10px; }

}
/**/
@media (min-width: 1024px) and (max-width: 1279px) {
    header .titre {
        margin: 60px 0 0 30px;
        font-size: 16px;
    }
    nav ul li a {
        font-size: 10px;
        line-height: 14px;
    }
    a#logo{ background-size: 70%; }
    .btn-contact{ font-size: 11px; background-size: 14px; line-height: 44px; }
    header > .row > div.bgblue { min-height: 166px; }
    h1 {
        font-size: 32px;
        margin: -82px 0 0 0;
    }
    .zone-texte h2 { font-size: 24px; }
    body h2{ font-size: 24px!important; }
    .zone-texte p, .bloc-thierry p {
        font-size: 11px;
        line-height: 16px;
    }
    .bloc-thierry {
        padding: 34px 0;
        margin: -58px 0 0 0;
    }
    .bggrey.mrgtneg {
        margin-top: -150px;
        padding: 236px 0 120px 0;
    }
    .contact .row.bordure {
        padding: 54px 0;
    }
    .contact .row p {
        font-size: 20px;
        line-height: 24px;
    }
    .contact .row p span { font-size: 16px; }
    .troisblocs h2 { margin: 80px 0 50px 0; }
    .troisblocs h3{ font-size: 18px; }
    .troisblocs p {
        font-size: 12px;
        line-height: 20px;
    }
    .bggrey {
        padding: 116px 0 120px 0;
    }
    .chiffres h3 b { font-size: 40px; }
    .chiffres h3 { font-size: 13px; }
    .chiffres img { margin: 20px auto 120px auto; }
    .reengeneering p { font-size: 20px; }
    .reengeneering h2 span.small {
        font-size: 12px;
        line-height: 20px;
    }
    .bgimage { margin-top: 64px; padding: 62px 0 110px 0; }
    .pontons h3 {
        font-size: 16px;
        margin: 28px 0 0 0;
    }
    .pontons p {
        font-size: 11px;
        line-height: 18px;
    }
    .equipements h3 b { font-size: 16px; }
    .equipements h3 { font-size: 12px; }
    input[type="text"], input[type="email"], 
    input[type="tel"], input[type="number"], select, textarea{
        font-size: 13px;
    }
    input[type="submit"]{ font-size: 13px; }
    .wpcf7-list-item-label{ font-size: 11px; }
    footer p.adresse {
        margin-top: 30px;
        font-size: 12px;
    }
    footer .coordonnees p.grey{ font-size: 11px; }
    footer #logo { margin-top: 100px; background-size: 50%; }
    footer .bgblue {
        padding: 60px 0 50px 0;
    }





}
/**/
@media (min-width: 1280px) and (max-width: 1479px){



   header .titre {
        margin: 60px 0 0 30px;
        font-size: 20px;
    }
    nav ul li a {
        font-size: 12px;
        line-height: 16px;
    }
    a#logo{ background-size: 70%; }
    .btn-contact{ font-size: 13px; background-size: 14px; line-height: 48px; }
    header > .row > div.bgblue { min-height: 166px; }
    h1 {
        font-size: 36px;
        margin: -90px 0 0 0;
    }
    .zone-texte h2 { font-size: 26px; }
    body h2{ font-size: 26px!important; }
    .zone-texte p, .bloc-thierry p {
        font-size: 12px;
        line-height: 20px;
    }
    .bloc-thierry {
        padding: 34px 0;
        margin: -58px 0 0 0;
    }
    .bggrey.mrgtneg {
        margin-top: -150px;
        padding: 236px 0 120px 0;
    }
    .contact .row.bordure {
        padding: 54px 0;
    }
    .contact .row p {
        font-size: 20px;
        line-height: 24px;
    }
    .contact .row p span { font-size: 16px; }
    .troisblocs h2 { margin: 80px 0 50px 0; }
    .troisblocs h3{ font-size: 20px; }
    .troisblocs p {
        font-size: 12px;
        line-height: 20px;
    }
    .bggrey {
        padding: 116px 0 120px 0;
    }
    .chiffres h3 b { font-size: 48px; }
    .chiffres h3 { font-size: 14px; }
    .chiffres img { margin: 20px auto 120px auto; }
    .reengeneering p { font-size: 24px; }
    .reengeneering h2 span.small {
        font-size: 12px;
        line-height: 20px;
    }
    .bgimage { margin-top: 64px; padding: 62px 0 110px 0; }
    .pontons h3 {
        font-size: 18px;
        margin: 28px 0 0 0;
    }
    .pontons p {
        font-size: 12px;
        line-height: 20px;
    }
    .equipements h3 b { font-size: 18px; }
    .equipements h3 { font-size: 13px; }
    input[type="text"], input[type="email"], 
    input[type="tel"], input[type="number"], select, textarea{
        font-size: 14px;
    }
    input[type="submit"]{ font-size: 16px; }
    .wpcf7-list-item-label{ font-size: 11px; }
    footer p.adresse {
        margin-top: 30px;
        font-size: 12px;
    }
    footer .coordonnees p.grey{ font-size: 11px; }
    footer #logo { margin-top: 100px; background-size: 50%; }
    footer .bgblue {
        padding: 60px 0 50px 0;
    }




}
/**/
@media (min-width: 1480px) and (max-width: 1599px){
    header .titre{ font-size: 26px; }
    nav ul li a{ font-size: 14px; }
    body h2 { font-size: 34px!important; }
    .reengeneering h2{ font-size: 30px!important; }




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

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

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

}
/**/