/* Charte graphique Green Service */
:root { 
    --vert: #12db12; 
    --gris: #f8f9fa; 
    --gris-fonce: #e9ecef;
    --blanc: #ffffff; 
    --noir: #333; 
    --fond-sombre: #1e2125; 
    --carte-sombre: #2b3035; 
    --bordure-sombre: #3c4146; 
    --font-family: 'Montserrat', sans-serif;
    --shadow-soft: 0 4px 10px rgba(0,0,0,0.05);
    --shadow-card: 0 10px 30px rgba(0,0,0,0.07);
    --transition-fast: 0.3s ease-in-out;
}

body { font-family: var(--font-family); background: var(--gris); margin: 0; color: var(--noir); scroll-behavior: smooth; overflow-x: hidden; }

/* Eviter que le menu ne cache les titres au scroll */
html { scroll-padding-top: 80px; }

/* Header et Logo */
header { background: var(--blanc); padding: 15px 5%; display: flex; justify-content: space-between; align-items: center; box-shadow: 0 2px 5px rgba(0,0,0,0.1); position: sticky; top: 0; z-index: 1000; }
header img { height: 75px; width: auto; }

nav a { margin-left: 20px; text-decoration: none; color: var(--noir); font-weight: bold; transition: var(--transition-fast); }
nav a:hover { color: var(--vert); }

/* Accueil avec photo de couverture */
#accueil { 
  text-align: center; color: var(--blanc); padding: 180px 20px; 
  background: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)), url('cover.jpg') no-repeat center center/cover;
}
#accueil h1 { font-size: 3.5em; text-transform: uppercase; text-shadow: 2px 2px 4px rgba(0,0,0,0.5); font-weight: 700; margin: 0; }

/* Boutons arrondis */
.btn { background: var(--vert); color: var(--blanc); padding: 12px 28px; text-decoration: none; border-radius: 30px; font-weight: bold; display: inline-block; border: none; cursor: pointer; transition: var(--transition-fast); text-align: center; }
.btn:hover { background: #10c410; transform: translateY(-2px); box-shadow: 0 4px 10px rgba(0,0,0,0.2); }
.btn-outline { background: transparent; border: 2px solid var(--blanc); margin-left: 10px; }

.btn-google { background: var(--blanc); color: var(--vert); border: 2px solid var(--vert); margin-bottom: 20px; display: block; width: 100%; box-sizing: border-box; }
.btn-google:hover { background: var(--vert); color: var(--blanc); }

/* Sections communes */
section { padding: 80px 5%; max-width: 1200px; margin: auto; }
h2 { text-align: center; margin-bottom: 40px; font-size: 2.2em; font-weight: 700; color: var(--noir); }
h2.vert { color: var(--vert); }
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }

/* Peaufinage des ombres sur les cartes */
.card { background: var(--blanc); padding: 25px; border-radius: 10px; box-shadow: var(--shadow-soft); transition: var(--transition-fast); }

/* Effet de soulèvement au survol sur toutes les cartes */
.card:hover, .card-sombre:hover, .service-card:hover, .valeur-card:hover, .contact-card:hover, .vehicule-card:hover { 
    transform: translateY(-5px); 
    box-shadow: var(--shadow-card); 
}

/* Chiffres clés */
.stats { background: var(--vert); color: var(--blanc); padding: 40px 5%; display: flex; justify-content: space-around; text-align: center; flex-wrap: wrap; }
.stats h3 { font-size: 2.5em; margin: 0; font-weight: 700; }

/* Correction pleine largeur pour les sections avec fond de couleur */
#services, #zones, #contact, #engagements-sombre, #vehicules { max-width: 100%; }

/* SECTION NOS SERVICES */
#services { background-color: var(--gris-fonce); text-align: center; }
#services p.sous-titre { color: #666; margin-bottom: 50px; font-size: 1.1em; max-width: 700px; margin-left: auto; margin-right: auto; }

