/* =============================================================
   AÉRO LEVAGE — Feuille de style partagée
   Levage & location d'engins — Paris / Île-de-France
   Charte : rouge #c8102e · crème #f7f4f2 · Anton / Barlow
   Architecture extensible (pages-villes phase 2 réutilisent tout)
   ============================================================= */

/* ----------------------------------------------------------------
   1. TOKENS
   ---------------------------------------------------------------- */
:root{
  /* Couleurs (charte stricte) */
  --red:#c8102e;
  --red-d:#9e0b22;
  --red-l:#e83048;
  --ink:#1a1414;
  --paper:#ffffff;
  --bone:#f7f4f2;
  --line:#e7dede;
  --muted:#8a7f7f;
  --shadow:rgba(200,16,46,.12);

  /* Dérivés utiles */
  --ink-80:rgba(26,20,20,.80);
  --ink-60:rgba(26,20,20,.60);
  --red-soft:rgba(200,16,46,.08);
  --red-soft-2:rgba(200,16,46,.16);

  /* Typo */
  --f-display:'Anton', Impact, sans-serif;
  --f-cond:'Barlow Condensed', system-ui, sans-serif;
  --f-body:'Barlow', system-ui, -apple-system, sans-serif;

  /* Rayons & ombres */
  --r-card:14px;
  --r-btn:9px;
  --r-pill:999px;
  --sh-card:0 10px 30px var(--shadow);
  --sh-card-hover:0 18px 44px rgba(200,16,46,.18);
  --sh-soft:0 4px 14px rgba(26,20,20,.06);

  /* Layout */
  --wrap:1200px;
  --gut:clamp(16px,4vw,28px);
  --header-h:76px;
}

/* ----------------------------------------------------------------
   2. 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(--f-body);
  color:var(--ink);
  background:var(--bone);
  line-height:1.6;
  font-size:17px;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:16px}
:focus-visible{outline:3px solid var(--red-l);outline-offset:2px;border-radius:4px}

/* ----------------------------------------------------------------
   3. LAYOUT HELPERS
   ---------------------------------------------------------------- */
.container{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(48px,7vw,86px)}
.section--bone{background:var(--bone)}
.section--paper{background:var(--paper)}
.section--ink{background:var(--ink);color:var(--paper)}
.section--tight{padding-block:clamp(36px,5vw,56px)}
.text-center{text-align:center}
.nowrap{white-space:nowrap}
.mx-auto{margin-inline:auto}

/* ----------------------------------------------------------------
   4. TYPOGRAPHIE
   ---------------------------------------------------------------- */
.eyebrow{
  font-family:var(--f-cond);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.86rem;
  color:var(--red);
  display:inline-flex;
  align-items:center;
  gap:.55em;
}
.eyebrow::before{
  content:"";width:26px;height:3px;background:var(--red);display:inline-block;border-radius:2px;
}
.eyebrow--center{justify-content:center}
.section--ink .eyebrow{color:var(--red-l)}
.section--ink .eyebrow::before{background:var(--red-l)}

.hero-title{
  font-family:var(--f-display);
  font-weight:400;
  line-height:1.26;
  letter-spacing:.005em;
  text-transform:uppercase;
  font-size:clamp(2.5rem,6.4vw,5rem);
  margin-top:.12em; /* dégage les accents (Î, À) du label au-dessus */
}
.section-title{
  font-family:var(--f-display);
  font-weight:400;
  line-height:1.02;
  text-transform:uppercase;
  letter-spacing:.005em;
  font-size:clamp(1.85rem,4vw,3rem);
}
.section-title .accent,.hero-title .accent{color:var(--red)}
.section-sub{
  font-family:var(--f-body);
  color:var(--ink-60);
  font-size:clamp(1.02rem,1.6vw,1.18rem);
  max-width:62ch;
  margin-top:.7rem;
}
.section--ink .section-sub{color:rgba(255,255,255,.72)}
.section-head{margin-bottom:clamp(28px,4vw,46px)}
.section-head--center{text-align:center;margin-inline:auto}
.section-head--center .section-sub{margin-inline:auto}

h3{font-family:var(--f-cond);font-weight:600;line-height:1.1;font-size:1.32rem}
.lead{font-size:1.12rem;color:var(--ink-80)}
p+p{margin-top:1em}

/* ----------------------------------------------------------------
   5. BOUTONS
   ---------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  font-size:1.02rem;line-height:1;
  padding:.92em 1.5em;border-radius:var(--r-btn);
  transition:transform .15s ease, background .15s ease, box-shadow .15s ease, color .15s ease;
  white-space:nowrap;cursor:pointer;text-align:center;
}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}

.btn-primary{background:var(--red);color:#fff;box-shadow:0 8px 20px var(--shadow)}
.btn-primary:hover{background:var(--red-d);box-shadow:var(--sh-card-hover)}

.btn-outline{background:transparent;color:var(--ink);border:2px solid var(--ink);padding:calc(.92em - 2px) calc(1.5em - 2px)}
.btn-outline:hover{background:var(--ink);color:#fff}

.btn-outline-red{background:#fff;color:var(--red);border:2px solid var(--red);padding:calc(.92em - 2px) calc(1.5em - 2px)}
.btn-outline-red:hover{background:var(--red);color:#fff}

.btn-white{background:#fff;color:var(--red)}
.btn-white:hover{background:var(--bone);color:var(--red-d)}

.btn-ghost-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6);padding:calc(.92em - 2px) calc(1.5em - 2px)}
.btn-ghost-white:hover{background:#fff;color:var(--red)}

.btn-lg{font-size:1.15rem;padding:1.05em 1.8em}
.btn-block{display:flex;width:100%}

/* ----------------------------------------------------------------
   6. HEADER (Flux A) — blanc, bordure rouge, bande diagonale
   ---------------------------------------------------------------- */
