/* ============================================================
   WILL-O-JARDIN — Paysagiste a Toulon
   DA : PAY-9 Neo-Editorial "Vert-de-gris"
   Display Fraunces | Body DM Sans | accent #3A4A40 | bg #F3EFE7
   Hero editorial centre | Layout magazine asym | Texture points
   ============================================================ */

/* -------- VARIABLES (contrat obligatoire) -------- */
:root{
  --bg:#F3EFE7;
  --bg-alt:#EEE9DE;
  --surface:#FAF7F1;
  --text:#2A2A26;
  --text-2:#5B5B53;
  --text-mute:#8C8C82;
  --border:#D9D2C2;
  --accent:#3A4A40;
  --accent-2:#5A6E60;
  --accent-soft:#E3DDD0;
  --primary:#3A4A40;
  --wa-green:#25D366;
  --wa-green-dark:#128C7E;
  --gold:#B49A6A;

  --ff-display:"Fraunces", "Cormorant Garamond", Georgia, serif;
  --ff-body:"DM Sans", "Inter", system-ui, sans-serif;
  --ff-ui:"DM Sans", "Inter", system-ui, sans-serif;

  --r-sm:6px;
  --r-md:10px;
  --r-lg:14px;
  --r-xl:22px;

  --header-h:76px;
  --header-h-mobile:64px;

  --z-header:900;
  --z-menu:1000;
  --z-burger:1001;
  --z-modal:1100;

  --container:1180px;

  --shadow-sm:0 1px 2px rgba(42,42,38,.06);
  --shadow-md:0 6px 18px rgba(42,42,38,.08);
  --shadow-lg:0 12px 36px rgba(42,42,38,.12);
}

/* -------- BASE -------- */
*,*::before,*::after{box-sizing:border-box;}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--header-h-mobile) + 12px);
}
@media (min-width:768px){
  html{scroll-padding-top:calc(var(--header-h) + 16px);}
}
body{
  margin:0;
  font-family:var(--ff-body);
  font-size:16px;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  background-image:radial-gradient(color-mix(in srgb, var(--text) 9%, transparent) 1px, transparent 1px);
  background-size:22px 22px;
  background-attachment:fixed;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit;}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:600;color:var(--text);margin:0 0 .6em;line-height:1.1;letter-spacing:-.01em;}
p{margin:0 0 1em;color:var(--text);}
ul,ol{margin:0 0 1em;padding-left:1.2em;}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px;}

.container{max-width:var(--container);margin:0 auto;padding:0 20px;}
@media (min-width:768px){.container{padding:0 32px;}}

.section{padding:56px 0;}
@media (min-width:768px){.section{padding:88px 0;}}

.section__eyebrow{
  display:inline-block;
  font-family:var(--ff-body);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  color:var(--accent);
  margin-bottom:14px;
  font-weight:500;
}
.section__title{
  font-family:var(--ff-display);
  font-size:clamp(1.9rem, 4.5vw, 3rem);
  font-weight:500;
  margin:0 0 18px;
  line-height:1.08;
}
.section__sub{
  font-size:1.02rem;
  color:var(--text-2);
  max-width:60ch;
  margin:0 0 36px;
}
.section__head{margin-bottom:36px;}
@media (min-width:768px){.section__head{margin-bottom:56px;}}

/* -------- HEADER -------- */
.header{
  position:fixed;
  top:0;left:0;right:0;
  height:var(--header-h-mobile);
  background:color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter:saturate(120%) blur(12px);
  -webkit-backdrop-filter:saturate(120%) blur(12px);
  border-bottom:1px solid color-mix(in srgb, var(--text) 8%, transparent);
  z-index:var(--z-header);
}
.header__inner{
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}
@media (min-width:768px){
  .header{height:var(--header-h);}
  .header__inner{padding:0 32px;}
}
.brand{display:flex;align-items:center;gap:12px;color:var(--text);}
.brand__mark{
  width:42px;height:42px;
  display:grid;place-items:center;
  border-radius:10px;
  background:var(--accent);
  flex:0 0 42px;
}
.brand__name{
  font-family:var(--ff-display);
  font-size:1.08rem;
  font-weight:600;
  letter-spacing:.01em;
  line-height:1;
  color:var(--text);
}
.brand__tag{
  display:block;
  font-family:var(--ff-body);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text-mute);
  margin-top:4px;
}

