/*
Theme Name: Evénement
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"],
button,
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; text-align: center; }
.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; }
.row.column{ flex-flow: column 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{ 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%; }

    /*14 colonnes*/
    .span-1{ width: 7.1428%; }
    .span-2{ width: 14.2856%; }
    .span-3{ width: 21.4284%; }
    .span-4{ width: 28.5712%; }
    .span-5{ width: 35.714%; }
    .span-6{ width: 42.8568%; }
    .span-7{ width: 50%; }
    .span-8{ width: 57.1428%; }
    .span-9{ width: 64.2856%; }
    .span-10{ width: 71.4284%; }
    .span-11{ width: 78.5716%; }
    .span-12{ width: 85.7144%; }
    .span-13{ width: 92.8572%; }
    .span-14{ 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%; }

    /*14 colonnes*/
    .span-1{ width: 7.1428%; }
    .span-2{ width: 14.2856%; }
    .span-3{ width: 21.4284%; }
    .span-4{ width: 28.5712%; }
    .span-5{ width: 35.714%; }
    .span-6{ width: 42.8568%; }
    .span-7{ width: 50%; }
    .span-8{ width: 57.1428%; }
    .span-9{ width: 64.2856%; }
    .span-10{ width: 71.4284%; }
    .span-11{ width: 78.5716%; }
    .span-12{ width: 85.7144%; }
    .span-13{ width: 92.8572%; }
    .span-14{ 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: 'Gotham';
        src: url('fonts/Gotham-LightItalic.woff2') format('woff2'),
            url('fonts/Gotham-LightItalic.woff') format('woff');
        font-weight: 300;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-BoldItalic.woff2') format('woff2'),
            url('fonts/Gotham-BoldItalic.woff') format('woff');
        font-weight: bold;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-MediumItalic.woff2') format('woff2'),
            url('fonts/Gotham-MediumItalic.woff') format('woff');
        font-weight: 500;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-Black.woff2') format('woff2'),
            url('fonts/Gotham-Black.woff') format('woff');
        font-weight: 900;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-Thin.woff2') format('woff2'),
            url('fonts/Gotham-Thin.woff') format('woff');
        font-weight: 100;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-XLight.woff2') format('woff2'),
            url('fonts/Gotham-XLight.woff') format('woff');
        font-weight: 200;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham Ultra';
        src: url('fonts/Gotham-UltraItalic.woff2') format('woff2'),
            url('fonts/Gotham-UltraItalic.woff') format('woff');
        font-weight: normal;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-Medium.woff2') format('woff2'),
            url('fonts/Gotham-Medium.woff') format('woff');
        font-weight: 500;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham Ultra';
        src: url('fonts/Gotham-Ultra.woff2') format('woff2'),
            url('fonts/Gotham-Ultra.woff') format('woff');
        font-weight: normal;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-XLightItalic.woff2') format('woff2'),
            url('fonts/Gotham-XLightItalic.woff') format('woff');
        font-weight: 200;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-Book.woff2') format('woff2'),
            url('fonts/Gotham-Book.woff') format('woff');
        font-weight: normal;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-BookItalic.woff2') format('woff2'),
            url('fonts/Gotham-BookItalic.woff') format('woff');
        font-weight: normal;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-Bold.woff2') format('woff2'),
            url('fonts/Gotham-Bold.woff') format('woff');
        font-weight: bold;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-BlackItalic.woff2') format('woff2'),
            url('fonts/Gotham-BlackItalic.woff') format('woff');
        font-weight: 900;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-Light.woff2') format('woff2'),
            url('fonts/Gotham-Light.woff') format('woff');
        font-weight: 300;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Gotham';
        src: url('fonts/Gotham-ThinItalic.woff2') format('woff2'),
            url('fonts/Gotham-ThinItalic.woff') format('woff');
        font-weight: 100;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Bon Vivant';
        src: url('fonts/BonVivant-Regular.woff2') format('woff2'),
            url('fonts/BonVivant-Regular.woff') format('woff');
        font-weight: normal;
        font-style: italic;
        font-display: swap;
    }

    @font-face {
        font-family: 'Bon Vivant Serif';
        src: url('fonts/BonVivantSerif.woff2') format('woff2'),
            url('fonts/BonVivantSerif.woff') format('woff');
        font-weight: normal;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Bon Vivant Serif';
        src: url('fonts/BonVivantSerif-Bold.woff2') format('woff2'),
            url('fonts/BonVivantSerif-Bold.woff') format('woff');
        font-weight: bold;
        font-style: normal;
        font-display: swap;
    }

    @font-face {
        font-family: 'Lena';
        src: url('fonts/Lena.woff2') format('woff2'),
            url('fonts/Lena.woff') format('woff');
        font-weight: normal;
        font-style: normal;
        font-display: swap;
    }

    .gotham{ font-family: 'Gotham', Helvetica, sans-serif; }
    .lena{ font-family: 'Lena', Arial, Helvetica, sans-serif; }
    .bonvivant{ font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif; }

    .thin{ font-weight: 100; }
    .light{ font-weight: 300; }
    .regular{ font-weight: 400; }
    .medium{ font-weight: 500; }
    .semibold{ font-weight: 600; }
    .bold{ font-weight: 700; }
    .ultrabold{ font-weight: 900; }

/**/

