/* ═══════════════════════════════════════════════════
   LM COUVERTURE — Shared Design System
   Direction: "Silence du Toit" — Premium Edition
   Typographie: Playfair Display + Outfit + Space Mono
   ═══════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,700&family=Outfit:wght@200;300;400;500;600;700&family=Space+Mono:ital,wght@0,400;0,700;1,400&display=swap');

:root{
  --ch:#0E0C0A;--ch2:#171310;--ch3:#211D19;--ch4:#2C2620;
  --stone:#E8E2D9;--stone2:#F4F0EB;
  --or:#B8955A;--or2:#D4AD72;--or-dim:rgba(184,149,90,.1);--or-glow:rgba(184,149,90,.18);
  --muted:#8F8478;--muted2:#9B9189;
  --line:rgba(232,226,217,.065);--line-or:rgba(184,149,90,.18);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Outfit',system-ui,sans-serif;
  --mono:'Space Mono',monospace;
  --e1:cubic-bezier(.19,1,.22,1);--e2:cubic-bezier(.77,0,.175,1);--e3:cubic-bezier(.34,1.56,.64,1);
  --max:1280px;--gutter:clamp(1.25rem,4vw,3rem);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html {
  font-size:16px;
  scroll-behavior:smooth;
  overflow-x:hidden;
  scroll-padding-top:80px;
  -webkit-text-size-adjust:100%
}
body {
  font-family:var(--sans);
  background:var(--ch);
  color:var(--stone);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none
}
@media(pointer:coarse){body{cursor:auto}}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:none;border:none;background:none;color:inherit}
@media(pointer:coarse){button{cursor:pointer}}
@media(min-width:768px) {
  body::after {
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:.042;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px
}

}

.wrap{width:min(var(--max),calc(100% - var(--gutter)*2));margin-inline:auto}

/* ── TYPOGRAPHY ── */
h1 {
  font-family:var(--serif);
  font-size:clamp(2.4rem,6vw,5rem);
  line-height:1.02;
  letter-spacing:-.03em;
  font-weight:400
}
h2 {
  font-family:var(--serif);
  font-size:clamp(1.8rem,3.5vw,3.2rem);
  line-height:1.06;
  letter-spacing:-.03em;
  font-weight:400
}
h3{font-size:clamp(.95rem,1.6vw,1.15rem);letter-spacing:-.01em;font-weight:500}
p{line-height:1.65}
h1 em,h2 em{font-style:italic;color:var(--or);font-weight:400}
.headline {
  font-family:var(--serif);
  font-size:clamp(2.2rem,4.5vw,4rem);
  font-weight:400;
  line-height:1.06;
  letter-spacing:-.03em;
  color:var(--stone2)
}
.headline em{font-style:italic;color:var(--or);font-weight:400}
.body-copy{font-size:.88rem;font-weight:300;line-height:1.9;color:var(--muted2)}
.eyebrow {
  display:inline-block;
  font-family:var(--mono);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--or);
  margin-bottom:.8rem
}

/* ── CURSOR ── */
#cur {
  position:fixed;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--or);
  pointer-events:none;
  z-index:9997;
  transform:translate(-50%,-50%);
  mix-blend-mode:screen;
  transition:width .3s var(--e3),height .3s var(--e3),background .3s
}
#cur-trail {
  position:fixed;
  width:40px;
  height:40px;
  border-radius:50%;
  border:1px solid rgba(184,149,90,.45);
  pointer-events:none;
  z-index:9996;
  transform:translate(-50%,-50%);
  transition:border-color .3s,background .3s,width .35s var(--e3),height .35s var(--e3)
}
body.hov #cur{width:3px;height:3px}
body.hov #cur-trail{width:54px;height:54px;border-color:var(--or);background:rgba(184,149,90,.06)}
body.down #cur-trail{width:28px;height:28px}
@media(pointer:coarse){#cur,#cur-trail{display:none}}

/* ── SCROLL PROGRESS ── */
#sprog {
  position:fixed;
  top:0;
  left:0;
  height:2px;
  width:0%;
  background:linear-gradient(90deg,var(--or),var(--or2));
  z-index:9000;
  box-shadow:0 0 12px rgba(184,149,90,.5)
}