.nav-desktop{display:none;}
@media (min-width:900px){
  .nav-desktop{
    display:flex;
    align-items:center;
    gap:26px;
    font-family:var(--ff-body);
    font-size:.94rem;
  }
  .nav-desktop a{
    color:var(--text-2);
    position:relative;
    padding:8px 0;
    transition:color .2s;
  }
  .nav-desktop a:hover{color:var(--accent);}
  .nav-desktop a::after{
    content:"";
    position:absolute;left:0;bottom:2px;
    width:0;height:1px;background:var(--accent);
    transition:width .25s ease;
  }
  .nav-desktop a:hover::after{width:100%;}
}

.header__cta-wrap{display:flex;align-items:center;gap:10px;}
.header__cta{display:none;}
@media (min-width:900px){
  .header__cta{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 18px;
    background:var(--accent);
    color:#fff;
    border-radius:999px;
    font-family:var(--ff-ui);
    font-size:.92rem;
    font-weight:500;
    transition:background .2s, transform .2s;
  }
  .header__cta:hover{background:var(--accent-2);transform:translateY(-1px);}
}
.header__status{
  display:none;
  align-items:center;
  gap:8px;
  font-family:var(--ff-body);
  font-size:.84rem;
  color:var(--text-2);
}
@media (min-width:900px){.header__status{display:inline-flex;}}
.status-dot{
  width:8px;height:8px;border-radius:50%;
  background:#8C8C82;
  box-shadow:0 0 0 3px color-mix(in srgb, #8C8C82 22%, transparent);
}
.status-dot.is-open{background:#4FAE6C;box-shadow:0 0 0 3px color-mix(in srgb, #4FAE6C 22%, transparent);}
.status-dot.is-closed{background:#C4633A;box-shadow:0 0 0 3px color-mix(in srgb, #C4633A 22%, transparent);}

/* -------- BURGER + MENU MOBILE (pattern obligatoire) -------- */
.burger{
  position:fixed;
  top:calc((var(--header-h-mobile) - 44px) / 2);
  right:16px;
  width:44px;height:44px;
  display:grid;place-items:center;
  background:transparent;border:0;cursor:pointer;
  z-index:var(--z-burger);
}
.burger span{
  position:relative;
  display:block;
  width:22px;height:2px;
  background:var(--text);
  border-radius:2px;
  transition:transform .25s ease, background-color .2s;
}
.burger span::before,
.burger span::after{
  content:"";
  position:absolute;left:0;
  width:22px;height:2px;
  background:var(--text);border-radius:2px;
  transition:transform .25s ease, top .25s ease;
}
.burger span::before{top:-7px;}
.burger span::after{top:7px;}
.burger.is-open span{background:transparent;}
.burger.is-open span::before{top:0;transform:rotate(45deg);}
.burger.is-open span::after{top:0;transform:rotate(-45deg);}
@media (min-width:900px){.burger{display:none;}}

.menu-mobile{
  position:fixed;
  top:0;left:0;
  width:100%;
  height:100dvh;
  background:var(--bg);
  z-index:var(--z-menu);
  padding:calc(var(--header-h-mobile) + 28px) 24px 40px;
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  transform:translateY(-100%);
  opacity:0;
  visibility:hidden;
  transition:transform .35s ease, opacity .35s ease, visibility 0s linear .35s;
}
.menu-mobile.is-open{
  transform:translateY(0);
  opacity:1;
  visibility:visible;
  transition:transform .35s ease, opacity .35s ease;
}
.menu-mobile a{
  font-family:var(--ff-display);
  font-size:1.6rem;
  color:var(--text);
  padding:14px 0;
  border-bottom:1px solid color-mix(in srgb, var(--text) 10%, transparent);
  transition:color .2s;
}
.menu-mobile a:hover{color:var(--accent);}
.menu-mobile .menu-mobile__cta{
  margin-top:24px;
  border:0;
  font-family:var(--ff-ui);
  font-size:1rem;
  font-weight:500;
  padding:16px 24px;
  background:var(--wa-green);
  color:#fff;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  justify-content:center;
}
.menu-mobile .menu-mobile__tel{
  border:0;
  font-family:var(--ff-ui);
  font-size:1rem;
  font-weight:500;
  padding:16px 24px;
  background:var(--accent);
  color:#fff;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  justify-content:center;
}
.menu-mobile__meta{
  margin-top:auto;
  padding-top:24px;
  font-family:var(--ff-body);
  font-size:.86rem;
  color:var(--text-2);
  border:0;
}
.menu-mobile__meta strong{color:var(--text);font-weight:500;}
@media (min-width:900px){.menu-mobile{display:none;}}

/* -------- BUTTONS -------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 24px;
  border-radius:999px;
  font-family:var(--ff-ui);
  font-size:.98rem;
  font-weight:500;
  line-height:1;
  cursor:pointer;
  transition:background .2s, transform .2s, box-shadow .2s, color .2s;
  white-space:nowrap;
}
.btn svg{flex:0 0 auto;}
.btn--primary{background:var(--accent);color:#fff;}
.btn--primary:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn--wa{background:var(--wa-green);color:#fff;}
.btn--wa:hover{background:var(--wa-green-dark);transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn--ghost{background:transparent;color:var(--text);border:1px solid var(--border);}
.btn--ghost:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn--light{background:#fff;color:var(--text);}
.btn--light:hover{background:var(--accent-soft);}

/* -------- HERO EDITORIAL CENTRE -------- */
.hero{
  padding-top:calc(var(--header-h-mobile) + 36px);
  padding-bottom:8px;
  position:relative;
}
@media (min-width:768px){
  .hero{padding-top:calc(var(--header-h) + 56px);}
}
.hero__inner{
  max-width:1000px;
  margin:0 auto;
  text-align:center;
  padding:0 20px;
}
.hero__eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--ff-body);
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:.74rem;
  color:var(--accent);
  margin-bottom:22px;
}
.hero__eyebrow::before,
.hero__eyebrow::after{
  content:"";
  display:inline-block;
  width:24px;height:1px;background:var(--accent);
}
.hero__title{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem, 7.4vw, 4.4rem);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-.02em;
  color:var(--text);
  margin:0 auto 18px;
  max-width:18ch;
}
.hero__title em{font-style:italic;color:var(--accent);font-weight:400;}
.hero__sub{
  font-size:clamp(1rem, 1.6vw, 1.16rem);
  color:var(--text-2);
  margin:0 auto 28px;
  max-width:55ch;
  line-height:1.55;
}
.hero__cta{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:12px;
  width:100%;
  max-width:420px;
  margin:0 auto;
}
.hero__cta .btn{width:100%;}
@media (min-width:560px){
  .hero__cta{
    flex-direction:row;
    justify-content:center;
    max-width:none;
  }
  .hero__cta .btn{width:auto;}
}
.hero__rating{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:22px auto 0;
  padding:10px 18px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  font-family:var(--ff-body);
  font-size:.9rem;
  color:var(--text);
  box-shadow:var(--shadow-sm);
  transition:transform .2s, box-shadow .2s;
}
.hero__rating:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}
.hero__rating strong{font-weight:600;}
.hero__rating .stars{display:inline-flex;gap:2px;color:#E0A53B;}
.hero__rating .stars svg{width:14px;height:14px;}
.hero__rating .dot{color:var(--text-mute);margin:0 2px;}

.hero__band{
  width:100%;
  margin:clamp(36px, 6vw, 60px) auto 0;
  aspect-ratio:21/9;
  border-radius:18px;
  overflow:hidden;
  position:relative;
}
.hero__band img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
@media (max-width:560px){
  .hero__band{aspect-ratio:16/11;border-radius:14px;}
}
.hero__band-caption{
  position:absolute;
  left:18px;bottom:14px;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  color:var(--text);
  padding:6px 14px;
  border-radius:999px;
  font-family:var(--ff-body);
  font-size:.78rem;
  letter-spacing:.05em;
  backdrop-filter:blur(6px);
}

/* -------- STATS STRIP -------- */
.stats{
  background:transparent;
  padding:48px 0;
}
.stats__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:32px 0;
}
@media (min-width:640px){
  .stats__grid{grid-template-columns:repeat(3, 1fr);gap:8px;}
}
.stat{
  text-align:center;
  padding:8px;
}
@media (min-width:640px){
  .stat + .stat{border-left:1px solid var(--border);}
}
.stat__num{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem, 5vw, 3.4rem);
  font-weight:500;
  color:var(--accent);
  line-height:1;
  margin-bottom:8px;
  letter-spacing:-.02em;
}
.stat__num em{font-style:normal;font-size:.65em;vertical-align:6px;}
.stat__label{
  font-family:var(--ff-body);
  font-size:.86rem;
  color:var(--text-2);
  text-transform:uppercase;
  letter-spacing:.12em;
}