.grid-services { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; max-width: 1100px; margin: auto; }
.service-card { background: var(--blanc); border: 1px solid #eee; padding: 40px 30px; border-radius: 5px; text-align: left; transition: var(--transition-fast); box-shadow: var(--shadow-soft); display: flex; flex-direction: column; }
.service-card:hover { border-color: var(--vert); }

.service-icon { width: 45px; height: 45px; min-width: 45px; background: #e0fee0; border-radius: 5px; display: flex; align-items: center; justify-content: center; margin-bottom: 25px; flex-shrink: 0; }
.service-icon svg { width: 25px !important; height: 25px !important; stroke: var(--vert); }

.service-card h3 { font-size: 1.25em; margin: 0 0 15px; font-weight: 600; color: var(--noir); }
.service-card p { font-size: 0.9em; color: #666; margin: 0 0 25px; flex-grow: 1; line-height: 1.6; }

.service-check { list-style: none; padding: 0; margin: 0; font-size: 0.9em; color: #333; }
.service-check li { display: flex; align-items: center; margin-bottom: 10px; }
.service-check li svg { width: 16px !important; height: 16px !important; stroke: var(--vert); margin-right: 10px; flex-shrink: 0; }

@media (max-width: 900px) { .grid-services { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .grid-services { grid-template-columns: 1fr; } }

/* SECTION À PROPOS */
#apropos { text-align: center; padding: 80px 5%; }
#apropos p.sous-titre { color: #666; margin-bottom: 50px; font-size: 1.1em; }

.about-top { display: grid; grid-template-columns: 2fr 1fr; gap: 30px; align-items: center; text-align: left; margin-bottom: 60px; }
.about-text h3 { font-size: 1.5em; font-weight: 700; margin: 0 0 20px; color: var(--noir); }
.about-text p { font-size: 1em; color: #666; margin: 0 0 15px; line-height: 1.6; }

.about-card-vert { background: var(--vert); color: var(--blanc); padding: 40px; border-radius: 10px; text-align: center; }
.about-card-vert h4 { font-size: 2.5em; margin: 0; font-weight: 700; }
.about-card-vert h5 { font-size: 1.1em; margin: 5px 0 15px; font-weight: 600; }
.about-card-vert p { font-size: 0.9em; color: rgba(255,255,255,0.8); margin: 0; line-height: 1.5; }

.grid-valeurs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; max-width: 1100px; margin: auto; }
.valeur-card { background: var(--blanc); padding: 30px 20px; border-radius: 5px; text-align: center; transition: var(--transition-fast); box-shadow: var(--shadow-soft); border: 1px solid #eee; }
.valeur-card:hover { border-color: var(--vert); }

.valeur-icon { width: 45px; height: 45px; min-width: 45px; background: var(--vert); border-radius: 5px; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; flex-shrink: 0; }
.valeur-icon svg { width: 24px !important; height: 24px !important; stroke: var(--blanc); }

.valeur-card h3 { font-size: 1.2em; margin: 0 0 10px; font-weight: 600; color: var(--noir); }
.valeur-card p { font-size: 0.85em; color: #666; margin: 0; line-height: 1.6; }

@media (max-width: 900px) { .about-top { grid-template-columns: 1fr; } .grid-valeurs { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .grid-valeurs { grid-template-columns: 1fr; } }

/* SECTION ENGAGEMENTS SOMBRE */
#engagements-sombre { background-color: var(--fond-sombre); color: var(--blanc); padding: 80px 5%; text-align: center; }
#engagements-sombre h2 { color: var(--blanc); margin-bottom: 10px; font-size: 2.5em; }
#engagements-sombre h2 span { color: var(--vert); }
#engagements-sombre p.sous-titre { color: #a0aab2; margin-bottom: 50px; font-size: 1.1em; }

.grid-engagements { display: grid; grid-template-columns: repeat(4, 1fr); gap: 15px; max-width: 1200px; margin: auto; }
.card-sombre { background: var(--carte-sombre); border: 1px solid var(--bordure-sombre); padding: 30px 20px; border-radius: 5px; transition: var(--transition-fast); display: flex; flex-direction: column; align-items: center; justify-content: center; box-shadow: var(--shadow-soft); }
.card-sombre:hover { border-color: var(--vert); }
.card-sombre svg { width: 35px !important; height: 35px !important; stroke: var(--vert); margin-bottom: 15px; flex-shrink: 0; }
.card-sombre h4 { color: var(--blanc); font-size: 1em; margin: 0; font-weight: 600; }

@media (max-width: 900px) { .grid-engagements { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .grid-engagements { grid-template-columns: 1fr; } }

/* SECTION PARTENAIRES */
#partenaires { text-align: center; padding: 60px 5%; }
.partenaires-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; align-items: center; justify-content: center; margin-top: 40px; }
.partenaire-logo { max-height: 50px; width: auto; filter: grayscale(100%); transition: var(--transition-fast); margin: auto; max-width: 100%; }
.partenaire-logo:hover { filter: grayscale(0%); }

/* Zones de livraison */
#zones { background-color: var(--vert); color: var(--blanc); text-align: center; padding: 60px 5%; }
#zones h2 { color: var(--blanc); margin-bottom: 20px; }
.pays-list { font-size: 1.3em; font-weight: bold; display: flex; flex-wrap: wrap; justify-content: center; gap: 15px; margin-top: 20px; }
.pays-list span { background: rgba(255,255,255,0.2); padding: 10px 20px; border-radius: 30px; }

@media (max-width: 900px) { .partenaires-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 500px) { .partenaires-grid { grid-template-columns: repeat(2, 1fr); } }

/* SECTION CONTACT REFONDUE */
#contact { background-color: var(--gris); text-align: center; }
#contact p.sous-titre { color: #666; margin-bottom: 50px; font-size: 1.1em; max-width: 700px; margin-left: auto; margin-right: auto; }

.grid-contact { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; max-width: 1100px; margin: auto; text-align: left; }
.contact-card { background: var(--blanc); padding: 40px; border-radius: 10px; box-shadow: var(--shadow-card); }
.contact-card h3 { font-size: 1.5em; font-weight: 700; margin: 0 0 30px; color: var(--noir); }

/* Formulaire contact */
form label { display: block; margin: 15px 0 5px; font-weight: bold; color: var(--noir); font-size: 0.9em; }
form label.required:after { content: ' *'; color: var(--vert); }

form .form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-bottom: 15px; }
form .form-grid-2 label { margin-top: 0; }

form input, form select, form textarea { width: 100%; padding: 12px; border: 1px solid #ccc; border-radius: 8px; box-sizing: border-box; font-family: var(--font-family); background: #fdfdfd; font-size: 0.9em; transition: var(--transition-fast); }
form input:focus, form select:focus, form textarea:focus { border-color: var(--vert); outline: none; box-shadow: 0 0 5px rgba(18,219,18,0.1); }

form .btn-submit { background: var(--vert); color: var(--blanc); padding: 12px 28px; text-decoration: none; border-radius: 30px; font-weight: bold; display: flex; align-items: center; justify-content: center; border: none; cursor: pointer; transition: var(--transition-fast); width: 100%; margin-top: 25px; font-size: 1em; }
form .btn-submit:hover { background: #10c410; transform: translateY(-2px); box-shadow: 0 4px 10px rgba(0,0,0,0.2); }
form .btn-submit svg { width: 18px !important; height: 18px !important; stroke: var(--blanc); margin-left: 10px; flex-shrink: 0; }

/* Coordonnées contact */
.contact-card .coord-list { list-style: none; padding: 0; margin: 0; font-size: 1em; color: #333; margin-bottom: 30px; }
.contact-card .coord-list li { display: flex; flex-direction: row; align-items: flex-start; margin-bottom: 25px; }

.contact-card .coord-list .icon-wrap { width: 45px !important; height: 45px !important; min-width: 45px !important; background: var(--vert); border-radius: 5px; display: flex; align-items: center; justify-content: center; margin-right: 20px; flex-shrink: 0; }
.contact-card .coord-list .icon-wrap svg { width: 22px !important; height: 22px !important; min-width: 22px !important; stroke: var(--blanc); flex-shrink: 0; }

.contact-card .coord-list .text-block { display: flex; flex-direction: column; justify-content: center; }
.contact-card .coord-list .text-block h4 { font-size: 1.05em; font-weight: 600; margin: 0 0 5px; color: var(--noir); }
.contact-card .coord-list .text-block p { font-size: 0.9em; color: #666; margin: 0; line-height: 1.4; }

/* Liens cliquables contact */
.contact-link { text-decoration: none; color: #666; transition: var(--transition-fast); }
.contact-link:hover { color: var(--vert); }

/* Carte Google Maps interactive */
.contact-card .map-container { border-radius: 10px; overflow: hidden; height: 250px; border: 1px solid var(--gris-fonce); box-shadow: var(--shadow-soft); transition: var(--transition-fast); margin-top: 20px; }
.contact-card .map-container:hover { transform: translateY(-3px); box-shadow: var(--shadow-card); }
.contact-card .map-container iframe { border:0; }

@media (max-width: 900px) { .grid-contact { grid-template-columns: 1fr; } .form-grid-2 { grid-template-columns: 1fr; } }
@media (max-width: 500px) { .contact-card { padding: 30px; } .form-grid-2 { grid-template-columns: 1fr; } }

/* FOOTER PROFESSIONNEL */
footer { background-color: var(--fond-sombre); color: #a0aab2; padding: 80px 5% 40px; text-align: center; }
.footer-content { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; max-width: 1200px; margin: auto; text-align: left; margin-bottom: 50px; }

.footer-col h4 { color: var(--blanc); font-weight: 600; font-size: 1.2em; margin: 0 0 25px; }

.footer-col img { height: 55px; width: auto; margin-bottom: 20px; }
.footer-col .slogan { font-size: 0.95em; color: var(--blanc); font-weight: 500; font-style: italic; margin-bottom: 10px; }
.footer-col p { font-size: 0.85em; margin: 0; line-height: 1.6; }

.footer-nav ul { list-style: none; padding: 0; margin: 0; font-size: 0.9em; }
.footer-nav li { margin-bottom: 12px; }
.footer-nav a { text-decoration: none; color: #a0aab2; transition: var(--transition-fast); }
.footer-nav a:hover { color: var(--vert); }

.footer-contact li { display: flex; align-items: start; margin-bottom: 20px; font-size: 0.9em; }
.footer-contact svg { width: 16px !important; height: 16px !important; stroke: var(--vert); margin-right: 15px; flex-shrink: 0; margin-top: 3px; }
.footer-contact .text-block p { font-size: 1em; color: var(--blanc); margin: 0; line-height: 1.5; }

/* Liens cliquables footer */
.contact-link-footer { text-decoration: none; color: #a0aab2; transition: var(--transition-fast); }
.contact-link-footer:hover { color: var(--vert); }

.dispo-tag { color: var(--vert); font-weight: 600; font-size: 1.1em; display: flex; align-items: center; margin-bottom: 15px; }
.dispo-tag svg { width: 18px !important; height: 18px !important; stroke: var(--vert); margin-right: 10px; flex-shrink: 0; }

.dispo-col p { font-size: 0.85em; color: #808a92; margin: 0; line-height: 1.6; }

.footer-bottom { text-align: center; padding-top: 30px; border-top: 1px solid var(--bordure-sombre); font-size: 0.8em; color: #666; margin-top: 30px; }

@media (max-width: 900px) { .footer-content { grid-template-columns: repeat(2, 1fr); } footer { padding: 60px 5% 30px; } }
@media (max-width: 500px) { .footer-content { grid-template-columns: 1fr; text-align: center; } .footer-contact li { justify-content: center; text-align: left; } .dispo-tag { justify-content: center; } .footer-col img { margin-left: auto; margin-right: auto; } }

/* Bouton permanent */
.btn-devis-fixe { position: fixed; bottom: 20px; right: 20px; z-index: 100; box-shadow: 0 4px 10px rgba(0,0,0,0.3); }

/* BANDEAU COOKIES */
#cookie-banner { position: fixed; bottom: -100%; left: 0; width: 100%; background: var(--fond-sombre); color: var(--blanc); padding: 20px 5%; box-sizing: border-box; display: flex; justify-content: space-between; align-items: center; z-index: 9999; transition: bottom 0.5s ease-in-out; box-shadow: 0 -5px 15px rgba(0,0,0,0.2); }
#cookie-banner.show { bottom: 0; }
.cookie-text { font-size: 0.9em; max-width: 70%; line-height: 1.5; }
.cookie-buttons { display: flex; gap: 10px; flex-shrink: 0; }
.btn-cookie-accept { background: var(--vert); color: var(--blanc); border: none; padding: 10px 20px; border-radius: 5px; cursor: pointer; font-weight: bold; transition: var(--transition-fast); }
.btn-cookie-accept:hover { background: #10c410; }
.btn-cookie-reject { background: transparent; color: var(--blanc); border: 1px solid var(--blanc); padding: 10px 20px; border-radius: 5px; cursor: pointer; font-weight: bold; transition: var(--transition-fast); }
.btn-cookie-reject:hover { background: rgba(255,255,255,0.1); }

@media (max-width: 768px) { #cookie-banner { flex-direction: column; text-align: center; gap: 15px; padding: 20px; } .cookie-text { max-width: 100%; } }

/* CSS POUR L'ANIMATION SCROLL REVEAL */
.reveal { opacity: 0; transform: translateY(40px); transition: all 0.8s ease-out; }
.reveal.active { opacity: 1; transform: translateY(0); }

/* MODIFICATIONS POUR LA FLOTTE DE VÉHICULES */
#vehicules { background-color: var(--gris); }

.vehicules-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-top: 40px; }

.vehicule-card { background: var(--blanc); border-radius: 5px; overflow: hidden; box-shadow: 0 4px 6px rgba(0,0,0,0.05); transition: var(--transition-fast); border: 1px solid var(--gris-fonce); }
.vehicule-card:hover { border-color: var(--vert); }

.card-image-wrap { height: 200px; overflow: hidden; }
.card-image-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.vehicule-card:hover .card-image-wrap img { transform: scale(1.05); }

.card-content { padding: 25px; display: flex; flex-direction: column; height: auto; }

.card-header { display: flex; justify-content: space-between; align-items: start; margin-bottom: 15px; }
.card-header h3 { font-size: 1.3em; margin: 0; font-weight: 700; color: var(--noir); text-align: left; }

.volume-tag { background-color: #e8f5e9; color: var(--vert); font-size: 0.8em; font-weight: 600; padding: 5px 12px; border-radius: 15px; white-space: nowrap; margin-left: 10px; }

.card-content p { color: #666; font-size: 0.9em; line-height: 1.6; margin: 0 0 20px 0; text-align: left; flex-grow: 1; }

.feature-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: auto; justify-content: start; }
.feature-tag { background-color: #f0f0f0; color: #666; font-size: 0.8em; padding: 6px 15px; border-radius: 5px; }

@media (max-width: 900px) { .vehicules-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .vehicules-grid { grid-template-columns: 1fr; } .card-image-wrap { height: 180px; } }

/* --- ADAPTATION MOBILE (SMARTPHONES) & MENU BURGER --- */
.menu-burger { display: none; flex-direction: column; cursor: pointer; gap: 5px; z-index: 1001; }
.menu-burger span { width: 25px; height: 3px; background-color: var(--noir); border-radius: 2px; transition: 0.3s; }

@media (max-width: 768px) {
    /* Afficher le bouton burger */
    .menu-burger { display: flex; }
    
    /* Cacher le menu classique à droite */
    nav#nav-menu {
        position: fixed; top: 0; right: -100%; width: 250px; height: 100vh;
        background-color: var(--blanc); box-shadow: -2px 0 10px rgba(0,0,0,0.1);
        display: flex; flex-direction: column; justify-content: center; align-items: center;
        transition: right 0.3s ease; z-index: 1000; margin: 0;
    }
    
    nav#nav-menu.ouvert { right: 0; }
    nav#nav-menu a { margin: 15px 0; font-size: 1.2em; }
    
    /* Ajuster la taille du texte d'accueil et l'espacement */
    #accueil { padding: 120px 20px; }
    #accueil h1 { font-size: 2.2em; }
    h2 { font-size: 1.8em; }
    
    /* Empiler les boutons d'accueil pour qu'ils rentrent à l'écran */
    #accueil .btn, #accueil .btn-outline { display: block; margin: 10px auto; width: 80%; box-sizing: border-box; }
}

/* Animation du burger en forme de croix quand c'est ouvert */
.menu-burger.ouvert span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.menu-burger.ouvert span:nth-child(2) { opacity: 0; }
.menu-burger.ouvert span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }