/* ═══════════════════════════════════════════════
   FONTS AUTO-HÉBERGÉES
═══════════════════════════════════════════════ */
/* Outfit — latin-ext */
@font-face{font-family:'Outfit';font-style:normal;font-weight:300 600;font-display:swap;src:url('../fonts/outfit-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
/* Outfit — latin */
@font-face{font-family:'Outfit';font-style:normal;font-weight:300 600;font-display:swap;src:url('../fonts/outfit-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
/* Plus Jakarta Sans — latin-ext */
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400 800;font-display:swap;src:url('../fonts/pjs-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
/* Plus Jakarta Sans — latin */
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400 800;font-display:swap;src:url('../fonts/pjs-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ═══════════════════════════════════════════════
   DIRECTION D — PIERRE & MÉTAL
   Béton clair · Bleu nuit · Orange industriel
   Typo : Syne (display) + Outfit (body)
   Ton : Expert local — moderne, précis, fiable
═══════════════════════════════════════════════ */
:root{
  --beton:     #E8E5E0;
  --beton2:    #D8D3CB;
  --beton3:    #F4F2EE;
  --blanc:     #FFFFFF;
  --nuit:      #0F1B2D;
  --nuit2:     #1A2B3D;
  --nuit3:     #243347;
  --orange:    #E8620A;
  --orange-lt: #FDF0E8;
  --orange-dk: #C44F06;
  --texte:     #0F1218;
  --soft:      #4A5568;
  --mu:        #8895A8;
  --border:    #C8C3BB;
  --vert:      #22C55E;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--beton3);color:var(--texte);overflow-x:hidden}

/* TOP BAR */
.top-bar{
  background:var(--nuit);
  padding:8px 48px;
  display:flex;align-items:center;justify-content:space-between;
}
.tb-l{font-size:11px;color:rgba(255,255,255,0.35);letter-spacing:1px;display:flex;gap:20px}
.tb-tel{
  font-size:14px;font-weight:600;color:var(--blanc);
  text-decoration:none;letter-spacing:0.5px;
  display:flex;align-items:center;gap:8px;transition:color .2s;
}
.tb-tel:hover{color:var(--orange)}
.pulse{width:7px;height:7px;background:var(--vert);border-radius:50%;animation:p 2s ease infinite}
@keyframes p{0%,100%{opacity:1}50%{opacity:0.3}}

/* HEADER */
header{
  background:var(--beton3);
  border-bottom:1px solid var(--border);
  height:70px;display:flex;align-items:center;
  padding:0 48px;justify-content:space-between;
  position:sticky;top:0;z-index:100;
}
.logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.logo-badge{
  width:44px;height:44px;background:var(--nuit);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.logo-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:700;color:var(--texte);letter-spacing:-0.3px}
.logo-sub{font-size:10px;color:var(--mu);letter-spacing:1.5px;text-transform:uppercase;margin-top:1px}
nav a{font-size:13px;font-weight:500;color:var(--soft);text-decoration:none;margin-left:28px;transition:color .2s;letter-spacing:0.2px}
nav a:hover{color:var(--texte)}
.h-cta{
  background:var(--orange);color:var(--blanc);
  padding:9px 22px;font-size:13px;font-weight:600;
  text-decoration:none;border-radius:6px;
  display:flex;align-items:center;gap:7px;transition:all .2s;
}
.h-cta:hover{background:var(--orange-dk)}

/* HERO — Géométrique métal */
.hero{
  display:grid;
  grid-template-columns:1fr 400px;
  min-height:calc(100vh - 106px);
  position:relative;overflow:hidden;
}
.hero-left{
  background:var(--nuit);
  padding:88px 72px 80px 48px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}

/* Trame métallique */
.hero-left::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size:48px 48px;
}

/* Accent orange top */
.hero-left::after{
  content:'';
  position:absolute;top:0;left:48px;right:48px;height:3px;
  background:linear-gradient(90deg,var(--orange),transparent 70%);
}

.h-kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;font-weight:500;
  color:var(--orange);letter-spacing:2.5px;text-transform:uppercase;
  margin-bottom:28px;position:relative;
}

h1{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(46px,6vw,80px);
  font-weight:800;line-height:1.0;
  letter-spacing:-1.5px;color:var(--blanc);
  margin-bottom:24px;position:relative;
}
h1 .accent{color:var(--orange)}
h1 .sub-line{
  display:block;font-size:0.45em;font-weight:400;
  letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,0.3);margin-bottom:8px;
}

.hero-copy{
  font-size:16px;font-weight:300;color:rgba(255,255,255,0.5);
  line-height:1.8;max-width:480px;margin-bottom:32px;position:relative;
}
.hero-copy strong{font-weight:600;color:rgba(255,255,255,0.85)}

/* Specs grid */
.specs{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:rgba(255,255,255,0.05);
  margin-bottom:36px;position:relative;
}
.spec{
  background:var(--nuit);padding:16px;
  display:flex;flex-direction:column;
}
.spec-val{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;font-weight:700;
  color:var(--blanc);letter-spacing:-0.5px;line-height:1;
}
.spec-val span{color:var(--orange);font-size:16px}
.spec-lbl{font-size:10px;color:rgba(255,255,255,0.25);margin-top:4px;letter-spacing:0.5px;text-transform:uppercase}

.hero-actions{display:flex;gap:12px;flex-wrap:wrap;position:relative}
.btn-orange{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:var(--blanc);
  padding:14px 28px;border-radius:6px;
  font-size:15px;font-weight:600;text-decoration:none;
  transition:all .25s;
}
.btn-orange:hover{background:var(--orange-dk);transform:translateY(-1px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:rgba(255,255,255,0.5);
  padding:14px 22px;border-radius:6px;
  border:1px solid rgba(255,255,255,0.12);
  font-size:14px;font-weight:400;text-decoration:none;transition:all .2s;
}
.btn-ghost:hover{border-color:rgba(255,255,255,0.35);color:var(--blanc)}

/* SIDEBAR */
.hero-right{
  background:var(--beton);
  padding:64px 40px;
  display:flex;flex-direction:column;justify-content:center;
  border-left:1px solid var(--border);
}

.sr-artisan{margin-bottom:24px}
.sr-tag{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--mu);margin-bottom:8px}
.sr-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:22px;font-weight:700;color:var(--texte);margin-bottom:4px;letter-spacing:-0.3px}
.sr-desc{font-size:13px;color:var(--soft);line-height:1.6}
.sr-desc strong{color:var(--texte);font-weight:600}

.tel-widget{
  background:var(--nuit);border-radius:8px;padding:18px 20px;margin-bottom:20px;
  position:relative;overflow:hidden;
}
.tel-widget::after{content:'🔑';position:absolute;right:-8px;bottom:-12px;font-size:64px;opacity:0.06}
.tw-tag{font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:6px}
.tw-num{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(24px,3vw,32px);font-weight:700;
  color:var(--blanc);display:block;text-decoration:none;letter-spacing:-0.5px;margin-bottom:4px;transition:color .2s;
}
.tw-num:hover{color:var(--orange)}
.tw-dispo{font-size:11px;color:rgba(255,255,255,0.3);display:flex;align-items:center;gap:6px}
.dispo-dot{width:5px;height:5px;background:var(--vert);border-radius:50%;animation:p 2s ease infinite;opacity:0.8}

.sep{width:100%;height:1px;background:var(--border);margin:16px 0}
.f-l{display:block;font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--mu);margin-bottom:6px}
.f-inp,.f-sel{
  width:100%;background:var(--blanc);border:1px solid var(--border);border-radius:6px;
  padding:11px 13px;color:var(--texte);font-size:14px;
  font-family:'Outfit',sans-serif;outline:none;transition:border-color .2s;
  -webkit-appearance:none;margin-bottom:11px;
}
.f-inp:focus,.f-sel:focus{border-color:var(--orange)}
.f-sel option{background:var(--blanc)}
.btn-form{
  width:100%;background:var(--nuit);color:var(--blanc);
  padding:12px;border:none;border-radius:6px;
  font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;
  cursor:pointer;transition:background .2s;margin-top:2px;
}
.btn-form:hover{background:var(--orange)}
.f-note{font-size:11px;color:var(--mu);text-align:center;margin-top:7px}

/* SECTIONS */
section{padding:88px 48px}
.si{max-width:1200px;margin:0 auto}
.ey{
  font-size:10px;font-weight:500;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--orange);
  margin-bottom:14px;display:flex;align-items:center;gap:10px;
}
.ey::before{content:'';width:16px;height:2px;background:var(--orange);border-radius:1px}
h2{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(32px,4vw,52px);
  font-weight:800;letter-spacing:-1.5px;color:var(--texte);line-height:1.05;margin-bottom:12px;
}
h2 .accent{color:var(--orange)}
.sd{font-size:15px;font-weight:300;color:var(--soft);line-height:1.75;max-width:500px;margin-bottom:48px}

/* SERVICES */
.svc-bg{background:var(--blanc);border-top:1px solid var(--border)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc{
  background:var(--beton3);border:1px solid var(--border);
  border-radius:10px;padding:28px 26px;
  text-decoration:none;color:inherit;display:block;
  transition:all .25s;position:relative;overflow:hidden;
}
.svc::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--orange);transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;
}
.svc:hover{background:var(--blanc);border-color:var(--orange);transform:translateY(-3px);box-shadow:0 8px 28px rgba(232,98,10,0.12)}
.svc:hover::before{transform:scaleX(1)}
.svc-num{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:2px;color:var(--mu);margin-bottom:16px;
}
.svc-t{font-family:'Plus Jakarta Sans',sans-serif;font-size:19px;font-weight:700;color:var(--texte);margin-bottom:8px;letter-spacing:-0.2px}
.svc-d{font-size:13px;font-weight:300;color:var(--soft);line-height:1.6;margin-bottom:14px}
.svc-prix{font-size:13px;font-weight:600;color:var(--orange);margin-bottom:10px}
.svc-l{font-size:13px;font-weight:600;color:var(--nuit);display:inline-flex;align-items:center;gap:5px;letter-spacing:0.2px}