/* ── NAVIGATION ── */
.nav {
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:800;
  padding:1.6rem 0;
  transition:padding .35s var(--e1),background .35s,border-color .35s,box-shadow .35s;
  border-bottom:1px solid transparent
}
.nav.stuck {
  padding:.9rem 0;
  background:rgba(14,12,10,.93);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom-color:var(--line-or);
  box-shadow:0 16px 48px rgba(0,0,0,.4)
}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav-brand{display:flex;align-items:center;gap:.85rem;flex-shrink:0}
.nav-brand-img{width:36px;height:36px;opacity:.88}
.nav-brand-copy{display:flex;flex-direction:column;gap:.05rem}
.nav-brand-name {
  font-family:var(--serif);
  font-size:1rem;
  font-weight:600;
  letter-spacing:.01em;
  color:var(--stone2);
  line-height:1.1
}
.nav-brand-tag {
  font-family:var(--mono);
  font-size:.6rem;
  letter-spacing:.14em;
  color:var(--muted);
  text-transform:uppercase
}
.nav-links{display:flex;align-items:center;gap:.2rem}
.nav-links a {
  font-size:.78rem;
  font-weight:400;
  letter-spacing:.07em;
  color:var(--muted2);
  padding:.45rem .85rem;
  border-radius:2px;
  transition:color .22s,background .22s;
  text-transform:uppercase
}
.nav-links a:hover{color:var(--stone2);background:rgba(232,226,217,.05)}
.nav-links a.active{color:var(--or)}
.nav-actions{display:flex;align-items:center;gap:1rem;flex-shrink:0}
.nav-tel{font-family:var(--mono);font-size:.72rem;color:var(--muted);transition:color .22s}
.nav-tel:hover{color:var(--stone)}
.nav-devis {
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.55rem 1.35rem;
  background:var(--or);
  color:var(--ch);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  border-radius:1px;
  transition:background .22s,color .22s,transform .2s var(--e3),box-shadow .22s;
  box-shadow:0 4px 20px rgba(184,149,90,.25)
}
.nav-devis:hover {
  background:var(--or2);
  transform:translateY(-2px);
  box-shadow:0 10px 36px rgba(184,149,90,.38);
  color:var(--ch)
}
.nav-burger {
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:40px;
  height:40px;
  border-radius:50%;
  border:1px solid var(--line);
  background:transparent;
  padding:0;
  cursor:pointer
}
.nav-burger span {
  display:block;
  height:1px;
  width:52%;
  margin:0 auto;
  background:var(--stone);
  border-radius:1px;
  transition:transform .28s var(--e1),opacity .28s,width .28s
}
.nav-burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;width:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.nav-drawer {
  position:fixed;
  inset:0;
  background:rgba(10,8,6,.98);
  backdrop-filter:blur(20px);
  z-index:799;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:2rem var(--gutter);
  gap:.4rem;
  transform:translateY(-100%);
  transition:transform .45s var(--e1)
}
.nav-drawer.open{transform:none}
.nav-drawer a {
  font-family:var(--serif);
  font-size:clamp(2rem,7vw,3.5rem);
  font-weight:400;
  color:var(--stone2);
  padding:.4rem 0;
  border-bottom:1px solid var(--line);
  transition:color .22s,padding-left .3s var(--e1)
}
.nav-drawer a:hover{color:var(--or);padding-left:.8rem}
@media(max-width:900px){.nav-links,.nav-tel{display:none}.nav-burger{display:flex}}
@media(max-width:480px){.nav-devis{font-size:.68rem;padding:.48rem 1rem}}

/* ── PAGE HERO ── */
.page-hero {
  padding:clamp(8rem,15vw,11rem) 0 clamp(3rem,5vw,5rem);
  border-bottom:1px solid var(--line-or);
  position:relative;
  overflow:hidden;
  background:var(--ch)
}
.page-hero::before {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 60%,rgba(184,149,90,.06),transparent 65%)
}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{color:var(--stone2);margin-bottom:1.2rem}
.page-hero .lead {
  font-size:.95rem;
  font-weight:300;
  line-height:1.85;
  color:var(--muted2);
  max-width:580px
}

