@import url('https://fonts.googleapis.com/css?family=Barlow:400,500,600,700,800,900&display=swap');
@import url('https://fonts.googleapis.com/css?family=Audiowide&display=swap');

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section,
main {
    display: block
}

html {
    scroll-behavior: smooth;
}

body {
    color: #333;
    font-family: 'Barlow', sans-serif;
    margin: 0;
    padding: 0;
    font-size: 17px;
    line-height: 1.5;
    text-align: justify;
    overflow-x: hidden !important;
    position: relative;
}

a img {
    border: 0
}

a {
    color: #000
}

a:hover {
    text-decoration: none;
    color: #3c9fe6;
}

#popup {
    padding: 0 10px
}

.mce-content-body {
    background: #fff
}

.hack {
    /height: 120px !important
}

.hidden {
    display: none !important
}

.clear {
    clear: both
}

.error {
    border: 1px solid #DF7B7B;
    background-color: #FFE6E6
}

.conf {
    border: 1px solid #72CB67;
    background-color: #DFFAD3
}

.conf,
.error {
    color: #383838;
    font-weight: 700;
    margin: 0 0 2%;
    line-height: auto;
    padding: 2% 3%
}

#cms2 #img-header-1 {
    display: block
}

#cms4 #img-header-2 {
    display: block
}

#cms8 #img-header-3 {
    display: block
}

#cms3 #img-header-4,
#cms7 #img-header-4,
#cms5 #img-header-4 {
    display: block
}

#img-header-1 {
    display: none
}

#img-header-2 {
    display: none
}

#img-header-3 {
    display: none
}

#img-header-4 {
    display: none
}

.row {
    margin: 0 !important
}

.headerTop {
    background: url(../img/top-bar.jpg)center no-repeat;
    background-size: cover;
    padding: 0
}

#cms1 div#kameleon {
    padding-bottom: 70px;
}

.footer-container-bottom {
    float: left;
    width: 100%;
    height: auto;
    background: #171717;
}

div#incomm {
    color: #fff;
    font-size: 14px;
    font-weight: 600
}

.fixed {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
    background: #fff5f5
}

.fixed a#home {
    padding: 15px 0 !important;
    transition: 1s all cubic-bezier(0.68, -0.55, 0.27, 1.55)
}

ul.header-ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
    display: flex;
    justify-content: center;
    flex-direction: row
}

ul.header-ul a {}

.phone {
    display: flex
}

.header-icon {
    color: #fff;
    background: #6a3315;
    padding: 0 6px;
    padding-right: 0;
    line-height: 48px;
    font-size: 25px
}

.header-icon i {
    transform: rotate(45deg)
}

.map-bg {
    float: left;
    width: 100%;
    background: url(../img/map.jpg)center no-repeat;
    background-size: cover;
    height: 100%;
    min-height: 260px;
}

#loader {
    position: fixed;
    background: #dac9be;
    background: linear-gradient(90deg, rgba(218, 201, 190, 1) 0%, rgba(210, 167, 182, 1) 100%);
    width: 100%;
    height: 100%;
    z-index: 1.0E+40
}

.preloader {
    width: 280px;
    height: 90px;
    position: absolute;
    display: block;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 150px;
    animation: bounce 1.2s ease infinite;
    transform: scale(0.8)
}

@keyframes bounce {
    0% {
        transform: scale(0.7)
    }

    100% {
        transform: scale(1)
    }
}

.f-left {
    float: left;
    width: 100%
}

.f-horaire {
    padding: 30px 0;
    background: #d0edf7
}

a.header-tel {
    display: table-cell;
    vertical-align: middle;
    background: #f1d7de;
    color: #de0040;
    font-family: 'Barlow', sans-serif;
    font-size: 18px;
    padding: 0 20px;
    padding-top: 10px;
    font-weight: 500;
    transition: .3s all ease-in-out
}

a.header-tel:hover {
    background: #b6e3f2;
    color: #4a1d23
}

.add-d {
    display: flex
}

a#h-tel {
    color: #fff;
    background: transparent
}

