

.numbered-title-line {
    width:0;
    -webkit-transition: all .5s 1.2s;
    -moz-transition: all .5s 1.2s;
    -o-transition: all .5s 1.2s;
    transition: all .5s 1.2s;
    transition-timing-function: cubic-bezier(0.48, 0.43, 0, 1.22);
}

.numbered-title-container.motion-animate .numbered-title-line {
    width:60px;
}

.numbered-title,
.numbered-title::after {
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-duration: 800ms;
    animation-duration: 800ms;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
    animation-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
}

.numbered-title-container .numbered-title {
    color:transparent;
    -webkit-transition: all 0.2s 0.3s;
    -moz-transition: all 0.2s 0.3s;
    -o-transition: all 0.2s 0.3s;
    transition: all 0.2s 0.3s;
}
.numbered-title-container.motion-animate .numbered-title {
    color:#000000;
    position:  relative;
}

.numbered-title-container.dark-background.motion-animate .numbered-title {
    color:#FFFFFF;
}

.numbered-title-container .numbered-title-number {
    transform:translateY(-20px);
    opacity:0;
    -webkit-transition: all 0.5s 0.8s;
    -moz-transition: all 0.5s 0.8s;
    -o-transition: all 0.5s 0.8s;
    transition: all 0.5s 0.8s;
}
.numbered-title-container.motion-animate .numbered-title-number {
    transform:translateY(0);
    opacity:1;
}

.numbered-title-container.motion-animate .numbered-title::after {
    content: "";
    position: absolute;
    z-index: 999;
    left: 0;
    right: 0;
    top:0;
    bottom: 0;
    background-color: #000000;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
    pointer-events: none;
    -webkit-animation-name: revealer-text;
    animation-name: revealer-text;
}


@-webkit-keyframes reveal-text {
    from {
        -webkit-clip-path: inset(0 100% 0 0);
        clip-path: inset(0 100% 0 0);
    }
    to {
        -webkit-clip-path: inset(0 0 0 0);
        clip-path: inset(0 0 0 0);
    }
}


@keyframes reveal-text {
    from {
        -webkit-clip-path: inset(0 100% 0 0);
        clip-path: inset(0 100% 0 0);
    }
    to {
        -webkit-clip-path: inset(0 0 0 0);
        clip-path: inset(0 0 0 0);
    }
}


@-webkit-keyframes revealer-text {

    0%, 50% {
        -webkit-transform-origin: 0 50%;
        transform-origin: 0 50%;
    }

    60%, 100% {
        -webkit-transform-origin: 100% 50%;
        transform-origin: 100% 50%;
    }


    60% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
    }

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


@keyframes revealer-text {

    0%, 50% {
        -webkit-transform-origin: 0 50%;
        transform-origin: 0 50%;
    }

    60%, 100% {
        -webkit-transform-origin: 100% 50%;
        transform-origin: 100% 50%;
    }


    60% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
    }

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



