:root{
  --green:#2E7D5A;
  --orange:#F4A261;
  --terra:#E76F51;
  --beige:#F8F4EF;
  --cream:#fff9f3;

  --text:#2B2B2B;
  --text2:#6D6A66;
  --label:#8A7F76;
  --placeholder:#A79F97;

  --border:#E3DED8;
  --shadow: 0 4px 12px rgba(0,0,0,.06);

  --radius-lg: 24px;
  --radius-md: 18px;

  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --space-7:32px;
  --space-8:40px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}

body{
  font-family:'Poppins', sans-serif;
  color:var(--text);
  
  line-height:1.5;
}
body{
  margin:0;
  font-family:'Poppins', sans-serif;
  color:var(--text);
  
}


a{color:inherit}

.container{
  width:min(1100px, 92%);
  margin:0 auto;
}

/* Typography */
h1, h2, h3{
  letter-spacing:-0.3px;
}

h1{
  font-weight:700;
  font-size:clamp(32px, 4vw, 46px);
  line-height:1.1;
  margin:0 0 14px;
}

h2{
  font-weight:600;
  font-size:30px;
  margin:0 0 8px;
}

h3{
  font-weight:600;
}

li{
  list-style: none;
}

.lead{
  font-weight:400;
  font-size:18px;
  color:var(--text2);
  margin:0 0 22px;
}

.muted{
  font-weight:400;
  color:var(--text2);
  margin:0;
}

/* Header */
.header{
  position:sticky;
  top:0;
  backdrop-filter:blur(10px);
  
  border-bottom:1px solid rgba(227,222,216,.7);
  z-index:10;
}

.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}

.brand__logo{
  width:28px;
  height:28px;
}

.brand__name{
  font-weight:700;
}

.nav{
  display:flex;
  gap:18px;
}

.nav a{
  color:var(--text2);
  text-decoration:none;
  font-weight:600;
}

.nav a:hover{
  color:var(--text);
}

/* Hero */
.hero{
  position:relative;
  padding: 90px 0 24px;
}

.hero__bg{
  position:absolute;
  inset:0;
  border-bottom-left-radius:48px;
  border-bottom-right-radius:48px;
  z-index:-1;
}

.hero__inner{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:40px;
  align-items:center;
}

.pill{
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(244,162,97,.18);
  color:#5c3a20;
  font-weight:700;
  margin:0 0 10px;
}

.hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:50px;
  padding:0 24px;
  border-radius:var(--radius-md);
  font-weight:600;
  text-decoration:none;
  border:1px solid transparent;
  cursor:pointer;
}

.btn--primary{
  background:var(--green);
  color:white;
  box-shadow:var(--shadow);
}

.btn--primary:hover{
  filter:brightness(.98);
}


.trust{
  display:flex;
  gap:12px;
  margin-top:16px;
  flex-wrap:wrap;
}

.trust__item{
  padding:10px 12px;
  border-radius:999px;
  background:rgba(248,244,239,.9);
  border:1px solid rgba(227,222,216,.9);
  color:var(--text2);
  font-weight:700;
}

.hero__mock{
  display:flex;
  justify-content:flex-end;
  align-items:center;
}

.hero__visual{
  width:100%;
  max-width:none;
  height:auto;
  display:block;
}

/* Sections */
.section{
  padding:56px 0;
}

.section__head{
  margin-bottom:22px;
}

/* Features grid */
.grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
}

.card{
  background:white;
  border:1px solid rgba(227,222,216,.9);
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:var(--shadow);
}

.icon{
  font-size:22px;
}

.card h3{
  margin:10px 0 6px;
}

.card p{
  margin:0;
  color:var(--text2);
}

/* Local section */
.section--local{
  background:linear-gradient(180deg, rgba(254, 254, 254, 0.85), rgba(252, 239, 220, 0.9), rgba(254, 254, 254, 0.85));
}

.local{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  align-items:center;
}

.list{
  margin:14px 0 0;
  padding-left:18px;
  color:var(--text2);
}

.local__media{
  position:relative;
  min-height:280px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(227,222,216,.9);
  box-shadow:0 18px 50px rgba(0,0,0,.08);

  background-image:url("./assets/images/local-scene.png");
  background-size:cover;
  background-position:center;
}



/* Newsletter */
.newsletter{
  background:white;
  border:1px solid rgba(227,222,216,.9);
  border-radius:28px;
  padding:24px;
  box-shadow:0 18px 50px rgba(0,0,0,.08);
}

.newsletter__head{
  margin-bottom:16px;
}

.form{
  margin-top:10px;
}

.label{
  display:block;
  font-weight:700;
  color:var(--label);
  margin-bottom:8px;
}

.form__row{
  display:flex;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
}

input[type="email"]{
  flex:1 1 280px;
  height:50px;
  border-radius:var(--radius-md);
  border:1px solid var(--border);
  padding:0 16px;
  font-size:16px;
  outline:none;
}

input[type="email"]::placeholder{
  color:var(--placeholder);
}

input[type="email"]:focus{
  border-color:var(--green);
  box-shadow:0 0 0 4px rgba(46,125,90,.12);
}

.fineprint{
  margin:10px 0 0;
  color:var(--text2);
  font-size:12px;
}

.fineprint a{
  color:var(--green);
  font-weight:700;
  text-decoration:none;
}

.note{
  margin-top:14px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(248,244,239,.8);
  border:1px solid rgba(227,222,216,.9);
  color:var(--text2);
}