/* ── SECTIONS ── */
.s{padding:clamp(4rem,9vw,8rem) 0;position:relative;overflow:hidden}
.s-alt{background:var(--ch2)}
.s-dark{background:var(--ch3)}
.s::before,.s-alt::before,.s-dark::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:radial-gradient(ellipse 50% 35% at 50% 0%,rgba(184,149,90,.04),transparent 60%)
}
.s-label{display:flex;align-items:center;gap:1.1rem;margin-bottom:1.6rem}
.s-label-n{font-family:var(--mono);font-size:.6rem;color:var(--or);letter-spacing:.1em}
.s-label-rule{flex:1;height:1px;background:linear-gradient(to right,var(--line-or),transparent)}
.s-label-txt {
  font-size:.68rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted)
}
.s-header{max-width:680px;margin:0 auto 3.5rem;text-align:center}
.s-header .headline{margin-bottom:.85rem}
.s-header .body-copy{font-size:.9rem}

/* ── BUTTONS ── */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.9rem 2rem;
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  border-radius:1px;
  transition:transform .22s var(--e3),box-shadow .22s,background .22s,color .22s,border-color .22s;
  position:relative;
  overflow:hidden;
  cursor:pointer
}
.btn::after {
  content:'';
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.07);
  transform:translateX(-101%);
  transition:transform .35s var(--e1)
}
.btn:hover::after{transform:none}
.btn:hover{transform:translateY(-2px)}
.btn-solid {
  background:var(--or);
  color:var(--ch);
  font-weight:700;
  box-shadow:0 6px 28px rgba(184,149,90,.28)
}
.btn-solid:hover{background:var(--or2);box-shadow:0 14px 48px rgba(184,149,90,.4);color:var(--ch)}
.btn-line{border:1px solid rgba(232,226,217,.22);color:var(--stone);background:transparent}
.btn-line:hover{border-color:rgba(232,226,217,.55);color:var(--stone2)}

/* ── REVEAL ── */
[data-reveal]{opacity:0;transition:opacity .9s var(--e1),transform .9s var(--e1)}
[data-reveal="up"]{transform:translateY(28px)}
[data-reveal="left"]{transform:translateX(-24px)}
[data-reveal="right"]{transform:translateX(24px)}
[data-reveal="scale"]{transform:scale(.96)}
[data-reveal].on{opacity:1;transform:none}

/* ── CARDS ── */
.card {
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:2px;
  padding:2rem;
  transition:border-color .3s,transform .3s,box-shadow .3s
}
.card:hover {
  border-color:var(--line-or);
  transform:translateY(-4px);
  box-shadow:0 20px 50px rgba(0,0,0,.3)
}
.card-gold {
  border-color:var(--line-or);
  background:linear-gradient(145deg,rgba(184,149,90,.06),rgba(184,149,90,.02))
}

/* ── GALLERY / LIGHTBOX ── */
.lb {
  position:fixed;
  inset:0;
  z-index:3000;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .28s var(--e1)
}
.lb.on{opacity:1;pointer-events:auto}
.lb-bg {
  position:absolute;
  inset:0;
  background:rgba(8,6,4,.95);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px)
}
.lb-content {
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1.2rem;
  max-width:min(900px,95vw);
  width:100%;
  padding:1rem
}
.lb-img-wrap {
  position:relative;
  width:100%;
  max-height:78vh;
  display:flex;
  align-items:center;
  justify-content:center
}
.lb-img {
  max-width:100%;
  max-height:78vh;
  object-fit:contain;
  border-radius:2px;
  border:1px solid var(--line);
  box-shadow:0 32px 80px rgba(0,0,0,.7)
}
.lb-close {
  position:fixed;
  top:1.5rem;
  right:1.5rem;
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid var(--line-or);
  background:var(--ch2);
  color:var(--stone);
  font-size:1.3rem;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:2;
  transition:background .2s,border-color .2s,transform .2s var(--e3)
}
.lb-close:hover{background:var(--or-dim);border-color:var(--or);transform:rotate(90deg)}
/* .lb-prev / .lb-next → défini dans premium-v4.css */
.lb-meta{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 .2rem}
.lb-cap {
  font-family:var(--mono);
  font-size:.65rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted)
}
.lb-count{font-family:var(--mono);font-size:.65rem;color:var(--muted);letter-spacing:.1em}


