/* ============================================================
   L'Entreprise Paysagiste — v4.2
   ============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --green-deep:#1a2e1a;
  --green:#2E7D32;
  --green-light:#4CAF50;
  --green-pale:#e8efe8;
  --cream:#FAF6F0;
  --cream-dark:#f0e9dd;
  --sand:#c9b896;
  --terracotta:#a04525;
  --terracotta-h:#863a1e;
  --text:#222;
  --text2:#666;
  --white:#fff;
  --border:#d8d0c4;
  --shadow-s:0 2px 8px rgba(0,0,0,.06);
  --shadow-m:0 6px 24px rgba(0,0,0,.09);
  --shadow-l:0 12px 40px rgba(0,0,0,.14);
  --font-h:'Cormorant Garamond',Georgia,serif;
  --font-b:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --r:10px;
  --rs:6px;
  --max:1100px;
}

html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:var(--font-b);font-size:1rem;line-height:1.65;color:var(--text);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none;transition:color .2s}
a:hover{color:var(--green-deep)}
h1,h2,h3{font-family:var(--font-h);font-weight:600;line-height:1.15;color:var(--green-deep)}
ul{list-style:none}
address{font-style:normal}

.skip-link{position:absolute;top:-100%;left:1rem;background:var(--green);color:#fff;padding:.4rem 1rem;border-radius:var(--rs);z-index:9999;font-weight:600}
.skip-link:focus{top:1rem;color:#fff}

.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}

/* ─── PARTICLES ─── */
.particles-canvas{position:fixed;inset:0;z-index:9998;pointer-events:none}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;font-family:var(--font-b);font-weight:600;font-size:.9rem;padding:.7rem 1.6rem;border-radius:var(--rs);border:2px solid transparent;cursor:pointer;transition:all .25s;text-decoration:none;line-height:1.4}
.btn--primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn--primary:hover{background:var(--green-deep);border-color:var(--green-deep);color:#fff}
.btn--glass{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.35);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.btn--glass:hover{background:rgba(255,255,255,.25);border-color:#fff;color:#fff}
.btn--outline{background:transparent;color:var(--green-deep);border-color:var(--green-deep)}
.btn--outline:hover{background:var(--green-deep);color:#fff}
.btn--terracotta{background:var(--terracotta);color:#fff;border-color:var(--terracotta)}
.btn--terracotta:hover{background:var(--terracotta-h);border-color:var(--terracotta-h);color:#fff}
.btn--contact-open{background:var(--white);color:var(--green-deep);border-color:rgba(255,255,255,.6);font-size:1rem;padding:1rem 2.5rem;border-radius:40px;box-shadow:var(--shadow-m);transition:all .3s}
.btn--contact-open:hover{transform:translateY(-2px);box-shadow:var(--shadow-l);color:var(--green-deep)}
.btn--lg{font-size:1rem;padding:.9rem 2.2rem}
.btn--sm{font-size:.85rem;padding:.4rem 1rem}
.btn--full{width:100%}

/* ─── SECTIONS ─── */
.section{padding:5rem 0}
.section--cream{background:var(--cream)}
.section--white{background:var(--white)}
.section__label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--green);margin-bottom:.4rem;text-align:center}
.section__label--light{color:var(--sand)}
.section__heading{font-size:2.2rem;text-align:center;margin-bottom:2rem}
.section__heading--left{text-align:left}
.section__cta{text-align:center;margin-top:2.5rem}

/* ─── NAVBAR ─── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 0;transition:background .4s,box-shadow .4s,padding .4s}
.navbar--scrolled{background:rgba(250,246,240,.96);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:var(--shadow-s);padding:.7rem 0}
.navbar__inner{display:flex;align-items:center;justify-content:space-between}

/* Logo area — pill/capsule aesthetic */
.navbar__logo{display:flex;align-items:center;gap:.7rem;color:#fff;transition:all .4s;background:rgba(30,30,30,.35);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:40px;padding:.25rem .9rem .25rem .25rem;border:1px solid rgba(255,255,255,.1)}
.navbar__logo:hover{color:#fff !important}
.navbar--scrolled .navbar__logo{color:var(--green-deep);background:rgba(240,233,221,.8);border-color:var(--border);backdrop-filter:none;-webkit-backdrop-filter:none}
.navbar--scrolled .navbar__logo:hover{color:var(--green-deep) !important}
.navbar__logo-img{width:48px;height:48px;border-radius:50%;object-fit:cover;padding:3px;transition:all .4s;background:transparent}
.navbar--scrolled .navbar__logo-img{background:rgba(46,125,50,.08)}
.navbar__name{font-family:var(--font-h);font-size:1.4rem;font-weight:700;letter-spacing:.01em;text-shadow:0 1px 8px rgba(0,0,0,.25)}
.navbar--scrolled .navbar__name{text-shadow:none}

/* Desktop pill - frosted dark capsule */
.navbar__pill{display:flex;align-items:center;gap:.1rem;background:rgba(30,30,30,.45);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:40px;padding:.35rem .5rem;border:1px solid rgba(255,255,255,.1)}
.navbar--scrolled .navbar__pill{background:rgba(240,233,221,.8);border-color:var(--border)}
.navbar__pill a{color:rgba(255,255,255,.9);font-weight:500;font-size:.88rem;padding:.35rem .85rem;border-radius:30px;transition:all .2s;white-space:nowrap}
.navbar__pill a:hover{background:rgba(255,255,255,.15);color:#fff}
.navbar--scrolled .navbar__pill a{color:var(--text)}
.navbar--scrolled .navbar__pill a:hover{background:var(--green-pale);color:var(--green-deep)}
.navbar__pill-cta{font-weight:600!important;padding:.4rem 1rem!important}
.navbar--scrolled .navbar__pill-cta{color:var(--green)!important}
/* On secondary pages, CTA looks like a normal link to avoid double-green confusion */
.page-secondary .navbar__pill-cta{color:var(--text)!important;font-weight:500!important}

/* Hamburger */
.navbar__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:0;border:0;cursor:pointer;padding:3px;z-index:110}
.navbar__toggle span{display:block;width:100%;height:2.5px;background:#fff;border-radius:2px;transition:all .3s}
.navbar--scrolled .navbar__toggle span{background:var(--text)}
.navbar__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg);background:#fff!important}
.navbar__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.navbar__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);background:#fff!important}

/* ─── NAVBAR ENTRANCE ANIMATION ─── */
.navbar[data-anim-state="hidden"] .navbar__logo{opacity:0;filter:blur(12px);transition:opacity 1s cubic-bezier(.16,1,.3,1),filter 1s cubic-bezier(.16,1,.3,1)}
.navbar[data-anim-state="visible"] .navbar__logo{opacity:1;filter:blur(0);transition:opacity 1s cubic-bezier(.16,1,.3,1),filter 1s cubic-bezier(.16,1,.3,1)}

.navbar[data-anim-state="hidden"] .navbar__pill{transform:scaleX(0);opacity:0;transition:transform .8s cubic-bezier(.16,1,.3,1) .3s,opacity .6s ease .3s}
.navbar[data-anim-state="visible"] .navbar__pill{transform:scaleX(1);opacity:1;transition:transform .8s cubic-bezier(.16,1,.3,1) .3s,opacity .6s ease .3s}

.navbar[data-anim-state="hidden"] .navbar__pill a{opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}
.navbar[data-anim-state="visible"] .navbar__pill a{opacity:1;transform:translateY(0)}
.navbar[data-anim-state="visible"] .navbar__pill a:nth-child(1){transition:opacity .4s ease .6s,transform .4s ease .6s}
.navbar[data-anim-state="visible"] .navbar__pill a:nth-child(2){transition:opacity .4s ease .72s,transform .4s ease .72s}
.navbar[data-anim-state="visible"] .navbar__pill a:nth-child(3){transition:opacity .4s ease .84s,transform .4s ease .84s}
.navbar[data-anim-state="visible"] .navbar__pill a:nth-child(4){transition:opacity .4s ease .96s,transform .4s ease .96s}

/* ─── HERO ─── */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero__bg{position:absolute;inset:0}
.hero__img{width:100%;height:100%;object-fit:cover;transform:scale(1.08)}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,46,26,.25) 0%,rgba(26,46,26,.55) 50%,rgba(26,46,26,.82) 100%)}
.hero__content{position:relative;z-index:2;max-width:800px;padding:0 1.5rem}
.hero__badge{display:inline-block;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);border-radius:40px;padding:.35rem 1.2rem;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.9);letter-spacing:.04em;margin-bottom:1.5rem}
.hero h1{font-size:clamp(1.8rem, 5.5vw, 3.2rem);color:#fff;margin-bottom:.3rem;line-height:1.15}
.hero__tagline{font-family:var(--font-h);font-size:clamp(1.5rem, 4.5vw, 2.4rem);color:#b5dab8;font-style:italic;font-weight:600;margin-bottom:1.2rem;line-height:1.2;white-space:nowrap}
.hero__sub{font-size:clamp(.9rem, 2.5vw, 1.15rem);color:rgba(255,255,255,.82);margin-bottom:2rem;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.6}
.hero__ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem}

/* ─── REVEAL ANIMATIONS ─── */
.reveal{opacity:0;transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal--up{transform:translateY(40px)}
.reveal--left{transform:translateX(-50px)}
.reveal--right{transform:translateX(50px)}
.reveal--scale{transform:scale(.92);opacity:0}
.reveal.is-visible{opacity:1;transform:none}
.reveal--d1{transition-delay:.18s}
.reveal--d2{transition-delay:.36s}
.reveal--d3{transition-delay:.54s}
.reveal--d4{transition-delay:.72s}

/* ─── VALUE ─── */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;max-width:960px;margin:0 auto}
.value-card{background:var(--white);border-radius:var(--r);padding:2rem 1.5rem 1.8rem;position:relative;border:1px solid var(--border);transition:transform .3s,box-shadow .3s;overflow:hidden}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.value-card__num{font-family:var(--font-b);font-size:2.8rem;font-weight:700;color:var(--terracotta);line-height:1;margin-bottom:.7rem;display:block;opacity:.5;letter-spacing:-.02em}
.value-card h2{font-size:1.1rem;margin-bottom:.45rem}
.value-card p{color:var(--text2);font-size:.88rem;line-height:1.65}

/* ─── SERVICES ─── */
.services-section{background:var(--white);padding:5rem 0}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem .8rem;max-width:520px;margin:0 auto 1.5rem}
.services-grid li{display:flex;align-items:center;gap:.6rem;font-size:.95rem;font-weight:500;padding:.5rem .7rem;border-radius:var(--rs);transition:background .2s;white-space:nowrap}
.services-grid li:hover{background:var(--green-pale)}
.services-grid__dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0}
.services-tax{display:flex;align-items:center;justify-content:center;gap:.6rem;background:var(--green-pale);border-radius:var(--rs);padding:.7rem 1.2rem;max-width:520px;margin:0 auto;font-size:.88rem;color:var(--green-deep);font-weight:500;border-left:3px solid var(--terracotta)}
.services-tax svg{flex-shrink:0}
.tax-block{background:var(--green-pale);border-radius:var(--r);padding:1.4rem 1.6rem;max-width:560px;margin:2rem auto 0;border-left:4px solid var(--terracotta)}
.tax-block__header{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem;color:var(--green-deep);font-size:1rem;flex-wrap:wrap}
.tax-block__header strong{font-size:1.1rem;white-space:nowrap}
.tax-block__badge{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--terracotta);background:rgba(160,69,37,.08);padding:.2rem .6rem;border-radius:20px;margin-left:.3rem;white-space:nowrap}
.tax-block__body{font-size:.88rem;color:var(--text2);line-height:1.65;margin:0}
.contact__response{font-size:.85rem;font-weight:600;color:var(--sand);letter-spacing:.02em}

