@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Open+Sans');
/*font-family: 'Open Sans', sans-serif;*/
@import url('https://fonts.googleapis.com/css?family=Open+Sans+Condensed:300');
/*font-family: 'Open Sans Condensed', sans-serif;*/
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300&display=swap');
/*font-family: 'Poppins', sans-serif;*/
@import url('https://fonts.googleapis.com/css2?family=Yeseva+One&display=swap');
/*font-family: 'Yeseva One', cursive;*/
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@200;300;400;600;700;800&display=swap'); /*font-family: 'Montserrat', sans-serif;*/




/* HEADER */
/*#header { background:#fff; width: 100%; height: 200px; background-size:100%;}*/
html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    overflow-x: hidden;
}

/*.carousel-inner {
    height: 100vh;
}

.carousel-item img {
    object-fit: cover;
    height: 100vh;
}*/

.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 250px;
    background-color: rgba(0, 0, 0, 0.95);
    padding-top: 10px;
    transform: translateX(-250px);
    transition: transform 0.3s ease;
    z-index: 1050;
}




@media (max-width: 960px) {
    .sidebar {
        width: 205px;
    }
}


.sidebar.active {
    transform: translateX(0);
}

.sidebar a {
    color: white;
    display: block;
    padding: 0.3rem 1rem;
    text-decoration: none;
}

.sidebar a:hover {
    background-color: rgba(255, 255, 255, 1);
}

.burger-btn {
    position: fixed;
    top: 20px;
    left: 20px;
    z-index: 1100;
    background-color: rgba(0, 0, 0, 0.7);
    border: none;
    color: white;
    padding: 0.1rem 0.75rem 0.3rem;
    font-size: 1.5rem;
    border-radius: 5px;
    transition: left 0.3s ease; font-size: 2.5rem; width: 80px; height: 80px;
}

.burger-btn.moved {
    left: 270px; /* 250px sidebar + 20px espace */
}

.content {
    margin-top: 100vh;
    padding: 2rem;
}

/*.carousel-item img {
    transform: scale(1);
    animation: none;
}

.carousel-item.active img {
    animation: zoomIn 10s ease-in-out forwards;
}

@keyframes zoomIn {
    from {
        transform: scale(1);
    }
    to {
        transform: scale(1.2);
    }
}*/



/*HEADER VIDEO*/


#slogan p {
    font-size: 16px;
    font-family: 'Montserrat', sans-serif;
    margin-top: 20px;
    color: #0A0A0A;
    line-height: 1.2em;
    z-index: 99999999;
}

#slogan p a {
    color: #0A0A0A;
}

#slogan p a:hover {
    text-decoration: none
}

#slogan .icone {
    text-align: right;
    padding: 5px 0px
}

#slogan .icone a {
    color: #fff
}

#slogan .icone a:hover {
    text-decoration: none;
    color: #000
}

#slogan .langue p {
    text-align: center;
    font-size: 14px;
    margin-top: 0px
}


