/* GLOBAL */


:root {
    --white: #ecf4fe;
    --black: #060d18;
    --grey: #d5d5d5;
    --dark: #333a3f;
    --accent: #cfad13;


    --bg-color1: var(--black);
    --bg-color2: var(--accent);
    --bg-color3: var(--dark);


    --color1: var(--white);
    --color2: var(--accent);
    --color3: var(--grey);


    --automatic-container: min(1200px, 100% - 8rem);
}



@media (max-width: 1024px) {
    :root {
        --automatic-container: calc(100% - 4rem);
    }
}

@media (max-width: 596px) {
    :root {
        --automatic-container: calc(100% - 2rem);
    }
}




/* RESET */


* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}



input::placeholder,
textarea::placeholder {
    color: var(--color1);
    /* Change à la couleur souhaitée */
    opacity: 1;
    /* Facultatif : pour s'assurer que la couleur soit bien visible */
}


ul {
    list-style: none;
}

a {
    text-decoration: none;
}

/* 
POUR LES IMAGES CREER UNE CHAINE LOGIQUE DES NOMS DES IMAGES
PAR EXEMPLE [NOM_DE_LA_PAGE | NOM_DE_LA_SECTION]-[QUALIFICATIF_DE_LA_SECTION]


LES SVG SOIENT VRAIMENT GENERIQUES

*/









/* TYPOGRAPHIE */


/* EN FONCTION DE LA TAILLE DES TEXTES */

.page-title {
    font-size: 4.5rem;
}

.section-title {
    font-size: 2.25rem;
    font-weight: 300;
}

.note {
    font-size: 1.1rem;
}

.card-title {
    font-size: 1.5rem;
}

.nav-link,
.cta-2 {
    font-size: 1.5rem;
}

@media (max-width: 1024px) {
    .page-title {
        font-size: 3.5rem;
    }

    .section-title {
        font-size: 1.85rem;
    }

    .note {
        font-size: 1rem;
    }

    .card-title {
        font-size: 1.25rem;
    }

    .nav-link,
    .cta-2 {
        font-size: 1.25rem;
    }
}

@media (max-width: 768px) {
    .page-title {
        font-size: 3.25rem;
    }

    .section-title {
        font-size: 3rem;
    }

    .note {
        font-size: 1.25rem;
    }

    .card-title {
        font-size: 1.5rem;
    }

    .nav-link,
    .cta-2 {
        font-size: 1.25rem;
    }
}

/* FIN CONCERNANT LA TAILLE DES TEXTES */


/* EN FONCTION DU STYLE DES TEXTES */

.page-title,
.section-title {
    text-transform: uppercase;
}

.card-title,
.cta-note {
    text-transform: capitalize;
}

.note {
    text-transform: none;
}


/* FIN CONCERNANT LE STYLE DES TEXTES */


/* EN FONCTION DE LA HAUTEUR DE LIGNE ET DE L'ESPACEMENT DES CARACTERES */

/* FIN CONCERNANT LA HAUTEUR DE LIGNE ET DE L'ESPACEMENT DES CARACTERES */




/* FIN TYPOGRAPHIE */





/* LE SECTIONNEMENT */

.cta {}

.section-page {}

.section-note {}

.card {}



/* EN FONCTION DE LA MARGE EXTERIEURE */

/* FIN CONCERNANT LA MARGE EXTERIEURE */



/* EN FONCTION DE LA MARGE INTERIEURE */

/* FINC CONCERNANT LA MARGE INTERIEURE */



/* EN FONCTION DU COLORIAGE FOND ET TEXTE */

/* FIN CONCERNANT COLORIAGE FOND ET TEXTE */



/* EN FONCTION DE L'ESPACEMENT (GAP) */

/* FIN CONCERNANT L'ESPACEMENT (GAP) */



/* FIN SECTIONNEMENT */






/* DISPOSITION & POSISTIONNEMENT */



/* ALIGNEMENT DE TEXTE */

/* FIN ALIGNEMENT DE TEXTE */



/* FIN CONCERNANT DISPOSIONT & POSITIONNEMENT */