.stripe{
  height:8px;width:100%;
  background:repeating-linear-gradient(135deg,var(--red) 0 14px,#fff 14px 28px);
}
.site-header{
  position:sticky;top:0;z-index:60;
  background:var(--paper);
  border-bottom:4px solid var(--red);
  box-shadow:0 2px 0 rgba(0,0,0,0);
  transition:box-shadow .2s ease;
}
.site-header.scrolled{box-shadow:0 10px 26px rgba(26,20,20,.10)}
.header-inner{
  display:flex;align-items:center;gap:18px;
  min-height:var(--header-h);
  padding-block:8px;
}
.brand{display:flex;align-items:center;gap:.7rem;flex:none}
.brand img{height:96px;width:auto}
.brand .brand-fallback{
  font-family:var(--f-display);text-transform:uppercase;font-size:1.4rem;
  color:var(--ink);line-height:.9;letter-spacing:.01em;
}
.brand .brand-fallback b{color:var(--red);display:block}

.main-nav{margin-left:auto}
.main-nav ul{display:flex;align-items:center;gap:clamp(10px,1.6vw,26px)}
.main-nav a{
  font-family:var(--f-cond);font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;font-size:1rem;color:var(--ink);
  padding:.35em 0;position:relative;transition:color .15s ease;
}
.main-nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:3px;
  background:var(--red);transition:right .2s ease;border-radius:2px;
}
.main-nav a:hover{color:var(--red)}
.main-nav a:hover::after,.main-nav a.is-active::after{right:0}
.main-nav a.is-active{color:var(--red)}

.header-actions{display:flex;align-items:center;gap:14px;flex:none}

/* Téléphone permanent — élément le plus important */
.phone-cta{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.4rem .8rem .4rem .55rem;border-radius:var(--r-btn);
  background:var(--red-soft);border:1px solid var(--red-soft-2);
  transition:background .15s ease,transform .15s ease;
}
.phone-cta:hover{background:var(--red-soft-2);transform:translateY(-1px)}
.phone-cta .ico{
  width:38px;height:38px;flex:none;border-radius:50%;
  background:var(--red);color:#fff;display:grid;place-items:center;
}
.phone-cta .ico svg{width:19px;height:19px}
.phone-cta .meta{display:flex;flex-direction:column;line-height:1.05}
.phone-cta .num{font-family:var(--f-cond);font-weight:700;font-size:1.28rem;color:var(--ink);letter-spacing:.01em}
.phone-cta .note{font-size:.72rem;color:var(--red);font-weight:600;text-transform:uppercase;letter-spacing:.04em}

/* Hamburger */
.nav-toggle{
  display:none;width:46px;height:46px;border-radius:10px;
  border:2px solid var(--line);background:#fff;
  flex-direction:column;gap:5px;align-items:center;justify-content:center;
}
.nav-toggle span{display:block;width:22px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ----------------------------------------------------------------
   7. HERO (accueil)
   ---------------------------------------------------------------- */
.hero{
  position:relative;overflow:hidden;
  /* Hauteur du panneau diagonal = hauteur du hero visible (≈ viewport − header),
     bornée pour ne jamais dépasser le bloc texte. Évite que la photo portrait
     s'étire sur toute la hauteur du hero et oblige à scroller. */
  --hero-panel-h:clamp(420px,calc(100svh - 124px),860px);
  background:
    radial-gradient(1200px 540px at 88% -10%,var(--red-soft) 0,transparent 60%),
    var(--paper);
  border-bottom:1px solid var(--line);
}
/* Photo matériel en fond du panneau rouge (desktop). Même géométrie que la
   découpe diagonale → l'image remplit toute la zone oblique, y compris dessous. */
.hero-photo{
  content:"";position:absolute;top:0;right:0;width:46%;height:var(--hero-panel-h);z-index:0;
  clip-path:polygon(28% 0,100% 0,100% 100%,0 100%);
  overflow:hidden;pointer-events:none;
}
/* grayscale = on neutralise le bleu (grue + ciel) pour éviter le mauve sous le
   voile rouge → bichromie rouge homogène. Cadrage ~centre (un poil vers le haut)
   pour garder la flèche qui monte + les toits parisiens + la Tour Eiffel en fond. */
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 45%;filter:grayscale(100%);display:block}
/* Voile rouge marque par-dessus la photo : opaque côté diagonale (raccord avec
   le texte) → quasi transparent à droite pour garder le camion bien visible. */
