html, body {
    background-color: #fff;
    color: #3B3B3B;
    font-weight: 300;
    height: 100vh;
    margin: 0;
    font-family: "Roboto", sans-serif;
}

.full-height {
    height: 100vh;
}

.flex-center {
    align-items: center;
    display: flex;
    justify-content: center;
}

.position-ref {
    position: relative;
}

.top-right {
    position: absolute;
    right: 10px;
    top: 18px;
}

.contentPage {

}

.title {
    font-size: 84px;
}

.links > a {
    color: #636b6f;
    padding: 0 25px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .1rem;
    text-decoration: none;
    text-transform: uppercase;
}

.m-b-md {
    margin-bottom: 30px;
}

#header {
    width: 100%;
    background: #0f173c;
    padding-top: 30px;
    background: linear-gradient(157deg, #0f1219, #6047af, #ff4700);
}

.bg-gradient {
    background: linear-gradient(157deg, #0f1219, #6047af, #ff4700)!important;
    color: white!important;
}

.waves {
    position:relative;
    width: 100%;
    height:15vh;
    margin-bottom:-7px;
    min-height:100px;
    max-height:150px;
}

.wavessmall {
    position:relative;
    width: 100%;
    height:5vh;
    margin-bottom:-7px;
    min-height:20px;
    max-height:50px;
}

.contentPage {
    padding-top: 50px;
}

.content {
    position:relative;
    height:10vh;
    text-align:center;
    background-color: white;
}

/* Animation */


.waves {
    position:relative;
    width: 100%;
    height:15vh;
    margin-bottom:-7px;
    min-height:100px;
    max-height:150px;
}

/*
.parallax > use {
    animation: move-forever 25s cubic-bezier(.55,.5,.45,.5)     infinite;
}
.parallax > use:nth-child(1) {
    animation-delay: -2s;
    animation-duration: 7s;
}
.parallax > use:nth-child(2) {
    animation-delay: -3s;
    animation-duration: 10s;
}
.parallax > use:nth-child(3) {
    animation-delay: -4s;
    animation-duration: 13s;
}
.parallax > use:nth-child(4) {
    animation-delay: -5s;
    animation-duration: 20s;
}
@keyframes move-forever {
    0% {
        transform: translate3d(-90px,0,0);
    }
    100% {
        transform: translate3d(85px,0,0);
    }
}
*/

/*Shrinking for mobile*/
@media (max-width: 768px) {
    .desktop-only {
        display: none;
    }

    .waves {
        height:40px;
        min-height:40px;
    }
    .content {
        height:30vh;
    }
    h1 {
        font-size:24px;
    }
}

.header-logo-img {
    width: auto;
    max-height: 60px;
    float:left;
}

.header-logo {
    width: 250px;
    float: left;
}

.header-logo span {
    font-size: 40px;
    width: auto;
    text-transform: uppercase;
    font-weight: 300;
    font-family: "Roboto", sans-serif;
    margin-left: 15px;
    margin-top: 1px;
    display: inline-block;
    color: white;
}

.logo-text {
    color: white;
    text-transform: uppercase;
    font-weight: 400;
    font-size:20px;
    font-family: "Roboto", sans-serif;
    display: inline-block;
    margin-left: 5px;
    margin-right: 5px;
    margin-top: 3px;
}


ul.header-menu {
    float: right;
    width: auto;
    list-style-type: none;
    margin-top:15px;
}

.header-menu li .header-menu-dropdown {
    display: none;
}

.header-menu li {
    display: inline;
    text-align: center;
}

.header-menu li a {
    margin: 2px;
    padding: 8px;
    padding-top: 5px;
    padding-bottom: 5px;
    color: white;
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 300;
    font-size: 16px;
    transition: all 0.5s;
    border-radius: 5px;
    text-align: center;
}

.header-menu li.active, .header-menu li:hover {
}

.header-menu li.active a {
    color: #3f3170;
    background: white;
}

.header-menu li.active a {
    font-weight: 400;
}

@keyframes fadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}



.header-menu-dropdown {
    position: absolute;
    background: rgba(0, 0, 0, 0.6);
    /* blur effect on background only */
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);

    text-align: left;
    z-index: 20;
    margin-top:3px;
    margin-left:90px;
    padding:0;
    border-radius:0px 5px 5px 5px;
}

