/* ══════════════════════════════════════════════════════════════
   LM COUVERTURE — core.css
   Système de design partagé — toutes les pages sauf accueil
   
   Contient (dans l'ordre de cascade) :
   1. Base : variables, reset, typographie, layout utilitaires
   2. Composants : boutons, cartes, formulaires, galerie, animations
   3. Navigation : barre fixe, drawer mobile, burger
   
   Sources originales fusionnées :
   • luxury.css (base design system)
   • premium-v4.css (composants améliorés)
   • nav-premium.css (navigation définitive)
   ══════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════
   PARTIE 1 — BASE (variables, reset, typographie, composants)
   ══════════════════════════════════════════════════════════ */

:root {
  /* — Palette — */
  --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);
  /* — Typo — */
  --serif: 'Playfair Display', Georgia, serif;
  --sans: 'Outfit', system-ui, sans-serif;
  --mono: 'Space Mono', monospace;
  /* — Motion — */
  --e1: cubic-bezier(.19,1,.22,1);
  --e2: cubic-bezier(.77,0,.175,1);
  --e3: cubic-bezier(.34,1.56,.64,1);
  /* — Layout — */
  --max: 1280px;
  --gutter: clamp(1.25rem,4vw,3rem);
  --nav-h: 80px;
  /* — Gold — */
  --gold: #b8955a;
}

*,*::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)
}

/* ── 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 supprimé — nav géré par nav-premium.css */
/* 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}}



/* ── LOCAL SEO LINKS (zones d'intervention) ── */
.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 — consolidated dans la section V10 ci-dessous */

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 supprimé — nav-drawer géré par nav-premium.css */
/* V10 — accessibilité sans casser le style premium */
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;}

/* ── Skip to content (accessibilité) ── */
.skip-to-content {
  position: absolute;
  top: -100px;
  left: 1rem;
  z-index: 10000;
  padding: .6rem 1.2rem;
  background: var(--or);
  color: var(--ch);
  font-family: var(--mono);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 1px;
  transition: top .2s;
}
.skip-to-content:focus { top: 1rem; }

/* ── Breadcrumb ── */
.breadcrumb {
  font-size: .75rem;
  color: var(--muted);
  margin-bottom: 1rem;
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
  align-items: center;
}
.breadcrumb a { color: var(--or); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }

/* ── Hero actions (shared) ── */
.hero-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 2rem;
}

/* ── Service cards grid ── */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.2rem;
  margin-top: 1rem;
}

.svc-card {
  display: block;
  border: 1px solid rgba(232, 226, 217, .08);
  padding: 1.5rem;
  text-decoration: none;
  background: rgba(255, 255, 255, .02);
  transition: border-color .2s, transform .2s, background .2s;
}

.svc-card:hover {
  border-color: rgba(184, 149, 90, .4);
  background: rgba(184, 149, 90, .05);
  transform: translateY(-2px);
}

.svc-card-num {
  font-family: var(--mono);
  font-size: .6rem;
  color: var(--or);
  letter-spacing: .15em;
  margin-bottom: .6rem;
}

.svc-card h3 {
  font-family: var(--serif);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--stone2);
  margin-bottom: .5rem;
}

.svc-card p {
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.6;
}

/* ── CTA section ── */
.cta-section { text-align: center; }

