/* --- Variables CSS Globales --- */

:root {

    --color-primary: #B5B205;       /* Couleur principale (jaune/vert) */

    --color-primary-dark: #8a8704;  /* Variante foncée pour hover */

    --color-text: #333;            /* Texte principal */

    --color-text-light: #555;      /* Texte plus clair */

    --color-background: #ffffff;   /* Fond principal */

    --color-background-alt: #f8f8f8;/* Fond alternatif léger */

    --color-border: #ccc;          /* Bordures générales */

    --color-white: #ffffff;

    --color-dark: #333;



    --font-primary: 'Montserrat', sans-serif;

    --font-secondary: 'Roboto Flex', sans-serif;



    --nav-height: 80px;             /* Hauteur de la barre de navigation */

    --nav-height-mobile: 70px;     /* Hauteur optionnelle pour mobile si différente */

    --breakpoint-mobile: 768px;     /* Point de bascule pour le menu hamburger */



    --container-max-width: 1200px;  /* Largeur maximale du contenu */

    --spacing-unit: 1rem;           /* Unité d'espacement (ex: 16px) */

}



/* --- Reset CSS Minimal --- */

*,

*::before,

*::after {

    box-sizing: border-box;

    margin: 0;

    padding: 0;

}



html {

    font-size: 100%; /* Base pour les unités rem (généralement 16px) */

    scroll-padding-top: var(--nav-height); /* Compense la nav fixe pour les ancres internes */

    scroll-behavior: smooth; /* Défilement doux pour les ancres */

}



body {

    font-family: var(--font-primary);

    color: var(--color-text);

    background-color: var(--color-background);

    line-height: 1.6;

    /* Compensation pour la nav fixe (s'assure que le contenu n'est pas caché dessous) */

    padding-top: var(--nav-height);

}



img {

    max-width: 100%;

    height: auto;

    display: block; /* Supprime l'espace sous les images */

}



a {

    color: var(--color-primary);

    text-decoration: none;

    transition: color 0.3s ease;

}



a:hover {

    color: var(--color-primary-dark);

}



button {

    font-family: inherit;

    cursor: pointer;

    border: none;

    background: none;

}

.btn-submit {

    display: inline-block;

    background-color: #b5b205; /* Couleur bouton (adaptez) */

    color: white;

    padding: 12px 25px;

    border: none;

    border-radius: 4px;

    cursor: pointer;

    font-size: 1.1em;

    font-weight: bold;

    transition: background-color 0.3s ease, transform 0.2s ease;

}



.btn-submit:hover {

    background-color: #333; /* Couleur au survol */

    transform: translateY(-2px); /* Léger effet de soulèvement */

}



/* --- Conteneur Principal --- */

.site-content {

    min-height: calc(100vh - var(--nav-height) - 50px); /* Hauteur min: viewport - nav - footer (ajuster hauteur footer si besoin) */

    padding: calc(var(--spacing-unit) * 2) var(--spacing-unit); /* Espacement haut/bas et côtés */

}



/* --- Header & Navigation --- */

.site-header {

    position: fixed;

    top: 0;

    left: 0;

    width: 100%;

    height: var(--nav-height);

    background-color: var(--color-background);

    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);

    z-index: 1000;

    display: flex; /* Pour centrer verticalement la nav */

    align-items: center; /* Pour centrer verticalement la nav */

}



.main-navigation {

    display: flex;

    justify-content: space-between;

    align-items: center;

    width: 100%;

    max-width: var(--container-max-width); /* Limite largeur nav */

    margin: 0 auto; /* Centre la nav */

    padding: 0 calc(var(--spacing-unit) * 1.5); /* Padding horizontal nav */

    height: 100%; /* Prend toute la hauteur du header */

}



/* Logo */

.nav-icon {

    display: flex;

    align-items: center;

    color: var(--color-text);

    font-weight: 600;

    font-size: 1.25rem; /* Utilisation de rem */

}



.nav-icon img {

    height: calc(var(--nav-height) * 0.65); /* Logo proportionnel à la hauteur nav */

    width: auto;

    margin-right: calc(var(--spacing-unit) * 0.5);

}



/* Conteneur liens + hamburger */

.main-navlinks {

    display: flex;

    align-items: center;

}



