/*
Theme Name: Construction FDA 360 — V2
Theme URI: https://constructionfda360.ca
Description: Thème custom V2 pour Construction FDA 360 — direction architecturale / éditoriale (béton + charbon + jaune sécurité). Bilingue FR/EN, logique custom.
Author: Jon Allenby
Version: 2.0.0
Text Domain: construction-fda360-v2
*/

/* ═══════════════════════════════════════════════
   DESIGN TOKENS — "Blueprint Editorial"
═══════════════════════════════════════════════ */
:root {
  /* Surfaces */
  --cf3-ink:        #16181D;   /* charbon quasi-noir */
  --cf3-graphite:   #23262E;   /* gris foncé sections */
  --cf3-concrete:   #EEEBE3;   /* béton chaud (fond clair) */
  --cf3-concrete-2: #E3DFD4;   /* béton plus marqué */
  --cf3-paper:      #FBFAF6;   /* blanc cassé */
  --cf3-white:      #FFFFFF;

  /* Accent — jaune sécurité chantier */
  --cf3-accent:     #F5C518;
  --cf3-accent-2:   #E0AC00;
  --cf3-accent-soft: rgba(245,197,24,.14);

  /* Texte */
  --cf3-text:       #1B1D22;
  --cf3-muted:      #6A6E78;
  --cf3-muted-dk:   rgba(255,255,255,.62);
  --cf3-line:       #D8D3C7;
  --cf3-line-dk:    rgba(255,255,255,.12);

  /* Type */
  --cf3-display: 'Space Grotesk', sans-serif;
  --cf3-body:    'Manrope', sans-serif;

  /* Radii & shadow — volontairement carrés/nets (architectural) */
  --cf3-r:    2px;
  --cf3-r-lg: 4px;
  --cf3-sh-sm: 0 1px 0 rgba(22,24,29,.06), 0 8px 24px rgba(22,24,29,.06);
  --cf3-sh-md: 0 18px 50px rgba(22,24,29,.14);

  --cf3-maxw: 1280px;
  --cf3-gut:  clamp(20px, 5vw, 64px);
  --cf3-pad:  clamp(72px, 10vw, 140px);
}

/* ═══════════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--cf3-body);
  font-size: 17px;
  line-height: 1.72;
  color: var(--cf3-text);
  background: var(--cf3-paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s ease; }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
::selection { background: var(--cf3-accent); color: var(--cf3-ink); }

/* ═══════════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════════ */
h1, h2, h3, h4, h5 {
  font-family: var(--cf3-display);
  font-weight: 600;
  line-height: 1.04;
  letter-spacing: -0.02em;
  color: var(--cf3-ink);
}
h1 { font-size: clamp(2.7rem, 6.4vw, 5.6rem); font-weight: 700; }
h2 { font-size: clamp(2rem, 4.4vw, 3.5rem); }
h3 { font-size: clamp(1.3rem, 2.2vw, 1.75rem); }
h4 { font-size: 1.12rem; letter-spacing: 0; }
p  { margin-bottom: 1.1rem; }
p:last-child { margin-bottom: 0; }
strong { font-weight: 700; }