/* ─── GALLERY SLIDER ─── */
.gallery-slider{position:relative}
.gallery-track{display:flex;gap:.8rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;padding:.5rem 0}
.gallery-track::-webkit-scrollbar{display:none}
.gallery-slide{flex:0 0 calc(33.333% - .55rem);scroll-snap-align:start;border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;aspect-ratio:4/3}
.gallery-slide img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.gallery-slide:hover img{transform:scale(1.08)}
.gallery__overlay{position:absolute;inset:0;background:rgba(26,46,26,.6);display:flex;align-items:flex-end;padding:1rem;opacity:0;transition:opacity .35s}
.gallery-slide:hover .gallery__overlay{opacity:1}
.gallery__overlay span{color:#fff;font-family:var(--font-h);font-size:1.05rem;font-weight:600;transform:translateY(10px);transition:transform .35s}
.gallery-slide:hover .gallery__overlay span{transform:translateY(0)}
.gallery-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;background:var(--cream);border:1px solid var(--border);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-m);transition:all .2s}
.gallery-btn:hover{background:var(--green-deep);color:#fff;border-color:var(--green-deep)}
.gallery-btn--prev{left:.5rem}
.gallery-btn--next{right:.5rem}
.gallery-hint{display:none;text-align:center;margin-top:.6rem;font-size:.78rem;color:var(--text2);opacity:.7}
.gallery-hint svg{vertical-align:middle;margin-right:.3rem}

/* ─── LIGHTBOX ─── */
.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s cubic-bezier(.32,.72,0,1),visibility .4s}
.lightbox.is-active{opacity:1;visibility:visible}
.lightbox__bg{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
.lightbox__img{position:relative;z-index:1;max-width:88vw;max-height:82vh;border-radius:var(--r);animation:lb-in .5s cubic-bezier(.32,.72,0,1);touch-action:pan-y}
.lightbox__img img{display:block;max-width:88vw;max-height:82vh;border-radius:var(--r);object-fit:contain;user-select:none;-webkit-user-drag:none;will-change:transform,opacity}
@keyframes lb-in{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.lightbox__close{position:absolute;z-index:4;top:1.2rem;right:1.2rem;display:flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.1rem;line-height:1;cursor:pointer;transition:background .25s cubic-bezier(.32,.72,0,1),transform .25s cubic-bezier(.32,.72,0,1)}
.lightbox__close:hover{background:rgba(255,255,255,.28);transform:scale(1.08)}
.lightbox__prev,.lightbox__next{display:none;position:absolute;top:50%;transform:translateY(-50%);z-index:2;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.6rem;line-height:1;width:3rem;height:3rem;border-radius:50%;cursor:pointer;transition:background .3s cubic-bezier(.32,.72,0,1),transform .3s cubic-bezier(.32,.72,0,1);align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.lightbox__prev:hover,.lightbox__next:hover{background:rgba(255,255,255,.28);transform:translateY(-50%) scale(1.1)}
.lightbox__prev{left:1.5rem}
.lightbox__next{right:1.5rem}
@media(min-width:769px){.lightbox__prev,.lightbox__next{display:flex}}
.lightbox__glow{position:absolute;inset:0;z-index:2;pointer-events:none;border-radius:var(--r);opacity:0}

/* Swipe hint — bottom of viewport, avoids blocking content */
.lightbox-hint{position:absolute;bottom:12%;left:50%;transform:translateX(-50%) scale(.95);z-index:10;display:flex;align-items:center;gap:.9rem;background:rgba(255,255,255,.15);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.2);border-radius:2rem;padding:.55rem 1.2rem;opacity:0;transition:opacity .4s ease,transform .4s ease;pointer-events:none}
.lightbox-hint.is-visible{opacity:1;transform:translateX(-50%) scale(1)}
.lightbox-hint__icon{font-size:1.2rem;color:#fff;animation:hintSlide 2s linear infinite}
.lightbox-hint__text{font-family:var(--font-b);font-size:.8rem;color:rgba(255,255,255,.9);white-space:nowrap}
@keyframes hintSlide{0%{transform:translateX(8px)}50%{transform:translateX(-8px)}100%{transform:translateX(8px)}}

/* ─── VIDEO SLIDER ─── */
.vslider{position:relative}
.vslider__track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;padding:.5rem 0}
.vslider__track::-webkit-scrollbar{display:none}
.vslider__slide{flex:0 0 calc(33.333% - .67rem);scroll-snap-align:start;border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;background:#111;box-shadow:var(--shadow-s);transition:transform .35s,box-shadow .35s}
.vslider__slide:hover{transform:translateY(-5px) scale(1.02);box-shadow:var(--shadow-m)}
.vslider__slide img{width:100%;aspect-ratio:16/9;object-fit:cover;transition:transform .4s,filter .4s}
.vslider__slide:hover img{transform:scale(1.06);filter:brightness(1.1)}
.vslider__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:0;border-radius:2rem;padding:.45rem 1rem;background:rgba(255,255,255,.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.25);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:background .25s,transform .25s;z-index:2}
.vslider__play svg{width:14px;height:14px;fill:#fff;margin-left:1px}
.vslider__play span{font-family:var(--font-b);font-size:.75rem;color:#fff;font-weight:500}
.vslider__play:hover{background:rgba(255,255,255,.3);transform:translate(-50%,-50%) scale(1.04)}
.vslider__btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;background:var(--cream);border:1px solid var(--border);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-m);transition:all .2s}
.vslider__btn:hover{background:var(--green-deep);color:#fff;border-color:var(--green-deep)}
.vslider__btn--prev{left:.3rem}
.vslider__btn--next{right:.3rem}

/* Video modal */
.vmodal{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.vmodal.is-active{opacity:1;visibility:visible}
.vmodal__bg{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.vmodal__close{position:absolute;top:1rem;right:1.5rem;z-index:2;background:0;border:0;color:#fff;font-size:2.8rem;cursor:pointer;transition:opacity .2s}
.vmodal__close:hover{opacity:.6}
.vmodal__frame{position:relative;z-index:1;width:88vw;max-width:920px;aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;animation:lb-in .3s ease}
.vmodal__frame iframe{width:100%;height:100%;border:0}
.vmodal__prev,.vmodal__next{display:none;position:absolute;top:50%;transform:translateY(-50%);z-index:2;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:1.6rem;line-height:1;width:3rem;height:3rem;border-radius:50%;cursor:pointer;transition:background .2s,transform .2s;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.vmodal__prev:hover,.vmodal__next:hover{background:rgba(255,255,255,.28);transform:translateY(-50%) scale(1.08)}
.vmodal__prev{left:1.5rem}
.vmodal__next{right:1.5rem}
@media(min-width:769px){.vmodal__prev,.vmodal__next{display:flex}}

/* ─── ZONE ─── */
.zone-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.zone__tags{display:grid;grid-template-columns:repeat(4,auto);gap:.4rem;margin:1rem 0;justify-content:start}
.zone__tags li{background:var(--green-pale);color:var(--green-deep);padding:.3rem .8rem;border-radius:20px;font-size:.85rem;font-weight:500;text-align:center;white-space:nowrap}
.zone__map iframe{width:100%;border-radius:var(--r)}

/* ─── CONTACT ─── */
.section--contact{background:linear-gradient(135deg,var(--green-deep) 0%,#243d24 100%);color:#fff;padding:5rem 0}
.contact-content{text-align:center;max-width:500px;margin:0 auto}
.contact-content h2{font-size:2rem;color:#fff;margin-bottom:.5rem}
.contact__sub{color:rgba(255,255,255,.75);margin-bottom:2rem;font-size:.95rem;line-height:1.6}
.contact__phone{display:inline-flex;align-items:center;gap:.5rem;font-size:1.6rem;font-family:var(--font-b);font-weight:700;color:#fff;margin-bottom:.8rem;letter-spacing:.02em;transition:color .2s}
.contact__phone:hover{color:var(--green-light)}
.contact__email{display:block;color:rgba(255,255,255,.7);font-size:.9rem;margin-bottom:1.2rem;transition:color .2s}
.contact__email:hover{color:#fff}
.contact__hours{color:rgba(255,255,255,.55);font-size:.85rem;margin-bottom:2rem}
.contact__hours-line{display:flex;align-items:center;justify-content:center;gap:.6rem}
.contact__hours-sep{width:1px;height:14px;background:rgba(255,255,255,.3);display:inline-block}

/* Contact modal */
.contact-modal{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .45s ease,visibility .45s ease}
.contact-modal.is-active{opacity:1;visibility:visible}
.contact-modal__bg{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.contact-modal__close{position:absolute;top:1rem;right:1.5rem;z-index:2;background:0;border:0;color:#fff;font-size:2.8rem;cursor:pointer;transition:opacity .2s}
.contact-modal__close:hover{opacity:.6}
.contact-modal__body{position:relative;z-index:1;background:var(--cream);padding:2.2rem 1.8rem;border-radius:var(--r);box-shadow:var(--shadow-l);width:88vw;max-width:420px;max-height:88vh;overflow-y:auto;transform:translateY(20px);opacity:0;transition:transform .45s cubic-bezier(.16,1,.3,1) .05s,opacity .45s ease .05s;-webkit-overflow-scrolling:touch}
.contact-modal.is-active .contact-modal__body{transform:translateY(0);opacity:1}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.form-group{margin-bottom:.75rem}
.form-group label{display:block;font-weight:600;font-size:.8rem;color:var(--text);margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.03em}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.6rem .8rem;font-family:var(--font-b);font-size:.92rem;border:1.5px solid var(--border);border-radius:var(--rs);background:var(--white);color:var(--text);transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(46,125,50,.1)}
.form-group input.is-error{border-color:#c62828}
.form-error{display:block;color:#c62828;font-size:.72rem;margin-top:.15rem;min-height:.8rem}
.form-note{text-align:center;color:var(--text2);font-size:.78rem;margin-top:.5rem}
.form-success{text-align:center;padding:3rem 1rem}
.form-success p{font-size:1.15rem;color:var(--green);font-weight:600}
.form-prev-notice{background:#fef3cd;border:1px solid #f0c040;color:#7a5c00;font-size:.82rem;padding:.55rem .75rem;border-radius:6px;margin-bottom:1rem;text-align:center}

/* ─── MENTIONS LÉGALES MODAL ─── */
.mentions-modal{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .45s ease,visibility .45s ease}
.mentions-modal.is-active{opacity:1;visibility:visible}
.mentions-modal__bg{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.mentions-modal__close{position:absolute;top:1rem;right:1.5rem;z-index:2;background:0;border:0;color:#fff;font-size:2.8rem;cursor:pointer;transition:opacity .2s}
.mentions-modal__close:hover{opacity:.6}
.mentions-modal__body{position:relative;z-index:1;background:var(--cream);padding:2.2rem 1.8rem;border-radius:var(--r);box-shadow:var(--shadow-l);width:90vw;max-width:540px;max-height:85vh;overflow-y:auto;transform:translateY(20px);opacity:0;transition:transform .45s cubic-bezier(.16,1,.3,1) .05s,opacity .45s ease .05s;-webkit-overflow-scrolling:touch}
.mentions-modal.is-active .mentions-modal__body{transform:translateY(0);opacity:1}
.mentions-modal__body h3{font-size:1.3rem;text-align:center;margin-bottom:1.2rem}
.mentions-modal__body h4{font-size:.82rem;font-family:var(--font-b);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--green-deep);margin:1rem 0 .3rem}
.mentions-modal__body h4:first-of-type{margin-top:0}
.mentions-modal__body p{font-size:.88rem;color:var(--text2);line-height:1.6}

/* ─── BLOG / CONSEILS ─── */
.conseils-page{padding-top:5rem}
.blog-intro{text-align:center;max-width:600px;margin:0 auto 2.5rem;color:var(--text2);font-size:.95rem;line-height:1.6}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.blog-grid--preview{grid-template-columns:repeat(2,1fr);max-width:720px;margin:0 auto}
.blog-card{background:#fff;border-radius:var(--r);box-shadow:0 2px 12px rgba(0,0,0,.06);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;display:block}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.blog-card__img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.blog-card__body{padding:1.2rem}
.blog-card__date{font-size:.75rem;color:var(--text2);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.04em}
.blog-card__title{font-family:var(--font-h);font-size:1.15rem;color:var(--green-deep);margin-bottom:.5rem;line-height:1.3}
.blog-card__excerpt{font-size:.88rem;color:var(--text2);line-height:1.6;margin-bottom:.8rem}
.blog-card__link{font-size:.85rem;color:var(--green);font-weight:600;display:inline-flex;align-items:center;gap:.3rem}
.blog-card__link::after{content:'\2192'}

/* ─── ARTICLE PAGE ─── */
.article-page{padding-top:5rem}
.article__hero{width:100%;max-height:420px;object-fit:cover;display:block}
.article__container{max-width:720px;margin:0 auto;padding:2rem 1.5rem 3rem}
.article__breadcrumb{font-size:.8rem;color:var(--text2);margin-bottom:1.2rem}
.article__breadcrumb a{color:var(--green);text-decoration:none}
.article__breadcrumb a:hover{text-decoration:underline}
.article__breadcrumb span{margin:0 .4rem;color:var(--border)}
.article__meta{display:flex;align-items:center;gap:1.2rem;font-size:.82rem;color:var(--text2);margin-bottom:.8rem}
.article__meta svg{width:14px;height:14px;vertical-align:-2px;margin-right:.25rem;stroke:var(--text2);fill:none;stroke-width:2}
.article__title{font-family:var(--font-h);font-size:2rem;color:var(--green-deep);line-height:1.2;margin-bottom:1.5rem}
.article__body{font-size:1rem;line-height:1.8;color:var(--text)}
.article__body mark{background:rgba(201,184,150,.25);color:inherit;padding:.05em .2em;border-radius:2px;font-style:normal}
.article__body p{margin-bottom:1.2rem}
.article__body h2{font-family:var(--font-h);font-size:1.5rem;color:var(--green-deep);margin:2.5rem 0 .8rem;line-height:1.25}
.article__body h3{font-family:var(--font-h);font-size:1.2rem;color:var(--green-deep);margin:1.8rem 0 .5rem}
.article__body img{width:100%;border-radius:var(--r);margin:1.5rem 0}
.article__body ul,.article__body ol{padding-left:1.5rem;margin-bottom:1.2rem}
.article__body li{margin-bottom:.4rem}
.article__body blockquote{border-left:3px solid var(--green);padding:.8rem 1.2rem;margin:1.5rem 0;background:var(--green-pale);border-radius:0 var(--rs) var(--rs) 0;font-style:italic;color:var(--text2)}
.article__cta-box{background:var(--green-pale);padding:2rem;border-radius:var(--r);text-align:center;margin-top:3rem}
.article__cta-box p{font-family:var(--font-h);font-size:1.3rem;color:var(--green-deep);margin-bottom:1rem}
.article__cta-box .btn{margin-top:.5rem}

/* ─── FOOTER ─── */
.footer{background:var(--cream-dark);border-top:1px solid var(--border);padding:2rem 0 1rem;color:var(--text)}
.footer__inner{display:flex;flex-direction:column;align-items:center;gap:1.2rem;text-align:center}
.footer__brand{display:flex;flex-direction:column;align-items:center;gap:.15rem}
.footer__logo-img{width:56px;height:56px;object-fit:cover}
.footer__brand strong{display:block;font-family:var(--font-h);font-size:1.25rem;line-height:1.2}
.footer__brand span{font-size:.8rem;color:var(--text2);line-height:1.2}
.footer__links{display:flex;flex-wrap:wrap;justify-content:center;gap:2.5rem}
.footer h3{font-size:.72rem;font-family:var(--font-b);font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text2);margin-bottom:.3rem}
.footer address,.footer p{font-size:.85rem;line-height:1.6;color:var(--text2)}
.footer a{color:#256b29}
.footer a:hover{color:var(--green-deep)}
.footer__social{display:flex;gap:.5rem;margin-top:.3rem;justify-content:center}
.footer__social a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--green-pale);color:var(--green-deep);transition:background .2s,color .2s}
.footer__social a:hover{background:var(--green);color:#fff}
.footer__bottom{display:flex;justify-content:center;align-items:center;gap:1.5rem;padding-top:.8rem;border-top:1px solid var(--border);font-size:.75rem;color:var(--text2);width:100%}
.footer__bottom a{color:var(--text2)}
.footer__bottom a:hover{color:var(--green)}

/* ─── GALERIE PAGE ─── */
.galerie-page{padding-top:5rem}
.galerie-page .section__heading{margin-bottom:.6rem}
.galerie-intro{text-align:center;color:var(--text2);font-size:.95rem;margin-bottom:2.5rem;margin-left:auto;margin-right:auto}
.galerie-grid{columns:3;column-gap:.8rem;column-fill:balance}
.galerie-grid .galerie-item{break-inside:avoid;margin-bottom:.8rem;border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.galerie-grid .galerie-item.is-visible{opacity:1;transform:translateY(0)}
.galerie-grid .galerie-item img{width:100%;display:block;transition:transform .45s cubic-bezier(.16,1,.3,1)}
.galerie-grid .galerie-item:hover img{transform:scale(1.05)}
.galerie-grid .galerie-item .galerie-overlay{position:absolute;inset:0;background:rgba(26,46,26,.55);display:flex;align-items:flex-end;padding:.8rem;opacity:0;transition:opacity .3s}
.galerie-grid .galerie-item:hover .galerie-overlay{opacity:1}
.galerie-overlay span{color:#fff;font-family:var(--font-h);font-size:.9rem;font-weight:600}

/* Pagination */
.galerie-pagination{display:flex;justify-content:center;align-items:center;gap:.4rem;margin-top:2.5rem}
.galerie-pagination button{min-width:40px;height:40px;border-radius:var(--rs);border:1.5px solid var(--border);background:var(--white);color:var(--text);font-family:var(--font-b);font-size:.88rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0 .6rem}
.galerie-pagination button:hover{background:var(--green-pale);border-color:var(--green);color:var(--green-deep)}
.galerie-pagination button.is-active{background:var(--green);color:#fff;border-color:var(--green)}
.galerie-pagination button:disabled{opacity:.35;cursor:default;pointer-events:none}
.galerie-pagination .gp-dots{color:var(--text2);font-size:.88rem;padding:0 .3rem}

/* Active page link in navbar */
.navbar__pill-active{color:var(--green) !important;font-weight:600 !important}
.navbar--scrolled .navbar__pill-active{color:var(--green) !important}

@media(max-width:1024px){
  .galerie-grid{columns:3}
}
@media(max-width:768px){
  .galerie-page{padding-top:4rem}
  .galerie-grid{columns:2;column-gap:.5rem}
  .galerie-grid .galerie-item{margin-bottom:.5rem}
  .galerie-intro{font-size:.88rem;margin-bottom:1.8rem}
}
@media(max-width:400px){
  .galerie-grid{columns:2;column-gap:.4rem}
  .galerie-grid .galerie-item{margin-bottom:.4rem}
}

/* ─── VIDEOS PAGE ─── */
.videos-page{padding-top:5rem}
.videos-page .section__heading{margin-bottom:.6rem}
.videos-intro{text-align:center;color:var(--text2);font-size:.95rem;margin-bottom:2.5rem;margin-left:auto;margin-right:auto}
.videos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.videos-grid .video-card{border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;background:#000;opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease,box-shadow .35s ease}
.videos-grid .video-card.is-visible{opacity:1;transform:translateY(0)}
.videos-grid .video-card.is-visible:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.video-card__thumb{position:relative;width:100%;padding-top:56.25%;overflow:hidden}
.video-card__thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video-card__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:0;border-radius:2rem;padding:.45rem 1rem;background:rgba(255,255,255,.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.25);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:background .25s,transform .25s;z-index:2}
.video-card__play svg{width:14px;height:14px;fill:#fff;margin-left:1px}
.video-card__play span{font-family:var(--font-b);font-size:.75rem;color:#fff;font-weight:500}
.video-card:hover .video-card__play{background:rgba(255,255,255,.3);transform:translate(-50%,-50%) scale(1.04)}

/* Video modal */
.video-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.video-modal.is-active{opacity:1;visibility:visible}
.video-modal__bg{position:absolute;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.video-modal__close{position:absolute;top:1rem;right:1.5rem;z-index:2;background:0;border:0;color:#fff;font-size:2.8rem;cursor:pointer;transition:opacity .2s}
.video-modal__close:hover{opacity:.6}
.video-modal__content{position:relative;z-index:1;width:min(88vw,960px);aspect-ratio:16/9;border-radius:var(--r);overflow:hidden}
.video-modal__content iframe{width:100%;height:100%;border:0}
.video-modal__prev,.video-modal__next{display:none;position:absolute;top:50%;transform:translateY(-50%);z-index:2;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:1.6rem;line-height:1;width:3rem;height:3rem;border-radius:50%;cursor:pointer;transition:background .2s,transform .2s;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.video-modal__prev:hover,.video-modal__next:hover{background:rgba(255,255,255,.28);transform:translateY(-50%) scale(1.08)}
.video-modal__prev{left:1.5rem}
.video-modal__next{right:1.5rem}
@media(min-width:769px){.video-modal__prev,.video-modal__next{display:flex}}

@media(max-width:768px){
  .videos-page{padding-top:4rem}
  .videos-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .videos-intro{font-size:.88rem;margin-bottom:1.8rem}
  .video-modal__content{width:95vw}
}
@media(max-width:400px){
  .videos-grid{grid-template-columns:1fr;gap:.5rem}
}

/* ─── MOBILE MENU (separate overlay, outside navbar) ─── */
.mobile-menu{
  position:fixed;inset:0;z-index:200;
  background:rgba(18,30,18,.88);
  backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);
  opacity:0;visibility:hidden;
  transition:opacity .35s ease,visibility .35s ease;
  cursor:pointer; /* clicking anywhere closes */
}
.mobile-menu.is-active{opacity:1;visibility:visible}

.mobile-menu__content{
  position:relative;z-index:1;
  display:flex;flex-direction:column;
  height:100%;padding:1.2rem 1.8rem 2rem;
  cursor:default; /* prevent close when clicking content */
}

/* Header: brand left + close right */
.mobile-menu__header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:auto;
}
.mobile-menu__brand{
  display:flex;align-items:center;gap:.65rem;
}
.mobile-menu__brand img{
  width:44px;height:44px;border-radius:50%;object-fit:cover;
}
.mobile-menu__brand span{
  font-family:var(--font-h);font-size:1.2rem;font-weight:700;
  color:#fff;letter-spacing:.01em;
}
.mobile-menu__close{
  background:0;border:0;
  color:rgba(255,255,255,.6);
  cursor:pointer;padding:.4rem;
  transition:color .2s,transform .25s;
}
.mobile-menu__close:hover{color:#fff;transform:rotate(90deg)}

/* Navigation links — centered vertically */
.mobile-menu__nav{
  display:flex;flex-direction:column;align-items:center;gap:.3rem;
  margin:auto 0;
}
.mobile-menu__link{
  font-family:var(--font-h);font-size:1.8rem;font-weight:600;
  color:rgba(255,255,255,.9);
  padding:.7rem 1.5rem;
  border-radius:var(--rs);
  letter-spacing:.02em;
  opacity:0;transform:translateY(16px);
  transition:opacity .35s ease,transform .35s ease,background .2s,color .2s;
}
.mobile-menu__link:hover{
  background:rgba(255,255,255,.08);
  color:#fff;
}
.mobile-menu.is-active .mobile-menu__link{opacity:1;transform:translateY(0)}
.mobile-menu.is-active .mobile-menu__link:nth-child(1){transition-delay:.08s}
.mobile-menu.is-active .mobile-menu__link:nth-child(2){transition-delay:.16s}
.mobile-menu.is-active .mobile-menu__link:nth-child(3){transition-delay:.24s}
.mobile-menu.is-active .mobile-menu__link:nth-child(4){transition-delay:.32s}
.mobile-menu.is-active .mobile-menu__link:nth-child(5){transition-delay:.40s}

/* Footer: phone number */
.mobile-menu__footer{
  margin-top:auto;text-align:center;
  opacity:0;transform:translateY(12px);
  transition:opacity .35s ease .3s,transform .35s ease .3s;
}
.mobile-menu.is-active .mobile-menu__footer{opacity:1;transform:translateY(0)}
.mobile-menu__phone{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--font-b);font-size:.88rem;font-weight:500;
  color:rgba(255,255,255,.45);
  letter-spacing:.03em;
  transition:color .2s;
}
.mobile-menu__phone:hover{color:#fff}

/* Hide mobile menu on desktop */
@media(min-width:769px){
  .mobile-menu{display:none}
}

/* ─── REDUCED MOTION ─── */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .hero__img{transform:none}
  .gallery-slide img,.vslider__slide img,.vslider__slide,.value-card{transition:none}
  .navbar[data-anim-state] .navbar__logo,
  .navbar[data-anim-state] .navbar__pill,
  .navbar[data-anim-state] .navbar__pill a{opacity:1!important;transform:none!important;filter:none!important;transition:none!important}
}

/* ─── TABLET ─── */
@media(max-width:1024px){
  .value-grid{grid-template-columns:1fr;gap:1.2rem;max-width:500px}
  .vslider__slide{flex:0 0 calc(50% - .5rem)}
  .gallery-slide{flex:0 0 calc(50% - .4rem)}
  .footer__links{gap:2rem}
  .review-card{flex:0 0 280px}
}

/* ─── MOBILE ─── */
@media(max-width:768px){
  .section{padding:3.5rem 0}
  .navbar{padding:.7rem 0;background:rgba(26,46,26,.15);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
  .navbar--scrolled{background:rgba(250,246,240,1);backdrop-filter:none;-webkit-backdrop-filter:none}
  .navbar__toggle{display:flex}
  .navbar__logo{padding:.2rem .7rem .2rem .2rem}
  .navbar__logo-img{width:40px;height:40px}
  .navbar__name{font-size:1.1rem}

  /* Hide desktop pill on mobile */
  .navbar__pill{display:none !important}

  .hero__tagline{white-space:normal}
  .hero__ctas{flex-direction:column;align-items:center}

  .value-grid{max-width:100%}

  .services-grid{grid-template-columns:repeat(2,1fr);gap:.3rem .6rem;max-width:340px}
  .services-grid li{font-size:.85rem;padding:.4rem .5rem}

  .gallery-slide{flex:0 0 78%}
  .gallery-btn{display:none}
  .gallery-hint{display:block}

  .vslider__slide{flex:0 0 85%}
  .vslider__btn{display:none}

  .review-card{flex:0 0 260px}

  .zone-grid{grid-template-columns:1fr;gap:2rem}
  .zone__map{display:none}
  .zone__text{text-align:center}
  .zone__text .section__heading--left{text-align:center}
  .zone__tags{justify-content:center;grid-template-columns:repeat(3,auto)}
  .zone__text .btn{margin:0 auto}

  .contact-content{padding:0 .5rem}
  .contact__phone{font-size:1.4rem}
  .form-row{grid-template-columns:1fr}
  .contact-modal__close{top:.6rem;right:1rem;font-size:2.2rem}
  .contact-modal__body{width:94vw;padding:2.6rem 1.2rem 1.2rem;max-height:85vh}
  .contact-modal__body .form-group{margin-bottom:.5rem}
  .contact-modal__body h3{font-size:1.15rem;margin-bottom:.7rem}

  .footer{padding:1.5rem 0 .8rem}
  .footer__inner{gap:1rem}
  .footer__links{gap:1.2rem}
  .footer__bottom{flex-direction:column;gap:.3rem}
  .footer__logo-img{width:48px;height:48px}

  .section__heading{font-size:1.8rem}

  .blog-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}
  .blog-card__title{font-size:1.05rem}
  .article__hero{max-height:250px}
  .article__title{font-size:1.5rem}
  .article__container{padding:1.5rem 1rem 2.5rem}
  .article__body h2{font-size:1.3rem}
  .conseils-page{padding-top:4rem}
}

/* ─── REVIEWS SLIDER ─── */
.reviews-score{display:flex;align-items:center;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}
.reviews-score__stars{display:flex;gap:2px}
.reviews-score__stars svg{width:22px;height:22px;fill:#F9A825;stroke:none}
.reviews-score__star--half{fill:url(#half-star-grad)}
.reviews-score__note{font-weight:700;font-size:1.05rem;color:var(--text)}
.reviews-score__count{color:var(--text2);font-size:.9rem}
.reviews-score__google{opacity:.85;flex-shrink:0}

.reviews-slider{position:relative;overflow:hidden}
.reviews-track{display:flex;gap:1.2rem;padding-right:1.2rem;width:max-content}
.review-card{flex:0 0 320px;background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem 1.6rem;box-shadow:var(--shadow-s);display:flex;flex-direction:column;gap:.8rem}
.review-card__stars{display:flex;gap:2px}
.review-card__stars svg{width:16px;height:16px;fill:#F9A825;stroke:none}
.review-card__text{font-size:.92rem;color:var(--text2);line-height:1.65;flex:1;font-style:italic}
.review-card__author{font-size:.82rem;font-weight:600;color:var(--green-deep);text-transform:uppercase;letter-spacing:.06em}

.reviews-dots{display:none}

/* ─── SMALL ─── */
@media(max-width:400px){
  .gallery-slide{flex:0 0 88%}
  .zone__tags{grid-template-columns:repeat(3,auto)}
  .blog-grid{grid-template-columns:1fr}
  .blog-grid--preview{max-width:none}
}

/* Large screens handled by clamp() */