img, iframe, video{ max-width: 100%; }
h1, h2, h3, h4, h5, h6{ }
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; }
.blue, a.blue{ color: #273065; }
.brown, a.brown{ color:#B08853; }

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: #273065; text-decoration: none; cursor: pointer; }
a:hover{ color: #B08853; 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:#273065;
    font-family: 'Gotham', Helvetica, sans-serif;
    font-weight: 400;
    font-size: 18px;
}
.conteneur{ max-width: 1920px; margin: 0 auto; overflow: hidden; width: 100%; }

header,  main, footer, .home_contenu{ width: 100%; }
header{ height: 130px; }
a#logo{
    display: block;
    background: transparent url('gfx/logo.svg') no-repeat center center / contain;
    width: 100%;
    min-height: 66px;
    margin: 0 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: center;
    width: auto;
}
.menu-menu-principal-container{
    display: flex;
    width: 100%;
    position: relative;
    margin-top: 3rem;
}
nav > div > ul{
    display: flex;
    flex-direction: row;
    width: 100%;
    align-items: flex-start;
    justify-content: flex-end;
}
nav > div > ul > li{
    list-style-type: none;
    display: inline-flex;
    text-align: center;
    background: transparent;
    transition: ease-in-out all 0.1s;
    position: relative;
    margin: 0 0 0 2rem;
}
nav > div > ul > li > a{
    font-family: 'Lena', Arial, Helvetica, sans-serif; 
    /*font-size: 20px;*/
	font-size: 19px;
    display: flex;
    color: white;
    text-decoration: none;
    line-height: 30px;
    padding: 10px 0;
    margin: 0 0px;
    opacity: .7;
    width: auto;
    background: transparent;
    border: 0;
}
nav > div > ul > li:last-child{ margin-left: 3rem; }
nav > div >ul > li:last-child > a{
    background: white;
    opacity: 1;
    color:#273065;
    font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif; 
    font-weight: 700;
    border-radius: 25px;
    padding: 9px 3rem;
    border: 1px solid white;
    transition: ease-in-out all .1s;
}
nav > div >ul > li:last-child > a:hover{
    background: #273065;
    color:#fff;
    transition: ease-in-out all .1s;
}
nav > div > ul > li > a:hover, 
nav > div > ul > li.current-menu-item > a{
    transition: ease-in-out all 0.1s;
    text-decoration: none;
    color: white;
    opacity: 1;
}
nav > div > ul > li.current-menu-item > a{ /*text-decoration: underline; */ }

nav > div > ul > li.menu-item-has-children > a{
    padding-right: 1.5rem;
}
nav > div > ul > li.menu-item-has-children::after{
    content: " ";
    background: transparent url('gfx/sousmenu.svg') no-repeat 0 0 / contain;
    width: 13px;
    height: 7px;
    position: absolute;
    right: 0;
    top: 20px;
}
nav > div > ul > li ul{
    position: absolute;
    top: 50px;
    left: 0;
    z-index: 5001;
    padding: .5rem 0 .5rem 15%;
    background: rgba(32,37,80,.8);
    border: 0px;
    display: none;
    width: 100%;
}
nav ul li:hover ul{ display: flex; flex-flow: column wrap;  }
nav ul li ul li{
    display: inline-flex;
    width: 100%;
    text-align: left;
    margin: .1rem 0;
}
nav ul li ul li a{
    color: #fff;
    font-size: 18px;
    opacity: .8;
    padding: .25rem 0;
    margin: 0;
    font-family: 'Lena', Arial, Helvetica, sans-serif; 
}
nav ul li ul li a:hover, nav ul li ul li.current-menu-item a{
    opacity: 1;
    color:white;
    text-decoration: none;
}
header .brdwhite{
    border-bottom: 1px solid white;
}
#home .conteneur{
    background: white url('gfx/bandeau-home.jpg') no-repeat left top / 100%;
}
footer{
    background: #273065;
    border-top-right-radius: 92px;
    padding: 110px 0;
}
.menu-footer-container{ display: flex; width: 100%; }
.footer-menu{ width: 100%; display: flex; flex-flow: row wrap; justify-content: space-between; }
.menu-footer-container{ display: flex; width: 100%; }
.footer-menu li a{ 
    color: white;
    font-family: 'Lena', Arial, Helvetica, sans-serif;
    font-size: 20px;
}
.footer-menu li ul{ margin: 1rem 0 0 1rem; }
.footer-menu li ul li{ margin: .25rem 0; }
.footer-menu li ul li a{ opacity: .7; }
.footer-menu li ul li a:hover{ opacity: 1; text-decoration: none; }
footer a#logo{ margin-bottom: 2rem; }
.ligne-sociaux img{ margin-right: 1.5rem; }
.ligne-sociaux{ padding-top: 2rem; position: relative; }
.ligne-sociaux::before{
    content: " ";
    width: 100%;
    height: 1px;
    background: white;
    position: absolute;
    top: 0;
    left: -50%;
}
.btn{
    display: inline-block;
    font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif;
    font-weight: 700;
    border-radius: 25px;
    padding: 9px 3rem;
    border: 1px solid transparent;
    line-height: 30px;
    transition: ease-in-out all .15s;
}
.btn:hover{ text-decoration: none; transition: ease-in-out all .15s; }
.btn.white{
    background: white;
    color: #273065;
    transition: ease-in-out all .15s;
}
.btn.white:hover{
    background: #273065;
    color: #fff;
    border: 1px solid white;
    transition: ease-in-out all .15s;
}
.btn.blue{
    background: #273065;
    color: #fff;
    border: 1px solid white;
    transition: ease-in-out all .15s;
}
.btn.blue:hover{
    background: white;
    color: #273065;
    transition: ease-in-out all .15s;
}
.btn.brd{
    background: white;
    color: #273065;
    border: 1px solid #273065;
    transition: ease-in-out all .15s;
}
.btn.brd:hover{
    background: #273065;
    color: #fff;
    transition: ease-in-out all .15s;
}

footer .btn{ margin-bottom: 1.5rem; }
p.copyright{ text-transform: uppercase; font-size: 14px; margin: 1rem 0; }
.partenaires .span-12.aligncenter{
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: center;
    margin: 0 0 6rem 0;
}
.partenaires .span-12.aligncenter img{ margin: 1rem; max-width: calc( 100% - 2rem ); }
.partenaires h2{
    font-size: 30px;
    margin: 3rem auto;
    text-transform:uppercase;
    font-weight: 500;
    letter-spacing: .05rem;
}
.contact-footer{ margin: 6rem 0; }
.contact-footer .contactimg{
    border-radius: 14px;
}
.econtact{
    position: absolute;
    max-width: max-content;
    left: -85%;
    top: -7rem;
    z-index: 3;
}
.contact-footer h2{
    font-size: 50px;
    line-height: 70px;
    margin: 0 0 3rem 0;
    letter-spacing: .01rem;
}
.wpcf7 input[type="text"], 
.wpcf7 input[type="password"], 
.wpcf7 input[type="email"], 
.wpcf7 input[type="tel"], 
.wpcf7 input[type="number"],
.wpcf7 input[type="date"], 
.wpcf7 select, 
.wpcf7 textarea{
    border: 0px;
    border-bottom: 1px solid #273065;
    padding-left: 0;
    padding-right: 0;
    width: 100%;
    line-height: 56px;
    color:#273065;
    font-size: 20px;
    margin: 0 0 1rem 0;
}
.wpcf7 input[type="text"]::placeholder, 
.wpcf7 input[type="password"]::placeholder, 
.wpcf7 input[type="email"]::placeholder, 
.wpcf7 input[type="tel"]::placeholder, 
.wpcf7 input[type="number"]::placeholder,
.wpcf7 textarea::placeholder{
    color:#273065;
}
.wpcf7 input[type="text"]:focus, 
.wpcf7 input[type="password"]:focus, 
.wpcf7 input[type="email"]:focus, 
.wpcf7 input[type="tel"]:focus, 
.wpcf7 input[type="number"]:focus,
.wpcf7 input[type="date"]:focus, 
.wpcf7 textarea:focus{
    border-color:#B08853;
}
.wpcf7 label{
    border: 0px;
    display: inline-block;
    padding-left: 0;
    line-height: 36px;
    color:#273065;
    font-size: 20px;
    width: 100%;
    margin-top: 20px;
}
.wpcf7-form-control-wrap, .wpcf7 input[type="date"]{ width: 100%; display: inline-block; }
.wpcf7 input[type="submit"]{
    width: max-content;
    display: inline-block;
    font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif;
    font-weight: 700;
    border-radius: 25px;
    padding: 9px 3rem;
    border: 1px solid transparent;
    line-height: 30px;
    transition: ease-in-out all .15s;
    background: #fff;
    color: #273065;
    border: 1px solid #273065;
    margin: 2rem 0 1rem 0;
}
.wpcf7 input[type="submit"]:hover{
    background: #273065;
    color: #fff;
}
.wpcf7-spinner{
    position: absolute;
    bottom: 0;
    left: 0;
}
.wpcf7 span.italique{
    font-size: .8rem;
    width: 100%;
    display: inline-block;
}
.wpcf7 { position: relative; }
/* HOME */
main{ }
.home_contenu .bandeau{ height: 40vw; max-height: 766px; position: relative; }
.home_contenu h1{ font-size: 2.625vw; width: 30%; }
.home_contenu h2{ font-size: 25px; margin: 2rem auto 3rem auto; }
.home_contenu .bandeau::after{ 
    content: " ";
    display: block;
    width: 26.25vw;
    height: 23vw;
    background: transparent url('gfx/e.svg') no-repeat 0 0 / 100%;
    position: absolute;
    z-index: 2;
    bottom: -.5rem;
    right: -.5rem;
}
.photohome1{ margin: -5rem 0 5rem 0; }
.photohome1 img{ border-radius: 16px; }
.home_contenu .lignepro h2{
    font-size: 30px;
}
.home_contenu .lignepro h2 span{
    font-size: 50px;
}
.zonetexte p{
    font-size: 18px; line-height: 28px; letter-spacing: .02rem;
    margin: 0 0 1rem 0;
}
.zonetexte ul li{
    font-size: 18px; line-height: 28px; letter-spacing: .02rem;
}
.zonetexte h2{
    font-size: 50px;
    font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif;
    margin: 0 0 2rem 0;
}
.zonetexte h3{
    font-size: 30px;
    color: #B08853;
    margin: 0 0 1rem 0;
}
.zonetexte h4{
    font-size: 24px;
    margin: 0 0 1rem 0;
}
.home_contenu .lignepro .zonetexte{ margin-top: 4rem; }
.home_contenu .lignepro { margin-bottom: 4rem; }
.lignepop p{
    font-family:'Lena', serif;
    line-height: 42px;
    font-size: 20px;
    margin: 0 0 .5rem 0;
    padding: .5rem 0;
    border-bottom: 1px solid #DEDEDE;
    position: relative;
    cursor: zoom-in;
    width: 100%;
}
.lignepop p span.voirplus{
    color:#B08853;
    float: right;
    font-weight: 600;
}
.lignepop p:hover span.voirplus{
    color: #273065;
}
.lignepop p span.popup{ 
    display: flex;
    flex-flow: column nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    background: transparent url('gfx/popup.svg') no-repeat center / 100%;
    position: absolute; 
    z-index: 10;
    left: 35%;
    top: -4.75rem;
 }
