/* ═══════════════════════════════════════════════════════
   DOCTOR AUTO — BESTMOTORS STYLE
   Dark navy + Yellow #FFC107 + White
═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&family=Open+Sans:wght@400;500;600&display=swap');

:root{
  --bg:    #0a0d14;
  --bg2:   #0d1120;
  --bg3:   #111827;
  --card:  #111827;
  --border:rgba(255,255,255,.08);
  --yellow:#FFC107;
  --yellow2:#FFB300;
  --white: #ffffff;
  --text:  #e8eaf0;
  --muted: rgba(232,234,240,.55);
  --muted2:rgba(232,234,240,.35);
  --blue:  #3B7EE8;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Open Sans',sans-serif;font-size:16px;line-height:1.7;overflow-x:hidden}

/* ── SKIP ── */
.skip{position:absolute;left:-9999px}.skip:focus{left:1rem;top:1rem;padding:.5rem 1rem;background:var(--yellow);color:#000;z-index:9999;font-weight:700}

/* ══════════════════════════════════
   NAV — Logo left / Hamburger+APPEL right
══════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:68px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2.5rem;
  background:var(--bg);
  border-bottom:1px solid var(--border);
  transition:background .3s;
}
.nav.scrolled{background:rgba(10,13,20,.97);backdrop-filter:blur(12px)}

.nav-logo{
  display:flex;align-items:center;gap:.6rem;
  text-decoration:none;
}
.nav-logo-text{
  font-family:'Montserrat',sans-serif;
  font-weight:900;font-size:1.25rem;
  letter-spacing:.02em;text-transform:uppercase;
  color:var(--white);
}
.nav-logo-text span{color:var(--yellow)}

.nav-right{display:flex;align-items:center;gap:1rem}

/* hamburger */
.hamburger{
  display:flex;flex-direction:column;gap:5px;
  cursor:pointer;padding:8px;background:none;border:none;
}
.hamburger span{
  display:block;width:24px;height:2px;
  background:var(--white);transition:all .3s;
}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* mobile menu */
.nav-menu{
  display:none;
  position:fixed;top:68px;left:0;right:0;
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:1rem 2.5rem 1.5rem;z-index:499;
  flex-direction:column;gap:.25rem;
}
.nav-menu.open{display:flex}
.nav-menu a{
  font-family:'Montserrat',sans-serif;font-weight:600;
  font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;
  padding:.7rem 0;border-bottom:1px solid var(--border);
  transition:color .2s;
}
.nav-menu a:last-child{border-bottom:none}
.nav-menu a:hover,.nav-menu a.active{color:var(--yellow)}

/* APPEL button */
.btn-appel{
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;
  background:var(--yellow);color:#000;
  border:none;padding:.6rem 1.6rem;cursor:pointer;
  text-decoration:none;
  transition:background .2s,transform .15s;
  display:inline-flex;align-items:center;
}
.btn-appel:hover{background:var(--yellow2);transform:translateY(-1px)}

/* ══════════════════════════════════
   HERO — Full viewport, photo bg, text left
══════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;
  padding:7rem 2.5rem 4rem;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(10,13,20,.9) 40%,rgba(10,13,20,.5) 100%);
}
.hero-inner{position:relative;z-index:2;max-width:680px}
.hero-label{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:1.2rem;
}
.hero h1{
  font-family:'Montserrat',sans-serif;font-weight:900;
  font-size:clamp(2.4rem,5.5vw,4.2rem);line-height:1.08;
  margin-bottom:1.4rem;
}
.hero h1 .y{color:var(--yellow)}
.hero h1 .w{color:var(--white)}
.hero-sub{
  color:rgba(255,255,255,.7);font-size:.97rem;
  max-width:540px;margin-bottom:2.2rem;line-height:1.75;
}
.hero-ctas{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.btn-sms{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--white);text-decoration:none;
  display:flex;align-items:center;gap:.5rem;
  transition:color .2s;
}
.btn-sms:hover{color:var(--yellow)}
.btn-sms::after{content:'→';transition:transform .2s}
.btn-sms:hover::after{transform:translateX(4px)}

/* ══════════════════════════════════
   STATS BAR — dark photo bg
══════════════════════════════════ */
.stats-bar{
  position:relative;overflow:hidden;
  padding:2.2rem 2.5rem;
  background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.stats-bar-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
}
.stats-bar-cta{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:1rem;color:var(--white);margin-right:auto;
}
.stats-bar-cta span{color:var(--yellow);font-size:1.5rem;font-weight:900;display:block;margin-top:.15rem}
.stat-box{
  border-left:1px solid var(--border);
  padding:.2rem 0 .2rem 2rem;
  min-width:120px;
}
.stat-box .num{
  font-family:'Montserrat',sans-serif;font-weight:900;
  font-size:2.2rem;color:var(--white);line-height:1;
}
.stat-box .lbl{color:var(--muted);font-size:.8rem;margin-top:.2rem}

/* ══════════════════════════════════
   CONTENT SECTION — white bg
══════════════════════════════════ */
.section-white{
  background:#fff;color:#1a1a2e;
  padding:4rem 2.5rem;
}
.section-white .container{max-width:900px;margin:0 auto}
.section-white h2{
  font-family:'Montserrat',sans-serif;font-weight:900;
  font-size:clamp(1.5rem,3vw,2.1rem);color:#1a1a2e;
  margin-bottom:1.2rem;line-height:1.2;
}
.section-white h3{
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:1.2rem;color:#1a1a2e;
  margin:2rem 0 .7rem;display:flex;align-items:center;gap:.5rem;
}
.section-white p{color:#333;margin-bottom:.9rem;font-size:.95rem}
.section-white ul{list-style:none;padding:0;margin:.5rem 0 1rem}
.section-white ul li{
  color:#333;font-size:.92rem;padding:.3rem 0;
  display:flex;align-items:flex-start;gap:.5rem;
}
.section-white ul li::before{content:'💠';flex-shrink:0;font-size:.8rem;margin-top:.15rem}
.section-white a.link{
  color:var(--blue);text-decoration:none;font-weight:600;
  border-bottom:1px solid transparent;transition:border-color .2s;
}
.section-white a.link:hover{border-color:var(--blue)}

/* ══════════════════════════════════
   PAGE HERO (pages internes)
══════════════════════════════════ */
.page-hero{
  position:relative;
  min-height:70vh;display:flex;align-items:flex-end;
  padding:8rem 2.5rem 4rem;overflow:hidden;
}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(10,13,20,.88) 45%,rgba(10,13,20,.45) 100%);
}
.page-hero-inner{position:relative;z-index:2;max-width:700px}
.page-hero-label{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:1rem;
}
.page-hero h1{
  font-family:'Montserrat',sans-serif;font-weight:900;
  font-size:clamp(1.8rem,4.5vw,3.4rem);line-height:1.1;
  margin-bottom:1rem;
}
.page-hero h1 .y{color:var(--yellow)}
.page-hero h1 .w{color:var(--white)}
.page-hero-sub{color:rgba(255,255,255,.65);font-size:.93rem;max-width:560px;margin-bottom:1.8rem}
.page-hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}