/* Conteneur des liens */

.navlinks-container {

    display: flex; /* Affiché en ligne par défaut */

}



.nav-link {

    display: block;

    padding: calc(var(--spacing-unit) * 0.5) var(--spacing-unit); /* Espacement interne */

    margin: 0 calc(var(--spacing-unit) * 0.25); /* Léger espace externe */

    color: var(--color-text);

    font-weight: 500;

    white-space: nowrap; /* Empêche les retours à la ligne */

}



.nav-link:hover,

.nav-link.active {

    color: var(--color-primary);

}

.nav-link.active {

    font-weight: 700; /* Met en gras le lien actif */

    /* ou text-decoration: underline; */

}



/* Authentification (optionnel) */

.nav-authentication {

    /* Styles si nécessaire */

    display: none; /* Caché pour cet exemple */

}



/* --- Bouton Hamburger & Styles Mobile --- */

.hamburger {

    display: none; /* Caché par défaut sur desktop */

    padding: var(--spacing-unit);

    margin-left: var(--spacing-unit);

    z-index: 1010; /* Au-dessus du menu */

}



.hamburger span {

    display: block;

    width: 25px;

    height: 3px;

    background-color: var(--color-dark);

    margin: 5px 0;

    transition: transform 0.3s ease, opacity 0.3s ease;

}



/* Media Query pour le mobile */

@media (max-width: 768px) { /* Utilisation de la variable possible ici aussi si support navigateur ok */

    /* Ajuster hauteur nav et padding body sur mobile si besoin */

    /* :root { --nav-height: var(--nav-height-mobile); } */

    /* body { padding-top: var(--nav-height-mobile); } */



    .hamburger {

        display: block; /* Afficher le hamburger */

    }



    .main-navigation {

        padding: 0 var(--spacing-unit); /* Moins de padding horizontal sur mobile */

    }



    .navlinks-container {

        display: none; /* Caché par défaut */

        position: absolute;

        top: var(--nav-height); /* Se positionne sous la nav */

        left: 0;

        width: 100%;

        background-color: var(--color-background);

        box-shadow: 0 4px 5px rgba(0, 0, 0, 0.1);

        flex-direction: column; /* Liens en colonne */

        padding: var(--spacing-unit) 0;

        border-top: 1px solid var(--color-border); /* Ligne de séparation */

    }



    /* Quand le menu est ouvert (classe 'active' ajoutée par JS) */

    .navlinks-container.active {

        display: flex;

    }



    .nav-link {

        margin: 0;

        padding: calc(var(--spacing-unit) * 0.75) calc(var(--spacing-unit) * 1.5);

        width: 100%;

        border-bottom: 1px solid #eee; /* Séparateur */

    }

    .nav-link:last-child {

        border-bottom: none;

    }



    /* Animation du hamburger en 'X' */

    .hamburger.active span:nth-child(1) {

        transform: translateY(8px) rotate(45deg);

    }

    .hamburger.active span:nth-child(2) {

        opacity: 0;

    }

    .hamburger.active span:nth-child(3) {

        transform: translateY(-8px) rotate(-45deg);

    }

}

.slide-content h2 {
  color: var(--color-primary); 
}


/* --- Footer --- */

.site-footer-bottom {

    background-color: var(--color-dark);

    color: var(--color-white);

    text-align: center;

    padding: calc(var(--spacing-unit) * 1.5) var(--spacing-unit);

    font-size: 0.9rem;

}



.site-footer-bottom p {

    margin-bottom: calc(var(--spacing-unit) * 0.5);

}

.site-footer-bottom a {

    color: var(--color-primary);

}

.site-footer-bottom a:hover {

    color: var(--color-white);

}



/* Sections */

section {

  padding: 40px;

  text-align: center;

}



section h2 {

  margin-bottom: 20px;

}



/* A Propos */

.a-propos p {

  max-width: 800px;

  margin: 0 auto 20px;

}

/* Services */

.service-grid {

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));

  gap: 20px;

  margin-top: 20px;

}



.service-item {

  border: 1px solid #ddd;

  padding: 20px;

  border-radius: 5px;

}



.service-item img {

  max-width: 100%;

  height: auto;

  margin-bottom: 10px;

}