a#h-adrs {
    color: #fff;
    background: transparent
}

.add-d2 a {
    font-weight: 500;
    color: #fff;
    position: relative;
    background: #010080;
    padding: 5px 20px;
    border-radius: 3px;
}

.add-d1 {
    color: #c41811;
    padding: 0;
    padding-top: 5px;
    margin-right: 10px;
}

.add-d1 i {
    position: relative;
    top: 0
}

.header-cords {
    padding: 5px 0;
}

.logo-section {
    width: 100%;
    display: block;
    background: url(../img/logo-bg.jpg)center no-repeat
}

.menu-bg {
    position: absolute;
    z-index: 999;
    width: 100%
}

div#bg-menu {
    background: #e5b8ba
}

.headerBottom {
    width: 100%;
    padding: 0;
}

.f-l {
    padding-top: 10px;
    -webkit-box-shadow: -1px -9px 15px -8px rgba(0, 0, 0, 0.26);
    -moz-box-shadow: -1px -9px 15px -8px rgba(0, 0, 0, 0.26);
    box-shadow: -1px -9px 15px -8px rgba(0, 0, 0, 0.10);
    background: #515347
}

.footer-right {
    min-height: 100%;
    padding: 30px 0;
    padding-bottom: 60px;
    background: #fff;
    background-size: cover;
}

.f-l img {
    padding-bottom: 10px
}

a#fb-h {
    padding: 3px 10px;
    border-radius: 5px;
    display: block
}

a#in-h {
    padding: 3px 8px
}

a#fb-h i {
    position: relative;
    top: 0
}

a#in-h i {
    position: relative;
    top: 2px
}

.fb-f {
    /* background: #fff; */
    /* margin: 0 3px; */
}

.in-f {
    /* background: #fff; */
    margin: 0 3px;
}

span.f-sp0 {
    font-family: 'Oswald', sans-serif;
    font-weight: 900;
    color: #fff;
    font-size: 40px
}

span.f-sp1 {
    font-weight: 300
}

.first-bg {}

a.cds-links {
    margin: 0 3px;
}

.header-accueil {
    display: none;
}

#cms1 .header-accueil {
    display: block;
}

#cms1 #souris-scroll {
    display: none;
    position: absolute;
    z-index: 9999999999999999;
    -webkit-animation: jump 2s linear 0s infinite normal;
    animation: jump 1.5s ease 0s infinite normal;
}

#souris-scroll {
    display: none;
}

@-webkit-keyframes jump {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }

    20% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }

    40% {
        -webkit-transform: translateY(-30px);
        transform: translateY(-30px);
    }

    50% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }

    60% {
        -webkit-transform: translateY(-15px);
        transform: translateY(-15px);
    }

    80% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }

    100% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}

@keyframes jump {
    0% {
        transform: translateY(0);
    }

    20% {
        transform: translateY(0);
    }

    40% {
        transform: translateY(-30px);
    }

    50% {
        transform: translateY(0);
    }

    60% {
        transform: translateY(-15px);
    }

    80% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(0);
    }
}

ul.header-ul a:hover {
    color: #fff;
}

.headerBottom {}

.bg-ftr {
    background: url(../img/footer.jpg)center no-repeat;
    background-size: cover;
    padding: 140px 0;
}

a.b2-a3:hover {
    color: #fff;
}