/* ══════════════════════════════════
   ARTICLE BODY — dark
══════════════════════════════════ */
.art-wrap{max-width:1100px;margin:0 auto;padding:4rem 2.5rem;display:grid;grid-template-columns:1fr 340px;gap:3rem;align-items:start}
.art-body{min-width:0;overflow:hidden}
.art-body h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.35rem;color:var(--white);margin:2.2rem 0 .8rem;display:flex;align-items:center;gap:.5rem}
.art-body h3{font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.05rem;color:var(--yellow);margin:1.5rem 0 .5rem}
.art-body p{color:var(--muted);font-size:.93rem;margin-bottom:.9rem;line-height:1.8}
.art-body strong{color:var(--white)}
.art-body ul{list-style:none;padding:0;margin:.5rem 0 1rem}
.art-body ul li{color:var(--muted);font-size:.92rem;padding:.3rem 0;display:flex;align-items:flex-start;gap:.5rem}
.art-body ul li::before{content:'💠';flex-shrink:0;font-size:.8rem;margin-top:.15rem}

/* ── Sidebar ── */
.sidebar{position:sticky;top:88px}
.sbox{
  background:var(--bg2);border:1px solid var(--border);
  padding:1.6rem;margin-bottom:1.2rem;
}
.sbox-label{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:1rem;
}
.price-list{list-style:none;padding:0}
.price-list li{
  display:flex;justify-content:space-between;align-items:center;
  padding:.65rem 0;border-bottom:1px solid var(--border);
  font-size:.88rem;color:var(--muted);
}
.price-list li:last-child{border-bottom:none}
.price-list strong{color:var(--yellow);font-family:'Montserrat',sans-serif;font-weight:700}

