/* Cassou Plâtrerie — Global CSS v1.1 — Toutes pages */

/* ═══════════════════════════════════════
   TOKENS
═══════════════════════════════════════ */
:root {
  --navy:       #1b375f;
  --navy-dk:    #142843;
  --navy-md:    #1f3f6e;
  --gold:       #c49d74;
  --gold-dk:    #a8824f;
  --gold-lt:    #d4b48e;
  --gold-pale:  #f5ede0;
  --gold-ultra: #faf6f0;
  --gold-line:  rgba(196,157,116,.25);
  --white:      #ffffff;
  --off:        #faf9f7;
  --cream:      #f4f0ea;
  --ink:        #1a1a1a;
  --ink-md:     #3d3d3d;
  --ink-mt:     #6b7280;
  --border:     rgba(196,157,116,.18);
  --border-md:  rgba(196,157,116,.35);
  --border-navy:rgba(27,55,95,.12);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.05);
  --shadow-md:  0 8px 28px rgba(0,0,0,.09);
  --shadow-lg:  0 20px 60px rgba(27,55,95,.12);
  --r:          12px;
  --r-lg:       18px;
  --serif:      'Platypi', Georgia, serif;
  --sans:       'DM Sans', system-ui, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);color:var(--ink);background:var(--off);overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:var(--sans);cursor:pointer;border:none;background:none}