header {background:#000;height: 200px}



.header-infos {border-bottom:1px solid #ccc; }

.navbar-light {background:#fff; box-shadow: 0px 15px 10px -15px #000 }
.nav-link {text-transform: uppercase; font-family: 'neue_montreallight'; font-size: 26px;}

.navbar {
    transition: background-color 0.2s;
}

.navbar.fixed-top {
    background-color: rgba(255, 255, 255, 0.90) !important;
    height: 190px;
}

.sticky-top {
    position: -webkit-sticky;
    position: sticky;
    top: 30%;
    z-index: 1020;
}

.collapse:not(.show) {
    display: block;
}

hr {
    border: 0.7px solid #0A0A0A;
    opacity: 1.0;
}

hr {
    margin: 0;
    margin-top: 1rem;
    border: 0;
}

@media (max-width: 960px) {
    .ui-block-a img {
        width: 44%;
        margin-top: -74%;
    }
    .navbar > .container, .navbar > .container-fluid, .navbar > .container-lg, .navbar > .container-md, .navbar > .container-sm, .navbar > .container-xl, .navbar > .container-xxl{display: block;}

    .overlay a  {
        font-size: 18px !important;
        margin-top: -5%;
    }
}



/*HEADER*/


/*MENU*/
.bg-light {
    background-color: #fff !important;
}

.navbar-brand {
    display: none !important
}

.navbar-brand.scrolled {
    display: block !important
}

.navbar-nav {
    margin: 0 auto
}

.navbar-toggler {
    padding: var(--bs-navbar-toggler-padding-y) var(--bs-navbar-toggler-padding-x);
    font-size: var(--bs-navbar-toggler-font-size);
    line-height: 1;
    color: var(--bs-navbar-color);
    background-color: transparent;
    border: var(--bs-border-width) solid var(--bs-navbar-toggler-border-color);
    border-radius: var(--bs-navbar-toggler-border-radius);
    transition: var(--bs-navbar-toggler-transition);
    background: #0A0A0A;
}


.navbar > .container, .navbar > .container-fluid, .navbar > .container-lg, .navbar > .container-md, .navbar > .container-sm, .navbar > .container-xl, .navbar > .container-xxl {
    display: block;
    flex-wrap: inherit;
    align-items: center;
    justify-content: space-between;
}

.menu-zindex {
    z-index: 1;
}

.overlay {
    height: 0%;
    width: 100%;
    position: fixed;
    z-index: 1;
    top: 0;
    left: 0;
    background-color: #FAFAFA;
    overflow-y: hidden;
    transition: 0.5s;
    color: #0A0A0A;
    font-family: 'Montserrat', sans-serif;
}

.overlay-content {
    position: relative;
    top: 25%;
    width: 100%;
    text-align: center;
    margin-top: 30px;
}

.overlay a {
    font-family: 'Montserrat', sans-serif;
    font-weight: 200;
    text-decoration: none;
    font-size: 28px;
    color: #0A0A0A;
    display: block;
    transition: 0.3s;
    text-transform: uppercase;
    background: #FAFAFA;
}

.overlay a:hover, .overlay a:focus {
    color: #0A0A0A;
    background: #dedede;
    border-radius: 8px;
}

.overlay .closebtn {
    position: absolute;
    top: 50px;
    right: 12%;
    font-size: 60px !important;
}

@media screen and (max-height: 450px) {
    .overlay {overflow-y: auto;}
    .overlay a {font-size: 20px}
    .overlay .closebtn {
        font-size: 40px;
        top: 15px;
        right: 35px;
    }
}

@media (max-width: 992px) {
    .navbar-nav {
        margin: 20px 0px;
    }

    .bg-light {
        background-color: #fff !important;
    }
}

.navbar-expand-lg .navbar-nav {
    flex-direction: column;
}

@media (min-width: 992px) {
    .navbar-expand-lg .navbar-nav {
        flex-direction: column;
    }
}

.dropdown-menu[data-bs-popper] {
    top: -19%;
    left: 100%;
    margin-top: var(--bs-dropdown-spacer);
    background: #fafafa;
}

.navbar-nav.active {
    display: block
}

.navbar-light .navbar-nav .active > .nav-link, .navbar-light .navbar-nav .nav-link.active, .navbar-light .navbar-nav .nav-link.show, .navbar-light .navbar-nav .show > .nav-link {
    color: #fff;
    background-color: #0A0A0A;
}


.navbar-light .navbar-nav .nav-link {
    color: #0A0A0A;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    font-size: 20px
}


.navbar-light .navbar-nav .nav-link:hover {
    color: #0A0A0A;
    border-bottom: 1px solid #0A0A0A;
}

.navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 1rem;
    padding-left: 1rem;
}

.dropdown-item {
    color: #0A0A0A;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    font-size: 15px
}

.size-drop {
    font-size: 20px !important;
    color: #0A0A0A;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
}

.dropdown-item:focus, .dropdown-item:hover {
    color: #fff;
    background-color: #0A0A0A;
}

.navbar-light .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

@media (min-width: 992px) {
    .navbar-expand-lg .navbar-nav .dropdown-menu {
        position: absolute;
        background: #FAFAFA;
    }
}

.submenu {
    background: #0A0A0A !important;
}

/*Custom ouverture menu mobile*/
@media (max-width: 992px) {
    .navbar-collapse {
        position: absolute;
        top: 54px;
        left: 0;
        padding-left: 15px;
        padding-right: 15px;
        padding-bottom: 15px;
        width: 100%;
    }

    .navbar-collapse.collapsing {
        height: auto;
        -webkit-transition: left 0.3s ease;
        -o-transition: left 0.3s ease;
        -moz-transition: left 0.3s ease;
        transition: left 0.3s ease;
        left: -100%;
    }

    .navbar-collapse.show {
        left: 0;
        -webkit-transition: left 0.3s ease-in;
        -o-transition: left 0.3s ease-in;
        -moz-transition: left 0.3s ease-in;
        transition: left 0.3s ease-in;
        background-color: #fff;
        height: 900px;
        text-align: center;
    }
}

/*MENU*/


/*INTEGRATION*/
a, a:hover {
    color: #000;
    text-decoration: none
}

h1, h2, h3, h4, h5{
    font-family: 'Montserrat', sans-serif;
    font-weight: 200;
    text-transform: uppercase;
}

.fal:hover {
    color: #838383;
}

p {
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
}

#section1 {
    background:#000
}

#section1 h1 {
    color: #fff;
    line-height: 1.4em;
}