/* ── Grille avantages ── */
.adv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin:1.2rem 0}
.adv-item{
  background:var(--bg2);border:1px solid var(--border);
  padding:1.1rem 1.2rem;font-size:.88rem;color:var(--muted);
  display:flex;gap:.7rem;align-items:flex-start;
}
.adv-item .ic{font-size:1.1rem;flex-shrink:0;margin-top:.1rem}
.adv-item strong{color:var(--white);display:block;margin-bottom:.2rem}

/* ── Steps ── */
.steps{display:flex;flex-direction:column;gap:1.2rem;margin:1.2rem 0}
.step{display:flex;gap:1rem;align-items:flex-start}
.step-num{
  background:var(--yellow);color:#000;
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-weight:900;font-size:.9rem;
}
.step-content p{color:var(--muted);font-size:.9rem}
.step-content strong{color:var(--white)}

/* ── FAQ ── */
.faq{margin:1.5rem 0}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  padding:1rem 0;cursor:pointer;
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.92rem;color:var(--text);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  user-select:none;transition:color .2s;background:none;border:none;width:100%;text-align:left;
}
.faq-q:hover{color:var(--yellow)}
.faq-a{display:none;padding:.2rem 0 1rem;color:var(--muted);font-size:.88rem;line-height:1.8}
.faq-item.open .faq-a{display:block}
.faq-item.open .faq-q{color:var(--yellow)}
.faq-t{color:var(--yellow);font-size:1.1rem;flex-shrink:0;transition:transform .2s}
.faq-item.open .faq-t{transform:rotate(45deg)}

/* ══════════════════════════════════
   SERVICES GRID (homepage)
══════════════════════════════════ */
.section-dark{padding:4.5rem 2.5rem;background:var(--bg)}
.section-dark .container{max-width:1100px;margin:0 auto}
.section-label{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:.8rem;
}
.section-dark h2{
  font-family:'Montserrat',sans-serif;font-weight:900;
  font-size:clamp(1.6rem,3.5vw,2.4rem);color:var(--white);
  margin-bottom:.6rem;
}
.section-dark h2 span{color:var(--yellow)}
.services-grid{display:flex;flex-wrap:nowrap;border:1px solid var(--border);margin-top:2.5rem;overflow:hidden}
.service-card{
  background:var(--bg2);padding:2rem;
  text-decoration:none;color:inherit;
  transition:background .2s;display:flex;
  flex-direction:column;
  flex:1 1 0;
  min-width:0;
  border-right:1px solid var(--border);
}
.service-card:last-child{border-right:none}
.service-card:hover{background:var(--bg3)}
.service-icon{font-size:2rem;margin-bottom:1rem}
.service-card h3{
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:1.05rem;color:var(--white);margin-bottom:.5rem;
}
.service-card p{color:var(--muted);font-size:.87rem}
.service-card .price{color:var(--yellow);font-weight:700;font-size:.85rem;margin-top:.8rem;font-family:'Montserrat',sans-serif}
.service-card .arrow{
  display:inline-flex;align-items:center;gap:.4rem;
  color:var(--yellow);font-size:.78rem;font-weight:700;
  font-family:'Montserrat',sans-serif;letter-spacing:.06em;text-transform:uppercase;
  margin-top:1rem;
}