/* PROX */
.prox-bg{background:var(--beton);border-top:1px solid var(--border)}
.prox-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.pf-stack{display:flex;flex-direction:column;gap:14px}
.pf{
  background:var(--blanc);border:1px solid var(--border);border-radius:8px;
  padding:18px 20px;display:flex;gap:14px;align-items:flex-start;
  transition:all .2s;
}
.pf:hover{border-color:var(--orange);transform:translateX(4px)}
.pf-icon{
  width:40px;height:40px;background:var(--nuit);border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.pf-t{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;color:var(--texte);margin-bottom:4px;letter-spacing:-0.2px}
.pf-d{font-size:12px;font-weight:300;color:var(--soft);line-height:1.55}

.villes-panel{
  background:var(--nuit);border-radius:10px;overflow:hidden;
}
.vp-header{
  background:var(--orange);padding:16px 20px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:700;
  color:var(--blanc);letter-spacing:0.5px;text-transform:uppercase;
}
.villes-list{display:flex;flex-direction:column}
.ville{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;border-bottom:1px solid rgba(255,255,255,0.05);
  text-decoration:none;transition:background .15s;
}
.ville:last-child{border-bottom:none}
.ville:hover{background:var(--nuit2)}
.v-name{font-size:14px;font-weight:500;color:var(--blanc)}
.v-delay{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;
  color:var(--orange);letter-spacing:0.5px;
}

/* AVIS */
.avis-bg{background:var(--beton3);border-top:1px solid var(--border)}
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.avis{
  background:var(--blanc);border:1px solid var(--border);
  border-radius:10px;padding:24px;transition:all .2s;
}
.avis:hover{border-color:var(--orange);box-shadow:0 4px 20px rgba(0,0,0,0.06)}
.avis-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.avis-stars{color:var(--orange);font-size:13px;letter-spacing:1.5px}
.avis-goog{font-size:10px;font-weight:600;color:var(--vert);background:rgba(34,197,94,0.1);padding:2px 7px;border-radius:100px}
.avis-txt{font-size:13px;font-weight:300;color:var(--soft);line-height:1.7;margin-bottom:14px;font-style:italic}
.avis-auth{display:flex;align-items:center;gap:9px;padding-top:12px;border-top:1px solid var(--border)}
.avis-av{width:32px;height:32px;background:var(--nuit);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:700;color:var(--blanc)}
.avis-n{font-size:12px;font-weight:600;color:var(--texte)}
.avis-l{font-size:11px;color:var(--mu);margin-top:1px}

/* TARIFS */
.tarifs-bg{background:var(--blanc);border-top:1px solid var(--border)}
.tarifs-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tc{
  background:var(--beton3);border:1px solid var(--border);
  border-radius:10px;padding:28px;position:relative;transition:all .25s;
}
.tc:hover{border-color:var(--orange);box-shadow:0 6px 24px rgba(232,98,10,0.08)}
.tc.f{background:var(--nuit)}
.tc-badge{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  background:var(--orange);color:var(--blanc);
  font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  padding:4px 12px;border-radius:100px;white-space:nowrap;
}
.tc-type{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--mu);margin-bottom:14px;margin-top:6px}
.tc.f .tc-type{color:rgba(255,255,255,0.3)}
.tc-prix{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:50px;font-weight:800;letter-spacing:-2px;
  color:var(--texte);line-height:1;margin-bottom:5px;
}
.tc.f .tc-prix{color:var(--blanc)}
.tc-prix sup{font-size:20px;vertical-align:top;margin-top:8px}
.tc-note{font-size:12px;color:var(--mu);margin-bottom:20px}
.tc.f .tc-note{color:rgba(255,255,255,0.3)}
.tc-items{list-style:none;display:flex;flex-direction:column;gap:8px}
.tc-items li{font-size:13px;color:var(--soft);display:flex;gap:8px}
.tc.f .tc-items li{color:rgba(255,255,255,0.65)}
.tc-chk{color:var(--vert)}