.lignepop p span.popup img{ margin: 1rem 1rem 1rem 3rem; max-width: calc( 100% - 4rem ) }
.lignepop p span.popup .poptxt{
    color: #273065;
    font-size: 18px;
    line-height: 28px;
    letter-spacing: .02rem;
    margin: 1rem 1rem 1rem 3rem;
    font-family: 'Gotham', Helvetica, sans-serif;
    font-weight: 400;
}
.lignepop p span.popup.hidden{ 
    visibility: hidden; 
    opacity: 0; 
    height: 0px; 
    width: 0px; 
    overflow: hidden; 
    transition: opacity ease-in-out .5s;
}
.lignepop p:hover span.voirplus span.popup.hidden{
    visibility: visible; 
    opacity: 1; 
    min-width: 384px;
    min-height: 414px;
    overflow:unset;
    transition: opacity ease-in-out .35s;
}
.ligneperso{ margin: 5rem 0 0 0; }
.home_contenu .ligneperso h2{
    font-size: 30px;
}
.home_contenu .ligneperso h2 span{
    font-size: 50px;
}
.home_contenu .ligneperso{ 
    background: transparent url('gfx/swoosh.svg') no-repeat -50rem -18rem;
}
.home_contenu .ligneperso .zonetexte{ margin-top: 11rem; }
.home_contenu .ligneperso a.btn{ margin: 3rem 0; }
.bggris{ background-color:#F2EDE3; }
.bgblue{ background-color:#273065; }
.home_contenu .bgblue{
    margin: -11rem 0 6rem 0;
    border-radius: 15px;
}
.home_contenu .bggris{ padding: 0 0 5rem 0; }
.bggris.quisommes{ margin: 24rem 0 0 0; }
.home_contenu .bgblue img.rond-bleu{ margin: -6rem auto 0rem auto; }
.home_contenu .bgblue h2{
    margin: 1rem auto 5rem auto;
    font-size: 40px;
    width: 60%;
}
.bggris h2{ font-size: 50px; margin: 0 0 3rem 0; }
.deuxphotos img{ border-radius: 16px; max-width: 97%; position: relative; z-index: 6; }
.deuxphotos .photon2 img{ margin-left: 3%; }
.motscles h3{ font-family:'Lena', serif; font-size: 25px; line-height: 60px; padding: 0 0 0 2rem; border-left: 1px solid #273065; }
.motscles{ margin: 5rem 0 3rem 0; }
.home_contenu .temoignages{
    position: relative;
    margin-bottom: 16rem; 
}
.home_contenu .temoignages > *{ position: relative; z-index: 4;}
.home_contenu .temoignages::before{
    content: " ";
    background: transparent url('gfx/2.svg') no-repeat center / 100%;
    width: 470px;
    height: 590px;
    position: absolute;
    top: -140px;
    right: 0;
    z-index: 1;
}
.home_contenu .temoignages::after{
    content: " ";
    background: transparent url('gfx/swoosh.svg') no-repeat center / 100%;
    width: 1022px;
    height: 580px;
    position: absolute;
    bottom: -380px;
    left: -330px;
    z-index: 2;
    transform: rotate(-55deg);
}
.home_contenu .temoignages h2{ margin: 7rem 0 5rem 0; font-size: 50px; }
.temoignages .temoignage{
    border: 1px solid #273065;
    width: calc(100% - 2px);
    border-radius: 15px;
    background: white;
    align-items: center;
}
.temoignages .temoigage-photo{ width: calc(38% - 4rem); padding: 2.5rem 2rem; }
.temoignages .temoigage-texte{ width: calc(62% - 12rem); padding: 2.5rem 10rem 2.5rem 2rem; }
.temoignages .temoigage-photo img{ display: flex; border-radius: 15px; }
.temoignages .temoigage-texte h3{ font-size: 35px; margin: 0 0 1rem 0; }
.temoignages .temoigage-texte h4{
    font-size: 25px;
    padding: 0 0 2rem 0;
    margin: 0 0 3rem 0;
    position: relative;
    font-weight: 300;
}
.temoignages .temoigage-texte h4::after{
    content: " ";
    display: block;
    background:#273065;
    width: 10rem;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 0;
}
.temoignages .temoigage-texte p.italique{
    font-size: 18px;
    line-height: 28px;
    letter-spacing: .02rem;
    margin: 0 0 1rem 0;
}
.temoignages .temoigage-texte p.bold{ 
    font-size: 25px;
    font-family: 'Lena', serif;
    margin: 2rem 0 0 0;
}
.temoignages .swiper-button-next, 
.temoignages .swiper-button-prev{
    width: 88px;
    height: 88px;
}
.temoignages .swiper-button-next::after, 
.temoignages .swiper-button-prev::after{
    background: transparent url('gfx/fleche.svg') no-repeat center / 100%;
    width: 88px;
    height: 88px;
    overflow: hidden;
    text-indent: -3000px;
}
.temoignages .swiper-button-next::after{ transform: rotate(180deg) }
.temoignages .swiper-button-next{ right: -120px;  }
.temoignages .swiper-button-prev{ left: -120px; }
/* page agence */
#page .bandeau{ 
    padding: 11.5vw 0 0 0;
}
#page .conteneur{
    background: white url('gfx/bandeau-page.jpg') no-repeat left top / 100%;
}
#page .bandeau h1{
    font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif;
    font-size: 50px;
    font-weight: 700;
    padding: 0 0 1.25rem 0;
    margin: 0 0 1.75rem 0;
    position: relative;
}
#page .bandeau h1::after{
    content: " ";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 3rem;
    height: 1px;
    background: white;
}
#page .bandeau p{
    /*font-size: 24px;
    line-height: 42px;*/
	font-size: 22px;
    line-height: 38px;
    max-width: 75%;
}
#page .bandeau img{ border-radius: 15px; }
#page h2{
    font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif;
    font-size: 50px;
    line-height: 54px;
    margin: 0 0 1rem 0;
}
#page h2 span{
    color:#B08853;
    font-family: 'Gotham', Helvetica, sans-serif;
    font-size: 30px;
}
.interlocutrices-titre{ margin: 2rem 0 0 0; }
.interlocutrices{ margin: 2rem 0 3rem 0; }
.interlocutrices img{ max-width: 95%; margin-right: 5%; }
.interlocutrices .zonetexte{ margin: 4rem 0 0 0; }
.interlocutrices .btn{ margin: 1.5rem 0 0 0; }
.interlocutrices h3{ font-size: 30px; margin: 1rem 5% .5rem 0; letter-spacing: .025rem; max-width: 95%; }
.interlocutrices h4{ font-size: 30px; color:#B08853; letter-spacing: .025rem; max-width: 95%; margin-right: 5%; }
#page .agence .bggris{
    margin: 7rem 0 3rem 0;
    padding: 6rem 0 9rem 0;
    position: relative;
}
#page .agence .bggris::before{
    content: " ";
    width: 660px;
    height: 260px;
    position: absolute;
    z-index: 2;
    right: 3%;
    top: -170px;
    background: transparent url(gfx/swoosh.svg) no-repeat center / 100%;
}
#page .bggris.distinctifs h2{ margin-bottom: 6rem; }
#page .bggris.distinctifs h3{
    font-weight: 700;
    font-size: 25px;
    line-height: 100px;
    border-bottom: 1px solid #273065;
    margin: 0 0 2rem 0;
    max-width: 85%;
}
#page .bggris.distinctifs p{ font-size: 18px; line-height: 28px; max-width: 70%; margin:0; letter-spacing: .025rem; }
#page .dessus-faq .bgblue{ border-radius: 15px; position: relative; }
#page .dessus-faq .bgblue img.rond-bleu {
    margin: -6rem auto 0rem auto;
}
#page .dessus-faq{
    padding: 6rem 0 2rem 0;
    background: white url('gfx/2.svg') no-repeat  2rem center / contain;
    margin: 0 0 3rem 0;
}
#page .dessus-faq h2 {
    margin: 1rem auto 5rem auto;
    font-size: 40px;
    width: 60%;
}
#page .faq h2{ margin: 1rem 0 6rem 0; }
#page .faq{ margin: 0 0 6rem 0; }
.tabs{
    background: white;
    padding: 1rem 2.5%;
    border: 1px solid #273065;
    border-radius: 15px;
    margin: 0 0 2rem 0;
    font-size: 18px;
    line-height: 28px;
}
.tabs .tab-reponse{
    height: 0;
    margin: 0;
    overflow: hidden;
    transition: ease-in-out all .3s;
	border:0;
}
.tabs .tab-question{
    cursor: pointer;
    font-weight: 500;
    position: relative;
    width: calc( 100% - 30px );
	border:0;
}
.tabs .tab-reponse.view{ 
    height: auto;
    margin: 1rem 0;
    transition: ease-in-out all .3s;
}
.tabs .tab-question::after{
    position: absolute;
    right: -30px;
    top: 8px;
    content: " ";
    background: transparent url('gfx/fleche-bas.svg') no-repeat center / 100%;
    width: 26px;
    height: 14px;
    transition: ease-in-out all .15s;
}
.tabs .tab-question.open::after{
    transform: rotate(-180deg);
    transition: ease-in-out all .15s;
}
.reverse{ flex-flow: row-reverse wrap; }
#page .prestation .services-titre{ margin: 9rem 0 4rem 0; }
#page .prestation .bloc{ margin: 6rem 0; }
#page .prestation .popservices{ margin: 0 0 3rem 0; }
#page .prestation .bloc h2{ margin-bottom: 3rem; }
#page .prestation .bloc .btn{ margin-top: 3rem; }
#page .prestation .bloc img{ border-radius: 15px; position: relative; z-index: 2; }
#page .prestation .bloc .span-6.relative::after{
    content: " ";
    background: transparent url(gfx/swoosh.svg) no-repeat center / 100%;
    width: 660px;
    height: 250px;
    position: absolute;
    bottom: 100px;
    left: -480px;
    z-index: 1;
    transform: scaleX(-1);
}
#page .prestation .bloc.reverse .span-6.relative::after{
    left: auto;
    transform: none;
    right: -480px;
}

