/* --- CONFIGURATION GÉNÉRALE --- */
html { scroll-behavior: smooth; }
body { margin: 0; padding: 0; font-family: 'Inter', sans-serif; background-color: #f9fafb; color: #333; overflow-x: hidden; }

/* --- 1. HEADER --- */
.header-section { position: sticky; top: 0; z-index: 9999; background: #fff; box-shadow: 0 2px 10px rgba(0,0,0,0.05); padding: 15px 64px; display: flex; justify-content: space-between; align-items: center; }
.header-contact-link { text-decoration: none; color: inherit; transition: opacity 0.2s; }
.header-contact-link:hover { opacity: 0.8; }
.header-contact-text { font-size: 16px; white-space: nowrap; }
.contact-label { font-weight: 700; color: #85b729; margin-right: 5px; }
.contact-phone { font-weight: 800; color: #000; }

/* --- 2. HERO SECTION --- */
.hero-section { position: relative; background: linear-gradient(rgba(0,0,0,0.6), rgba(0,0,0,0.6)), url('/img/La-vallee-de-la-Sarthe.webp') center/cover; padding: 100px 24px; text-align: center; color: #ffffff !important; min-height: 400px; display: flex; align-items: center; justify-content: center; }
.hero-title, .hero-subtitle { color: #ffffff !important; }
.hero-title { font-size: clamp(32px, 5vw, 56px); line-height: 1.1; font-weight: 800; margin-bottom: 24px; }
.hero-cta { background: #fff; color: #111; padding: 16px 32px; text-decoration: none; border-radius: 8px; font-weight: 700; transition: 0.3s; display: inline-block; }
/* --- 3. SECTION SÉCURITÉ --- */
.security-section { background: #fff; padding: 60px 24px; display: flex; justify-content: center; }
.security-container { max-width: 1200px; width: 100%; display: flex; align-items: center; gap: 48px; }
.security-image { flex: 1; max-width: 450px; }
.security-image img { width: 100%; height: auto; border-radius: 8px; }
.security-content { flex: 1; }
.security-title { color: #85b729; font-size: clamp(24px, 4vw, 36px); font-weight: 700; margin-bottom: 24px; line-height: 1.2; }
.security-text { font-size: clamp(16px, 2.5vw, 20px); line-height: 1.5; margin: 0; color: #333; }

/* --- TITRES --- */
.section-header { padding: 40px 24px 20px; display: flex; justify-content: center; }
.section-container { max-width: 1200px; width: 100%; }
.section-heading { font-size: clamp(24px, 4vw, 36px); font-weight: 700; color: #000; margin: 0; }

/* --- CARTES --- */
.cards-section { padding: 0 24px 48px; display: flex; justify-content: center; }
.cards-container { max-width: 1200px; width: 100%; display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.card { background: #fff; border-radius: 16px; box-shadow: 0 4px 15px rgba(0,0,0,0.05); overflow: hidden; display: flex; flex-direction: column; }
.card-image { width: 100%; height: 220px; object-fit: cover; }
.card-content { padding: 24px; flex-grow: 1; }
.card-title { font-size: 24px; font-weight: 700; margin: 0 0 16px; color: #000; }
.card-text { font-size: 15px; line-height: 1.6; color: #6b7280; }

/* --- SOLUTIONS --- */
.pricing-section { padding: 0 24px 80px; display: flex; justify-content: center; }
.pricing-container { max-width: 1200px; width: 100%; display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.price-card { background: #fff; border-radius: 16px; padding: 40px 24px; box-shadow: 0 10px 30px rgba(0,0,0,0.08); border: 1px solid #eee; display: flex; flex-direction: column; }
.offer-name { font-size: 20px; font-weight: 800; color: #000000; margin: 0; }
.offer-desc { font-size: 14px; font-weight: 700; color: #85b729; margin: 4px 0 20px; }
.sub-price { color: #888; font-size: 13px; margin-bottom: 4px; display: block; }
.main-price { font-size: 44px; font-weight: 800; margin: 0 0 32px; color: #000; }
.main-price span { font-size: 16px; font-weight: 400; color: #666; }
.features-list { list-style: none; padding: 0; margin: 0 0 40px; flex-grow: 1; }
.features-list li { padding: 10px 0 10px 28px; border-bottom: 1px solid #f3f4f6; position: relative; font-size: 14px; color: #333; }
.features-list li::before { content: "✓"; position: absolute; left: 0; color: #8fb800; font-weight: 900; top: 10px; }
.price-btn { text-align: center; padding: 14px; background: #8fb800; color: #ffffff; border-radius: 12px; text-decoration: none; font-weight: 700; transition: 0.3s; font-size: 14px; border: none; }

/* --- AVANTAGES --- */
.why-choose-section { padding: 60px 24px; display: flex; justify-content: center; background: #fff; }
.why-choose-container { max-width: 1200px; width: 100%; text-align: center; }
.why-choose-title { font-size: clamp(28px, 5vw, 48px); font-weight: 800; margin-bottom: 16px; }
.why-choose-subtitle { font-size: clamp(16px, 2.5vw, 20px); color: rgba(0,0,0,0.55); margin-bottom: 40px; font-weight: 500; }
.why-map-area { margin-bottom: 40px; }
.why-map-image { max-width: 100%; height: auto; }
.why-benefits-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.benefit-card { background: #fff; border-radius: 16px; padding: 24px; border: 1px solid rgba(0,0,0,0.1); box-shadow: 0 4px 12px rgba(0,0,0,0.05); text-align: left; }
.benefit-header { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.benefit-titles h4 { margin: 0; font-size: 15px; font-weight: 700; color: #000; }
.benefit-titles span { font-size: 13px; color: rgba(0,0,0,0.55); }
.benefit-card p { font-size: 14px; line-height: 1.6; color: rgba(0,0,0,0.55); margin: 0; }

/* --- CTA FINAL --- */
.final-contact-section { padding: 60px 24px; display: flex; justify-content: center; background-color: #ffffff; }
.final-contact-container { max-width: 1200px; width: 100%; text-align: center; }
.final-contact-title { font-size: clamp(32px, 6vw, 64px); font-weight: 800; color: #000000; line-height: 1.1; margin-bottom: 24px; }
.green-text { color: #85b729; }
.final-contact-btn { display: inline-block; padding: 18px 36px; background-color: #85b729; color: #ffffff; text-decoration: none; border-radius: 12px; font-size: 18px; font-weight: 800; transition: 0.3s; }
.final-phone-info { margin-top: 24px; font-size: 16px; color: #444; }
.final-phone-info strong { color: #000; font-weight: 800; }

/* --- PAGES LÉGALES --- */
.legal-content { padding: 60px 24px; background: #fff; line-height: 1.6; }
.legal-container { max-width: 900px; margin: 0 auto; color: #333; }
.legal-container h1 { font-size: 36px; color: #000; margin-bottom: 40px; }
.legal-container h2 { font-size: 22px; color: #85b729; margin: 30px 0 15px; border-bottom: 2px solid #f3f4f6; padding-bottom: 10px; }
.legal-container p { margin-bottom: 15px; font-size: 15px; }
/* --- STYLE SPÉCIFIQUE POUR LE VERSIONNING --- */
.version {
    font-family: 'Inter', sans-serif; /* Conserve la cohérence NGA */
    font-size: 12px !important;      /* Taille réduite pour plus de discrétion */
    color: #9ca3af !important;      /* Gris clair pour ne pas attirer l'oeil */
    margin-top: 40px;               /* Espace suffisant après le dernier article */
    font-style: italic;             /* Style italique typique des documents officiels */
    text-align: left;               /* Aligné à gauche comme votre texte */
}

/* --- FOOTER --- */
.footer-section { padding: 40px 24px; background-color: #ffffff; border-top: 1px solid rgba(0,0,0,0.05); display: flex; justify-content: center; }
.footer-container { max-width: 1200px; width: 100%; display: flex; align-items: center; gap: 40px; }
.footer-logo { height: 35px; width: auto; object-fit: contain; }
.footer-links { display: flex; gap: 24px; flex-wrap: wrap; }
.footer-links a { font-size: 14px; color: rgba(0,0,0,0.55); text-decoration: none; font-weight: 500; transition: color 0.2s ease; }

/* --- RESPONSIVE --- */
@media (max-width: 900px) {
    .header-section { padding: 15px 24px; flex-direction: column; gap: 10px; }
    .header-contact-text { text-align: center; }
    .security-container { flex-direction: column; text-align: center; gap: 32px; }
    .security-image { max-width: 300px; order: -1; }
    .cards-container, .pricing-container, .why-benefits-grid { grid-template-columns: 1fr; }
    .footer-container { flex-direction: column; text-align: center; gap: 24px; }
}
