/* ============================================================
   LE DOCTEUR DES PNEUS — style.css
   Design épuré inspiré Atrakt : fond blanc, typo bold centrée,
   grands espaces, accents bleu/rouge, animations subtiles.
   Titres Montserrat · Texte Inter
   Palette bleu #1a3a5c / rouge #d32f2f
   ============================================================ */

/* ── Reset & Variables ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
:root {
    --blue:       #1a3a5c;
    --blue-d:     #0f2640;
    --blue-l:     #e8eef5;
    --red:        #ef4444;
    --red-d:      #dc2626;
    --red-l:      #fef2f2;
    --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;
    --font-head:  'Montserrat', 'Inter', system-ui, 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-family:var(--font-head); font-size:clamp(2rem,4.5vw,3.2rem); font-weight:900; line-height:1.12; letter-spacing:-.03em; color:var(--blue-d); }
h2 { font-family:var(--font-head); font-size:clamp(1.5rem,3vw,2.4rem); font-weight:800; color:var(--blue-d); line-height:1.15; letter-spacing:-.02em; }
h3 { font-family:var(--font-head); 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(239,68,68,.3); }
.btn--red:hover  { background:var(--red-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(239,68,68,.4); }
.btn--blue    { background:var(--blue); color:#fff !important; box-shadow:0 2px 8px rgba(26,58,92,.25); }
.btn--blue:hover { background:var(--blue-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(26,58,92,.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--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--lg      { padding:.9rem 2.2rem; font-size:1rem; }

/* Boutons Waze / Maps */
.btn--waze { background:#33ccff; color:#fff !important; box-shadow:0 2px 8px rgba(51,204,255,.3); }
.btn--waze:hover { background:#1ab8ed; transform:translateY(-2px); box-shadow:0 6px 16px rgba(51,204,255,.4); }
.btn--maps { background:#4285f4; color:#fff !important; box-shadow:0 2px 8px rgba(66,133,244,.3); }
.btn--maps:hover { background:#3367d6; transform:translateY(-2px); box-shadow:0 6px 16px rgba(66,133,244,.4); }
.btn--waze img, .btn--maps img { flex-shrink:0; }


/* ============================================================
   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.is-scrolled { box-shadow:var(--shadow-md); }
.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:52px; width:auto; }
@media(max-width:768px) { .logo img { height:48px; } }

/* 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__sub.is-visible { 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.is-open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.burger.is-open span:nth-child(2) { opacity:0; }
.burger.is-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:40px; right:24px; z-index:95; opacity:1; visibility:visible; }
@media(max-width:768px) { .fab { bottom:80px; right:16px; } }

.fab__btn {
    display:flex; align-items:center; justify-content:center;
    width:64px; height:64px; border-radius:50%; border:none; cursor:pointer;
    background:linear-gradient(145deg, #e53935 0%, #c62828 50%, #b71c1c 100%);
    color:#fff; position:relative; z-index:2;
    box-shadow:
        0 8px 24px rgba(198,40,40,.45),
        0 2px 6px rgba(198,40,40,.25),
        inset 0 2px 4px rgba(255,255,255,.2),
        inset 0 -2px 4px rgba(0,0,0,.2);
    transition:transform .25s, box-shadow .25s;
    overflow:hidden;
}
.fab__btn:hover { transform:scale(1.08); box-shadow:0 10px 32px rgba(198,40,40,.55), inset 0 2px 4px rgba(255,255,255,.2), inset 0 -2px 4px rgba(0,0,0,.2); }
.fab__btn svg { width:26px; height:26px; fill:#fff; transition:transform .3s; position:relative; z-index:2; }

/* Rotor montre automatique — forme haricot */
.fab__rotor {
    position:absolute; top:0; left:0; width:100%; height:100%;
    border-radius:50%; z-index:1; pointer-events:none;
    animation:fab-rotor 5s ease-in-out infinite;
}
.fab__rotor::before {
    content:''; position:absolute;
    top:4%; left:12%; width:76%; height:44%;
    background:rgba(255,255,255,.14);
    border-radius:50% 50% 40% 40% / 60% 60% 40% 40%;
    box-shadow:inset 0 1px 2px rgba(255,255,255,.15);
}
@keyframes fab-rotor {
    0%   { transform:rotate(0deg); }
    40%  { transform:rotate(220deg); }
    60%  { transform:rotate(180deg); }
    100% { transform:rotate(360deg); }
}

/* 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__popup.is-visible { 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; align-items:center; }
.fab__popup-actions .btn { justify-content:center; font-size:.85rem; padding:.6rem 1.5rem; width:auto; box-shadow:0 3px 10px rgba(0,0,0,.15), inset 0 1px 1px rgba(255,255,255,.2); }

.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; }


/* ============================================================
   HERO — Grille texte + image (accueil)
   ============================================================ */
.hero { padding:4rem 0 3rem; background:var(--white); overflow:hidden; }
.hero__inner { display:grid; grid-template-columns:55% 45%; gap:3rem; align-items:center; }
.hero__text { display:flex; flex-direction:column; gap:.8rem; }
.hero__overtitle {
    font-family:var(--font-head); font-size:.78rem; font-weight:700;
    text-transform:uppercase; letter-spacing:.1em; color:var(--red);
    background:var(--red-l);
    padding:.35rem 1rem; border-radius:50px; line-height:1.4;
    align-self:flex-start; width:fit-content;
    margin-bottom:.6rem;
}
.hero__headline {
    font-family:var(--font-head); font-size:clamp(1.8rem,4vw,3rem);
    font-weight:900; line-height:1.15; letter-spacing:-.03em; color:var(--blue-d);
}
.hero__accent {
    color:var(--red); position:relative; display:inline-block;
}
.hero__accent::after {
    content:''; position:absolute; bottom:-.02em; left:-.04em; right:-.04em;
    height:.28em; background:var(--red-l); border-radius:4px; z-index:-1;
}
.hero__sub { font-size:1.05rem; max-width:560px; color:var(--muted); line-height:1.75; }
.hero__addr { display:flex; align-items:center; gap:.4rem; font-size:.88rem; color:var(--text-mid); font-weight:500; }
.hero__addr svg { flex-shrink:0; }
.hero__cta { display:flex; flex-wrap:wrap; gap:.8rem; margin-top:.5rem; }
.hero__img { border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-lg); }
.hero__img img { width:100%; display:block; object-fit:cover; height:380px; border-radius:var(--r); }

/* Rating Badge */
.rating-badge { display:inline-flex; align-items:center; gap:.5rem; background:var(--light); border:1px solid var(--border); padding:.4rem 1rem; border-radius:50px; align-self:flex-start; }
.rating-badge__stars { color:#f59e0b; font-size:1.2rem; letter-spacing:.04em; line-height:1; }
.rating-badge__note { font-weight:700; color:var(--blue); font-size:.92rem; }
.rating-badge__total { font-size:.82rem; color:var(--muted); }

/* Navigation Waze/Maps buttons (inline) */
.nav-btns { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:.5rem; }
.nav-btns .btn { font-size:.82rem; padding:.5rem 1.2rem; }


/* ============================================================
   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%); }


/* ============================================================
   BANDEAU ADRESSE (accueil)
   ============================================================ */
.adresse-band { background:var(--blue-d); padding:1.4rem 0; }
.adresse-band__inner {
    display:flex; align-items:center; justify-content:center; gap:1rem; flex-wrap:wrap;
    text-align:center;
}
.adresse-band__inner svg { flex-shrink:0; }
.adresse-band__inner strong {
    font-family:var(--font-head); font-size:clamp(.95rem, 2.5vw, 1.35rem);
    font-weight:800; color:#fff; letter-spacing:.01em;
}
.adresse-band__inner span { font-size:.95rem; color:rgba(255,255,255,.55); margin-left:.3rem; }


/* ============================================================
   FAMILLES DE PRESTATIONS (accueil)
   ============================================================ */
.familles { padding:5rem 0; background:var(--light); }
.familles h2 { text-align:center; margin-bottom:.6rem; font-size:clamp(1.3rem,2.5vw,2rem); }
.familles > .container > p { text-align:center; color:var(--muted); margin-bottom:3rem; max-width:700px; margin-left:auto; margin-right:auto; }
.familles__grid { display:grid; grid-template-columns:repeat(2, 1fr); gap:2rem; }

.familles__card {
    background:var(--white); border:1px solid var(--border);
    border-radius:var(--r); padding:2rem;
    transition:all var(--transition); position:relative; overflow:hidden;
}
.familles__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);
}
.familles__card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.familles__card:hover::before { opacity:1; }

.familles__icon {
    display:flex; align-items:center; justify-content:center;
    width:68px; height:68px; margin-bottom:1.2rem;
    border-radius:18px; transition:all .35s cubic-bezier(.4,0,.2,1);
    position:relative;
}
.familles__icon--blue {
    background:linear-gradient(145deg, #e8eef5 0%, #cfdced 60%, #b8cce1 100%);
    color:var(--blue);
    box-shadow:
        6px 6px 14px rgba(26,58,92,.15),
        -4px -4px 10px rgba(255,255,255,.8),
        inset 0 1px 2px rgba(255,255,255,.6),
        inset 0 -1px 2px rgba(26,58,92,.08);
}
.familles__icon--red {
    background:linear-gradient(145deg, #fdecea 0%, #f5d4d4 60%, #edbfbf 100%);
    color:var(--red);
    box-shadow:
        6px 6px 14px rgba(211,47,47,.12),
        -4px -4px 10px rgba(255,255,255,.8),
        inset 0 1px 2px rgba(255,255,255,.6),
        inset 0 -1px 2px rgba(211,47,47,.08);
}
.familles__card:hover .familles__icon {
    transform:translateY(-3px) scale(1.05);
}
.familles__card:hover .familles__icon--blue {
    box-shadow:
        8px 8px 20px rgba(26,58,92,.22),
        -4px -4px 12px rgba(255,255,255,.9),
        inset 0 1px 2px rgba(255,255,255,.6),
        inset 0 -1px 2px rgba(26,58,92,.1);
}
.familles__card:hover .familles__icon--red {
    box-shadow:
        8px 8px 20px rgba(211,47,47,.18),
        -4px -4px 12px rgba(255,255,255,.9),
        inset 0 1px 2px rgba(255,255,255,.6),
        inset 0 -1px 2px rgba(211,47,47,.1);
}
.familles__card h3 { font-size:1.15rem; margin-bottom:.6rem; }
.familles__card > p { font-size:.9rem; color:var(--muted); margin-bottom:1rem; line-height:1.65; }
.familles__body { margin-bottom:1.5rem; }
.familles__body p { font-size:.9rem; color:var(--text-mid); line-height:1.7; margin-bottom:.8rem; }
.familles__body p:last-child { margin-bottom:0; }
.familles__body a { color:var(--red); font-weight:600; transition:color .15s; }
.familles__body a:hover { color:var(--blue); text-decoration:underline; }
.familles__list { display:flex; flex-direction:column; gap:.4rem; margin-bottom:1.5rem; }
.familles__list li a { font-size:.88rem; color:var(--text-mid); display:flex; align-items:center; gap:.4rem; transition:color .15s, padding-left .15s; }
.familles__list li a::before { content:'\203A'; color:var(--red); font-weight:700; flex-shrink:0; }
.familles__list li a:hover { color:var(--blue); padding-left:.3rem; }


/* ============================================================
   CHIFFRES / STATS (accueil)
   ============================================================ */
.stats { background:linear-gradient(145deg, var(--blue-d) 0%, var(--blue) 100%); padding:3.5rem 0; }
.stats__grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:1.5rem; }
.stats__item {
    text-align:center; padding:1.5rem 1rem;
    background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08);
    border-radius:var(--r);
}
.stats__item strong { display:block; font-family:var(--font-head); font-size:2rem; font-weight:900; color:#fff; line-height:1; margin-bottom:.3rem; }
.stats__item span   { font-size:.82rem; color:rgba(255,255,255,.55); font-weight:500; }


/* ============================================================
   PORTRAIT / À PROPOS
   ============================================================ */
.portrait { background:var(--white); padding:5rem 0; }
.portrait__inner { display:grid; grid-template-columns:280px 1fr; gap:3rem; align-items:center; }
.portrait__img { border-radius:var(--r); overflow:hidden; display:flex; align-items:center; justify-content:center; }
.portrait__img img { width:100%; height:auto; }
.portrait__text h2 { margin-bottom:1rem; }
.portrait__text > p { color:var(--muted); font-size:.92rem; margin-bottom:.8rem; line-height:1.75; }
.portrait__grid { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; margin-top:1.5rem; }
.portrait__value {
    display:flex; align-items:center; gap:.6rem;
    background:var(--light); border:1px solid var(--border);
    border-radius:var(--r); padding:.8rem 1rem;
    transition:all var(--transition);
}
.portrait__value:hover { box-shadow:var(--shadow); }
.portrait__value svg { flex-shrink:0; }
.portrait__value span { font-size:.84rem; font-weight:600; color:var(--blue-d); }


/* ============================================================
   AVIS CLIENTS — Carrousel horizontal
   ============================================================ */
.reviews { padding:5rem 0; background:var(--light); }
.reviews h2 { text-align:center; margin-bottom:.6rem; }
.reviews__summary {
    text-align:center; font-size:1rem; color:var(--text-mid); margin-bottom:2.5rem;
    display:flex; align-items:center; justify-content:center; gap:.5rem; flex-wrap:wrap;
}
.reviews__stars { color:#f59e0b; font-size:1.4rem; letter-spacing:.04em; line-height:1; }
.reviews__summary strong { color:var(--blue); font-size:1.05rem; }

.reviews__wrapper { position:relative; display:flex; align-items:center; gap:.8rem; }
.reviews__container {
    display:flex; gap:1.2rem; overflow-x:auto; scroll-snap-type:x mandatory;
    padding:.5rem 0; -ms-overflow-style:none; scrollbar-width:none;
}
.reviews__container::-webkit-scrollbar { display:none; }

.reviews__card {
    flex:0 0 320px; scroll-snap-align:start;
    background:var(--white); border:1px solid var(--border);
    border-radius:var(--r); padding:1.4rem;
    border-left:3px solid var(--blue);
    transition:all var(--transition);
}
.reviews__card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.reviews__header { margin-bottom:.6rem; }
.reviews__author { display:block; color:var(--blue-d); font-size:.92rem; margin-bottom:.2rem; }
.reviews__card-stars { color:#f59e0b; font-size:1rem; letter-spacing:.04em; }
.reviews__content p { font-size:.88rem; color:var(--text); line-height:1.75; font-style:italic; margin-bottom:.6rem; }
.reviews__footer small { font-size:.75rem; color:var(--muted); }

.reviews__arrow {
    flex-shrink:0; width:40px; height:40px; border-radius:50%;
    border:1px solid var(--border); background:var(--white);
    cursor:pointer; display:flex; align-items:center; justify-content:center;
    font-size:1.1rem; color:var(--text-mid);
    transition:all var(--transition);
    box-shadow:var(--shadow);
}
.reviews__arrow:hover { background:var(--blue-l); color:var(--blue); border-color:var(--blue); }


/* ============================================================
   ZONES D'INTERVENTION (accueil + page dédiée)
   ============================================================ */
.zones { padding:5rem 0; background:var(--white); }
.zones h2 { text-align:center; margin-bottom:.6rem; }
.zones > .container > p { text-align:center; color:var(--muted); margin-bottom:3rem; max-width:700px; margin-left:auto; margin-right:auto; }

.zones__clusters { display:grid; gap:2.5rem; }
.zones__cluster h3 { font-size:1rem; font-weight:700; color:var(--blue); margin-bottom:1rem; padding-bottom:.6rem; border-bottom:2px solid var(--blue-l); }

.zones__pills { display:flex; flex-wrap:wrap; gap:.4rem; }
.pill {
    display:inline-flex; align-items:center;
    background:var(--white); border:1px solid var(--border);
    padding:.35rem .9rem; border-radius:50px;
    font-size:.82rem; font-weight:500; color:var(--text-mid);
    transition:all .2s;
}
.pill:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-l); }
.pill--more { background:var(--blue-l); color:var(--blue); font-weight:600; border-color:var(--blue-l); }
.pill--more:hover { background:var(--blue); color:#fff; border-color:var(--blue); }

.zones__cta { text-align:center; margin-top:2.5rem; }


/* ============================================================
   CTA FINAL (accueil)
   ============================================================ */
.cta-final { background:linear-gradient(145deg, var(--blue-d) 0%, var(--blue) 100%); padding:5rem 0; text-align:center; }
.cta-final h2 { color:#fff; margin-bottom:.6rem; }
.cta-final p  { color:rgba(255,255,255,.65); margin-bottom:2rem; max-width:600px; margin-left:auto; margin-right:auto; }
.cta-final__btns { display:flex; justify-content:center; gap:1rem; flex-wrap:wrap; }
.btn--whatsapp { background:#25D366; color:#fff !important; box-shadow:0 2px 8px rgba(37,211,102,.3); }
.btn--whatsapp:hover { background:#1fba59; transform:translateY(-2px); box-shadow:0 6px 20px rgba(37,211,102,.4); }


/* ============================================================
   CONTENT GRID — Pages communes + services (sidebar layout)
   ============================================================ */
.page-grid { display:grid; grid-template-columns:1fr 320px; gap:3rem; align-items:start; padding-top:2rem; padding-bottom:4rem; }
.main-content h2 { margin:2.5rem 0 .8rem; font-size:1.3rem; }
.main-content h2:first-child { margin-top:0; }
.main-content p { margin-bottom:1rem; }

/* Breadcrumb */
.breadcrumb { display:flex; gap:.4rem; flex-wrap:wrap; padding:1.2rem 0; font-size:.82rem; color:var(--muted); background:var(--light); border-bottom:1px solid var(--border); }
.breadcrumb .container { display:flex; gap:.4rem; flex-wrap:wrap; }
.breadcrumb a { color:var(--muted); }
.breadcrumb a:hover { color:var(--blue); }
.breadcrumb strong { color:var(--text); }


/* ============================================================
   COMMUNE PAGES (pneu-[slug])
   ============================================================ */
.commune-hero { margin-bottom:2rem; }
.commune-hero .rating-badge { margin-bottom:1rem; }
.commune-hero h1 { font-size:clamp(1.6rem,3vw,2.2rem); margin-bottom:.6rem; }
.commune-hero__artisan {
    font-family:var(--font-head); font-size:clamp(1.1rem,2.5vw,1.5rem);
    font-weight:800; color:var(--blue-d); line-height:1.3; margin-bottom:1rem;
}
.commune-hero__accent {
    color:var(--red); position:relative; display:inline-block;
}
.commune-hero__accent::after {
    content:''; position:absolute; bottom:-.02em; left:-.04em; right:-.04em;
    height:.28em; background:var(--red-l); border-radius:4px; z-index:-1;
}
.commune-hero__intro { font-size:1rem; line-height:1.75; color:var(--text-mid); margin-bottom:.8rem; }
.commune-hero__expertise { font-size:.95rem; line-height:1.75; color:var(--text-mid); }

/* Grille prestations communes (anchor grid) */
.commune-services { margin:2rem 0; }
.commune-services h2 { margin-bottom:.6rem; }
.commune-services > p { margin-bottom:1.5rem; }
.commune-services__grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:1rem; }
.commune-services__item {
    display:flex; flex-direction:column; gap:.3rem;
    background:var(--white); border:1px solid var(--border);
    border-radius:var(--r); padding:1.2rem 1.4rem;
    transition:all var(--transition); color:inherit; text-decoration:none;
}
.commune-services__item:hover { border-color:var(--blue); transform:translateY(-2px); box-shadow:var(--shadow); color:inherit; }
.commune-services__item strong { color:var(--blue); font-size:.9rem; }
.commune-services__item span   { font-size:.82rem; color:var(--muted); }

/* Contenu SEO communes */
.commune-content { margin:2rem 0; }
.commune-content h2 { margin-bottom:.8rem; }
.commune-content p { margin-bottom:1rem; line-height:1.75; }
.commune-content a { color:var(--red); font-weight:600; }
.commune-content a:hover { text-decoration:underline; }

/* Galerie photos communes */
.commune-gallery { margin:2rem 0; }
.gallery__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:.6rem; margin-top:1rem; }
.gallery__item { overflow:hidden; border-radius:var(--r-sm); }
.gallery__item img { width:100%; height:220px; object-fit:cover; display:block; transition:transform .5s ease; }
.gallery__item:hover img { transform:scale(1.05); }

/* Communes voisines */
.commune-voisines { margin:2rem 0; }
.commune-voisines h2 { margin-bottom:1rem; }


/* ============================================================
   SERVICE PAGES (services/[slug])
   ============================================================ */
.service-hero { margin-bottom:2rem; }
.service-hero__badge {
    display:inline-block; background:var(--blue-l); 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);
}
.service-hero .rating-badge { margin-bottom:1rem; }
.service-hero h1 { font-size:clamp(1.6rem,3vw,2.2rem); margin-bottom:.6rem; }
.service-hero__artisan {
    font-family:var(--font-head); font-size:clamp(1rem,2.2vw,1.35rem);
    font-weight:800; color:var(--blue-d); line-height:1.3; margin-bottom:.8rem;
}
.service-hero__accent {
    color:var(--red); position:relative; display:inline-block;
}
.service-hero__accent::after {
    content:''; position:absolute; bottom:-.02em; left:-.04em; right:-.04em;
    height:.28em; background:var(--red-l); border-radius:4px; z-index:-1;
}
.service-hero__desc { font-size:1rem; line-height:1.75; color:var(--text-mid); }

.service-img { margin:1.5rem 0 2rem; border-radius:var(--r); overflow:hidden; box-shadow:0 4px 20px rgba(0,0,0,.1); }
.service-img img { width:100%; height:auto; display:block; object-fit:cover; max-height:420px; }
.service-img--secondary { margin:1.5rem 0; border-radius:var(--r); }
.service-img--secondary img { max-height:360px; }

.service-section { margin:2rem 0; }
.service-section h2 { margin-bottom:.8rem; }
.service-section p  { margin-bottom:1rem; line-height:1.75; }

.service-why { margin:2rem 0; background:var(--light); border:1px solid var(--border); border-radius:var(--r); padding:2rem; }
.service-why h2 { margin-bottom:1rem; margin-top:0; }
.service-why__list { display:flex; flex-direction:column; gap:.6rem; padding-left:1.4rem; list-style:disc; }
.service-why__list li { padding:.2rem 0; line-height:1.65; color:var(--text-mid); font-size:.92rem; }

/* Services liés */
.service-related { margin:2rem 0; }
.service-related__grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:1rem; margin-top:1rem; }
.service-related__card {
    display:flex; flex-direction:column; gap:.3rem;
    background:var(--white); border:1px solid var(--border);
    border-radius:var(--r); padding:1.2rem 1.4rem;
    transition:all var(--transition); color:inherit; text-decoration:none;
}
.service-related__card:hover { border-color:var(--blue); transform:translateY(-2px); box-shadow:var(--shadow); color:inherit; }
.service-related__card strong { color:var(--blue); font-size:.9rem; }
.service-related__card span   { font-size:.82rem; color:var(--muted); }

/* Communes section on service pages */
.service-communes { margin:2rem 0; }
.service-communes h2 { margin-bottom:.6rem; }
.service-communes p { margin-bottom:1rem; }


/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar { position:sticky; top:92px; display:flex; flex-direction:column; gap:1rem; }
.sidebar__card {
    background:var(--light); border:1px solid var(--border);
    border-radius:var(--r); padding:1.5rem;
}
.sidebar__card h3   { margin-bottom:.3rem; }
.sidebar__card > p  { font-size:.84rem; 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__card--cta { background:var(--blue-l); border-color:rgba(26,58,92,.12); }
.sidebar__card--cta h3 { color:var(--blue-d); }
.sidebar__card--cta .btn { margin-bottom:.5rem; }
.sidebar__card--cta .btn:last-child { margin-bottom:0; }

.sidebar__line { display:flex; align-items:center; gap:.5rem; font-size:.88rem; color:var(--text-mid); margin-bottom:.5rem; }
.sidebar__line svg { flex-shrink:0; color:var(--blue); }
.sidebar__line a { color:var(--blue); font-weight:600; }
.sidebar__line a:hover { color:var(--red); }

.sidebar__horaires { font-size:.82rem; color:var(--muted); margin-top:.8rem; }
.sidebar__urgence { font-size:.82rem; color:var(--red); font-weight:600; margin-top:.4rem; }

.sidebar__nav-btns { display:flex; flex-direction:column; gap:.5rem; }
.sidebar__nav-btns .btn { justify-content:center; font-size:.84rem; padding:.6rem 1.2rem; }

.sidebar__services { display:flex; flex-direction:column; gap:.3rem; }
.sidebar__services li a { font-size:.84rem; color:var(--text-mid); display:flex; align-items:center; gap:.4rem; padding:.35rem 0; border-bottom:1px solid var(--border); transition:color .15s, padding-left .15s; }
.sidebar__services li:last-child a { border:none; }
.sidebar__services li a::before { content:'\203A'; color:var(--red); font-weight:700; flex-shrink:0; }
.sidebar__services li a:hover { color:var(--blue); padding-left:.3rem; }


/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-container { display:grid; grid-template-columns:1fr 1fr; gap:3rem; padding:3rem 0; max-width:var(--max); margin:0 auto; padding-left:1.5rem; padding-right:1.5rem; }
.contact-left h1 { font-size:2rem; margin-bottom:1rem; }
.contact-left > p { font-size:1rem; line-height:1.6; margin-bottom:2rem; color:var(--muted); }
.contact-methods { margin-bottom:2rem; }
.method { margin-bottom:1.5rem; }
.method h3 { font-size:1rem; font-weight:600; margin-bottom:.5rem; }
.method a { color:var(--red); text-decoration:none; font-size:1.1rem; font-weight:600; }
.method a:hover { text-decoration:underline; }
.address-section, .hours-section { margin-bottom:1.5rem; }
.address-section h3, .hours-section h3 { font-size:1rem; font-weight:600; margin-bottom:.5rem; }
.address-section p, .hours-section p { color:var(--muted); line-height:1.6; }

.contact-right { background:var(--light); padding:2rem; border-radius:var(--r); border:1px solid var(--border); }

/* Form elements */
.form-group { margin-bottom:1rem; }
.form-group label { display:block; font-weight:600; margin-bottom:.3rem; font-size:.86rem; color:var(--text); }
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group select,
.form-group 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;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
    outline:none; border-color:var(--blue);
    box-shadow:0 0 0 3px rgba(26,58,92,.1);
}
.form-group textarea { resize:vertical; min-height:100px; }

.checkboxes { display:flex; flex-direction:column; gap:.6rem; }
.checkbox-item { display:flex; align-items:center; gap:.5rem; }
.checkbox-item input[type="checkbox"] { width:auto; cursor:pointer; accent-color:var(--blue); }
.checkbox-item label { margin:0; font-weight:400; cursor:pointer; font-size:.88rem; }

.radios { display:flex; gap:1.5rem; }
.radio-item { display:flex; align-items:center; gap:.5rem; }
.radio-item input[type="radio"] { width:auto; cursor:pointer; accent-color:var(--blue); }
.radio-item label { margin:0; font-weight:400; cursor:pointer; font-size:.88rem; }

.btn-submit {
    width:100%; padding:.75rem 1.5rem;
    background:var(--red); color:white; border:none;
    border-radius:50px; font-size:1rem; font-weight:600;
    cursor:pointer; transition:all var(--transition);
    font-family:var(--font);
    box-shadow:0 2px 8px rgba(239,68,68,.3);
}
.btn-submit:hover { background:var(--red-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(239,68,68,.4); }


/* ============================================================
   SITEMAP / PLAN DU SITE
   ============================================================ */
.sitemap-container { max-width:var(--max); margin:0 auto; padding:3rem 1.5rem; }
.sitemap-container h1 { font-size:2rem; margin-bottom:2rem; }
.sitemap-content { display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:2rem; }
.sitemap-section h2 { font-size:1.1rem; font-weight:700; color:var(--red); margin-bottom:1rem; padding-bottom:.5rem; border-bottom:2px solid var(--red-l); }
.sitemap-section ul { display:flex; flex-direction:column; gap:.3rem; }
.sitemap-section li a { font-size:.88rem; color:var(--text-mid); display:flex; align-items:center; gap:.4rem; transition:color .15s, padding-left .15s; }
.sitemap-section li a::before { content:'\203A'; color:var(--red); font-weight:700; flex-shrink:0; }
.sitemap-section li a:hover { color:var(--blue); padding-left:.3rem; }


/* ============================================================
   PAGES STATIQUES (mentions légales, merci, etc.)
   ============================================================ */
.static-wrap { max-width:820px; margin:0 auto; padding:4rem 1.5rem; }
.static-wrap h1 { margin-bottom:1.5rem; }
.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; word-break:break-word; }
.static-wrap strong { color:var(--blue-d); }


/* ============================================================
   404
   ============================================================ */
.notfound { background:var(--text); min-height:calc(100vh - 76px); display:flex; align-items:center; padding:5rem 1.5rem; }
.notfound__inner { max-width:var(--max); margin:0 auto; text-align:center; }
.notfound__code { display:block; font-family:var(--font-head); font-size:8rem; font-weight:900; color:rgba(255,255,255,.06); line-height:1; margin-bottom:.5rem; }
.notfound h1 { color:#fff; margin-bottom:1rem; }
.notfound p { color:rgba(255,255,255,.6); font-size:1rem; margin-bottom:2rem; line-height:1.75; }
.notfound__btns { display:flex; justify-content:center; flex-wrap:wrap; gap:.8rem; }


/* ============================================================
   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; max-width:var(--max); margin:0 auto; padding:0 1.5rem; }
.ft__logo { display:inline-flex; flex-shrink:0; }
.ft__logo img { height:80px; width:auto; transition:opacity .2s; opacity:.9; }
.ft__logo:hover img { opacity:1; }
.ft__addr { font-size:.88rem; color:#94A3B8; font-weight:500; }
.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; }

/* Legacy footer class compatibility */
.footer { background:#111827; padding:1.8rem 0; }
.footer__inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.footer__logo { display:inline-flex; flex-shrink:0; }
.footer__logo img { height:80px; width:auto; transition:opacity .2s; opacity:.9; }
.footer__logo:hover img { opacity:1; }
.footer__address { font-size:.88rem; color:#94A3B8; font-weight:500; }
.footer__nav { display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.footer__nav a { color:#94A3B8; font-size:.82rem; font-weight:500; transition:color .2s; }
.footer__nav a:hover { color:#fff; }
.footer__copy { color:#4B5563; font-size:.78rem; }


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


/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px) {
    .hero__inner            { grid-template-columns:1fr; text-align:center; }
    .hero__text             { align-items:center; }
    .hero__img              { max-width:520px; margin:0 auto; }
    .hero__img img          { height:300px; }
    .familles__grid         { grid-template-columns:1fr; }
    .stats__grid            { grid-template-columns:repeat(2,1fr); }
    .portrait__inner        { grid-template-columns:1fr; }
    .portrait__img          { max-width:200px; margin:0 auto; }
    .gallery__grid          { grid-template-columns:repeat(2,1fr); }
    .contact-container      { grid-template-columns:1fr; }
}
@media(max-width:768px) {
    .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;
        border:none; border-radius:0;
    }
    .nav.is-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.no-scroll          { overflow:hidden; position:fixed; width:100%; }

    /* Texte aligné à gauche sur mobile pour la lisibilité */
    .familles__body, .familles__card > p,
    .portrait__text, .service-section,
    .service-hero__desc, .service-why,
    .hero__sub,
    .commune-intro, .commune-section,
    .cta-final p { text-align:left; }

    .page-grid              { grid-template-columns:1fr; }
    .sidebar                { position:static; }
    .commune-services__grid { grid-template-columns:1fr; }
    .service-related__grid  { grid-template-columns:1fr; }
    .footer__inner          { flex-direction:column; text-align:center; gap:.8rem; }
    .footer__nav            { justify-content:center; gap:1rem; }
    .ft__inner              { flex-direction:column; text-align:center; gap:.8rem; }
    .ft__links              { justify-content:center; gap:1rem; }
    .stats__grid            { grid-template-columns:1fr 1fr; }
    .portrait__grid         { grid-template-columns:1fr; }
    .gallery__grid          { grid-template-columns:repeat(2,1fr); }
    .gallery__item img      { height:160px; }
    .hero__cta              { flex-direction:column; align-items:center; }
    .hero__cta .btn         { min-width:240px; justify-content:center; }
    .nav-btns               { justify-content:center; }
    .cta-final__btns        { flex-direction:column; align-items:center; }
    .cta-final__btns .btn   { min-width:240px; justify-content:center; }
    .fab__popup             { width:calc(100vw - 32px); right:-8px; }
    .sitemap-content        { grid-template-columns:1fr; }
}
@media(max-width:480px) {
    .familles__grid         { grid-template-columns:1fr; }
    .gallery__grid          { grid-template-columns:1fr; }
    .gallery__item img      { height:200px; }
    .stats__grid            { grid-template-columns:1fr; }
}