/* -------- AVIS (row-sep) -------- */
.avis{background:var(--bg-alt);}
.avis__rating-bar{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:18px;
  margin-bottom:32px;
  padding:22px 26px;
  background:#fff;
  border-radius:18px;
  box-shadow:var(--shadow-sm);
}
.avis__rating-score{
  font-family:var(--ff-display);
  font-size:2.4rem;
  font-weight:500;
  color:var(--text);
  line-height:1;
}
.avis__rating-meta{flex:1;min-width:160px;}
.avis__rating-stars{display:flex;gap:3px;color:#E0A53B;margin-bottom:4px;}
.avis__rating-stars svg{width:18px;height:18px;}
.avis__rating-label{font-family:var(--ff-body);font-size:.92rem;color:var(--text-2);}
.avis__rating-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--accent);
  font-family:var(--ff-body);
  font-size:.92rem;
  font-weight:500;
}
.avis__rating-cta:hover{text-decoration:underline;}
.avis-rows{display:flex;flex-direction:column;}
.avis-rows__item{
  padding:28px 0;
  border-top:1px solid color-mix(in srgb, var(--text) 12%, transparent);
}
.avis-rows__item:first-child{border-top:0;}
.avis-rows__head{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:14px;
}
.avis-rows__stars{display:inline-flex;gap:2px;color:#E0A53B;}
.avis-rows__stars svg{width:14px;height:14px;}
.avis-rows__verified{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--ff-body);font-size:.78rem;color:var(--text-2);
  padding:4px 10px;background:var(--bg);border-radius:999px;border:1px solid var(--border);
}
.avis-rows__verified svg{width:12px;height:12px;}
.avis-rows__text{
  font-family:var(--ff-display);
  font-style:italic;
  font-weight:400;
  font-size:clamp(1.05rem, 1.6vw, 1.25rem);
  line-height:1.5;
  color:var(--text);
  margin:0 0 12px;
  max-width:74ch;
}
.avis-rows__text::before{content:"\201C ";color:var(--accent);font-size:1.4em;line-height:0;vertical-align:-.3em;}
.avis-rows__text::after{content:" \201D";color:var(--accent);font-size:1.4em;line-height:0;vertical-align:-.3em;}
.avis-rows__author{
  font-family:var(--ff-body);
  font-size:.88rem;
  color:var(--text-2);
}
.avis-rows__author strong{color:var(--text);font-weight:500;}
.avis-rows__date{color:var(--text-mute);}