/* ── FORMS ── */
.form-lux .f-row{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem}
.form-lux .f-group{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.4rem}
.form-lux .f-label {
  font-family:var(--mono);
  font-size:.58rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted)
}
.form-lux input,.form-lux select,.form-lux textarea {
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(232,226,217,.12);
  padding:.7rem 0;
  font-family:var(--sans);
  font-size:.87rem;
  font-weight:300;
  color:var(--stone);
  outline:none;
  transition:border-color .28s;
  -webkit-appearance:none;
  width:100%;
  border-radius:0
}
.form-lux input:focus,.form-lux select:focus,.form-lux textarea:focus{border-bottom-color:var(--or)}
.form-lux input::placeholder,.form-lux textarea::placeholder{color:rgba(124,112,104,.45)}
.form-lux select option{background:var(--ch2);color:var(--stone)}
.form-lux textarea{resize:none;height:85px}
.f-check{display:flex;align-items:flex-start;gap:.7rem;margin:.5rem 0 1.8rem}
.f-check input{margin-top:.2rem;accent-color:var(--or);flex-shrink:0;width:14px;height:14px}
.f-check span {
  font-size:.76rem;
  font-weight:300;
  color:var(--muted);
  line-height:1.6;
  word-break:break-word;
  max-width:100%
}
.form-note-sm {
  font-size:.68rem;
  font-weight:300;
  color:var(--muted);
  text-align:center;
  margin-top:.75rem;
  line-height:1.55
}
@media(max-width:680px){.form-lux .f-row{grid-template-columns:1fr}}

/* ── FOOTER ── */
.footer{background:#090706;border-top:1px solid rgba(184,149,90,.12);padding:4.5rem 0 1.5rem}
.footer-grid {
  display:grid;
  grid-template-columns:1.5fr repeat(3,1fr);
  gap:3rem;
  padding-bottom:3rem;
  border-bottom:1px solid var(--line)
}
.footer-brand-name {
  font-family:var(--serif);
  font-size:1.4rem;
  font-weight:400;
  letter-spacing:-.02em;
  color:var(--stone2);
  margin-bottom:.55rem
}
.footer-brand-desc {
  font-size:.78rem;
  font-weight:300;
  line-height:1.75;
  color:var(--muted);
  max-width:265px
}
.footer-col h4 {
  font-family:var(--mono);
  font-size:.58rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1.2rem
}
.footer-links{display:flex;flex-direction:column;gap:.55rem}
.footer-links a,.footer-links li {
  font-size:.8rem;
  font-weight:300;
  color:var(--muted);
  line-height:1.5;
  transition:color .22s,transform .22s;
  display:inline-block
}
.footer-links a:hover{color:var(--stone2);transform:translateX(3px)}
.footer-bottom {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  padding-top:1.8rem
}
.footer-bottom p{font-size:.7rem;font-weight:300;color:rgba(124,112,104,.45)}
@media(max-width:1024px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px) {
  .footer-grid {
  grid-template-columns:1fr
}
.footer-bottom {
  flex-direction:column;
  align-items:flex-start
}

}

/* ── FIXED UI ── */

#scroll-top {
  position:fixed;
  right:1.6rem;
  bottom:5.6rem;
  width:38px;
  height:38px;
  border-radius:50%;
  border:1px solid var(--line-or);
  background:var(--ch2);
  color:var(--or);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.85rem;
  cursor:pointer;
  z-index:900;
  opacity:0;
  pointer-events:none;
  transform:translateY(10px);
  transition:opacity .28s,transform .28s;
  box-shadow:0 6px 20px rgba(0,0,0,.4)
}
#scroll-top.on{opacity:1;pointer-events:auto;transform:none}
#scroll-top:hover{background:var(--or-dim)}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--ch)}
::-webkit-scrollbar-thumb{background:rgba(184,149,90,.22);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:rgba(184,149,90,.42)}
:focus-visible{outline:2px solid var(--or);outline-offset:4px}

/* Patch V3 checkbox overflow */
.form-lux .f-check input[type="checkbox"] {
  width:14px;
  min-width:14px;
  max-width:14px;
  height:14px;
  padding:0;
  -webkit-appearance:checkbox;
  appearance:auto
}
.form-lux .f-check {
  display:grid;
  grid-template-columns:16px minmax(0,1fr);
  align-items:start
}
.form-lux .f-check span {
  min-width:0;
  white-space:normal;
  overflow-wrap:anywhere
}


/* Patch V4 — navigation homogène */
.nav-links { gap: .05rem; }
.nav-links a { white-space: nowrap; }
@media(max-width:1080px) {
  .nav-links a {
  padding-inline:.55rem;
  font-size:.72rem
}
.nav-actions {
  gap:.75rem
}

}