#page .prestation .bggris{
    padding: 6rem 0;
    margin: 3rem 0;
}
#page .prestation .bggris h2{ margin-bottom: 6rem; }
#page .prestation .bggris .comment h3{
    font-size: 25px; 
    line-height: 36px; 
    min-height: 72px;
    font-weight: 500;
    margin: 0 0 2rem 0;
    padding: 1rem 0 2rem;
    border-bottom: 1px solid #273065;
    max-width: 85%;
}
#page .prestation .bggris .comment p{
    font-size: 18px;
    line-height: 28px;
    letter-spacing: .025rem;
    max-width: 70%;
    margin-bottom: 6rem;
}
.row.even{ align-items: stretch; }
#page .prestation .faq{
    padding-top: 6rem;
    position: relative;
}
#page .prestation .faq > *{ position: relative; z-index: 2; }
#page .prestation .faq::before{
    content: " ";
    background: transparent url(gfx/2.svg) no-repeat center / 100%;
    width: 470px;
    height: 590px;
    position: absolute;
    top: -140px;
    left: 1rem;
    z-index: 1;
}
#page .prestation  .temoignages{ position: relative; margin-bottom: 10rem; }
#page .prestation  .temoignages > * {
    position: relative;
    z-index: 4;
}
#page .prestation .temoignages::after {
    content: " ";
    background: transparent url(gfx/swoosh.svg) no-repeat center / 100%;
    width: 1022px;
    height: 580px;
    position: absolute;
    bottom: -380px;
    left: -330px;
    z-index: 2;
    transform: rotate(-55deg);
}
#page .defaut .bandeau h1{ font-weight: 400; }
#page .conteneur.contact{ 
    background: #F2ECE3 url('gfx/e.svg') no-repeat 2% 45% / 55%
}
#page .conteneur.contact header a#logo{
    background: transparent url(gfx/logo-bleu.svg) no-repeat center center / contain;
}
#page .conteneur.contact nav > div > ul > li > a{ color :#273065; }
#page .conteneur.contact nav > div > ul > li:last-child a:hover{ color: white; }
#page .conteneur.contact header .brdwhite{ border-color :#273065; }
#page .conteneur.contact .wpcf7{
    background: white;
    padding: 3rem 15%;
    border-radius: 15px;
    position: relative;
}
#page .conteneur.contact article{
    padding: 3rem 0;
}
#page .conteneur.contact h1{
    font-size: 50px;
    margin: 4rem 0 1em 0;
    font-family: 'Bon Vivant Serif', 'Times New Roman', Times, serif;
}
.zonetexte p.tel-contact, .zonetexte p.mail-contact{
    font-weight: 500;
    padding-left: 4rem;
    line-height: 32px;
    margin: 0 0 1rem 0;
}
.zonetexte p.tel-contact{ background: transparent url('gfx/tel.svg') no-repeat left center / contain; margin-top: 5rem; }
.zonetexte p.mail-contact{ background: transparent url('gfx/email.svg') no-repeat left center / 2.5rem; }