.hero::after{
  content:"";position:absolute;top:0;right:0;width:46%;height:var(--hero-panel-h);
  background:
    linear-gradient(100deg,
      rgba(200,16,46,.64) 0%,
      rgba(200,16,46,.46) 40%,
      rgba(200,16,46,.13) 100%);
  clip-path:polygon(28% 0,100% 0,100% 100%,0 100%);
  z-index:1;pointer-events:none;
}
.hero::before{
  content:"";position:absolute;top:0;right:0;width:46%;height:var(--hero-panel-h);z-index:2;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.07) 0 18px,transparent 18px 36px);
  clip-path:polygon(28% 0,100% 0,100% 100%,0 100%);pointer-events:none;
}
.hero-inner{position:relative;z-index:3;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;padding-block:clamp(48px,7vw,92px)}
.hero-copy{max-width:38ch}
.hero-title{margin:.55rem 0 1rem}
.hero-sub{font-size:clamp(1.05rem,1.7vw,1.25rem);color:var(--ink-80);max-width:46ch}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.8rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:18px;margin-top:1.7rem;color:var(--ink-60);font-size:.95rem}
.hero-trust span{display:inline-flex;align-items:center;gap:.45em}
.hero-trust svg{width:18px;height:18px;color:var(--red)}
.hero-visual{position:relative;z-index:3;align-self:stretch;display:grid;place-items:start center;min-height:240px;padding-top:clamp(10px,3vw,30px)}
.hero-badge{
  background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-card);
  padding:22px 26px;text-align:center;border:1px solid var(--line);
  transform:rotate(-2deg);
}
.hero-badge .big{font-family:var(--f-display);font-size:3.4rem;color:var(--red);line-height:.9}
.hero-badge .lbl{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.08em;color:var(--ink);font-weight:600}

/* ----------------------------------------------------------------
   7B. TRUST BAR (références clients — « Ils nous font confiance »)
   Bandeau pleine largeur sous le hero. Fond blanc (les PNG des logos
   sont sur fond blanc → fondu invisible), logos en couleur d'origine,
   hauteurs calées à l'œil pour un poids visuel homogène sur la ligne.
   ---------------------------------------------------------------- */
.trust-bar{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  padding-block:clamp(2.1rem,4vw,2.9rem);
}
.trust-bar__label{
  font-family:var(--f-cond);font-weight:600;
  text-transform:uppercase;letter-spacing:.16em;
  font-size:.82rem;color:var(--muted);
  text-align:center;margin-bottom:1.5rem;
}
/* Marquee : fenêtre pleine largeur, masque les débords + fondu sur les bords G/D */
.trust-bar__marquee{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 9%,#000 91%,transparent 100%);
          mask-image:linear-gradient(to right,transparent 0,#000 9%,#000 91%,transparent 100%);
}
/* Piste : 3 séries de logos côte à côte, défilement continu droite → gauche */
.trust-bar__track{
  list-style:none;margin:0;padding:0;
  display:flex;align-items:center;width:max-content;
  animation:trust-scroll 35s linear infinite;
  will-change:transform;
}
.trust-bar__track li{flex:0 0 auto;display:flex;align-items:center;margin-inline:clamp(1.1rem,2.2vw,2rem)}
/* Pause au survol */
.trust-bar__marquee:hover .trust-bar__track{animation-play-state:paused}
/* Boucle sans couture : −1/3 de la piste = exactement une série sur trois */
@keyframes trust-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-100% / 3))}
}
/* Hauteur optique commune (+~30 % vs version précédente) ; couleur d'origine (pas de gris) */
.trust-logo{height:55px;width:auto;opacity:.9;transition:opacity .2s ease}
.trust-logo:hover{opacity:1}
/* Ajustements fins par logo (proportions relatives conservées, Chambord le plus grand) */
.trust-logo--spie{height:44px}
.trust-logo--kuhne{height:52px}
.trust-logo--chambord{height:65px}
.trust-logo--paris2024{height:57px}

@media (max-width:768px){
  .trust-logo{height:39px}
  .trust-logo--spie{height:31px}
  .trust-logo--kuhne{height:38px}
  .trust-logo--chambord{height:47px}
  .trust-logo--paris2024{height:42px}
}

/* Accessibilité : si l'utilisateur réduit les animations → défilement figé, logos centrés */
@media (prefers-reduced-motion:reduce){
  .trust-bar__marquee{overflow:visible;-webkit-mask-image:none;mask-image:none}
  .trust-bar__track{animation:none;width:auto;flex-wrap:wrap;justify-content:center;row-gap:1.4rem}
  .trust-bar__track li[aria-hidden="true"]{display:none}
}

/* ----------------------------------------------------------------
   8. PAGE-HERO (pages internes + base pages-villes)
   ---------------------------------------------------------------- */
.page-hero{
  position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(135deg,var(--ink) 0%,#2a1f1f 100%);
  border-bottom:4px solid var(--red);
}
.page-hero::after{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,rgba(200,16,46,.18) 0 16px,transparent 16px 40px);
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1;padding-block:clamp(40px,6vw,72px)}
.page-hero .eyebrow{color:var(--red-l)}
.page-hero .eyebrow::before{background:var(--red-l)}
.page-hero h1{font-family:var(--f-display);text-transform:uppercase;line-height:1;font-size:clamp(2.1rem,5vw,3.6rem);margin:.5rem 0 .7rem}
.page-hero p{color:rgba(255,255,255,.78);max-width:64ch;font-size:1.1rem}
.page-hero .hero-ctas{margin-top:1.5rem}

