:root{
  --primary:#15803D; --primary-dark:#166534; --secondary:#86EFAC;
  --cta:#C2410C; --cta-dark:#9A3412;
  --bg:#F7FCF8; --surface:#FFFFFF; --surface-alt:#EAF7EE;
  --text:#11301E; --muted:#4A6152; --line:#D6EEDD;
  --shadow-sm:0 1px 3px rgba(21,128,61,.09),0 1px 2px rgba(21,128,61,.06);
  --shadow:0 10px 30px -12px rgba(21,128,61,.22);
  --shadow-lg:0 24px 48px -20px rgba(21,128,61,.28);
  --radius:16px; --radius-sm:10px; --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,.brand-name{font-family:'Bricolage Grotesque','DM Sans',sans-serif;line-height:1.15;letter-spacing:-.01em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
svg{width:20px;height:20px;flex:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.97rem;
  padding:12px 22px;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:background-color .2s,color .2s,box-shadow .2s,transform .2s;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-ghost{background:#fff;color:var(--primary-dark);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}
.btn-cta{background:var(--cta);color:#fff;box-shadow:0 10px 30px -12px rgba(194,65,12,.4)}
.btn-cta:hover{background:var(--cta-dark)}
.btn-call{background:var(--surface-alt);color:var(--primary-dark);font-weight:700;padding:10px 18px}
.btn-call:hover{background:#DCF4E3}

/* Header */
.site-header{position:sticky;top:0;z-index:30;background:rgba(247,254,255,.85);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.brand-name{font-size:clamp(.82rem,2.4vw,1.05rem);font-weight:700;white-space:nowrap}
.brand-stars{display:inline-flex;align-items:center;gap:3px;margin-left:7px;flex:none}
.brand-stars svg{animation:twinkle 1.8s ease-in-out infinite;transform-origin:center;filter:drop-shadow(0 0 3px rgba(244,183,64,.55))}
.brand-stars svg:nth-child(1){width:14px;height:14px;color:#F4B740;animation-delay:0s}
.brand-stars svg:nth-child(2){width:9px;height:9px;color:#FBD879;animation-delay:.55s}
.brand-stars svg:nth-child(3){width:11px;height:11px;color:#E89B3A;animation-delay:1.05s}
@keyframes twinkle{0%,100%{opacity:.3;transform:scale(.7) rotate(0deg)}50%{opacity:1;transform:scale(1.15) rotate(20deg)}}
.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:var(--shadow-sm)}
.brand-mark svg{width:22px;height:22px}
.main-nav{display:flex;gap:6px;margin-left:auto}
.main-nav a{padding:9px 14px;border-radius:9px;font-weight:500;color:var(--muted);transition:background-color .2s,color .2s}
.main-nav a:hover{background:var(--surface-alt);color:var(--text)}
.main-nav a.active{color:var(--primary-dark);background:var(--surface-alt)}
.btn-call{margin-left:8px}

/* Hero */
.hero{background:radial-gradient(120% 120% at 80% -10%,#D7F2DF 0%,var(--bg) 55%);padding:84px 0 64px}
.hero-text{max-width:680px}
.eyebrow{display:inline-flex;align-items:center;gap:7px;color:var(--primary-dark);font-weight:600;
  background:var(--surface-alt);padding:6px 14px;border-radius:999px;font-size:.9rem;margin-bottom:22px}
.eyebrow svg{width:16px;height:16px}
.hero h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:700;margin-bottom:20px}
.lead{font-size:1.16rem;color:var(--muted);max-width:62ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:30px 0 26px}
.trust-list{display:flex;flex-wrap:wrap;gap:10px 26px;list-style:none}
.trust-list li{display:flex;align-items:center;gap:8px;font-weight:500;font-size:.95rem}
.trust-list svg{width:18px;height:18px;color:var(--cta)}

/* Sections */
.section{padding:72px 0}
.section-alt{background:var(--surface-alt)}
.section-eyebrow{color:var(--primary-dark);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;margin-bottom:10px}
.section-title{font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:700;margin-bottom:14px}
.section-title.sm{font-size:1.5rem}
.section-sub{color:var(--muted);font-size:1.08rem;max-width:60ch;margin-bottom:38px}

/* Service grid */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-sm);transition:box-shadow .25s,border-color .25s,transform .25s;cursor:pointer}
.service-card:hover{box-shadow:var(--shadow-lg);border-color:var(--secondary);transform:translateY(-3px)}
.service-icon{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;
  background:var(--surface-alt);color:var(--primary-dark);margin-bottom:18px}
.service-icon svg{width:26px;height:26px}
.service-icon.sm{width:38px;height:38px;border-radius:10px;margin:0}
.service-icon.sm svg{width:20px;height:20px}
.service-card h3{font-size:1.22rem;margin-bottom:8px}
.service-card p{color:var(--muted);font-size:.97rem;margin-bottom:16px}
.card-link{color:var(--primary-dark);font-weight:600;font-size:.95rem}

/* Split + stats */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
.split p{color:var(--muted);margin-bottom:16px;font-size:1.05rem}
.split .btn{margin-top:8px}
.stat-cards{display:grid;gap:16px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow-sm);display:flex;align-items:baseline;gap:16px}
.stat-num{font-family:'Bricolage Grotesque',sans-serif;font-size:2.2rem;font-weight:700;color:var(--primary)}
.stat-label{color:var(--muted);font-weight:500}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;padding:54px 0}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.cta-band h2{font-size:1.7rem;margin-bottom:6px}
.cta-band p{color:#D8F0DF;max-width:48ch}

/* Page hero / breadcrumb */
.page-hero{background:radial-gradient(120% 120% at 85% -20%,#D7F2DF,var(--bg) 60%);padding:54px 0 40px}
.breadcrumb{font-size:.9rem;color:var(--muted);margin-bottom:16px}
.breadcrumb a{color:var(--primary-dark)}
.breadcrumb span{margin:0 6px;opacity:.6}
.page-hero h1{font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:14px}

/* Article */
.article-head{max-width:780px;padding-top:48px;padding-bottom:8px}
.article-icon{display:grid;place-items:center;width:60px;height:60px;border-radius:16px;background:var(--surface-alt);color:var(--primary-dark);margin-bottom:20px}
.article-icon svg{width:30px;height:30px}
.article-head h1{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:14px}
.article-body{max-width:760px;padding-top:18px;padding-bottom:18px}
.article-body h2{font-size:1.5rem;margin:38px 0 14px;color:var(--text)}
.article-body p{color:#3A4D43;font-size:1.07rem;margin-bottom:16px;max-width:70ch}
.article-body .note{background:#FFF7E6;border:1px solid #FCD9A0;border-radius:var(--radius-sm);padding:14px 18px;font-size:.95rem;color:#7A5B12}

/* Related */
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.related-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:14px 16px;font-weight:600;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s}
.related-card:hover{border-color:var(--secondary);box-shadow:var(--shadow)}
.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0 8px}
.mini-card{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:12px 14px;font-weight:600;font-size:.96rem;transition:border-color .2s,box-shadow .2s}
.mini-card:hover{border-color:var(--secondary);box-shadow:var(--shadow-sm)}

/* Communes */
.commune-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.commune-card{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s,transform .2s}
.commune-card:hover{border-color:var(--secondary);box-shadow:var(--shadow);transform:translateY(-2px)}
.commune-card svg{color:var(--primary);width:22px;height:22px;margin-top:2px}
.commune-card strong{display:block;font-size:1.08rem}
.commune-card em{color:var(--muted);font-style:normal;font-size:.92rem}

/* Footer */
.site-footer{background:#14271C;color:#C5D9CD;padding:60px 0 28px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:42px}
.brand-footer .brand-name{color:#fff}
.footer-tag{color:#92AE9C;margin:14px 0 20px;max-width:34ch}
.footer-contact{list-style:none;display:grid;gap:11px}
.footer-contact li{display:flex;align-items:flex-start;gap:10px;font-size:.95rem}
.footer-contact svg{width:18px;height:18px;color:var(--secondary);margin-top:2px}
.footer-contact a:hover{color:#fff}
.footer-col h3{font-size:1rem;color:#fff;margin-bottom:16px}
.footer-links{list-style:none;display:grid;gap:9px}
.footer-links a{color:#92AE9C;font-size:.95rem;transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.1);margin-top:42px;padding-top:22px;font-size:.88rem;color:#7C9685}
.footer-bottom a:hover{color:#fff}

/* Invitation contact (footer) */
.footer-invite{color:#BDD6C6;margin:6px 0 16px;max-width:34ch;font-weight:500}
.btn-footer-contact{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.22)}
.btn-footer-contact:hover{background:rgba(255,255,255,.16);border-color:var(--secondary)}

/* Fiche contact (modale révélée à la demande) */
.contact-overlay{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:20px;
  background:rgba(6,54,63,.55);backdrop-filter:blur(4px);animation:fadeIn .2s ease}
.contact-overlay[hidden]{display:none}
.contact-card{position:relative;width:100%;max-width:440px;background:var(--surface);
  border-radius:20px;padding:38px 34px 34px;box-shadow:var(--shadow-lg);text-align:center;animation:popIn .22s ease}
.contact-close{position:absolute;top:14px;right:14px;width:38px;height:38px;display:grid;place-items:center;
  border:none;border-radius:10px;background:var(--surface-alt);color:var(--primary-dark);cursor:pointer;transition:background-color .2s}
.contact-close:hover{background:#DCF4E3}
.contact-close svg{width:20px;height:20px}
.contact-icon{display:inline-grid;place-items:center;width:58px;height:58px;border-radius:16px;margin-bottom:16px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}
.contact-icon svg{width:28px;height:28px}
.contact-card h2{font-size:1.5rem;margin-bottom:8px}
.contact-lead{color:var(--muted);margin-bottom:22px}
.contact-details{list-style:none;display:grid;gap:12px;text-align:left;margin-bottom:24px}
.contact-details li{display:flex;align-items:center;gap:12px;background:var(--surface-alt);
  border-radius:var(--radius-sm);padding:13px 16px;font-weight:500}
.contact-details svg{width:20px;height:20px;color:var(--primary);flex:none}
.contact-details a:hover{color:var(--primary-dark);text-decoration:underline}
.contact-main-btn{width:100%;justify-content:center}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}

/* Responsive */
@media(max-width:900px){
  .service-grid,.commune-grid,.mini-grid{grid-template-columns:repeat(2,1fr)}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:34px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .main-nav{display:none}
  .header-inner{gap:12px}
  .brand-mark{display:none}
  /* Le nom du site (phrase longue) passe sur plusieurs lignes et s'agrandit
     pour rester bien lisible sur mobile, au lieu de rétrécir sur une ligne. */
  .brand-name{font-size:1.02rem;white-space:normal;line-height:1.2;max-width:64vw}
  .brand-stars{display:none}
  .btn-call span{display:none}
  .btn-call{padding:10px}
  .hero{padding:56px 0 44px}
  .section{padding:52px 0}
  .service-grid,.commune-grid,.mini-grid,.related-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:6px}
