/*
Theme Name: Couleur Villas by Aurélien Allemand
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*/

    @font-face {
        font-family: 'Coruse';
        src: url('fonts/CoruseRegular.woff2') format('woff2'),
            url('fonts/CoruseRegular.woff') format('woff');
        font-weight: normal;
        font-style: normal;
        font-display: swap;
    }
    @font-face {
        font-family: 'Champagne-Limousines';
        src: url('fonts/ChampagneLimousines-Bold.woff2') format('woff2'),
            url('fonts/ChampagneLimousines-Bold.woff') format('woff'),
            url('fonts/ChampagneLimousines-Bold.ttf') format('truetype'),
            url('fonts/ChampagneLimousines-Bold.svg#Champagne&Limousines-Bold') format('svg');
        font-weight: 500;
        font-style: normal;
        font-display: swap;
    }
    .champagne{ font-family:'Champagne-Limousines'; }
    .coruse{ font-family: 'Coruse', sans-serif; }
    .poppins{ font-family: "Poppins", sans-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%; }
img{ height: auto; }
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: #959393; }
.red, a.red{ color:#da374b; }

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 }

.flex{ display: flex; }

.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: #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; }


.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:#6e5e64;
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    font-size: 18px;
}
.conteneur{ max-width: 1920px; margin: 0 auto; width: 100%; overflow-x:hidden; }