/**/
@media (min-width: 2px) and (max-width: 1023px){
    header{ height: 110px; }
    header .span-2{ width: 70%; }
    header .span-8{ width: 30%; }
    a#logo, #page .conteneur.contact header a#logo{ background-size: 75%; }
    .menu-menu-principal-container{ margin: 0; }
    .menu-toggle{
        width: 100%;
        padding: 0;
        background: transparent;
        color: #fff;
        border:0;
        display: block;
        font-size: 4rem;
        font-weight: 300;
        line-height: 4rem;
        text-align: center;
    }
    #page .conteneur.contact header .menu-toggle{ color:#212856; }
   .menu-toggle:active, .menu-toggle:focus, .menu-toggle:hover{
        text-decoration: none;
    }
    .nav-menu{ 
        display: none; 
        padding: 1rem 0 2rem 0; 
        margin:0; 
        z-index: 10001; 
        width: 333%;
        position: absolute;
        right: 0;
        top: 16px;
        background-color:#212856;
        border-radius: 10px;
     }
    .nav-menu.toggled-on{ display: flex; }
    nav > div > 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 > div > ul > li{
        flex-flow: column wrap;
        width: calc(100% - 4rem);
    }
    nav > div > ul > li > a, #page .conteneur.contact nav > div > ul > li > a{
        font-size: 22px;
        width: calc(100% - 1.5rem);
        color: white;
    }
    nav > div > ul > li ul{
        position: relative;
        top: auto;
        left: auto;
        padding: .5rem 0 1rem 0;
    }
    nav > div >ul > li:last-child > a, 
    #page .conteneur.contact nav > div > ul > li:last-child > a{ width: auto; color: #273065; }
    nav > div > ul > li:last-child { margin-left: 2rem; margin-top: .5rem; }
    nav ul li ul li a{ font-size: 20px; }

    .home_contenu h1{ font-size: 1.5rem; width: 80%; margin: 1.5rem 0 0 0; }
    .home_contenu .bandeau{ height: auto; }
    #home .conteneur{ background-size: 275%; background-position: right top; }
    .home_contenu h2 { font-size: 20px; }
    .home_contenu .bandeau .btn{ margin-bottom: 5rem; }
    .home_contenu .bandeau::after {
        width: 40.25vw;
        height: 36vw;
        bottom: -2.5rem;
    }
    .photohome1{ margin-top: -2rem; }
    .row.lignepro, 
    .row.photohome1, 
    .row.lignepop, 
    .row.ligneperso{
        width: 80%;
        padding: 0 10%;
    }
    .home_contenu .lignepro h2,.home_contenu  .ligneperso h2{ font-size: 20px; text-align: center; }
    .home_contenu .lignepro h2 span,.home_contenu  .ligneperso h2 span{ font-size: 30px; }
    .zonetexte p{ font-size: 14px; line-height: 22px; }
    .home_contenu .lignepro .zonetexte, 
    .home_contenu .ligneperso .zonetexte { margin-top: 2rem; }
    .lignepop p{ display: flex; flex-flow: column wrap; font-size: 22px; line-height: 32px; }
    .lignepop p span.popup{
        position: relative;
        left: auto;
        top: auto;
        min-width: 100%;
    }
    .lignepop p:hover span.voirplus span.popup.hidden{ 
        min-width: 100%; 
        max-width: 100%; 
        background: white;
        border: 1px solid #242b59;
        border-radius: 10px;
    }
    .lignepop p span.popup img {
        margin: 1rem 1rem 1rem 1rem;
        max-width: calc(100% - 2rem);
    }
    .lignepop p span.popup .poptxt {
        font-size: 16px;
        line-height: 24px;
        margin: 1rem 1rem 1rem 1rem;
        text-align: left;
    }
    .ligneperso { margin: 2rem 0 0 0; }
    .lignepop p span.voirplus{ text-align: right; }
    .home_contenu .ligneperso{ 
        background-position: 70% -9rem;
        background-size: 200%;
    }
    .row.lignepop.popperso{ width: 100%; padding: 3rem 0 0 0; }
    .home_contenu .ligneperso a.btn{ font-size: 22px; }
    .btn{ padding: 9px 2rem; }
    .bggris.quisommes { margin: 18rem 0 0 0; padding: 0 10%; width: 80%; }
    .home_contenu .bgblue img.rond-bleu { width: 50%; }
    .home_contenu .bgblue h2 {
        margin: 0 auto 3rem auto;
        font-size: 22px;
        width: 80%;
    }
    .home_contenu .bgblue { margin: -9rem 0 3rem 0; }
    .motscles h3 {
        font-size: 20px;
        line-height: 50px;
    }
    .motscles { margin: 3rem 0 2rem 0; }
    .home_contenu .deuxphotos{ margin-top: 2rem; }
    .home_contenu .temoignages h2 {
        margin: 5rem 0 3rem 0;
        font-size: 30px;
    }
    .temoignages .temoignage{ flex-flow: column wrap; }
    .temoignages .temoigage-photo{ width: calc(100% - 4rem); padding: 2.5rem 2rem; }
    .temoignages .temoigage-texte{ padding: 0 2rem 2.5rem 2rem; width: calc(100% - 4rem); }
    .temoignages .temoigage-texte h3 { font-size: 24px; margin: 0 0 1rem 0; }
    .temoignages .temoigage-texte h4{ font-size: 18px; }
    .temoignages .temoigage-texte p.italique { font-size: 14px; line-height: 20px; }
    .temoignages .temoigage-texte p.bold { font-size: 20px; }
    .home_contenu .temoignages::after{ width: 150%; bottom: -10rem; left: 0; }
    .home_contenu .temoignages { margin-bottom: 8rem; }
    .contact-footer{ width: 80%; padding: 0 10%; }
    .contact-footer h2 {
        font-size: 20px;
        line-height: 32px;
        margin: 2rem 0;
        text-align: center;
    }
    .wpcf7 input[type="text"], .wpcf7 input[type="password"], 
    .wpcf7 input[type="email"], .wpcf7 input[type="tel"], 
    .wpcf7 input[type="number"], .wpcf7 input[type="date"], 
    .wpcf7 select, .wpcf7 textarea{
        line-height: 36px;
        font-size: 16px;
    }
    .wpcf7 label{ line-height: 26px; font-size: 16px; }
    .contact-footer { margin: 3rem 0; }
    .partenaires.row{ width: 80%; padding: 0 10%; }
    .partenaires h2 { font-size: 20px; margin: 2rem auto; }
    .partenaires .span-12.aligncenter{ flex-flow: column wrap; margin-bottom: 3rem; }
    .partenaires .span-12.aligncenter img { margin: .5rem 1rem; max-width: calc(100% - 2rem); }
    footer.row { border-top-right-radius: 62px; padding: 30px 10%; width: 80%; }
    .footer-menu{ display: none; }
    footer .btn{ margin: 1.5rem 0 0 0; }
    p.copyright{ width: 80%; margin: 1rem 10%; font-size: 10px; }
    .ligne-sociaux img{ width: 34px; }
    #page .conteneur{ background-size: 320%; background-position: right top; }
    #page .bandeau h1{ font-size: 30px; }
    #page .bandeau{ width: 80%; padding: 2rem 10% 0 10%; }
    #page .bandeau p{ max-width: 100%; font-size: 14px; line-height: 22px; margin-bottom: 1rem; }
    .interlocutrices-titre{ width: 80%; padding: 0 10% 0 10%; }
    .interlocutrices img{ width: 80%; margin: 0 10% 0 10%; }
    #page h2 span{ font-size: 20px; line-height: 30px; }
    #page h2 { font-size: 32px; line-height: 44px; }
    .interlocutrices { margin: 0; }
    .interlocutrices h3 {
        font-size: 20px;
        margin: .5rem 0;
        max-width: 100%;
    }
    .interlocutrices h4 {
        font-size: 18px;
        max-width: 100%;
        margin: 0 0 1rem 0;
    }
    .interlocutrices .zonetexte {
        margin: 2rem 0 0 0;
        width: 80%;
        padding: 0 10%;
    }
    #page .agence .bggris{
        width: 80%;
        padding: 6rem 10% 9rem 10%;
    }
    #page .bggris.distinctifs h2 { margin-bottom: 3rem; }
    #page .bggris.distinctifs h3 {
        font-size: 20px;
        line-height: 80px;
        max-width: 100%;
        text-align: center;
    }
    #page .bggris.distinctifs p {
        font-size: 14px;
        line-height: 20px;
        max-width: 100%;
    }
    #page .dessus-faq{ padding-top: 0; }
    #page .dessus-faq .bgblue img.rond-bleu{ width: 50%; }
    #page .dessus-faq h2 {
        margin: 1rem auto 3rem auto;
        font-size: 26px;
        line-height: 36px;
        width: 80%;
    }
    #page .faq{ width: 80%; padding: 0 10%; margin-bottom: 3rem; }
    #page .faq h2{ margin-bottom: 3rem; }
    .tabs .tab-question, .tabs .tab-reponse{ font-size: 14px; line-height: 22px; }
    .tabs {
        padding: 1rem 5%;
        margin: 0 0 1rem 0;
        font-size: 14px;
        line-height: 22px;
    }
    .tabs .tab-reponse{ padding: 0; }
    #page .contact-footer h2{ margin-top: 2rem; font-size: 28px; line-height: 34px;}
    #page .partenaires h2{ font-size: 26px; line-height: 34px; }
    #page .prestation .services-titre{ width: 80%; padding: 0 10%; margin: 3rem 0 2rem 0; }
    #page .prestation .bggris {
        padding: 2rem 10%;
        margin: 3rem 0;
        width: 80%;
        border-radius: 10px;
    }
    #page .prestation .bggris h2{ margin-bottom: 2rem; }
    #page .prestation .bggris h2 span{ font-size: 16px; }
    #page .prestation .bggris .comment h3 {
        font-size: 20px;
        line-height: 30px;
        min-height: 42px;
        margin: 0 0 2rem 0;
        padding: 1rem 0 1rem;
        max-width: 100%;
    }
    #page .prestation .bggris .comment p {
        font-size: 16px;
        line-height: 24px;
        max-width: 100%;
        margin-bottom: 2rem;
    }
    #page .prestation .faq {
        padding-top: 3rem;
    }
    #page .prestation .temoignages::after{ width: 210%; left: -60%; }
    #page .prestation .bloc{ width: 80%; padding: 0 10%; }
    .zonetexte h3{ font-size: 22px; margin-top: 1rem; }
    #page .conteneur.contact article{ padding: 3rem 10% 0 10%; width: 80%; }
    #page .conteneur.contact h1{ margin: 1rem 0; font-size: 30px; }
    .zonetexte p.tel-contact{ margin-top: 2rem; }
    #page .conteneur.contact .wpcf7{ padding: 2rem 5%; margin-bottom: 3rem; }
    .conteneur.defaut .zonetexte{ width: 80%; padding: 0 10%; margin: 3rem 0; }
    .econtact {
        left: 25%;
        top: -8rem;
        width: 50%;
    }




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

    a#logo, #page .conteneur.contact header a#logo { background-size: 45%; }
    #home .conteneur{ background-size: 100%; }
    nav > div >ul > li:last-child > a, 
    #page .conteneur.contact nav > div > ul > li:last-child > a {
        width: 30%;
    }
    .home_contenu .bandeau::after {
        width: 25.25vw;
        height: 36vw;
        bottom: -4.5rem;
    }
    .row.lignepro, .row.photohome1, .row.lignepop, .row.ligneperso, 
    .bggris.quisommes, .partenaires.row{
        width: 100%;
        padding: 0;
    }
    .home_contenu .ligneperso {
        background-position: 0 21rem;
        background-size: 100%;
    } 
    .econtact{ width: 10rem; left: 0; top: -9rem;}
    .partenaires .span-12.aligncenter{ flex-flow: row wrap; }
    footer.row {
        border-top-right-radius: 62px;
        padding: 30px 0;
        width: 100%;
    }
    footer a#logo{ background-size: 100%; }
    .footer-menu{ display: flex; flex-flow: column wrap; }
    #page .bandeau{ width: 100%; padding: 2rem 0 0 0; min-height: 20rem; }
    #page .conteneur {
        background-size: 150%;
        background-position: right top;
    }
    .interlocutrices-titre, #page .agence .bggris{ width: 100%; padding: 0; }
    .interlocutrices .zonetexte{ width: 35.714%; padding: 0; margin: 0; }
    #page .agence .bggris::before{ top: -240px; }
    #page .bggris.distinctifs h3 {
        font-size: 20px;
        line-height: 40px;
    }
    #page .bggris.distinctifs p{ max-width: 90%; margin-bottom: 3rem; }
    #page .bggris.distinctifs h2{ margin-top: 2rem; }
    #page .dessus-faq .bgblue img.rond-bleu{ width: auto; }
    #page .faq, .contact-footer{ width: 100%; padding: 0 0; }
    .econtact {
        width: 10rem;
        left: -4rem;
        top: -5rem;
    }
    #page .prestation .services-titre{ width: 100%; padding: 0 0; }
    #page .prestation .bggris{ width: 100%; padding: 2rem 0; }
    #page .prestation .bggris .comment h3, 
    #page .prestation .bggris .comment p{ max-width: 90%; }
    #page .prestation .temoignages::after{
        width: 1022px;
        left: -330px;
    }
    #page .conteneur.contact article {
        padding: 3rem 0 0 0;
        width: 100%;
    }
    #page .prestation .bloc{
        padding: 0 0;
        width: 100%;
        margin: 3rem 0;
    }






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

    header{ height: 100px; }
    nav > div >ul > li:last-child > a{ padding: 10px 1.5rem; }
    nav > div > ul > li > a{ font-size: 13px; line-height: 20px; }
    nav > div > ul > li{ margin: 0 0 0 1rem; }
    nav > div > ul > li:last-child{ margin-left: 1.5rem; }
    .menu-menu-principal-container{ margin-top: 1rem; }
    nav > div > ul > li ul { top: 40px; }
    nav ul li ul li a { font-size: 13px; }
    .econtact{ width: 8rem; top: -4rem; }
    .contact-footer h2 {
        font-size: 34px;
        line-height: 44px;
        margin: 0 0 2rem 0;
    }
    .wpcf7 input[type="text"], 
    .wpcf7 input[type="password"], 
    .wpcf7 input[type="email"], 
    .wpcf7 input[type="tel"], 
    .wpcf7 input[type="number"], 
    .wpcf7 input[type="date"], 
    .wpcf7 select, 
    .wpcf7 textarea {
        line-height: 30px;
        font-size: 14px;
    }
    .wpcf7 label {
        line-height: 26px;
        font-size: 12px;
    }
    .wpcf7 input[type="submit"] {
        padding: 9px 2rem;
        line-height: 20px;
        margin: 1rem 0 1rem 0;
        font-size: 16px;
    }
    .partenaires h2 { font-size: 20px; margin: 2rem auto; }
    .partenaires .span-12.aligncenter{ margin-bottom: 4rem; }
    .contact-footer { margin: 3rem 0; }
    .btn{ font-size: 12px; padding: 9px 1rem; line-height: 20px; }
    .footer-menu li a{ font-size: 12px; }
    footer { padding: 70px 0; }
    .ligne-sociaux img{ max-width: 2rem; }
    p.copyright { font-size: 10px; }
    .home_contenu .bandeau{ height: 37vw; }
    .photohome1 {  margin: -3rem 0 3rem 0; }
    .home_contenu h2 {
        font-size: 17px;
        margin: 1rem auto 2rem auto;
    }
    .home_contenu .lignepro h2, .home_contenu .ligneperso h2 { font-size: 18px; }
    .home_contenu .lignepro h2 span, .home_contenu .ligneperso h2 span { font-size: 30px; }
    .zonetexte p , .zonetexte ul li{
        font-size: 12px;
        line-height: 22px;
    }
    .zonetexte h2{ font-size: 30px;}
    .zonetexte h3{ font-size: 18px; }
    .home_contenu .lignepro .zonetexte {  margin-top: 1rem; }
    .lignepop p{ font-size: 14px; }
    .lignepop p span.popup .poptxt {
        font-size: 12px;
        line-height: 22px;
    }
    .lignepop p:hover span.voirplus span.popup.hidden {
        min-width: 324px;
        min-height: 354px;
    }
    .home_contenu .ligneperso .zonetexte { margin-top: 7rem; }
    .home_contenu .ligneperso{ background-size: 60%; background-position: -18rem 2rem; }
    .bggris.quisommes {  margin: 16rem 0 0 0; }
    .home_contenu .bgblue img.rond-bleu {
        margin: -4rem auto 0rem auto;
        max-width: 25%;
    }
    .home_contenu .bgblue h2{ font-size: 24px; }
    .bggris h2{ font-size: 30px; }
    .motscles h3 { font-size: 16px; line-height: 40px; }
    .motscles { margin: 3rem 0 2rem 0; }
    .home_contenu .temoignages h2 { margin: 5rem 0 3rem 0; font-size: 30px; }
    .temoignages .temoigage-texte h3 { font-size: 20px; }
    .temoignages .temoigage-texte h4 {
        font-size: 14px;
        padding: 0 0 1rem 0;
        margin: 0 0 2rem 0;
    }
    .temoignages .temoigage-texte p.italique{
        font-size: 12px;
        line-height: 22px;
    }
    .temoignages .temoigage-texte {
        width: calc(62% - 6rem);
        padding: 2.5rem 4rem 2.5rem 2rem;
    }
    .temoignages .temoigage-texte p.bold {
        font-size: 14px;
        margin: 1rem 0 0 0;
    }
    .home_contenu .temoignages { margin-bottom: 12rem; }
    .home_contenu .temoignages::after{ left: -470px; }
    .home_contenu .temoignages::before{ top: -270px; }
    #page .bandeau h1{ font-size: 30px; }
    #page .bandeau p { font-size: 14px; line-height: 22px; }
    #page .bandeau { padding: 7.5vw 0 0 0; }
    #page h2 { font-size: 30px; line-height: 34px; }
    #page h2 span{ font-size: 20px; }
    .interlocutrices-titre {  margin: 1rem 0 0 0; }
    .interlocutrices h3 { font-size: 16px; }
    .interlocutrices h4 { font-size: 16px; }
    .interlocutrices .zonetexte { margin: 1rem 0 0 0; } 
    #page .agence .bggris::before {
        width: 460px;
        height: 190px;
        top: -130px;
    }
    #page .agence .bggris { margin: 5rem 0 3rem 0; padding: 4rem 0 6rem 0; }
    #page .bggris.distinctifs h3 { font-size: 16px; line-height: 60px; }
    #page .bggris.distinctifs p { font-size: 12px; line-height: 22px; }
    #page .bggris.distinctifs h2 { margin-bottom: 4rem; }
    #page .dessus-faq .bgblue img.rond-bleu{ max-width: 25%; margin: -4rem auto 0rem auto; }
    #page .dessus-faq h2 {  margin: 0 auto 3rem auto; font-size: 20px; }
    #page .dessus-faq { padding: 4rem 0 1rem 0; }
    #page .faq h2 { margin: 1rem 0 4rem 0; }
    .tabs{ font-size: 12px; line-height: 22px; }
    #page .prestation .services-titre { margin: 5rem 0 2rem 0; }
    #page .prestation .bloc h2 { margin-bottom: 1rem; }
    #page .prestation .bloc .btn { margin-top: 1rem; }
    #page .prestation .bloc {  margin: 3rem 0; }
    #page .prestation .bloc .span-6.relative::after{ bottom: 0; }
    #page .prestation .bggris { padding: 3rem 0; margin: 1rem 0; }
    #page .prestation .bggris .comment h3 {
        font-size: 14px;
        line-height: 26px;
        min-height: 52px;
    }
    #page .prestation .bggris .comment p {
        font-size: 12px;
        line-height: 22px;
        margin-bottom: 3rem;
    }
    #page .prestation .faq { padding-top: 3rem; margin-bottom: 3rem; }
    #page .prestation .faq::before {
        width: 330px;
        height: 440px;
        top: -80px;
    }
    #page .prestation .temoignages::after{ left: -450px; }
    #page .prestation .bggris h2{ margin-bottom: 3rem; }
    #page .conteneur.contact h1 {
        font-size: 30px;
        margin: 2rem 0 1em 0;
    }
    .zonetexte p.tel-contact{ margin-top: 3rem; }
    #page .conteneur.contact {
        background: #F2ECE3 url(gfx/e.svg) no-repeat 2% 55% / 55%;
    }





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

    header{ height: 110px; }
    nav > div >ul > li:last-child > a{ padding: 10px 1.5rem; }
    nav > div > ul > li > a{ font-size: 16px; line-height: 20px; }
    nav > div > ul > li{ margin: 0 0 0 1rem; }
    nav > div > ul > li:last-child{ margin-left: 1.5rem; }
    .menu-menu-principal-container{ margin-top: 1rem; }
    nav > div > ul > li ul { top: 40px; }
    nav ul li ul li a { font-size: 14px; }
    .econtact{ width: 10rem; top: -5rem; }
    .contact-footer h2 {
        font-size: 38px;
        line-height: 48px;
        margin: 0 0 2rem 0;
    }
    .wpcf7 input[type="text"], 
    .wpcf7 input[type="password"], 
    .wpcf7 input[type="email"], 
    .wpcf7 input[type="tel"], 
    .wpcf7 input[type="number"], 
    .wpcf7 input[type="date"], 
    .wpcf7 select, 
    .wpcf7 textarea {
        line-height: 30px;
        font-size: 16px;
    }
    .wpcf7 label {
        line-height: 26px;
        font-size: 14px;
    }
    .wpcf7 input[type="submit"] {
        padding: 9px 2rem;
        line-height: 20px;
        margin: 1rem 0 1rem 0;
        font-size: 16px;
    }
    .partenaires h2 { font-size: 24px; margin: 2rem auto; }
    .partenaires .span-12.aligncenter{ margin-bottom: 4rem; }
    .contact-footer { margin: 3rem 0; }
    .btn{ font-size: 14px; padding: 9px 1.5rem; line-height: 24px; }
    .footer-menu li a{ font-size: 14px; }
    footer { padding: 70px 0; }
    .ligne-sociaux img{ max-width: 2rem; }
    p.copyright { font-size: 10px; }
    .home_contenu h2 { font-size: 18px; }
    .home_contenu .bandeau { height: 38vw; }
    .photohome1 { margin: -4rem 0 4rem 0; }
    .home_contenu .lignepro h2, .home_contenu .ligneperso h2 { font-size: 22px; }
    .home_contenu .lignepro h2 span, .home_contenu .ligneperso h2 span { font-size: 38px; }
    .zonetexte p, .zonetexte ul li {
        font-size: 14px;
        line-height: 26px;
    }
    .zonetexte h2{ font-size: 38px;}
    .zonetexte h3{ font-size: 22px; }
    .home_contenu .lignepro .zonetexte {  margin-top: 1.5rem; }
    .lignepop p span.popup .poptxt {
        font-size: 14px;
        line-height: 26px;
    }
    .home_contenu .ligneperso{ background-size: 60%; background-position: -18rem 2rem; }
    .home_contenu .bgblue h2{ font-size: 30px; }
    .bggris.quisommes {
        margin: 18rem 0 0 0;
    }
    .bggris h2 {
        font-size: 38px;
    }
    .motscles h3 {
        font-size: 18px;
        line-height: 50px;
    }
    .home_contenu .temoignages h2 {
        margin: 5rem 0 4rem 0;
        font-size: 38px;
    }
    .home_contenu .temoignages::before{ top: -290px; }
    .temoignages .temoigage-texte h3 {
        font-size: 26px;
    } 
    .temoignages .temoigage-texte h4 {
        font-size: 22px;
    }
    .temoignages .temoigage-texte p.italique{
        font-size: 14px; line-height: 26px;
    }
    .temoignages .temoigage-texte p.bold {  font-size: 18px; }
    .temoignages .temoigage-texte {
        width: calc(62% - 8rem);
        padding: 2.5rem 6rem 2.5rem 2rem;
    }
    #page .bandeau h1 { font-size: 36px; }
    #page h2 { font-size: 36px; line-height: 40px; }
    #page .bandeau p { font-size: 16px; line-height: 30px; }
    #page .bandeau { padding: 5.5vw 0 0 0; }
    #page h2 span { font-size: 24px; }
    .interlocutrices h3, .interlocutrices h4 { font-size: 22px; }
    #page .bggris.distinctifs h3 { font-size: 20px; line-height: 80px; }
    #page .bggris.distinctifs p, .tabs{
        font-size: 14px;
        line-height: 26px;
    }
    #page .dessus-faq h2 { font-size: 26px; }
    #page .prestation .services-titre { margin: 7rem 0 3rem 0; }
    #page .prestation .bloc { margin: 4rem 0; }
    #page .prestation .bloc .span-6.relative::after{ bottom: 40px; }
    #page .prestation .bloc h2 { margin-bottom: 2rem; }
    #page .prestation .bloc .btn { margin-top: 2rem; }
    #page .prestation .bggris .comment h3 { font-size: 18px; line-height: 28px;  min-height: 56px; }
    #page .prestation .bggris .comment p {
        font-size: 14px;
        line-height: 26px;
    }
    #page .prestation .bggris { padding: 4rem 0; }
    #page .prestation .faq { padding-top: 4rem; }
    #page .prestation .temoignages::after{ left: -430px; }
    #page .conteneur.contact h1 {
        font-size: 40px;
        margin: 3rem 0 1em 0;
    }
    .zonetexte p.tel-contact{ margin-top: 4rem; }






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

    nav > div > ul > li > a{ font-size: 17px; padding: 10px 0; }
    nav ul li ul li a { font-size: 16px; }
    .econtact{ width: 12rem; top: -6rem; }
    .btn{ padding: 9px 2rem; font-size: 16px; }
    .footer-menu li a{ font-size: 18px; }
    .home_contenu .ligneperso{ background-size: 60%; background-position: -18rem 2rem; }
    #page .bandeau p {
        font-size: 20px;
        line-height: 32px;
    }
	#page .bandeau { padding: 5.5vw 0 0 0; }
    
}
/**/
@media (min-width: 1600px) and (max-width: 1799px){
    .home_contenu .ligneperso{ background-size: 60%; background-position: -18rem 2rem; }
	#page .bandeau { padding: 6.5vw 0 0 0; }
}
/**/
@media (min-width: 1800px){

}
/**/
@media (min-width: 1900px){
    .home_contenu h1{ font-size: 50px;  }
    .home_contenu .bandeau::after{  width: 500px; height: 440px; }
    #page .bandeau{ padding: 13.75rem 0 0 0; }

}
/**/