/* ----------------------------------------------------------------
   9. AIGUILLAGE particulier / pro
   ---------------------------------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.split-card{
  position:relative;overflow:hidden;
  border-radius:var(--r-card);padding:30px 30px 28px;
  background:#fff;border:1px solid var(--line);box-shadow:var(--sh-card);
  transition:transform .18s ease,box-shadow .18s ease;
  display:flex;flex-direction:column;
}
.split-card:hover{transform:translateY(-4px);box-shadow:var(--sh-card-hover)}
.split-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:6px;background:var(--red)}
.split-card--pro{background:linear-gradient(135deg,var(--ink) 0,#2a1f1f 100%);color:#fff;border-color:var(--ink)}
.split-card--pro::before{background:var(--red-l)}
.split-icon{width:58px;height:58px;border-radius:14px;display:grid;place-items:center;background:var(--red-soft);color:var(--red);margin-bottom:16px}
.split-card--pro .split-icon{background:rgba(232,48,72,.18);color:var(--red-l)}
.split-icon svg{width:30px;height:30px}
.split-card h3{font-size:1.55rem;margin-bottom:.35rem}
.split-tag{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:.82rem;color:var(--red)}
.split-card--pro .split-tag{color:var(--red-l)}
.split-card p{margin:.5rem 0 1rem;color:var(--ink-80)}
.split-card--pro p{color:rgba(255,255,255,.76)}
.split-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1.3rem}
.split-list li{font-family:var(--f-cond);font-weight:600;font-size:.92rem;background:var(--bone);border:1px solid var(--line);color:var(--ink);padding:.3em .7em;border-radius:var(--r-pill)}
.split-card--pro .split-list li{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);color:#fff}
.split-card .btn{margin-top:auto}

/* ----------------------------------------------------------------
   10. STATS BAND
   ---------------------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat{padding:18px 10px;border-radius:var(--r-card);background:#fff;border:1px solid var(--line)}
.section--ink .stat{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}
.stat-num{font-family:var(--f-display);font-size:clamp(2rem,4vw,2.9rem);color:var(--red);line-height:.95}
.section--ink .stat-num{color:var(--red-l)}
.stat-label{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--ink-80);font-size:.92rem;margin-top:.25rem}
.section--ink .stat-label{color:rgba(255,255,255,.74)}
/* Compteur "zone d'intervention" : titre à la même taille que les autres compteurs,
   sous-texte plus petit juste en dessous (tient sur une ligne, pas de débordement) */
.stat--area .stat-num{font-size:clamp(2rem,4vw,2.9rem);line-height:1.02;white-space:nowrap}
.stat--area .stat-label{font-size:.8rem;letter-spacing:.03em;line-height:1.2;margin-top:.35rem}
/* Petite accroche commerciale sous un compteur */
.stat-note{font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;color:var(--red);margin-top:.35rem}
.section--ink .stat-note{color:var(--red-l)}
/* Compteur cliquable (devis) : lien, même gabarit */
.stat-link{text-decoration:none;color:inherit;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease,border-color .15s ease}
.stat-link:hover{transform:translateY(-2px)}
/* Variante "bouton" : couleurs inversées (fond rouge + texte blanc) pour ressortir comme un CTA */
.stat--cta{background:var(--red);border-color:var(--red)}
.stat--cta .stat-num{color:#fff}
.stat--cta .stat-label{color:rgba(255,255,255,.92)}
.stat--cta:hover{background:var(--red-d);border-color:var(--red-d);box-shadow:0 10px 24px rgba(200,16,46,.30)}

/* ----------------------------------------------------------------
   11. SERVICES GRID
   ---------------------------------------------------------------- */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cards-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.service-card{
  display:flex;flex-direction:column;gap:.5rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:26px 24px;box-shadow:var(--sh-card);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--sh-card-hover);border-color:var(--red-soft-2)}
