/* =====================================================================
   RF Toiture — Design system
   Charte : crème + serif haute-graisse + accents terracotta / or, bois sombre
   Display : Playfair Display   ·   Texte/UI : Mulish
   ===================================================================== */

:root{
  /* Surfaces */
  --cream:        #FBF6ED;
  --cream-2:      #F4EADB;   /* section alternée */
  --tan-card:     #EFE1CB;   /* cartes valeurs */
  --line:         #E3D6C2;   /* filets sur crème */

  /* Encre */
  --ink:          #443426;   /* corps de texte (brun chaud) */
  --ink-strong:   #2B1D12;   /* titres */
  --ink-soft:     #6E5B49;   /* texte atténué */

  /* Accents */
  --terracotta:   #C36B3A;   /* accent sur fond clair */
  --terracotta-d: #AC5A2D;   /* hover */
  --gold:         #D5AD83;   /* accent sur fond sombre */

  /* Sombre / bois */
  --dark:         #2A1B10;   /* header */
  --dark-2:       #1C1109;   /* footer */
  --dark-ink:     #EFE3D2;   /* texte sur sombre */
  --dark-soft:    #B9A48C;   /* texte atténué sur sombre */

  /* Système */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --shadow: 0 24px 60px -28px rgba(40,24,12,.45);
  --ease: cubic-bezier(.22,.61,.36,1);

  --font-display: "Playfair Display", Georgia, serif;
  --font-body: "Mulish", system-ui, -apple-system, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
h1,h2,h3,h4,p{ margin:0; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(64px,9vw,120px); }
.section--cream2{ background:var(--cream-2); }

/* ---------- Typographie ---------- */
.display{
  font-family:var(--font-display);
  color:var(--ink-strong);
  font-weight:500;
  line-height:1.08;
  letter-spacing:.005em;
}
.h1{ font-size:clamp(2.6rem, 6.2vw, 5rem); }
.h2{ font-size:clamp(2rem, 4vw, 3.3rem); }
.h3{ font-size:clamp(1.5rem, 2.4vw, 2rem); }

/* Deuxième ligne en italique : accent terracotta (clair) / or (sombre) */
.display em{
  display:block;
  font-style:italic;
  font-weight:500;
  color:var(--terracotta);
}
.on-dark .display, .on-dark.display{ color:#fff; }
.on-dark .display em, .on-dark.display em{ color:var(--gold); }

.lead{ font-size:1.075rem; color:var(--ink); }
.muted{ color:var(--ink-soft); }
.on-dark{ color:var(--dark-ink); }
.on-dark .muted{ color:var(--dark-soft); }

/* ---------- Eyebrow ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-size:.72rem; font-weight:700; letter-spacing:.28em;
  text-transform:uppercase; color:var(--terracotta);
  margin-bottom:18px;
}
.eyebrow::before{ content:""; width:34px; height:2px; background:currentColor; }
.eyebrow--center{ justify-content:center; }
.eyebrow--center::after{ content:""; width:34px; height:2px; background:currentColor; }
.on-dark .eyebrow{ color:var(--gold); }

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:15px 30px; border-radius:var(--radius);
  font-weight:700; font-size:.82rem; letter-spacing:.13em; text-transform:uppercase;
  border:1.5px solid transparent; transition:.25s var(--ease);
  white-space:nowrap;
}
.btn-primary{ background:var(--terracotta); color:#fff; }
.btn-primary:hover{ background:var(--terracotta-d); transform:translateY(-2px); }
.btn-outline{ border-color:rgba(255,255,255,.55); color:#fff; }
.btn-outline:hover{ background:rgba(255,255,255,.1); border-color:#fff; }
.btn-dark{
  display:inline-flex; align-items:center; justify-content:center; white-space:nowrap;
  background:var(--dark); color:var(--cream); border-radius:var(--radius);
  letter-spacing:.06em; text-transform:none; font-size:.95rem; padding:13px 26px;
}
.btn-dark:hover{ background:#3a2718; transform:translateY(-2px); }

/* =====================================================================
   HEADER
   ===================================================================== */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .35s var(--ease), box-shadow .35s var(--ease);
}
.site-header.scrolled{ background:var(--dark); box-shadow:0 10px 30px -18px rgba(0,0,0,.6); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding-block:16px; }

.brand{ display:flex; align-items:center; gap:12px; }
.brand-logo{ height:48px; width:auto; display:block; }
.site-footer .brand-logo{ height:40px; }
@media (max-width:600px){ .brand-logo{ height:40px; } }
@media (max-width:380px){ .brand-logo{ height:34px; } }
.brand-mark{ width:46px; height:auto; flex:none; color:#fff; }
.brand-text{ line-height:1; }
.brand-name{ font-family:var(--font-display); font-size:1.5rem; color:#fff; letter-spacing:.02em; }
.brand-tag{ display:block; margin-top:4px; font-size:.52rem; letter-spacing:.24em; color:var(--dark-soft); text-transform:uppercase; }

.nav{ display:flex; align-items:center; gap:34px; }
.nav a{ font-size:.78rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--dark-ink); transition:color .2s; }
.nav a:hover, .nav a[aria-current="page"]{ color:var(--gold); }
.nav .has-sub{ position:relative; }
.nav .has-sub>a{ display:inline-flex; align-items:center; gap:7px; }
.nav .has-sub>a::after{
  content:""; width:6px; height:6px; flex:none;
  border-right:1.7px solid currentColor; border-bottom:1.7px solid currentColor;
  transform:translateY(-2px) rotate(45deg);
}
.submenu{
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%) translateY(8px);
  background:var(--dark); border:1px solid rgba(213,173,131,.25); border-radius:6px;
  padding:8px; min-width:230px; opacity:0; visibility:hidden; transition:.22s var(--ease);
  box-shadow:var(--shadow);
}
.nav .has-sub:hover .submenu, .nav .has-sub:focus-within .submenu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.submenu a{ display:block; padding:10px 14px; border-radius:4px; letter-spacing:.08em; }
.submenu a:hover{ background:rgba(213,173,131,.12); }

.header-cta{ display:flex; align-items:center; gap:18px; }
.btn-phone{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--terracotta); color:#fff; padding:12px 22px; border-radius:var(--radius);
  font-weight:700; letter-spacing:.04em; font-size:.95rem; transition:.25s var(--ease);
}
.btn-phone:hover{ background:var(--terracotta-d); }
.btn-phone .phone-ico{ display:none; }