#section1 h2 {
    color: #fff !important;
    line-height: 1.4em
}

#section1 h3 {
    color: #fff !important;
    line-height: 1.4em
}

#section1 h4 {
    color: #fff !important;
    line-height: 1.4em
}

#section1 h5 {
    color: #fff !important;
    line-height: 1.4em
}

#section1 h4 {
    color: #fff !important;
    line-height: 1.4em
}

#section1 p {
    color: #fff;
}

#section2 {
    background: url("../charte/back-section2.jpg") no-repeat;
    background-color: #0A0A0A;
    background-size: 100%
}

#section2 h1 {
    color: #fff;
    line-height: 1.4em
}

#section2 h2, h3, h5 {
    color: #fff !important;
    line-height: 1.4em
}

#section2 h4 {
    color: #fff !important;
    line-height: 1.4em
}

#section2 p {
    color: #fff;
}

#section2 i {
    color: #fff;
}

#section3 {
    background: none
}

#section3 h1 {
    color: #333333;
    line-height: 1.4em
}

#section3 h2, h3, h4, h5 {
    color: #333333 !important;
    line-height: 1.4em
}

#section3 h5 {
    color: #333333 !important;
    line-height: 1.4em
}

#section3 p {
    color: #000;
}

#section4 {
    background: none
}

#section4 h1 {
    color: #333333;
    line-height: 1.4em
}

#section4 h2, h3, h4, h5 {
    color: #333333 !important;
    line-height: 1.4em
}

#section4 p {
    color: #000;
}

#section5 {
    background: #0A0A0A
}

#section5 h1 {
    color: #fff;
    line-height: 1.4em
}

#section5 h2 {
    color: #fff;
    line-height: 1.4em
}

#section5 h3, h4 {
    color: #0A0A0A !important;
    line-height: 1.4em
}

#section5 h5 {
    color: #333333 !important;
    line-height: 1.4em
}

#section5 p {
    color: #fff;
}


#section-parallax img {
    padding-top: 200px;
}

#section-parallax h2 {
    color: #000;
    text-align: center
}


@media (max-width: 1400px) {

    #section-parallax img {
        padding-top: 5px;
    }
}


@media (max-width: 992px) {
    #section-parallax h2 {
        padding-top: 50px
    }

    #section-parallax img {
        padding-top: 10px;
    }

    #section1 h1 {
        color: #fff;
        line-height: 1.4em;
        font-size: 20px
    }
}