/* V5 polish: compact SEO links + service images + nav ergonomics */
.locality-link-grid {
  margin-top:2.1rem;
  padding:1.15rem 1.2rem;
  border:1px solid rgba(184,149,90,.18);
  background:rgba(255,255,255,.018)
}
.locality-link-grid h3 {
  margin:0 0 .9rem;
  font-family:var(--serif);
  font-size:1.05rem;
  color:var(--stone2)
}
.locality-link-grid div{display:flex;flex-wrap:wrap;gap:.55rem}
.locality-link-grid a {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:.55rem .78rem;
  border:1px solid rgba(184,149,90,.32);
  background:rgba(184,149,90,.045);
  color:var(--or2);
  font-family:var(--mono);
  font-size:.66rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  text-decoration:none;
  transition:background .2s,border-color .2s,transform .2s
}
.locality-link-grid a:hover {
  background:rgba(184,149,90,.14);
  border-color:rgba(184,149,90,.65);
  transform:translateY(-1px)
}
.svc-full-img img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:1180px) {
  .nav-links a {
  padding-inline:.48rem;
  font-size:.68rem
}
.nav-devis {
  padding-inline:1rem
}
.nav-tel {
  font-size:.72rem
}

}
@media(max-width:1030px){.nav-links a[href="recrutement.html"]{display:none}}


/* V7 — dernière passe SEO / accessibilité / menu mobile.
   Ici on garde le look premium, mais on rend le menu vraiment utilisable sur téléphone. */
.nav-burger { position: relative; z-index: 1002; }
.nav-burger:focus-visible,
.nav-devis:focus-visible,
.nav-links a:focus-visible,
.nav-drawer a:focus-visible,
.nav-drawer-close:focus-visible {
  outline: 2px solid var(--or);
  outline-offset: 4px;
}
.nav-drawer {
  z-index: 1000;
  padding-top: 6rem;
  padding-bottom: 2rem;
  overflow-y: auto;
}
.nav-drawer-close {
  position: fixed;
  top: 1.15rem;
  right: max(1rem, var(--gutter));
  width: 48px;
  height: 48px;
  border: 1px solid var(--line-or);
  border-radius: 999px;
  background: rgba(14,12,10,.72);
  color: var(--stone2);
  cursor: pointer;
  display: grid;
  place-items: center;
  z-index: 1003;
  box-shadow: 0 18px 44px rgba(0,0,0,.35);
}
.nav-drawer-close span {
  position: absolute;
  width: 22px;
  height: 1px;
  background: var(--stone2);
  border-radius: 2px;
}
.nav-drawer-close span:first-child { transform: rotate(45deg); }
.nav-drawer-close span:last-child { transform: rotate(-45deg); }
.drawer-devis {
  color: var(--ch);
  background: linear-gradient(135deg, var(--or2), var(--or));
  border: 0;
  padding: .9rem 1.1rem;
  margin-top: .6rem;
  font-family: var(--mono);
  font-size: clamp(.9rem, 4vw, 1.05rem);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.drawer-phone {
  font-family: var(--mono);
  font-size: clamp(1rem, 4.5vw, 1.35rem);
  color: var(--or);
}
.local-seo-links { padding: 2rem 0 1rem; }
.local-seo-links h2 {
  margin: 1rem 0 .65rem;
  font-family: var(--serif);
  font-size: clamp(1.7rem, 3vw, 2.7rem);
  color: var(--stone2);
}
.local-seo-links p { max-width: 760px; color: var(--muted2); margin-bottom: 1.25rem; }
.local-links-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .65rem;
}
.local-links-grid a {
  border: 1px solid var(--line);
  background: rgba(232,226,217,.025);
  color: var(--stone2);
  padding: .72rem .85rem;
  font-size: .85rem;
  transition: border-color .2s, background .2s, color .2s, transform .2s;
}
.local-links-grid a:hover,
.local-links-grid a:focus-visible {
  border-color: var(--line-or);
  background: rgba(184,149,90,.09);
  color: var(--or2);
  transform: translateY(-1px);
}
@media (max-width: 980px) {
  .nav-links, .nav-tel { display: none; }
  .nav-burger { display: flex; }
  .nav-row { gap: .8rem; }
  .nav-devis { padding-inline: .95rem; font-size: .66rem; }
  .local-links-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .nav { padding: .82rem 0; background: rgba(14,12,10,.94); border-bottom-color: var(--line-or); }
  .nav-brand-copy { max-width: 140px; }
  .nav-brand-name { font-size: .88rem; }
  .nav-brand-tag { font-size: .52rem; }
  .nav-devis { padding: .54rem .72rem; letter-spacing: .08em; }
  .nav-drawer { justify-content: flex-start; }
  .nav-drawer a { font-size: clamp(1.65rem, 9vw, 2.5rem); }
  .local-links-grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
*, *::before, *::after {
   scroll-behavior: auto;
   transition-duration: .01ms;
   animation-duration: .01ms;
   animation-iteration-count: 1; 
}
}