/* FAQ details/summary */
.faq-bg{background:var(--beton);border-top:1px solid var(--border)}
.faq-layout{display:grid;grid-template-columns:320px 1fr;gap:64px;align-items:start}
.faq-aside{position:sticky;top:90px}
.faq-box{background:var(--nuit);border-radius:10px;padding:26px}
.fb-tag{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:8px}
.fb-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:700;color:var(--blanc);margin-bottom:4px;letter-spacing:-0.2px}
.fb-tel{font-family:'Plus Jakarta Sans',sans-serif;font-size:26px;font-weight:700;color:var(--blanc);display:block;text-decoration:none;letter-spacing:-0.3px;margin-bottom:4px;transition:color .2s}
.fb-tel:hover{color:var(--orange)}
.fb-dispo{font-size:11px;color:rgba(255,255,255,0.25);margin-bottom:18px}
.fb-btn{display:block;background:var(--orange);color:var(--blanc);padding:11px;border-radius:6px;text-align:center;text-decoration:none;font-size:13px;font-weight:600;transition:background .2s}
.fb-btn:hover{background:var(--orange-dk)}
.faq-list{display:flex;flex-direction:column;gap:8px}
details.faq-item{background:var(--blanc);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .2s;margin-bottom:0}
details.faq-item[open]{border-color:var(--orange)}
details.faq-item summary.faq-q{padding:16px 18px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;color:var(--texte);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .2s;list-style:none}
details.faq-item summary.faq-q::-webkit-details-marker{display:none}
details.faq-item summary.faq-q::marker{display:none}
details.faq-item summary.faq-q:hover{color:var(--orange)}
.faq-ic{width:24px;height:24px;background:var(--beton);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;color:var(--mu);transition:all .3s}
details.faq-item[open] .faq-ic{background:var(--orange);color:var(--blanc);transform:rotate(45deg)}
details.faq-item .faq-ans-in{padding:0 18px 14px;font-size:13px;font-weight:300;color:var(--soft);line-height:1.75}