/*COOKIES */
body #cookie-notice{
    height: 100%;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: rgba(0,0,0,0.4)!important;
}
.cookie-notice-container{
	width: 50%;
    margin: 10% 25% 0 25%;
    background: #fff url(gfx/logo-bleu.svg) no-repeat center 25% / 50%;
    border: 1px solid #273065;
    padding: 220px 5% 20px 5%;
}
@media (max-width: 1024px){
    .cookie-notice-container{
        width: 70%;
        margin: 2% 15% 0;
    }
}
@media (max-width: 767px){
    .cookie-notice-container{
        width: 90%;
        margin: 2% 5% 0 5%;
    }
}
#cn-notice-text{ font-size: 1.2em; line-height: 1.6em; float: left; width: 100%; text-align: center; margin-bottom: 1em; color: black!important; }
#cn-notice-text a{ color: black!important; text-decoration: underline; }
#cn-notice-buttons{ width: 100%; }
#cookie-notice .cn-button{
	width: max-content!important;
    transform: none!important;
    display: inline-block!important;
    margin-top: 0px!important;
    font-size: 1.2em!important;
    background:#273065!important;
    color: #fff!important;
    border: 1px solid #273065!important;
    text-shadow: none!important;
    border-radius: 0px!important;
    padding: 8px 28px!important;
    transition: ease-in-out all .1s;
}
#cookie-notice .cn-button:hover{
    background: white!important;
    color: #273065!important;
    border-color: #273065!important;
    transition: ease-in-out all .1s;
}
#cookie-notice #cn-refuse-cookie.cn-button, #cookie-notice #cn-more-info.cn-button{
  background: white!important;
  border: 1px solid #bbb!important;
  color:#bbb!important;
}
#cookie-notice #cn-refuse-cookie.cn-button:hover, #cookie-notice #cn-more-info.cn-button:hover{
  background: white!important;
  border: 1px solid #000!important;
  color:#000!important;
}
 #cookie-notice #cn-more-info.cn-button{ display: block!important; margin: 1rem auto!important; max-width: 270px; }
.cookie-notice-hidden{ display:none!important; }

#revocation{
    position: fixed;
    right: 0;
    bottom: 0;
    width: 50%;
    max-width: 240px;
    height: 28px;
    z-index: 10003;
    opacity: 1;
}
#in-revocation{
    width: 99%;
    height: 26px;
    margin: 1px 0.5%;
}
#in-revocation .cn-button{
    border-color: #e2003b; background: #e2003b; color:#fff; border-radius: 0;
    padding: 0;
    height: 26px;
    font-size: 0.7em;
    line-height: 26px;
    display: block;
}
#in-revocation .cn-button:hover{
    background:#fff!important; color: #e2003b!important; box-shadow: none;
}
#cn-close-notice{ display: none; }