ul,ol{list-style:none}
/* ─── LAYOUT ──────────────────────────── */
.wrap    {max-width:1160px;margin:0 auto;padding:0 40px}
.wrap-md {max-width:860px;margin:0 auto;padding:0 40px}
/* ─── BOUTONS ─────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:8px;border:1.5px solid transparent;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.01em;transition:all .18s;cursor:pointer;white-space:nowrap}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-dk);transform:translateY(-1px);box-shadow:0 4px 16px rgba(196,157,116,.35)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-dk);transform:translateY(-1px)}
.btn-outline-gold{background:transparent;color:var(--gold-dk);border-color:var(--gold)}
.btn-outline-gold:hover{background:var(--gold-ultra)}
.btn-outline-navy{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline-navy:hover{background:var(--gold-ultra);border-color:var(--gold)}
.btn-ghost-white{background:transparent;color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.btn-ghost-white:hover{background:rgba(255,255,255,.1);color:#fff}
.btn-lg{padding:14px 28px;font-size:14px}
/* ─── NAV — bleu, liens inter-pages ──── */
.nav{background:#1b375f;border-bottom:1px solid rgba(196,157,116,.2);position:sticky;top:0;z-index:100;transition:box-shadow .2s}
.nav.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.2)}
.nav-inner{max-width:1160px;margin:0 auto;padding:12px 40px;height:auto;min-height:72px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-brand{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--gold);letter-spacing:.02em}
.nav-tagline{font-size:9px;letter-spacing:.1em;color:rgba(255,255,255,.35);text-transform:uppercase;display:block;margin-top:1px}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-link{font-size:12px;font-weight:500;color:rgba(255,255,255,.55);padding:6px 12px;border-radius:6px;transition:all .15s}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-link.active{color:#fff;font-weight:700}
.nav-phone{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--gold);padding:8px 14px;border-radius:8px;border:1.5px solid rgba(196,157,116,.4);transition:all .18s}
.nav-phone:hover{background:rgba(196,157,116,.12)}
/* ─── HERO — fond blanc, photo subtile ── */
.hero{
  background:#fff;padding:80px 0 64px;
  position:relative;overflow:hidden;
}
.hero::after{
  content:'';position:absolute;right:0;top:0;bottom:0;width:55%;
  background-image:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=1400&q=80&fit=crop&crop=center');
  background-size:cover;background-position:center;
  opacity:.12;
  mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.7) 35%,rgba(0,0,0,.9) 100%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.7) 35%,rgba(0,0,0,.9) 100%);
}
.hero-inner{
  max-width:1160px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:1fr 380px;gap:56px;align-items:center;
  position:relative;z-index:1;
}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--gold-pale);color:var(--gold-dk);border:1px solid var(--border-md);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:20px}
.hero-h1{font-family:var(--serif);font-size:clamp(38px,4.8vw,62px);font-weight:700;color:var(--navy);line-height:1.07;letter-spacing:-.01em;max-width:600px}
.hero-h1 em{color:var(--gold);font-style:italic}
.hero-stroke{width:40px;height:3px;background:var(--gold);border-radius:2px;margin:20px 0}
.hero-desc{font-size:15px;color:var(--ink-md);line-height:1.75;max-width:520px;margin-bottom:28px}
.hero-desc strong{color:var(--navy);font-weight:600}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;border-top:1px solid var(--gold-line);padding-top:20px}
.trust-item{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--ink-mt)}
.trust-dot{width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0}
/* EEAT box */
.hero-eeat{background:#fff;border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-lg);border:1px solid var(--border);align-self:center}
.eeat-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.eeat-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-md));display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-size:20px;font-weight:700;flex-shrink:0}
.eeat-name{font-weight:700;color:var(--navy);font-size:15px}
.eeat-title{font-size:12px;color:var(--ink-mt);margin-top:2px}
.eeat-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.eeat-stat{background:var(--off);border-radius:10px;padding:12px;text-align:center;border:1px solid var(--border)}
.eeat-stat-num{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--navy);display:block;line-height:1}
.eeat-stat-label{font-size:10px;color:var(--ink-mt);margin-top:3px}
.eeat-badges{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px}
.eeat-badge{background:var(--gold-pale);color:var(--gold-dk);border:1px solid var(--border-md);border-radius:6px;font-size:11px;font-weight:600;padding:4px 10px}
.eeat-rating{display:flex;align-items:center;gap:8px}
.eeat-stars{color:var(--gold);font-size:14px}
.eeat-score{font-weight:700;color:var(--navy)}
.eeat-count{font-size:11px;color:var(--ink-mt)}
/* ─── STATS BAND ──────────────────────── */
.stats-band{background:var(--navy);border-top:2px solid var(--gold);display:grid;grid-template-columns:repeat(3,1fr)}
.stats-item{padding:26px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.stats-item:last-child{border-right:none}
.stats-num{font-family:var(--serif);font-size:44px;font-weight:700;color:var(--gold);line-height:1}
.stats-label{font-size:11px;color:rgba(255,255,255,.42);margin-top:6px;line-height:1.5}
/* ─── QUICK NAV ───────────────────────── */
/* Fond blanc, padding vertical avec espace bas vers la section suivante */
.quicknav{padding:36px 0 48px;background:var(--white)}
.qnav-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-mt);margin-bottom:14px}
.qnav-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.qnav-card{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);
  padding:20px 16px;cursor:pointer;transition:all .2s;
  display:flex;flex-direction:column;gap:6px;
  box-shadow:var(--shadow-sm);
}
.qnav-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.qnav-icon{font-size:24px;line-height:1;margin-bottom:2px}
.qnav-title{font-size:13px;font-weight:700;color:var(--navy)}
.qnav-sub{font-size:11px;color:var(--ink-mt);line-height:1.45}
/* ─── SECTIONS ────────────────────────── */
.sec{padding:64px 0}
.sec-white{background:#fff}
.sec-off{background:var(--off)}
.sec-cream{background:var(--cream)}
.sec-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-dk);margin-bottom:6px;display:block}
.sec-title{font-family:var(--serif);font-size:clamp(26px,3vw,36px);font-weight:700;color:var(--navy);line-height:1.15}
.sec-title em{color:var(--gold);font-style:italic}
.sec-sub{font-size:14px;color:var(--ink-mt);line-height:1.75;margin-top:10px;max-width:520px}
.sec-intro{margin-bottom:28px;padding:18px 22px;background:#fff;border-radius:var(--r);border-left:3px solid var(--gold);box-shadow:var(--shadow-sm)}
.sec-intro h2{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--navy);margin-bottom:5px}
.sec-intro p{font-size:13px;color:var(--ink-mt);line-height:1.7}
.sec-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px}
.sec-count{font-size:12px;color:var(--ink-mt)}
/* ─── SPLIT ───────────────────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.split-text{padding:60px 52px;display:flex;flex-direction:column;justify-content:center;background:#fff}
.split-text-cream{background:var(--cream)}
.split-text p{font-size:14px;color:var(--ink-md);line-height:1.8;margin-bottom:14px}
.split-text p strong{color:var(--navy);font-weight:600}
.split-text p:last-of-type{margin-bottom:22px}
.split-photo{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:380px}
.split-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .5s ease}
.split:hover .split-photo img{transform:scale(1.03)}
/* overlay photo avec icone + description */
.split-photo-overlay{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(to top,rgba(27,55,95,.75) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;
}
.split-photo-tag{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(27,55,95,.7);backdrop-filter:blur(4px);
  border:1px solid rgba(196,157,116,.35);
  color:var(--gold-lt);font-size:11px;font-weight:700;
  padding:6px 12px;border-radius:20px;width:fit-content;
}
.split-photo::after{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);z-index:3}
/* ─── SERVICE GRID ────────────────────── */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-radius:var(--r-lg);overflow:hidden}
.srv-card{background:#fff;padding:28px 24px;border-top:2px solid transparent;transition:border-color .15s,background .15s}
.srv-card:hover{border-top-color:var(--gold);background:var(--gold-ultra)}
.srv-card-cta{background:var(--navy);display:flex;align-items:center;justify-content:center;border-top:2px solid var(--gold)}
.srv-num{font-size:10px;font-weight:700;color:var(--gold-dk);letter-spacing:.1em;margin-bottom:10px}
.srv-name{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:8px}
.srv-desc{font-size:13px;color:var(--ink-md);line-height:1.75}
.srv-kw{font-size:10px;color:var(--gold-dk);margin-top:12px;opacity:.7}
.ck{padding:0;margin:10px 0 0}
.ck li{font-size:13px;color:var(--ink-md);padding:6px 0 6px 20px;position:relative;border-bottom:1px solid rgba(0,0,0,.05);line-height:1.5}
.ck li:last-child{border-bottom:none}
.ck li::before{content:'✓';position:absolute;left:0;top:6px;color:var(--gold);font-weight:700;font-size:11px}
/* ─── GALERIE APERÇU ──────────────────── */
.gallery-preview{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:3px;border-radius:var(--r-lg);overflow:hidden;
  margin-top:32px;
}
.gp-item{
  position:relative;overflow:hidden;aspect-ratio:4/3;cursor:pointer;
  background:var(--navy-md);
}
.gp-item.tall{aspect-ratio:3/4;grid-row:span 2}
.gp-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gp-item:hover img{transform:scale(1.06)}
.gp-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(27,55,95,.85) 0%,transparent 50%);
  opacity:0;transition:opacity .3s;
  display:flex;flex-direction:column;justify-content:flex-end;padding:18px;
}
.gp-item:hover .gp-overlay{opacity:1}
.gp-cat{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:3px}
.gp-title{font-family:var(--serif);font-size:15px;font-weight:700;color:#fff}
.gp-badge{
  position:absolute;top:12px;left:12px;
  background:rgba(27,55,95,.8);backdrop-filter:blur(4px);
  border:1px solid rgba(196,157,116,.3);
  color:var(--gold-lt);font-size:10px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px;
}
.gallery-preview-cta{
  display:flex;align-items:center;justify-content:center;
  background:var(--navy);aspect-ratio:4/3;
  text-decoration:none;transition:background .2s;
  flex-direction:column;gap:10px;
}
.gallery-preview-cta:hover{background:var(--navy-md)}
.gallery-preview-cta span{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--gold-lt)}
.gallery-preview-cta small{font-size:11px;color:rgba(255,255,255,.4)}
/* ─── SYNTH CARDS ─────────────────────── */
.synth-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.synth-card{background:var(--navy);border-top:2px solid var(--gold);border-radius:var(--r);padding:26px 22px}
.synth-icon{margin-bottom:14px;opacity:.85}
.synth-title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--gold-lt);margin-bottom:14px}
.synth-list{display:flex;flex-direction:column;gap:8px}
.synth-list li{font-size:13px;color:rgba(255,255,255,.55);padding-left:14px;position:relative;line-height:1.55}
.synth-list li::before{content:'';position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--gold)}
/* ─── FEATURED BAND ───────────────────── */
.featured{background:var(--navy);border-radius:var(--r-lg);padding:32px 36px;display:flex;justify-content:space-between;align-items:center;gap:24px;margin-bottom:32px;box-shadow:var(--shadow-md)}
.featured-badge{display:inline-flex;align-items:center;gap:6px;background:var(--gold);color:#fff;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:10px}
.featured-title{font-family:var(--serif);font-size:24px;font-weight:700;color:#fff;margin-bottom:8px;line-height:1.2}
.featured-desc{font-size:13px;color:rgba(255,255,255,.62);line-height:1.65;margin-bottom:18px;max-width:440px}
.featured-actions{display:flex;gap:10px;flex-wrap:wrap}
.featured-stats{display:flex;gap:24px;flex-shrink:0}
.fstat{text-align:center;border-left:2px solid rgba(196,157,116,.35);padding-left:16px}
.fstat-num{font-family:var(--serif);font-size:34px;font-weight:700;color:var(--gold);display:block;line-height:1}
.fstat-label{font-size:11px;color:rgba(255,255,255,.42);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
/* ─── AVIS ────────────────────────────── */
.avis-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}
.avis-card{background:#fff;padding:24px;border:1.5px solid var(--border);border-left:3px solid var(--gold);border-radius:var(--r);box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.avis-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.avis-stars{color:var(--gold);font-size:13px;letter-spacing:2px;margin-bottom:10px}
.avis-quote{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--ink-md);line-height:1.65}
.avis-author{font-size:13px;font-weight:700;color:var(--navy);margin-top:14px}
.avis-loc{font-size:11px;color:var(--ink-mt)}
.avis-bar{margin-top:14px;padding:12px 16px;background:var(--off);border:1px solid var(--border);border-radius:var(--r);display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-md)}
.avis-bar span{color:var(--gold);font-size:14px}
/* ─── FAQ ─────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:28px}
.faq-item{background:#fff;border-radius:var(--r);border:1px solid var(--border);overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;text-align:left;font-family:var(--serif);font-size:16px;font-weight:700;color:var(--navy);background:#fff;cursor:pointer;transition:background .12s}
.faq-q:hover{background:var(--gold-ultra)}
.faq-item.open .faq-q{background:var(--navy);color:#fff}
.faq-arrow{font-size:11px;color:var(--gold);flex-shrink:0;transition:transform .2s}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;font-size:13px;color:rgba(255,255,255,.65);line-height:1.75;background:var(--navy)}
.faq-item.open .faq-a{max-height:200px}
.faq-a-in{padding:0 18px 16px}
.faq-a-in strong{color:var(--gold-lt);font-weight:600}
/* ─── ZONE BLOCK ──────────────────────── */
.zone-wrap{background:var(--navy);border-radius:var(--r-lg);padding:28px;position:relative;overflow:hidden}
.zone-wrap::before{content:'';position:absolute;top:0;right:0;width:60px;height:60px;border-top:2px solid rgba(196,157,116,.4);border-right:2px solid rgba(196,157,116,.4)}
.zone-title{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--gold-lt);margin-bottom:8px}
.zone-desc{font-size:13px;color:rgba(255,255,255,.52);line-height:1.75;margin-bottom:14px;max-width:500px}
.zone-tags{display:flex;flex-wrap:wrap;gap:6px}
.zone-tag{font-size:11px;font-weight:600;letter-spacing:.07em;padding:5px 13px;border:1px solid rgba(196,157,116,.3);color:rgba(255,255,255,.58);border-radius:6px;transition:all .15s}
.zone-tag:hover{background:rgba(196,157,116,.15);border-color:var(--gold);color:#fff}
/* ─── CTA ─────────────────────────────── */
.cta-sec{background:var(--off);border-top:2px solid var(--gold-line);padding:80px 0;text-align:center}
.cta-title{font-family:var(--serif);font-size:clamp(28px,3.4vw,42px);font-weight:700;color:var(--navy);line-height:1.15;margin-bottom:10px}
.cta-title em{color:var(--gold);font-style:italic}
.cta-sub{font-size:14px;color:var(--ink-mt);margin-bottom:30px;line-height:1.75}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* Form CTA */
.form-wrap{max-width:580px;margin:48px auto 0;text-align:left}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mt)}
.form-field{padding:12px 14px;background:#fff;border:1.5px solid var(--border-navy);border-radius:8px;font-family:var(--sans);font-size:13px;color:var(--ink);outline:none;transition:border-color .15s}
.form-field:focus{border-color:var(--gold)}
.form-field::placeholder{color:var(--ink-mt)}
.form-select{color:var(--ink-md);background:#fff}
.form-textarea{resize:vertical;min-height:100px;line-height:1.6}
/* ─── FOOTER ──────────────────────────── */
.footer{background:var(--navy-dk);border-top:2px solid var(--gold-line)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:52px;padding:56px 0 44px}
.footer-brand{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--gold-lt);margin-bottom:4px}
.footer-tagline{font-size:11px;color:rgba(255,255,255,.28);font-style:italic;margin-bottom:14px}
.footer-about{font-size:13px;color:rgba(255,255,255,.32);line-height:1.8}
.footer-head{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.32);transition:color .15s}
.footer-links a:hover{color:var(--gold-lt)}
.footer-contact-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.32);line-height:1.65;margin-bottom:10px}
.footer-contact-row a{color:rgba(255,255,255,.32);transition:color .15s}
.footer-contact-row a:hover{color:var(--gold-lt)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:16px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px}
.footer-copy{font-size:11px;color:rgba(255,255,255,.2)}
.footer-legal a{font-size:11px;color:rgba(255,255,255,.2);transition:color .15s}
.footer-legal a:hover{color:var(--gold)}
/* ─── FLOAT ───────────────────────────── */
.float-call{display:none;position:fixed;bottom:16px;right:14px;z-index:999;background:var(--gold);color:#fff;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 4px 20px rgba(0,0,0,.25);align-items:center;gap:8px}
/* ─── ANIMATIONS ──────────────────────── */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
/* ─── RESPONSIVE ──────────────────────── */
@media(max-width:1024px){.hero-inner{grid-template-columns:1fr}
.hero-eeat{display:none}
}
@media(max-width:960px){
  .nav-links{display:none}
.split{grid-template-columns:1fr}
.stats-band{grid-template-columns:1fr}
.stats-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
.qnav-grid{grid-template-columns:1fr 1fr}
.synth-grid{grid-template-columns:1fr 1fr}
.avis-grid{grid-template-columns:1fr}
.faq-grid{grid-template-columns:1fr}
.footer-top{grid-template-columns:1fr;gap:28px}
.float-call{display:flex}
.gallery-preview{grid-template-columns:1fr 1fr}
.gp-item.tall{aspect-ratio:4/3;grid-row:span 1}
.featured{flex-direction:column}
.featured-stats{display:none}
@media(max-width:600px){
  .wrap,.wrap-md{padding:0 18px}
.hero{padding:52px 0 40px}
.srv-grid{grid-template-columns:1fr}
.synth-grid{grid-template-columns:1fr}
.sec{padding:48px 0}
.form-row{grid-template-columns:1fr}
.split-text{padding:40px 22px}
.qnav-grid{grid-template-columns:1fr}
.gallery-preview{grid-template-columns:1fr}
/* ═══════════════════════════════════════
   TOKENS — identiques à la home v7
═══════════════════════════════════════ */
:root {
  --navy:       #1b375f;
  --navy-dk:    #142843;
  --navy-md:    #1f3f6e;
  --gold:       #c49d74;
  --gold-dk:    #a8824f;
  --gold-lt:    #d4b48e;
  --gold-pale:  #f5ede0;
  --gold-ultra: #faf6f0;
  --gold-line:  rgba(196,157,116,.25);
  --white:      #ffffff;
  --off:        #faf9f7;
  --cream:      #f4f0ea;
  --ink:        #1a1a1a;
  --ink-md:     #3d3d3d;
  --ink-mt:     #6b7280;
  --border:     rgba(196,157,116,.18);
  --border-md:  rgba(196,157,116,.35);
  --border-navy:rgba(27,55,95,.12);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.05);
  --shadow-md:  0 8px 28px rgba(0,0,0,.09);
  --shadow-lg:  0 20px 60px rgba(27,55,95,.12);
  --r:          12px;
  --r-lg:       18px;
  --serif:      'Platypi', Georgia, serif;
  --sans:       'DM Sans', system-ui, sans-serif;
}
/* ─── LAYOUT ─────────────────────────────── */
.wrap    {max-width:1160px;margin:0 auto;padding:0 40px}
/* ─── BOUTONS ────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:8px;border:1.5px solid transparent;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.01em;transition:all .18s;cursor:pointer;white-space:nowrap}
/* ─── NAV — bleu #1b375f ─────────────────── */
.nav{background:#1b375f;border-bottom:1px solid rgba(196,157,116,.2);position:sticky;top:0;z-index:100;transition:box-shadow .2s}
/* ─── BREADCRUMB ─────────────────────────── */
.breadcrumb{background:#fff;border-bottom:1px solid var(--gold-line);padding:12px 0}
.breadcrumb-inner{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-mt)}
.breadcrumb-inner a{color:var(--gold-dk);transition:color .15s}
.breadcrumb-inner a:hover{color:var(--navy)}
.breadcrumb-sep{color:var(--gold-line);font-size:14px}
.breadcrumb-current{color:var(--navy);font-weight:600}
/* ─── PAGE HERO — fond blanc ─────────────── */
.page-hero{
  background:#fff;
  padding:56px 0 48px;
  border-bottom:1px solid var(--gold-line);
  position:relative;overflow:hidden;
}
.page-hero::after{
  content:'';position:absolute;right:0;top:0;bottom:0;width:40%;
  background-image:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=900&q=70&fit=crop&crop=right');
  background-size:cover;background-position:center;
  opacity:.12;
  mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.7) 40%,rgba(0,0,0,.9) 100%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.7) 40%,rgba(0,0,0,.9) 100%);
}
.page-hero-inner{position:relative;z-index:1}
.page-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--gold-pale);color:var(--gold-dk);border:1px solid var(--border-md);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:16px}
.page-h1{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:700;color:var(--navy);line-height:1.08;letter-spacing:-.01em;margin-bottom:0;max-width:580px}
.page-h1 em{color:var(--gold);font-style:italic}
.page-stroke{width:40px;height:3px;background:var(--gold);border-radius:2px;margin:18px 0}
.page-desc{font-size:15px;color:var(--ink-md);line-height:1.75;max-width:540px;margin-bottom:28px}
.page-desc strong{color:var(--navy);font-weight:600}
.page-actions{display:flex;gap:12px;flex-wrap:wrap}
/* ─── STICKY FILTER BAR ──────────────────── */
.filter-bar{
  background:#fff;border-bottom:1px solid var(--gold-line);
  position:sticky;top:64px;z-index:90;
  box-shadow:0 2px 12px rgba(0,0,0,.04);
}
.filter-inner{max-width:1160px;margin:0 auto;padding:0 40px;display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.filter-inner::-webkit-scrollbar{display:none}
.filter-tab{display:flex;align-items:center;gap:7px;padding:16px 18px;font-size:13px;font-weight:500;color:var(--ink-mt);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all .18s;font-family:var(--sans)}
.filter-tab:hover{color:var(--navy)}
.filter-tab.active{color:var(--navy);font-weight:700;border-bottom-color:var(--gold)}
.filter-tab-icon{font-size:16px}
/* ─── SECTIONS ───────────────────────────── */
.sec{padding:64px 0}
.sec-navy{background:var(--navy)}
.sec-title{font-family:var(--serif);font-size:clamp(24px,3vw,34px);font-weight:700;color:var(--navy);line-height:1.15}
.sec-intro{margin-bottom:32px;padding:18px 22px;background:#fff;border-radius:var(--r);border-left:3px solid var(--gold);box-shadow:var(--shadow-sm)}
/* ─── PRESTATION DETAIL CARD ─────────────── */
.prestation-block{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:440px;border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-md);
  margin-bottom:24px;
}
.prestation-block.reverse{direction:rtl}
.prestation-block.reverse > *{direction:ltr}
.prestation-text{
  background:#fff;padding:48px 44px;
  display:flex;flex-direction:column;justify-content:center;
}
.prestation-text.cream{background:var(--cream)}
.prestation-num{
  font-family:var(--serif);font-size:56px;font-weight:700;
  color:var(--gold-line);line-height:1;margin-bottom:4px;
  -webkit-text-stroke:1.5px var(--gold);color:transparent;
}
.prestation-title{
  font-family:var(--serif);font-size:28px;font-weight:700;
  color:var(--navy);line-height:1.15;margin-bottom:6px;
}
.prestation-title em{color:var(--gold);font-style:italic}
.prestation-tagline{
  font-size:13px;color:var(--gold-dk);font-weight:600;
  letter-spacing:.04em;margin-bottom:18px;
}
.prestation-desc{font-size:14px;color:var(--ink-md);line-height:1.8;margin-bottom:20px}
.prestation-desc strong{color:var(--navy);font-weight:600}
/* checklist */
.ck{padding:0;margin:0 0 22px}
/* photo zone */
.prestation-photo{
  background:var(--navy-md);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;min-height:360px;
}
.prestation-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.prestation-photo-ph{display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.2}
.prestation-photo-ph span{font-size:10px;color:#fff;letter-spacing:.1em;text-transform:uppercase}
/* accent or sur la photo */
.prestation-photo::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);z-index:2}
.prestation-block.reverse .prestation-photo::before{left:auto;right:0}
/* badge numéro dans la photo */
.prestation-badge{
  position:absolute;top:20px;right:20px;z-index:3;
  width:48px;height:48px;border-radius:50%;
  background:var(--gold);color:#fff;
  font-family:var(--serif);font-size:20px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
/* ─── APPLICATIONS GRID ──────────────────── */
/* Petites cards d'applications (neuf, réno, pro, particulier) */
.appli-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:28px}
.appli-card{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r);
  padding:20px 16px;text-align:center;transition:all .18s;
}
.appli-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.appli-icon{font-size:28px;margin-bottom:10px}
.appli-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px}
.appli-desc{font-size:11px;color:var(--ink-mt);line-height:1.55}
/* ─── PRODUITS / MARQUES ─────────────────── */
.marques-bar{
  background:var(--navy);padding:24px 0;
  border-top:1px solid rgba(196,157,116,.15);
  border-bottom:1px solid rgba(196,157,116,.15);
}
.marques-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:14px}
.marques-list{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.marque-item{
  font-family:var(--serif);font-size:16px;font-weight:700;
  color:rgba(255,255,255,.25);letter-spacing:.04em;
  transition:color .2s;
}
.marque-item:hover{color:var(--gold)}
/* ─── COMPARATIF / TABLEAU ───────────────── */
.ptable{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.ptable-hd{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;background:var(--navy);color:rgba(255,255,255,.65);padding:14px 24px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.ptable-hd span:not(:first-child){text-align:center}
.prow{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:14px 24px;border-bottom:1px solid var(--border);transition:background .15s;align-items:center}
.prow:last-child{border-bottom:none}
.prow:hover{background:var(--gold-ultra)}
.prow.hi{border-left:3px solid var(--gold);background:rgba(196,157,116,.05)}
.pr-name{font-size:14px;font-weight:600;color:var(--navy)}
.pr-sub{font-size:11px;color:var(--ink-mt);margin-top:2px}
.pr-cell{font-size:13px;color:var(--ink-md);text-align:center}
.pr-check{font-size:16px;text-align:center;color:var(--gold)}
.pr-cross{font-size:16px;text-align:center;color:var(--ink-mt);opacity:.35}
/* ─── PROCESS STEPS ──────────────────────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;margin-top:36px}
.process-grid::before{
  content:'';position:absolute;top:28px;left:10%;right:10%;height:2px;
  background:linear-gradient(to right,var(--gold),rgba(196,157,116,.3));z-index:0;
}
.process-step{text-align:center;padding:0 16px;position:relative;z-index:1}
.process-dot{
  width:56px;height:56px;border-radius:50%;
  background:var(--navy);border:3px solid var(--gold);
  color:var(--gold);font-family:var(--serif);font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;box-shadow:var(--shadow-sm);
}
.process-title{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--navy);margin-bottom:6px}
.process-desc{font-size:12px;color:var(--ink-mt);line-height:1.65}
/* ─── FAQ ────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:28px}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;text-align:left;font-family:var(--serif);font-size:15px;font-weight:700;color:var(--navy);background:#fff;cursor:pointer;transition:background .12s}
.faq-item.open .faq-a{max-height:240px}
/* ─── FEATURED BAND ──────────────────────── */
.featured{background:var(--navy);border-radius:var(--r-lg);padding:32px 36px;display:flex;justify-content:space-between;align-items:center;gap:24px;box-shadow:var(--shadow-md);margin-bottom:0}
/* ─── ZONE BLOCK ─────────────────────────── */
.zone-wrap{background:var(--navy);border-radius:var(--r-lg);padding:28px;position:relative;overflow:hidden}
/* ─── CTA SECTION ────────────────────────── */
.cta-sec{background:var(--off);border-top:2px solid var(--gold-line);padding:72px 0;text-align:center}
.cta-title{font-family:var(--serif);font-size:clamp(26px,3.2vw,40px);font-weight:700;color:var(--navy);line-height:1.15;margin-bottom:10px}
.cta-sub{font-size:14px;color:var(--ink-mt);margin-bottom:28px;line-height:1.75}
/* ─── FOOTER ─────────────────────────────── */
.footer{background:var(--navy-dk);border-top:2px solid var(--gold-line)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:52px;padding:52px 0 40px}
.footer-legal{font-size:11px}
.footer-legal a{color:rgba(255,255,255,.2);transition:color .15s}
/* ─── FLOAT BTN MOBILE ───────────────────── */
.float-call{display:none;position:fixed;bottom:16px;right:14px;z-index:999;background:var(--gold);color:#fff;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 4px 20px rgba(0,0,0,.25);align-items:center;gap:8px}
/* ─── ANIMATIONS ─────────────────────────── */
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
/* ─── RESPONSIVE ─────────────────────────── */
@media(max-width:960px){
  .nav-links{display:none}
.prestation-block{grid-template-columns:1fr}
.prestation-block.reverse{direction:ltr}
.prestation-photo{min-height:280px}
.appli-grid{grid-template-columns:1fr 1fr}
.process-grid{grid-template-columns:1fr 1fr;gap:24px}
.process-grid::before{display:none}
.ptable-hd,.prow{grid-template-columns:2fr 1fr 1fr}
.ptable-hd span:last-child,.prow .pr-cell:last-child{display:none}
.prestation-text{padding:36px 22px}
.process-grid{grid-template-columns:1fr}
/* ═══ TOKENS ═════════════════════════════ */
:root {
  --navy:       #1b375f;
  --navy-dk:    #142843;
  --navy-md:    #1f3f6e;
  --gold:       #c49d74;
  --gold-dk:    #a8824f;
  --gold-lt:    #d4b48e;
  --gold-pale:  #f5ede0;
  --gold-ultra: #faf6f0;
  --gold-line:  rgba(196,157,116,.25);
  --white:      #ffffff;
  --off:        #faf9f7;
  --cream:      #f4f0ea;
  --ink:        #1a1a1a;
  --ink-md:     #3d3d3d;
  --ink-mt:     #6b7280;
  --border:     rgba(196,157,116,.18);
  --border-md:  rgba(196,157,116,.35);
  --border-navy:rgba(27,55,95,.12);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.05);
  --shadow-md:  0 8px 28px rgba(0,0,0,.09);
  --shadow-lg:  0 20px 60px rgba(27,55,95,.12);
  --r:          12px;
  --r-lg:       18px;
  --serif:      'Platypi', Georgia, serif;
  --sans:       'DM Sans', system-ui, sans-serif;
}
/* ─── NAV ─────────────────────────────── */
.nav{background:#1b375f;border-bottom:1px solid rgba(196,157,116,.2);position:sticky;top:0;z-index:100;transition:box-shadow .2s}
/* ─── BREADCRUMB ──────────────────────── */
.breadcrumb{background:#fff;border-bottom:1px solid var(--gold-line);padding:12px 0}
.breadcrumb-sep{color:var(--gold);font-size:14px}
/* ─── PAGE HERO ───────────────────────── */
.page-hero{background:#fff;padding:52px 0 44px;border-bottom:1px solid var(--gold-line);position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;right:0;top:0;bottom:0;width:35%;background-image:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=800&q=60&fit=crop&crop=right');background-size:cover;background-position:center;opacity:.1;mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.8) 50%);-webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.8) 50%)}
.page-h1{font-family:var(--serif);font-size:clamp(32px,4vw,50px);font-weight:700;color:var(--navy);line-height:1.08;letter-spacing:-.01em;max-width:540px}
.page-desc{font-size:15px;color:var(--ink-md);line-height:1.75;max-width:500px}
/* ─── STATS ROW ───────────────────────── */
.stats-row{
  background:var(--navy);border-top:2px solid var(--gold);
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stats-row-item{padding:22px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.07)}
.stats-row-item:last-child{border-right:none}
.stats-row-num{font-family:var(--serif);font-size:36px;font-weight:700;color:var(--gold);line-height:1}
.stats-row-lbl{font-size:11px;color:rgba(255,255,255,.4);margin-top:5px;line-height:1.4}
/* ─── FILTER BAR ──────────────────────── */
.filter-bar{background:#fff;border-bottom:1px solid var(--gold-line);position:sticky;top:64px;z-index:90;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.filter-inner{max-width:1160px;margin:0 auto;padding:0 40px;display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none}
.filter-tab{display:flex;align-items:center;gap:7px;padding:15px 18px;font-size:13px;font-weight:500;color:var(--ink-mt);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all .18s;font-family:var(--sans)}
.filter-count{background:var(--gold-pale);color:var(--gold-dk);font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;margin-left:2px}
.filter-tab.active .filter-count{background:var(--navy);color:var(--gold)}
/* ─── GALERIE PRINCIPALE ──────────────── */
.gallery-section{padding:52px 0 72px}
/* Featured — 1 grande photo en tête */
.gallery-featured{
  display:grid;grid-template-columns:2fr 1fr;
  gap:3px;border-radius:var(--r-lg);overflow:hidden;
  margin-bottom:3px;
}
.gallery-featured-right{display:grid;grid-template-rows:1fr 1fr;gap:3px}
/* Grille standard */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:3px;
}
.gallery-grid.hidden{display:none}
/* Item galerie */
.gallery-item{
  position:relative;overflow:hidden;
  aspect-ratio:4/3;cursor:pointer;
  background:var(--navy-md);
}
.gallery-item.tall{aspect-ratio:3/4}
.gallery-item.wide{grid-column:span 2}
.gallery-item.square{aspect-ratio:1}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;display:block;
}
.gallery-item:hover img{transform:scale(1.05)}
/* Overlay au hover */
.gallery-item-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(27,55,95,.9) 0%,transparent 55%);
  opacity:0;transition:opacity .3s;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;
}
.gallery-item:hover .gallery-item-overlay{opacity:1}
.gallery-item-cat{
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);margin-bottom:4px;
}
.gallery-item-title{
  font-family:var(--serif);font-size:17px;font-weight:700;
  color:#fff;line-height:1.2;margin-bottom:2px;
}
.gallery-item-loc{font-size:11px;color:rgba(255,255,255,.6)}
/* Badge catégorie (toujours visible) */
.gallery-item-badge{
  position:absolute;top:12px;left:12px;
  background:rgba(27,55,95,.85);backdrop-filter:blur(4px);
  color:var(--gold-lt);font-size:10px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px;
  border:1px solid rgba(196,157,116,.3);
}
/* Placeholder chantier */
.gallery-ph{
  width:100%;height:100%;
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:10px;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-md) 100%);
}
.gallery-ph-icon{opacity:.25}
.gallery-ph-label{
  font-size:10px;color:rgba(255,255,255,.3);
  letter-spacing:.1em;text-transform:uppercase;
}
.gallery-ph-cat{
  font-family:var(--serif);font-size:14px;font-weight:700;
  color:rgba(196,157,116,.5);margin-top:4px;
}
/* Bouton load more */
.load-more-wrap{text-align:center;margin-top:40px}
/* ─── CHANTIER DETAIL (mini case study) ─ */
.chantier-section{padding:64px 0}
.chantier-block{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:var(--border);
  border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-md);margin-bottom:24px;
}
.chantier-text{background:#fff;padding:44px 40px;display:flex;flex-direction:column;justify-content:center}
.chantier-num{font-family:var(--serif);font-size:48px;font-weight:700;-webkit-text-stroke:1.5px var(--gold);color:transparent;line-height:1;margin-bottom:6px}
.chantier-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-dk);margin-bottom:8px}
.chantier-title{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:6px}
.chantier-loc{font-size:13px;color:var(--ink-mt);margin-bottom:16px;display:flex;align-items:center;gap:6px}
.chantier-desc{font-size:14px;color:var(--ink-md);line-height:1.8;margin-bottom:20px}
.chantier-tags{display:flex;flex-wrap:wrap;gap:6px}
.chantier-tag{font-size:11px;font-weight:600;padding:4px 12px;background:var(--gold-pale);border:1px solid var(--border-md);color:var(--gold-dk);border-radius:20px}
.chantier-photo{background:var(--navy-md);position:relative;overflow:hidden;min-height:360px;display:flex;align-items:center;justify-content:center}
.chantier-photo::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);z-index:2}
/* ─── TÉMOIGNAGES INTÉGRÉS ─────────────── */
.temoignage-strip{
  background:var(--navy);padding:48px 0;
  border-top:2px solid var(--gold);border-bottom:2px solid var(--gold);
}
.temoignage-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.temoignage-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(196,157,116,.15);
  border-radius:var(--r);padding:22px;
}
.temo-stars{color:var(--gold);font-size:13px;letter-spacing:1px;margin-bottom:10px}
.temo-quote{font-family:var(--serif);font-style:italic;font-size:15px;color:rgba(255,255,255,.8);line-height:1.65;margin-bottom:14px}
.temo-author{font-size:13px;font-weight:700;color:#fff}
.temo-detail{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px}
/* ─── CTA ─────────────────────────────── */
.cta-sec{background:var(--off);border-top:2px solid var(--gold-line);padding:72px 0;text-align:center}
/* ─── LIGHTBOX ────────────────────────── */
.lightbox{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(20,40,67,.94);backdrop-filter:blur(8px);
  align-items:center;justify-content:center;padding:24px;
}
.lightbox.open{display:flex}
.lightbox-inner{
  max-width:900px;width:100%;
  animation:lbIn .28s ease both;
}
@keyframes lbIn{from{opacity:0;transform:scale(.94)}
to{opacity:1;transform:scale(1)}
.lightbox-img-wrap{
  border-radius:var(--r-lg);overflow:hidden;
  background:var(--navy-md);
  aspect-ratio:16/9;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.lightbox-img-wrap img{width:100%;height:100%;object-fit:cover}
.lightbox-info{
  padding:20px 24px;background:#fff;
  border-radius:0 0 var(--r-lg) var(--r-lg);
  border-top:2px solid var(--gold);
}
.lightbox-cat{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dk);margin-bottom:4px}
.lightbox-title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--navy);margin-bottom:4px}
.lightbox-desc{font-size:13px;color:var(--ink-mt)}
.lightbox-close{
  position:fixed;top:20px;right:20px;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:18px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.lightbox-close:hover{background:rgba(255,255,255,.25)}
.lightbox-nav{
  position:fixed;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:20px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.lightbox-nav:hover{background:rgba(255,255,255,.25)}
.lightbox-nav.prev{left:16px}
.lightbox-nav.next{right:16px}
/* ─── ANIMATIONS ──────────────────────── */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .45s ease,transform .45s ease}
/* ─── RESPONSIVE ──────────────────────── */
@media(max-width:960px){
  .nav-links{display:none}
.gallery-grid{grid-template-columns:1fr 1fr}
.gallery-item.wide{grid-column:span 1}
.gallery-featured{grid-template-columns:1fr}
.gallery-featured-right{grid-template-rows:1fr}
.stats-row{grid-template-columns:1fr 1fr}
.stats-row-item{border-bottom:1px solid rgba(255,255,255,.07)}
.chantier-block{grid-template-columns:1fr}
.temoignage-grid{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:1fr}
.gallery-item{aspect-ratio:4/3}
/* ─── LAYOUT ─────────────────────────── */
.wrap    {max-width:1160px;margin:0 auto;padding:0 40px}
/* ─── BOUTONS ────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:8px;border:1.5px solid transparent;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.01em;transition:all .18s;cursor:pointer;white-space:nowrap}
/* ─── NAV — bleu #1b375f ─────────────── */
.nav{background:#1b375f;border-bottom:1px solid rgba(196,157,116,.2);position:sticky;top:0;z-index:100;transition:box-shadow .2s}
/* ─── BREADCRUMB ─────────────────────── */
.breadcrumb{background:#fff;border-bottom:1px solid var(--gold-line);padding:12px 0}
/* ─── PAGE HERO — fond blanc ──────────── */
.page-hero{
  background:#fff;padding:52px 0 44px;
  border-bottom:1px solid var(--gold-line);
  position:relative;overflow:hidden;
}
.page-hero::after{
  content:'';position:absolute;right:0;top:0;bottom:0;width:35%;
  background-image:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=800&q=60&fit=crop&crop=right');
  background-size:cover;background-position:center;opacity:.1;
  mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.8) 50%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.8) 50%);
}
/* ─── CONTACT RAPIDE — 3 cartes haut ─── */
.contact-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  padding:36px 0;
}
.contact-card{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);
  padding:28px 24px;text-align:center;
  transition:all .2s;box-shadow:var(--shadow-sm);
}
.contact-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.contact-card-icon{
  width:52px;height:52px;border-radius:50%;
  background:var(--navy);margin:0 auto 14px;
  display:flex;align-items:center;justify-content:center;
}
.contact-card-title{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--navy);margin-bottom:6px}
.contact-card-value{font-size:16px;font-weight:700;color:var(--gold-dk);margin-bottom:4px}
.contact-card-sub{font-size:12px;color:var(--ink-mt);line-height:1.5;margin-bottom:16px}
.contact-card-cta{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;color:var(--navy);
  padding:8px 18px;border-radius:8px;border:1.5px solid var(--border-navy);
  transition:all .18s;
}
.contact-card-cta:hover{background:var(--gold-pale);border-color:var(--gold);color:var(--gold-dk)}
/* ─── MAIN GRID — Formulaire + Infos ─── */
.contact-grid{
  display:grid;grid-template-columns:1fr 380px;gap:40px;
  padding:64px 0 80px;
}
/* ─── FORMULAIRE ─────────────────────── */
.form-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.form-card-header{
  background:var(--navy);padding:24px 28px;
  border-bottom:2px solid var(--gold);
}
.form-card-title{
  font-family:var(--serif);font-size:22px;font-weight:700;color:#fff;margin-bottom:4px;
}
.form-card-sub{font-size:13px;color:rgba(255,255,255,.5)}
.form-card-body{padding:28px 28px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}
.form-group-full{grid-column:span 2}
.form-label{
  font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-mt);
}
.form-req{color:var(--gold);margin-left:2px}
.form-input,
.form-select,
.form-textarea{
  padding:12px 14px;background:var(--off);
  border:1.5px solid var(--border-navy);border-radius:8px;
  font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;
  transition:border-color .15s,box-shadow .15s;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(196,157,116,.12);
  background:#fff;
}
.form-input::placeholder,
.form-textarea::placeholder{color:var(--ink-mt)}
.form-select{color:var(--ink-md);cursor:pointer}
.form-textarea{resize:vertical;min-height:120px;line-height:1.65}
/* Radio type de travaux */
.form-radios{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
.form-radio{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:8px;border:1.5px solid var(--border-navy);
  cursor:pointer;transition:all .15s;
  font-size:13px;color:var(--ink-md);
}
.form-radio:hover{border-color:var(--gold);background:var(--gold-ultra)}
.form-radio input{accent-color:var(--gold);width:15px;height:15px;flex-shrink:0}
.form-radio.selected{border-color:var(--gold);background:var(--gold-pale);color:var(--navy);font-weight:600}
/* Budget slider */
.form-budget-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-mt);margin-top:4px}
.form-range{width:100%;accent-color:var(--gold);height:4px;cursor:pointer;margin-top:6px}
.form-submit-row{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;padding-top:8px;
  border-top:1px solid var(--border);margin-top:20px;
}
.form-notice{font-size:11px;color:var(--ink-mt);max-width:300px;line-height:1.5}
.form-notice svg{display:inline-block;vertical-align:middle;margin-right:4px}
/* ─── SIDEBAR INFOS ──────────────────── */
.contact-sidebar{display:flex;flex-direction:column;gap:16px}
/* Card info */
.info-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.info-card-header{
  background:var(--navy);padding:18px 22px;
  border-bottom:2px solid var(--gold);
}
.info-card-title{
  font-family:var(--serif);font-size:18px;font-weight:700;
  color:var(--gold-lt);
}
.info-card-body{padding:20px 22px;display:flex;flex-direction:column;gap:16px}
.info-row{display:flex;align-items:flex-start;gap:12px}
.info-icon{
  width:36px;height:36px;border-radius:8px;
  background:var(--gold-pale);border:1px solid var(--border-md);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.info-content{}
.info-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mt);margin-bottom:2px}
.info-value{font-size:14px;font-weight:600;color:var(--navy)}
.info-sub{font-size:12px;color:var(--ink-mt);margin-top:2px;line-height:1.5}
.info-link{color:var(--gold-dk);transition:color .15s}
.info-link:hover{color:var(--navy)}
/* Horaires */
.horaires-grid{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.horaire-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.horaire-row:last-child{border-bottom:none}
.horaire-day{color:var(--ink-md);font-weight:500}
.horaire-time{color:var(--navy);font-weight:600}
.horaire-time.closed{color:var(--ink-mt);font-weight:400}
/* Card EEAT Damien */
.eeat-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:22px;box-shadow:var(--shadow-sm);
}
.eeat-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.eeat-avatar{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--navy-md));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--serif);font-size:20px;font-weight:700;flex-shrink:0;
}
.eeat-role{font-size:12px;color:var(--ink-mt)}
.eeat-body{font-size:13px;color:var(--ink-md);line-height:1.75;margin-bottom:14px}
.eeat-body strong{color:var(--navy);font-weight:600}
.eeat-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.eeat-stat{background:var(--off);border-radius:8px;padding:10px;text-align:center;border:1px solid var(--border)}
.eeat-stat-num{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--navy);display:block;line-height:1}
.eeat-stat-lbl{font-size:10px;color:var(--ink-mt);margin-top:3px}
/* Zone mini */
.zone-mini{
  background:var(--navy);border-radius:var(--r-lg);
  padding:20px 22px;
}
.zone-mini-title{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--gold-lt);margin-bottom:8px}
.zone-mini-tags{display:flex;flex-wrap:wrap;gap:5px}
.zone-mini-tag{font-size:11px;font-weight:600;padding:4px 11px;border:1px solid rgba(196,157,116,.3);color:rgba(255,255,255,.58);border-radius:6px}
/* ─── SUCCESS MESSAGE ────────────────── */
.form-success{
  display:none;text-align:center;padding:40px 20px;
}
.form-success-icon{
  width:64px;height:64px;border-radius:50%;
  background:var(--gold-pale);border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;font-size:28px;
}
.form-success-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--navy);margin-bottom:8px}
.form-success-sub{font-size:14px;color:var(--ink-mt);line-height:1.7}
/* ─── FOOTER ─────────────────────────── */
.footer{background:var(--navy-dk);border-top:2px solid var(--gold-line)}
/* ─── FLOAT ──────────────────────────── */
.float-call{display:none;position:fixed;bottom:16px;right:14px;z-index:999;background:var(--gold);color:#fff;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 4px 20px rgba(0,0,0,.25);align-items:center;gap:8px}
/* ─── ANIMATIONS ─────────────────────── */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .45s ease,transform .45s ease}
/* ─── RESPONSIVE ─────────────────────── */
@media(max-width:960px){
  .nav-links{display:none}
.contact-grid{grid-template-columns:1fr}
.contact-cards{grid-template-columns:1fr}
@media(max-width:640px){
  .wrap,.wrap-md{padding:0 18px}
.form-grid{grid-template-columns:1fr}
.form-group-full{grid-column:span 1}
.form-radios{grid-template-columns:1fr}
/* ─── Stats encadrée (variante card) ─── */
.stats-band--card {
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
  margin: 32px 0;
  overflow: hidden;
}

/* Stats-band encadrée — override border-top pleine largeur */
.stats-band[style*="border-radius"] {
  border-top: none !important;
}

/* ─── BURGER & MENU MOBILE ──────────────────────── */

/* Burger caché par défaut (desktop) */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  padding: 6px;
  background: none;
  border: none;
  cursor: pointer;
  border-radius: 6px;
  transition: background .15s;
  flex-shrink: 0;
}
.nav-burger:hover { background: rgba(255,255,255,.1); }
.nav-burger span {
  display: block;
  width: 100%;
  height: 2px;
  background: #c49d74;
  border-radius: 2px;
  transition: transform .25s ease, opacity .25s ease;
  transform-origin: center;
}
.nav-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Menu mobile caché par défaut */
.mobile-menu {
  display: none;
  position: fixed;
  top: 64px;
  left: 0;
  right: 0;
  background: #142843;
  border-top: 2px solid rgba(196,157,116,.3);
  z-index: 99;
  box-shadow: 0 8px 32px rgba(0,0,0,.3);
  transform: translateY(-8px);
  opacity: 0;
  transition: opacity .2s ease, transform .2s ease;
  pointer-events: none;
}
.mobile-menu.visible {
  display: block;
}
.mobile-menu.open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.mobile-menu-inner {
  display: flex;
  flex-direction: column;
  padding: 8px 0 16px;
}
.mobile-link {
  font-size: 15px;
  font-weight: 500;
  color: rgba(255,255,255,.7);
  padding: 14px 24px;
  border-left: 3px solid transparent;
  transition: all .15s;
  text-decoration: none;
  display: block;
}
.mobile-link:hover,
.mobile-link.active {
  color: #fff;
  background: rgba(255,255,255,.06);
  border-left-color: #c49d74;
}
.mobile-tel {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  color: #c49d74;
  padding: 14px 24px;
  margin-top: 4px;
  border-top: 1px solid rgba(255,255,255,.08);
  text-decoration: none;
}

/* Mobile : afficher burger, cacher liens desktop et téléphone */
@media(max-width:960px) {
  .nav-burger { display: flex; }
  .nav-phone  { display: none; }
  .nav-links  { display: none; }
}