/* CTA */
.cta-sect{background:var(--nuit);padding:96px 48px;text-align:center;position:relative;overflow:hidden;border-top:3px solid var(--orange)}
.cta-sect::before{
  content:'';position:absolute;top:0;right:0;
  width:400px;height:400px;
  background:radial-gradient(circle, rgba(232,98,10,0.08) 0%,transparent 60%);
  border-radius:50%;transform:translate(100px,-100px);
}
.cta-in{position:relative;max-width:680px;margin:0 auto;z-index:2}
.cta-ey{font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:18px}
.cta-t{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(36px,5.5vw,60px);
  font-weight:800;color:var(--blanc);letter-spacing:-1.5px;line-height:1.05;margin-bottom:14px;
}
.cta-t .accent{color:var(--orange)}
.cta-tel{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(42px,7vw,68px);font-weight:800;
  color:var(--blanc);display:block;text-decoration:none;letter-spacing:-1.5px;margin-bottom:8px;transition:color .2s;
}
.cta-tel:hover{color:var(--orange)}
.cta-sub{font-size:13px;color:rgba(255,255,255,0.35);margin-bottom:28px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-w{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:var(--blanc);padding:13px 26px;border-radius:6px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s}
.btn-w:hover{background:var(--orange-dk)}
.btn-ow{display:inline-flex;align-items:center;gap:8px;background:transparent;color:rgba(255,255,255,0.55);padding:13px 22px;border-radius:6px;border:1px solid rgba(255,255,255,0.15);font-size:14px;text-decoration:none;transition:all .2s}
.btn-ow:hover{border-color:rgba(255,255,255,0.4);color:var(--blanc)}

footer{background:var(--nuit);padding:48px 48px 28px;border-top:1px solid rgba(255,255,255,0.06)}
.fg{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:36px}
.fb-logo{font-family:'Plus Jakarta Sans',sans-serif;font-size:18px;font-weight:700;color:var(--blanc);text-decoration:none;display:block;margin-bottom:10px;letter-spacing:-0.2px}
.fb-desc{font-size:13px;font-weight:300;color:rgba(255,255,255,0.3);line-height:1.7;max-width:260px}
.fc h4{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.2);margin-bottom:14px}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.fc ul li a{font-size:13px;font-weight:300;color:rgba(255,255,255,0.4);text-decoration:none;transition:color .2s}
.fc ul li a:hover{color:var(--blanc)}
.fbot{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;padding-top:22px;border-top:1px solid rgba(255,255,255,0.06);font-size:12px;color:rgba(255,255,255,0.2);flex-wrap:wrap;gap:8px}