/* ══════════════════════════════════
   TESTIMONIALS
══════════════════════════════════ */
.section-darker{padding:4.5rem 2.5rem;background:var(--bg2)}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);margin-top:2.5rem}
.testi-card{background:var(--bg);padding:1.8rem}
.testi-stars{color:var(--yellow);font-size:.9rem;margin-bottom:.8rem;letter-spacing:.05em}
.testi-text{color:var(--muted);font-size:.88rem;line-height:1.75;font-style:italic;margin-bottom:1rem}
.testi-author{font-family:'Montserrat',sans-serif;font-weight:700;font-size:.85rem;color:var(--white)}
.testi-role{color:var(--muted2);font-size:.78rem}

/* ══════════════════════════════════
   CTA BAND
══════════════════════════════════ */
.cta-band{
  background:var(--yellow);padding:3.5rem 2.5rem;
  text-align:center;
}
.cta-band h2{
  font-family:'Montserrat',sans-serif;font-weight:900;
  font-size:clamp(1.5rem,3vw,2rem);color:#000;
  margin-bottom:.5rem;
}
.cta-band p{color:rgba(0,0,0,.7);margin-bottom:2rem;font-size:.95rem}
.cta-band-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-dark{
  background:#000;color:#fff;
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.8rem 2.2rem;text-decoration:none;
  transition:background .2s;
  display:inline-flex;align-items:center;gap:.5rem;
}
.btn-dark:hover{background:#111}
.btn-outline-dark{
  background:transparent;color:#000;
  border:2px solid #000;
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.8rem 2.2rem;text-decoration:none;
  transition:background .2s,color .2s;
  display:inline-flex;align-items:center;
}
.btn-outline-dark:hover{background:#000;color:#fff}

/* ══════════════════════════════════
   ZONES GRID
══════════════════════════════════ */
.zones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.8rem;margin-top:2rem}
.zone-pill{
  background:var(--bg2);border:1px solid var(--border);
  padding:.7rem 1.2rem;text-decoration:none;
  font-family:'Montserrat',sans-serif;font-weight:600;
  font-size:.83rem;color:var(--muted);
  display:flex;align-items:center;gap:.5rem;
  transition:border-color .2s,color .2s;
}
.zone-pill:hover{border-color:var(--yellow);color:var(--yellow)}
.zone-pill::before{content:'📍';font-size:.8rem}

/* ══════════════════════════════════
   BREADCRUMB
══════════════════════════════════ */
.bc{
  padding:.9rem 2.5rem;
  font-size:.78rem;color:var(--muted2);
  max-width:1100px;margin:0 auto;
}
.bc a{color:var(--muted2);text-decoration:none;transition:color .2s}
.bc a:hover{color:var(--yellow)}
.bc-sep{margin:0 .4rem;opacity:.4}

/* ══════════════════════════════════
   BLOG CARDS
══════════════════════════════════ */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:var(--border);border:1px solid var(--border)}
.blog-card{
  background:var(--bg2);padding:1.8rem;
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;gap:.7rem;
  transition:background .2s;
}
.blog-card:hover{background:var(--bg3)}
.blog-cat{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--yellow);
}
.blog-card h3{
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:.98rem;color:var(--white);line-height:1.3;
  margin:0;
}
.blog-card p{color:var(--muted);font-size:.83rem;line-height:1.65;flex:1}
.blog-link{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--yellow);margin-top:.3rem;
}

/* ══════════════════════════════════
   FOOTER
══════════════════════════════════ */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:4rem 2.5rem 2rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto 3rem}
.footer-brand .nav-logo-text{font-size:1.1rem}
.footer-desc{color:var(--muted);font-size:.85rem;margin-top:.8rem;line-height:1.75}
.footer-col h4{
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:1.1rem;
}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul li a{color:var(--muted);text-decoration:none;font-size:.85rem;transition:color .2s}
.footer-col ul li a:hover{color:var(--yellow)}
.footer-bottom{
  border-top:1px solid var(--border);padding-top:1.8rem;
  display:flex;justify-content:space-between;align-items:center;
  max-width:1200px;margin:0 auto;
  color:var(--muted2);font-size:.78rem;flex-wrap:wrap;gap:1rem;
}
.footer-bottom a{color:var(--muted2);text-decoration:none;transition:color .2s}
.footer-bottom a:hover{color:var(--yellow)}