/* FAQ */
.faq{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.faq__item{
  background:white;
  border:1px solid rgba(227,222,216,.9);
  border-radius:18px;
  padding:14px 16px;
  box-shadow:var(--shadow);
}

.faq__item summary{
  cursor:pointer;
  font-weight:800;
}

.faq__item p{
  color:var(--text2);
  margin:10px 0 0;
}

/* Footer */
.footer{
  background-color: #0f432b;
  color:rgba(255,255,255,.92);
  padding:36px 0;
  margin-top:24px;
}

.footer__inner{
  display:flex;
  justify-content:space-between;
  gap:22px;
  flex-wrap:wrap;
}

.brand--footer .brand__name{
  color:white;
}

.footer__text{
  margin:10px 0 0;
  color:rgba(255,255,255,.86);
}

.footer__links{
  display:flex;
  gap:16px;
  align-items:flex-start;
}

.footer__links a{
  color:white;
  text-decoration:none;
  font-weight:700;
}

.footer__links a:hover{
  opacity:.9;
}

.hidden{
  display:none;
}

/* Responsive */
@media (max-width: 980px){
.hero{
  
  padding: 15px;
}
  .hero__inner{
    grid-template-columns:1fr;
    text-align:left;
  }
.lead{
  max-width: 390px;
}
  .hero__mock{
    display:none;
  }
.grid{
    grid-template-columns:repeat(2, 1fr);
  }
  .local{
    grid-template-columns:1fr;
  }
}
  


@media (max-width: 520px){
  .nav{
    display:none;
  }
  .grid{
    grid-template-columns:1fr;
  }
  h2{
    font-size:26px;
  }
}

.cookie-banner{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  background:#fff;
  border-top:1px solid rgba(227,222,216,.9);
  padding:16px;
  box-shadow:0 -4px 20px rgba(0,0,0,.08);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  z-index:9999;
}

.cookie-banner p{
  margin:0;
  font-size:14px;
  color:var(--text2);
}

.cookie-actions{
  display:flex;
  gap:10px;
}

@media (max-width:600px){
  .cookie-banner{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* =========================
   Brevo form skin (Proximity) — CLEAN
   ========================= */

   .brevo{
    margin-top: 12px;
  }
  
  /* Retire le fond gris du wrapper Brevo */
  .sib-form{
    background: transparent !important;
  }
  
  /* Container Brevo (enlève les inline styles: bordure bleue + radius 3px) */
  #sib-container{
    max-width: 100% !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    text-align: left !important; /* important: sinon ça centre tout */
  }
  
  /* Reset typographie */
  #sib-container, #sib-container *{
    font-family: 'Poppins', sans-serif !important;
  }
  
  /* Enlève les paddings en dur de Brevo */
  #sib-container .sib-form-block{
    padding: 0 !important;
    margin: 0 !important;
  }
  
  /* EMAIL label */
  #sib-container .entry__label{
    font-weight: 700 !important;
    color: var(--label) !important;
    font-size: 14px !important;
    margin: 0 0 8px !important;
  }
  
  /* Champ email */
  #sib-container .entry__field{
    width: 100% !important;
  }
  
  #sib-container input#EMAIL,
  #sib-container input[type="email"],
  #sib-container input[type="text"]{
    width: 100% !important;
    height: 52px !important;
    border-radius: 16px !important; /* plus doux */
    border: 1px solid var(--border) !important;
    background: #fff !important;
    padding: 0 16px !important;
    font-size: 16px !important;
    color: var(--text) !important;
    box-shadow: none !important; /* supprime contour chelou */
    outline: none !important;
  }
  
  #sib-container input::placeholder{
    color: var(--placeholder) !important;
  }
  
  #sib-container input:focus{
    border-color: rgba(46,125,90,.55) !important;
    box-shadow: 0 0 0 4px rgba(46,125,90,.12) !important;
  }
  
  /* Checkbox RGPD : alignement propre */
  #sib-container .entry_mcq{
    margin-top: 12px !important;
  }
  
  #sib-container .entry__choice label{
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }
  
  /* IMPORTANT : Brevo met un <p> dans le texte -> on l'annule */
  #sib-container .entry__choice p{
    margin: 0 !important;
    display: inline !important;
  }
  
  #sib-container .entry__choice .checkbox{
    margin-top: 2px !important;
  }
  
  /* Texte RGPD */
  #sib-container .entry__choice span[style]{
    font-size: 13px !important;
    color: var(--text2) !important;
    line-height: 1.45 !important;
  }
  
  /* Phrase “Vous pouvez vous désinscrire…” */
  #sib-container .entry__specification{
    display: block !important;
    margin-top: 8px !important;
    font-size: 12px !important;
    color: var(--text2) !important;
  }
  
  /* Bouton : pas full width “3km”, style Proximity */
  /* Bouton : style Proximity + texte parfaitement centré */
#sib-container button{
  height: 52px !important;
  border-radius: 18px !important;
  border: 0 !important;
  background: var(--green) !important;
  color: #fff !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  box-shadow: var(--shadow) !important;

  width: auto !important;
  min-width: 180px !important;

  /* ✅ fix centrage texte */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  line-height: 1 !important;

  /* padding OK (ne décale plus grâce au flex) */
  padding: 0 22px !important;
}
  
  #sib-container button:hover{
    filter: brightness(.98) !important;
  }
  
  /* Le texte dans le bouton */
  #sib-container button,
  #sib-container button *{
    color: #fff !important;
  }
  
  /* Centre le bouton (comme sur ta capture) */
  #sib-container .sib-form-block[style*="text-align: left"],
  #sib-container .sib-form-block{
    text-align: center !important;
  }
  
  /* Ligne “liens légaux” que tu as ajoutée */
  .brevo-legal{
    margin: 10px 0 0;
    font-size: 12px;
    color: var(--text2);
    text-align: center;
  }
  
  .brevo-legal a{
    color: var(--green);
    font-weight: 700;
    text-decoration: none;
  }
  .brevo-legal a:hover{
    opacity: .9;
  }