.sm{display:none;position:fixed;bottom:0;left:0;right:0;z-index:999}
.sm-inner{background:var(--nuit);display:grid;grid-template-columns:1fr 1fr;border-top:3px solid var(--orange)}
.sm-tel{background:var(--orange);color:var(--blanc);padding:15px;text-align:center;text-decoration:none;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:7px}
.sm-cb{background:var(--nuit);color:rgba(255,255,255,0.6);padding:15px;text-align:center;text-decoration:none;font-size:14px;border-left:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;gap:7px}

/* BREADCRUMB */
.breadcrumb{padding:10px 48px;background:var(--blanc);border-bottom:1px solid var(--border)}
.bc{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--mu);flex-wrap:wrap}
.bc a{color:var(--mu);text-decoration:none;transition:color .2s}.bc a:hover{color:var(--texte)}
.bc-sep{color:var(--border)}

/* HERO PAGE SERVICE */
.hero-svc{border-bottom:1px solid var(--border)}
.hero-svc h1{color:var(--texte);font-size:clamp(40px,5.5vw,68px)}
.hero-svc .h-kicker{color:var(--orange)}
.hero-svc .btn-ghost{color:var(--nuit);border-color:var(--border)}
.hero-svc .btn-ghost:hover{border-color:var(--nuit);background:var(--nuit);color:var(--blanc)}
.hero-svc-wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 380px;padding:0 48px}
.hsl{padding:72px 64px 72px 0;border-right:1px solid var(--border)}
h1 .inv{background:var(--nuit);color:var(--blanc);padding:2px 16px;display:inline-block}
.hero-lead{font-size:16px;font-weight:400;color:var(--soft);line-height:1.75;max-width:520px;margin-bottom:28px}
.hero-lead strong{font-weight:600;color:var(--texte)}