/* ══════════════════════════════════
   MOBILE STICKY CTA
══════════════════════════════════ */
.mob-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:400;
  display:none;
  background:var(--bg2);border-top:1px solid var(--border);
  padding:.8rem 1.5rem;
  justify-content:center;gap:1rem;
}
@media(max-width:768px){
  .mob-cta{display:flex}
  .mob-cta .btn-appel{flex:1;justify-content:center;padding:.75rem}
  .mob-cta .btn-sms-mob{
    flex:1;justify-content:center;
    background:var(--bg3);border:1px solid var(--border);
    font-family:'Montserrat',sans-serif;font-weight:700;
    font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
    color:var(--white);text-decoration:none;
    display:flex;align-items:center;justify-content:center;
  }
}

/* ══════════════════════════════════
   RESPONSIVE
══════════════════════════════════ */
@media(max-width:1024px){
  .art-wrap{grid-template-columns:1fr;gap:2rem}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav{padding:0 1.2rem}
  .hero{padding:6rem 1.2rem 5rem}
  .page-hero{padding:7rem 1.2rem 3rem}
  .section-dark,.section-darker,.section-white{padding:3rem 1.2rem}
  .stats-bar{padding:1.8rem 1.2rem}
  .stats-bar-inner{gap:1.2rem}
  .stat-box{padding:.2rem 0 .2rem 1.2rem}
  .art-wrap{padding:2.5rem 1.2rem}
  .cta-band{padding:3rem 1.2rem}
  .footer-grid{grid-template-columns:1fr}
  .bc{padding:.7rem 1.2rem}
  body{padding-bottom:64px}
}
@media(max-width:480px){
  .hero h1{font-size:2.2rem}
  .services-grid{flex-direction:column}.testi-grid,.blog-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════
   UTILITY
══════════════════════════════════ */
.container{max-width:1100px;margin:0 auto}
.read-progress{position:fixed;top:0;left:0;height:2px;background:var(--yellow);z-index:9999;width:0;transition:width .1s}

/* ══════════════════════════════════
   RESPONSIVE FIXES
══════════════════════════════════ */

/* Fix mob-cta double display:none */
.mob-cta { display: none }
@media(max-width:768px) {
  .mob-cta { display: flex }
}

/* Stats bar mobile — empiler proprement */
@media(max-width:600px) {
  .stats-bar-inner { flex-direction:column; align-items:flex-start; gap:1.5rem }
  .stats-bar-cta { margin-right:0 }
  .stat-box { border-left:none; border-top:1px solid rgba(255,255,255,.08); padding:.8rem 0 0; min-width:0; width:100% }
  .stat-box .num { font-size:1.8rem }
}

/* Hero mobile */
@media(max-width:480px) {
  .hero { min-height:90vh; padding:5.5rem 1rem 6rem }
  .hero h1 { font-size:2rem; line-height:1.1 }
  .hero-ctas { flex-direction:column; gap:.8rem }
  .hero-ctas .btn-appel, .hero-ctas .btn-sms { width:100%; justify-content:center; text-align:center }
  .page-hero { padding:6rem 1rem 2.5rem; min-height:50vh }
  .page-hero h1 { font-size:1.7rem }
}

/* Article sidebar mobile — mettre la sidebar AVANT le contenu sur mobile */
@media(max-width:1024px) {
  .art-wrap { grid-template-columns:1fr; gap:0 }
  .sidebar { order:-1; margin-bottom:2rem }
  .art-body { order:1 }
  /* Sur mobile sidebar: affichage horizontal pour les tarifs */
  .sbox { padding:1.2rem }
}
@media(max-width:600px) {
  .art-wrap { padding:2rem 1rem }
  .price-list { display:grid; grid-template-columns:1fr 1fr; gap:.5rem }
  .price-list li { border:1px solid rgba(255,255,255,.08); padding:.6rem; flex-direction:column; gap:.2rem }
}

/* Blog grid mobile */
@media(max-width:600px) {
  .blog-grid { grid-template-columns:1fr }
  .blog-card { padding:1.4rem }
}

/* Services grid mobile */
@media(max-width:600px) {
  .services-grid { flex-direction:column }
  .testi-grid { grid-template-columns:1fr }
}

/* Footer mobile */
@media(max-width:480px) {
  footer { padding:3rem 1rem 2rem }
  .footer-grid { gap:2rem }
  .footer-bottom { flex-direction:column; text-align:center; gap:.8rem }
}

/* Nav menu padding mobile */
@media(max-width:480px) {
  .nav-menu { padding:1rem 1.2rem 1.5rem }
}

/* Section padding mobile */
@media(max-width:480px) {
  .section-dark, .section-darker { padding:2.5rem 1rem }
  .section-white { padding:2.5rem 1rem }
  .cta-band { padding:2.5rem 1rem }
  .bc { padding:.7rem 1rem }
}

/* Zones grid mobile */
@media(max-width:480px) {
  .zones-grid { grid-template-columns:repeat(2,1fr) }
}

/* Adv grid mobile */
@media(max-width:480px) {
  .adv-grid { grid-template-columns:1fr }
}

/* See-also grid mobile */
.see-also-grid { display:grid; gap:.8rem; margin-top:1rem }
@media(max-width:480px) {
  .see-also-grid { grid-template-columns:1fr 1fr !important }
}
.see-also-card {
  background:var(--bg2); border:1px solid var(--border);
  padding:.8rem 1rem; text-decoration:none; display:flex;
  flex-direction:column; gap:.2rem; transition:border-color .2s;
}
.see-also-card:hover { border-color:var(--yellow) }
.see-also-card strong { color:var(--white); font-size:.88rem; font-family:'Montserrat',sans-serif }
.see-also-card span { color:var(--muted); font-size:.78rem }
.see-also-label { font-family:'Montserrat',sans-serif; font-weight:700; font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--yellow); margin-bottom:.5rem }