/* -------- SERVICES (grid-asym) -------- */
.services{background:var(--bg);}
.svc-asym{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:16px;
}
.svc-card{
  background:color-mix(in srgb, var(--text) 4%, var(--bg));
  border-radius:22px 4px 22px 4px;
  padding:28px 26px;
  display:flex;
  flex-direction:column;
  position:relative;
  transition:transform .25s ease, box-shadow .25s ease, background .25s;
  grid-column:span 2;
}
.svc-card:hover{
  transform:translateY(-4px);
  background:color-mix(in srgb, var(--accent) 5%, var(--bg));
  box-shadow:var(--shadow-md);
}
.svc-card__icon{
  width:48px;height:48px;
  display:grid;place-items:center;
  background:#fff;
  border-radius:12px;
  color:var(--accent);
  margin-bottom:18px;
}
.svc-card__icon svg{width:24px;height:24px;}
.svc-card__title{
  font-family:var(--ff-display);
  font-size:1.32rem;
  font-weight:500;
  margin:0 0 10px;
  line-height:1.2;
  color:var(--text);
}
.svc-card__text{
  font-family:var(--ff-body);
  font-size:.94rem;
  color:var(--text-2);
  margin:0;
  line-height:1.5;
}
.svc-card--wide{grid-column:span 3;}
.svc-card--lead{grid-column:span 4;background:var(--accent);color:#fff;}
.svc-card--lead .svc-card__title,
.svc-card--lead .svc-card__text{color:#fff;}
.svc-card--lead .svc-card__text{color:rgba(255,255,255,.85);}
.svc-card--lead .svc-card__icon{background:rgba(255,255,255,.12);color:#fff;}
.svc-card--lead:hover{background:var(--accent);transform:translateY(-4px);}
@media (max-width:768px){
  .svc-asym{grid-template-columns:1fr;}
  .svc-card,
  .svc-card--wide,
  .svc-card--lead{grid-column:1/-1;}
}

/* -------- REALISATIONS (gallery grid-feat) -------- */
.realisations{background:var(--bg-alt);}
.gal-feat{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:1fr;
  gap:14px;
}
.gal-feat__item{
  position:relative;
  cursor:pointer;
  border-radius:14px;
  overflow:hidden;
  background:var(--accent-soft);
  transition:transform .3s ease;
}
.gal-feat__item:hover{transform:scale(1.01);}
.gal-feat__item img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  aspect-ratio:1/1;
  transition:transform .5s ease;
}
.gal-feat__item:hover img{transform:scale(1.04);}
.gal-feat__big{grid-column:span 2;grid-row:span 2;}
.gal-feat__big img{aspect-ratio:auto;height:100%;}
.gal-feat__item::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.32) 100%);
  opacity:0;transition:opacity .25s;
  pointer-events:none;
}
.gal-feat__item:hover::after{opacity:1;}
.gal-feat__caption{
  position:absolute;
  left:14px;bottom:12px;
  font-family:var(--ff-body);
  font-size:.84rem;
  color:#fff;
  opacity:0;
  transform:translateY(6px);
  transition:opacity .25s, transform .25s;
  pointer-events:none;
  z-index:2;
}
.gal-feat__item:hover .gal-feat__caption{opacity:1;transform:none;}
@media (max-width:560px){
  .gal-feat{grid-template-columns:repeat(2,1fr);}
  .gal-feat__big{grid-column:span 2;grid-row:span 1;}
  .gal-feat__big img{aspect-ratio:16/10;}
}
.realisations__more{
  display:flex;justify-content:center;
  margin-top:36px;
}