.wpb_text_column.wpb_content_element.animated-motion h2 {
    transform: translateX(-30px);
    opacity: 0;
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.wpb_text_column.wpb_content_element.animated-motion.motion-animate h2 {
    transform: translateX(0);
    opacity: 1;
}





.full_width_image_container.appear-left .full_width_image_container_mask {
    width: 0px;
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
    transition-timing-function: cubic-bezier(.475,.425,0,.995);
    overflow: hidden;
    height: 100%;
    position:  relative;
}

.full_width_image_container.appear-left.motion-animate .full_width_image_container_mask {
    width:100%;
}

.full_width_image_container.appear-left .full_width_image {
    position: absolute;
    left:  0;
    top: 0;
    right: 0;
    bottom: 0;
    transform: translateX(-60px);
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.full_width_image_container.appear-left.motion-animate .full_width_image {
    transform: translateX(0px);
}





.section-numbered .wpb_wrapper div, .section-numbered .wpb_wrapper h4 {
    transform: translateX(-30px);
    -webkit-transition: all .5s;
    -moz-transition: all .5s;
    -o-transition: all .5s;
    transition: all .5s;
    opacity:0;
    line-height: 2.3;
}

.section-numbered .wpb_wrapper div:nth-child(1) {
    transition-delay:0.10s;
}
.section-numbered .wpb_wrapper div:nth-child(2) {
    transition-delay:0.2s;
}
.section-numbered .wpb_wrapper div:nth-child(3) {
    transition-delay:0.3s;
}
.section-numbered .wpb_wrapper div:nth-child(4) {
    transition-delay:0.4s;
}
.section-numbered .wpb_wrapper div:nth-child(5) {
    transition-delay:0.5s;
}
.section-numbered .wpb_wrapper div:nth-child(6) {
    transition-delay:0.6s;
}

.section-numbered.motion-animate .wpb_wrapper div, .section-numbered.motion-animate .wpb_wrapper h4 {
    transform: translateX(0px);
    opacity:1;
}


.projet-mis-en-avant h4 {
    transform: translateX(-30px);
    opacity: 0;
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.projet-mis-en-avant.motion-animate h4 {
    transform: translateX(0px);
    opacity:1;
}




.text-appear:after {
    content:"";
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 50%, #ffffff 50%);
    background-size: 200%;
    background-position: -100% 0%;
    display: inline;
    transition: 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    position:  absolute;
    left:  0;
    top: 0;
    width:  100%;
    height: 100%;
    z-index: 2;
}

.text-appear.motion-animate:after {
    background-position: -200% 0;
}




.line_split span
{
    display:  block;
    overflow: hidden;
}

.line_split.motion-animate span {
    padding-top: 0px!important;
}


.borded-header-image {
    opacity:0;
    -webkit-transition: all 1s 0.5s cubic-bezier(.475,.425,0,.995);
    -moz-transition: all 1s 0.5s cubic-bezier(.475,.425,0,.995);
    -o-transition: all 1s 0.5s cubic-bezier(.475,.425,0,.995);
    transition: all 1s 0.5s cubic-bezier(.475,.425,0,.995);
    background-size: cover;
    background-position: 50%;
    transform: translateY(200px);
}

.borded_header.motion-animate .borded-header-image {
    opacity:1;
    transform: translateY(0px);
}

.borded-header-text.left span{
    left: 25px;
    -webkit-transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    -moz-transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    -o-transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    pointer-events: all;
}

.borded-header-text.right span{
    right: 25px;
    -webkit-transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    -moz-transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    -o-transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
    transition: all 0.5s 0.5s cubic-bezier(.475,.425,0,.995);
}

.borded_header.motion-animate .borded-header-text.left span{
    left: 20px;
}

.borded_header.motion-animate .borded-header-text.right span{
    right: 20px;
}

.square-reveal-image {
    /* background-size:0px 0px; */
    position:  relative;
    background-position: 50%;
}

.square-reveal-image .full_width_image {
    opacity:0;
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    -o-transition: all 0.5s;
    transition: all 0.5s;
}

.square-reveal-image.motion-animate {
    -webkit-animation-name: visible-at-half;
    animation-name: visible-at-half;
    transition: all 2s cubic-bezier(.475,.425,0,.995), background-image 0s;
    -webkit-animation-duration: 2s;
    animation-duration: 2s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
}

.square-reveal-image:after {
    content:"";
    position:  absolute;
    left:  0;
    top: 0;
    bottom: 0;
    background: #c8333e;
    z-index: 0;
}

.square-reveal-image.motion-animate .full_width_image {
    opacity:1;
    -webkit-transition: all 0s 1s;
    -moz-transition: all 0s 1s;
    -o-transition: all 0s 1s;
    transition: all 0s 1s;
}

.square-reveal-image.motion-animate:after{
    -webkit-animation-name: appear-left;
    animation-name: appear-left;
    transition: all 2s cubic-bezier(.475,.425,0,.995);
    -webkit-animation-duration: 2s;
    animation-duration: 2s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
}

@-webkit-keyframes appear-left {
    0% {
        left:0;
        right: 100%;
    }
    50% {
        left:0px;
        right: 0;
    }
    100% {
        left:100%;
        right:0;
    }
}

@-webkit-keyframes visible-at-half {
    0% {
        background-size:0px 0px;
    }
    49.999% {
        background-size:0px 0px;
    }
    50% {
        background-size:cover;
    }
    100% {
        background-size:cover;
    }
}


.fade-image-bottom {
    -webkit-transition: transform 1s, opacity 1s;
    -moz-transition: transform 1s, opacity 1s;
    -o-transition: transform 1s, opacity 1s;
    transition: transform 1s, opacity 1s;
    transform: translateY(60px);
    opacity: 0;
}

.fade-image-bottom.motion-animate {
    transform: translateY(0px);
    opacity: 1;
}

.fade-image-left {
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
    transform: translateX(-30px);
    opacity: 0;
}

.fade-image-left.motion-animate {
    transform: translateX(0px);
    opacity: 1;
}

.fade-image-right {
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
    transform: translateX(30px);
    opacity: 0;
}

.fade-image-right.motion-animate {
    transform: translateY(0px);
    opacity: 1;
}

.fade-image-top-mini {
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
    opacity: 0;
    transform: translateY(30px);
}

.fade-image-top-mini.motion-animated {
    opacity: 1;
    transform: translateY(0px);
}

.delayed-500 {
    -webkit-transition-delay: 0.5s;
    -moz-transition-delay: 0.5s;
    -o-transition-delay: 0.5s;
    transition-delay: 0.5s;
}


.text-appear-left {
    opacity: 0;
    transform:translateX(-60px);
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.text-appear-left.motion-animated {
    opacity: 1;
    transform:translateX(0px);
}


.text-appear-right {
    opacity: 0;
    transform:translateX(60px);
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.text-appear-right.motion-animated {
    opacity: 1;
    transform:translateX(0px);
}


.text-appear-top {
    opacity: 0;
    transform:translateY(-30px);
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.text-appear-top.motion-animated, .realisation.active .text-appear-top {
    opacity: 1;
    transform:translateY(0px);
}


.text-appear-bottom {
    opacity: 0;
    transform:translateY(30px);
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.text-appear-bottom.motion-animated {
    opacity: 1;
    transform:translateY(0px);
}


.text-reveal-bottom {
    overflow:hidden;
    padding-bottom: 5px;
}

.text-reveal-bottom h3 {
    transform:translateY(100px);
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.text-reveal-bottom h1 {
    transform:translateY(200px);
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.text-reveal-bottom.motion-animated h3 {
    transform:translateY(0px);
}

.text-reveal-bottom.motion-animated h1 {
    transform:translateY(0px);
}

.text-appear-fadein {
    opacity: 0;
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    -o-transition: all 1s;
    transition: all 1s;
}

.text-appear-fadein.motion-animated {
    opacity: 1;
}

.text-appear-fadein2 {
    opacity: 0;
    -webkit-transition: all 2s;
    -moz-transition: all 2s;
    -o-transition: all 2s;
    transition: all 2s;
}

.text-appear-fadein2.motion-animated {
    opacity: 1;
}

.text-appear-fadein3 {
    opacity: 0;
    -webkit-transition: all 3s;
    -moz-transition: all 3s;
    -o-transition: all 3s;
    transition: all 3s;
}

.text-appear-fadein3.motion-animated {
    opacity: 1;
}