/* ══════════════════════════════════
   NAV ACTIVE LINK
══════════════════════════════════ */
.nav-menu a.active-page { color:var(--yellow) !important }

/* ══════════════════════════════════
   BLOG FILTER DYNAMIQUE
══════════════════════════════════ */
.blog-filters {
  display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:2rem;
}
.blog-filter-btn {
  font-family:'Montserrat',sans-serif; font-weight:700;
  font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  background:var(--bg2); border:1px solid var(--border);
  color:var(--muted); padding:.5rem 1.2rem; cursor:pointer;
  transition:all .2s;
}
.blog-filter-btn:hover, .blog-filter-btn.active {
  border-color:var(--yellow); color:var(--yellow);
}
.blog-card[hidden] { display:none }

/* ══════════════════════════════════
   BLOG SEARCH
══════════════════════════════════ */
.blog-search-wrap {
  position:relative; margin-bottom:2rem;
}
.blog-search {
  width:100%; background:var(--bg2); border:1px solid var(--border);
  color:var(--text); padding:.8rem 1rem .8rem 2.8rem;
  font-family:'Open Sans',sans-serif; font-size:.9rem;
  outline:none; transition:border-color .2s;
}
.blog-search:focus { border-color:var(--yellow) }
.blog-search-icon {
  position:absolute; left:.9rem; top:50%; transform:translateY(-50%);
  color:var(--muted); pointer-events:none;
}
.blog-no-results {
  text-align:center; padding:3rem; color:var(--muted);
  font-family:'Montserrat',sans-serif; display:none;
}