.nav-toggle{ display:none; background:none; border:0; padding:8px; }
.nav-toggle span{ display:block; width:26px; height:2px; background:#fff; margin:5px 0; transition:.25s; }

/* =====================================================================
   HERO
   ===================================================================== */
.hero{
  position:relative; min-height:100svh; display:grid; place-items:center;
  grid-template-columns:minmax(0,1fr);
  text-align:center; color:#fff; overflow:hidden; padding:140px 0 70px;
}
.hero-bg{ position:absolute; inset:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; }
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(28,17,9,.78) 0%, rgba(28,17,9,.34) 26%, rgba(28,17,9,.42) 64%, rgba(28,17,9,.72) 100%);
}
.hero-inner{ position:relative; z-index:2; width:100%; max-width:880px; padding-inline:var(--gutter); }
.hero .eyebrow{ color:var(--gold); }
.hero .display{ color:#fff; }
.hero .display em{ color:var(--gold); }
.hero .h1{ margin-bottom:26px; }
.hero-sub{ max-width:620px; margin:0 auto; color:#f0e6d8; }
.dots{ display:flex; gap:9px; justify-content:center; align-items:center; margin:26px 0; }
.dots span{ width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.45); }
.dots span.on{ width:22px; height:7px; border-radius:4px; background:var(--gold); }
.hero-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.hero-badges{ display:flex; gap:18px; justify-content:center; margin-top:40px; }
.hero-badges img{ width:62px; height:62px; border-radius:50%; object-fit:cover; background:#fff; }
.scroll-cue{ margin-top:34px; font-size:.66rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); }
.scroll-cue::after{ content:""; display:block; width:1px; height:34px; margin:12px auto 0; background:linear-gradient(var(--gold), transparent); }

/* =====================================================================
   MARQUEE STRIP
   ===================================================================== */
.strip{
  background:var(--dark); background-image:url("img/wood-card.jpg");
  background-size:cover; background-position:center;
  text-align:center; padding:18px var(--gutter);
}
.strip span{
  font-size:.74rem; font-weight:700; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold); background:rgba(28,17,9,.45); padding:4px;
}