/* -------- A PROPOS (intercale) -------- */
.about{background:var(--bg);}
.about__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:28px;
  align-items:center;
}
@media (min-width:900px){
  .about__grid{grid-template-columns:1fr 1.1fr;gap:64px;}
}
.about__media{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  aspect-ratio:4/5;
  background:var(--accent-soft);
}
@media (max-width:899px){
  .about__media{aspect-ratio:16/11;max-height:420px;}
}
.about__media img{width:100%;height:100%;object-fit:cover;display:block;}
.about__badge{
  position:absolute;
  left:18px;bottom:18px;
  background:var(--bg);
  padding:14px 18px;
  border-radius:14px;
  box-shadow:var(--shadow-md);
  font-family:var(--ff-display);
  font-size:.94rem;
  color:var(--text);
  display:flex;align-items:center;gap:10px;
}
.about__badge strong{font-size:1.3em;color:var(--accent);font-weight:500;line-height:1;}
.about__text p{margin-bottom:18px;font-size:1.05rem;color:var(--text);line-height:1.65;}
.about__text p:first-of-type{
  font-family:var(--ff-display);
  font-size:clamp(1.2rem, 1.8vw, 1.45rem);
  line-height:1.4;
  color:var(--text);
  font-weight:400;
  margin-bottom:24px;
}
.about__signature{
  margin-top:24px;
  padding-top:24px;
  border-top:1px solid var(--border);
  font-family:var(--ff-display);
  font-style:italic;
  color:var(--accent);
  font-size:1.1rem;
}
.about__values{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:24px;
}
.about__value{
  padding:14px 16px;
  background:color-mix(in srgb, var(--text) 4%, var(--bg));
  border-radius:12px;
}
.about__value-num{
  font-family:var(--ff-display);
  font-size:.78rem;
  color:var(--accent);
  letter-spacing:.18em;
  font-weight:500;
}
.about__value-title{
  font-family:var(--ff-display);
  font-size:1.02rem;
  color:var(--text);
  margin:4px 0 4px;
  font-weight:500;
}
.about__value-text{
  font-family:var(--ff-body);
  font-size:.86rem;
  color:var(--text-2);
  margin:0;
  line-height:1.4;
}