section.hero {
    position: relative;
    overflow: hidden;
    color: white;
    display: flex;
    align-items: center;
    padding-top: 0;
    padding-bottom: 10%;
    max-width: 100%;
    margin-inline: auto;
    padding-left: 10%;
    z-index: 1;
}




/* Contenu texte */
section.hero .hero-note {
    /* max-width: 55%; */
    flex: 1;
    height: 100%;
    z-index: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-top: 5%;
    gap: 5rem;
    /* clip-path: polygon(97% 0, 93% 53%, 100% 100%, 0% 100%, 0 54%, 0% 0%); */

}

.page-title {
    padding-block: 1.5rem;
    padding-right: 2.5%;
}

.section-note {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}


.cta {
    align-self: start;
    padding: 1vw 1.75vw;
    border-radius: 99px;
}



.note-hero-section {
    width: 50%;
}



.hero-bg {
    flex: 0.8;
    align-self: stretch;
    background-image: url('../assets/accueil-hero_image.webp');
    /* Remplace avec ton image */
    background-size: 250%;
    aspect-ratio: 1/1;
    background-position-x: 50%;
    background-position-y: 50%;
    background-repeat: no-repeat;
    border-bottom-left-radius: 250px;
    /* border-bottom-left-radius: 40%; */
}


.cta-1 {
    display: flex;
    align-items: center;
    gap: 2rem;
    align-self: start;
}

.cta-span {
    display: grid;
    place-items: center;
    padding-right: 0.75rem;
    padding-block: 0.5rem;
    clip-path: circle();
    background-color: var(--accent);
}

.cta-span .cta-icon {
    margin-left: -25%;
    transition: .2s ease margin-left;
}

.cta-1:hover .cta-icon {
    margin-left: 0;
}


.cta-1 .cta-txt {
    font-size: 2rem;
    position: relative;
}

.cta-1 .cta-txt::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    background-color: var(--accent);
    width: 0;
    height: 0.35vw;
    transform: translateY(0.75rem);
    transition: .2s linear width;
}

.cta-1:hover .cta-txt::after {
    width: 100%;
}


@media (max-width: 1024px) {
    section.hero {
        flex-direction: column;
        padding-left: 0;
        max-width: var(--automatic-container);
        padding-top: 5%;
        margin-inline: auto;
        gap: 7.5vw;
    }

    section.hero .hero-note {
        padding-left: 0;
        flex: 1;
        gap: 5vw;
    }

    .note-hero-section {
        width: 100%;
    }

    .hero-note .section-note {
        gap: 2.5vw;
    }

    .hero-bg {
        flex: 0.8;
        aspect-ratio: 7/3;
        border-radius: 25px;
    }
}

@media (max-width: 768px) {
    section.hero {
        flex-direction: column;
        padding-left: 0;
        max-width: var(--automatic-container);
        margin-inline: auto;
        padding-top: 10%;
        gap: 10vw;
    }



    section.hero .hero-note {
        gap: 5vw;
        align-items: center;
    }

    .hero-note .section-note {
        gap: 2.5vw;
        text-align: center;
    }

    .note-hero-section {
        width: 100%;
    }

    .cta-1 {
        align-self: center;
    }

    .hero-bg {
        flex: 0.8;
        background-size: 250%;
        aspect-ratio: 5/3;
        border-radius: 20px;
    }

    .cta-span {
        padding-right: 0.5rem;
        padding-block: 0.25rem;
    }

    .cta-1 .cta-txt {
        font-size: 1.5rem;
    }

    .cta-span .cta-icon {
        width: 30px;
        height: 30px;
    }

}


@media (max-width: 596px) {
    section.hero {
        padding-top: 15%;
        gap: 15vw;
    }

    section.hero .hero-note {
        gap: 10vw;
    }

    .hero-note .section-note {
        gap: 3.5vw;
    }

    .note-hero-section {
        width: 100%;
    }

    .hero-bg {
        flex: 1;
        background-size: 250%;
        aspect-ratio: 5/4;
        border-radius: 20px;
    }

}







section.benefice {
    max-width: 100%;
    margin-inline: 0;
    display: flex;
    align-items: center;
    flex-direction: column;
    background-color: var(--bg-color3);
    padding-inline: calc(calc(100% - var(--automatic-container)) / 2);
}