.service-icon{width:56px;height:56px;border-radius:13px;background:var(--red-soft);color:var(--red);display:grid;place-items:center;margin-bottom:.4rem}
.service-icon svg{width:30px;height:30px}
.service-card h3{font-size:1.3rem}
.service-card p{color:var(--ink-60);font-size:.98rem}
.service-card .more{margin-top:auto;padding-top:.7rem;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--red);font-size:.92rem;display:inline-flex;align-items:center;gap:.4em}
.service-card .more svg{width:1em;height:1em;transition:transform .15s ease}
.service-card:hover .more svg{transform:translateX(3px)}
/* Carte mise en avant : fond légèrement teinté rouge (charte rouge/blanc) */
.service-card--accent{background:var(--red-soft);border-color:var(--red-soft-2)}
.service-card--accent .service-icon{background:#fff}
.service-card--accent:hover{border-color:var(--red)}

/* ----------------------------------------------------------------
   12. BANDEAU RÉASSURANCE
   ---------------------------------------------------------------- */
.reassure{background:var(--ink);color:#fff}
.reassure .container{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;padding-block:22px}
.reassure-item{display:flex;align-items:center;gap:.7rem;font-family:var(--f-cond);font-weight:600;font-size:1.04rem;text-transform:uppercase;letter-spacing:.03em}
.reassure-item svg{width:26px;height:26px;color:var(--red-l);flex:none}

/* ----------------------------------------------------------------
   13. WHY / FEATURES
   ---------------------------------------------------------------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.why-item{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);padding:26px 22px;box-shadow:var(--sh-card)}
.why-num{font-family:var(--f-display);font-size:2.4rem;color:var(--red-soft-2);line-height:1;margin-bottom:.2rem;-webkit-text-stroke:1px var(--red);color:transparent}
.why-item h3{font-size:1.22rem;margin-bottom:.35rem}
.why-item p{color:var(--ink-60);font-size:.97rem}

/* ----------------------------------------------------------------
   14. TÉMOIGNAGES
   ---------------------------------------------------------------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:26px 24px;box-shadow:var(--sh-card);display:flex;flex-direction:column;gap:.9rem;
}
.testi-card.is-featured{border-color:var(--red-soft-2);box-shadow:var(--sh-card-hover)}
.stars{display:inline-flex;gap:2px;color:#FBBC04}
.stars svg{width:18px;height:18px}
.testi-quote{font-size:1.04rem;color:var(--ink);font-style:normal;line-height:1.55}
.testi-quote::before{content:"\201C";font-family:var(--f-display);color:var(--red-soft-2);font-size:2.2rem;line-height:0;vertical-align:-.35em;margin-right:.1em}
.testi-author{display:flex;align-items:center;gap:.8rem;margin-top:auto}
.testi-avatar{width:46px;height:46px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-family:var(--f-display);font-size:1.2rem;flex:none}
.testi-name{display:block;font-family:var(--f-cond);font-weight:700;font-size:1.05rem;line-height:1.2}
.testi-role{font-size:.86rem;color:var(--muted)}
.testi-role .tag-part{color:var(--red);font-weight:700}
.testi-role .tag-pro{color:var(--ink);font-weight:700}
/* Mention "Avis Google vérifié" + logo G multicolore sous le nom */
.testi-google{display:flex;align-items:center;gap:.4em;margin-top:.4rem;font-size:.84rem;color:var(--muted);font-family:var(--f-body)}
.testi-google .g-logo{width:1em;height:1em;flex:none}

/* Témoignage inline près d'un CTA */
.testi-inline{
  display:flex;align-items:center;gap:1rem;max-width:560px;margin-inline:auto;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r-card);padding:14px 18px;text-align:left;
}
.testi-inline .testi-avatar{background:#fff;color:var(--red)}
.testi-inline p{font-size:.98rem;line-height:1.4}
.testi-inline .who{font-family:var(--f-cond);font-weight:700;font-size:.9rem;opacity:.85;margin-top:.2rem}
.testi-inline .testi-google{color:#fff;opacity:.85;margin-top:.3rem}

/* Section vidéo — cadre paysage 16:9 (largeur maxi confortable), grille extensible (plusieurs vidéos à terme) */
.video-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px}
.video-card{margin:0;width:100%;max-width:900px}
.video-frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--r-card);overflow:hidden;box-shadow:var(--sh-card);background:#000}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}

/* ----------------------------------------------------------------
   15. ZONE D'INTERVENTION
   ---------------------------------------------------------------- */
.zone-wrap{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
/* Évite que l'accent du "Î" du titre chevauche le label "Zone d'intervention" */
.zone-wrap .section-title{margin-top:.42em}
.zone-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.2rem}
.zone-chip{
  display:inline-flex;align-items:center;gap:.45em;
  font-family:var(--f-cond);font-weight:600;font-size:1rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);
  padding:.5em 1em;box-shadow:var(--sh-soft);transition:transform .15s ease,border-color .15s ease;
}
.zone-chip:hover{transform:translateY(-2px);border-color:var(--red-soft-2)}
.zone-chip b{color:var(--red);font-family:var(--f-body);font-weight:700;font-size:.85em}
.zone-map{
  background:linear-gradient(135deg,var(--ink) 0,#2a1f1f 100%);
  border-radius:var(--r-card);min-height:280px;position:relative;overflow:hidden;
  display:grid;place-items:center;color:#fff;text-align:center;padding:30px;
  border:1px solid var(--line);
}
.zone-map::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(200,16,46,.16) 0 14px,transparent 14px 34px)}
.zone-map .pin{position:relative;z-index:1}
.zone-map .pin .big{font-family:var(--f-display);font-size:2.6rem;color:var(--red-l);line-height:1}
.zone-map .pin .sub{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.08em;margin-top:1.15rem;font-size:.95rem;color:rgba(255,255,255,.82)}
/* Logos régions (Île-de-France + PACA) sur pastilles blanches, sur fond foncé */
.zone-logos{display:flex;justify-content:center;align-items:center;gap:20px;flex-wrap:wrap}
.zone-logo{background:#fff;border-radius:14px;padding:14px;display:grid;place-items:center;box-shadow:0 8px 20px rgba(0,0,0,.28)}
.zone-logo img{width:96px;height:96px;object-fit:contain;display:block}

/* ----------------------------------------------------------------
   16. CTA BAND (pleine largeur rouge)
   ---------------------------------------------------------------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--red) 0,var(--red-d) 100%);color:#fff;text-align:center}
.cta-band::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 16px,transparent 16px 38px);pointer-events:none}
.cta-band .container{position:relative;z-index:1;padding-block:clamp(40px,6vw,68px)}
.cta-band h2{font-family:var(--f-display);text-transform:uppercase;font-size:clamp(1.9rem,4vw,3.1rem);line-height:1.02}
.cta-band p{color:rgba(255,255,255,.88);max-width:60ch;margin:.7rem auto 0;font-size:1.1rem}
.cta-band .cta-actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:1.6rem}
.cta-band .phone-inline{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--f-display);font-size:clamp(1.6rem,3.4vw,2.4rem);color:#fff;line-height:1;
}
.cta-band .phone-inline svg{width:.9em;height:.9em}
.cta-band .phone-inline:hover{color:var(--bone)}
.cta-band .testi-inline{margin-top:1.8rem}

/* ----------------------------------------------------------------
   17. FORMULAIRE
   ---------------------------------------------------------------- */
.form-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--sh-card);padding:clamp(22px,3vw,34px)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:.35rem}
.form-group.full{grid-column:1 / -1}
.form-group label{font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:.86rem;color:var(--ink)}
.form-group label .req{color:var(--red)}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:.78em .9em;border:1.5px solid var(--line);border-radius:10px;
  background:var(--bone);color:var(--ink);transition:border-color .15s ease,background .15s ease,box-shadow .15s ease;
}
.form-group textarea{resize:vertical;min-height:110px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 3px var(--red-soft);
}
.form-actions{margin-top:1.2rem;display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.form-note{font-size:.86rem;color:var(--muted);margin-top:.8rem}
.form-note a{color:var(--red);font-weight:600}

/* ----------------------------------------------------------------
   18. CONTACT / BLOCS INFO
   ---------------------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:start}
.info-list{display:flex;flex-direction:column;gap:14px}
.info-item{display:flex;gap:.9rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r-card);padding:18px 20px;box-shadow:var(--sh-soft)}
.info-item .ico{width:46px;height:46px;border-radius:12px;background:var(--red-soft);color:var(--red);display:grid;place-items:center;flex:none}
.info-item .ico svg{width:22px;height:22px}
.info-item .k{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:.82rem;color:var(--muted)}
.info-item .v{font-size:1.12rem;font-weight:600;color:var(--ink)}
.info-item .v a:hover{color:var(--red)}

/* Téléphone géant (contact / landing) */
.phone-giant{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--f-display);font-size:clamp(2rem,6vw,3.4rem);color:var(--red);line-height:1;
}
.phone-giant svg{width:.85em;height:.85em}
.phone-giant:hover{color:var(--red-d)}
.phone-giant-wrap{text-align:center}
.phone-giant-wrap .note{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--ink-60);margin-top:.4rem}