@media (max-width: 600px) {
  .hero-actions { flex-direction: column; }
  .svc-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════
   STICKY MOBILE CTA — global (toutes les pages)
   ══════════════════════════════════════════════════════ */
.cta-sticky {
  display: none;
  position: fixed;
  bottom: 1.4rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 700;
  background: var(--or);
  color: #0e0c0a;
  padding: 0.88rem 2rem;
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 700;
  white-space: nowrap;
  text-decoration: none;
  box-shadow: 0 8px 32px rgba(184,149,90,.45), 0 2px 8px rgba(0,0,0,.3);
  align-items: center;
  gap: 0.55rem;
  border-radius: 1px;
  transition: opacity 0.3s ease, transform 0.3s ease, background 0.2s;
}
.cta-sticky svg { flex-shrink: 0; }
.cta-sticky:hover { background: var(--or2); }
.cta-sticky.hide {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(1rem);
}
@media (max-width: 768px) {
  .cta-sticky { display: flex; }
}


/* ══════════════════════════════════════════════════════════
   PARTIE 2 — COMPOSANTS PREMIUM (urgence-band, lightbox,
   perks, scroll-top, animations, sélection)
   ══════════════════════════════════════════════════════════ */

.nav-spacer {
  height: var(--nav-h, 80px);
  display: block;
}

/* L'urgence-band est dans le flux normal — pas de position spéciale */
.urgence-band {
  position: static;
  background: linear-gradient(135deg, #1A0F0A 0%, #1e1208 100%);
  border-bottom: 1px solid rgba(184,149,90,.2);
  border-top: none;
  padding: .7rem 0;
}

/* Hero : padding normal, le spacer s'est déjà occupé de l'offset nav */
.hero { margin-top: 0; }

@media (max-width: 960px) {
  .nav-spacer { height: var(--nav-h, 68px); }
  .urgence-txt { font-size: .58rem; letter-spacing: .13em; }
}

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  2. ICÔNES PERK — SVG premium (remplace les emojis)             ║
   ╚══════════════════════════════════════════════════════════════════╝ */

.perk {
  position: relative;
  padding: 2rem 1.5rem 1.8rem;
  border: 1px solid rgba(232,226,217,.07);
  background: var(--ch2, #171310);
  text-align: center;
  transition: border-color .35s, background .35s, transform .35s cubic-bezier(.19,1,.22,1);
  overflow: hidden;
}

.perk::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--or, #B8955A), transparent);
  opacity: 0;
  transition: opacity .35s;
}

.perk:hover {
  border-color: rgba(184,149,90,.2);
  background: rgba(184,149,90,.04);
  transform: translateY(-4px);
}

.perk:hover::before {
  opacity: 1;
}

/* Conteneur icône — cercle or discret */
.perk-ico {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid rgba(184,149,90,.2);
  background: rgba(184,149,90,.06);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.2rem;
  transition: border-color .35s, background .35s;
  font-size: 0; /* masque l'emoji si toujours présent */
}
/* Masquer tout contenu texte (emoji) dans perk-ico */
.perk-ico::before { font-size: 0; }

.perk:hover .perk-ico {
  border-color: rgba(184,149,90,.45);
  background: rgba(184,149,90,.1);
}

.perk-ico svg {
  width: 22px;
  height: 22px;
  color: var(--or, #B8955A);
  stroke-width: 1.5;
  flex-shrink: 0;
}

.perk h4 {
  font-family: var(--serif, 'Playfair Display', serif);
  font-size: .95rem;
  font-weight: 500;
  color: var(--stone2, #F4F0EB);
  margin-bottom: .5rem;
  letter-spacing: -.01em;
}

.perk p {
  font-size: .8rem;
  color: var(--muted, #8F8478);
  line-height: 1.65;
}


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  3. LIGHTBOX GALERIE — overlay cinématique premium              ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* Overlay principal */
#lb-overlay {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(5, 4, 3, .96);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;

  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .35s cubic-bezier(.19,1,.22,1),
              visibility 0s linear .35s;
}

#lb-overlay.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity .35s cubic-bezier(.19,1,.22,1),
              visibility 0s linear 0s;
}

/* Conteneur central image */
.lb-stage {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 1100px;
  max-height: calc(100svh - 4rem);
}

/* Image */
.lb-img-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.lb-img-wrap img {
  max-width: 100%;
  max-height: calc(100svh - 8rem);
  object-fit: contain;
  display: block;
  transition: opacity .28s, transform .4s cubic-bezier(.19,1,.22,1);
}

.lb-img-wrap img.lb-transitioning {
  opacity: 0;
  transform: scale(.97);
}

/* Gradient bas pour la légende */
.lb-img-wrap::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 30%;
  background: linear-gradient(to top, rgba(5,4,3,.7), transparent);
  pointer-events: none;
  border-radius: 0 0 2px 2px;
}

/* Légende */
.lb-caption {
  position: absolute;
  bottom: 1.2rem;
  left: 1.5rem;
  right: 5rem;
  z-index: 1;
}

.lb-caption-title {
  font-family: var(--mono, 'Space Mono', monospace);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--stone2, #F4F0EB);
  display: block;
  margin-bottom: .2rem;
}

.lb-caption-sub {
  font-family: var(--mono, 'Space Mono', monospace);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--or, #B8955A);
  opacity: .8;
}

/* Compteur */
.lb-counter {
  position: absolute;
  bottom: 1.4rem;
  right: 1.5rem;
  font-family: var(--mono, 'Space Mono', monospace);
  font-size: .6rem;
  letter-spacing: .14em;
  color: var(--muted, #8F8478);
  z-index: 1;
}

/* Bouton fermer */
.lb-close {
  position: fixed;
  top: 1.5rem;
  right: 1.5rem;
  z-index: 9001;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(184,149,90,.35);
  background: rgba(20,17,14,.8);
  display: grid;
  place-items: center;
  cursor: pointer;
  color: var(--stone, #E8E2D9);
  transition: border-color .22s, background .22s, transform .22s;
}

.lb-close:hover {
  border-color: rgba(184,149,90,.7);
  background: rgba(184,149,90,.1);
  transform: rotate(90deg);
}

.lb-close svg {
  width: 16px;
  height: 16px;
  stroke-width: 1.5;
}

/* Flèches nav */
.lb-prev,
.lb-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 9001;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid rgba(184,149,90,.2);
  background: rgba(10,8,6,.7);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--stone, #E8E2D9);
  transition: border-color .22s, background .22s, transform .22s;
  backdrop-filter: blur(8px);
}

.lb-prev { left: -70px; }
.lb-next { right: -70px; }

.lb-prev:hover,
.lb-next:hover {
  border-color: rgba(184,149,90,.5);
  background: rgba(184,149,90,.12);
}

.lb-prev:hover { transform: translateY(-50%) translateX(-3px); }
.lb-next:hover { transform: translateY(-50%) translateX(3px); }

.lb-prev svg,
.lb-next svg {
  width: 18px;
  height: 18px;
  stroke-width: 1.5;
}

/* Barre thumbnails en bas */
.lb-thumbs {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9001;
  display: flex;
  gap: 6px;
  max-width: calc(100vw - 4rem);
  overflow-x: auto;
  padding: .4rem;
  scrollbar-width: none;
  background: rgba(10,8,6,.6);
  border: 1px solid rgba(232,226,217,.06);
  backdrop-filter: blur(12px);
}

.lb-thumbs::-webkit-scrollbar { display: none; }

.lb-thumb {
  width: 48px;
  height: 36px;
  flex-shrink: 0;
  border: 1.5px solid transparent;
  overflow: hidden;
  cursor: pointer;
  opacity: .45;
  transition: opacity .22s, border-color .22s;
}

.lb-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lb-thumb.active,
.lb-thumb:hover {
  opacity: 1;
  border-color: var(--or, #B8955A);
}

/* Cursor zoom sur les éléments galerie */
.gallery-item,
.case-img-wrap {
  cursor: zoom-in;
}

/* Touch swipe hint mobile */
@media (max-width: 768px) {
  .lb-prev { left: .5rem; width: 42px; height: 42px; }
  .lb-next { right: .5rem; width: 42px; height: 42px; }
  .lb-thumbs { display: none; }
  .lb-caption { right: 1rem; }
}


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  4. AMÉLIORATIONS ULTRA-PREMIUM                                  ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ── 4a. SECTION LABELS numérotés premium ───────────────────────── */
.s-label {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  margin-bottom: 2.5rem;
}

.s-label-n {
  font-family: var(--mono, 'Space Mono', monospace);
  font-size: .62rem;
  letter-spacing: .22em;
  color: var(--or, #B8955A);
  opacity: .6;
}

.s-label-rule {
  flex: 1;
  height: 1px;
  background: rgba(232,226,217,.08);
  max-width: 80px;
}

.s-label-txt {
  font-family: var(--mono, 'Space Mono', monospace);
  font-size: .6rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted, #8F8478);
}


/* ── 4b. SCROLL TOP BUTTON — premium ──────────────────────────── */
#scroll-top {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 700;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(184,149,90,.3);
  background: rgba(14,12,10,.9);
  color: var(--or, #B8955A);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  cursor: pointer;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .3s, transform .3s cubic-bezier(.34,1.56,.64,1),
              border-color .22s, background .22s;
  backdrop-filter: blur(8px);
}

#scroll-top.on {
  opacity: 1;
  transform: translateY(0);
}

#scroll-top:hover {
  background: rgba(184,149,90,.12);
  border-color: rgba(184,149,90,.6);
}

#scroll-top svg {
  width: 16px;
  height: 16px;
  stroke-width: 2;
}


/* ── 4c. REVEAL ANIMATIONS — améliorées ──────────────────────── */
[data-reveal] {
  opacity: 0;
  transition: opacity .7s cubic-bezier(.19,1,.22,1),
              transform .7s cubic-bezier(.19,1,.22,1);
}
[data-reveal="up"]    { transform: translateY(28px); }
[data-reveal="left"]  { transform: translateX(-28px); }
[data-reveal="right"] { transform: translateX(28px); }
[data-reveal="scale"] { transform: scale(.96); }
[data-reveal].on      { opacity: 1; transform: none; }


/* ── 4d. FORM INPUTS — focus premium ─────────────────────────── */
.form-lux input:focus,
.form-lux textarea:focus,
.form-lux select:focus {
  border-color: rgba(184,149,90,.5);
  box-shadow: 0 0 0 3px rgba(184,149,90,.08);
  outline: none;
}


/* ── 4e. GALLERY CASE CARDS — hover premium ──────────────────── */
.case-card {
  transition: transform .45s cubic-bezier(.19,1,.22,1);
}
.case-card:hover {
  transform: translateY(-6px);
}


/* ── 4f. BOUTONS — micro-interactions premium ─────────────────── */
.btn {
  position: relative;
  overflow: hidden;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.06);
  transform: translateX(-100%);
  transition: transform .4s cubic-bezier(.19,1,.22,1);
}
.btn:hover::after {
  transform: translateX(0);
}


/* ── 4g. LIGNE DÉCORATIVE NAV → SECTION ─────────────────────── */
.section-divider {
  width: 40px;
  height: 1px;
  background: linear-gradient(90deg, var(--or, #B8955A), transparent);
  margin: 2rem 0 3rem;
}


/* ── 4h. FOOTER LINKS — hover ligne ──────────────────────────── */
.footer-links a {
  position: relative;
  display: inline-block;
}
.footer-links a::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--or, #B8955A);
  transition: width .28s cubic-bezier(.19,1,.22,1);
}
.footer-links a:hover::after {
  width: 100%;
}


/* ── 4i. TABLE PRIX dans localités — alternance propre ───────── */
.price-guide .price-row:nth-child(even) > div {
  background: rgba(232,226,217,.02);
}


/* ── 4j. SELECTION COULEUR OR ────────────────────────────────── */
::selection {
  background: rgba(184,149,90,.25);
  color: var(--stone2, #F4F0EB);
}


/* ══════════════════════════════════════════════════════════
   PARTIE 3 — NAVIGATION (barre fixe, drawer, burger)
   Source autoritaire : nav-premium.css
   Override définitif de tous les patches précédents.
   ══════════════════════════════════════════════════════════ */

:root { --nav-h: 80px; }
html  { scroll-padding-top: var(--nav-h); }

/* ── 1. BARRE NAV ─────────────────────────────────────────────── */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 900;
  height: var(--nav-h);
  display: flex;
  align-items: center;
  padding: 0;               /* reset luxury.css padding:1.6rem 0 */
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: background .4s cubic-bezier(.19,1,.22,1),
              border-color .4s, box-shadow .4s;
}
.nav.stuck {
  padding: 0;               /* reset luxury.css .stuck padding:.9rem 0 */
  background: rgba(14,12,10,.97);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom-color: rgba(184,149,90,.2);
  box-shadow: 0 8px 40px rgba(0,0,0,.45);
}
.nav > .wrap {
  width: min(var(--max,1280px), calc(100% - var(--gutter,clamp(1.25rem,4vw,3rem)) * 2));
  margin-inline: auto;
}

/* ── 2. LIGNE NAV-ROW ─────────────────────────────────────────── */
.nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  height: var(--nav-h);
}

/* ── 3. BRAND ─────────────────────────────────────────────────── */
.nav-brand {
  display: flex;
  align-items: center;
  gap: .85rem;
  flex-shrink: 0;
  text-decoration: none;
  min-width: 0;
}
.nav-brand-img {
  width: 48px; height: 48px;  /* +12px vs V11 original */
  flex-shrink: 0;
  opacity: .9;
  display: block;
}
.nav-brand-copy {
  display: flex;
  flex-direction: column;
  gap: .22rem;
  min-width: 0;
}
.nav-brand-name {
  font-family: var(--serif,'Playfair Display',Georgia,serif);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: .01em;
  color: var(--stone2,#F4F0EB);
  line-height: 1.1;
  white-space: nowrap;
  max-width: none; /* reset patch mobile */
}
/* Baseline en OR — visible (l'original était var(--muted) = gris #8F8478) */
.nav-brand-tag {
  font-family: var(--mono,'Space Mono',monospace);
  font-size: .58rem;
  letter-spacing: .22em;
  color: var(--or,#B8955A);
  text-transform: uppercase;
  white-space: nowrap;
  opacity: .78;
  display: block; /* reset display:none des patches */
}

/* ── 4. LIENS CENTRE ──────────────────────────────────────────── */
.nav-links {
  display: flex;
  align-items: center;
  gap: 0;          /* reset gap:.05rem du Patch V4 */
  flex: 1 1 auto;
  justify-content: center;
  min-width: 0;
  overflow: hidden;
}
.nav-links a {
  font-family: var(--mono,'Space Mono',monospace);
  font-size: .65rem;
  font-weight: 400;
  letter-spacing: .11em;
  color: var(--muted2,#9B9189);
  padding: .5rem .7rem;
  white-space: nowrap;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 1px;
  transition: color .22s;
  background: transparent;
}
.nav-links a:hover          { color: var(--stone2,#F4F0EB); background: transparent; }
.nav-links a.active,
.nav-links a.cur            { color: var(--or,#B8955A); background: transparent; }

/* ── 5. ACTIONS DROITE ────────────────────────────────────────── */
.nav-actions {
  display: flex;
  align-items: center;
  gap: .65rem;
  flex-shrink: 0;
}
.nav-tel {
  font-family: var(--mono,'Space Mono',monospace);
  font-size: .67rem;
  letter-spacing: .09em;
  color: var(--muted,#8F8478);
  text-decoration: none;
  white-space: nowrap;
  transition: color .22s;
}
.nav-tel:hover { color: var(--stone,#E8E2D9); }

/* Urgence — sobre, contour rouge */
.nav-urgence {
  display: inline-flex;
  align-items: center;
  padding: .44rem .85rem;
  border: 1px solid rgba(185,65,65,.45);
  color: #cc8080;
  font-family: var(--mono,'Space Mono',monospace);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  border-radius: 1px;
  transition: border-color .22s, color .22s, background .22s;
}
.nav-urgence:hover {
  border-color: rgba(185,65,65,.85);
  background: rgba(185,65,65,.1);
  color: #e09090;
}

/* Devis — CTA or plein */
.nav-devis {
  display: inline-flex;
  align-items: center;
  padding: .52rem 1.2rem;
  background: var(--or,#B8955A);
  color: var(--ch,#0E0C0A);
  font-family: var(--mono,'Space Mono',monospace);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  border-radius: 1px;
  box-shadow: 0 4px 18px rgba(184,149,90,.3);
  transition: background .22s, color .22s,
              transform .2s cubic-bezier(.34,1.56,.64,1), box-shadow .22s;
}
.nav-devis:hover {
  background: var(--or2,#D4AD72);
  color: var(--ch,#0E0C0A);
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(184,149,90,.42);
}

/* Burger — masqué desktop */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 1px solid rgba(232,226,217,.18);
  background: transparent;
  padding: 0;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  z-index: 902;
}
.nav-burger span {
  display: block;
  height: 1.5px; width: 18px;
  background: var(--stone,#E8E2D9);
  border-radius: 1px;
  transition: transform .28s cubic-bezier(.19,1,.22,1), opacity .22s, width .22s;
}
.nav-burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; width: 0; }
.nav-burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── 6. DRAWER MOBILE ─────────────────────────────────────────── */
.nav-drawer {
  position: fixed;
  inset: 0;
  z-index: 901;
  background: rgba(10,8,6,.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-top: calc(env(safe-area-inset-top,0px) + 5rem);
  padding-right: max(var(--gutter,1.5rem), env(safe-area-inset-right,0px));
  padding-bottom: calc(env(safe-area-inset-bottom,0px) + 2.5rem);
  padding-left: max(var(--gutter,1.5rem), env(safe-area-inset-left,0px));
  gap: 0;
  /* Fermé — slide droite */
  transform: translateX(100%);
  visibility: hidden;
  pointer-events: none;
  transition: transform .42s cubic-bezier(.19,1,.22,1),
              visibility 0s linear .42s;
}
.nav-drawer.open {
  transform: translateX(0);
  visibility: visible;
  pointer-events: auto;
  transition: transform .42s cubic-bezier(.19,1,.22,1),
              visibility 0s linear 0s;
}
.nav-drawer[inert] { pointer-events: none; visibility: hidden; }

/* Scroll lock */
html.menu-open,
html.menu-open body { overflow: hidden; }

/* ── 7. CLOSE BUTTON ──────────────────────────────────────────── */
.nav-drawer-close {
  position: fixed;
  top: calc(env(safe-area-inset-top,0px) + 1rem);
  right: calc(max(var(--gutter,1.5rem), env(safe-area-inset-right,0px)));
  z-index: 903;
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(184,149,90,.45);
  background: rgba(20,17,14,.85);
  cursor: pointer;
  display: grid;
  place-items: center;
  opacity: 0;
  pointer-events: none;
  transform: scale(.85);
  transition: opacity .3s, transform .3s cubic-bezier(.34,1.56,.64,1),
              background .22s, border-color .22s;
}
.nav-drawer.open .nav-drawer-close {
  opacity: 1;
  pointer-events: auto;
  transform: scale(1);
}
.nav-drawer-close:hover {
  background: rgba(184,149,90,.12);
  border-color: rgba(184,149,90,.7);
}
/* Croix via ::before / ::after — 1 seul <span> requis */
.nav-drawer-close span {
  position: relative;
  display: block;
  width: 18px; height: 18px;
  pointer-events: none;
}
.nav-drawer-close span::before,
.nav-drawer-close span::after {
  content: '';
  position: absolute;
  top: 50%; left: 0;
  width: 100%;
  height: 1.5px;
  background: var(--stone2,#F4F0EB);
  border-radius: 1px;
}
.nav-drawer-close span::before { transform: translateY(-50%) rotate(45deg); }
.nav-drawer-close span::after  { transform: translateY(-50%) rotate(-45deg); }

/* ── 8. LIENS DRAWER ──────────────────────────────────────────── */
.nav-drawer a {
  font-family: var(--serif,'Playfair Display',Georgia,serif);
  font-size: clamp(1.75rem, 7vw, 3rem);
  font-weight: 400;
  color: var(--stone2,#F4F0EB);
  padding: .4rem 0;
  border-bottom: 1px solid rgba(232,226,217,.07);
  text-decoration: none;
  line-height: 1.2;
  transition: color .22s, padding-left .3s cubic-bezier(.19,1,.22,1);
}
.nav-drawer a:hover { color: var(--or,#B8955A); padding-left: .65rem; }

.nav-drawer .drawer-phone {
  font-family: var(--mono,'Space Mono',monospace);
  font-size: clamp(.95rem,3.5vw,1.2rem);
  font-weight: 700;
  color: var(--or,#B8955A);
  letter-spacing: .06em;
  margin-top: 1.8rem;
  padding: .4rem 0;
  border-bottom: none;
}
.nav-drawer .drawer-phone:hover { color: var(--or2,#D4AD72); padding-left: 0; }

.nav-drawer .drawer-devis {
  display: inline-flex;
  align-items: center;
  margin-top: .8rem;
  padding: .9rem 1.8rem;
  background: var(--or,#B8955A);
  color: var(--ch,#0E0C0A);
  font-family: var(--mono,'Space Mono',monospace);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: none;
  width: fit-content;
  box-shadow: 0 4px 24px rgba(184,149,90,.3);
  transition: background .22s;
}
.nav-drawer .drawer-devis:hover {
  background: var(--or2,#D4AD72);
  color: var(--ch,#0E0C0A);
  padding-left: 1.8rem;
}

/* ── 9. FOCUS ─────────────────────────────────────────────────── */
.nav-burger:focus-visible,
.nav-devis:focus-visible,
.nav-urgence:focus-visible,
.nav-tel:focus-visible,
.nav-links a:focus-visible,
.nav-brand:focus-visible,
.nav-drawer a:focus-visible,
.nav-drawer-close:focus-visible {
  outline: 2px solid var(--or,#B8955A);
  outline-offset: 4px;
}

/* ╔══════════════════════════════════════════════════════════════╗
   ║  RESPONSIVE                                                  ║
   ╚══════════════════════════════════════════════════════════════╝ */

@media (max-width: 1280px) {
  .nav-links a { padding-inline: .6rem; }
}

@media (max-width: 1100px) {
  .nav-links a { padding-inline: .5rem; font-size: .61rem; }
  .nav-tel { display: none; }
  .nav-actions { gap: .55rem; }
}

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

/* ── 960px : BASCULE MOBILE ──────────────────────────────────── */
@media (max-width: 960px) {
  :root { --nav-h: 68px; }
  .nav { background: rgba(14,12,10,.97); border-bottom-color: rgba(184,149,90,.15); }
  .nav.stuck { background: rgba(14,12,10,.99); }
  .nav-links  { display: none; }
  .nav-urgence { display: none; }
  .nav-tel    { display: none; }
  .nav-burger { display: flex; }
  .nav-actions { gap: .5rem; }
  .nav-row { gap: 1rem; }
}

@media (max-width: 480px) {
  .nav-devis { display: none; }
  .nav-brand-img  { width: 40px; height: 40px; }
  .nav-brand-name { font-size: .95rem; }
  .nav-brand-tag  { font-size: .54rem; letter-spacing: .18em; }
}

@media (max-width: 360px) {
  .nav-brand-tag { display: none; }
  .nav-brand-img { width: 36px; height: 36px; }
}

/* FIX 2026-05-08 — Scroll-top mobile au-dessus du CTA appel.
   Sur les pages internes, #scroll-top était repris par une règle globale bottom:2rem,
   ce qui le plaçait derrière / contre le bouton Appeler. On limite le correctif au mobile. */
@media (max-width: 768px) {
  #scroll-top {
    right: max(1.2rem, env(safe-area-inset-right, 0px) + 1.2rem);
    bottom: calc(env(safe-area-inset-bottom, 0px) + 5.7rem);
    z-index: 720;
  }
}