section.stats {
    display: flex;
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    gap: 5vw;
}

.stat-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 200px;
}

.stat-card h4 {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5vw;
}

.stat-card h4 span:first-child {
    font-size: 5rem;
}

.stat-card h4 span:last-child {
    font-size: 2.5rem;
}


@media (max-width: 768px) {

    .stat-card h4 span:first-child {
        font-size: 3.5rem;
    }

    .stat-card h4 span:last-child {
        font-size: 2rem;
    }
}













section.products .section-note {
    text-align: center;
}



section.products {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    gap: 5vw;
    margin-bottom: 5%;
}


section.cards {
    display: flex;
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    gap: 5vw;
}

section.cards .card {
    max-width: 300px;
    background-color: var(--bg-color3);
    padding: 1rem;
    border-radius: 0.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: start;
    gap: 1.5rem;
}

section.cards .card-note {
    font-size: 1rem;
}



.middle-hero {
    background: #e0b909;
    max-width: 100%;
    display: flex;
}
















button {
    border: none;
    background-color: transparent;
}



html {
    font-size: 16px;
    font-family: "DM Sans", sans-serif;
}


/* TYPOGRAPHIE */
h1 {
    font-size: 5.5rem;
    line-height: 110%;
}

h2 {
    font-size: 3rem;
    font-weight: 300;
}

h3 {
    font-size: 2rem;
}

.service-price {
    font-size: 2rem;
    color: var(--color2);
    font-weight: 600;
}

.product-price {
    color: var(--color2) !important;
    font-weight: 600;
}

p,
span {
    font-size: 1.25rem;
}

.nav-link,
button,
.cta-nav {
    font-size: 1.5rem;
}


@media (max-width: 1024px) {

    h1 {
        font-size: 3.5rem;
    }

    h2 {
        font-size: 2rem;
    }

    h3 {
        font-size: 1.5rem;
        margin-bottom: 2.5vw;
    }

    .service-price {
        font-size: 1.5rem;
    }

    p,
    span {
        font-size: 1.25rem;
    }

    .nav-link,
    button,
    .cta-nav {
        font-size: 1.25rem;
    }
}

@media (max-width: 596px) {

    h1 {
        font-size: 2.5rem;
    }

    h2 {
        font-size: 1.75rem;
    }

    .service-price {
        font-size: 1.25rem;
    }

    h3 {
        font-size: 1.25rem;
        margin-bottom: 5vw;
    }

    p,
    span {
        font-size: 1.175rem;
    }

    .nav-link,
    button,
    .cta-nav {
        font-size: 1.25rem;
    }
}

.span-cta .hero-cta,
.section-cta,
h1,
h2 {
    text-transform: uppercase;
}


.cta2,
.card-cta,
mark,
h3 {
    text-transform: capitalize;
}


.nav-link {
    font-size: 1.2rem;
}

/* COMPONENTS & BOX-MODEL */

.cta2,
.card-cta,
.brd-cta,
.brd-cta2 {
    padding: max(1vw, 12px) max(2vw, 24px);
    border-radius: 999px;
    cursor: pointer;
}

.cta {
    background-color: var(--bg-color2);
    color: var(--color1);
}

.cta2 {
    background-color: var(--bg-color2);
    color: var(--color1);
}

.brd-cta,
.card-cta {
    padding: max(1vw, 12px) max(1.5vw, 18px);
    background-color: var(--bg-color2);
}



mark {
    background-color: transparent;
    font-weight: 600;
    color: inherit;
}


a {
    color: var(--color1);
}


.cta:hover,
.cta2:hover,
.card-cta:hover,
.brd-cta:hover,
.brd-cta2:hover {
    background-color: var(--bg-color2);
    color: var(--color1);
}





/* CODE DE LA PAGE */

body {
    background-color: var(--bg-color1);
    overflow-x: hidden;
    color: var(--color1);
}


main>* {
    max-width: var(--automatic-container);
    margin-inline: auto;
    display: block;
    padding-block: 5%;
}

main {
    margin-top: 6.25%;
    max-width: 100%;
    overflow-x: hidden;
}