/* Eyebrow / kicker avec index */
.cf3-kicker {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  font-family: var(--cf3-display);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--cf3-ink);
}
.cf3-kicker::before {
  content: "";
  width: 30px; height: 2px;
  background: var(--cf3-accent-2);
  display: inline-block;
}
.cf3-kicker--light { color: #fff; }
.cf3-kicker--index { gap: .9rem; }
.cf3-kicker--index::before { content: none; }
.cf3-kicker__num {
  font-size: .72rem;
  color: var(--cf3-accent-2);
}
.cf3-accent-txt { color: var(--cf3-accent-2); }
.cf3-mark {
  background: linear-gradient(180deg, transparent 62%, var(--cf3-accent) 62%);
  padding: 0 .06em;
}

/* ═══════════════════════════════════════════════
   LAYOUT PRIMITIVES
═══════════════════════════════════════════════ */
.cf3-wrap {
  max-width: var(--cf3-maxw);
  margin: 0 auto;
  padding-left: var(--cf3-gut);
  padding-right: var(--cf3-gut);
}
.cf3-sec { padding-top: var(--cf3-pad); padding-bottom: var(--cf3-pad); }
.cf3-sec--ink      { background: var(--cf3-ink);      color: #fff; }
.cf3-sec--graphite { background: var(--cf3-graphite); color: #fff; }
.cf3-sec--concrete { background: var(--cf3-concrete); }
.cf3-sec--paper    { background: var(--cf3-paper); }
.cf3-sec--ink h1,.cf3-sec--ink h2,.cf3-sec--ink h3,.cf3-sec--ink h4,
.cf3-sec--graphite h1,.cf3-sec--graphite h2,.cf3-sec--graphite h3,.cf3-sec--graphite h4 { color: #fff; }

/* En-tête de section éditorial (aligné à gauche, en grille) */
.cf3-sechead {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem 4rem;
  align-items: end;
  margin-bottom: clamp(48px, 6vw, 88px);
}
.cf3-sechead__lead h2 { margin-top: 1rem; }
.cf3-sechead__desc { color: var(--cf3-muted); font-size: 1.06rem; max-width: 46ch; }
.cf3-sec--ink .cf3-sechead__desc,
.cf3-sec--graphite .cf3-sechead__desc { color: var(--cf3-muted-dk); }

/* ═══════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════ */
.cf3-btn {
  --b: var(--cf3-ink);
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  font-family: var(--cf3-display);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 1.05rem 1.7rem;
  border-radius: var(--cf3-r);
  background: var(--b);
  color: #fff;
  border: 2px solid var(--b);
  transition: transform .18s ease, background .2s ease, color .2s ease, border-color .2s ease;
  position: relative;
}
.cf3-btn:hover { transform: translateY(-2px); }
.cf3-btn svg { width: 16px; height: 16px; transition: transform .2s ease; }
.cf3-btn:hover svg { transform: translateX(4px); }

.cf3-btn--accent { --b: var(--cf3-accent); color: var(--cf3-ink); }
.cf3-btn--accent:hover { background: var(--cf3-accent-2); border-color: var(--cf3-accent-2); }

.cf3-btn--ghost {
  background: transparent;
  color: var(--cf3-ink);
  border-color: var(--cf3-ink);
}
.cf3-btn--ghost:hover { background: var(--cf3-ink); color: #fff; }

.cf3-sec--ink .cf3-btn--ghost,
.cf3-sec--graphite .cf3-btn--ghost { color:#fff; border-color: rgba(255,255,255,.4); }
.cf3-sec--ink .cf3-btn--ghost:hover,
.cf3-sec--graphite .cf3-btn--ghost:hover { background:#fff; color: var(--cf3-ink); }

.cf3-textlink {
  display: inline-flex; align-items:center; gap:.5rem;
  font-family: var(--cf3-display); font-weight:600; font-size:.85rem;
  letter-spacing:.04em; text-transform:uppercase;
  border-bottom: 2px solid var(--cf3-accent);
  padding-bottom: 3px;
}
.cf3-textlink svg { width:15px;height:15px; transition: transform .2s ease; }
.cf3-textlink:hover svg { transform: translateX(4px); }

/* ═══════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════ */
.cf3-topbar {
  background: var(--cf3-ink);
  color: rgba(255,255,255,.78);
  font-size: .78rem;
  letter-spacing: .02em;
}
.cf3-topbar__inner {
  max-width: var(--cf3-maxw); margin: 0 auto;
  padding: .55rem var(--cf3-gut);
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
}
.cf3-topbar a { display:inline-flex; align-items:center; gap:.4rem; }
.cf3-topbar a:hover { color: var(--cf3-accent); }
.cf3-topbar__set { display:flex; gap:1.4rem; align-items:center; }
.cf3-topbar svg { width: 14px; height:14px; opacity:.8; }

.cf3-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--cf3-paper);
  border-bottom: 1px solid var(--cf3-line);
  transition: box-shadow .25s ease, padding .25s ease;
}
.cf3-header.is-stuck { box-shadow: var(--cf3-sh-sm); }
.cf3-header__inner {
  max-width: var(--cf3-maxw); margin: 0 auto;
  padding: .95rem var(--cf3-gut);
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
}
.cf3-logo { display:flex; align-items:center; gap:.7rem; flex-shrink:0; }
.cf3-logo svg { height: 44px; width:auto; }

.cf3-nav { display:flex; align-items:center; gap: 2.1rem; margin-left: auto; }
.cf3-nav a {
  font-family: var(--cf3-display);
  font-weight: 500; font-size: .92rem; letter-spacing: .01em;
  color: var(--cf3-ink);
  position: relative; padding: .3rem 0;
}
.cf3-nav a::after {
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background: var(--cf3-accent); transition: width .22s ease;
}
.cf3-nav a:hover::after, .cf3-nav a.is-active::after { width:100%; }

.cf3-header__cta { display:flex; align-items:center; gap: 1rem; }
.cf3-lang {
  font-family: var(--cf3-display); font-weight:600; font-size:.82rem;
  letter-spacing:.08em; padding:.45rem .7rem; border:1.5px solid var(--cf3-line);
  border-radius: var(--cf3-r); transition: all .2s ease;
}
.cf3-lang:hover { border-color: var(--cf3-ink); background: var(--cf3-ink); color:#fff; }
.cf3-header .cf3-btn { padding: .8rem 1.25rem; font-size:.76rem; }

.cf3-burger { display:none; width:46px;height:46px; flex-direction:column; justify-content:center; align-items:center; gap:5px; border:1.5px solid var(--cf3-line); border-radius: var(--cf3-r); }
.cf3-burger span { width:20px;height:2px;background:var(--cf3-ink); transition: all .25s ease; }
.cf3-burger.is-open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.cf3-burger.is-open span:nth-child(2){ opacity:0; }
.cf3-burger.is-open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

.cf3-mobile {
  position: fixed; inset: 0 0 0 auto; width: min(86vw, 380px);
  background: var(--cf3-ink); color:#fff; z-index: 200;
  transform: translateX(100%); transition: transform .35s cubic-bezier(.7,0,.2,1);
  padding: 6rem var(--cf3-gut) 2rem; display:flex; flex-direction:column; gap: .4rem;
}
.cf3-mobile.is-open { transform: translateX(0); }
.cf3-mobile a {
  font-family: var(--cf3-display); font-size: 1.5rem; font-weight:500;
  padding: .7rem 0; border-bottom:1px solid var(--cf3-line-dk);
}
.cf3-mobile a:hover { color: var(--cf3-accent); }
.cf3-mobile__foot { margin-top:auto; display:flex; flex-direction:column; gap:1rem; padding-top:1.5rem; }
.cf3-mobile__close { position:absolute; top:1.5rem; right:var(--cf3-gut); width:42px;height:42px; border:1px solid var(--cf3-line-dk); border-radius:var(--cf3-r); color:#fff; font-size:1.4rem; display:grid; place-items:center; }
.cf3-overlay { position:fixed; inset:0; background:rgba(10,11,14,.55); opacity:0; visibility:hidden; transition:.3s; z-index:150; }
.cf3-overlay.is-open { opacity:1; visibility:visible; }

/* ═══════════════════════════════════════════════
   HERO — asymétrique éditorial
═══════════════════════════════════════════════ */
.cf3-hero { background: var(--cf3-concrete); position: relative; overflow: hidden; }
.cf3-hero__grid {
  max-width: var(--cf3-maxw); margin:0 auto;
  display: grid; grid-template-columns: 1.05fr .95fr;
  min-height: clamp(560px, 80vh, 820px);
}
.cf3-hero__text {
  padding: clamp(48px,7vw,96px) clamp(28px,4vw,64px) clamp(48px,7vw,96px) var(--cf3-gut);
  display:flex; flex-direction:column; justify-content:center;
  position: relative; z-index: 2;
}
.cf3-hero h1 { margin: 1.4rem 0 1.6rem; }
.cf3-hero h1 .line { display:block; }
.cf3-hero__sub { font-size: 1.15rem; color: var(--cf3-muted); max-width: 50ch; margin-bottom: 2.2rem; }
.cf3-hero__cta { display:flex; flex-wrap:wrap; gap:1rem; }

.cf3-hero__media { position: relative; }
.cf3-hero__media .cf3-img { position:absolute; inset:0; }
.cf3-hero__media .cf3-img svg,
.cf3-hero__media .cf3-img img { width:100%; height:100%; object-fit: cover; }
.cf3-hero__badge {
  position:absolute; left: -54px; bottom: 56px; z-index:3;
  background: var(--cf3-accent); color: var(--cf3-ink);
  padding: 1.4rem 1.7rem; border-radius: var(--cf3-r-lg);
  box-shadow: var(--cf3-sh-md); max-width: 230px;
}
.cf3-hero__badge .num { font-family: var(--cf3-display); font-weight:700; font-size: 3rem; line-height:1; }
.cf3-hero__badge .lbl { font-family: var(--cf3-display); font-weight:600; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; margin-top:.4rem; }

/* Bandeau de stats sous le hero */
.cf3-statbar { background: var(--cf3-ink); color:#fff; }
.cf3-statbar__grid {
  max-width: var(--cf3-maxw); margin:0 auto; padding: 0 var(--cf3-gut);
  display:grid; grid-template-columns: repeat(4, 1fr);
}
.cf3-statbar__item { padding: 2.2rem 1.5rem; border-left:1px solid var(--cf3-line-dk); }
.cf3-statbar__item:first-child { border-left:none; padding-left:0; }
.cf3-statbar__num { font-family:var(--cf3-display); font-weight:700; font-size: clamp(2rem,3vw,2.8rem); color: var(--cf3-accent); line-height:1; }
.cf3-statbar__lbl { font-size:.86rem; color: var(--cf3-muted-dk); margin-top:.5rem; letter-spacing:.02em; }

/* ═══════════════════════════════════════════════
   IMG FRAME (illustrations SVG)
═══════════════════════════════════════════════ */
.cf3-frame { position: relative; border-radius: var(--cf3-r-lg); overflow: hidden; background: var(--cf3-concrete-2); }
.cf3-frame svg, .cf3-frame img { width:100%; height:100%; object-fit: cover; display:block; }
.cf3-frame--tag::after {
  content: attr(data-tag);
  position:absolute; left:1rem; bottom:1rem;
  font-family:var(--cf3-display); font-size:.7rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  background: var(--cf3-ink); color:#fff; padding:.4rem .7rem; border-radius: var(--cf3-r);
}

/* ═══════════════════════════════════════════════
   SPLIT (intro / about strips)
═══════════════════════════════════════════════ */
.cf3-split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(36px,5vw,80px); align-items:center; }
.cf3-split--media-first .cf3-split__media { order:-1; }
.cf3-split__media { align-self: stretch; min-height: 380px; }
.cf3-split h2 { margin: 1rem 0 1.3rem; }
.cf3-split__lead { color: var(--cf3-muted); font-size:1.08rem; margin-bottom: 1.6rem; }
.cf3-sec--ink .cf3-split__lead, .cf3-sec--graphite .cf3-split__lead { color: var(--cf3-muted-dk); }

/* ═══════════════════════════════════════════════
   SERVICES — lignes numérotées (accordéon visuel)
═══════════════════════════════════════════════ */
.cf3-rows { border-top: 1px solid var(--cf3-line); }
.cf3-sec--ink .cf3-rows, .cf3-sec--graphite .cf3-rows { border-color: var(--cf3-line-dk); }
.cf3-row {
  display:grid; grid-template-columns: 90px 1fr 1.3fr auto;
  gap: 1.5rem; align-items: center;
  padding: 2.1rem 0; border-bottom:1px solid var(--cf3-line);
  transition: padding-left .25s ease, background .25s ease;
}
.cf3-sec--ink .cf3-row, .cf3-sec--graphite .cf3-row { border-color: var(--cf3-line-dk); }
.cf3-row:hover { padding-left: 1.2rem; background: var(--cf3-accent-soft); }
.cf3-row__num { font-family:var(--cf3-display); font-weight:700; font-size:1.05rem; color:var(--cf3-accent-2); }
.cf3-row__title { font-family:var(--cf3-display); font-weight:600; font-size: clamp(1.3rem,2.4vw,1.9rem); color: var(--cf3-ink); }
.cf3-sec--ink .cf3-row__title, .cf3-sec--graphite .cf3-row__title { color:#fff; }
.cf3-row__desc { color: var(--cf3-muted); font-size:.98rem; }
.cf3-sec--ink .cf3-row__desc, .cf3-sec--graphite .cf3-row__desc { color: var(--cf3-muted-dk); }
.cf3-row__arrow { width:48px;height:48px;border-radius:50%; border:1.5px solid var(--cf3-line); display:grid;place-items:center; transition:.22s; }
.cf3-row:hover .cf3-row__arrow { background:var(--cf3-accent); border-color:var(--cf3-accent); transform: rotate(-45deg); }
.cf3-row__arrow svg { width:18px;height:18px; }

/* ═══════════════════════════════════════════════
   VALUES — cartes
═══════════════════════════════════════════════ */
.cf3-cards { display:grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; }
.cf3-card {
  background: var(--cf3-paper); padding: 2.1rem 1.7rem;
  border:1px solid var(--cf3-line); border-radius: var(--cf3-r-lg);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.cf3-card:hover { transform: translateY(-6px); box-shadow: var(--cf3-sh-md); border-color: transparent; }
.cf3-card__ico { width:54px;height:54px;border-radius:var(--cf3-r); background: var(--cf3-ink); display:grid;place-items:center; margin-bottom:1.3rem; }
.cf3-card__ico svg { width:26px;height:26px; color: var(--cf3-accent); }
.cf3-card h3 { font-size:1.25rem; margin-bottom:.6rem; }
.cf3-card p { color: var(--cf3-muted); font-size:.96rem; }
.cf3-sec--ink .cf3-card, .cf3-sec--graphite .cf3-card { background: var(--cf3-graphite); border-color: var(--cf3-line-dk); }
.cf3-sec--ink .cf3-card p, .cf3-sec--graphite .cf3-card p { color: var(--cf3-muted-dk); }

/* Liste "ce qui nous distingue" */
.cf3-checks { display:grid; grid-template-columns: repeat(2,1fr); gap: .9rem 2rem; margin-top: .5rem; }
.cf3-checks li { display:flex; gap:.8rem; align-items:flex-start; font-weight:600; font-size:1rem; }
.cf3-checks svg { width:22px;height:22px;flex-shrink:0;color:var(--cf3-accent-2); margin-top:2px; }
.cf3-sec--ink .cf3-checks svg, .cf3-sec--graphite .cf3-checks svg { color: var(--cf3-accent); }

/* ═══════════════════════════════════════════════
   GALLERY
═══════════════════════════════════════════════ */
.cf3-filter { display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom: 2.5rem; }
.cf3-filter button {
  font-family:var(--cf3-display); font-weight:600; font-size:.8rem; letter-spacing:.05em; text-transform:uppercase;
  padding:.6rem 1.1rem; border:1.5px solid var(--cf3-line); border-radius: 100px; color: var(--cf3-muted); transition:.2s;
}
.cf3-filter button:hover { border-color: var(--cf3-ink); color: var(--cf3-ink); }
.cf3-filter button.is-active { background: var(--cf3-ink); color:#fff; border-color:var(--cf3-ink); }

.cf3-gallery { display:grid; grid-template-columns: repeat(12,1fr); gap: 1.2rem; }
.cf3-gallery__item { position:relative; overflow:hidden; border-radius:var(--cf3-r-lg); background: var(--cf3-concrete-2); min-height: 240px; }
.cf3-gallery__item svg, .cf3-gallery__item img { width:100%;height:100%;object-fit:cover; transition: transform .5s ease; }
.cf3-gallery__item:hover svg, .cf3-gallery__item:hover img { transform: scale(1.05); }
.cf3-gallery__item.span-6 { grid-column: span 6; }
.cf3-gallery__item.span-4 { grid-column: span 4; }
.cf3-gallery__item.span-8 { grid-column: span 8; }
.cf3-gallery__item.tall { min-height: 360px; }
.cf3-gallery__cap {
  position:absolute; left:0; right:0; bottom:0; padding:1.4rem;
  background: linear-gradient(transparent, rgba(18,20,24,.82));
  color:#fff; transform: translateY(8px); opacity:0; transition:.3s;
}
.cf3-gallery__item:hover .cf3-gallery__cap { transform:translateY(0); opacity:1; }
.cf3-gallery__cap .t { font-family:var(--cf3-display); font-weight:600; font-size:1.1rem; }
.cf3-gallery__cap .c { font-size:.82rem; color: var(--cf3-accent); letter-spacing:.06em; text-transform:uppercase; }
.cf3-gallery__item.is-hidden { display:none; }

/* ═══════════════════════════════════════════════
   PROCESS — étapes
═══════════════════════════════════════════════ */
.cf3-steps { display:grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; counter-reset: step; }
.cf3-step { position: relative; padding-top: 2.5rem; }
.cf3-step::before {
  counter-increment: step; content: "0" counter(step);
  font-family:var(--cf3-display); font-weight:700; font-size: 2.6rem; color: var(--cf3-accent);
  position:absolute; top:-.5rem; left:0;
}
.cf3-step__bar { height:3px; background: var(--cf3-line-dk); margin: 1rem 0 1.2rem; position:relative; }
.cf3-step__bar::after { content:""; position:absolute; left:0;top:0;height:100%; width:30%; background: var(--cf3-accent); }
.cf3-step h4 { color:#fff; font-family:var(--cf3-display); font-size:1.2rem; margin-bottom:.5rem; }
.cf3-step p { color: var(--cf3-muted-dk); font-size:.92rem; }

/* ═══════════════════════════════════════════════
   FAQ accordéon
═══════════════════════════════════════════════ */
.cf3-faq { max-width: 880px; margin: 0 auto; }
.cf3-faq__item { border-bottom: 1px solid var(--cf3-line); }
.cf3-faq__q {
  width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:1.5rem;
  padding: 1.6rem 0; font-family:var(--cf3-display); font-weight:600; font-size: clamp(1.05rem,2vw,1.35rem); color:var(--cf3-ink);
}
.cf3-faq__icon { flex-shrink:0; width:38px;height:38px;border:1.5px solid var(--cf3-line); border-radius:50%; display:grid;place-items:center; position:relative; transition:.25s; }
.cf3-faq__icon::before, .cf3-faq__icon::after { content:""; position:absolute; background: var(--cf3-ink); transition:.25s; }
.cf3-faq__icon::before { width:14px;height:2px; }
.cf3-faq__icon::after  { width:2px;height:14px; }
.cf3-faq__item.is-open .cf3-faq__icon { background: var(--cf3-accent); border-color:var(--cf3-accent); }
.cf3-faq__item.is-open .cf3-faq__icon::after { transform: scaleY(0); }
.cf3-faq__a { max-height:0; overflow:hidden; transition: max-height .35s ease; }
.cf3-faq__a-inner { padding: 0 0 1.7rem; color: var(--cf3-muted); max-width: 70ch; }

/* ═══════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════ */
.cf3-contact { display:grid; grid-template-columns: 1fr 1.1fr; gap: clamp(36px,5vw,72px); }
.cf3-info-list { display:flex; flex-direction:column; gap: 1.6rem; margin-top: 2rem; }
.cf3-info { display:flex; gap:1.1rem; align-items:flex-start; }
.cf3-info__ico { flex-shrink:0; width:52px;height:52px;border-radius:var(--cf3-r); background:var(--cf3-accent); display:grid;place-items:center; }
.cf3-info__ico svg { width:24px;height:24px;color:var(--cf3-ink); }
.cf3-info__t { font-family:var(--cf3-display); font-weight:600; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--cf3-muted); margin-bottom:.2rem; }
.cf3-info__v { font-size:1.12rem; font-weight:600; color:var(--cf3-ink); }
.cf3-info__v a:hover { color: var(--cf3-accent-2); }
.cf3-sec--ink .cf3-info__v, .cf3-sec--graphite .cf3-info__v { color:#fff; }

.cf3-form { background: var(--cf3-paper); border:1px solid var(--cf3-line); border-radius: var(--cf3-r-lg); padding: clamp(28px,4vw,48px); }
.cf3-field { margin-bottom: 1.2rem; }
.cf3-field label { display:block; font-family:var(--cf3-display); font-weight:600; font-size:.8rem; letter-spacing:.04em; margin-bottom:.5rem; color:var(--cf3-ink); }
.cf3-field input, .cf3-field select, .cf3-field textarea {
  width:100%; font-family:var(--cf3-body); font-size:1rem; color:var(--cf3-text);
  padding: .95rem 1.05rem; border:1.5px solid var(--cf3-line); border-radius:var(--cf3-r); background:#fff;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.cf3-field textarea { min-height: 140px; resize: vertical; }
.cf3-field input:focus, .cf3-field select:focus, .cf3-field textarea:focus {
  outline:none; border-color: var(--cf3-ink); box-shadow: 0 0 0 4px var(--cf3-accent-soft);
}
.cf3-field--row { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.cf3-form__note { font-size:.85rem; color:var(--cf3-muted); margin-top:1rem; }
.cf3-form__msg { margin-top:1rem; padding:1rem 1.2rem; border-radius:var(--cf3-r); font-weight:600; font-size:.95rem; display:none; }
.cf3-form__msg.ok { display:block; background:#e7f6ec; color:#1c7a3f; }
.cf3-form__msg.err { display:block; background:#fdeaea; color:#b3261e; }

.cf3-map { border:0; width:100%; height:100%; min-height:320px; border-radius:var(--cf3-r-lg); filter: grayscale(.3) contrast(1.05); }

/* ═══════════════════════════════════════════════
   CTA BAND
═══════════════════════════════════════════════ */
.cf3-cta {
  background: var(--cf3-accent); color: var(--cf3-ink);
  position: relative; overflow:hidden;
}
.cf3-cta__inner { display:grid; grid-template-columns: 1.4fr auto; gap:2.5rem; align-items:center; }
.cf3-cta h2 { color: var(--cf3-ink); max-width: 18ch; }
.cf3-cta p { color: rgba(22,24,29,.7); font-size:1.1rem; margin-top:.8rem; max-width: 50ch; }
.cf3-cta .cf3-btn--ink { background: var(--cf3-ink); color:#fff; border-color:var(--cf3-ink); }
.cf3-cta .cf3-btn--ink:hover { background:#000; }

/* ═══════════════════════════════════════════════
   PAGE HERO (intérieures)
═══════════════════════════════════════════════ */
.cf3-pagehero { background: var(--cf3-ink); color:#fff; padding: clamp(70px,9vw,120px) 0 clamp(56px,7vw,90px); position:relative; overflow:hidden; }
.cf3-pagehero__grid { position:relative; z-index:2; }
.cf3-pagehero h1 { color:#fff; margin: 1.1rem 0 1rem; max-width: 18ch; }
.cf3-pagehero p { color: var(--cf3-muted-dk); font-size:1.12rem; max-width: 56ch; }
.cf3-crumbs { font-size:.82rem; color: var(--cf3-muted-dk); letter-spacing:.04em; }
.cf3-crumbs a:hover { color: var(--cf3-accent); }
.cf3-pagehero__deco { position:absolute; right: -40px; top:50%; transform:translateY(-50%); width: 340px; opacity:.16; color: var(--cf3-accent); z-index:1; }

/* Prose (pages légales) */
.cf3-prose { max-width: 800px; }
.cf3-prose h2 { font-size: clamp(1.5rem,3vw,2rem); margin: 2.4rem 0 1rem; }
.cf3-prose h3 { font-size:1.2rem; margin: 1.6rem 0 .6rem; }
.cf3-prose p, .cf3-prose li { color: var(--cf3-text); }
.cf3-prose ul { list-style: disc; padding-left: 1.3rem; margin-bottom:1.1rem; }
.cf3-prose li { margin-bottom:.4rem; }
.cf3-prose a { color: var(--cf3-accent-2); border-bottom:1px solid var(--cf3-accent); }

/* ═══════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════ */
.cf3-footer { background: var(--cf3-ink); color: var(--cf3-muted-dk); padding-top: clamp(64px,7vw,96px); }
.cf3-footer__top { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 2.5rem; padding-bottom: 3.5rem; border-bottom:1px solid var(--cf3-line-dk); }
.cf3-footer__brand svg { height:46px; width:auto; margin-bottom:1.3rem; }
.cf3-footer__brand p { font-size:.95rem; max-width: 34ch; }
.cf3-footer h4 { color:#fff; font-family:var(--cf3-display); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1.2rem; }
.cf3-footer__links { display:flex; flex-direction:column; gap:.7rem; }
.cf3-footer__links a:hover { color: var(--cf3-accent); }
.cf3-footer__contact a { display:flex; gap:.6rem; align-items:flex-start; margin-bottom:.7rem; }
.cf3-footer__contact svg { width:17px;height:17px;color:var(--cf3-accent); flex-shrink:0; margin-top:3px; }
.cf3-footer__contact a:hover { color:#fff; }
.cf3-footer__bottom { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding: 1.8rem 0; font-size:.84rem; flex-wrap:wrap; }
.cf3-footer__bottom a:hover { color:var(--cf3-accent); }
.cf3-footer__legal { display:flex; gap:1.4rem; }

/* ═══════════════════════════════════════════════
   COOKIE BANNER
═══════════════════════════════════════════════ */
.cf3-cookie {
  position: fixed; left: clamp(16px,3vw,32px); bottom: clamp(16px,3vw,32px); z-index: 300;
  max-width: 420px; background: var(--cf3-ink); color: #fff;
  border-radius: var(--cf3-r-lg); padding: 1.5rem 1.6rem; box-shadow: var(--cf3-sh-md);
  border-top: 3px solid var(--cf3-accent);
  transform: translateY(160%); transition: transform .4s cubic-bezier(.7,0,.2,1);
}
.cf3-cookie.is-show { transform: translateY(0); }
.cf3-cookie p { font-size:.9rem; color: var(--cf3-muted-dk); margin-bottom:1rem; }
.cf3-cookie__row { display:flex; gap:.7rem; }
.cf3-cookie .cf3-btn { padding:.65rem 1.1rem; font-size:.74rem; }

/* ═══════════════════════════════════════════════
   ANIM (reveal on scroll)
═══════════════════════════════════════════════ */
.cf3-reveal { opacity:0; transform: translateY(26px); transition: opacity .7s ease, transform .7s ease; }
.cf3-reveal.is-in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce) {
  .cf3-reveal { opacity:1; transform:none; transition:none; }
  html { scroll-behavior:auto; }
}

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .cf3-nav, .cf3-header__cta .cf3-lang, .cf3-header__cta .cf3-btn { display:none; }
  .cf3-burger { display:flex; }
  .cf3-hero__grid { grid-template-columns: 1fr; min-height: 0; }
  .cf3-hero__media { min-height: 420px; }
  .cf3-hero__badge { left:auto; right: var(--cf3-gut); bottom: -28px; }
  .cf3-cards { grid-template-columns: repeat(2,1fr); }
  .cf3-steps { grid-template-columns: repeat(2,1fr); gap: 2.5rem 1.5rem; }
  .cf3-statbar__grid { grid-template-columns: repeat(2,1fr); }
  .cf3-statbar__item:nth-child(3) { border-left:none; padding-left:0; }
  .cf3-gallery__item.span-8, .cf3-gallery__item.span-6 { grid-column: span 6; }
  .cf3-footer__top { grid-template-columns: 1fr 1fr; gap:2.5rem; }
}
@media (max-width: 768px) {
  body { font-size: 16px; }
  .cf3-topbar__inner { font-size:.72rem; }
  .cf3-topbar__set .cf3-topbar__hideS { display:none; }
  .cf3-sechead { grid-template-columns: 1fr; gap:1.2rem; }
  .cf3-split, .cf3-contact, .cf3-cta__inner { grid-template-columns: 1fr; }
  .cf3-split--media-first .cf3-split__media { order:0; }
  .cf3-split__media { min-height: 320px; }
  .cf3-row { grid-template-columns: 60px 1fr auto; gap:1rem; }
  .cf3-row__desc { display:none; }
  .cf3-gallery__item.span-8, .cf3-gallery__item.span-6, .cf3-gallery__item.span-4 { grid-column: span 12; }
  .cf3-cta__inner { gap:1.6rem; }
}
@media (max-width: 480px) {
  .cf3-cards, .cf3-steps, .cf3-statbar__grid { grid-template-columns: 1fr; }
  .cf3-statbar__item { border-left:none; padding-left:0; border-top:1px solid var(--cf3-line-dk); }
  .cf3-statbar__item:first-child { border-top:none; }
  .cf3-checks { grid-template-columns: 1fr; }
  .cf3-field--row { grid-template-columns: 1fr; }
  .cf3-cookie { left:12px; right:12px; max-width:none; }
  .cf3-hero__cta { flex-direction:column; align-items:stretch; }
  .cf3-hero__cta .cf3-btn { justify-content:center; }
}