html.menu-open, html.menu-open body { overflow: hidden; }

/* V8 — CTA localités / zones plus visibles. */
.local-contact-btn,
.zone-card .zone-card-link,
.local-card .zone-card-link {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:.78rem 1.1rem;
  border:1px solid rgba(184,149,90,.42);
  background:rgba(184,149,90,.10);
  color:var(--or2);
  font-family:var(--mono);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.local-contact-btn:hover,
.zone-card .zone-card-link:hover,
.local-card .zone-card-link:hover {
  background:var(--or);
  color:var(--ch);
  border-color:var(--or);
}

/* V9 — fix iPhone : la croix de fermeture doit rester visible, même avec Safari et le notch.
   Je la pose en fixe, bien grosse, avec un fond clair pour qu'on ne la cherche pas. */
@media (max-width: 980px) {
  html.menu-open,
  html.menu-open body {
    overflow: hidden;
  }

  .nav-drawer {
    position: fixed;
    inset: 0;
    z-index: 9998;
    padding-top: calc(env(safe-area-inset-top, 0px) + 96px);
    padding-right: max(1.5rem, env(safe-area-inset-right, 0px));
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 2rem);
    padding-left: max(1.5rem, env(safe-area-inset-left, 0px));
    justify-content: flex-start;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .nav-drawer-close {
    position: fixed;
    top: calc(env(safe-area-inset-top, 0px) + 14px);
    right: calc(env(safe-area-inset-right, 0px) + 16px);
    z-index: 10050;
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    border: 1px solid rgba(184,149,90,.55);
    background: rgba(232,226,217,.96);
    box-shadow: 0 18px 42px rgba(0,0,0,.45);
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateZ(0);
    -webkit-tap-highlight-color: transparent;
  }

  .nav-drawer.open .nav-drawer-close {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .nav-drawer-close span,
  .nav-drawer-close::before,
  .nav-drawer-close::after {
    content: "";
    position: absolute;
    width: 26px;
    height: 2px;
    border-radius: 999px;
    background: #0e0c0a;
  }

  .nav-drawer-close span:first-child,
  .nav-drawer-close::before {
    transform: rotate(45deg);
  }

  .nav-drawer-close span:last-child,
  .nav-drawer-close::after {
    transform: rotate(-45deg);
  }
}

/* V10 — accessibilité sans casser le style premium */
:root{--muted:#a99f96;--muted2:#c3bab2}
button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible {
  outline:2px solid var(--gold);
  outline-offset:4px
}
.footer-col h3 {
  font-family:var(--mono);
  font-size:.58rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1.2rem
}
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after {
  animation-duration:.01ms;
  animation-iteration-count:1;
  scroll-behavior:auto;
  transition-duration:.01ms
}

}

/* ── Print styles ── */
@media print {
#cur, #cur-trail, #sprog, #scroll-top, .nav-burger, .nav-drawer {
   display: none !important; 
}
  body { background: #fff; color: #000; cursor: auto; }
  .nav { position: static; background: #fff; border: none; padding: .5rem 0; }
  .nav-devis { display: none; }
  a { color: #000; }
  a[href]::after { content: " (" attr(href) ")"; font-size: .75em; }
  a[href^="tel"]::after, a[href^="mailto"]::after { content: " (" attr(href) ")"; }
}

/* ── Autofill mobile — supprime le fond jaune navigateur ── */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px #171310 inset !important;
  -webkit-text-fill-color: #E8E2D9 !important;
  caret-color: #E8E2D9;
  background-color: #171310 !important;
  color: #E8E2D9 !important;
  transition: background-color 9999s ease-in-out 0s;
}


/* Correctif articles : ne jamais cacher le curseur natif si le curseur premium n'est pas injecté. */
body:not(.custom-cursor-ready){cursor:auto;}
body:not(.custom-cursor-ready) a, body:not(.custom-cursor-ready) button{cursor:pointer;}
