/* ============================================================
   NEVES COUVREUR 83 — style.css
   Design épuré inspiré Atrakt : fond blanc, typo bold centrée,
   grands espaces, accents rouge/bleu, animations subtiles.
   Police Inter · Palette bleu #1a5fb4 / rouge #c0392b
   ============================================================ */

/* ── Polices Inter ── */
@font-face { font-family:'Inter'; src:url('../fonts/inter-latin-400-normal.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Inter'; src:url('../fonts/inter-latin-500-normal.woff2') format('woff2'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'Inter'; src:url('../fonts/inter-latin-600-normal.woff2') format('woff2'); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:'Inter'; src:url('../fonts/inter-latin-700-normal.woff2') format('woff2'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'Inter'; src:url('../fonts/inter-latin-800-normal.woff2') format('woff2'); font-weight:800; font-style:normal; font-display:swap; }
@font-face { font-family:'Inter'; src:url('../fonts/inter-latin-900-normal.woff2') format('woff2'); font-weight:900; font-style:normal; font-display:swap; }

/* ── Reset & Variables ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
:root {
    --blue:       #1a5fb4;
    --blue-d:     #0e3d7a;
    --blue-l:     #e8f0fc;
    --red:        #c0392b;
    --red-d:      #a5281b;
    --red-l:      #fdf0ee;
    --white:      #ffffff;
    --light:      #f8f9fb;
    --gray:       #f1f3f5;
    --border:     #e2e5ea;
    --text:       #1a1a2e;
    --text-mid:   #4a5568;
    --muted:      #8492a6;
    --r:          12px;
    --r-sm:       6px;
    --shadow:     0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --shadow-md:  0 4px 16px rgba(0,0,0,.07);
    --shadow-lg:  0 12px 40px rgba(0,0,0,.1);
    --font:       'Inter', system-ui, -apple-system, sans-serif;
    --max:        1180px;
    --transition: .25s cubic-bezier(.4,0,.2,1);
}
html { scroll-behavior:smooth; }
body { font-family:var(--font); color:var(--text); line-height:1.7; background:var(--light); -webkit-font-smoothing:antialiased; padding-top:76px; }
@media(max-width:768px) { body { padding-bottom:0; } }
.container { max-width:var(--max); margin:0 auto; padding:0 1.5rem; }
a { color:var(--blue); text-decoration:none; transition:color var(--transition); }
a:hover { color:var(--red); }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
h1 { font-size:clamp(2rem,4.5vw,3.2rem); font-weight:900; line-height:1.12; letter-spacing:-.03em; color:var(--blue-d); }
h2 { font-size:clamp(1.5rem,3vw,2.4rem); font-weight:800; color:var(--blue-d); line-height:1.15; letter-spacing:-.02em; }
h3 { font-size:1.05rem; font-weight:700; color:var(--blue-d); }
p  { line-height:1.75; color:var(--text-mid); }


/* ============================================================
   BOUTONS
   ============================================================ */
.btn { display:inline-flex; align-items:center; gap:.5rem; padding:.75rem 1.8rem; border-radius:50px; font-weight:600; font-size:.9rem; border:none; cursor:pointer; font-family:var(--font); transition:all var(--transition); white-space:nowrap; text-decoration:none; }
.btn--red     { background:var(--red); color:#fff !important; box-shadow:0 2px 8px rgba(192,57,43,.25); }
.btn--red:hover  { background:var(--red-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(192,57,43,.35); }
.btn--blue    { background:var(--blue); color:#fff !important; box-shadow:0 2px 8px rgba(26,95,180,.25); }
.btn--blue:hover { background:var(--blue-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(26,95,180,.35); }
.btn--outline { background:var(--white); color:var(--blue) !important; border:2px solid var(--blue); }
.btn--outline:hover { background:var(--blue-l); border-color:var(--blue-d); }
.btn--outline .icone { filter:brightness(0) saturate(100%) invert(27%) sepia(83%) saturate(1200%) hue-rotate(197deg) brightness(90%); }
.btn--white   { background:var(--white); color:var(--text) !important; border:2px solid var(--border); }
.btn--white:hover { border-color:var(--blue); color:var(--blue) !important; }
.btn--full    { width:100%; justify-content:center; }
.btn--red .icone,
.btn--blue .icone { filter:brightness(0) invert(1); }


/* ============================================================
   HEADER — Clean, aéré, type Atrakt
   ============================================================ */
.hd { position:fixed; top:0; left:0; right:0; z-index:100; background:rgba(255,255,255,.92); backdrop-filter:blur(16px) saturate(1.8); border-bottom:1px solid var(--border); }
.hd__inner { display:flex; align-items:center; justify-content:space-between; gap:1.5rem; height:76px; }

/* Logo */
.logo { display:inline-flex; align-items:center; flex-shrink:0; }
.logo img  { height:64px; width:auto; }
.logo--ft  { color:#fff !important; }
.logo--img-ft { filter:brightness(0) invert(1); }
@media(max-width:768px) { .logo img { height:64px; } }

/* Nav desktop — centré dans une pilule */
.nav { display:flex; align-items:center; background:var(--light); border:1px solid var(--border); border-radius:50px; padding:.25rem; }
.nav__list { display:flex; align-items:center; gap:.1rem; }
.nav__list > li > a { display:flex; align-items:center; gap:.25rem; padding:.45rem .8rem; border-radius:50px; font-weight:500; font-size:.84rem; color:var(--text-mid); transition:all .2s; letter-spacing:-.01em; }
.nav__list > li > a svg { color:var(--muted); }
.nav__list > li > a:hover { background:var(--white); color:var(--blue); box-shadow:var(--shadow); }
.nav__list > li > a:hover svg { color:var(--blue); }
.nav__dd { position:relative; }
.nav__sub { display:none; position:absolute; top:calc(100% + .5rem); left:50%; transform:translateX(-50%); min-width:240px; background:var(--white); border:1px solid var(--border); border-radius:var(--r); box-shadow:var(--shadow-lg); padding:.5rem; z-index:200; }
.nav__sub::before { content:''; position:absolute; top:-.6rem; left:0; width:100%; height:.6rem; }
.nav__dd:hover .nav__sub { display:block; }
.nav__sub li a { display:block; padding:.5rem 1rem; border-radius:var(--r-sm); font-size:.84rem; color:var(--text-mid); }
.nav__sub li a:hover { background:var(--blue-l); color:var(--blue); }

/* CTA header desktop */
.hd__cta { flex-shrink:0; display:flex; align-items:center; gap:.5rem; }
.hd__cta .btn { border-radius:50px; font-size:.84rem; padding:.55rem 1.4rem; }
.hd__wa {
    display:flex; align-items:center; justify-content:center;
    width:42px; height:42px; border-radius:50%;
    background:#25D366; color:#fff; flex-shrink:0;
    transition:all var(--transition);
    box-shadow:0 2px 8px rgba(37,211,102,.3);
}
.hd__wa:hover { transform:scale(1.08); box-shadow:0 4px 14px rgba(37,211,102,.45); }
.hd__wa svg { width:22px; height:22px; }

/* Éléments mobile dans le menu — masqués sur desktop */
.nav__mobile-cta { display:none; }
.nav__mobile-footer { display:none; }

/* Burger */
.burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:.5rem; z-index:200; }
.burger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:transform .3s, opacity .3s; }
.burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity:0; }
.burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }


/* ============================================================
   FAB — Bouton flottant animé + popup CTA
   Style Atrakt : ring pulse + carte contact au clic
   ============================================================ */
.fab { position:fixed; bottom:24px; right:24px; z-index:95; }
@media(max-width:768px) { .fab { bottom:80px; right:16px; } }

.fab__btn {
    display:flex; align-items:center; justify-content:center;
    width:60px; height:60px; border-radius:50%; border:none; cursor:pointer;
    background:linear-gradient(135deg, var(--red) 0%, #e74c3c 100%);
    color:#fff; position:relative; z-index:2;
    box-shadow:0 4px 20px rgba(192,57,43,.35);
    transition:transform .25s, box-shadow .25s;
}
.fab__btn:hover { transform:scale(1.08); box-shadow:0 6px 28px rgba(192,57,43,.45); }
.fab__btn svg { width:26px; height:26px; fill:#fff; transition:transform .3s; }
.fab.open .fab__btn svg { transform:rotate(135deg); }

/* Ring pulse */
.fab__ring {
    position:absolute; top:50%; left:50%; width:60px; height:60px;
    margin:-30px 0 0 -30px; border-radius:50%; z-index:1;
    border:2px solid var(--red);
    animation:fab-ring 2.5s cubic-bezier(.4,0,.6,1) infinite;
}
.fab__ring:nth-child(2) { animation-delay:.8s; }
@keyframes fab-ring {
    0%   { transform:scale(1); opacity:.6; }
    100% { transform:scale(2.2); opacity:0; }
}

/* Popup card */
.fab__popup {
    position:absolute; bottom:calc(100% + 16px); right:0;
    width:320px; background:var(--white); border-radius:var(--r);
    box-shadow:var(--shadow-lg); border:1px solid var(--border);
    opacity:0; visibility:hidden; transform:translateY(12px) scale(.95);
    transition:all .3s cubic-bezier(.4,0,.2,1);
    overflow:hidden;
}
.fab.open .fab__popup { opacity:1; visibility:visible; transform:translateY(0) scale(1); }

.fab__popup-header {
    display:flex; align-items:center; gap:.75rem;
    padding:1.2rem 1.2rem .8rem; border-bottom:1px solid var(--border);
}
.fab__popup-avatar {
    width:48px; height:48px; border-radius:50%; object-fit:cover;
    border:2px solid var(--blue-l);
}
.fab__popup-name { font-weight:700; font-size:.92rem; color:var(--text); line-height:1.3; }
.fab__popup-role { font-size:.76rem; color:var(--muted); }
.fab__popup-online { display:inline-block; width:8px; height:8px; background:#10b981; border-radius:50%; margin-left:.4rem; vertical-align:middle; }

.fab__popup-body { padding:1rem 1.2rem 1.2rem; }
.fab__popup-msg {
    background:var(--light); border-radius:var(--r) var(--r) var(--r) 4px;
    padding:.8rem 1rem; font-size:.84rem; color:var(--text-mid); line-height:1.6;
    margin-bottom:1rem;
}
.fab__popup-actions { display:flex; flex-direction:column; gap:.5rem; }
.fab__popup-actions .btn { justify-content:center; font-size:.85rem; padding:.7rem 1rem; }

.fab__popup-close {
    position:absolute; top:.6rem; right:.6rem;
    width:28px; height:28px; border:none; background:var(--light);
    border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center;
    color:var(--muted); font-size:1.1rem; transition:background .2s;
}
.fab__popup-close:hover { background:var(--border); }


/* ============================================================
   BARRE MOBILE BOTTOM
   ============================================================ */
.mob-bar { display:none; position:fixed; bottom:0; left:0; right:0; height:64px; z-index:99; transform:translateY(100%); transition:transform .35s ease; background:var(--white); border-top:1px solid var(--border); }
.mob-bar--visible { transform:translateY(0); }
.mob-bar a { display:flex; align-items:center; justify-content:center; gap:.4rem; width:50%; height:100%; font-weight:700; font-size:.88rem; }
.mob-bar__tel   { background:var(--red); color:#fff !important; }
.mob-bar__devis { background:var(--blue); color:#fff !important; }
.mob-bar__tel .icone,
.mob-bar__devis .icone { filter:brightness(0) invert(1); }


/* ============================================================
   HERO — Centré, fond blanc, grande typo (style Atrakt)
   ============================================================ */
.hero { padding:4rem 0 3rem; background:var(--light); text-align:center; overflow:hidden; }
.hero .container { max-width:900px; }

.hero__proof {
    display:inline-flex; align-items:center; gap:.6rem;
    margin-bottom:2rem;
}
.hero__avatars { display:flex; }
.hero__avatars img {
    width:36px; height:36px; border-radius:50%; border:2px solid var(--white);
    margin-left:-8px; object-fit:cover;
}
.hero__avatars img:first-child { margin-left:0; }
.hero__rating { display:flex; flex-direction:column; align-items:flex-start; gap:0; }
.hero__stars  { color:#f59e0b; font-size:1.5rem; letter-spacing:.06em; line-height:1; }
.hero__rating-text { font-size:1rem; color:var(--text-mid); font-weight:600; }
.hero__rating-text strong { color:var(--blue); font-size:1.1rem; }

.hero h1 { margin-bottom:.6rem; }
.hero__company { font-size:clamp(1.4rem,3vw,1.8rem); font-weight:800; color:var(--blue); letter-spacing:.02em; margin-bottom:1rem; text-transform:uppercase; }
.hero h1 .accent {
    color:var(--red); position:relative; display:inline-block;
}
.hero h1 .accent::after {
    content:''; position:absolute; bottom:-.04em; left:-.06em; right:-.06em;
    height:.32em; background:var(--red-l); border-radius:4px; z-index:-1;
}
.hero__sub { font-size:1.1rem; max-width:640px; margin:0 auto 2rem; color:var(--muted); line-height:1.75; }
.hero__btns { display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center; margin-bottom:2.5rem; }

.hero__stats {
    display:inline-flex; gap:2.5rem; padding:1.5rem 2.5rem;
    background:var(--light); border:1px solid var(--border); border-radius:60px;
}
.hero__stats div { text-align:center; }
.hero__stats div strong { display:block; font-size:1.5rem; font-weight:900; color:var(--blue); line-height:1.2; }
.hero__stats div span   { font-size:.72rem; color:var(--muted); font-weight:500; }

.hero__img-wrap {
    max-width:800px; margin:3rem auto 0; position:relative;
    border-radius:var(--r); overflow:hidden;
    box-shadow:var(--shadow-lg);
}
.hero__img-wrap img { width:100%; display:block; }
.hero__img-wrap picture img { border-radius:var(--r); }
.hero__garantie-band {
    display:inline-flex; align-items:center; gap:.8rem;
    background:var(--white); border:1px solid var(--border);
    border-radius:50px; padding:.5rem 1.6rem .5rem .5rem;
    color:var(--text); font-size:1.3rem; font-weight:700;
    margin:1.5rem auto 0; white-space:nowrap;
}
.hero__garantie-logo { height:58px; width:58px; object-fit:contain; flex-shrink:0; border-radius:50%; }


/* ============================================================
   SECTIONS GÉNÉRIQUES
   ============================================================ */
.section { padding:5rem 0; }
.section--light { background:var(--light); }
.section--blue-light { background:var(--blue-l); }
.section--dark  { background:linear-gradient(145deg, var(--blue-d) 0%, var(--blue) 100%); }
.sec-head { text-align:center; margin-bottom:3.5rem; max-width:700px; margin-left:auto; margin-right:auto; }
.sec-head h2 { margin-bottom:.6rem; }
.sec-head p { color:var(--muted); font-size:1rem; }
.sec-head--white h2 { color:#fff; }
.sec-head--white p { color:rgba(255,255,255,.65); }


/* ============================================================
   SILOS — Cartes services
   ============================================================ */
.silos { display:grid; grid-template-columns:repeat(auto-fill, minmax(210px,1fr)); gap:1.2rem; }
.silo-card {
    background:var(--white); border:1px solid var(--border);
    border-radius:var(--r); padding:1.8rem 1.4rem;
    transition:all var(--transition); position:relative; overflow:hidden;
    text-align:center;
}
.silo-card::before {
    content:''; position:absolute; top:0; left:0; right:0; height:3px;
    background:linear-gradient(90deg, var(--blue), var(--red));
    opacity:0; transition:opacity var(--transition);
}
.silo-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.silo-card:hover::before { opacity:1; }
.silo-card__icon {
    display:flex; align-items:center; justify-content:center;
    width:56px; height:56px; margin:0 auto .8rem;
    background:var(--blue-l); border-radius:50%;
}
.silo-card__icon img { width:30px; height:30px; object-fit:contain; }
.silo-card h3 { margin-bottom:.4rem; font-size:.95rem; }
.silo-card p  { font-size:.82rem; color:var(--muted); margin-bottom:.8rem; }
.silo-card a  { color:var(--blue); font-weight:600; font-size:.8rem; }
.silo-card a:hover { color:var(--red); }


/* ============================================================
   CHIFFRES / ENGAGEMENTS
   ============================================================ */
.chiffres { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.chiffre {
    text-align:center; padding:2.5rem 1.5rem;
    background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08);
    border-radius:var(--r);
}
.chiffre strong { display:block; font-size:3rem; font-weight:900; color:#fff; line-height:1; margin-bottom:.5rem; }
.chiffre h3 { color:#fff; margin-bottom:.4rem; font-size:.95rem; }
.chiffre p  { color:rgba(255,255,255,.5); font-size:.84rem; }


/* ============================================================
   CLUSTERS & VILLES
   ============================================================ */
.cluster { margin-bottom:3rem; }
.cluster__title { font-size:1rem; font-weight:700; color:var(--blue); margin-bottom:1rem; padding-bottom:.6rem; border-bottom:2px solid var(--blue-l); }
.cluster--page .cluster__title { font-size:1.2rem; }
.cluster__villes { display:grid; grid-template-columns:repeat(auto-fill, minmax(160px,1fr)); gap:.5rem; }
.cluster-cta { background:var(--light); border-radius:var(--r); padding:2rem; text-align:center; margin-top:3rem; }
.cluster-cta h3 { margin-bottom:.5rem; }
.cluster-cta p  { color:var(--muted); margin-bottom:1.5rem; }

.ville-pill {
    display:flex; align-items:center; justify-content:space-between;
    background:var(--white); border:1px solid var(--border);
    border-radius:50px; padding:.55rem 1rem;
    transition:all var(--transition); color:inherit;
}
.ville-pill:hover { border-color:var(--blue); box-shadow:var(--shadow); color:inherit; transform:translateY(-1px); }
.ville-pill strong { color:var(--blue); font-size:.82rem; }
.ville-pill span   { font-size:.7rem; color:var(--muted); }


/* ============================================================
   CTA FINAL
   ============================================================ */
.cta { background:linear-gradient(145deg, var(--blue-d) 0%, var(--blue) 100%); padding:5rem 0; text-align:center; }
.cta h2 { color:#fff; margin-bottom:.6rem; }
.cta p  { color:rgba(255,255,255,.65); margin-bottom:2rem; }
.cta__phones { display:flex; justify-content:center; gap:1rem; flex-wrap:wrap; margin-top:2rem; }
.cta__phones div { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:50px; padding:.8rem 2rem; text-align:center; }
.cta__phones small { display:block; font-size:.68rem; color:rgba(255,255,255,.4); text-transform:uppercase; margin-bottom:.25rem; }
.cta__phones a { font-size:1.1rem; font-weight:800; color:#fff !important; }


/* ============================================================
   CONTENT GRID (pages services/villes)
   ============================================================ */
.page-hero { background:linear-gradient(145deg, var(--blue-d) 0%, var(--blue) 100%); padding:3.5rem 0 3rem; }
.page-hero__inner { display:grid; grid-template-columns:55% 45%; gap:3rem; align-items:center; }
.breadcrumb { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:1rem; font-size:.8rem; color:rgba(255,255,255,.45); }
.breadcrumb a { color:rgba(255,255,255,.45); }
.breadcrumb a:hover { color:#fff; }
.page-hero h1 { color:#fff; font-size:clamp(1.6rem,3vw,2.2rem); }
.page-hero__desc { color:rgba(255,255,255,.7); max-width:640px; margin:.8rem 0 1rem; }
.page-hero__tags { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.2rem; }
.page-hero__tags span { display:inline-flex; align-items:center; gap:.4rem; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); padding:.25rem .75rem; border-radius:50px; font-size:.76rem; color:#fff; font-weight:600; }
.page-hero__tags .icone { filter:brightness(0) invert(1); }
.page-hero__btns { display:flex; flex-wrap:wrap; gap:.8rem; margin-bottom:1rem; }
.page-hero__img-wrap { position:relative; }
.page-hero__img-wrap > img { width:100%; border-radius:var(--r); box-shadow:var(--shadow-lg); display:block; object-fit:cover; height:320px; }

.content-wrap { padding:4rem 0; }
.content-grid { display:grid; grid-template-columns:1fr 300px; gap:3rem; align-items:start; }
.content-body h2 { margin:2.5rem 0 .8rem; font-size:1.3rem; }
.content-body h2:first-child { margin-top:0; }
.content-body p { margin-bottom:1rem; }
.check-list { padding-left:1.4rem; list-style:disc; margin:.8rem 0 1.4rem; }
.check-list li { padding:.2rem 0; line-height:1.65; color:var(--text-mid); }


/* ============================================================
   GRILLE SERVICES
   ============================================================ */
.srv-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:1rem; margin:1.5rem 0; }
.srv-card {
    display:flex; flex-direction:column; gap:.4rem;
    background:var(--white); border:1px solid var(--border);
    border-radius:var(--r); padding:1.2rem 1.4rem;
    transition:all var(--transition); color:inherit;
}
.srv-card:hover { border-color:var(--blue); transform:translateY(-2px); box-shadow:var(--shadow); color:inherit; }
.srv-card strong { color:var(--blue); font-size:.9rem; }
.srv-card span   { font-size:.82rem; color:var(--muted); }

.pills { display:flex; flex-wrap:wrap; gap:.4rem; margin:.8rem 0 1.4rem; }
.pills a { background:var(--white); border:1px solid var(--border); padding:.3rem .8rem; border-radius:50px; font-size:.8rem; font-weight:500; color:var(--text-mid); transition:all .2s; }
.pills a:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-l); }


/* ============================================================
   FAQ
   ============================================================ */
.faq { max-width:100%; margin:1rem 0; }
.faq__item { background:var(--white); border:1px solid var(--border); border-radius:var(--r); margin-bottom:.5rem; overflow:hidden; }
.faq__q { width:100%; text-align:left; padding:1rem 1.4rem; background:none; border:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:1rem; font-family:var(--font); font-size:.92rem; font-weight:700; color:var(--blue-d); }
.faq__q:hover { background:var(--light); }
.faq__q svg { flex-shrink:0; transition:transform .3s; color:var(--red); }
.faq__q.open svg { transform:rotate(180deg); }
.faq__a { display:none; padding:0 1.4rem 1.2rem; font-size:.88rem; line-height:1.8; color:var(--text-mid); }
.faq__a.open { display:block; }


/* ============================================================
   GALERIE
   ============================================================ */
.galerie-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:.6rem; margin:1rem 0; }
.galerie-item { overflow:hidden; border-radius:var(--r-sm); }
.galerie-item img { width:100%; height:220px; object-fit:cover; display:block; transition:transform .5s ease; }
.galerie-item:hover img { transform:scale(1.05); }


/* ============================================================
   AVIS CLIENTS
   ============================================================ */
.avis-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(300px,1fr)); gap:1.2rem; }
.avis-card {
    background:var(--white); border:1px solid var(--border);
    border-radius:var(--r); padding:1.6rem;
    transition:all var(--transition);
}
.avis-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.avis-card__stars { color:#f59e0b; font-size:1rem; letter-spacing:.05rem; margin-bottom:.8rem; }
.avis-card__texte { font-size:.88rem; color:var(--text-mid); line-height:1.7; margin-bottom:1rem; font-style:italic; }
.avis-card__auteur { display:flex; align-items:center; gap:.6rem; }
.avis-card__auteur-avatar { width:40px; height:40px; border-radius:50%; background:var(--blue-l); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.85rem; color:var(--blue); flex-shrink:0; }
.avis-card__auteur strong { color:var(--blue); font-size:.85rem; display:block; }
.avis-card__auteur span   { font-size:.75rem; color:var(--muted); }


/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar__card { background:var(--light); border:1px solid var(--border); border-radius:var(--r); padding:1.5rem; position:sticky; top:92px; margin-bottom:1rem; }
.sidebar__card h3   { margin-bottom:.3rem; }
.sidebar__card > p  { font-size:.82rem; color:var(--muted); margin-bottom:1rem; }
.sidebar__card h4   { margin-bottom:.8rem; font-size:.82rem; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; }
.sidebar__sep       { border:none; border-top:1px solid var(--border); margin:1rem 0; }
.sidebar__tels      { display:flex; flex-direction:column; gap:.65rem; }
.sidebar__tels small { display:block; font-size:.68rem; color:var(--muted); text-transform:uppercase; }
.sidebar__tels a    { display:flex; align-items:center; gap:.4rem; font-weight:800; color:var(--blue) !important; }
.sidebar__tels a.urg { color:var(--red) !important; }
.sidebar__garantie  { display:flex; align-items:center; gap:.4rem; background:var(--white); border:1px solid var(--border); border-radius:50px; padding:.5rem .8rem; font-size:.8rem; font-weight:600; color:var(--blue); margin-top:.8rem; }
.sidebar__addr      { display:flex; align-items:center; gap:.4rem; font-size:.8rem; color:var(--muted); margin-top:.6rem; }
.sidebar__links     { display:flex; flex-direction:column; gap:.4rem; }
.sidebar__links a   { font-size:.84rem; color:var(--text-mid); padding:.35rem 0; border-bottom:1px solid var(--border); }
.sidebar__links a:last-child { border:none; }
.sidebar__links a:hover { color:var(--blue); }


/* ============================================================
   FORMULAIRES
   ============================================================ */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.form-wrap { background:var(--light); border:1px solid var(--border); border-radius:var(--r); padding:2rem; }
.form-wrap h3 { margin-bottom:1.4rem; }
.fg { margin-bottom:.9rem; }
.fg label { display:block; margin-bottom:.3rem; font-weight:600; font-size:.82rem; color:var(--text); }
.fg input, .fg select, .fg textarea { width:100%; padding:.7rem 1rem; border:1px solid var(--border); border-radius:var(--r-sm); font-size:.88rem; font-family:var(--font); background:var(--white); color:var(--text); transition:border-color .2s, box-shadow .2s; }
.fg input:focus, .fg select:focus, .fg textarea:focus { outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(26,95,180,.1); }
.fg textarea { resize:vertical; min-height:110px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.msg-ok  { background:#D1FAE5; color:#065F46; padding:.8rem 1.2rem; border-radius:var(--r-sm); margin-bottom:1rem; font-weight:600; border-left:4px solid #10B981; }
.msg-err { background:#FEE2E2; color:#991B1B; padding:.5rem 1rem; border-radius:var(--r-sm); margin-bottom:.5rem; font-size:.84rem; }
.contact-list { display:flex; flex-direction:column; gap:.8rem; margin-top:1.5rem; }
.contact-list li { font-size:.92rem; line-height:1.6; }


/* ============================================================
   PAGES STATIQUES
   ============================================================ */
.static-wrap { max-width:820px; padding:4rem 0; }
.static-wrap h2 { font-size:1.1rem; margin:2rem 0 .5rem; border-bottom:1px solid var(--border); padding-bottom:.4rem; }
.static-wrap p  { margin-bottom:.8rem; font-size:.9rem; line-height:1.75; }


/* ============================================================
   SECTION ARTISAN / PORTRAIT
   ============================================================ */
.artisan { background:var(--light); }
.artisan__top { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; margin-bottom:2.5rem; }
.artisan__label { display:inline-block; background:var(--white); color:var(--blue); font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; padding:.35rem 1rem; border-radius:50px; margin-bottom:1rem; border:1px solid var(--border); }
.artisan__intro h2 { margin-bottom:1rem; }
.artisan__intro p  { color:var(--muted); font-size:.9rem; margin-bottom:.75rem; }
.artisan__photo { border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-md); }
.artisan__photo img { width:100%; height:auto; display:block; }
.artisan__atouts { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:2rem; }
.artisan__atout { display:flex; align-items:flex-start; gap:.8rem; background:var(--white); border-radius:var(--r); padding:1rem; border:1px solid var(--border); transition:all var(--transition); }
.artisan__atout:hover { box-shadow:var(--shadow); }
.artisan__atout strong { display:block; font-size:.86rem; color:var(--text); margin-bottom:.15rem; }
.artisan__atout div > span { font-size:.8rem; color:var(--muted); line-height:1.4; }
.artisan__cta { display:flex; align-items:center; gap:1rem; padding-top:1.5rem; border-top:1px solid var(--border); flex-wrap:wrap; }


/* ============================================================
   ENTRETIEN SPLIT
   ============================================================ */
.entretien-split { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.entretien-split__text h2 { margin-bottom:1rem; }
.entretien-split__text p  { margin-bottom:1rem; line-height:1.75; }
.entretien-split__text a  { color:var(--red); text-decoration:underline; font-weight:600; }
.entretien-split__img img { width:100%; height:auto; border-radius:var(--r); object-fit:cover; }


/* ============================================================
   PLAN DU SITE
   ============================================================ */
.sitemap { max-width:1000px; }
.sitemap__section { margin-bottom:3rem; padding-bottom:3rem; border-bottom:1px solid var(--border); }
.sitemap__section:last-child { border-bottom:none; }
.sitemap__section > h2 { margin-bottom:1.5rem; padding-bottom:.5rem; border-bottom:3px solid var(--red); display:inline-block; font-size:1.2rem; }
.sitemap__silos    { display:grid; grid-template-columns:repeat(auto-fill, minmax(200px,1fr)); gap:2rem; }
.sitemap__silo h3  { margin-bottom:.8rem; font-size:.92rem; }
.sitemap__silo h3 a { color:var(--text); font-weight:700; }
.sitemap__silo h3 a:hover { color:var(--red); }
.sitemap__clusters { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.sitemap__cluster h3 { margin-bottom:.8rem; font-size:.88rem; color:var(--text); padding-bottom:.4rem; border-bottom:1px solid var(--border); }
.sitemap__list { display:flex; flex-direction:column; gap:.3rem; }
.sitemap__list li a { font-size:.84rem; color:var(--text-mid); display:flex; align-items:center; gap:.4rem; transition:color .15s, padding-left .15s; }
.sitemap__list li a::before { content:'\203A'; color:var(--red); font-weight:700; flex-shrink:0; }
.sitemap__list li a:hover { color:var(--blue); padding-left:.3rem; }


/* ============================================================
   FOOTER — Sobre, une ligne, style Atrakt
   ============================================================ */
.ft { background:#111827; padding:1.8rem 0; }
.ft__inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.ft__logo { display:inline-flex; flex-shrink:0; }
.ft__logo img { height:56px; width:auto; filter:brightness(0) invert(1); opacity:.8; transition:opacity .2s; }
.ft__logo:hover img { opacity:1; }
.ft__links { display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.ft__links a { color:#94A3B8; font-size:.82rem; font-weight:500; transition:color .2s; }
.ft__links a:hover { color:#fff; }
.ft__copy { color:#4B5563; font-size:.78rem; }


/* ============================================================
   SECTION AVANT / APRÈS — Comparatif style Atrakt
   ============================================================ */
.compare { text-align:center; }
.compare h2 { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:900; margin-bottom:.6rem; }
.compare__sub { font-size:1.05rem; color:var(--text-mid); max-width:700px; margin:0 auto 1.5rem; }

.compare__stats {
    display:inline-flex; align-items:center; gap:2rem;
    margin-bottom:3rem; flex-wrap:wrap; justify-content:center;
}
.compare__stat {
    display:flex; align-items:center; gap:.5rem;
    font-size:.88rem; color:var(--text-mid); font-weight:500;
}
.compare__stat-icon {
    display:flex; align-items:center; justify-content:center;
    width:32px; height:32px; border-radius:50%;
    background:var(--blue-l); color:var(--blue); flex-shrink:0;
}
.compare__stat-icon svg { width:16px; height:16px; }
.compare__stat strong { color:var(--blue); }

.compare__grid {
    display:grid; grid-template-columns:1fr 1.2fr 1fr;
    gap:1.5rem; align-items:center;
}

/* Carte gauche — problèmes */
.compare__card {
    background:var(--white); border:1px solid var(--border);
    border-radius:20px; padding:2rem 1.8rem;
    text-align:left;
}
.compare__card h3 { font-size:1.15rem; font-weight:800; margin-bottom:1.2rem; }
.compare__card ul { display:flex; flex-direction:column; gap:.7rem; }
.compare__card li {
    display:flex; align-items:flex-start; gap:.6rem;
    font-size:.9rem; line-height:1.5; color:var(--text-mid);
}
.compare__card li .x-icon,
.compare__card li .check-icon {
    flex-shrink:0; width:20px; height:20px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:.7rem; font-weight:800; margin-top:.1rem;
}
.compare__card li .x-icon { background:#fee2e2; color:#dc2626; }
.compare__card li .check-icon { background:#d1fae5; color:#059669; }

/* Carte droite — Neves */
.compare__card--neves {
    background:var(--blue-l); border-color:rgba(26,95,180,.15);
}
.compare__card--neves h3 { color:var(--blue); }

.compare__card-cta { margin-top:1.5rem; }

/* Image centrale */
.compare__img {
    border-radius:16px; overflow:hidden;
    box-shadow:var(--shadow-lg); position:relative;
}
.compare__img img {
    width:100%; height:100%; object-fit:cover; display:block;
    min-height:400px;
}
.compare__img-label {
    position:absolute; bottom:1rem;
    background:rgba(0,0,0,.6); color:#fff;
    padding:.35rem .9rem; border-radius:50px;
    font-size:.78rem; font-weight:600;
    backdrop-filter:blur(8px);
}
.compare__img-label--before { left:1rem; }
.compare__img-label--after  { right:1rem; }

@media(max-width:1024px) {
    .compare__grid { grid-template-columns:1fr; gap:1.2rem; }
    .compare__img img { min-height:280px; }
    .compare__card { text-align:center; }
    .compare__card ul { align-items:center; }
    .compare__card-cta { display:flex; justify-content:center; }
}
@media(max-width:768px) {
    .compare__stats { gap:1rem; }
}


/* ============================================================
   SECTION ÉTAPES — Style Atrakt (fond arrondi, numéros, ligne)
   ============================================================ */
.etapes-wrap {
    background:var(--blue-l); border-radius:24px;
    padding:4rem 3rem 0; max-width:var(--max); margin:0 auto;
    position:relative; overflow:hidden;
}
.etapes-wrap h2 { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:900; color:var(--blue-d); margin-bottom:3rem; font-style:italic; }

.etapes-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-bottom:3rem; }

.etape { position:relative; }
.etape__num-row { display:flex; align-items:center; gap:0; margin-bottom:1.2rem; }
.etape__num {
    font-size:3.5rem; font-weight:900; color:var(--blue);
    line-height:1; flex-shrink:0; letter-spacing:-.04em;
}
.etape__line {
    flex:1; height:2px; background:var(--blue);
    opacity:.25; margin-left:1rem;
}
.etape:last-child .etape__line { display:none; }
.etape h3 { font-size:1rem; font-weight:800; color:var(--blue-d); margin-bottom:.5rem; line-height:1.35; }
.etape p  { font-size:.88rem; color:var(--text-mid); line-height:1.7; }

.etapes-cta {
    background:var(--white); border-radius:16px;
    padding:1.8rem 2.5rem; margin:0 -3rem;
    display:flex; align-items:center; justify-content:space-between;
    gap:2rem; flex-wrap:wrap;
}
.etapes-cta__text h3 { font-size:1.2rem; font-weight:800; color:var(--blue-d); margin-bottom:.25rem; }
.etapes-cta__text p  { font-size:.88rem; color:var(--muted); }

@media(max-width:768px) {
    .etapes-wrap { padding:2.5rem 1.5rem 0; border-radius:16px; margin:0 1rem; }
    .etapes-grid { grid-template-columns:1fr; gap:1.5rem; }
    .etape__line { display:none; }
    .etapes-cta  { flex-direction:column; text-align:center; margin:0 -1.5rem; padding:1.5rem; gap:1rem; }
}


/* ============================================================
   ICÔNES
   ============================================================ */
.icone { display:inline-block; vertical-align:middle; flex-shrink:0; }
.icone--white { filter:brightness(0) invert(1); }
.icone--ft    { filter:brightness(0) invert(0.6); }


/* ============================================================
   404
   ============================================================ */
.notfound { background:var(--text); min-height:calc(100vh - 76px); display:flex; align-items:center; padding:5rem 0; }
.notfound__inner { display:grid; grid-template-columns:1fr 360px; gap:4rem; align-items:center; }
.notfound__code { display:block; font-size:6rem; font-weight:900; color:rgba(255,255,255,.06); line-height:1; margin-bottom:.25rem; }
.notfound__left h1 { color:#fff; margin-bottom:1rem; }
.notfound__left > p { color:rgba(255,255,255,.6); font-size:1rem; margin-bottom:2rem; line-height:1.75; }
.notfound__btns { display:flex; flex-wrap:wrap; gap:.8rem; margin-bottom:2.5rem; }
.notfound__btn { display:inline-flex; align-items:center; justify-content:center; padding:.7rem 1.5rem; border-radius:50px; font-weight:700; font-size:.88rem; transition:all var(--transition); text-decoration:none; white-space:nowrap; }
.notfound__btn--red { background:var(--red); color:#fff !important; }
.notfound__btn--red:hover { background:var(--red-d); transform:translateY(-2px); color:#fff !important; }
.notfound__btn--outline { background:transparent; color:#fff !important; border:2px solid rgba(255,255,255,.3); }
.notfound__btn--outline:hover { background:rgba(255,255,255,.08); color:#fff !important; }
.notfound__btn--full { width:100%; }
.notfound__links p { font-size:.72rem; color:rgba(255,255,255,.3); text-transform:uppercase; letter-spacing:.06em; margin-bottom:.75rem; }
.notfound__links ul { display:flex; flex-wrap:wrap; gap:.5rem; }
.notfound__links li a { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.7); padding:.3rem .9rem; border-radius:50px; font-size:.8rem; font-weight:500; transition:all .2s; }
.notfound__links li a:hover { background:rgba(255,255,255,.12); color:#fff; }
.notfound__card { background:var(--white); border-radius:var(--r); padding:2rem; text-align:center; box-shadow:var(--shadow-lg); }
.notfound__card h3 { color:var(--text); margin-bottom:.75rem; font-size:1.05rem; line-height:1.35; }
.notfound__card > p { font-size:.86rem; color:var(--muted); margin-bottom:1.5rem; line-height:1.65; }
.notfound__tel2 { display:block; margin-top:.75rem; font-size:.88rem; font-weight:700; color:var(--blue) !important; text-align:center; }
.notfound__tel2:hover { color:var(--red) !important; }
.notfound__garantie { margin-top:1rem; padding-top:1rem; border-top:1px solid var(--border); font-size:.76rem; font-weight:600; color:var(--muted); }


/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px) {
    .silos              { grid-template-columns:repeat(2,1fr); }
    .ft__grid           { grid-template-columns:1fr 1fr; }
    .hero__stats        { gap:1.5rem; padding:1.2rem 1.5rem; }
    .page-hero__inner   { grid-template-columns:1fr; }
    .page-hero__img-wrap { max-width:480px; margin:0 auto; }
    .page-hero__img-wrap > img { height:260px; }
    .sitemap__silos     { grid-template-columns:repeat(2,1fr); }
    .sitemap__clusters  { grid-template-columns:repeat(2,1fr); }
    .galerie-grid       { grid-template-columns:repeat(2,1fr); }
    .notfound__inner    { grid-template-columns:1fr; }
    .notfound__right    { max-width:380px; margin:0 auto; width:100%; }
    .notfound__code     { font-size:5rem; }
}
@media(max-width:768px) {
    .mob-bar        { display:flex; }
    .burger         { display:flex; position:relative; z-index:200; }
    .hd__cta        { display:none; }
    .hd             { z-index:160; }
    .nav {
        display:none; position:fixed; top:0; left:0; width:100%; height:100vh; height:100dvh;
        z-index:150; background:linear-gradient(180deg, var(--white) 0%, var(--light) 100%);
        padding:6rem 2rem 2rem; overflow-y:auto; -webkit-overflow-scrolling:touch;
    }
    .nav.open           { display:flex; flex-direction:column; }
    .nav__list          { flex-direction:column; gap:0; width:100%; background:none; border:none; border-radius:0; padding:0; }
    .nav__list > li > a {
        padding:1.1rem .5rem; font-size:1.15rem; font-weight:600;
        color:var(--text); border-bottom:1px solid var(--border);
        border-radius:0; background:none;
    }
    .nav__list > li > a:hover { background:var(--blue-l); }
    .nav__list > li > a svg { display:none; }
    .nav__sub           { display:none !important; }
    .nav__mobile-footer {
        display:flex; flex-direction:column; align-items:center; gap:1.2rem;
        margin-top:auto; padding-top:2.5rem; width:100%;
    }
    .nav__mobile-logo img { height:56px; width:auto; }
    .nav__mobile-wa {
        display:inline-flex; align-items:center; gap:.6rem;
        background:#25D366; color:#fff !important;
        padding:.75rem 1.8rem; border-radius:50px;
        font-weight:700; font-size:.95rem;
        box-shadow:0 3px 12px rgba(37,211,102,.3);
        transition:all var(--transition);
    }
    .nav__mobile-wa:hover { background:#1fba59; transform:translateY(-2px); }
    .nav__mobile-wa svg { flex-shrink:0; }
    body.menu-open      { overflow:hidden; position:fixed; width:100%; }
    .content-grid       { grid-template-columns:1fr; }
    .form-grid          { grid-template-columns:1fr; }
    .form-row           { grid-template-columns:1fr; }
    .ft__inner          { flex-direction:column; text-align:center; gap:.8rem; }
    .ft__links          { justify-content:center; gap:1rem; }
    .chiffres           { grid-template-columns:1fr; gap:1rem; }
    .srv-grid           { grid-template-columns:1fr; }
    .avis-grid          { grid-template-columns:1fr; }
    .sitemap__silos     { grid-template-columns:1fr; }
    .sitemap__clusters  { grid-template-columns:1fr; }
    .artisan__top       { grid-template-columns:1fr; gap:2rem; }
    .artisan__photo     { max-width:400px; margin:0 auto; }
    .artisan__atouts    { grid-template-columns:1fr; }
    .galerie-grid       { grid-template-columns:repeat(2,1fr); }
    .galerie-item img   { height:160px; }
    .entretien-split    { grid-template-columns:1fr; }
    .entretien-split__img { order:-1; }
    .hero__stats        { flex-direction:column; gap:.6rem; padding:1rem 1.5rem; border-radius:var(--r); }
    .hero__btns         { flex-direction:column; align-items:center; }
    .hero__btns .btn    { min-width:240px; justify-content:center; }
    .notfound__btns     { flex-direction:column; }
    .fab__popup         { width:calc(100vw - 32px); right:-8px; }
}
@media(max-width:480px) {
    .silos        { grid-template-columns:1fr; }
    .ft__links    { gap:.8rem; }
    .galerie-grid { grid-template-columns:1fr; }
    .galerie-item img { height:200px; }
    .nav__mobile-wa { font-size:.9rem; padding:.7rem 1.4rem; }
    .page-hero__btns { flex-direction:column; align-items:center; }
    .page-hero__btns .btn { min-width:220px; justify-content:center; }
}