@media only screen and (min-width: 320px) {
    .footer-right {
        min-height: 100%;
        padding: 30px 0;
        padding-bottom: 60px;
        background: #fff;
        background-size: cover;
    }

    #cms1 div#kameleon {}

    #cms1 #souris-scroll {
        display: none;
    }

    .header-cords {
        padding: 20px 0;
        background: url(../img/bg-header2.jpg)center no-repeat;
        background-size: cover;
    }

    .menu-bg {
        position: initial;
        z-index: 999;
        width: 100%
    }

    ul.header-ul {
        margin: 0;
        padding: 0;
        list-style-type: none;
        display: flex;
        justify-content: flex-end;
    }

    .header-li1,
    .header-li2,
    .header-li3 {
        font-size: 16px
    }

    ul.horaire-ul {
        padding: 0;
        margin: 0;
        list-style-type: none;
        display: flex;
        justify-content: space-around;
        flex-direction: column
    }

    a.header-tel {
        font-size: 18px;
        padding: 0 20px;
        padding-top: 10px;
        margin-bottom: 20px
    }

    .logocentre {
        display: none !important
    }

    #page {
        margin: auto;
        width: 100%
    }

    #header {
        position: relative;
    }

    #header a#home {
        display: block;
        width: 260px;
        padding: 20px 25px;
        margin: 0 auto
    }

    #header p#slogan {
        display: none
    }

    #cms1 #columns {
        clear: both;
        float: left;
        width: 100%;
        padding: 0;
    }

    #columns {
        clear: both
    }

    #center_column {
        width: 100%;
        padding: 0
    }

    #breadcrumb {
        margin: 5px 0;
        color: #666;
        font-size: .8em
    }

    #breadcrumb a {
        color: #666
    }

    #center_column,
    #left_column,
    #right_column {
        float: none
    }

    #left_column {
        width: 90%;
        padding: 5%
    }

    #right_column {
        width: 200px;
        padding-right: 40px
    }

    #footer {
        height: auto;
        margin: 0;
        /* margin-top: 20px; */
        float: left;
        width: 100%;
        background: #fff;
    }

    #footer p.address {
        margin: 5px 0
    }

    #footer p.address a {
        color: #333
    }

    #footer #incomm,
    #footer #seone {
        width: 100%;
        text-align: center;
        margin: 10px 0 5px;
        float: left;
        font-size: .7em
    }

    #footer #incomm a,
    #footer #seone a {
        color: #333;
        text-decoration: none
    }

    .column .block {
        margin-bottom: 1em;
        border: 1px solid #ccc
    }

    .column .block p {
        margin: 0 0 1%
    }

    .column .block header,
    article header,
    aside header {
        text-align: center;
        border-bottom: 0;
        padding: 3px 0
    }

    .column .block .block_content {
        padding: 2%
    }

    img {
        max-width: 100%;
        height: auto
    }

    iframe {
        max-width: 100%
    }

    .no_image {
        display: none
    }
}

@media only screen and (min-width: 768px) {
    .footer-right {
        padding: 30px 0;
        padding-bottom: 10px;
    }

    span#tel a:hover {
        color: #010080;
    }

    #cms1 #souris-scroll {
        float: none;
        margin: 0 auto;
        display: block;
        left: 0;
        right: 0;
        margin-top: -120px;
    }

    .header-li1,
    .header-li2,
    .header-li3 {
        font-size: 16px
    }

    ul.horaire-ul {
        flex-direction: column;
        text-align: center
    }

    a.header-tel {
        font-size: 18px;
        padding: 0 20px;
        padding-top: 10px
    }

    #footer {
        margin: 0;
    }

    .column .block {
        float: left;
        width: 47%;
        margin: 1%
    }

    .column .block p {
        margin: 0 0 2%
    }

    #center_column,
    #left_column,
    #right_column {
        float: left
    }

    .no_image {
        display: block
    }
}

