/* Style général pour les liens */
a {
    color: inherit; /* Hérite de la couleur du texte */
    text-decoration: none; /* Enlève le soulignement */
}

/* Pour enlever l'effet de contour (outline) lors du focus */
a:focus {
    outline: none; /* Enlève la bordure bleue autour du lien */
}

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

/* Appliquer la police Roboto à tout le site */
body {
    font-family: 'Roboto', sans-serif;
}

/* Style pour la section principale */
.landing-page {
    position: relative;
    height: 100vh;
    width: 100%;
    overflow: hidden;
}

/* La vidéo en arrière-plan */
.background-video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
}

/* Contenu centré au milieu */
.content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #F56331;
    z-index: 1;
    height: 100%; /* Assure que le contenu occupe toute la hauteur disponible */
}

.content p {
    font-weight: 500;
    margin-bottom: 20px;
    margin-top: 8rem;
}

.content p span {
    font-size: 1.5rem;
}

/* Image dans le contenu */
.content-image {
    width: 100%;
    max-width: 200px; /* Limite la taille de l'image */
    height: auto; /* Conserve les proportions de l'image */
    margin-bottom: 30px; /* Espacement sous l'image */
}

/* Bouton d'appel à l'action (CTA) */
.cta-button {
    display: inline-flex;           /* Aligne l'image et le texte sur une seule ligne */
    align-items: center;            /* Centre l'image et le texte verticalement */
    padding: 15px 30px;
    background-color: #ff5722;
    color: #fff;
    border-radius: 50px !important;
    text-decoration: none;
    font-size: 1.2rem;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

/* Style pour l'image à l'intérieur du bouton */
.cta-button .icon {
    width: 20px;                    /* Taille de l'icône */
    height: auto;                   /* Garde les proportions de l'image */
    margin-left: 10px;              /* Ajoute de l'espace entre le texte et l'image */
}

/* Effet au hover sur les boutons CTA */
.cta-button:hover {
    color: #ff5722;
    background-color: #F4C7DE;
    box-shadow: 4px 4px 3px rgba(255, 87, 34, 1);
} 

/* Nouvelle section après les blocs */
.section-info {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap; /* Permet aux éléments de passer à la ligne suivante si nécessaire */
    gap: 20px; /* Espacement entre les éléments */
    padding: 3rem;
    text-align: left; /* Change le texte aligné à gauche au lieu de centré */
    background-color: lightgrey;
}

.section-info .menu-item {
    flex: 1 1 200px; /* Permet aux éléments de se redimensionner selon l'espace disponible */
    margin-bottom: 0; /* Enlève l'espacement en bas */
    font-size: 1rem;
    color: #F56331;
    text-align: left; /* Supprime le centrage du texte, aligné à gauche */
}

/* Style pour la nouvelle section avec deux blocs */
.two-blocks-section {
    display: flex;
    justify-content: center;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
}

/* Style pour chaque bloc dans la section two-blocks-section */
.two-blocks-section .block:nth-child(1) {
    background-color: #F8ECE0; /* Première couleur de fond (par exemple, orange) */
}

.two-blocks-section .block:nth-child(2) {
    background-color: #F8FFEC; /* Deuxième couleur de fond (par exemple, rose clair) */
}


/* Style pour chaque bloc */
.block {
    flex-basis: 50%; /* Chaque bloc occupe environ 48% de la largeur */
    padding: 5rem;
    background-color: #F4C7DE; /* Couleur d'arrière-plan */
    text-align: center;
}

/* Titre dans les blocs */
.block p span {
    color: #F56331;
    margin-bottom: 1rem;
}

/* Paragraphe dans les blocs */
.block p {
    font-size: 1rem;
    margin-bottom: 1.5rem;
}

/* Bouton dans les blocs */
.block .cta-button {
    display: inline-block;
    padding: 15px 30px;
    background-color: #ff5722;
    color: #fff;
    border-radius: 50px !important;
    text-decoration: none;
    font-size: 1.2rem;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.block .cta-button:hover {
    color: #ff5722;
    background-color: #F4C7DE;
    text-decoration: underline;
    text-decoration-thickness: 1.3px; /* Définit l'épaisseur du soulignement */
    text-underline-offset: 3px; /* Ajoute un espacement entre le texte et la ligne du soulignement */
    box-shadow: 4px 4px 3px rgba(255, 87, 34, 1);
} 

.footer {
    position: relative; /* Fixe le footer en bas de la page */
    bottom: 0; /* Place le footer tout en bas */
    left: 0; /* Aligne le footer à gauche */
    right: 0; /* Aligne le footer à droite */
    margin: auto; /* Centre horizontalement */
    width: 100%; /* La largeur du footer est ajustée à son contenu */
    text-align: center; /* Centre le texte à l'intérieur du footer */
    padding: 10px 20px; /* Ajoute de l'espace autour du texte */
    color: #F56331; /* Couleur du texte */
    background-color: lightgrey;
    font-size: 0.8rem; /* Taille du texte */
    z-index: 1; /* Assure que le footer reste au-dessus des autres éléments */
}

.footer p {
    margin: 0;
}

/* Responsiveness */
@media screen and (max-width: 768px) {
    .content h1 {
        font-size: 2rem;
    }

    .content p {
        font-size: 1rem;
    }

    .cta-button {
        font-size: 1rem;
        padding: 12px 25px;
    }

    .top-menu {
        justify-content: space-between; /* Espacement égal entre les éléments */
    }

    .menu-item {
        margin-bottom: 10px; /* Ajoute un espacement vertical entre les éléments */
    }

    .footer {
        font-size: 0.9rem;
        padding: 8px 0; /* Ajuste l'espace autour du texte sur les petits écrans */
    }
}

/* Responsiveness pour les petits écrans (moins de 480px) */
@media screen and (max-width: 480px) {
    .content h1 {
        font-size: 1.5rem;
    }

    .content p {
        font-size: 0.9rem;
        width: max-content;
        margin-top: 5rem;
    }

    .content p span {
        font-size: 1rem;
        font-weight: bold;
    }

    .cta-button {
        font-size: 1rem;
        padding: 10px 20px;
    }

    .menu-item {
        font-size: 1rem;
        width: 45%; /* Chaque élément prend 45% de la largeur */
        margin-bottom: 10px; /* Espacement sous chaque élément */
        text-align: center !important; 
    }

    .top-menu {
        flex-direction: row; /* Met les éléments en ligne */
        justify-content: space-between; /* Espacement égal entre les éléments */
    }

    .top-menu .menu-item:nth-child(3),
    .top-menu .menu-item:nth-child(4) {
        margin-top: 10px; /* Ajoute un petit espacement entre les lignes */
    }

    .footer {
        font-size: 0.8rem;
        padding: 5px 0; /* Ajuste l'espace autour du texte sur les petits écrans */
    }

    /* Pour afficher les 2 premiers éléments sur une ligne, les 2 derniers sur une autre ligne */
    .top-menu {
        flex-wrap: wrap; /* Permet à la flexbox de gérer les éléments sur plusieurs lignes */
        gap: 0;
    }

    .top-menu .menu-item:nth-child(1),
    .top-menu .menu-item:nth-child(2) {
        flex-basis: 39%; /* Prend environ 48% de la largeur */
        font-weight: 300;
    }

    .top-menu .menu-item:nth-child(3),
    .top-menu .menu-item:nth-child(4) {
        flex-basis: 39%; /* Prend environ 48% de la largeur */
        font-weight: 300;
    }

    .contact-menu {
        right: 7rem !important;
    }
}

/* Réduire la taille des blocs et ajuster pour les petits écrans */
@media screen and (max-width: 768px) {
    .two-blocks-section {
        flex-direction: column;
        align-items: center;
    }

    .block {
        flex-basis: 100%;
    }

    .block p {
        width: max-content;
        font-size: 0.8rem;
    }
}

/* Contact Menu */
.contact-menu {
    position: absolute;
    top: 20px; /* Espacement du haut de la page */
    right: 10rem; /* Espacement de la droite */
    display: flex;
    align-items: center;
    z-index: 2; /* Pour s'assurer qu'il se trouve au-dessus de la vidéo */
    color: #fff; /* Couleur du texte */
}

.contact-text {
    margin-right: 20px; /* Espace entre le texte et le bouton */
    font-size: 0.8rem; /* Taille du texte */
    color: #ff5722;
    font-weight: 100;
}

.contact-menu .cta-button {
    display: inline-flex;           /* Aligne l'image et le texte sur une seule ligne */
    align-items: center;            /* Centre l'image et le texte verticalement */
    padding: 10px 40px;
    background-color: #ff5722;
    color: #fff;
    text-decoration: none;
    border-radius: 50px;
    font-size: 1rem;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.contact-menu .cta-button .icon {
    width: 20px;                    /* Taille de l'icône */
    height: auto;                   /* Garde les proportions de l'image */
    margin-left: 10px;              /* Ajoute de l'espace entre le texte et l'image */
}

.contact-menu .cta-button:hover {
    color: #ff5722;
    background-color: #F4C7DE;
    box-shadow: 4px 4px 3px rgba(255, 87, 34, 1);
}