/* -------- FAQ -------- */
.faq{background:var(--bg);}
.faq__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  max-width:880px;
  margin:0 auto;
}
.faq__item{
  border-top:1px solid var(--border);
}
.faq__item:last-child{border-bottom:1px solid var(--border);}
.faq__q{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:24px 0;
  text-align:left;
  font-family:var(--ff-display);
  font-size:clamp(1.05rem, 1.6vw, 1.22rem);
  font-weight:500;
  color:var(--text);
  background:none;
  border:0;
  cursor:pointer;
}
.faq__q::after{
  content:"";
  flex:0 0 22px;
  width:22px;height:22px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 22 22' fill='none' stroke='%233A4A40' stroke-width='1.6' stroke-linecap='round'><path d='M5 8 L11 14 L17 8'/></svg>");
  background-repeat:no-repeat;background-position:center;
  transition:transform .3s ease;
}
.faq__item.is-open .faq__q::after{transform:rotate(180deg);}
.faq__a{
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease;
}
.faq__a-inner{
  padding:0 0 24px;
  font-family:var(--ff-body);
  font-size:1rem;
  color:var(--text-2);
  line-height:1.6;
  max-width:70ch;
}

/* -------- ZONE INTERVENTION -------- */
.zone{background:var(--bg-alt);}
.zone__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
}
@media (min-width:900px){
  .zone__grid{grid-template-columns:1.2fr .8fr;gap:48px;}
}
.zone__map{
  width:100%;
  aspect-ratio:4/3;
  border-radius:18px;
  overflow:hidden;
  position:relative;
  background:var(--accent-soft);
  box-shadow:var(--shadow-sm);
}
.zone__map iframe{
  width:100%;height:100%;border:0;display:block;
  filter:saturate(.9) contrast(.95);
}
.zone__info h3{
  font-family:var(--ff-display);
  font-size:1.4rem;
  font-weight:500;
  margin-bottom:16px;
}
.zone__chips{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:28px;
}
.zone__chips span{
  display:inline-block;
  padding:7px 14px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  font-family:var(--ff-body);
  font-size:.86rem;
  color:var(--text);
}
.zone__hours{
  border-top:1px solid var(--border);
  padding-top:24px;
}
.zone__hours table{
  width:100%;
  border-collapse:collapse;
  font-family:var(--ff-body);
  font-size:.94rem;
}
.zone__hours td{
  padding:8px 0;
  border-bottom:1px dotted var(--border);
  color:var(--text-2);
}
.zone__hours td:first-child{color:var(--text);}
.zone__hours tr:last-child td{border-bottom:0;}
.zone__hours tr.is-today td{
  color:var(--accent);
  font-weight:500;
}
.zone__hours tr.is-today td:first-child::before{
  content:"\2022 ";
  color:var(--accent);
}