/* ══════════════════════════════════
   PAGE TRANSITIONS
══════════════════════════════════ */
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(16px) }
  to   { opacity:1; transform:translateY(0) }
}
.fade-in { animation: fadeInUp .45s ease both }
.fade-in-1 { animation-delay:.05s }
.fade-in-2 { animation-delay:.12s }
.fade-in-3 { animation-delay:.2s }

/* ══════════════════════════════════
   SCROLL ANIMATIONS
══════════════════════════════════ */
[data-reveal] {
  opacity:0; transform:translateY(20px);
  transition:opacity .5s ease, transform .5s ease;
}
[data-reveal].revealed {
  opacity:1; transform:translateY(0);
}


/* ══ ICÔNES SVG PRO ══ */
.ico { display:inline-flex; align-items:center; vertical-align:middle; flex-shrink:0 }
.ico svg { display:block }
.ico-y svg { stroke: var(--yellow) }
.ico-w svg { stroke: var(--white) }
.ico-k svg { stroke: #000 }
h2 .ico, h3 .ico { margin-right:.5rem }
.btn-appel .ico, .btn-dark .ico { margin-right:.4rem }

/* ══ FAQ LISIBILITÉ ══ */
.section-dark .faq-a,
.section-dark .faq-q { color: var(--text) }
.section-dark .faq-a { color: rgba(232,234,240,.85) }
.section-dark .faq-item { border-color: rgba(255,255,255,.12) }

/* ══ BOUTON MESSAGE STICKY ══ */
.msg-bubble {
  position: fixed;
  bottom: 84px;
  right: 1.4rem;
  z-index: 450;
  background: var(--yellow);
  color: #000;
  border-radius: 50px;
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .65rem 1.1rem;
  text-decoration: none;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .78rem;
  letter-spacing: .05em;
  box-shadow: 0 4px 20px rgba(255,193,7,.35);
  transition: transform .2s, box-shadow .2s;
  white-space: nowrap;
}
.msg-bubble:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(255,193,7,.5);
}
.msg-bubble svg { flex-shrink: 0 }
@media(max-width:768px) {
  .msg-bubble { bottom: 72px; padding: .6rem .9rem; font-size: .72rem }
}

/* ══ CONTACT DIRECT (sans form) ══ */
.contact-direct {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 480px;
  margin: 2rem auto;
}
.contact-direct-label {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: .5rem;
}
.contact-btn {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.2rem 1.6rem;
  text-decoration: none;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  border-radius: 2px;
  transition: transform .15s, box-shadow .15s;
}
.contact-btn:hover { transform: translateY(-2px) }
.contact-btn-tel {
  background: var(--yellow);
  color: #000;
}
.contact-btn-wa {
  background: var(--yellow);
  color: #fff;
}
.contact-info-txt {
  color: var(--muted);
  font-size: .82rem;
  text-align: center;
  margin-top: .5rem;
}

/* ══ ADV-ITEM icône (pas emoji) ══ */
.adv-item .ico { margin-top: .1rem }

