                        @import 'https://fonts.googleapis.com/css?family=Montserrat:300, 400, 700&display=swap';
                        * {
                            padding: 0;
                            margin: 0;
                            box-sizing: border-box;
                        }
                        
                        html {
                            font-size: 10px;
                            font-family: 'Montserrat', sans-serif;
                            scroll-behavior: smooth;
                        }
                        
                        a {
                            text-decoration: none;
                        }
                        
                        img {
                            height: 100%;
                            width: 100%;
                            object-fit: cover;
                        }
                        
                        p {
                            color: white;
                            font-size: 1.4rem;
                            margin-top: 5px;
                            line-height: 2.5rem;
                            font-weight: 300;
                            letter-spacing: 0.05rem;
                        }
                        
                        .section-title {
                            font-size: 4rem;
                            font-weight: 300;
                            color: white;
                            margin-bottom: 10px;
                            text-transform: uppercase;
                            letter-spacing: 0.2rem;
                            text-align: center;
                        }
                        
                        .section-title span {
                            color: #4682B4;
                            ;
                        }
                        
                        .container {
                            min-height: 100vh;
                            width: 100%;
                            display: flex;
                            align-items: center;
                            justify-content: center;
                        }
                        
                        @keyframes animate {
                            0% {
                                background-image: url(IMG/ph1-min.jpg);
                            }
                            25% {
                                background-image: url(IMG/ph2-min.jpg);
                            }
                            50% {
                                background-image: url(IMG/ph3-min.jpg);
                            }
                            75% {
                                background-image: url(IMG/ph4-min.jpg);
                            }
                            100% {
                                background-image: url(IMG/ph5-min.jpg);
                            }
                        }
                        /* Hero Section */
                        
                        #hero .arriere {
                            background-image: url(IMG/2123-min.jpeg);
                            background-size: cover;
                            animation: animate 19s ease-in-out infinite;
                        }
                        
                        #hero {
                            background-position: top center;
                            position: relative;
                            z-index: 1;
                            background-image: url(IMG/2123-min.jpeg);
                            background-size: cover;
                            color: white;
                        }
                        
                        #hero::after {
                            content: '';
                            position: absolute;
                            left: 0;
                            top: 0;
                            height: 100%;
                            width: 100%;
                            background-color: black;
                            opacity: 0.3;
                            z-index: -1;
                            color: white;
                        }
                        
                        #hero .hero {
                            max-width: 1200px;
                            margin: 0 auto;
                            padding: 0 50px;
                            justify-content: flex-start;
                            color: white;
                        }
                        
                        #hero h1 {
                            display: block;
                            width: fit-content;
                            font-size: 4rem;
                            position: relative;
                            color: transparent;
                            animation: text_reveal .5s ease forwards;
                            animation-delay: 1.5s;
                            color: white;
                        }
                        
                        #hero h1:nth-child(1) {
                            animation-delay: 1s;
                        }
                        
                        #hero h1:nth-child(2) {
                            animation-delay: 2s;
                        }
                        
                        #hero h1:nth-child(3) {
                            animation: text_reveal_name 0.5s ease forwards;
                            animation-delay: 3s;
                        }
                        
                        #hero h1 span {
                            position: absolute;
                            top: 0;
                            left: 0;
                            height: 100%;
                            width: 0;
                            background-color: #4682B4;
                            animation: text_reveal_box 1s ease;
                            animation-delay: 1s;
                        }
                        
                        #hero h1:nth-child(1) span {
                            animation-delay: 0.5s;
                        }
                        
                        #hero h1:nth-child(2) span {
                            animation-delay: 1.5s;
                        }
                        
                        #hero h1:nth-child(3) span {
                            animation-delay: 2.5s;
                        }
                        
                        #hero .cta {
                            display: inline-block;
                            padding: 10px 30px;
                            color: white;
                            background-color: #4682B4;
                            border: 2px solid#4682B4;
                            font-size: 2rem;
                            text-transform: uppercase;
                            letter-spacing: .1rem;
                            margin-top: 20px;
                            transition: .3s ease;
                            transition-property: background-color, color;
                        }
                        
                        #hero .cta:hover {
                            color: white;
                            display: inline-block;
                            background-color: transparent;
                            font-weight: bold;
                        }
                        /*  End Hero Section */
                        /* Header section */
                        
                        .logo {
                            position: absolute;
                            margin-top: -2px;
                            margin-left: 0;
                            margin-right: 0;
                            width: 15%;
                            height: 15%;
                        }
                        
                        #header {
                            position: fixed;
                            z-index: 1000;
                            left: 0;
                            top: 0;
                            width: 100%;
                            height: auto;
                        }
                        
                        @media screen and (max-width: 640px) {
                            .logo {
                                width: 50%!important;
                                margin: auto;
                                padding: auto;
                            }
                        }
                        
                        #header .header {
                            min-height: 8vh;
                        }
                        
                        #header .nav-bar {
                            display: flex;
                            align-items: left;
                            justify-content: space-between;
                            width: 100%;
                            height: 85px;
                            max-width: 1300px;
                            padding: 0 0px;
                        }
                        /* menu column*/
                        
                        #header .nav-list ul {
                            list-style: none;
                            position: absolute;
                            width: 100vw;
                            height: 100vh;
                            left: 100%;
                            top: 0;
                            display: flex;
                            flex-direction: column;
                            justify-content: center;
                            align-items: center;
                            z-index: 1;
                            overflow-x: hidden;
                            transition: 0.5s ease left;
                            color: white;
                            background-color: #45596e;
                        }
                        
                        #header .nav-list ul.active {
                            left: 0%;
                        }
                        
                        #header .nav-list ul a {
                            font-size: 2.5rem;
                            font-weight: bold;
                            letter-spacing: 0.2rem;
                            text-decoration: none;
                            color: white;
                            text-transform: uppercase;
                            padding: 20px;
                            display: block;
                        }
                        
                        #header .nav-list ul a::after {
                            content: attr(data-after);
                            position: absolute;
                            top: 50%;
                            left: 50%;
                            transform: translate(-50%, -50%) scale(0);
                            color: #C0C0C0;
                            font-size: 13rem;
                            letter-spacing: 50px;
                            z-index: -1;
                            transition: 0.3s ease letter-spacing;
                        }
                        
                        #header .nav-list ul li:hover a::after {
                            transform: translate(-50%, -50%) scale(1);
                            letter-spacing: initial;
                        }
                        
                        #header .nav-list ul li:hover a {
                            color: #4682B4;
                        }
                        
                        #header .hamburger {
                            height: 60px;
                            width: 60px;
                            display: inline-block;
                            border: 3px solid white;
                            border-radius: 50%;
                            position: relative;
                            display: flex;
                            align-items: center;
                            justify-content: center;
                            z-index: 100;
                            cursor: pointer;
                            transform: scale(0.8);
                            margin-right: 20px;
                        }
                        
                        #header .hamburger:after {
                            position: absolute;
                            content: '';
                            height: 100%;
                            width: 100%;
                            border-radius: 50%;
                            border: 3px solid white;
                            animation: hamburger_puls 1s ease infinite;
                        }
                        
                        #header .hamburger .bar {
                            height: 2px;
                            width: 30px;
                            position: relative;
                            z-index: -1;
                            background-color: #485563;
                        }
                        
                        #header .hamburger .bar::after,
                        #header .hamburger .bar::before {
                            content: '';
                            position: absolute;
                            height: 100%;
                            width: 100%;
                            left: 0;
                            background-color: white;
                            transition: 0.3s ease;
                            transition-property: top, bottom;
                        }
                        
                        #header .hamburger .bar::after {
                            top: 8px;
                        }
                        
                        #header .hamburger .bar::before {
                            bottom: 8px;
                        }
                        
                        #header .hamburger.active .bar::before {
                            bottom: 0;
                        }
                        
                        #header .hamburger.active .bar::after {
                            top: 0;
                        }
                        /* End Header section */
                        /* Services Section */
                        
                        #services .services {
                            flex-direction: column;
                            text-align: center;
                            max-width: 1500px;
                            margin: 0 auto;
                            padding: 100px 0;
                        }
                        
                        #services .section-title {
                            font-size: 4rem;
                            font-weight: 300;
                            color: black;
                            margin-bottom: 10px;
                            text-transform: uppercase;
                            letter-spacing: 2rem;
                            text-align: center;
                        }
                        
                        #services .section-title span {
                            color: #00bfff;
                        }
                        
                        #services .service-top p {
                            font-size: 1.4rem;
                            margin-top: 5px;
                            line-height: 2.5rem;
                            font-weight: 300;
                            letter-spacing: .05rem;
                        }
                        
                        #services .service-bottom {
                            display: flex;
                            align-items: center;
                            justify-content: center;
                            flex-wrap: wrap;
                            margin-top: 50px;
                        }
                        
                        #services .service-item {
                            flex-basis: 80%;
                            display: flex;
                            align-items: flex-start;
                            justify-content: center;
                            flex-direction: column;
                            padding: 30px;
                            border-radius: 10px;
                            background-image: url(IMG/2123-min.jpeg);
                            background-size: cover;
                            margin: 10px 5%;
                            position: relative;
                            z-index: 1;
                            overflow: hidden;
                        }
                        
                        #services .service-item::after {
                            content: '';
                            position: absolute;
                            left: 0;
                            top: 0;
                            height: 100%;
                            width: 100%;
                            opacity: 0.7;
                            background-image: linear-gradient(60deg, #29323c 0%, #485563 100%);
                            z-index: -1;
                        }
                        
                        #services .service-bottom .icon {
                            height: 50px;
                            width: 50px;
                            margin-bottom: 20px;
                        }
                        
                        #services .service-item h2 {
                            font-size: 2rem;
                            color: white;
                            margin-bottom: 10px;
                            text-transform: uppercase;
                            justify-content: end;
                        }
                        
                        #services .service-item h3 {
                            font-size: 2rem;
                            color: #00bfff;
                            margin-bottom: 10px;
                            justify-content: end;
                        }
                        
                        #services .service-item p {
                            font-size: 1.6rem;
                            color: white;
                            text-align: left;
                            line-height: 2rem;
                        }
                        /* Projects section */
                        
                        #projects .projects {
                            flex-direction: column;
                            max-width: 1200px;
                            margin: 0 auto;
                            padding: 100px 0;
                        }
                        
                        #projects .projects-header h1 {
                            margin-bottom: 50px;
                            color: black;
                        }
                        
                        #projects .all-projects {
                            display: flex;
                            align-items: center;
                            justify-content: center;
                            flex-direction: column;
                        }
                        
                        #projects .project-item {
                            display: flex;
                            align-items: center;
                            justify-content: center;
                            flex-direction: column;
                            width: 70%;
                            margin: 20px auto;
                            overflow: hidden;
                            border-radius: 10px;
                        }
                        
                        #projects .project-info {
                            padding: 30px;
                            flex-basis: 50%;
                            height: 100%;
                            display: flex;
                            align-items: flex-start;
                            justify-content: center;
                            flex-direction: column;
                            background-image: linear-gradient(#6f7b86, #45596e);
                            color: white;
                        }
                        
                        #projects .project-info .icon {
                            height: 100px;
                            width: 100px;
                            margin-bottom: 30px;
                        }
                        
                        #projects .project-info h1 {
                            font-size: 4rem;
                            font-weight: 500;
                        }
                        
                        #projects .project-info h2 {
                            font-size: 1.8rem;
                            font-weight: 500;
                            margin-top: 10px;
                        }
                        
                        #projects .project-info p {
                            color: white;
                        }
                        
                        #projects .project-img {
                            flex-basis: 50%;
                            height: 300px;
                            overflow: hidden;
                            position: relative;
                        }
                        
                        #projects .project-img:after {
                            content: '';
                            position: absolute;
                            left: 0;
                            top: 0;
                            height: 100%;
                            width: 100%;
                            opacity: 0.7;
                        }
                        
                        #projects .project-img img {
                            transition: 0.3s ease transform;
                        }
                        
                        #projects .project-item:hover .project-img img {
                            transform: scale(1.1);
                        }
                        /* About Section */
                        
                        #about .about {
                            flex-direction: column-reverse;
                            text-align: center;
                            max-width: 1200px;
                            margin: 0 auto;
                            padding: 100px 20px;
                        }
                        
                        .video-responsive {
                            overflow: hidden;
                            padding-bottom: 56.25%;
                            position: relative;
                            height: 0;
                        }
                        
                        .video-responsive iframe {
                            left: 0;
                            top: 0;
                            height: 100%;
                            width: 100%;
                            position: absolute;
                        }
                        
                        #about .col-left {
                            width: 250px;
                            height: 360px;
                        }
                        
                        #about .col-right {
                            width: 100%;
                        }
                        
                        #about .col-right h1 {
                            color: black;
                        }
                        
                        #about .col-right h2 {
                            font-size: 2rem;
                            font-weight: 500;
                        }
                        
                        #about .col-right p {
                            margin-bottom: 20px;
                            color: black;
                        }
                        
                        #about .col-right .cta {
                            color: black;
                            margin-bottom: 50px;
                            padding: 10px 20px;
                            font-size: 2rem;
                            display: inline-block;
                            padding: 10px 30px;
                            background-color: transparent;
                            border: 2px solid #00bfff;
                            font-size: 2rem;
                            text-transform: uppercase;
                            letter-spacing: .1rem;
                            margin-top: 20px;
                            transition: .3s ease;
                            transition-property: background-color, color;
                        }
                        
                        #about .cta:hover {
                            color: white;
                            background-color: #00bfff;
                            font-weight: bold;
                        }
                        
                        #about .col-left .about-img {
                            height: 100%;
                            width: 100%;
                            position: relative;
                            border: 10px solid white;
                        }
                        
                        #about .col-left .about-img::after {
                            content: '';
                            position: absolute;
                            left: -33px;
                            top: 19px;
                            height: 98%;
                            width: 98%;
                            border: 7px solid #00bfff;
                            z-index: -1;
                        }
                        /* End About Section */
                        /* contact Section */
                        
                        #contact .contact {
                            flex-direction: column;
                            max-width: 1200px;
                            margin: 0 auto;
                            width: 90%;
                        }
                        
                        #contact .contact-items {
                            /* max-width: 400px; */
                            width: 100%;
                        }
                        
                        #contact .contact-item {
                            width: 80%;
                            padding: 20px;
                            text-align: center;
                            border-radius: 10px;
                            padding: 30px;
                            margin: 30px;
                            display: flex;
                            justify-content: center;
                            align-items: center;
                            flex-direction: column;
                            box-shadow: 0px 0px 18px 0 #0000002c;
                            transition: 0.3s ease box-shadow;
                        }
                        
                        #contact .contact-item:hover {
                            box-shadow: 0px 0px 5px 0 #0000002c;
                        }
                        
                        #contact .icon {
                            width: 70px;
                            margin: 0 auto;
                            margin-bottom: 10px;
                        }
                        
                        #contact .section-title h1 {
                            color: black;
                        }
                        
                        #contact .contact-info h1 {
                            color: black;
                            font-size: 2.5rem;
                            font-weight: 500;
                            margin-bottom: 5px;
                        }
                        
                        #contact .contact-info h1 {
                            font-size: 1.3rem;
                            line-height: 2rem;
                            font-weight: 500;
                            color: black;
                        }
                        /*End contact Section */
                        /* Nous contacter Section */
                        
                        #envoie {
                            height: 100vh;
                            width: 100%;
                            background-color: aliceblue;
                            display: flex;
                            align-items: center;
                            justify-content: center;
                            flex-direction: column;
                        }
                        
                        #envoie .contain {
                            width: 90%;
                            max-width: 500px;
                            margin: 0 auto;
                            padding: 20px;
                            box-shadow: 0px 0px 20px #00bfff;
                            background-color: white;
                            border-radius: 8px;
                            margin-bottom: 20px;
                        }
                        
                        #envoie .infos h1 {
                            font-size: 2.5rem;
                            font-weight: bold;
                            color: #00bfff;
                            text-transform: uppercase;
                            text-align: center;
                        }
                        
                        #envoie .infos h2 {
                            font-size: 1.5rem;
                            font-weight: bold;
                            color: black;
                            text-align: left;
                        }
                        
                        #envoie .form-group {
                            width: 100%;
                            margin-top: 20px;
                            font-size: 20px;
                            font-weight: bold;
                        }
                        
                        .form-group input,
                        .form-group textarea {
                            width: 100%;
                            padding: 5px;
                            font-size: 10px;
                            border: 1px solid rgba(128, 128, 128, 0.199);
                            margin-top: 5px;
                        }
                        
                        textarea {
                            resize: vertical;
                        }
                        
                        button[type="submit"] {
                            width: 100%;
                            border: none;
                            outline: none;
                            padding: 20px;
                            font-size: 24px;
                            border-radius: 8px;
                            font-family: 'Montserrat';
                            color: rgb(27, 166, 247);
                            text-align: center;
                            cursor: pointer;
                            margin-top: 10px;
                            transition: .3s ease background-color;
                        }
                        
                        button[type="submit"]:hover {
                            background-color: rgb(214, 226, 236);
                        }
                        
                        #status {
                            width: 90%;
                            max-width: 500px;
                            text-align: center;
                            padding: 10px;
                            margin: 0 auto;
                            border-radius: 8px;
                        }
                        
                        #status.success {
                            background-color: rgb(211, 250, 153);
                            animation: status 4s ease forwards;
                        }
                        
                        #status.error {
                            background-color: rgb(250, 129, 92);
                            color: white;
                            animation: status 4s ease forwards;
                        }
                        
                        @keyframes status {
                            0% {
                                opacity: 1;
                                pointer-events: all;
                            }
                            90% {
                                opacity: 1;
                                pointer-events: all;
                            }
                            100% {
                                opacity: 0;
                                pointer-events: none;
                            }
                        }
                        /* Footer */
                        
                        #footer {
                            background-image: linear-gradient(60deg, #29323c 0%, #485563 100%);
                        }
                        
                        #footer .footer {
                            min-height: 200px;
                            flex-direction: column;
                            padding-top: 50px;
                            padding-bottom: 10px;
                        }
                        
                        #footer h2 {
                            color: white;
                            font-weight: 500;
                            font-size: 1.8rem;
                            letter-spacing: 0.1rem;
                            margin-top: 10px;
                            margin-bottom: 10px;
                        }
                        
                        #footer .social-icon {
                            display: flex;
                            margin-bottom: 30px;
                        }
                        
                        #footer .social-item {
                            height: 50px;
                            width: 50px;
                            margin: 0 5px;
                        }
                        
                        #footer .social-item img {
                            filter: grayscale(1);
                            transition: 0.3s ease filter;
                        }
                        
                        #footer .social-item:hover img {
                            filter: grayscale(0);
                        }
                        
                        #footer p {
                            color: white;
                            font-size: 1.3rem;
                        }
                        /* End Footer */
                        
                        @keyframes hamburger_puls {
                            0% {
                                opacity: 1;
                                transform: scale(1);
                            }
                            100% {
                                opacity: 0;
                                transform: scale(1.4);
                            }
                        }
                        
                        @keyframes text_reveal_box {
                            50% {
                                width: 100%;
                                left: 0;
                            }
                            100% {
                                width: 0;
                                left: 100%;
                            }
                        }
                        
                        @keyframes text_reveal {
                            100% {
                                color: white;
                            }
                        }
                        
                        @keyframes text_reveal_name {
                            100% {
                                color: #4682B4;
                                font-weight: 500;
                            }
                        }
                        /* End Keyframes */
                        
                        .left {
                            float: left;
                            width: 50%;
                        }
                        
                        .right {
                            float: right;
                            width: 50%;
                        }
                        
                        .project-img:after {
                            content: "";
                            display: table;
                            clear: both;
                        }
                        
                        img {
                            max-width: 100%;
                            height: auto;
                        }
                        /* Media Query For Tablet */
                        /* Media Query For Desktop */
                        
                        @media only screen and (min-width: 1200px) {
                            /* header */
                            #header .hamburger {
                                display: none;
                            }
                            #header .nav-list ul {
                                position: initial;
                                display: block;
                                height: auto;
                                width: fit-content;
                                background-color: transparent;
                            }
                            #header .nav-list ul li {
                                display: inline-block;
                            }
                            #header .nav-list ul li a {
                                font-size: 1.8rem;
                            }
                            #header .nav-list ul a:after {
                                display: none;
                            }
                            #header.logo {
                                width: 50%!important;
                                margin: auto;
                                padding: auto;
                            }
                            /* End header */
                            #services .service-bottom .service-item {
                                flex-basis: 22%;
                                margin: 1.5%;
                            }
                        }
                        /* End  Media Query For Desktop */