/* -------- CONTACT -------- */
.contact{
  background:var(--accent);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.contact::before{
  content:"";
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:22px 22px;
  pointer-events:none;
}
.contact .section__eyebrow,
.contact .section__title,
.contact .section__sub,
.contact h3,
.contact p,
.contact li,
.contact a,
.contact span,
.contact small{
  color:#fff;
}
.contact .section__eyebrow{color:rgba(255,255,255,.78);}
.contact .section__sub{color:rgba(255,255,255,.82);}
.contact .btn--light,
.contact .btn--light svg,
.contact .btn--light:hover{color:var(--text);}
.contact .btn--light:hover{background:var(--accent-soft);}
.contact__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  position:relative;
}
@media (min-width:768px){
  .contact__grid{grid-template-columns:1fr 1fr;gap:56px;}
}
.contact__info-block{
  display:flex;align-items:flex-start;gap:14px;
  padding:18px 0;
  border-bottom:1px solid rgba(255,255,255,.14);
}
.contact__info-block:last-child{border-bottom:0;}
.contact__info-icon{
  width:42px;height:42px;
  flex:0 0 42px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.10);
  border-radius:12px;
}
.contact__info-icon svg{width:20px;height:20px;color:#fff;}
.contact__info-label{
  font-family:var(--ff-body);
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  opacity:.7;
  margin-bottom:4px;
}
.contact__info-value{
  font-family:var(--ff-display);
  font-size:1.18rem;
  font-weight:500;
  line-height:1.3;
}
.contact__info-value a:hover{text-decoration:underline;}
.contact__cta-block{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px 4px 22px 4px;
  padding:28px;
}
.contact__cta-block h3{
  font-family:var(--ff-display);
  font-size:1.5rem;
  font-weight:500;
  margin:0 0 8px;
}
.contact__cta-block p{margin-bottom:22px;font-size:1rem;}
.contact__cta-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.contact__cta-list .btn{justify-content:flex-start;padding:16px 22px;}
.contact__signature{
  display:flex;align-items:center;gap:14px;
  margin-top:24px;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.14);
}
.contact__signature-avatar{
  width:48px;height:48px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  display:grid;place-items:center;
  font-family:var(--ff-display);
  font-weight:500;
  font-size:1.1rem;
}
.contact__signature-text{font-family:var(--ff-body);font-size:.92rem;line-height:1.4;}