/* =====================================================================
   GRILLES 2 COLONNES (alternées)
   ===================================================================== */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,80px); align-items:center; }
.split--text-narrow{ grid-template-columns:1fr 1.05fr; }
.split .media{ align-self:stretch; }

/* Portrait avec cadre décalé */
.portrait{ position:relative; }
.portrait-frame{
  position:absolute; top:26px; bottom:26px; left:-30px; right:-30px;
  border:1.5px solid var(--gold); border-radius:2px; z-index:0;
}
.portrait figure{ position:relative; z-index:1; margin:0; box-shadow:0 30px 60px -28px rgba(40,24,12,.55); }
.portrait img{ width:100%; object-fit:cover; aspect-ratio:3/4; }
.portrait figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:18px 20px;
  background:linear-gradient(transparent, rgba(20,12,6,.85));
  color:#fff;
}
.portrait figcaption b{ font-family:var(--font-display); font-style:italic; font-weight:500; font-size:1.15rem; }
.portrait figcaption span{ display:block; margin-top:4px; font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }

.stack p + p{ margin-top:16px; }
/* Air entre le titre de section et le texte qui suit (retour François) */
.stack .display{ margin-bottom:clamp(16px,2vw,24px); }
.stack .eyebrow + .display{ margin-top:2px; }

/* Divider à points */
.divider{ display:flex; align-items:center; gap:14px; margin:34px 0; color:var(--line); }
.divider::before, .divider::after{ content:""; flex:1; height:1px; background:var(--line); }
.divider i{ width:6px; height:6px; border-radius:50%; background:var(--line); }
.divider i.on{ background:var(--terracotta); }