.header-menu-dropdown li a {
    padding: 10px;
    background: transparent!important;
    display: block;
    margin: 8px;
    text-align: left!important;
    color: white!important;
}

.header-menu-dropdown li {
    background: transparent!important;
    text-align: left!important;
}


.header-menu-dropdown li.active a {
    background: rgba(255, 255, 255, 0.09) !important;
}

#content-header {
    width: 100%;
    clear: both;
    position: relative;
    padding-top: 80px;
    padding-bottom: 80px;
    color: white;
    font-size: 18px;
    font-weight: 200;
}

#content-header h1 {
    color: white;
    text-align: left;
    display: inline-block;
    padding: 10px;
    padding-right: 20px;
    padding-bottom: 0px;
    border-radius: 8px;
    font-size: 40px;
    text-shadow: 4px 4px 0px #00000026;
    margin-bottom:20px;
}

span.surligned {
    background: #00000040;
    padding: 5px;
    padding-left: 10px;
    padding-right: 10px;
    border-radius: 5px;
}

.content-header-formulaire {
    width: 100%;
    height: auto;
    position: relative;
}

.header-formulaire {
    background: white;
    border-radius: 5px;
    position: absolute;
    width: 100%;
    color: #222222;
    padding: 20px;
    font-size: 15px;
    z-index: 10;
    box-shadow: 0px 0px 20px #00000033;
    top: -40px;
}

.header-formulaire h2 {
    color: #463680;
    font-size: 25px;
    font-weight: 500;
}

.header-formulaire p {
    font-size: 15px;
    font-weight: 300;
    color: #686868;
}

.font-weight-bold {
    font-weight: bolder;
}

.btn-primary, .badge-primary {
    background-color: #5e45b2;
    border-color: #5e45b2;
}

.badge-pill {
    border-radius: 50%;
}

h3 {
    font-size: 24px;
    border-bottom: 2px solid #FFFFFF50;
    padding-bottom: 6px;
    text-shadow: 2px 2px 0px #00000030;
}

.btn-primary:hover {
    background-color: #463680;
    border-color: #463680;
}

.text-primary {
    color: #453680!important;
}

.header-partenaires img {
    max-height: 55px;
    margin: 10px;
}

#header h2 {
    font-size: 25px;
    margin-bottom: 15px;
}

.content {
    text-align: justify;
}

.content h2 {
    color: #453680;
    font-size: 30px;
    margin-top: 30px;
    margin-bottom: 30px;
}

.content h3 {
    color: #222222;
    font-size: 25px;
    margin-top: 20px;
    margin-bottom: 20px;
}

.separator {
    width: 100px;
    height: 5px;
    background: #00000014;
    display: block;
    margin-top: 10px;
    margin-bottom: 25px;
}

.content b {
    color: #453680;
    font-weight: 400;
}

.content span.surligned {
    background: #0000000a;
}

.section-simple {
    padding-top: 30px;
    padding-bottom: 30px;
}

.section-dark {
    padding-top: 30px;
    padding-bottom: 60px;
    margin-top:50px;
    margin-bottom: 50px;
    color: white;
}

.section-dark h2 {
    color: white;
    margin-bottom:30px;
}

.section-grey {
    padding-top: 30px;
    padding-bottom: 30px;
    background: #EEEEEE;
}

.prestation-item {
    width: 100%;
    height: 100%;
    position:relative;
    background: white;
    padding: 15px;
    text-align: left;
    border-radius: 5px;
    box-shadow: 0px 0px 10px #00000010;
    transition: all 0.5s;
}

.prestation-cta {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
}



.prestation-image {
    width: 100%;
    padding:20px;
}

.prestation-image img {
    width: 100%;
    max-height: 150px;
}

.prestation-content {
    padding-bottom: 50px;
}

.prestation-content h3 {
    text-align: center;
    font-size: 22px;
    text-shadow: 2px 2px 10px #00000030;
}

.colors-arc {
    margin-top: 18px;
    margin-bottom: 35px;
}

.colors-arc .color1, .colors-arc .color2, .colors-arc .color3 {
    width: 100%;
    border-radius:5px;
    height: 12px;
}