/* ══ FAQ sur fond blanc ══ */
.section-white .faq-q {
  color: #1a1a2e;
  border-bottom-color: rgba(26,26,46,.12);
}
.section-white .faq-q:hover { color: #c8970a }
.section-white .faq-item.open .faq-q { color: #c8970a }
.section-white .faq-a {
  color: #333;
}
.section-white .faq-item { border-bottom-color: rgba(26,26,46,.1) }
.section-white .faq-t { color: #FFC107 }

/* ══ Service icon SVG couleur jaune ══ */
.service-icon svg { stroke: var(--yellow) }

/* ══ Images voiture dans sections ══ */
.car-visual {
  width: 100%;
  height: 320px;
  object-fit: cover;
  display: block;
  margin: 2.5rem 0;
}
.car-visual-sm {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  margin: 1.5rem 0;
}
.img-caption {
  font-size: .78rem;
  color: var(--muted2);
  text-align: center;
  margin-top: -.5rem;
  margin-bottom: 1.5rem;
  font-style: italic;
}
/* Hero split layout avec image */
.hero-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
}
.hero-split-img {
  position: relative;
  overflow: hidden;
}
.hero-split-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media(max-width:900px) {
  .hero-split { grid-template-columns: 1fr }
  .hero-split-img { height: 240px }
}

.ico svg { stroke-width: 2 !important }
.service-icon svg { stroke-width: 1.5 !important }

/* ══ IMAGES CONTENU SERVICE ══ */
.content-img-wrap {
  margin: 2.5rem 0;
  overflow: hidden;
  border-radius: 2px;
  background: var(--bg2);
}
.content-img-wrap img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  object-position: center 30%;
  display: block;
  transition: transform .5s ease;
}
.content-img-wrap:hover img { transform: scale(1.03) }
.content-img-cap {
  font-size: .72rem;
  color: var(--muted2);
  padding: .5rem .8rem;
  font-style: italic;
  background: var(--bg2);
  border-top: 1px solid var(--border);
}
@media(max-width:768px) {
  .content-img-wrap img { height: 200px }
}
@media(max-width:480px) {
  .content-img-wrap img { height: 160px }
}

/* ══ BLOG REFAIT ══ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
  margin-top: 1.5rem;
}
.blog-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition: border-color .2s, transform .2s;
  overflow: hidden;
}
.blog-card:hover {
  border-color: var(--yellow);
  transform: translateY(-2px);
}
.blog-card-img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .4s ease;
}
.blog-card:hover .blog-card-img { transform: scale(1.04) }
.blog-card-body {
  padding: 1.4rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  flex: 1;
}
.blog-cat {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .62rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--yellow);
}
.blog-card h3 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: .95rem;
  color: var(--white);
  line-height: 1.35;
  margin: 0;
}
.blog-card p {
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.65;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.blog-link {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-top: .5rem;
  display: flex;
  align-items: center;
  gap: .3rem;
}
.blog-link::after { content: '→'; transition: transform .2s }
.blog-card:hover .blog-link::after { transform: translateX(4px) }

/* Hero blog amélioré */
.blog-hero-filters {
  padding: 2rem 2.5rem 0;
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}
.blog-count {
  font-size: .82rem;
  color: var(--muted);
  margin-left: auto;
  font-family: 'Montserrat', sans-serif;
}
@media(max-width:600px) {
  .blog-grid { grid-template-columns: 1fr; gap: 1rem }
  .blog-card-img { height: 130px }
  .blog-hero-filters { padding: 1.5rem 1rem 0 }
}

/* ══ BLOG CARD THUMBNAILS GRADIENT ══ */
.blog-card-thumb {
  height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}
.blog-card-thumb-reprog {
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
  border-bottom: 3px solid var(--yellow);
}
.blog-card-thumb-adblue {
  background: linear-gradient(135deg, #0a0d14 0%, #1a2744 50%, #1e3a5f 100%);
  border-bottom: 3px solid #4a9eff;
}
.blog-card-thumb-egr {
  background: linear-gradient(135deg, #1a0a0a 0%, #3d1515 50%, #5c1e1e 100%);
  border-bottom: 3px solid #ff4444;
}
.blog-card-thumb-fap {
  background: linear-gradient(135deg, #0a1a0a 0%, #143d14 50%, #1a5c1a 100%);
  border-bottom: 3px solid #44cc44;
}
.blog-card-thumb-legal {
  background: linear-gradient(135deg, #1a1510 0%, #3d2e15 50%, #5c4520 100%);
  border-bottom: 3px solid #ffaa00;
}
.blog-card-thumb svg {
  opacity: .35;
  width: 60px;
  height: 60px;
}
.blog-card-thumb-label {
  position: absolute;
  bottom: .6rem;
  left: .8rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
}

/* ══ SÉPARATEURS IMAGES HOMEPAGE ══ */
.service-sep-img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  object-position: center;
  display: block;
  margin: 2.5rem 0;
  filter: brightness(.85);
  transition: filter .3s;
}
.service-sep-img:hover { filter: brightness(1) }
@media(max-width:768px) {
  .service-sep-img { height: 200px; margin: 1.5rem 0 }
}