@media only screen and (min-width: 992px) {
    .footer-right {
        padding: 30px 0;
        padding-bottom: 30px;
    }

    .first-bg>div>div {
        border-bottom: 1px solid #010080;
        margin-bottom: 10px;
    }

    #cms1 div#kameleon {}

    li.header-li2 {
        margin-right: 10px;
    }

    #cms1 #souris-scroll {
        float: none;
        margin: 0 auto;
        display: block;
        left: 0;
        right: 0;
        top: 440px;
        position: absolute;
    }

    #nav li a:hover:before,
    #nav li.selected a:before {}

    .headerBottom {
        padding: 0;
    }

    .header-cords {
        background: url(../img/bg-header2.jpg)center no-repeat;
        background-size: cover;
        padding: 5px 0;
    }

    .menu-bg {
        position: absolute
    }

    ul.header-ul {
        padding-bottom: 0;
    }

    .header-li1,
    .header-li2,
    .header-li3 {
        font-size: 15px
    }

    ul.horaire-ul {
        flex-direction: row
    }

    a.header-tel {
        font-size: 15px;
        padding: 0 20px;
        padding-top: 10px;
        margin-bottom: 0
    }

    .logocentre {
        display: flex !important
    }

    #page {
        margin: auto;
        width: 100%
    }

    #header {
        position: relative;
        height: auto;
        float: left;
        width: 100%
    }

    #header a#home {
        display: block;
        transition: .3s all ease-in-out;
        margin: 0;
        padding: 10px 0;
        padding-top: 0;
        width: auto;
    }

    #header p#slogan {
        margin: 10px 0 0 10px;
        float: left;
        display: block
    }

    #columns {
        clear: both
    }

    #center_column {
        width: 100%
    }

    #breadcrumb {
        margin: 5px 0;
        color: #666;
        font-size: .8em
    }

    #breadcrumb a {
        color: #666
    }

    #center_column,
    #left_column,
    #right_column {
        float: left
    }

    #left_column {
        width: 200px;
        padding-left: 40px
    }

    #right_column {
        width: 200px;
        padding-right: 40px
    }

    #footer {
        margin: 0;
    }

    #footer p.address {
        float: left;
        margin: 5px 0
    }

    #footer p.address a {
        color: #333
    }

    #footer #incomm,
    #footer #seone {
        float: left;
        width: 980px;
        text-align: center;
        margin: 10px 0 0;
        font-size: .8em
    }

    #footer #incomm a,
    #footer #seone a {
        color: #333;
        text-decoration: none
    }

    .column .block {
        width: 198px;
        margin-bottom: 1em;
        border: 1px solid #ccc
    }

    .column .block p {
        margin: 0 0 10px
    }

    .column .block header,
    article header,
    aside header {
        text-align: center;
        border-bottom: 0;
        padding: 3px 0
    }

    .column .block .block_content {
        padding: 5px
    }
}

@media only screen and (min-width: 1200px) {
    #cms1 #souris-scroll {
        float: none;
        margin: 0 auto;
        display: block;
        left: 0;
        right: 0;
        top: 560px;
    }

    #nav li a:hover:before,
    #nav li.selected a:before {}

    .headerBottom {
        padding: 0
    }

    .header-li1,
    .header-li2,
    .header-li3 {
        font-size: 15px
    }

    a.header-tel {
        font-size: 15px;
        padding: 0 20px;
        padding-top: 10px
    }
}

@media only screen and (min-width: 1400px) {
    .header-cords {
        background: url(../img/bg-header.jpg)center no-repeat;
        background-size: cover;
        padding: 10px 0;
    }

    #cms1 #souris-scroll {
        float: none;
        margin: 0 auto;
        display: block;
        left: 0;
        right: 0;
        top: 680px;
    }

    #nav li a:hover:before,
    #nav li.selected a:before {}

    .header-li1,
    .header-li2,
    .header-li3 {
        font-size: 16px
    }

    a.header-tel {
        font-size: 16px;
        padding: 0 20px;
        padding-top: 10px
    }

    ul.header-ul a {
        font-size: 18px;
    }
}

@media only screen and (min-width: 1700px) {
    #cms1 #souris-scroll {
        float: none;
        margin: 0 auto;
        display: block;
        left: 0;
        right: 0;
        top: 800px;
    }

    #nav li a:hover:before,
    #nav li.selected a:before {}

    .header-li1,
    .header-li2,
    .header-li3 {
        font-size: 16px
    }

    a.header-tel {
        font-size: 18px;
        padding: 0 20px;
        padding-top: 10px
    }
}

@media only screen and (min-width: 1800px) {
    #cms1 #souris-scroll {
        float: none;
        margin: 0 auto;
        margin-top: 0px;
        display: block;
        left: 0;
        right: 0;
        top: 800px;
    }
}