/* Carte contact bois (about) */
.contact-card{
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
  border-radius:6px; overflow:hidden; box-shadow:var(--shadow);
  background:var(--dark); background-image:url("img/wood-card.jpg"); background-size:cover; background-position:center;
}
.contact-card > div{ padding:22px 24px; position:relative; display:flex; flex-direction:column; justify-content:center; }
.contact-card > div + div::before{ content:""; position:absolute; left:0; top:18%; bottom:18%; width:1px; background:rgba(213,173,131,.3); }
.contact-card dt{ font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.contact-card dd{ margin:0; color:#fff; font-weight:600; }

/* Galerie zinguerie : 1 grande + 2 vignettes */
.media-stack{ display:grid; gap:16px; }
.media-stack .big img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:3px; }
.media-stack .thumbs{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.media-stack .thumbs img{ width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:3px; }
/* Variante À propos : grande image verticale, vignettes paysage, espace resserré */
.media-stack--tight{ gap:12px; }
.media-stack--tight .thumbs{ gap:12px; }
.media-stack--tight .big img{ aspect-ratio:3/4; }
.media-stack--tight .thumbs img{ aspect-ratio:4/3; }

/* Cadre doré décalé pour une image paysage (même style que la photo de François) */
.portrait--wide figure{ box-shadow:0 30px 60px -28px rgba(40,24,12,.55); }
.portrait--wide img{ aspect-ratio:4/3; }

/* Image encadrée d'un filet doré (section Couvreur Marseillais) */
.media-single--framed img{ width:100%; display:block; aspect-ratio:3/2; object-fit:cover;
  border-radius:3px; border:1px solid var(--gold); padding:6px; background:var(--cream); }

/* 2 images empilées (réparations) */
/* Paire d'images (zinguerie sur mesure) : remplit toute la hauteur du bloc
   texte voisin, quelles que soient les images (les images sont recadrées). */
.media-pair{ display:grid; grid-template-rows:0.8fr 1fr; gap:18px; min-height:100%; }
.media-pair img{ width:100%; height:100%; min-height:0; object-fit:cover; border-radius:3px; display:block; }

/* Galerie « Travaux de zinguerie » : grande image (remplit la hauteur restante)
   + 2 vignettes paysage. Hauteur totale = hauteur du bloc texte. */
.media-stack--travaux{ grid-template-rows:1fr auto; min-height:100%; }
.media-stack--travaux .big{ min-height:0; }
.media-stack--travaux .big img{ height:100%; min-height:0; aspect-ratio:auto; }
.media-stack--travaux .thumbs img{ aspect-ratio:4/3; }

/* =====================================================================
   BANDE SOMBRE PLEINE LARGEUR (image + overlay)
   ===================================================================== */
.feature-band{ position:relative; color:#fff; overflow:hidden; }
.feature-band .band-bg{ position:absolute; inset:0; }
.feature-band .band-bg img{ width:100%; height:100%; object-fit:cover; }
.feature-band .band-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(24,14,7,.9) 0%, rgba(24,14,7,.72) 42%, rgba(24,14,7,.25) 100%); }
.feature-band .wrap{ position:relative; z-index:2; padding-block:clamp(70px,8vw,110px); }
.feature-band .band-content{ max-width:560px; }
.feature-band .band-content p{ margin:18px 0 30px; color:#ecdfce; }

/* =====================================================================
   EXPERTISE
   ===================================================================== */
.value-card{
  background:var(--tan-card); border-left:4px solid var(--terracotta);
  padding:22px 26px; border-radius:0 4px 4px 0; margin-top:18px;
}
.value-card h3{ font-family:var(--font-display); font-weight:600; font-size:1.2rem; color:var(--ink-strong); margin-bottom:6px; }
.value-card p{ font-size:.95rem; color:var(--ink); }

.expertise-list{ display:grid; grid-template-columns:minmax(0,1fr); gap:14px; }
.expertise-item{
  display:flex; align-items:center; gap:18px; width:100%; text-align:left;
  background:#fff; border:1px solid var(--line); border-left:4px solid var(--terracotta);
  border-radius:0 4px 4px 0; padding:14px 18px; transition:.25s var(--ease);
  cursor:pointer; font:inherit; color:inherit; -webkit-appearance:none; appearance:none;
}
.expertise-item:hover{ transform:translateX(4px); box-shadow:0 14px 30px -22px rgba(40,24,12,.5); }
.expertise-item img{ width:60px; height:60px; border-radius:50%; object-fit:cover; flex:none; transition:.25s var(--ease); }
.expertise-item span{ font-family:var(--font-display); font-size:1.15rem; color:var(--ink-strong); min-width:0; overflow-wrap:break-word; transition:color .2s; }
/* Onglet actif */
.expertise-item.is-active{ border-left-width:6px; background:#fff; box-shadow:0 16px 34px -20px rgba(40,24,12,.55); transform:translateX(4px); }
.expertise-item.is-active span{ color:var(--terracotta); }
.expertise-item.is-active img{ box-shadow:0 0 0 2px var(--terracotta); }

/* Panneaux dynamiques (texte + image à droite) */
.expertise-panels{ position:relative; }
.expertise-panel{ display:none; }
.expertise-panel.is-active{ display:block; animation:expFade .45s var(--ease); }
@keyframes expFade{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }
.exp-title{ font-family:var(--font-display); font-style:italic; font-weight:500; color:var(--terracotta);
  font-size:clamp(1.3rem,2.1vw,1.7rem); line-height:1.28; margin:6px 0 14px; }
.expertise-panel p{ margin-bottom:22px; }

.badges{ display:flex; justify-content:center; gap:clamp(24px,5vw,60px); margin-top:34px; }
.badge{ text-align:center; }
.badge img{ width:84px; height:84px; border-radius:50%; object-fit:cover; background:#fff; margin-inline:auto; box-shadow:0 8px 20px -10px rgba(40,24,12,.35); }
.badge span{ display:block; margin-top:10px; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); }

/* =====================================================================
   CONTACT (fond bois)
   ===================================================================== */
.contact{ position:relative; color:var(--dark-ink); }
.contact .bg{ position:absolute; inset:0; }
.contact .bg img{ width:100%; height:100%; object-fit:cover; }
.contact .bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,12,6,.86), rgba(20,12,6,.92)); }
.contact .wrap{ position:relative; z-index:2; }
.contact .split{ align-items:start; }
.contact p.lead{ color:#e7d9c6; }

.info-list{ margin-top:34px; display:grid; grid-template-columns:minmax(0,1fr); gap:24px; }
.info dd{ overflow-wrap:anywhere; }
.info-list .info{ border-left:3px solid var(--terracotta); padding-left:18px; }
.info dt{ font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:4px; }
.info dd{ margin:0; font-size:1.2rem; color:#fff; }

.map{ margin-top:30px; border-radius:6px; overflow:hidden; border:1px solid rgba(213,173,131,.25); }
.map iframe{ display:block; width:100%; height:240px; border:0; filter:saturate(.9); }

/* Formulaire */
.form-panel{
  background:rgba(38,24,13,.55); border:1px solid rgba(213,173,131,.22);
  border-radius:8px; padding:clamp(26px,3vw,40px); backdrop-filter:blur(2px);
}
.form-panel h3{ font-family:var(--font-display); color:var(--gold); font-weight:600; margin-bottom:22px; font-size:1.5rem; }
.field{ margin-bottom:20px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:0 16px; }
@media (max-width:560px){ .field-row{ grid-template-columns:1fr; gap:0; } }
.field label{ display:block; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.field input, .field textarea{
  width:100%; background:rgba(20,12,6,.4); border:1px solid rgba(213,173,131,.28);
  border-radius:4px; padding:13px 15px; color:#fff; font:inherit; transition:border-color .2s;
}
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold); }
.field textarea{ resize:vertical; min-height:120px; }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:.82rem; color:var(--dark-soft); }
.consent input{ margin-top:4px; accent-color:var(--terracotta); }
.req-note{ font-size:.78rem; color:var(--dark-soft); margin:14px 0 18px; }
.btn-submit{ width:100%; background:var(--terracotta); color:#fff; border:0; padding:16px; border-radius:4px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; transition:.25s var(--ease); }
.btn-submit:hover{ background:var(--terracotta-d); }
.form-msg{ margin-top:14px; font-size:.9rem; color:var(--gold); min-height:1.2em; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{ background:var(--dark-2); color:var(--dark-soft); }
.footer-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding-block:30px; flex-wrap:wrap; }
.footer-inner .brand-name{ font-size:1.2rem; }
.footer-mid{ font-size:.85rem; text-align:center; }
.footer-end{ display:flex; gap:24px; font-size:.85rem; }
.footer-end a:hover{ color:var(--gold); }

/* =====================================================================
   PAGE HERO (pages internes, plus court)
   ===================================================================== */
.page-hero{ min-height:62vh; padding-top:160px; }
.page-hero .h1{ font-size:clamp(2.2rem,5vw,4rem); }

/* =====================================================================
   REVEAL
   ===================================================================== */
.reveal{ opacity:1; transform:none; }
.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.js .reveal.in{ opacity:1; transform:none; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:920px){
  .nav, .header-cta .btn-phone span.label{ display:none; }
  .header-cta .btn-phone .phone-ico{ display:block; }
  .header-cta .btn-phone{ padding:11px 13px; gap:0; }
  .header-inner{ gap:12px; }
  .header-cta{ gap:10px; }
  .brand{ gap:9px; min-width:0; }
  .nav-toggle{ display:block; }
  .nav.open{
    display:flex; flex-direction:column; align-items:flex-start; gap:4px;
    position:absolute; top:100%; left:0; right:0; background:var(--dark);
    padding:16px var(--gutter) 24px; box-shadow:var(--shadow);
  }
  .nav.open a{ padding:12px 0; width:100%; border-bottom:1px solid rgba(213,173,131,.12); }
  .nav.open .submenu{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:0; background:rgba(0,0,0,.2); margin:4px 0 0; transform:none; min-width:0; }
  .submenu{ left:0; transform:none; }

  .split{ grid-template-columns:1fr; gap:40px; }
  .feature-band .band-content{ max-width:none; }
  .feature-band .band-bg::after{ background:linear-gradient(180deg, rgba(24,14,7,.82), rgba(24,14,7,.7)); }
  .portrait-frame{ top:18px; bottom:18px; left:-18px; right:-18px; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .contact-card{ grid-template-columns:1fr; }
  .contact-card > div + div::before{ display:none; }
  .contact-card > div + div{ border-top:1px solid rgba(213,173,131,.25); }
  .hero-actions{ flex-direction:column; }
  .hero-actions .btn{ width:100%; }
  .footer-inner{ flex-direction:column; text-align:center; }
  .badges{ flex-wrap:wrap; gap:24px; }
}

/* ---- Anti-débordement sur très petits écrans ---- */
html, body{ overflow-x:hidden; }
.display, h1, h2, h3, p{ overflow-wrap:break-word; }
.split > *{ min-width:0; }                 /* autorise les colonnes à rétrécir */
.info dd, .contact-card dd{ overflow-wrap:anywhere; }  /* coupe les e-mails longs */

@media (max-width:400px){
  :root{ --gutter:16px; }
  .h1{ font-size:clamp(2rem, 8.5vw, 2.6rem); }
  .h2{ font-size:clamp(1.7rem, 7vw, 2.4rem); }
  .form-panel{ padding:22px 18px; }
  .btn-dark{ padding:13px 18px; }
  /* Boutons : autorise le retour à la ligne et réduit l'empattement sous 400px */
  .btn{ padding:13px 16px; letter-spacing:.05em; white-space:normal; }
  .eyebrow{ flex-wrap:wrap; letter-spacing:.16em; }
  .info dd{ font-size:1rem; }
  /* En-tête compact : évite le chevauchement marque / téléphone */
  .brand-mark{ width:28px; }
  .brand-name{ font-size:1.02rem; }
  .brand-tag{ display:none; }
  .brand{ overflow:hidden; }
  .header-cta{ gap:8px; }
  .header-cta .btn-phone{ padding:10px 11px; }
  .nav-toggle{ padding:6px; }
}

/* Titres des prestations : réduit la police sur petits écrans pour que les
   mots tiennent sur une ligne (au lieu d'être coupés au milieu). */
@media (max-width:360px){ .expertise-item span{ font-size:1.02rem; } }
@media (max-width:300px){ .expertise-item span{ font-size:.9rem; } }
@media (max-width:250px){
  .expertise-item span{ font-size:.78rem; }
  .expertise-item{ gap:12px; padding:12px 14px; }
  .expertise-item img{ width:46px; height:46px; }
}

@media (prefers-reduced-motion:reduce){
  *{ scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; transition:none; }
}

/* Contact en page autonome (sans hero) */
.contact--top{ padding-top:clamp(120px,16vh,170px); }
/* Image seule (section Pourquoi nous choisir) */
.media-single img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:3px; box-shadow:var(--shadow); }

/* ---------- États formulaire (validation + retours serveur) ---------- */
.field.invalid input, .field.invalid textarea{ border-color:#e07a6a; }
.field .field-err{ display:none; margin-top:6px; font-size:.78rem; color:#f0a896; }
.field.invalid .field-err{ display:block; }
.form-msg.is-ok{ color:#9fe0b4; }
.form-msg.is-err{ color:#f0a896; }
.consent--err{ color:#f0a896; }
.consent--err input{ outline:2px solid #e07a6a; outline-offset:2px; }
.btn-submit[disabled]{ opacity:.6; cursor:not-allowed; }

/* ---------- Pied de page : liens légaux ---------- */
.footer-legal{ border-top:1px solid rgba(213,173,131,.14); }
.footer-legal .wrap{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:10px;
  padding-block:16px; font-size:.82rem; color:var(--dark-soft); }
.footer-legal a, .footer-cookies-link{ color:var(--dark-soft); text-decoration:none; background:none; border:0;
  font:inherit; cursor:pointer; padding:0; }
.footer-legal a:hover, .footer-cookies-link:hover{ color:var(--gold); }

/* ---------- Bandeau cookies (RGPD) ---------- */
.cookie-banner{ position:fixed; left:16px; right:16px; bottom:16px; z-index:200; max-width:760px; margin:0 auto;
  background:var(--dark); color:var(--dark-ink); border:1px solid rgba(213,173,131,.25); border-radius:12px;
  box-shadow:0 20px 50px -18px rgba(0,0,0,.6); padding:18px 20px; display:flex; flex-wrap:wrap; align-items:center;
  gap:14px 18px; }
.cookie-banner[hidden]{ display:none; }
.cookie-banner__txt{ flex:1 1 320px; min-width:0; margin:0; font-size:.88rem; line-height:1.55; }
.cookie-banner__txt a{ color:var(--gold); text-decoration:underline; }
.cookie-banner__btns{ display:flex; gap:10px; flex:0 0 auto; }
.btn-cookie{ font:inherit; font-weight:700; font-size:.82rem; letter-spacing:.02em; border-radius:8px;
  padding:10px 18px; cursor:pointer; border:1.5px solid transparent; transition:.2s var(--ease); }
.btn-cookie--accept{ background:var(--terracotta); color:#fff; }
.btn-cookie--accept:hover{ background:var(--terracotta-d); }
.btn-cookie--ghost{ background:transparent; color:var(--dark-ink); border-color:rgba(213,173,131,.5); }
.btn-cookie--ghost:hover{ background:rgba(255,255,255,.06); }

/* ---------- Pages légales ---------- */
.legal-page .legal-wrap{ max-width:820px; }
.legal-page h1{ margin-bottom:8px; }
.legal-page .legal-updated{ color:var(--ink-soft); font-size:.9rem; margin-bottom:30px; }
.legal-page h2{ font-family:var(--font-display); font-size:1.4rem; color:var(--ink-strong); margin:34px 0 10px; }
.legal-page h3{ font-size:1.05rem; color:var(--ink-strong); margin:20px 0 6px; }
.legal-page p, .legal-page li{ color:var(--ink); line-height:1.75; }
.legal-page p{ margin:0 0 14px; }
.legal-page ul{ margin:0 0 14px; padding-left:22px; }
.legal-page li{ margin-bottom:6px; }
.legal-page a{ color:var(--terracotta); }
.legal-page .legal-note{ background:var(--cream-2); border-left:3px solid var(--terracotta);
  padding:14px 18px; border-radius:0 6px 6px 0; font-size:.9rem; }

@media (max-width:560px){
  .cookie-banner{ left:10px; right:10px; bottom:10px; padding:16px; }
  .cookie-banner__btns{ width:100%; }
  .btn-cookie{ flex:1; }
}

/* =====================================================================
   GABARIT LANDING / MERCI (sans menu)
   ===================================================================== */
.site-header--minimal{ position:relative; background:var(--dark); box-shadow:0 6px 24px -18px rgba(0,0,0,.6); }
.brand--static{ cursor:default; }
.site-header--minimal .header-inner{ justify-content:space-between; }

/* ---- Page de remerciement ---- */
.lp-thanks{ background:var(--cream); }
.lp-thanks__in{ max-width:680px; margin-inline:auto; text-align:center; }
.lp-thanks__icon{ width:78px; height:78px; margin:0 auto 24px; border-radius:50%;
  display:grid; place-items:center; font-size:2.2rem; color:#fff; background:#2e9e54;
  box-shadow:0 16px 34px -14px rgba(46,158,84,.6); }
.lp-thanks .lead{ margin:18px auto 26px; max-width:560px; }
.lp-thanks__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:24px; }

/* ---- Hero de landing SEA (texte + logos à gauche, formulaire à droite) ---- */
.lp-hero{ position:relative; background:var(--dark); color:#fff; overflow:hidden;
  padding:clamp(40px,6vw,80px) 0; }
.lp-hero__bg{ position:absolute; inset:0; }
.lp-hero__bg img{ width:100%; height:100%; object-fit:cover; opacity:.28; }
.lp-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(120deg,rgba(28,17,9,.92) 40%,rgba(28,17,9,.7)); }
.lp-hero__in{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(32px,5vw,64px); align-items:center; }
.lp-hero__left .eyebrow{ color:var(--gold); }
.lp-hero__left h1{ color:#fff; }
.lp-hero__left h1 em{ color:var(--gold); }
.lp-hero__left .lead{ color:#f0e6d8; max-width:520px; margin-top:18px; }
.lp-points{ list-style:none; margin:22px 0 0; padding:0; display:grid; gap:10px; }
.lp-points li{ position:relative; padding-left:30px; color:#f0e6d8; font-size:1rem; }
.lp-points li::before{ content:""; position:absolute; left:0; top:3px; width:18px; height:18px;
  border-radius:50%; background:var(--terracotta);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");
  background-size:13px; background-repeat:no-repeat; background-position:center; }
.lp-badges{ display:flex; align-items:center; gap:22px; margin-top:28px; flex-wrap:wrap; }
.lp-badges img{ width:66px; height:66px; border-radius:50%; object-fit:cover; background:#fff;
  box-shadow:0 8px 20px -10px rgba(0,0,0,.5); }
.lp-hero__phone{ display:inline-flex; align-items:center; gap:10px; margin-top:26px;
  font-family:var(--font-display); font-size:1.5rem; color:#fff; }
.lp-hero__phone svg{ width:22px; height:22px; fill:var(--gold); }

/* Carte formulaire du hero */
.lp-form{ background:#fff; border-radius:14px; padding:clamp(24px,3vw,36px);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.55); color:var(--ink); }
.lp-form h2{ font-family:var(--font-display); font-weight:600; color:var(--ink-strong);
  font-size:1.5rem; margin-bottom:4px; }
.lp-form__sub{ color:var(--ink-soft); font-size:.92rem; margin-bottom:20px; }
.lp-form .field{ margin-bottom:14px; }
.lp-form .field label{ display:block; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); margin-bottom:6px; font-weight:700; }
.lp-form .field input, .lp-form .field textarea{ width:100%; background:#faf7f2;
  border:1px solid var(--line); border-radius:6px; padding:12px 14px; color:var(--ink); font:inherit;
  transition:border-color .2s; }
.lp-form .field input:focus, .lp-form .field textarea:focus{ outline:none; border-color:var(--terracotta); background:#fff; }
.lp-form .field textarea{ resize:vertical; min-height:84px; }
.lp-form .consent{ color:var(--ink-soft); align-items:flex-start; }
.lp-form .consent a{ color:var(--terracotta); }
.lp-form .btn-submit{ width:100%; background:var(--terracotta); color:#fff; border:0; padding:15px;
  border-radius:6px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; cursor:pointer;
  transition:.2s var(--ease); }
.lp-form .btn-submit:hover{ background:var(--terracotta-d); }
.lp-form .req-note{ font-size:.76rem; color:var(--ink-soft); margin:10px 0 0; }
.lp-form .form-msg{ margin-top:12px; font-size:.9rem; min-height:1.2em; color:var(--terracotta); }
.lp-form .form-msg.is-ok{ color:#2e9e54; }
.lp-form .form-msg.is-err{ color:#c0392b; }

@media (max-width:880px){
  .lp-hero__in{ grid-template-columns:1fr; }
  .lp-hero__form{ order:-1; }
}