.row {
    display: flex;
}

.column {
    display: flex;
    flex-direction: column;
}

.relative {
    position: relative;
}

.absolute {
    position: absolute;
}



p.note {
    color: var(--color3);
}







@media (max-width: 1024px) {
    main {
        margin-top: 8.5%;
    }

    main>* {
        padding-block: 8.5%;
    }
}

@media (max-width: 596px) {
    main {
        margin-top: 15%;
    }

    main>* {
        padding-block: 15%;
    }
}








footer,
header.header {
    padding-inline: calc(calc(100% - var(--automatic-container)) / 2);
}


header.header {
    padding-block: 1.25rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    top: 0;
    width: 100%;
    transition: transform 0.3s ease, opacity 0.3s ease;
    transform: translateY(0);
    opacity: 1;
    background-color: var(--bg-color1);
    z-index: 12;
}

header.header.hidden {
    transform: translateY(-100%);
    opacity: 0;
}

.header .navigation,
.nav-links {
    display: flex;
    align-items: center;
    gap: 2vw;
}

.navigation .nav-link {
    color: var(--color1);
}

.navigation .nav-link:hover {
    color: var(--color2);
}


/* 


footer {
    padding-block: 7.5%;
    background-color: var(--bg-color1);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

footer .logo-big {
    color: var(--color1);
    font-weight: 600;
    font-size: 2rem;

}

.footer-left {
    color: var(--color1);
    display: flex;
    align-items: baseline;
    gap: 4rem;
}

footer .social-icon {
    cursor: pointer;
    margin-inline: 0.5rem;
    color: var(--color1);
}

.footer-right {
    display: flex;
    flex-direction: row-reverse;
    gap: 2rem;
    align-items: center;
}

.terms-link {
    color: var(--color1);
}

footer .social-icon:hover,
.terms-link:hover {
    color: var(--color2);
}

footer .social-icon .st0 {
    fill: var(--bg-color1);
}

footer .social-icon:hover .st0 {
    fill: var(--bg-color1);
}

footer .social-icon .st32 {
    stroke: var(--bg-color1);
}

footer .social-icon:hover .st32 {
    stroke: var(--bg-color1);
}


@media (max-width: 728px) {
    footer {
        padding-block: 7.5%;
        background-color: var(--bg-color1);
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between;
        gap: 2.5rem;
    }

    .footer-left {
        color: var(--color1);
        display: flex;
        align-items: center;
        gap: 2rem;
    }

    .footer-right {
        flex-direction: column;
    }

    header.header {

        padding-block: 1%;
    }
}
 */








/* --- BURGER --- */
.burger {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    z-index: 1002;
}

.burger span {
    width: 35px;
    height: 5px;
    background: var(--color1);
    border-radius: 3px;
    transition: all 0.3s ease;
}

.burger.open span:nth-child(1) {
    transform: translate(7.5px, 10px) rotate(45deg);
}

.burger.open span:nth-child(2) {
    opacity: 0;
}

.burger.open span:nth-child(3) {
    transform: translate(7.5px, -10px) rotate(-45deg);
}

/* --- OVERLAY MENU (mobile uniquement) --- */
.nav-overlay {
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100vw;
    background: var(--bg-color1);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
    transition: all 0.4s ease;
    z-index: 1000;
}