/* -------- FOOTER -------- */
.footer{
  background:#222220;
  color:rgba(255,255,255,.78);
  padding:48px 0 28px;
  font-family:var(--ff-body);
  font-size:.92rem;
}
.footer__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  margin-bottom:36px;
}
@media (min-width:700px){
  .footer__grid{grid-template-columns:1.4fr 1fr 1fr;}
}
.footer h4{
  font-family:var(--ff-display);
  font-size:1.02rem;
  font-weight:500;
  color:#fff;
  margin:0 0 14px;
}
.footer__brand{
  display:flex;align-items:center;gap:12px;
  margin-bottom:14px;
}
.footer__brand .brand__mark{background:rgba(255,255,255,.12);}
.footer__brand .brand__name,
.footer__brand .brand__tag{color:#fff;}
.footer__about{color:rgba(255,255,255,.7);max-width:38ch;line-height:1.55;}
.footer ul{list-style:none;padding:0;margin:0;}
.footer li{margin-bottom:10px;}
.footer a{color:rgba(255,255,255,.78);transition:color .2s;}
.footer a:hover{color:#fff;}
.footer__bar{
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:22px;
  display:flex;flex-wrap:wrap;gap:12px;
  justify-content:space-between;
  font-size:.84rem;
  color:rgba(255,255,255,.6);
}
.footer__bar a{color:rgba(255,255,255,.7);}
.footer__bar a:hover{color:#fff;}

/* -------- LIGHTBOX -------- */
.lightbox{
  position:fixed;inset:0;
  background:rgba(20,22,20,.92);
  z-index:var(--z-modal);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.lightbox.is-open{display:flex;}
.lightbox__img{
  max-width:min(100%, 1100px);
  max-height:88vh;
  border-radius:8px;
  display:block;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
}
.lightbox__close,
.lightbox__nav{
  position:absolute;
  width:44px;height:44px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.12);
  border-radius:50%;
  color:#fff;
  border:0;
  cursor:pointer;
  transition:background .2s, transform .2s;
}
.lightbox__close{top:18px;right:18px;}
.lightbox__nav{top:50%;transform:translateY(-50%);}
.lightbox__prev{left:18px;}
.lightbox__next{right:18px;}
.lightbox__close:hover,
.lightbox__nav:hover{background:rgba(255,255,255,.22);}
@media (max-width:560px){
  .lightbox__nav{width:38px;height:38px;}
}

/* -------- MODAL MENTIONS -------- */
.modal{
  position:fixed;inset:0;
  background:rgba(20,22,20,.55);
  z-index:var(--z-modal);
  display:none;
  align-items:center;
  justify-content:center;
  padding:16px;
}
.modal.is-open{display:flex;}
.modal__panel{
  background:var(--bg);
  width:100%;
  max-width:680px;
  max-height:86vh;
  overflow-y:auto;
  border-radius:18px;
  padding:32px 28px;
  position:relative;
  box-shadow:var(--shadow-lg);
}
.modal__close{
  position:absolute;
  top:14px;right:14px;
  width:36px;height:36px;
  display:grid;place-items:center;
  background:transparent;border:0;
  font-size:1.4rem;cursor:pointer;
  color:var(--text-2);
}
.modal__close:hover{color:var(--text);}
.modal__panel h2{
  font-family:var(--ff-display);
  font-size:1.5rem;
  margin:0 0 16px;
  color:var(--text);
}
.modal__panel h3{
  font-family:var(--ff-display);
  font-size:1.08rem;
  margin:18px 0 6px;
  color:var(--text);
}
.modal__panel p,
.modal__panel li{font-size:.94rem;line-height:1.55;color:var(--text-2);}

/* -------- MOTION (MOT-3 Stagger marque) -------- */
[data-reveal]{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .55s ease, transform .55s ease;
}
[data-reveal].in{opacity:1;transform:none;}
.stagger > *{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .5s ease, transform .5s ease;
}
.stagger.in > *{opacity:1;transform:none;}
.stagger.in > *:nth-child(1){transition-delay:.05s;}
.stagger.in > *:nth-child(2){transition-delay:.12s;}
.stagger.in > *:nth-child(3){transition-delay:.19s;}
.stagger.in > *:nth-child(4){transition-delay:.26s;}
.stagger.in > *:nth-child(5){transition-delay:.33s;}
.stagger.in > *:nth-child(6){transition-delay:.40s;}
.stagger.in > *:nth-child(7){transition-delay:.47s;}
@media (prefers-reduced-motion:reduce){
  [data-reveal],
  .stagger > *{opacity:1;transform:none;transition:none;}
}

/* -------- UTILITIES -------- */
.no-scroll{overflow:hidden;}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* -------- PAGE REALISATIONS -------- */
.page-hero{
  padding-top:calc(var(--header-h-mobile) + 48px);
  padding-bottom:32px;
  text-align:center;
}
@media (min-width:768px){.page-hero{padding-top:calc(var(--header-h) + 72px);}}
.page-hero h1{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem, 5vw, 3.4rem);
  font-weight:400;
  letter-spacing:-.01em;
  margin:0 0 14px;
}
.page-hero p{
  font-size:1.05rem;
  color:var(--text-2);
  max-width:56ch;
  margin:0 auto 24px;
}
.page-hero__back{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-body);font-size:.92rem;
  color:var(--accent);margin-bottom:18px;
}
.page-hero__back:hover{text-decoration:underline;}
.gal-masonry{
  column-count:2;column-gap:14px;
}
@media (min-width:700px){.gal-masonry{column-count:3;}}
@media (min-width:1024px){.gal-masonry{column-count:3;}}
.gal-masonry__item{
  width:100%;
  margin:0 0 14px;
  border-radius:14px;
  overflow:hidden;
  display:block;
  break-inside:avoid;
  cursor:pointer;
  position:relative;
  background:var(--accent-soft);
}
.gal-masonry__item img{
  width:100%;height:auto;display:block;
  transition:transform .5s ease;
}
.gal-masonry__item:hover img{transform:scale(1.03);}