/* ----------------------------------------------------------------
   19. SERVICE DETAIL (services.html)
   ---------------------------------------------------------------- */
.svc-block{scroll-margin-top:calc(var(--header-h) + 20px);padding-block:clamp(36px,5vw,60px);border-bottom:1px solid var(--line)}
.svc-block:last-of-type{border-bottom:none}
.svc-inner{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.svc-block:nth-child(even) .svc-media{order:-1}
.svc-media{
  background:linear-gradient(135deg,var(--bone) 0,#fff 100%);
  border:1px solid var(--line);border-radius:var(--r-card);min-height:260px;
  display:grid;place-items:center;box-shadow:var(--sh-card);position:relative;overflow:hidden;
}
.svc-media::before{content:"";position:absolute;top:0;left:0;width:100%;height:6px;background:var(--red)}
.svc-media .glyph{width:120px;height:120px;color:var(--red);opacity:.92}
.svc-media .glyph svg{width:100%;height:100%}
.svc-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
/* Carte nacelle : source en portrait → cadre forcé en 3:2 (cohérent avec les autres). L'image est
   positionnée en absolu pour remplir exactement le cadre : object-position contrôle alors vraiment
   le recadrage (sinon place-items:center recentrait l'image quelle que soit la valeur). Cadrage
   décalé vers le bas pour montrer le panier de la nacelle au premier plan. Ciblé #nacelle : ni la
   règle globale .svc-media img ni les 5 autres cartes ne sont touchées. min-height:0 évite le
   débordement horizontal en mobile (aspect-ratio + min-height:260 élargirait la carte). */
#nacelle .svc-media{aspect-ratio:3/2;min-height:0}
#nacelle .svc-media img{position:absolute;inset:0;object-position:center 46%}
.svc-audience{display:inline-flex;gap:8px;margin:.4rem 0 1rem;flex-wrap:wrap}
.aud-tag{font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;padding:.32em .8em;border-radius:var(--r-pill)}
.aud-part{background:var(--red-soft);color:var(--red);border:1px solid var(--red-soft-2)}
.aud-pro{background:var(--ink);color:#fff}
.svc-list{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0 1.4rem}
.svc-list li{display:flex;gap:.6em;align-items:flex-start;color:var(--ink-80)}
.svc-list li svg{width:20px;height:20px;color:var(--red);flex:none;margin-top:.2em}
.svc-actions{display:flex;flex-wrap:wrap;gap:12px}

/* ----------------------------------------------------------------
   20. MATÉRIEL (materiel.html)
   ---------------------------------------------------------------- */
.spec-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden;box-shadow:var(--sh-card);transition:transform .18s ease,box-shadow .18s ease}
.spec-card:hover{transform:translateY(-4px);box-shadow:var(--sh-card-hover)}
.spec-media{position:relative;background:linear-gradient(135deg,var(--ink) 0,#2a1f1f 100%);min-height:170px;display:grid;place-items:center;color:var(--red-l)}
.spec-media::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(200,16,46,.16) 0 14px,transparent 14px 32px)}
.spec-body{padding:22px 22px 24px}
.spec-body h4{font-family:var(--f-cond);font-weight:600;line-height:1.1;font-size:1.32rem;margin-bottom:.5rem}
.spec-table{width:100%;border-collapse:collapse;margin:.4rem 0 1rem}
.spec-table th,.spec-table td{text-align:left;padding:.45em 0;border-bottom:1px dashed var(--line);font-size:.95rem;vertical-align:top}
.spec-table th{font-family:var(--f-cond);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:.82rem;width:46%}
.spec-table td{color:var(--ink);font-weight:600}
.spec-use{color:var(--ink-60);font-size:.95rem}

/* Photos réelles des engins (1600×1200, fond blanc, logo intégré) :
   zone média blanche, hauteur cohérente d'une carte à l'autre (ratio 4:3),
   object-fit:contain pour ne jamais rogner la machine ni le logo */
.spec-media:has(.spec-photo){background:#fff;min-height:0;border-bottom:1px solid var(--line)}
.spec-media:has(.spec-photo)::after{display:none}
.spec-photo{display:block;width:100%;height:auto;aspect-ratio:4 / 3;object-fit:contain;background:#fff}

/* Intertitre de catégorie dans la grille parc — span pleine largeur de la grille */
.spec-cat{grid-column:1 / -1;margin-top:.7rem;padding-bottom:.45rem;border-bottom:2px solid var(--red-soft-2);font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.07em;font-size:1.2rem;color:var(--ink)}
.spec-cat:first-child{margin-top:0}
.spec-cat span{margin-left:.5em;text-transform:none;letter-spacing:.01em;font-weight:600;font-size:.8rem;color:var(--muted)}

/* ----------------------------------------------------------------
   21. RÉALISATIONS / CHANTIERS TYPES
   ---------------------------------------------------------------- */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.case-card{display:flex;gap:1rem;background:#fff;border:1px solid var(--line);border-radius:var(--r-card);padding:24px;box-shadow:var(--sh-card)}
.case-card .ico{width:54px;height:54px;border-radius:13px;background:var(--red-soft);color:var(--red);display:grid;place-items:center;flex:none}
.case-card .ico svg{width:28px;height:28px}
.case-card h3{font-size:1.2rem;margin-bottom:.3rem}
.case-card p{color:var(--ink-60);font-size:.96rem}
.case-tag{display:inline-block;margin-top:.6rem;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;color:var(--red)}

/* ----------------------------------------------------------------
   22. FOOTER
   ---------------------------------------------------------------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.74);padding-top:clamp(40px,6vw,64px)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img{height:56px;width:auto;background:#fff;border-radius:10px;padding:6px 10px}
.footer-brand .brand-fallback{font-family:var(--f-display);text-transform:uppercase;font-size:1.5rem;color:#fff;line-height:.9}
.footer-brand .brand-fallback b{color:var(--red-l);display:block}
.footer-brand p{margin-top:1rem;font-size:.95rem;max-width:34ch}
.footer-brand .tagline{font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--red-l);margin-top:.8rem}
.footer-col h4{font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.06em;color:#fff;font-size:1.02rem;margin-bottom:1rem;font-weight:600}
.footer-col ul{display:flex;flex-direction:column;gap:.6rem}
.footer-col a{font-size:.96rem;transition:color .15s ease}
.footer-col a:hover{color:#fff}
.footer-contact li{display:flex;gap:.6em;align-items:flex-start;font-size:.96rem;margin-bottom:.7rem}
.footer-contact svg{width:18px;height:18px;color:var(--red-l);flex:none;margin-top:.2em}
.footer-contact a{color:#fff;font-weight:600}
.footer-phone{font-family:var(--f-display);font-size:1.5rem;color:#fff!important}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding-block:20px;font-size:.86rem;color:rgba(255,255,255,.55)}
.footer-bottom a:hover{color:#fff}
.footer-bottom .legal-links{display:flex;gap:16px;flex-wrap:wrap}

/* ----------------------------------------------------------------
   23. BARRE CTA MOBILE FIXE (conversion)
   ---------------------------------------------------------------- */
.mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  display:none;grid-template-columns:1fr 1fr;gap:0;
  background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(26,20,20,.12);
}
.mobile-cta a{
  display:flex;align-items:center;justify-content:center;gap:.5em;
  padding:.95em 1em;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.03em;font-size:1.02rem;
}
.mobile-cta a svg{width:1.2em;height:1.2em}
.mobile-cta .m-call{background:var(--red);color:#fff}
.mobile-cta .m-quote{background:var(--ink);color:#fff}

/* ----------------------------------------------------------------
   24. LANDING PAGES (Flux B) — minimal, objectif unique
   ---------------------------------------------------------------- */
.lp-header{
  position:sticky;top:0;z-index:60;background:#fff;
  border-bottom:4px solid var(--red);
}
.lp-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:68px;padding-block:8px}
.lp-header .brand img{height:84px}
.lp-phone-top{display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-display);font-size:clamp(1.2rem,4.5vw,1.7rem);color:var(--red);line-height:1}
.lp-phone-top svg{width:.85em;height:.85em}
.lp-phone-top:hover{color:var(--red-d)}

.lp-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--ink) 0,#2a1f1f 100%);color:#fff}
.lp-hero::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(200,16,46,.18) 0 16px,transparent 16px 40px);pointer-events:none}
.lp-hero .container{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center;padding-block:clamp(36px,5vw,64px)}
.lp-hero .eyebrow{color:var(--red-l)}
.lp-hero .eyebrow::before{background:var(--red-l)}
.lp-hero h1{font-family:var(--f-display);text-transform:uppercase;line-height:1;font-size:clamp(2rem,5vw,3.3rem);margin:.5rem 0 .8rem}
.lp-hero .sub{color:rgba(255,255,255,.82);font-size:1.12rem;max-width:48ch}
.lp-benefits{display:flex;flex-direction:column;gap:14px;margin:1.4rem 0}
.lp-benefit{display:flex;gap:.8rem;align-items:center}
.lp-benefit .ico{width:42px;height:42px;border-radius:11px;background:rgba(232,48,72,.18);color:var(--red-l);display:grid;place-items:center;flex:none}
.lp-benefit .ico svg{width:22px;height:22px}
.lp-benefit b{font-family:var(--f-cond);font-weight:700;font-size:1.08rem}
.lp-benefit span{display:block;color:rgba(255,255,255,.72);font-size:.95rem}
.lp-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:1rem}