header,  main, footer, .home_contenu{ width: 100%; }
header{
    padding: 82px 0 90px 0;
}
a#logo{
    display: block;
    background: transparent url('gfx/logo.svg') no-repeat center top / 100%;
    width: 276px;
    height: 110px;
    margin: 0 auto;
}
.menu-toggle{ display: none; }
.nav-menu{ display: flex; }
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;
    justify-content: center;
}
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: 14px;
    text-transform: uppercase;
    font-family:'Champagne-Limousines';
    display: flex;
    color: #6e5e64;
    text-decoration: none;
    line-height: 14px;
    padding: 10px;
    margin: 0 0px;
    letter-spacing: .2rem;
    width: auto;
    background: transparent;
    border: 0;
}
nav ul li a:hover{ color: #da374b; text-decoration: none; }
nav ul li:hover{ }
nav ul li:hover a, 
nav ul li.current-menu-item a{
}
/*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;
}*/
.btn-contact{
    background:#6e5e64;
    display: inline-block;
    line-height: 58px;
    color: white;
    font-size: 14px;
    text-transform: uppercase;
    font-family:'Champagne-Limousines';
    letter-spacing: .1rem;
    padding: 0 40px;
    transition: ease-in-out all .1s;
}
.btn-contact:hover{
    text-decoration: none;
    color: white;
    background-color:#da374b;
    transition: ease-in-out all .1s;
}
header .btn-contact{ margin: 0 0 0 20px; }
header p{ margin: 0; }
.telephone{
    color:#6e5e64;
    font-family:'Champagne-Limousines';
    font-size: 18px;
    letter-spacing: .1rem;
    margin: 12px 46px 0 0;
    padding-left: 50px;
    line-height: 50px;
    display: inline-block;
    border-left: 1px solid #da374b;
}
.telephone:hover{
    color:#da374b;
    text-decoration: none;
}
.slidelegende{
    right: 100px;
    bottom: 0;
    margin: 0;
    color: white;
    z-index: 12;
    font-weight: 300;
    font-size: 20px;
    line-height: 20px;
    bottom: 56px;
    text-transform: uppercase;
    letter-spacing: .3rem;
}
.slidelegende span{
    font-size: 34px;
    text-transform: none;
    font-family: 'Coruse', sans-serif; 
    letter-spacing: 0;
}
.swiperhome .swiper-slide::after{
    content: " ";
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    top: 0;
    background: transparent url('gfx/masque.png') no-repeat center / cover;
    z-index: 10;
}
.encart-blanc{
    background: white;
    bottom: -40px;
    left: 0;
    z-index: 999;
    padding: 72px 3.25% 40px 6.25%;
    width: 29%;
}
.swiper-button-next::after, .swiper-button-prev::after{ 
    content: " ";
    background: transparent url('gfx/fleche.svg') no-repeat center / 100%;
    width: 42px;
    height: 74px;
}
.swiper-button-prev::after{ transform: rotate(180deg); }
.swiper-button-next{ right: 3%; }
.swiper-button-prev{ left: 3%; }
h1{
    font-size: 54px;
    line-height: 70px;
    text-transform: uppercase;
    font-weight: 300;
}
h1 span{ font-size: 70px; font-family: 'Coruse', sans-serif; text-transform: none; }
.encart-blanc p{ font-size: 16px; line-height: 24px; }
.diapo1{ margin-bottom: 230px; }
.dessusvideo1{ top: 0; left: 0; z-index: 2; }
.stretch{ align-items: stretch; }
.bgvideo1 video{ }
.carre-rouge{
    background-color:#da374b;
    height: 100%;
    aspect-ratio: 1/1;
}
.dessusvideo1{ mix-blend-mode: multiply; }
.dessusvideo1 .span-8.flex .swiper-slide{ 
    justify-content: space-between; 
    display: flex; 
}
.dessusvideo1 .span-8.flex .swiper-slide img.mini1{ max-width: 46%; }
.dessusvideo1 .span-8.flex .swiper-slide img.mini2{ max-width: 46%; }
h2{
    font-size: 54px;
    line-height: 70px;
    text-transform: uppercase;
    font-weight: 300;
    color:#cdc6c9;
    margin: 0 0 24px 0;
}
h2 span{ color: #6e5e64; }
p{ font-size: 16px; line-height: 28px; margin: 0 0 20px 0; }
.zone-petites-photo p{
    max-width: 70%;
}
.video-signature{ 
    bottom: 24px;
    left: 44%;
    text-align: left; 
    z-index: 10; 
    font-size: 26px; 
    line-height: 28px; 
}
.zone-petites-photo{ margin: 0 0 120px 0; }
.ligne-contact{ margin-bottom: 120px; }
.ligne-contact p{
    font-size: 25px;
    line-height: 36px;
    font-weight: 300;
}
.ligne-contact .spannomargin-8 p{ margin: 8px 0 0 0; }
.ligne-contact p span{
     font-size: 30px; font-family: 'Coruse', sans-serif;
}
.trait-rouge{
    width: 96%;
    height: 1px;
    background-color:#da374b;
}
.ligne-contact .trait-rouge{ margin: 36px 0 0 0; }
.ligne-contact .telephone{ margin-right: 64px; }
h2 .petit{
    font-size: 18px;
    letter-spacing: .1rem;
    color:#9d9397;
}
.bloc-blanc{
    background:white;
    padding: 100px 15% 60px 15%;
}
.row.marginneg{ margin-top: -340px; }
.latelier .zone-texte.txtatelier{ margin: 90px 0 110px 0; width: 87.5%; }
.trait-vertical{
    width: 1px;
    height: 240px;
    background-color:#da374b;
}
.stretch{ align-items:stretch; }
.latelier .trait-vertical{ position: absolute; top: 25%; right: 0; }
.latelier .zone-texte.spannomargin-17{ margin-top: 60px; }
.latelier .stretch .spannomargin-10, 
.latelier .stretch .spannomargin-9{ position: relative; z-index: 3; }
.latelier .fondvideo{ position: absolute; bottom: 0; left: 10%; z-index: 1; }
.latelier .stretch { position: relative; padding-bottom: 270px; }
.latelier .zone-texte.spannomargin-17 p{ width: 75%; }
.ligne-contact2 p{ margin-left: 5%; }
.expertise h2 .petit{ line-height: 34px; }
.expertise h2{ margin-bottom: 40px; margin-top: -30px;}
.expertise img.mrgleft{ margin-left: 10%; }
.expertise img.expert3{ margin-top: 100px; }
.expertise{ padding-bottom: 200px; }
.ligne-contact3 p{ margin-left: 5%; }
.ligne-contact3 .trait-rouge{ position: relative; }
.ligne-contact3 .trait-rouge::after{
    content: " ";
    height: 160px;
    width: 1px;
    background-color:#da374b;
    position: absolute;
    right: 50px;
    bottom: -20px;
}
.esplarge{ max-width: 63.25%; }
.espsmall{ max-width: 35.5%; }
.space-between{ justify-content: space-between; }
h3{
    font-size: 28px;
    line-height: 44px;
    text-transform: uppercase;
    font-weight: 300;
    color: #cdc6c9;
    margin: 0 0 24px 0;
}
h3 span { color: #6e5e64; }
h3 span.coruse{ text-transform: none; font-size: 38px; }
.bloc-blanc2{
    padding: 70px 15% 100px 15%;
    background: white;
}
.marginneg2{ margin-top: -210px; position: relative; z-index: 3;}
.espacesdevie h4{
    margin-left: 20%;
    margin-right: 10%;
    font-size: 22px;
    line-height: 36px;
    margin-bottom: 80px;
}
.espacesdevie .stretch .zone-texte::after{
    content: " ";
    width: 33%;
    height: 1px;
    background-color:#da374b;
    position: absolute;
    bottom: 20px;
    left: 0;
}
.realisations .ligne-rouge{
    width: 100%;
    height: 1px;
    background-color:#da374b;
    margin-top: 80px;
    margin-bottom: 100px;
}
.realisations h3{
    font-size: 18px;
    letter-spacing: .1rem;
    margin: 20px 0;
}
.mrgplus{ margin-top: 120px; }

.masque-pop{
    position: fixed;
    display: flex;
    flex-flow: column wrap;
    align-items: center;
    justify-content: center;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10000;
    background: rgba(255,255,255,.9);
}
.masque-pop.hidden{
    top: 0;
    left: -100%;
    right: 100%;
    bottom: 0;
    opacity: 0;
    transition: ease-in-out opacity .2s;
}
.masque-pop.show{
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 1;
    transition: ease-in-out opacity .2s;
}
.in-pop{
    display: flex;
    width: calc(75% - 2px);
    padding: 120px 6.25%;
    margin: 2rem 6.25%;
    border: 1px solid black;
    box-shadow: 16px 16px 16px rgba(110,94,100,.16);
    background: white;
    overflow:auto;
}
.closepop{
    color:#da374b;
    position: absolute;
    font-weight: 100;
    font-size: 1px;
    right: 24px;
    top: 24px;
    width: 22px;
    height: 23px;
    padding: 10px;
    background: transparent url('gfx/croix.png') no-repeat center;
    overflow:hidden;
    text-indent: -3000px;
    transition: ease-in-out all .2s;
    cursor: pointer;
}
.closepop:hover{ transform: rotate(90deg); transition: ease-in-out all .2s; }
.in-pop .ligne-contact{ margin: 0; }
.in-pop .ligne-contact p{ margin-left: 10%; margin-top: 40px; }
.in-pop .ligne-contact p.alignright{ margin:0 0 60px 0; }
.in-pop h3{ 
    background: white; 
    font-size: 40px; 
    line-height: 60px; 
    font-weight: 300; 
    margin: 0 0 60px -50%;
    padding: 10px 0 10px 54px;
    position: relative;
    z-index: 100;
}
.in-pop p.coruse{ 
    background: white;
    font-size: 26px;
    margin: -50px 0 0 -50%;
    padding: 0 0 0 54px;
    position: relative;
    z-index: 100;
}
.in-pop .swiper-slide span{
    position: absolute;
    z-index: 2;
    bottom: 24px;
    left: calc(50% - 90px);
    width: 180px;
    height: 64px;
    background: transparent url('gfx/logo-blanc.svg') no-repeat center / 100%;
}
.clicpop img{ display: flex; }
.clicpop p.coruse{ font-size: 26px; letter-spacing: .1rem; margin: 42px 0 6px 0; }
.clicpop h4{ font-size: 18px; text-transform: uppercase; letter-spacing: .1rem; color:#9d9397; }
.clicpop{ cursor: pointer; position: relative; }
.clicpop .btnplus{
    position: absolute;
    bottom: 0;
    right: 0;
    width: 90px;
    text-align: right;
    font-size: 20px;
}
.clicpop .btnplus::after{
    content: " ";
    display: block;
    width: 70px;
    position: absolute; 
    left: 0;
    bottom: 15px;
    height: 1px;
    background : #da374b;
}
.clicpop:hover .btnplus{ color:#9d9397; }
.clicpop:hover .btnplus::after{ background:#9d9397; }
.clicpop:hover h4, .clicpop:hover p{ color:#da374b; }
.bgmarron{
    background-color:#7b6a6e;
    margin: 160px 0 0 0;
    padding: 0 0 50px 0;
    overflow: hidden;
}
.bgmarron .mille.center{ position: relative; z-index: 10; }
.bgmarron .bgvidmarron{
    right: 7.5%;
    top: -60px;
    z-index: 0;
}
.bgmarron h2{ margin-top: 90px; color: white; margin-bottom: 70px; }
.bgmarron h2 .petit{ color:#cdc6c9; line-height: 40px; }

input[type="text"], input[type="date"], 
input[type="email"], input[type="tel"], 
select, textarea{
    background-color:transparent;
    border: 0px;
    border-bottom: 1px solid white;
    color: white;
    padding: 0;
    width: 100%;
    line-height: 40px;
    margin:0 0 40px 0;
}
input[type="text"]::placeholder, input[type="date"]::placeholder, 
input[type="email"]::placeholder, input[type="tel"]::placeholder, 
textarea::placeholder{
    color: white;
    text-transform: uppercase;
}
.wpcf7 p, .wpcf7 label{
    color: white;
    margin: 0;
}
.wpcf7 .spannomargin-11 .row .spannomargin-11 select{
    margin-top: 30px;
}
.wpcf7-list-item-label{ font-style: italic; }
.wpcf7-list-item{ margin-left: 0; }
input[type="submit"]{
    width: max-content;
    margin: 50px auto 0 auto;
    line-height: 56px;
    padding: 0 70px;
    color: white;
    border: 1px solid white;
    background-color:#7b6a6e;
    font-weight: 300;
    text-transform: uppercase;
    font-size: 14px;
    letter-spacing: .1rem;
}
.acceptances{ position: relative; }
.wpcf7-spinner{ position: absolute; bottom: 0; right: 0; }
.wpcf7 label.lieu{ margin-top: 72px; display: block; }
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: black;
}
.wpcf7-not-valid-tip, .wpcf7 form.invalid .wpcf7-response-output, 
.wpcf7 form.unaccepted .wpcf7-response-output, 
.wpcf7 form.payment-required .wpcf7-response-output{ background-color: white; padding: 0 1rem; font-size: 14px; }
.wpcf7 form.invalid .wpcf7-response-output, 
.wpcf7 form.unaccepted .wpcf7-response-output, 
.wpcf7 form.payment-required .wpcf7-response-output{ margin: 1rem auto; }

footer{ background: white; padding: 104px 0 0 0; }
footer .ligne-contact{ margin: 0; }
footer p.aligncenter{
    color:#b8afa9;
    width: 100%;
    font-size: 14px; 
    margin: 2rem 0;
}
footer p.aligncenter a{ color:#b8afa9; }
.footerlogo{ width: 58%; }
footer h3{
    font-size: 14px;
    text-transform: none;
    color:#6e5e64;
    letter-spacing: .05rem;
    line-height: 22px;
    margin: 2rem 0 0 0;
}
footer h3 span{ color:#6e5e64; font-size: 16px; text-transform: uppercase; }




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

    .menu-toggle{
        width: 100%;
        padding: 0;
        background: #fff;
        color: #8d001a;
        border:0;
        display: block;
        font-size: 2rem;
        line-height: 2rem;
        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%;
        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: inline-flex;
        text-align: center;
        transition: ease-in-out all 0.1s;
    }
    nav ul li a{
        font-size: 20px;
        display: block;
        color: #000;
        background: white;
        text-decoration: none;
        width: 100%;
        padding: 0;
        margin: 0;
    }
    nav ul li a:hover{ color: #8d001a; }
    nav ul li ul{
        margin:0;
        padding:0;
    }
    nav ul li:hover ul{ }
    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;
    }




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

}
/**/
@media (min-width: 1024px) and (max-width: 1479px) {
    h1 {
        font-size: 30px;
        line-height: 40px;
    }
    h1 span {  font-size: 38px; }
    a#logo{ width: 60%; height: 80px; }
    .btn-contact {
        line-height: 48px;
        font-size: 10px;
        letter-spacing: .1rem;
        padding: 0 20px;
    }
    .telephone {
        font-size: 14px;
        letter-spacing: .05rem;
        margin: 12px 20px 0 0;
        padding-left: 30px;
        line-height: 40px;
    }
    header { padding: 52px 0 50px 0 }
    nav ul li a {
        font-size: 10px;
        line-height: 10px;
        padding: 10px;
        margin: 0 0px;
        letter-spacing: .1rem;
    }
    .encart-blanc p {
        font-size: 12px;
        line-height: 18px;
    }
    .encart-blanc{ padding: 42px 3.25% 40px 6.25%; }
    .slidelegende {
        right: 40px;
        bottom: 0;
        margin: 0;
        font-size: 14px;
        line-height: 14px;
        bottom: 26px;
        letter-spacing: .1rem;
    }
    .slidelegende span { font-size: 24px; }
    .diapo1 {
        margin-bottom: 130px;
    }
    h2 {
        font-size: 28px;
        line-height: 40px;
    }
    p {
        font-size: 12px;
        line-height: 20px;
        margin: 0 0 12px 0;
    }
    .zone-petites-photo p {
        max-width: 80%;
    }
    .video-signature {
        font-size: 18px;
        line-height: 20px;
    }
    .zone-petites-photo { margin: 0 0 60px 0; }
    .ligne-contact p {
        font-size: 17px; line-height: 30px;
    }
    .ligne-contact p span {
        font-size: 26px;
    }
    .ligne-contact {
        margin-bottom: 60px;
    }
    .row.marginneg { margin-top: -180px; }
    .bloc-blanc { padding: 50px 15% 20px 15%; }
    h2 .petit { font-size: 12px; }
    .latelier .zone-texte.txtatelier {
        margin: 60px 0 80px 0;
        width: 87.5%;
    }
    .latelier .fondvideo video{ width: 70%; }
    .latelier .stretch { padding-bottom: 200px; }
    .expertise img.mrgleft{ max-width: 60%; }
    .expertise { padding-bottom: 160px; }
    h3 {
        font-size: 18px;
        line-height: 34px;
    }
    h3 span.coruse { font-size: 28px; }
    .bloc-blanc2 { padding: 50px 15% 60px 15%; }
    .marginneg2 { margin-top: -140px; }
    .espacesdevie h4 {
        font-size: 14px;
        line-height: 26px;
        margin-bottom: 60px;
    }
    img.expert4{ width: 40%; }
    .clicpop p.coruse {
        font-size: 18px;
        letter-spacing: .1rem;
        margin: 32px 0 6px 0;
    }
    .clicpop h4 {  font-size: 14px; }
    .clicpop .btnplus{ width: 60px; }
    .clicpop .btnplus::after{ width: 40px; }
    .mrgplus { margin-top: 80px; }
    .in-pop h3 { font-size: 20px; line-height: 40px; margin: 0 0 30px -50%; }
    .in-pop p.coruse{ font-size: 16px; line-height: 20px; }
    .in-pop p {
        font-size: 10px;
        line-height: 16px;
    }
    .in-pop .ligne-contact p span { font-size: 20px; }
    .in-pop .ligne-contact p.alignright { margin: 0 0 30px 0; }
    .in-pop .ligne-contact .telephone{ margin-right: 30px; }
    .in-pop {
        width: calc(75% - 2px);
        padding: 80px 6.25% 40px 6.25%;
        margin: 2rem 6.25%;
    }
    .in-pop .swiper-slide span{ left: calc(50% - 60px); width: 120px; }
    .bgmarron .bgvidmarron{ width: 60%; top: -20px; }
    .bgmarron h2 {
        margin-top: 70px;
        margin-bottom: 50px;
    }
    input[type="text"], input[type="date"], 
    input[type="email"], input[type="tel"], select, textarea{ font-size: 14px; }
    .wpcf7 .spannomargin-11 .row .spannomargin-11 select { margin-top: 22px; }
    .wpcf7 p, .wpcf7 label{ font-size: 12px; }
    input[type="submit"] {
        margin: 50px auto 0 auto;
        line-height: 46px;
        padding: 0 50px;
        font-size: 12px;
    }
    footer { padding: 64px 0 0 0; }
    footer h3 span{ font-size: 11px; }
    footer h3{ font-size: 9px; line-height: 16px; margin: 1rem 0 0 0; }
    footer p.aligncenter { font-size: 10px; margin: 1rem 0; }





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

    nav ul li a {
        font-size: 11px;
        line-height: 12px;
    }
    .latelier .fondvideo video {
        width: 60%;
    }
    .latelier .stretch { padding-bottom: 220px; }
    .in-pop{ padding-top: 100px; }
    .bgmarron .bgvidmarron{ top: -80px; }


}
/**/
@media (min-width: 1480px) and (max-width: 1799px){
    h1 {
        font-size: 44px;
        line-height: 60px;
    }
    h1 span { font-size: 60px; }
    .encart-blanc{ padding-top: 62px; }
    .slidelegende{ font-size: 16px; }
    .slidelegende span{ font-size: 28px; }
    h2 {
        font-size: 40px;
        line-height: 56px;
    }
    h2 .petit {
        font-size: 14px;
    }
    .bloc-blanc{ padding-top: 70px; }
    .row.marginneg { margin-top: -270px; }
    p {
        font-size: 14px;
        line-height: 24px;
    }
    .latelier .fondvideo video{ width: 55%; }
    .espacesdevie h4 {
        font-size: 18px;
        line-height: 32px;
    }
    .in-pop h3{ font-size: 36px; }
    .bgmarron .bgvidmarron{ top: -80px; }




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

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

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

}
/**/