.colors-arc .color1 {
    background: linear-gradient(90deg, #453680, #ff7223);
}

.colors-arc .color2 {
    background: #FFFFFF;
}

.colors-arc .color3 {
    background: linear-gradient(270deg, #453680, #ff7223);
}

.disc-item {
    width: 100%;
    padding: 10px;
    background: #FFFFFF;
    border-radius: 5px;
    box-shadow: 0px 0px 10px #00000030;
    text-align: center;
    transition: all 0.5s;
}

.disc-item-title {
    text-align: center;
    margin-bottom: 30px;
}


.disc-item p {
    text-align: justify;
}

.disc-item img {
    width: auto;
    text-align: center;
    max-height: 150px;
}

.realisation-item h3 {
    color: white;
    text-align: center;
    font-size: 17px;
    margin-top: 12px;
    margin-bottom: 6px;
    border-bottom: 3px solid #3d3d3d;
    padding-bottom: 5px;
}

.realisation-item {
    padding: 10px;
    background: #2b2b2b;
    border-radius: 5px;
    box-shadow: 0px 0px 20px #00000075;
    transition: all 1s;
}


.realisation-item p {
    font-size: 14px;
    text-align: center;
    margin-bottom: 0px;
}

.blog-item {
    border: 1px solid #DDDDDD;
    background: #DDDDDD;
    border-radius: 5px;
    padding: 10px;
    height: 100%;
    position: relative;
}

.blog-item .btn {
    position: absolute;
    left: 0px;
    right: 0;
    bottom: 0;
}

.blog-item img {
    width: 100%;
    max-height: 130px;
    text-align: center;
    margin: auto;
    display: block;
    margin-bottom: 10px;
    padding-top:10px;
    padding-bottom:10px;
    background: #FFFFFF;
    border-radius: 5px;
}

.blog-item h3 {
    font-size: 16px;
    text-align: center;
    color: #222222;
    margin-top:10px;
}

.blog-item p {
    font-size: 13px;
    padding-left: 10px;
    padding-right: 10px;
    text-align: justify;
    color: #222222;
    margin-bottom: 30px;
}

.footer-mentions {
    text-align: center;
    font-size: 15px;
    color: #CCCCCC;
    border-top: 2px solid #333333;
    padding-top: 8px;
    padding-bottom: 10px;
}

.footer-mentions a {
    color: #6ca8ff;
    text-decoration: underline;
}

.footer-contact, .footer-links {
    list-style-type: none;
    padding: 0;
}

.footer-contact li span {
    padding-right: 6px;
}

.footer-contact li {
    margin-bottom: 8px;
    font-size: 16px;
    color: #CCCCCC;
}

.footer-links li {
    margin-bottom: 0px;
    font-size: 14px;
}

.footer-links li a {
    color: #8eb9ff;
    text-decoration: none;
}

.footer-links li a:hover {
    text-decoration: underline;
}

#footerpage {
    width: 100%;
    padding-top: 60px;
    margin-top: 50px;
    color: #CCCCCC;
    padding-bottom:50px;
}

#footerpage h3 {
    margin-bottom: 25px;
    font-size: 20px;
}

.bg-dark {
    background: #1c1f2a!important;
}

h2 {
    text-align: left;
    margin-top: 30px;
    margin-bottom: 30px;
}

.cta-project {
    padding: 20px;
    padding-top:50px;
    padding-bottom:50px;
    border-radius: 5px;
    display: inline-block;
    margin: auto;
}

.cta-project h2 {
    padding: 0px;
    margin: 0px;
}

.text-red, .text-danger {
    color: #c54040;
}


.text-warning {
    color: #ff8522;
}

.btn-red {
    background: #c54040;
    border-color: #c54040;
    color: white;
}

.btn-red:hover {
    background: #a13333;
    border-color: #a13333;
    color: white;
}

.zoom-in-out-box {
    animation: zoom-in-zoom-out 1s ease infinite;
}

@keyframes zoom-in-zoom-out {
    0% {
        transform: scale(1, 1);
    }
    50% {
        transform: scale(1.05, 1.05);
    }
    100% {
        transform: scale(1, 1);
    }
}

.header-small {
    padding-top: 50px!important;
    padding-bottom: 0px!important;
}

.header-small h1 {
    text-align: center!important;
    display: block!important;
}