/* SITUATIONS GRID */
.situations{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:32px}
.sit{display:flex;align-items:center;gap:11px;padding:12px 15px;background:var(--blanc);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;color:var(--soft);transition:all .2s;cursor:default}
.sit:hover{border-color:var(--orange);color:var(--texte)}
.sit-ico{font-size:18px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* SIDEBAR DELAY */
.hsr{padding:56px 0 56px 40px;display:flex;flex-direction:column;justify-content:center}
.delay-box{background:var(--nuit);border-radius:10px;padding:22px;margin-bottom:16px;position:relative;overflow:hidden}
.delay-box::after{content:'🚪';position:absolute;right:-8px;bottom:-10px;font-size:72px;opacity:0.06}
.db-tag{font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:6px}
.db-val{font-family:'Plus Jakarta Sans',sans-serif;font-size:56px;font-weight:800;color:var(--blanc);letter-spacing:-2px;line-height:1}
.db-val span{font-size:24px;color:var(--orange)}
.db-sub{font-size:11px;color:rgba(255,255,255,0.25);margin-top:4px;margin-bottom:14px}
.db-tel{font-family:'Plus Jakarta Sans',sans-serif;font-size:26px;font-weight:700;color:var(--blanc);display:block;text-decoration:none;letter-spacing:-0.5px;margin-bottom:3px;transition:color .2s}
.db-tel:hover{color:var(--orange)}
.db-dispo{font-size:11px;color:rgba(255,255,255,0.25);display:flex;align-items:center;gap:6px}

/* GARANTIES LIST */
.gars-list{border:1px solid var(--border);border-radius:8px;overflow:hidden}
.gl-item{padding:12px 16px;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--soft);border-bottom:1px solid var(--border);background:var(--blanc)}
.gl-item:last-child{border-bottom:none}
.gl-ico{font-size:16px;flex-shrink:0}
.gl-item strong{color:var(--texte);font-weight:600}

/* CAS D'OUVERTURE */
.cas-bg{background:var(--blanc);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cas-grid{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--border)}
.cas-item{padding:36px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);position:relative}
.cas-item:nth-child(even){border-right:none}
.cas-item:nth-last-child(-n+2){border-bottom:none}
.cas-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:52px;font-weight:800;color:var(--orange);opacity:0.12;line-height:1;margin-bottom:10px;letter-spacing:-2px}
.cas-t{font-family:'Plus Jakarta Sans',sans-serif;font-size:18px;font-weight:700;color:var(--texte);margin-bottom:8px}
.cas-d{font-size:13px;font-weight:300;color:var(--soft);line-height:1.65;margin-bottom:12px}
.cas-prix{font-size:13px;font-weight:700;color:var(--orange)}
.cas-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(34,197,94,0.1);color:var(--vert);font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px;margin-top:8px}

/* MÉTHODE ÉTAPES */
.meth-bg{background:var(--beton);border-top:1px solid var(--border)}
.meth-layout{display:grid;grid-template-columns:1fr 380px;gap:72px;align-items:start}
.meth-steps{display:flex;flex-direction:column}
.mstep{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid var(--border)}
.mstep:first-child{border-top:1px solid var(--border)}
.mstep-num{font-family:'Plus Jakarta Sans',sans-serif;font-size:32px;font-weight:800;color:var(--orange);opacity:0.25;line-height:1;flex-shrink:0;width:44px;text-align:right}
.mstep-t{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:700;color:var(--texte);margin-bottom:5px}
.mstep-d{font-size:13px;font-weight:300;color:var(--soft);line-height:1.65}
.meth-right{position:sticky;top:88px}
.mbox{background:var(--nuit);border-radius:10px;padding:26px;margin-bottom:16px}
.mb-tag{font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:8px}
.mb-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:18px;font-weight:700;color:var(--blanc);margin-bottom:4px}
.mb-tel{font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;font-weight:700;color:var(--blanc);display:block;text-decoration:none;letter-spacing:-0.5px;margin-bottom:4px;transition:color .2s}
.mb-tel:hover{color:var(--orange)}
.mb-sub{font-size:11px;color:rgba(255,255,255,0.25);margin-bottom:18px}
.mb-btn{display:block;background:var(--orange);color:var(--blanc);padding:11px;border-radius:6px;text-align:center;text-decoration:none;font-size:13px;font-weight:600;transition:background .2s}
.mb-btn:hover{background:var(--orange-dk)}