.lp-card{background:#fff;color:var(--ink);border-radius:var(--r-card);box-shadow:0 20px 50px rgba(0,0,0,.3);padding:clamp(22px,3vw,30px)}
.lp-card h2{font-family:var(--f-cond);font-weight:700;font-size:1.5rem;line-height:1.05}
.lp-card .card-sub{color:var(--ink-60);margin:.3rem 0 1.1rem;font-size:.98rem}
.lp-card .or{display:flex;align-items:center;gap:12px;margin:1.1rem 0;color:var(--muted);font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.85rem}
.lp-card .or::before,.lp-card .or::after{content:"";height:1px;background:var(--line);flex:1}

.lp-strip{background:var(--red);color:#fff;text-align:center}
.lp-strip .container{padding-block:14px;display:flex;flex-wrap:wrap;justify-content:center;gap:10px 26px}
.lp-strip span{display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.lp-strip svg{width:20px;height:20px}

.lp-footer{background:var(--ink);color:rgba(255,255,255,.6);text-align:center}
.lp-footer .container{padding-block:24px;display:flex;flex-direction:column;gap:.5rem;align-items:center}
.lp-footer a{color:#fff}
.lp-footer .legal{font-size:.82rem;color:rgba(255,255,255,.5)}

/* ----------------------------------------------------------------
   25. ANIMATIONS AU SCROLL (légères)
   ---------------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ----------------------------------------------------------------
   26. RESPONSIVE
   ---------------------------------------------------------------- */
@media (max-width:1024px){
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .hero-inner{grid-template-columns:1.1fr .9fr;gap:28px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .main-nav a{font-size:.95rem}
  .phone-cta .num{font-size:1.15rem}
}

@media (max-width:768px){
  body{font-size:16px}
  /* Header → menu mobile */
  .nav-toggle{display:flex}
  .main-nav{
    position:fixed;inset:var(--header-h) 0 auto 0;margin:0;
    background:#fff;border-bottom:4px solid var(--red);
    transform:translateY(-130%);transition:transform .28s ease;
    box-shadow:0 18px 30px rgba(26,20,20,.14);max-height:calc(100vh - var(--header-h));overflow:auto;
  }
  .main-nav.open{transform:translateY(0)}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:0;padding:8px var(--gut) 16px}
  .main-nav li{border-bottom:1px solid var(--line)}
  .main-nav a{display:block;padding:.95em 0;font-size:1.1rem}
  .main-nav a::after{display:none}
  .header-actions .btn-quote{display:none} /* le devis reste accessible via barre mobile + menu */
  .phone-cta .note{display:none}
  .phone-cta .num{font-size:1.12rem}
  .phone-cta{padding:.35rem .6rem .35rem .4rem}

  /* Hero — pas de photo sur mobile : on retrouve la bande rouge d'origine
     (height/bottom remis à pleine hauteur, le panneau capé du desktop est annulé) */
  .hero-photo{display:none}
  .hero::after{background:linear-gradient(135deg,var(--red) 0%,var(--red-d) 100%)}
  .hero::after,.hero::before{width:100%;height:auto;bottom:0;clip-path:polygon(0 78%,100% 62%,100% 100%,0 100%);opacity:.12}
  .hero-inner{grid-template-columns:1fr;text-align:left;gap:18px}
  .hero-copy{max-width:100%}
  .hero-visual{display:none}

  /* Grilles → 1-2 colonnes */
  .split{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .cards-grid,.cards-grid.cols-2,.testi-grid,.case-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .zone-wrap,.contact-grid,.svc-inner,.lp-hero .container,.form-grid{grid-template-columns:1fr}
  .svc-block:nth-child(even) .svc-media{order:0}
  .reassure .container{justify-content:flex-start;flex-direction:column;align-items:flex-start;gap:12px}

  /* Barre CTA mobile visible + place pour ne pas masquer le footer */
  .mobile-cta{display:grid}
  body{padding-bottom:62px}
  .lp-card{box-shadow:var(--sh-card)}
}

@media (max-width:520px){
  :root{--gut:16px}
  .brand img{height:76px}
  .hero-ctas .btn,.svc-actions .btn,.form-actions .btn{width:100%}
  .hero-ctas,.svc-actions{flex-direction:column}
  .cta-band .cta-actions{flex-direction:column}
  .cta-band .cta-actions .btn{width:100%}
  .footer-grid{grid-template-columns:1fr}
  .stat-num{font-size:2.1rem}
  /* "PARIS, IDF" : fluide sur petit mobile pour rester proche des autres sans déborder */
  .stat--area .stat-num{font-size:clamp(1.6rem,8.5vw,2.1rem)}
  .testi-grid{gap:16px}
}

/* Impression : masquer barres collantes */
@media print{.site-header,.mobile-cta,.lp-header{position:static}.mobile-cta{display:none}}