.nav-overlay.active {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.nav-overlay .over-l1 {
    display: flex !important;
    flex-direction: column;
    font-size: 1.5rem;
    text-decoration: none;
    color: var(--violet);
    text-align: center;
    cursor: pointer;
}


.logo {
    font-size: 2.5rem;
    font-weight: 600;
}


.cta-2 {
    padding: max(0.75vw, 0.75rem) max(1.5vw, 1.5rem);
    border: 2px solid var(--color1);
    border-radius: 7px;
    background-color: transparent;
    color: var(--color1);
}






@media (max-width: 1024px) {
    .cta-nav {
        display: none;
    }

    .navigation .nav-links,
    .header .navigation {
        display: none;
        /* cache le menu classique */
    }

    .burger {
        display: flex;
    }

    .nav-overlay {
        display: flex;
        margin-bottom: 0;
    }

    .Btn-Container {
        display: none !important;
        /* sécurité */
    }

    .logonav {
        width: 40vw;
        height: 8vw;
    }
}

@media (min-width: 1025px) {
    .nav-overlay {
        display: none !important;
        /* sécurité */
    }

}


@media (max-width: 1092px) {
    /* html {
        font-size: 15px;
    } */

    .navbar {
        padding: 1vh 3vw;
    }

    .nav-links {
        margin-right: 0;
    }

}

@media (max-width: 600px) {
    /* html {
        font-size: 13px;
    } */

}


/* FIN CODE DE LA .navbar */





.partnership {
    text-align: center;
    /* padding: 50px 20px; */
}

.partnership h2 {
    margin-top: 1.25rem;
    font-size: 2rem;
    font-weight: 300;
    margin-bottom: 20px;
}

.partners {
    padding-top: max(5%, 2rem);
    display: flex;
    justify-content: center;
    column-gap: 2rem;
    row-gap: 1rem;
    flex-wrap: wrap;
    /* filter:
        grayscale(200%) brightness(200%); */
}

.partners img {
    width: 16rem;
    height: 7.5rem;
}


.partners .partner {
    padding-block: 1.5rem;
    padding-inline: 2rem;
    display: grid;
    place-items: center;
    font-size: 1.5rem;
}










/* CODE DU FOOTER */
.banner {
    background-color: #0f0f0f;
    display: flex;
    justify-content: space-between;
    padding: 0;
    align-items: center;
    flex-wrap: wrap;
    background: var(--bg-color3);
    border-radius: 1rem;
    margin-block: 7.5%;
    overflow: hidden;
}

.banner-text {
    margin-left: 3rem;
    margin-block: 1rem;
    max-width: 500px;
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 2rem;
}

.banner-text h2 {
    font-size: 2.5em;
    font-weight: 300;
    color: #fff;
}

.banner-text h2 span {
    color: var(--color2);
}


.banner-image img {
    width: 40vw;
    aspect-ratio: 3/2;
    margin: 0;
    padding: 0;
    transform: scaleY(1.05);
}

.footer {
    padding-inline: calc(calc(100% - var(--automatic-container)) / 2);
    padding-block: 2.5%;
    padding-bottom: 5%;
    display: flex;
    gap: 10vw;
    align-items: center;
}

.footer-top {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    justify-content: space-between;
}

.footer-brand {
    max-width: 300px;
}

.footer-brand h2 {
    margin-bottom: 1.5rem;
}

.footer-links {
    display: flex;
    gap: 5vw;
}

.footer-links div h4 {
    font-size: 1.25rem;
    margin-bottom: 1.25rem;
    color: var(--color2);
}

.footer-links ul {
    list-style: none;
}

.footer-links li {
    margin-bottom: 8px;
    color: var(--color3);
    font-size: 1.5rem;
    cursor: pointer;
}

.footer-links li:hover {
    margin-bottom: 8px;
    color: var(--color2);
    cursor: pointer;
}

.footer-bottom {
    display: grid;
    place-items: center;
    row-gap: 2.5rem;
}

.legal-term {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
    align-items: center;
}

.footer-bottom p {
    font-size: 1rem;
    color: var(--color1);
}

.contact-info-header {
    display: grid;
    row-gap: 1.5rem;
}

@media (max-width: 768px) {
    .footer {
        flex-direction: column;
    }

    .banner {
        flex-direction: column;
        margin-block: 12.5%;
        padding-top: 10%;
    }

    .banner-text {
        margin-left: 0;
        margin-top: 2rem;
        padding-bottom: 5%;
    }

    .banner-text .cta-1 {
        align-self: start;
        transform: translateX(0);
        margin-bottom: 5%;
        font-size: 1rem;
    }

    .banner-image img {
        width: 100%;
        aspect-ratio: 2/1;
        margin-bottom: -5px;
    }

    .footer-top {
        width: 100%;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 10vw;

    }

    .footer-brand {
        text-align: center;

    }

    .footer-brand h2 {
        margin-bottom: 2.25rem;
    }

    .footer-links {
        gap: 10vw;
    }

    .footer-links li {
        font-size: 1rem;
    }
}











/* FIN CODE DU FOOTER */













.faq-section {
    /* max-width: 800px; */
    /* margin: auto; */
}

.start-line {
    color: var(--color3);
    font-size: 14px;
}


.faq-section .start-line {
    color: var(--color3);
    font-size: 14px;
    margin-bottom: 10px;
}


.faq-title {
    font-size: 3rem;
    font-weight: 300;
    margin-bottom: 50px;
}

.faq-item {
    margin-bottom: 40px;
}

.faq-question {
    font-size: 20px;
    font-weight: 400;
    margin-bottom: 8px;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}

.faq-number {
    color: var(--color2);
    font-size: 14px;
    margin-left: 10px;
    font-weight: 300;
}

.faq-answer {
    color: #888;
    font-size: 16px;
    max-width: 600px;
}

.faq-divider {
    height: 1px;
    background-color: var(--color2);
    margin: 30px 0;
}


@media(max-width: 768px) {

    .faq-section .start-line,
    .faq-title {
        text-align: center;
    }
}








.card-section {
    display: flex;
    gap: 5vw;
    flex-wrap: wrap;
    justify-content: center;
    align-content: center;
}

.card {
    background-color: var(--dark);
    border-radius: 1rem;
    overflow: hidden;
    /* width: 350px; */
    width: 100%;
    min-width: 325px;
    flex: 0 0;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
    position: relative;
}

.card.vdt-card {
    width: 350px;
}

.card.card-star {
    background-color: var(--bg-color2);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}

.card.card-star h3,
.card.card-star p {
    color: var(--bg-color1) !important;
}

.card-image {
    position: relative;
    padding: 0.75rem;
}

.card-image img {
    border-radius: 0.75rem;
    width: 100%;
    aspect-ratio: 3/2;
    object-fit: cover;
    display: block;
}

.card-content {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 10px;
}

.card-content h3 {
    color: var(--color1);
}

.card-content p {
    color: var(--color3);
}

.card-order-link {
    padding: 0.75rem 1.25rem;
    background-color: var(--bg-color2);
    color: var(--bg-color1);
    border: 2px solid var(--color2);
    border-radius: 10px;
    font-size: 1.25rem;
    font-weight: 600;
}

.card-order-link:hover {
    border: 2px solid var(--color1);
    background-color: var(--bg-color1);
    color: var(--color1);
}


.restau-menu-card {
    width: 100%;
    height: 100%;
    height: 75vw;
    max-width: 425px;
    max-height: 500px;
    color: white;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}


@media(max-width: 1024px) {}







.team-section {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    max-width: 1200px;
    margin: auto;
}

.team-title {
    flex: 1 1 300px;
}

.team-title h2 {
    line-height: 1.3;
}

.team-title span {
    font-weight: bold;
}

.team-members {
    display: flex;
    flex: 2 1 800px;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
}

.member {
    text-align: center;
    max-width: 250px;
}

.member img {
    width: 100%;
    height: auto;
    border-radius: 5px;
    filter: grayscale(100%);
}

.member h4 {
    margin-top: 1.5rem;
    font-size: 1.75rem;
    font-weight: 600;
    color: #fff;
}

.member p {
    font-size: 1.25rem;
    color: #bbb;
    margin-top: 1rem;
}


@media(max-width: 1328px) {
    .team-title {
        text-align: center;
        min-width: var(--automatic-container);
    }
}




.socials {
    display: flex;
    gap: max(2.5vw, 1rem);
}


.svg-link {
    color: var(--color1);
    width: 50px;
}

.svg-link:hover {
    color: var(--color2);
}





.features-hero {
    max-width: 100%;
    height: 400px;
    padding: 5% 15%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-image:
        url("../assets/ciel-ouvert.jpg"),
        linear-gradient(var(--accent));
    /* url('https://images.unsplash.com/photo-1519389950473-47ba0277781c'); */
    background-size: cover;
    background-position: center;
    background-blend-mode: overlay;
    /* optional: improves blend feel */
}

.features-hero .content {
    display: flex;
    align-items: center;
    justify-content: start;
    gap: 5vw;
    width: 100%;
}

.features-hero h2 {
    font-size: 5rem;
    font-weight: bold;
    color: var(--bg-color1);
    line-height: 1.2;
}

.circle-button {
    color: var(--color2);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    font-weight: bold;
    text-decoration: none;
    /* transition: transform 0.3s ease; */
}

.circle-button .cta-span {
    background-color: var(--bg-color1);
}

.circle-button:hover {
    /* transform: scale(1.1); */
}


@media (max-width: 596px) {
    .features-hero h2 {
        font-size: max(10vw, 3rem);
        font-weight: bold;
        line-height: 1.25;
    }

    .features-hero .content {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

}














section.video-section {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 7.5vw;
    margin-bottom: 0.5%;
}

section.video-section .section-note {
    text-align: center;
}

section.video-section .video {
    border: 2px solid var(--color1);
    border-radius: 1vw;
}



















section.vision {
    width: 100%;
    display: grid;
    grid-template-columns: 35% auto;
    gap: 5vw;
}

section.vision .vision-bg {
    background-image: url("../assets/vision-background.webp");
    background-position: 0.5%;
    /* width: 30%; */
    /* height: 50vw; */
    border-top-right-radius: 3vw;
    border-bottom-right-radius: 3vw;
}

section.vision .services {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 7.25vw;
}

.services .services-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 2vw;
}

.services .service-card {
    background-color: var(--bg-color3);
    padding: max(1.5vw, 1rem);
    border-radius: 1.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: start;
    gap: 2vw;

    box-shadow: 0 0 2px var(--color3);
}

.service-card .service-card-icon {
    background-color: var(--bg-color2);
    padding: 0.75rem;
    border-radius: 0.5rem;
}

@media(max-width: 768px) {
    section.vision {
        grid-template-columns: auto;
    }

    .vision-bg {
        display: none;
    }

    .services .services-cards {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 20px;
    }

    .services .service-card {
        align-items: center;
        padding: 30px;
        border-radius: 10px;
        flex: 1 1 250px;
        max-width: 300px;
        text-align: center;
    }

}




.contact-container {
    margin-block: 7.5%;
    display: flex;
    background-color: var(--bg-color3);
    border-radius: 1rem;
    padding: 40px;
    /* border: 1px solid var(--color3); */
    box-shadow: 0 0 5px 2px rgba(255, 255, 255, 0.1);
}

.contact-info {
    width: 50%;
    padding-right: 40px;
    border-right: 2px solid var(--bg-color2);
    display: flex;
    flex-direction: column;
    justify-content: space-between;

}

.contact-info h2 {
    margin-bottom: 20px;
    font-size: min(5.5vw, 4rem);
    font-weight: 300;
}

.contact-info p {}

.contact-details {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.contact-details .details {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1.5rem;
}

.contact-details p {
    display: flex;
    align-items: center;
    gap: 10px;
}

.contact-icons {
    display: flex;
    gap: 15px;
    font-size: 40px;
}

.contact-details p .contact-svg {
    cursor: pointer;
    width: 30px;
}

.contact-details p .contact-svg:hover {
    color: var(--color2);
}

.contact-form {
    width: 50%;
    min-height: 350px;
    padding-left: 40px;
}

.contact-form form {
    display: flex;
    flex-direction: column;
}

.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form textarea {
    background-color: var(--bg-color3);
    border-radius: 5px;
    border: 1px solid #ffffff2f;
    /* Bordure visible */
    padding: 10px;
    margin-bottom: 15px;
    font-size: 1.25rem;
    width: 100%;
    color: var(--color1);
}


.contact-form input::placeholder,
.contact-form textarea::placeholder {
    font-size: 1rem;
}

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form button:focus {
    outline: none;
    border: 1px solid var(--color3);
    /* Ou une couleur claire visible */
}


.input-row {
    display: grid;
    width: 100%;
    gap: 10px;
    grid-template-columns: 1fr 1fr;
}

.contact-form textarea {
    resize: vertical;
    min-height: 150px;
}

.contact-form button {
    align-self: start;
    cursor: pointer;
}




@media (max-width: 1024px) {
    .input-row {
        display: grid;
        width: 100%;
        gap: 10px;
        grid-template-columns: 1fr;
        grid-template-rows: 1fr 1fr;
    }
}

@media (max-width: 768px) {
    .contact-container {
        flex-direction: column;
    }

    .contact-info h2 {
        margin-bottom: 20px;
        font-size: min(10vw, 7rem);
    }

    .contact-info {
        width: 100%;
        padding-inline: 20px;
        padding-bottom: 10vw;
        border-right: none;
        border-bottom: 2px solid var(--bg-color2);
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        text-align: center;
        gap: 7.5vw;
    }

    .input-row {
        display: grid;
        width: 100%;
        gap: 10px;
        grid-template-rows: 1fr;
        grid-template-columns: 1fr 1fr;
    }

    .contact-form {
        width: 100%;
        min-height: 150px;
        padding-top: 10vw;
        padding-left: 0;
    }

    .contact-form button {
        align-self: center;
        cursor: pointer;
    }

    .contact-icons {
        font-size: 50px;
    }
}


@media (max-width: 596px) {
    .input-row {
        display: grid;
        width: 100%;
        gap: 10px;
        grid-template-columns: 1fr;
        grid-template-rows: 1fr 1fr;
    }

    .contact-icons {
        flex-direction: column;
        gap: 10px;
        font-size: 40px;
    }
}











.testimonials {
    display: flex;
    flex-direction: column;
    gap: 2.5vw;
    width: 100%;
    padding-inline: 5%;
    margin-bottom: 2.5%;
}


.testimonial-card {
    background-color: var(--bg-color3);
    padding: max(2.5vw, 1rem);
    border-radius: 12px;
    box-shadow: 0 0 2px var(--color3);
}

.user-info {
    display: flex;
    align-items: center;
    margin-bottom: 1.25rem;
    position: relative;
}

.user-details h3 {
    margin: 0;
    /* font-size: 1rem; */
}

.user-details>p {
    margin: 2px 0 0;
    font-size: 0.9rem;
    color: var(--color2);
}

.company-logo {
    position: absolute;
    right: 0;
    top: 5px;
    width: 40px;
    aspect-ratio: 1/1;
    border-radius: 50%;
    height: auto;
    color: var(--color2);
}

.testimonial>p {
    font-size: 1rem;
    line-height: 1.6;
    color: #c9d1d9;
}

.quote {
    font-size: 2rem;
    color: var(--color2);
    vertical-align: top;
}


section.services {
    display: flex;
    flex-direction: column;
    gap: 7.5vw;
    align-items: center;
}


section.services .section-note {
    text-align: center;
}

.service {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 1200px;
    gap: 5vw;
}

.image-container img {
    width: min(40vw, 500px);
    aspect-ratio: 6/7;
    border-radius: 16px;
    object-fit: cover;
}

.text-container {
    /* max-width: 500px; */
}

.text-container h2 {
    font-size: 32px;
    font-weight: 300;
    margin-bottom: 20px;
}

.text-container p {
    font-size: 16px;
    line-height: 1.6;
    margin-bottom: 30px;
    color: #ccc;
}

.button {
    display: inline-block;
    background-color: var(--color1);
    color: var(--bg-color1);
    padding: 10px 20px;
    border-radius: 20px;
    text-decoration: none;
    font-weight: bold;
    transition: background-color 0.3s ease;
}

.button:hover {
    background-color: var(--bg-color2);
    color: var(--color1);
}

@media(max-width: 1024px) {
    .image-container img {
        aspect-ratio: 6/9;
    }
}

@media(max-width: 768px) {
    .image-container img {
        aspect-ratio: 6/12;
    }

    .testimonials {
        margin-top: 2rem;
    }
}

@media(max-width: 596px) {
    .service {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        max-width: 1200px;
        gap: 5vw;
    }

    .image-container img {
        aspect-ratio: auto;
        width: 100%;
        height: 250px;
    }

    .text-container {
        display: grid;
        place-items: center;
        text-align: center;
        /* max-width: 500px; */
    }

    .service:last-child {
        flex-direction: column-reverse;
    }

}