:root{
  --clr-primary:#008C74;
  --clr-accent:#F8C146;
  --clr-dark:#1a1a1a;
  --clr-light:#f7f7f7;
}
body{ background:var(--clr-light); color:var(--clr-dark); font-family:system-ui,-apple-system,'Segoe UI',Roboto,Ubuntu,'Helvetica Neue',Arial,'Noto Sans','Apple Color Emoji','Segoe UI Emoji'; }
.navbar{ background:var(--clr-primary); }
.navbar .nav-link{ color:#fff!important; }
.navbar .nav-link.active{ font-weight:700; text-decoration:underline; text-underline-offset: 6px; }
.main-pad{ padding-top: 84px; }
.hero{ background: url('../img/hero-landing.jpg') center/cover no-repeat; min-height: 70vh; color:#fff; position:relative; display:flex; align-items:center; }
.hero::after{ content:''; position:absolute; inset:0; background: linear-gradient(rgba(0,0,0,0.55), rgba(0,0,0,0.55)); }
.hero .inner{ position:relative; z-index:2; }
.hero .inner h1{ text-shadow: 0 2px 10px rgba(0,0,0,0.35); }
.btn-blink{ background:var(--clr-accent); color:#000; font-weight:600; border:none; }
.btn-accent{ background:var(--clr-accent); color:#000; border:0; font-weight:700; }
.btn-accent:hover{ filter:brightness(0.95); }
.section-title{ font-size:1.8rem; font-weight:700; border-left:5px solid var(--clr-primary); padding-left:10px; margin: 1.2rem 0; }
.project-card img{ width:100%; height:180px; object-fit:cover; border-radius:10px 10px 0 0; }
.card.hover-rise{ transition: transform .2s ease, box-shadow .2s ease; }
.card.hover-rise:hover{ transform: translateY(-4px); box-shadow:0 10px 22px rgba(0,0,0,0.12); }
.site-footer{ background:#222; color:#ccc; padding:2rem 0; }
.map-container{ height:480px; border-radius:12px; overflow:hidden; box-shadow:0 3px 8px rgba(0,0,0,0.1); background:#fff; }
.badge-soft{ background:#eef6f4; color:#0c6; border:1px solid #cde; }
.badge-outline{ border:1px solid rgba(0,0,0,0.1); background:#fff; }
.testimonial-card{ background: linear-gradient(135deg,#ffffff,#f7faf9); border:1px solid #eef2f1; }
.testimonial-quote{ font-size:1.05rem; line-height:1.6; }
.org-logo{ height:64px; width:auto; object-fit:contain; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.08)); }
.filter-bar .form-control, .filter-bar .form-select{ background:#fff; }
.leaflet-container{ background:#f0f6f5; }

/* Navbar + brand */
.site-navbar{
  background: #008C74; /* vert Mzizi */
}
.brand-logo{
  height: 44px;
  width: auto;
  border-radius: 8px;        /* coin doux pour s'intégrer au thème */
  box-shadow: 0 1px 3px rgba(0,0,0,.15);
}
.brand-title{
  font-weight: 800;
  font-size: 1.1rem;
  letter-spacing: .2px;
  color: #fff;
  line-height: 1.05;
}
.brand-tagline{
  font-size: .72rem;
  color: rgba(255,255,255,.85);
  letter-spacing: .6px;
  text-transform: uppercase;
}
.navbar .nav-link{ color:#fff !important; opacity:.95; }
.navbar .nav-link.active{ font-weight:700; text-decoration:underline; text-underline-offset:6px; }
.btn-accent{ background:#F8C146; color:#000; border:0; font-weight:700; }
.btn-accent:hover{ filter:brightness(.95); }

.main-pad{ padding-top: 96px; } /* espace sous la navbar fixe */

/* ---- Header / Navbar tidy ---- */
.site-navbar{ background:#008C74; padding: .35rem 0; }        /* navbar plus compacte */
.navbar-brand{ padding:0; margin-right: .75rem; }              /* supprime padding du brand */
.brand{ gap:.5rem; }                                           /* espace logo / texte */
.brand-logo{
  height: 44px;                                                /* taille contrôlée */
  width: auto;
  display:block;
  object-fit: contain;                                         /* évite la déformation */
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(0,0,0,.12);
}
.brand-text{ line-height:1; }
.brand-title{
  font-weight:800;
  font-size: 1.05rem;                                          /* taille réduite */
  color:#fff;
}
.brand-tagline{
  font-size:.7rem;
  color:rgba(255,255,255,.85);
  letter-spacing:.6px;
  text-transform:uppercase;
}
.navbar .nav-link{
  color:#fff !important;
  opacity:.95;
  white-space: nowrap;                                         /* empêche le retour à la ligne */
  font-size:.95rem;
  line-height:1.2;
  padding: .5rem .6rem;                                        /* liens plus compacts */
}
.navbar .nav-link.active{
  font-weight:700;
  text-decoration: underline;
  text-underline-offset:6px;
}
.navbar-nav{ gap:.15rem; }                                     /* réduit l’écart entre items */
.btn-accent{ background:#F8C146; color:#000; border:0; font-weight:700; }
.btn-accent:hover{ filter:brightness(.95); }
.main-pad{ padding-top: 76px; }                                /* compense la hauteur de la navbar fixe */

@media (max-width: 1200px){
  .brand-logo{ height:40px; }
  .brand-tagline{ display:none; }                              /* cache la baseline sur écrans moyens/petits */
  .navbar .nav-link{ font-size:.92rem; }
}
@media (max-width: 992px){
  .main-pad{ padding-top: 70px; }
}

/* ========== Sections "à la Block" ========== */
.section-block{
  padding: 72px 0;
  position: relative;
}
.section-bg{                       /* fond RGB faible luminosité */
  background: rgb(244, 248, 247);  /* très doux, change si tu veux */
}
.section-head{
  max-width: 880px;
  margin: 0 auto 32px;
  text-align: center;
}
.section-eyebrow{
  display:inline-block;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#3b7a6d;
  background: rgba(0,140,116,.08);
  border:1px solid rgba(0,140,116,.18);
  padding:.25rem .6rem;
  border-radius:999px;
  margin-bottom:12px;
}
.section-title{
  font-size: clamp(1.6rem, 1.1rem + 1.5vw, 2rem);
  font-weight:800;
  margin:0 0 8px;
  color:#122;
}
.section-underline{
  width:72px;height:4px;border-radius:4px;
  background: var(--clr-accent);
  margin: 10px auto 0;
}
.section-desc{
  color:#5b6670;
  font-size:1rem;
  line-height:1.65;
}

/* cartes adoucies */
.card.soft{
  border:1px solid #e9efed;
  box-shadow: 0 8px 26px rgba(0,0,0,.06);
  border-radius:18px;
}

/* carte + placeholder */
.map-wrapper{ position:relative; border-radius:14px; overflow:hidden; }
#mapPlaceholder{
  position:absolute; inset:0; z-index:5;
  display:flex; align-items:center; justify-content:center;
  background:#eaf3f1; transition:opacity .8s ease;
}
#mapPlaceholder img{ max-width:70%; border-radius:10px; opacity:.9; }

/* grille centrée sur grands écrans */
.center-cols{ justify-content:center; }