.dark-visuels img {
    background: #ffffff;
    padding: 10px;
    border-radius: 0.5rem;
}

.questions-frequentes .question h3 {
    background: #DDDDDD;
    padding: 8px;
    border: none;
    color: #222222;
    text-shadow: none;
    font-size: 20px;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.5s;
}

.blog-item h3 {
    border: none;
    text-shadow: none;
}




.questions-frequentes .reponse {
    text-align: justify;
    font-size: 16px;
}

.header-logo a {
    text-decoration: none!important;
}

.header-menu-button-open-mobile {
    display: none;
}

@media only screen and (min-width: 992px) {

    .header-menu li:hover a {
        color: #3f3170;
        background: rgba(255, 255, 255, 0.86);
    }

    .header-menu li:hover .header-menu-dropdown {
        animation: fadeIn 0.5s;
        -webkit-animation: fadeIn 0.5s;
        -moz-animation: fadeIn 0.5s;
        -o-animation: fadeIn 0.5s;
        -ms-animation: fadeIn 0.5s;
        display: block;
        height:auto!important;
    }

    .header-menu-dropdown li:hover a {
        background: #FFFFFF30!important;
    }

    .prestation-item:hover {
        scale: 1.1;
    }

    .disc-item:hover {
        scale: 1.05;
    }

    .realisation-item:hover {
        scale: 1.3;
    }

    .questions-frequentes .question h3:hover {
        background: #CCCCCC;
    }

}

@media only screen and (max-width: 992px) {

    .d-sm-none {
        display: none!important;
    }

    .col-xs-6 {
        width: 50%;
    }

    .text-menu {
        font-size:20px;
        margin-left:10px;
        display: inline-block;
        font-weight: 400;
    }

    .header-menu-button-open-mobile {
        display: flex;
        color: #322758;
        font-size: 30px;
        position: absolute;
        top: 16px;
        right: 20px;
        background: #FFFFFF;
        padding-top: 5px;
        padding-bottom: 5px;
        padding-left: 10px;
        padding-right: 10px;
        border-radius: 0.5rem;
    }

    .header-logo {
        width: auto;
        text-align: center;
        font-size:35px;
    }

    .header-menu {
        display: none;
    }

    .header-logo-img {
        float: none;
        max-height: 40px;
    }

    .header-logo span {
        font-size: 30px;
        margin-left: 5px;
        margin-top: 1px;
    }

    #header {
        padding-top: 10px;
    }

    #content-header {
        padding-top: 15px!important;
        padding-bottom: 20px;
    }

    #content-header h1 {
        font-size: 30px;
        text-align: center;
        width: 100%;
    }

    #content-header p {
        font-size:15px;
    }

    .contentPage {
        padding-top: 20px;
    }

    .section-dark {
        padding-top: 10px;
        padding-bottom: 30px;
        margin-top: 20px;
        margin-bottom: 20px;
        color: white;
    }

    .header-formulaire {
        position: relative;
        top:0px;
    }

    .header-partenaires img {
        max-height: 30px;
        margin: 5px;
    }

    .header-partenaires {
        margin-bottom: 15px;
    }

    #header h2 {
        font-size: 20px;
        margin-bottom: 15px;
    }

    ul.header-menu {
        float: none;
        transition: all 0.5s;
        opacity:0;
        width: 100%;
        list-style-type: none;
        margin-top: 0px;
        position: fixed;
        background: rgba(0, 0, 0, 0.6);
        /* blur effect on background only */
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
        top: 70px;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 500;
        padding:0;
        margin-bottom: 0;
        display: block;
        border-radius: 20px 20px 0 0;
        margin-left:100%;
    }

    .disc-item-title {
        margin-top: 20px;
    }

    ul.header-menu.is-visible {
        opacity:1;
        margin-left:0;
    }

    .header-menu li {
        display: block;
        text-align: center;
        background: transparent;
        padding-top: 15px;
        padding-bottom: 15px;
        border-radius: .5rem;
        margin:10px;
    }

    .header-menu li a {
        background: transparent;
        font-weight: 400;
    }

    .header-menu li.active a {
        background: transparent;
        color: white;
        font-weight: 500;
    }

    .header-menu li.active {
        background: #FFFFFF50;
    }


    .header-menu li:hover .header-menu-dropdown {
        display: none;
    }

}