/* AVIS MINI */
.avis-mini{display:flex;flex-direction:column;gap:12px}
.av-mini{background:var(--blanc);border:1px solid var(--border);border-radius:8px;padding:16px}
.av-stars{color:var(--orange);font-size:12px;letter-spacing:1.5px;margin-bottom:7px}
.av-txt{font-size:13px;font-weight:300;color:var(--soft);line-height:1.65;font-style:italic;margin-bottom:10px}
.av-auth{font-size:11px;font-weight:600;color:var(--mu)}

/* TARIF BAND */
.tarif-band{background:var(--nuit);border-top:3px solid var(--orange);padding:40px 48px}
.tarif-band-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.tb-col{padding:0 40px;border-right:1px solid rgba(255,255,255,0.08)}
.tb-col:first-child{padding-left:0}
.tb-col:last-child{border-right:none}
.tb-label{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:6px}
.tb-prix{font-family:'Plus Jakarta Sans',sans-serif;font-size:44px;font-weight:800;color:var(--blanc);letter-spacing:-1.5px;line-height:1}
.tb-prix sup{font-size:18px;vertical-align:top;margin-top:6px}
.tb-note{font-size:12px;color:rgba(255,255,255,0.3);margin-top:4px}
.tb-items{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.tb-items li{font-size:12px;color:rgba(255,255,255,0.45);display:flex;gap:7px;list-style:none}
.tb-chk{color:var(--vert)}

@media(max-width:960px){
  .top-bar,header,section,footer{padding-left:24px;padding-right:24px}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:64px 24px 48px}
  .hero-right{padding:40px 24px 56px;border-left:none;border-top:1px solid var(--border)}
  .specs{grid-template-columns:1fr 1fr}
  .svc-grid,.tarifs-cards{grid-template-columns:1fr}
  .prox-grid,.faq-layout{grid-template-columns:1fr}
  .faq-aside{position:static;margin-bottom:28px}
  .avis-grid{grid-template-columns:1fr}
  nav{display:none}
  .sm{display:block}
  footer{padding-bottom:80px}
  .fg{grid-template-columns:1fr 1fr}
  .breadcrumb{padding-left:24px;padding-right:24px}
  .hero-svc-wrap{grid-template-columns:1fr;padding:0 24px}
  .hsl{padding:56px 0 40px;border-right:none;border-bottom:1px solid var(--border)}
  .hsr{padding:36px 0 52px}
  .situations{grid-template-columns:1fr}
  .cas-grid{grid-template-columns:1fr}
  .cas-item{border-right:none}
  .cas-item:nth-last-child(-n+2){border-bottom:1px solid var(--border)}
  .cas-item:last-child{border-bottom:none}
  .meth-layout{grid-template-columns:1fr}
  .meth-right{position:static}
  .tarif-band{padding:32px 24px}
  .tarif-band-inner{grid-template-columns:1fr}
  .tb-col{padding:20px 0;border-right:none;border-bottom:1px solid rgba(255,255,255,0.08)}
  .tb-col:last-child{border-bottom:none}
}
@media(max-width:560px){
  .specs{grid-template-columns:1fr 1fr}
  .fg{grid-template-columns:1fr}
  .fbot,.cta-btns{flex-direction:column;align-items:center}
}
@keyframes fu{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.h-kicker{animation:fu .4s ease both}
h1{animation:fu .4s ease .1s both}
.hero-copy{animation:fu .4s ease .18s both}
.specs{animation:fu .4s ease .26s both}
.hero-actions{animation:fu .4s ease .34s both}
.hero-right{animation:fu .5s ease .12s both}
.hero-lead{animation:fu .4s ease .16s both}
.situations{animation:fu .4s ease .22s both}
.hero-ctas{animation:fu .4s ease .28s both}