#section-bouton {background: #000}
#section-bouton h2 {color: #fff}

.top-services {
    top: 15%;
}

.parallax {
    /* The image used */
    background-image: url("../../../assets/theme8/charte/img-parallax.jpg");
    /* Set a specific height */
    height: 600px;
    /* Create the parallax scrolling effect */
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

@media only screen and (max-device-width: 1366px) {
    .parallax {
        background-attachment: scroll;
        height: 300px;
    }
}

/*boutons custom bootstrap*/
.btn-custom {
    color: #fff;
    background-color: #333;
    border-color: #333;
}

.btn-custom:hover, .btn-custom:focus, .btn-custom:active, .btn-custom.active, .open > .dropdown-toggle.btn-custom {
    color: #fff;
    background-color: #333;
    border-color: #333; /*set the color you want here*/
}

/*fin boutons custom bootstrap*/


/*boutons custom bootstrap*/
.button {
    flex: 1 1 auto;
    margin: 0px;
    padding: 20px;
    border: 1px solid #fff;
    text-align: center;
    text-transform: uppercase;
    position: relative;
    overflow: hidden;
    transition: 0.3s;
    color: #fff; background: #0A0A0A; border-radius: 16px;font-family: 'Montserrat', sans-serif; font-weight: 300;
}

.button:after {
    position: absolute;
    transition: 0.3s;
    content: "";
    width: 0;
    left: 50%;
    bottom: 0;
    height: 3px;
    background: #000;
}

.button:hover:nth-of-type(1) {
    border-radius: 16px;background: #fff;color: #0A0A0A;
}

.button:hover:nth-of-type(1):after {
    width: 0%;
}

.button:hover {
    cursor: pointer;
}

.button:hover:after {
    width: 100%;
    left: 0;
}

/*Fin Boutons*/

/*survol sur le photobox*/
.survol {
    color: #fff
}

/*survol sur le photobox*/


/*FIN INTEGRATION*/


/*FOOTER*/
footer {
    background: #0A0A0A;
    padding: 20px;
    min-height: 100px;
}

footer h2 {
    color: #fff;
    font-size: 18px
}

footer p {
    color: #fff;
    font-size: 14px
}

footer p a {
    color: #fff;
}

footer a:hover {
    color: #dedede;
    text-decoration: none
}

footer hr {
    border-color: #fff;
    margin: 0rem 0 !important;
}

footer ul.list-unstyled li a {
    color: #fff
}

footer .rubrique {
    color: #fff
}

/*FOOTER*/


.encart {
    border: 1px solid #eee;
    padding: 20px 10px 10px
}

.encart:hover {
    border: 1px solid #eee;
    padding: 20px 10px 10px;
    background: #fff
}



#burgerContainer {
    position: fixed;
    top: 115px;
    left: 0;
    width: 100%;
    height: 50px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 20px;
    box-shadow: 0 2px 5px rgba(0,0,0,0);
    z-index: 1000;
    transition: transform 0.3s ease; /* animation fluide */
}



@media (max-width: 960px) {
#burgerContainer {
    top: 35px;
}
}



#burgerContainer.moved {
    transform: translateX(250px); /* déplace vers la droite, adapte selon la largeur de ton menu */
}


@media (max-width: 960px) {
    #burgerContainer.moved {
        transform: translateX(205px); /* déplace vers la droite, adapte selon la largeur de ton menu */
    }
}



#burgerBtn {background-color: rgb(0,0,0,0.8); border:none; border-radius:10px; padding:30px 30px 35px; color:#fff; font-size:35px}
@media (max-width: 960px) {
    #burgerBtn {background-color: rgb(0,0,0,0.8); border:none; border-radius:10px; padding:10px 10px 15px; color:#fff; font-size:25px}
}

@media (max-width: 960px) {
#burgerContainer img { width: 28%}
}

label {color:#fff!important}

.legales  {color:#fff!important}
.legales a  {color:#fff!important}