/* Poppins chargée via <link> dans le HTML — plus rapide */

/* ============================================================
   CORNER MOBILE — Palette fidèle au logo
   Bleu  #03A0D6 : navigation, prix, structure
   Vert  #53AE17 : boutons RDV, badges action, bande stats
   ============================================================ */
:root {
  /* Bleu logo */
  --blue:        #026a90;
  --blue-dark:   #01506e;
  --blue-light:  #e5f6fd;
  --blue-mid:    #a8ddf2;

  /* Vert logo */
  --green:       #026a90;
  --green-dark:  #01506e;
  --green-light: #e5f6fd;
  --green-mid:   #a8ddf2;

  /* Neutres */
  --white:       #ffffff;
  --gray-50:     #f7fafc;
  --gray-100:    #eef2f7;
  --gray-200:    #dde6ef;
  --gray-400:    #8fa8bc;
  --gray-600:    #4d6a80;
  --gray-800:    #1e3545;
  --black:       #0d1e2a;

  --font: 'Poppins', system-ui, sans-serif;
  --r-sm:4px; --r-md:12px; --r-lg:20px; --r-xl:32px;
  --sh-sm:0 1px 4px rgba(0,0,0,.07);
  --sh-md:0 4px 18px rgba(0,0,0,.09);
  --sh-lg:0 8px 36px rgba(0,0,0,.11);
  --sh-blue: 0 4px 20px rgba(3,160,214,.20);
  --sh-green:0 4px 20px rgba(3,160,214,.22);
  --max-w:1376px; --hdr-h:84px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html{overflow-x:hidden;max-width:100%}
body{font-family:var(--font);color:var(--gray-800);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100%}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none;text-underline-offset:3px}
a:hover{color:var(--blue-dark)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;font-family:inherit}
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}
.header-inner.container,.container.header-inner{max-width:100%;padding:0 24px;width:100%}
.hero .container.hero-inner,.hero .hero-inner.container{max-width:1500px;padding:0 40px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.text-blue{color:var(--blue)}
.text-green{color:var(--green)}

/* ── TOPBAR — bleu ── */
.topbar{background:var(--blue);color:#fff;font-size:.75rem;font-weight:500;padding:7px 20px}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px;max-width:var(--max-w);margin:0 auto}
.topbar a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.topbar-promo,.topbar-tel,.topbar-mail{display:flex;align-items:center;gap:5px}

/* ── HEADER ── */
.site-header{position:sticky;top:0;z-index:200;background:var(--white);border-bottom:1px solid var(--gray-200);box-shadow:var(--sh-sm);overflow:visible}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--hdr-h);gap:16px}
.site-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;padding:12px 0}
.logo-img{height:60px;width:auto;object-fit:contain}
.logo-fallback{display:flex;flex-direction:column}
.logo-name{font-size:1rem;font-weight:800;color:var(--blue);line-height:1.1}
.logo-tagline{font-size:.58rem;font-weight:600;color:var(--gray-600);letter-spacing:.06em;text-transform:uppercase}
.header-search{display:none !important}
.header-search input{width:300px;padding:7px 34px 7px 12px;border:1.5px solid var(--gray-200);border-radius:var(--r-xl);font-size:.8rem;font-family:var(--font);background:var(--gray-50);outline:none;transition:border-color .15s}
.header-search input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(3,160,214,.12)}
.header-search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;color:var(--gray-400);padding:0}

/* ── HAMBURGER ── */
.menu-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;padding:8px;border-radius:var(--r-sm);width:38px;height:38px}
.menu-toggle span{display:block;height:2px;background:var(--gray-800);border-radius:2px;transition:all .2s}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-rdv-mob{display:block;margin:20px 20px 0;background:var(--green);color:#fff!important;border-radius:var(--r-md);text-align:center;padding:13px;font-weight:700;font-size:.9rem}

/* ── LOCAL STRIP — bleu clair ── */
.local-strip{background:var(--blue-light);border-bottom:1px solid var(--blue-mid);padding:9px 0}
.local-strip-inner{display:flex;flex-wrap:wrap;gap:10px 18px;font-size:.73rem;font-weight:600;color:var(--gray-600)}
.local-strip-inner span{display:flex;align-items:center;gap:5px}

/* ── BREADCRUMB ── */
.breadcrumb{background:var(--gray-50);border-bottom:1px solid var(--gray-100);padding:9px 0}
.breadcrumb ol{display:flex;flex-wrap:wrap;align-items:center;gap:4px;font-size:.7rem;color:var(--gray-600)}
.breadcrumb a{color:var(--gray-600);font-weight:500}
.breadcrumb a:hover{color:var(--blue)}
.breadcrumb li+li::before{content:"›";margin-right:4px}
.breadcrumb li:last-child{color:var(--gray-800);font-weight:600}

/* ── HERO ── */
.hero-model{background:linear-gradient(135deg,var(--blue-light) 0%,var(--white) 65%);padding:40px 0 32px;border-bottom:1px solid var(--blue-mid)}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--blue);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;border-radius:var(--r-xl);margin-bottom:12px}
.hero-model h1{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;color:var(--gray-800);line-height:1.2;margin-bottom:12px}
.hero-model h1 span{color:var(--blue)}
.hero-subtitle{font-size:.9rem;color:var(--gray-600);line-height:1.7;max-width:600px;margin-bottom:16px}
.hero-price-badge{display:inline-flex;align-items:baseline;gap:8px;background:var(--green-light);border:1.5px solid var(--green-mid);border-radius:var(--r-md);padding:10px 20px;margin-bottom:16px}
.price-from{font-size:.72rem;color:var(--gray-600);font-weight:500}
.price-main{font-size:1.9rem;font-weight:800;color:var(--green)}
.price-label{font-size:.72rem;color:var(--gray-600);font-weight:500}
.hero-guarantees{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.guarantee-pill{display:flex;align-items:center;gap:6px;background:var(--white);border:1.5px solid var(--blue-mid);border-radius:var(--r-xl);padding:5px 12px;font-size:.74rem;font-weight:600;color:var(--gray-800);box-shadow:var(--sh-sm)}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}

/* ── BOUTONS ── */
.btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:var(--font);font-weight:600;font-size:.86rem;padding:12px 22px;border-radius:var(--r-md);cursor:pointer;transition:all .15s;text-decoration:none;border:2px solid transparent}
/* Vert = action principale */
.btn-primary{background:var(--green);color:#fff;box-shadow:var(--sh-green)}
.btn-primary:hover{background:var(--green-dark);color:#fff;transform:translateY(-1px)}
/* Bleu = action secondaire */
.btn-outline{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-outline:hover{background:var(--blue-light)}
.btn-tel{background:var(--gray-800);color:#fff}
.btn-tel:hover{background:var(--black);color:#fff}
.btn-sm{font-size:.78rem;padding:8px 16px}
.btn-lg{font-size:.92rem;padding:14px 28px}
.btn-white{background:#fff;color:var(--green);font-weight:700}
.btn-tel-white{background:rgba(255,255,255,.15);color:#fff !important;border:2px solid rgba(255,255,255,.5)}
.btn-tel-white svg{stroke:#fff}

/* ── TARIFS ── */
.tarifs-section{padding:48px 0}
.section-header{margin-bottom:28px}
.section-title{font-size:clamp(1.1rem,2.5vw,1.55rem);font-weight:800;color:var(--gray-800);margin-bottom:6px}
.section-title span{color:var(--blue)}
.section-subtitle{font-size:.82rem;color:var(--gray-600)}
.repair-type-nav{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.repair-type-link{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-md);font-size:.82rem;font-weight:600;color:var(--gray-600);text-decoration:none;transition:all .14s}
.repair-type-link:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}
.repair-type-link.active{border-color:var(--green);background:var(--green);color:#fff}
.repair-type-link.active svg{stroke:#fff}
.tarif-main-card{display:flex;flex-direction:column;gap:24px;background:var(--white);border:2px solid var(--blue-mid);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-blue)}
@media(min-width:640px){.tarif-main-card{flex-direction:row;align-items:flex-start}}
.tarif-main-left{display:flex;align-items:flex-start;gap:18px;flex:1}
.tarif-main-icon{width:60px;height:60px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--blue-light);border-radius:var(--r-md);color:var(--blue)}
.tarif-main-title{font-size:.96rem;font-weight:700;color:var(--gray-800);margin-bottom:7px}
.tarif-main-desc{font-size:.78rem;color:var(--gray-600);line-height:1.6;margin-bottom:12px}
.tarif-includes{display:grid;gap:5px}
.tarif-includes li{display:flex;align-items:center;gap:7px;font-size:.78rem;font-weight:500;color:var(--gray-600)}
.tarif-includes li svg{stroke:var(--green);flex-shrink:0}
.tarif-main-right{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:150px;border-top:1.5px solid var(--blue-light);padding-top:20px}
@media(min-width:640px){.tarif-main-right{border-top:none;border-left:1.5px solid var(--blue-light);padding-top:0;padding-left:24px}}
.tarif-main-price{font-size:2.2rem;font-weight:800;color:var(--blue);line-height:1}
.tarif-main-price span{font-size:1.2rem}
.tarif-main-delay{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:600;color:var(--gray-400);background:var(--gray-100);padding:3px 10px;border-radius:var(--r-xl)}
.tarifs-grid{display:grid;gap:14px}
.tarif-card{display:flex;align-items:flex-start;gap:14px;background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-sm);transition:border-color .15s,box-shadow .15s,transform .15s}
.tarif-card:hover{border-color:var(--blue);box-shadow:var(--sh-blue);transform:translateY(-2px)}
.tarif-card.diagnostic-card{background:var(--blue-light);border-color:var(--blue-mid)}
.tarif-icon{width:46px;height:46px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--blue-light);border-radius:var(--r-md);color:var(--blue)}
.tarif-info{flex:1}
.tarif-name{font-weight:700;font-size:.88rem;color:var(--gray-800);margin-bottom:3px}
.tarif-desc{font-size:.74rem;color:var(--gray-600);line-height:1.5}
.tarif-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.tarif-price{font-size:1.25rem;font-weight:800;color:var(--blue)}
.tarif-price.free{color:var(--gray-600);font-size:.92rem}
.tarif-delay{font-size:.66rem;color:var(--gray-400);font-weight:600;background:var(--gray-100);padding:2px 8px;border-radius:var(--r-xl)}
.tarif-cta{font-size:.72rem;font-weight:700;color:var(--green);border:1.5px solid var(--green-mid);border-radius:var(--r-sm);padding:4px 10px;background:var(--green-light);white-space:nowrap;text-decoration:none;transition:background .12s}
.tarif-cta:hover{background:var(--green-mid)}

/* ── REASSURANCE ── */
.reassurance{background:var(--gray-800);color:#fff;padding:28px 0}
.reassurance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:768px){.reassurance-grid{grid-template-columns:repeat(4,1fr)}}
.reassurance-item{display:flex;align-items:flex-start;gap:12px}
.reassurance-icon{flex-shrink:0;color:#fff}
.reassurance-item strong{display:block;font-size:.83rem;font-weight:700;margin-bottom:2px}
.reassurance-item p{font-size:.72rem;opacity:.72;line-height:1.5}

/* ── CONTENT SEO ── */
.content-seo{padding:52px 0;background:var(--gray-50)}
.content-seo-inner{max-width:820px}
.content-block h2{font-size:clamp(1.1rem,2.5vw,1.45rem);font-weight:800;color:var(--gray-800);margin-bottom:16px;line-height:1.3}
.content-block h3{font-size:.95rem;font-weight:700;color:var(--gray-800);margin:22px 0 10px}
.content-block p{font-size:.86rem;color:var(--gray-600);line-height:1.8;margin-bottom:12px}
.content-list{display:grid;gap:7px;margin:10px 0 16px}
.content-list li{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;color:var(--gray-600);line-height:1.6}
ul.content-list li::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);margin-top:8px;flex-shrink:0}
ol.content-list{counter-reset:item}
ol.content-list li{counter-increment:item}
ol.content-list li::before{content:counter(item);display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--green);color:#fff;font-size:.66rem;font-weight:700;flex-shrink:0;margin-top:2px}

/* ── RELATED ── */
.related-repairs{padding:44px 0}
.related-grid{display:grid;gap:14px;grid-template-columns:1fr;margin-top:24px}
@media(min-width:600px){.related-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.related-grid{grid-template-columns:repeat(3,1fr)}}
.related-card{display:flex;align-items:center;gap:16px;background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-lg);padding:20px;text-decoration:none;color:inherit;box-shadow:var(--sh-sm);transition:border-color .14s,box-shadow .14s,transform .14s}
.related-card:hover{border-color:var(--green);box-shadow:var(--sh-green);transform:translateY(-2px)}
.related-icon{width:50px;height:50px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--blue-light);border-radius:var(--r-md);color:var(--blue)}
.related-card h3{font-size:.84rem;font-weight:700;color:var(--gray-800);margin-bottom:3px}
.related-card p{font-size:.74rem;color:var(--gray-600);margin-bottom:4px}
.related-price{font-size:1rem;font-weight:800;color:var(--green)}
.related-arrow{margin-left:auto;flex-shrink:0;color:var(--gray-600)}
.related-card:hover .related-arrow{color:var(--green)}

/* ── OTHER MODELS ── */
.other-models{padding:44px 0}
.models-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:10px;scrollbar-width:thin;scrollbar-color:var(--blue-mid) transparent;-webkit-overflow-scrolling:touch;margin-top:20px}
.models-scroll::-webkit-scrollbar{height:3px}
.models-scroll::-webkit-scrollbar-thumb{background:var(--blue-mid);border-radius:2px}
.model-chip{flex-shrink:0;display:block;padding:7px 15px;background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-xl);font-size:.76rem;font-weight:600;color:var(--gray-800);white-space:nowrap;transition:all .14s;text-decoration:none}
.model-chip:hover,.model-chip.active{background:var(--green);color:#fff;border-color:var(--green)}

/* ── FAQ ── */
.faq-section{padding:48px 0;background:var(--gray-50)}
.faq-list{display:grid;gap:10px;margin-top:28px}
.faq-item{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-md);overflow:hidden}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:none;font-family:var(--font);font-size:.84rem;font-weight:600;color:var(--gray-800);text-align:left;gap:12px}
.faq-question:hover{background:var(--blue-light)}
.faq-chevron{flex-shrink:0;transition:transform .2s;color:var(--blue)}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-answer{display:none;padding:0 20px 16px;font-size:.81rem;color:var(--gray-600);line-height:1.7}
.faq-item.open .faq-answer{display:block}

/* ── RDV BAND — vert ── */
.rdv-band{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);padding:44px 0;text-align:center;color:#fff;width:100%;box-sizing:border-box;position:relative;left:0;right:0}
.rdv-band h2{font-size:clamp(1.1rem,3vw,1.75rem);font-weight:800;margin-bottom:8px}
.rdv-band p{font-size:.86rem;opacity:.9;margin-bottom:22px}

/* ── FOOTER ── */
.site-footer{background:var(--gray-800);color:#fff;padding:48px 0 24px}
.footer-grid{display:grid;gap:32px;grid-template-columns:1fr}
@media(min-width:600px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr 1fr}}
.footer-brand .logo-name{color:#fff}
.footer-brand .logo-tagline{color:rgba(255,255,255,.55)}
.footer-desc{font-size:.76rem;color:rgba(255,255,255,.6);line-height:1.7;margin-top:10px;max-width:260px}
.footer-col h3{font-size:.72rem;font-weight:700;color:var(--green-mid);margin-bottom:12px;text-transform:uppercase;letter-spacing:.06em}
.footer-col ul{display:grid;gap:6px}
.footer-col a{font-size:.76rem;color:rgba(255,255,255,.65);transition:color .14s}
.footer-col a:hover{color:#fff}
.footer-contact{font-size:.76rem;color:rgba(255,255,255,.65);line-height:2}
.footer-contact strong,.footer-contact a{color:#fff}
.footer-bottom{border-top:none;margin-top:36px;padding:20px 0 0;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;font-size:.8rem;color:rgba(255,255,255,.7);width:100%;position:relative}
.footer-bottom::before{content:'';display:block;position:absolute;top:0;left:calc(-50vw + 50%);width:100vw;height:1px;background:rgba(255,255,255,.15)}
.footer-bottom a{color:#ffffff;font-weight:700}
.footer-bottom a:hover{color:var(--blue)}

/* ── SEARCH ── */
.search-section{background:var(--white);padding:22px 0;border-bottom:1px solid var(--gray-100)}
.search-box{display:flex;max-width:560px;background:var(--white);border:2px solid var(--blue);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-blue)}
.search-box input{flex:1;padding:11px 18px;border:none;outline:none;font-size:.88rem;font-family:var(--font);background:transparent}
.search-box button{background:var(--blue);color:#fff;padding:0 18px;font-weight:700;font-size:.82rem;white-space:nowrap;display:flex;align-items:center;gap:6px;transition:background .14s}
.search-box button:hover{background:var(--blue-dark)}
.search-results{display:none;background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-md);box-shadow:var(--sh-md);max-height:260px;overflow-y:auto;margin-top:8px;max-width:560px}
.search-results.visible{display:block}
.search-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--gray-100);font-size:.82rem;text-decoration:none;color:inherit;transition:background .12s}
.search-item:hover{background:var(--blue-light)}
.search-item:last-child{border-bottom:none}
.search-item-name{font-weight:600;color:var(--gray-800)}
.search-item-price{color:var(--green);font-weight:700;white-space:nowrap;margin-left:12px}

/* ── RESPONSIVE ── */
@media(min-width:768px){.tarifs-grid{grid-template-columns:1fr 1fr 1fr}}
@media(min-width:1024px){.menu-toggle{display:none}.tarifs-grid{grid-template-columns:repeat(3,1fr)}.header-inner,.header-inner.container,.container.header-inner{display:flex !important;height:var(--hdr-h) !important;padding:0 24px !important;align-items:center !important;max-width:100% !important;width:100% !important;position:static !important}.site-logo{position:static !important;transform:none !important;left:auto !important;order:unset !important;padding:12px 0 !important}.menu-toggle{display:none !important}.logo-img{height:60px !important}.header-actions{margin-left:0 !important;order:unset !important}.main-nav{display:flex !important}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition:none!important;animation:none!important}}
:focus-visible{outline:3px solid var(--green);outline-offset:2px}


/* ── COMPOSANTS PAGES HUB ── */
/* ── Styles spécifiques à cette page ── */
    .repair-choices { padding: 48px 0; background: var(--white); }
    .repair-choices-grid {
      display: grid; gap: 20px;
      grid-template-columns: 1fr;
      margin-top: 32px;
    }
    @media(min-width:640px){ .repair-choices-grid { grid-template-columns: repeat(3,1fr); } }

    .repair-card {
      display: flex; flex-direction: column;
      background: var(--white);
      border: 2px solid var(--gray-200);
      border-radius: var(--r-lg);
      padding: 28px 24px 24px;
      text-decoration: none; color: inherit;
      box-shadow: var(--sh-sm);
      transition: border-color .18s, box-shadow .18s, transform .18s;
      position: relative; overflow: hidden;
    }
    .repair-card::before {
      content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
      background: var(--blue); transform: scaleX(0); transition: transform .2s;
      transform-origin: left;
    }
    .repair-card:hover { border-color: var(--blue); box-shadow: var(--sh-blue); transform: translateY(-4px); }
    .repair-card:hover::before { transform: scaleX(1); }

    .repair-card-icon {
      width: 56px; height: 56px; border-radius: var(--r-md);
      background: var(--blue-light); display: flex; align-items: center; justify-content: center;
      color: var(--blue); margin-bottom: 18px;
    }
    .repair-card-label {
      font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
      color: var(--blue); margin-bottom: 6px;
    }
    .repair-card h3 { font-size: 1.05rem; font-weight: 800; color: var(--gray-800); margin-bottom: 10px; }
    .repair-card p { font-size: .82rem; color: var(--gray-600); line-height: 1.6; flex: 1; margin-bottom: 20px; }
    .repair-card-symptoms { display: grid; gap: 5px; margin-bottom: 20px; }
    .repair-card-symptoms li {
      display: flex; align-items: flex-start; gap: 7px;
      font-size: .78rem; color: var(--gray-600);
    }
    .repair-card-symptoms li::before {
      content: ''; width: 5px; height: 5px; border-radius: 50%;
      background: var(--blue); flex-shrink: 0; margin-top: 6px;
    }
    .repair-card-price-block {
      border-top: 1.5px solid var(--gray-100); padding-top: 16px;
      display: flex; align-items: center; justify-content: space-between;
    }
    .repair-card-price { font-size: 1.6rem; font-weight: 800; color: var(--blue); }
    .repair-card-price small { font-size: .72rem; font-weight: 500; color: var(--gray-600); display: block; }
    .repair-card-cta {
      background: var(--blue); color: #fff; border-radius: var(--r-md);
      padding: 10px 16px; font-size: .8rem; font-weight: 700;
      display: flex; align-items: center; gap: 6px;
      transition: background .14s;
    }
    .repair-card:hover .repair-card-cta { background: var(--blue-dark); }

    .repair-card-featured {
      border-color: var(--blue); box-shadow: var(--sh-blue);
    }
    .repair-card-featured::before { transform: scaleX(1); }
    .repair-card-badge {
      position: absolute; top: 16px; right: 16px;
      background: var(--blue); color: #fff;
      font-size: .62rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
      padding: 3px 8px; border-radius: var(--r-xl);
    }

    /* Stats band */
    .stats-band { background: var(--blue); color: #fff; padding: 28px 0; }
    .stats-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
    @media(min-width:640px){ .stats-grid { grid-template-columns: repeat(4,1fr); } }
    .stat-item { text-align: center; }
    .stat-number { font-size: 1.8rem; font-weight: 800; display: block; line-height: 1; }
    .stat-label { font-size: .76rem; opacity: .85; margin-top: 4px; display: block; }

    /* Pourquoi nous */
    .why-us { padding: 52px 0; background: var(--gray-50); }
    .why-grid { display: grid; gap: 20px; margin-top: 32px; grid-template-columns: 1fr; }
    @media(min-width:640px){ .why-grid { grid-template-columns: repeat(2,1fr); } }
    @media(min-width:1024px){ .why-grid { grid-template-columns: repeat(3,1fr); } }
  @media(min-width:1280px){ .why-grid { grid-template-columns: repeat(4,1fr); } }
    .why-card {
      background: var(--white); border: 1.5px solid var(--gray-200);
      border-radius: var(--r-lg); padding: 24px;
      box-shadow: var(--sh-sm);
    }
    .why-card-icon {
      width: 46px; height: 46px; background: var(--blue-light);
      border-radius: var(--r-md); display: flex; align-items: center; justify-content: center;
      color: var(--blue); margin-bottom: 14px;
    }
    .why-card h3 { font-size: .92rem; font-weight: 700; color: var(--gray-800); margin-bottom: 8px; }
    .why-card p { font-size: .8rem; color: var(--gray-600); line-height: 1.65; }

    /* Other models in same series */
    .serie-nav { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
    .serie-chip {
      display: flex; align-items: center; gap: 8px;
      background: var(--white); border: 1.5px solid var(--gray-200);
      border-radius: var(--r-lg); padding: 10px 16px;
      text-decoration: none; font-size: .8rem; font-weight: 600; color: var(--gray-800);
      transition: all .14s; box-shadow: var(--sh-sm);
    }
    .serie-chip:hover { border-color: var(--blue); color: var(--blue); background: var(--blue-light); }
    .serie-chip.active { border-color: var(--blue); background: var(--blue); color: #fff; }
    .serie-chip-price { font-size: .72rem; opacity: .75; }
.hub-hero { background: linear-gradient(135deg, var(--blue-light) 0%, #fff 65%); padding: 44px 0 36px; border-bottom: 1px solid var(--blue-mid); }
    .hub-hero h1 { font-size: clamp(1.6rem,4vw,2.4rem); font-weight: 800; color: var(--gray-800); margin-bottom: 14px; }
    .hub-hero h1 span { color: var(--blue); }
    .hub-hero p { font-size: .92rem; color: var(--gray-600); line-height: 1.7; max-width: 680px; margin-bottom: 20px; }

    /* Filtre série */
    .series-filter { background: var(--white); border-bottom: 1px solid var(--gray-100); padding: 14px 0; position: sticky; top: var(--hdr-h); z-index: 50; }
    .series-filter-scroll { display: flex; gap: 8px; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; padding-bottom: 2px; }
    .series-filter-scroll::-webkit-scrollbar { display: none; }
    .series-btn { flex-shrink: 0; padding: 7px 14px; background: var(--gray-100); border: none; border-radius: var(--r-xl); font-size: .76rem; font-weight: 600; color: var(--gray-600); cursor: pointer; transition: all .14s; font-family: var(--font); white-space: nowrap; }
    .series-btn:hover, .series-btn.active { background: var(--blue); color: #fff; }

    /* Sections modèles */
    .models-hub { padding: 44px 0; }
    .models-section { margin-bottom: 44px; }
    .models-section-title { font-size: 1.05rem; font-weight: 800; color: var(--gray-800); margin-bottom: 18px; padding-left: 12px; border-left: 3px solid var(--blue); }
    .models-grid { display: grid; gap: 12px; grid-template-columns: repeat(2,1fr); }
    @media(min-width:480px){ .models-grid { grid-template-columns: repeat(3,1fr); } }
    @media(min-width:768px){ .models-grid { grid-template-columns: repeat(4,1fr); } }
    @media(min-width:1024px){ .models-grid { grid-template-columns: repeat(5,1fr); } }
  @media(min-width:1280px){ .models-grid { grid-template-columns: repeat(6,1fr); } }

    .model-card {
      display: flex; flex-direction: column;
      background: var(--white); border: 1.5px solid var(--gray-200);
      border-radius: var(--r-md); padding: 14px 14px 12px;
      text-decoration: none; color: inherit;
      box-shadow: var(--sh-sm);
      transition: border-color .15s, box-shadow .15s, transform .15s;
    }
    .model-card:hover { border-color: var(--blue); box-shadow: var(--sh-blue); transform: translateY(-2px); }
    .model-card-name { font-size: .82rem; font-weight: 700; color: var(--gray-800); margin-bottom: 10px; line-height: 1.3; }
    .model-card-prices { display: grid; gap: 4px; flex: 1; margin-bottom: 10px; }
    .model-price-item { display: flex; justify-content: space-between; align-items: center; }
    .model-price-label { font-size: .68rem; color: var(--gray-600); font-weight: 500; }
    .model-price-val { font-size: .76rem; font-weight: 700; color: var(--blue); }
    .model-card-cta { display: flex; align-items: center; justify-content: space-between; font-size: .72rem; font-weight: 700; color: var(--blue); border-top: 1px solid var(--gray-100); padding-top: 9px; margin-top: 2px; }
    .model-card:hover .model-card-cta span { transform: translateX(3px); display: inline-block; transition: transform .14s; }

    /* CTA local SEO band */
    .local-seo-band { background: var(--gray-50); border-top: 1px solid var(--gray-100); border-bottom: 1px solid var(--gray-100); padding: 40px 0; }
    .local-seo-grid { display: grid; gap: 16px; grid-template-columns: 1fr; }
    @media(min-width:640px){ .local-seo-grid { grid-template-columns: repeat(3,1fr); } }
    .local-seo-card { background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--r-md); padding: 18px; }
    .local-seo-card h3 { font-size: .86rem; font-weight: 700; color: var(--gray-800); margin-bottom: 8px; }
    .local-seo-card ul { display: grid; gap: 4px; }
    .local-seo-card a { font-size: .78rem; color: var(--gray-600); transition: color .12s; }
    .local-seo-card a:hover { color: var(--blue); }


/* ═══ PAGE D'ACCUEIL ═══ */
/* ═══ PAGE D'ACCUEIL — styles spécifiques ═══ */

  /* ── HERO ── */
  .hero {
    background: linear-gradient(135deg, var(--gray-800) 0%, #0d2233 100%);
    color: #fff;
    padding: 0;
    overflow: hidden;
    position: relative;
    min-height: 380px;
  }
  .hero-inner {
    display: flex;
    align-items: center;
    min-height: 380px;
  }
  .hero-content {
    padding: 48px 40px 48px 0;
    position: relative;
    z-index: 2;
    max-width: 780px;
  }
  .hero-eyebrow {
    font-size: .75rem; font-weight: 700; letter-spacing: .12em;
    text-transform: uppercase; color: var(--green); margin-bottom: 12px;
    display: flex; align-items: center; gap: 8px;
  }
  .hero-eyebrow::before { content: ''; width: 24px; height: 2px; background: var(--green); }
  .hero h1 {
    font-size: clamp(2rem,4.2vw,3.1rem); font-weight: 800;
    line-height: 1.1; margin-bottom: 20px; color: #fff;
  }
  .hero h1 em { color: var(--green); font-style: normal; }
  .hero-sub {
    font-size: .95rem; color: rgba(255,255,255,.75);
    line-height: 1.7; margin-bottom: 28px; max-width: 420px;
  }
  .hero-badges {
    display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px;
  }
  .hero-badge-pill {
    display: flex; align-items: center; gap: 6px;
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
    border-radius: var(--r-xl); padding: 6px 14px;
    font-size: .78rem; font-weight: 600; color: #fff;
  }
  .hero-badge-pill svg { flex-shrink: 0; }
  .hero-cta-group { display: flex; flex-wrap: wrap; gap: 12px; }
  .hero-mention {
    font-size: .50rem;
    color: rgba(255,255,255,.5);
    line-height: 1.5;
    margin-top: 14px;
    max-width: 520px;
  }
  
  .hero-image-bg {
    position: absolute; inset: 0;
    background: radial-gradient(circle at 60% 50%, rgba(3,160,214,.25) 0%, transparent 70%);
  }
  
  .hero-partner-badge {
    position: absolute; top: 24px; right: 24px; z-index: 3;
    background: var(--blue); color: #fff;
    border-radius: var(--r-md); padding: 10px 16px;
    font-size: .78rem; font-weight: 700; text-align: center;
    box-shadow: 0 4px 16px rgba(83,174,23,.4);
  }
  .hero-partner-badge span { display: block; font-size: .62rem; opacity: .85; margin-bottom: 2px; }

  /* ── FINDER — sélecteur hero ── */
  .finder-wrap {
    padding: 0;
    margin-top: -28px;
    position: relative;
    z-index: 20;
  }
  .finder-card {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 8px 40px rgba(0,0,0,.13);
    padding: 20px 24px;
    width: 100%;
    flex-wrap: wrap;
    gap: 4px;
  }
  .finder-col {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
    min-width: 140px;
  }
  .finder-label {
    font-size: .7rem;
    font-weight: 700;
    color: var(--gray-600);
    letter-spacing: .07em;
    text-transform: uppercase;
    padding-left: 2px;
  }
  .finder-select-wrap {
    position: relative;
  }
  .finder-select-wrap::after {
    content: '';
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 0; height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid var(--gray-400);
    pointer-events: none;
  }
  .finder-select {
    width: 100%;
    padding: 10px 32px 10px 12px;
    border: 1.5px solid var(--gray-200);
    border-radius: 10px;
    font-size: .88rem;
    font-family: var(--font);
    font-weight: 500;
    color: var(--gray-800);
    background: var(--gray-50);
    appearance: none;
    outline: none;
    cursor: pointer;
    transition: border-color .15s;
  }
  .finder-select:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(2,144,196,.12); }
  .finder-select:disabled { opacity: .45; cursor: not-allowed; }
  .finder-divider {
    width: 1px;
    height: 44px;
    background: var(--gray-200);
    margin: 0 12px;
    align-self: flex-end;
    margin-bottom: 2px;
    flex-shrink: 0;
  }
  .finder-btn {
    background: var(--blue);
    color: #fff;
    border: none;
    border-radius: 10px;
    padding: 11px 22px;
    font-size: .88rem;
    font-weight: 700;
    font-family: var(--font);
    cursor: pointer;
    white-space: nowrap;
    transition: background .14s, transform .1s;
    display: flex;
    align-items: center;
    gap: 7px;
    align-self: flex-end;
    margin-left: 12px;
    flex-shrink: 0;
  }
  .finder-btn:hover { background: var(--blue-dark); transform: translateY(-1px); }
  .finder-btn svg { stroke: #fff; flex-shrink: 0; }

  /* ── SECTION TITRE ── */
  .section-title-home {
    font-size: clamp(1.2rem,3vw,1.7rem); font-weight: 800;
    color: var(--gray-800); margin-bottom: 6px;
  }
  .section-title-home span { color: var(--blue); }
  .section-sub { font-size: .86rem; color: var(--gray-600); margin-bottom: 28px; }

  /* ── GRILLE MODÈLES HOMEPAGE ── */
  .models-home { padding: 52px 0; background: var(--gray-50); }
  .models-home-tabs {
    display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 28px;
  }
  .tab-btn {
    padding: 8px 18px; border-radius: var(--r-xl); font-size: .8rem;
    font-weight: 700; font-family: var(--font); cursor: pointer;
    border: 1.5px solid var(--gray-200); background: var(--white);
    color: var(--gray-600); transition: all .14s;
  }
  .tab-btn.active, .tab-btn:hover {
    background: var(--blue); color: #fff; border-color: var(--blue);
  }
  .tab-content { display: none; }
  .tab-content.active { display: grid; }
  .models-home-grid {
    grid-template-columns: repeat(2,1fr);
    gap: 14px;
  }
  @media(min-width:480px){ .models-home-grid { grid-template-columns: repeat(3,1fr); } }
  @media(min-width:768px){ .models-home-grid { grid-template-columns: repeat(4,1fr); } }
  @media(min-width:1024px){ .models-home-grid { grid-template-columns: repeat(5,1fr); } }
  @media(min-width:1280px){ .models-home-grid { grid-template-columns: repeat(6,1fr); } }

  .model-home-card {
    background: var(--white); border: 1.5px solid var(--gray-200);
    border-radius: var(--r-lg); padding: 18px 14px 14px;
    text-decoration: none; color: inherit;
    box-shadow: var(--sh-sm);
    display: flex; flex-direction: column; align-items: center;
    text-align: center; gap: 10px;
    transition: border-color .15s, box-shadow .15s, transform .15s;
    position: relative;
  }
  .model-home-card:hover {
    border-color: var(--green); box-shadow: 0 6px 20px rgba(0,0,0,.13);
  }
  .model-home-card-img {
    width: 70px; height: 90px; object-fit: contain;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,.12));
  }
  .model-home-card-img-placeholder {
    width: 70px; height: 90px;
    display: flex; align-items: center; justify-content: center;
    color: var(--blue-mid);
  }
  .model-home-card-name {
    font-size: .8rem; font-weight: 700; color: var(--gray-800);
    line-height: 1.3;
  }
  .model-home-card-price {
    font-size: .76rem; color: var(--gray-600);
  }
  .model-home-card-price strong {
    display: block; font-size: 1rem; font-weight: 800; color: var(--blue);
  }
  .model-home-card-cta {
    font-size: .72rem; font-weight: 700; color: var(--green);
    border: 1.5px solid var(--green-mid); border-radius: var(--r-xl);
    padding: 4px 12px; background: var(--green-light);
    transition: background .12s;
  }
  .model-home-card:hover .model-home-card-cta { background: var(--green-mid); }
  .model-home-card-new {
    position: absolute; top: 10px; right: 10px; z-index: 2;
    background: var(--blue); color: #fff;
    font-size: .58rem; font-weight: 700; letter-spacing: .04em;
    text-transform: uppercase; padding: 2px 7px; border-radius: var(--r-xl);
  }
  .see-all-link {
    display: inline-flex; align-items: center; gap: 6px;
    margin-top: 24px; font-size: .86rem; font-weight: 700;
    color: var(--blue); text-decoration: none;
    border-bottom: 1.5px solid var(--blue-mid); padding-bottom: 2px;
    transition: color .14s, border-color .14s;
  }
  .see-all-link:hover { color: var(--blue-dark); border-color: var(--blue); }

  /* ── PROMO BAND ── */
  .promo-band {
    background: linear-gradient(135deg, var(--blue) 0%, var(--gray-800) 100%);
    padding: 48px 0; overflow: hidden; position: relative;
  }
  .promo-band-inner {
    display: grid; grid-template-columns: 1fr;
    gap: 32px; align-items: center;
    position: relative; z-index: 2;
  }
  @media(min-width:768px){ .promo-band-inner { grid-template-columns: 1fr 1fr; } }
  .promo-tag {
    display: inline-flex; align-items: baseline; gap: 6px;
    background: var(--green); color: #fff;
    border-radius: var(--r-md); padding: 12px 24px;
    margin-bottom: 16px;
  }
  .promo-tag-amount { font-size: 2.4rem; font-weight: 800; line-height: 1; }
  .promo-tag-label { font-size: .86rem; font-weight: 600; }
  .promo-band h2 {
    font-size: clamp(1.2rem,3vw,1.8rem); font-weight: 800;
    color: #fff; margin-bottom: 10px;
  }
  .promo-band p { font-size: .9rem; color: rgba(255,255,255,.8); line-height: 1.6; margin-bottom: 20px; }
  .promo-band-image {
    display: flex; justify-content: center; align-items: center;
    position: relative;
  }
  .promo-circle {
    width: 280px; height: 280px; border-radius: 50%;
    background: rgba(255,255,255,.06);
    display: flex; align-items: center; justify-content: center;
  }
  .promo-band-bg {
    position: absolute; right: -60px; top: -60px;
    width: 300px; height: 300px; border-radius: 50%;
    background: rgba(255,255,255,.04);
  }

  /* ── SERVICES ── */
  .services-section { padding: 52px 0; background: var(--white); }
  .services-grid {
    display: grid; gap: 16px;
    grid-template-columns: 1fr;
    margin-top: 32px;
  }
  @media(min-width:600px){ .services-grid { grid-template-columns: repeat(2,1fr); } }
  @media(min-width:1024px){ .services-grid { grid-template-columns: repeat(3,1fr); } }
  .service-card {
    display: flex; flex-direction: column;
    background: var(--gray-50); border: 1.5px solid var(--gray-200);
    border-radius: var(--r-lg); padding: 28px 24px;
    text-decoration: none; color: inherit;
    transition: border-color .15s, box-shadow .15s, transform .15s;
    position: relative; overflow: hidden;
  }
  .service-card::before {
    content: ''; position: absolute; bottom: 0; left: 0; right: 0;
    height: 3px; background: var(--green);
    transform: scaleX(0); transform-origin: left;
    transition: transform .2s;
  }
  .service-card:hover { border-color: var(--green); box-shadow: var(--sh-green); transform: translateY(-2px); }
  .service-card:hover::before { transform: scaleX(1); }
  .service-card-icon {
    width: 52px; height: 52px; background: var(--blue-light);
    border-radius: var(--r-md); display: flex; align-items: center;
    justify-content: center; color: var(--blue); margin-bottom: 16px;
  }
  .service-card h3 { font-size: .95rem; font-weight: 700; color: var(--gray-800); margin-bottom: 8px; }
  .service-card p { font-size: .8rem; color: var(--gray-600); line-height: 1.65; flex: 1; }
  .service-card-price {
    margin-top: 16px; font-size: .78rem; font-weight: 600; color: var(--gray-600);
  }
  .service-card-price strong { color: var(--green); font-size: .9rem; }
  .service-card-link {
    margin-top: 12px; font-size: .78rem; font-weight: 700;
    color: var(--blue); display: flex; align-items: center; gap: 5px;
  }

  /* ── REASSURANCE BAND ── */
  .reassurance-home {
    background: var(--gray-800); color: #fff; padding: 32px 0;
  }
  .reassurance-home-grid {
    display: grid; gap: 20px;
    grid-template-columns: repeat(2,1fr);
  }
  @media(min-width:768px){ .reassurance-home-grid { grid-template-columns: repeat(4,1fr); } }
  .reassurance-home-item { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; }
  .reassurance-home-icon {
    width: 52px; height: 52px; border-radius: 50%;
    background: rgba(255,255,255,.08);
    display: flex; align-items: center; justify-content: center; color: var(--green);
  }
  .reassurance-home-item strong { font-size: .88rem; font-weight: 700; }
  .reassurance-home-item p { font-size: .74rem; opacity: .7; line-height: 1.5; }

  /* ── BOUTIQUE ── */
  .boutique-section { padding: 52px 0; background: var(--blue-light); }
  .boutique-inner {
    display: grid; gap: 32px; align-items: center;
    grid-template-columns: 1fr;
  }
  @media(min-width:768px){ .boutique-inner { grid-template-columns: 1fr 1fr; } }
  .boutique-map {
    background: var(--gray-200); border-radius: var(--r-lg);
    overflow: hidden; height: 280px; position: relative;
  }
  .boutique-map iframe {
    width: 100%; height: 100%; border: none;
  }
  .boutique-info h2 {
    font-size: clamp(1.2rem,3vw,1.6rem); font-weight: 800;
    color: var(--gray-800); margin-bottom: 16px;
  }
  .boutique-info h2 span { color: var(--blue); }
  .boutique-details { display: grid; gap: 12px; margin-bottom: 24px; }
  .boutique-detail {
    display: flex; align-items: flex-start; gap: 12px;
    font-size: .86rem; color: var(--gray-600);
  }
  .boutique-detail svg { flex-shrink: 0; color: var(--blue); margin-top: 1px; }
  .boutique-detail strong { color: var(--gray-800); display: block; margin-bottom: 2px; font-size: .88rem; }
  .horaires-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 4px;
    font-size: .8rem; color: var(--gray-600);
  }
  .horaires-grid dt { font-weight: 600; color: var(--gray-800); }

  /* ── TRUST BAND ── */
  .trust-band {
    background: var(--white); border-top: 1px solid var(--gray-100);
    border-bottom: 1px solid var(--gray-100); padding: 24px 0;
  }
  .trust-logos {
    display: flex; align-items: center; justify-content: center;
    gap: 32px; flex-wrap: wrap;
  }
  .trust-item {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    font-size: .72rem; color: var(--gray-600); font-weight: 600; text-align: center;
  }
  .trust-item-icon { color: var(--blue); }

  /* ── AVIS CLIENTS ── */
  .avis-section { padding: 52px 0; background: var(--gray-50); }
  .avis-grid {
    display: grid; gap: 14px; margin-top: 28px;
    grid-template-columns: 1fr;
  }
  @media(min-width:600px){ .avis-grid { grid-template-columns: repeat(3,1fr); } }
  @media(min-width:1280px){ .avis-grid { grid-template-columns: repeat(3,1fr); } }
  .avis-card {
    background: var(--white); border: 1.5px solid var(--gray-200);
    border-radius: var(--r-lg); padding: 20px;
    box-shadow: var(--sh-sm);
  }
  .avis-stars { color: #f59e0b; font-size: .9rem; margin-bottom: 8px; }
  .avis-text { font-size: .82rem; color: var(--gray-600); line-height: 1.65; margin-bottom: 12px; }
  .avis-author { font-size: .76rem; font-weight: 700; color: var(--gray-800); }
  .avis-source { font-size: .7rem; color: var(--gray-600); }

  /* ── CTA FINAL ── */
  .cta-final { padding: 52px 0; background: var(--white); text-align: center; }
  .cta-final h2 { font-size: clamp(1.3rem,3vw,1.9rem); font-weight: 800; color: var(--gray-800); margin-bottom: 10px; }
  .cta-final p { font-size: .9rem; color: var(--gray-600); margin-bottom: 28px; max-width: 500px; margin-left: auto; margin-right: auto; }

  /* ── PHONE SVG PLACEHOLDER ── */
  

/* ═══════════════════════════════════════════
   DRAWER MENU MOBILE — version propre unique
   ═══════════════════════════════════════════ */

/* ═══════════════════════════════════════════
   DRAWER MENU MOBILE — version propre unique
   ═══════════════════════════════════════════ */
.mob-overlay{position:fixed;inset:0;z-index:190;background:rgba(0,0,0,.52);opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;}
.mob-overlay.open{opacity:1;visibility:visible;}
.mob-drawer{position:fixed;top:0;left:0;bottom:0;width:min(320px,88vw);background:var(--white);z-index:195;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 32px rgba(0,0,0,.18);will-change:transform;}
.mob-drawer.open{transform:translateX(0);}
.mob-drawer-header{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px 16px 16px;
  background:var(--white);
  border-bottom:1px solid var(--gray-100);
  flex-shrink:0;
  position:relative;
  min-height:80px;
}
.mob-drawer-logo-img{height:52px;object-fit:contain;display:block;margin:0 auto;}
.mob-drawer-logo-text{font-weight:800;font-size:1.1rem;color:var(--blue);text-align:center;}
.mob-drawer-close{
  position:absolute;
  top:12px;
  right:12px;
  width:32px;height:32px;border-radius:50%;
  background:var(--gray-100);
  border:none;color:var(--gray-600);
  cursor:pointer;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;font-family:var(--font);
}
.mob-drawer-close:hover{background:var(--gray-200);color:var(--gray-800);}
.mob-drawer-rdv{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--green);color:#fff;font-weight:700;font-size:.86rem;text-decoration:none;flex-shrink:0;transition:background .14s;}
.mob-drawer-rdv:hover{background:var(--green-dark);color:#fff;}
.mob-drawer-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
.mob-link{display:flex;align-items:center;gap:10px;padding:14px 16px;font-size:.88rem;font-weight:600;color:var(--gray-800);text-decoration:none;border-bottom:1px solid var(--gray-100);transition:background .12s;}
.mob-link:hover{background:var(--blue-light);color:var(--blue);}
.mob-link svg{color:var(--gray-400);flex-shrink:0;}
.mob-brand{border-bottom:1px solid var(--gray-100);}
.mob-brand-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:none;border:none;font-family:var(--font);font-size:.88rem;font-weight:700;color:var(--gray-800);cursor:pointer;text-align:left;transition:background .12s;}
.mob-brand-btn:hover{background:var(--blue-light);color:var(--blue);}
.mob-brand-btn svg{flex-shrink:0;transition:transform .22s;color:var(--gray-400);}
.mob-brand-btn.active{color:var(--blue);background:var(--blue-light);}
.mob-brand-btn.active svg{transform:rotate(180deg);color:var(--blue);}
.mob-brand-list{display:none;background:var(--gray-50);border-top:1px solid var(--gray-100);max-height:340px;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.mob-brand-list.open{display:block;}
.mob-brand-list a{display:block;padding:10px 16px 10px 32px;font-size:.82rem;font-weight:500;color:var(--gray-600);text-decoration:none;border-bottom:1px solid var(--gray-100);transition:color .12s,background .12s;}
.mob-brand-list a:last-child{border-bottom:none;}
.mob-brand-list a:hover{color:var(--blue);background:var(--blue-light);}
.mob-drawer-footer{padding:14px 16px;background:var(--gray-50);border-top:1px solid var(--gray-100);flex-shrink:0;font-size:.78rem;color:var(--gray-600);display:flex;flex-direction:column;gap:6px;}
.mob-drawer-footer a{color:var(--blue);font-weight:700;}
.mob-drawer-footer span{display:flex;align-items:center;gap:6px;}
.mobile-nav{display:none!important;}
@media(min-width:1024px){.mob-drawer{display:none!important;}.mob-overlay{display:none!important;}}

/* ═══════════════════════════════════════════════════
   CORRECTIONS ERGONOMIE MOBILE — d'après capture
   ═══════════════════════════════════════════════════ */

/* 1. Topbar : non-sticky sur mobile, scroll avec la page */
@media(max-width:1023px){
  .topbar { position:relative; z-index:1; }
  /* Réduire la topbar sur mobile */
  .topbar { padding:5px 14px; font-size:.72rem; }
  .topbar-promo, .topbar-mail { display:none; } /* Masquer la promo et le mail sur mobile, garder le tel */
  
  /* 2. Header mobile : hamburger gauche | logo centré | boutons droite */
  .site-header { position:sticky; top:0; z-index:200; }
  .header-inner,
  .header-inner.container,
  .container.header-inner {
    display:flex !important;
    flex-direction:row !important;
    align-items:center !important;
    justify-content:space-between !important;
    height:72px !important;
    padding:0 14px !important;
    max-width:100% !important;
    width:100% !important;
    margin:0 !important;
    gap:0 !important;
    box-sizing:border-box !important;
    position:relative !important;
  }
  /* Hamburger : gauche */
  .menu-toggle {
    display:flex !important;
    flex-direction:column !important;
    justify-content:center !important;
    align-items:center !important;
    width:38px !important;
    height:38px !important;
    flex-shrink:0 !important;
    order:1 !important;
    margin:0 !important;
    position:relative !important;
    z-index:2 !important;
  }
  .menu-toggle span { display:block !important; background:#1e3545 !important; height:2px !important; width:22px !important; border-radius:2px !important; }
  /* Logo : centre absolu */
  .site-logo {
    position:absolute !important;
    left:50% !important;
    top:50% !important;
    transform:translate(-50%,-50%) !important;
    display:flex !important;
    align-items:center !important;
    padding:0 !important;
    order:2 !important;
    pointer-events:auto !important;
    z-index:1 !important;
  }
  .logo-img { height:54px !important; width:auto !important; }
  /* Boutons : droite */
  .header-actions {
    display:flex !important;
    align-items:center !important;
    gap:6px !important;
    flex-shrink:0 !important;
    order:3 !important;
    margin-left:auto !important;
    position:relative !important;
    z-index:2 !important;
  }
  /* Masquer nav desktop */
  .main-nav { display:none !important; }

  /* 3. Drawer : part bien de top:0, couvre TOUT l'écran */
  .mob-drawer { top:0; height:100%; height:100dvh; z-index:300; }
  .mob-overlay { z-index:299; }
  
  /* 4. Drawer header plus compact */
  .mob-drawer-header { height:54px; padding:0 14px; }
  .mob-drawer-logo-img { height:30px; }
  
  /* 5. Hero mobile : padding réduit, texte lisible */
  .hero-content { padding:28px 0 24px; }
  .hero h1 { font-size:clamp(1.6rem,7vw,2rem); }
  .hero-sub { font-size:.88rem; }
  .hero-cta-group { gap:10px; }
  .btn-lg { padding:12px 20px; font-size:.86rem; }
  
  /* 6. Sélecteur : empilé verticalement */
  .finder-card { flex-direction: column; align-items: stretch; gap: 10px; padding: 16px; border-radius: 12px; margin-top: 0; }
  .finder-divider { display: none; }
  .finder-col { min-width: 100%; }
  .finder-btn { width: 100%; justify-content: center; }
  
  /* 7. Tabs modèles : scroll horizontal propre */
  .models-home-tabs { flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch;
    padding-bottom:4px; gap:8px; scrollbar-width:none; }
  .models-home-tabs::-webkit-scrollbar { display:none; }
  .tab-btn { flex-shrink:0; white-space:nowrap; }
  
  /* 8. Grille modèles : 2 colonnes sur mobile */
  .models-home-grid { grid-template-columns:repeat(2,1fr) !important; gap:10px; }
  .model-home-card { padding:12px 8px 10px; gap:6px; min-height:200px; }
  
  /* 9. Services : 1 colonne */
  .services-grid { grid-template-columns:1fr !important; }
  
  /* 10. Réassurance : 2 colonnes */
  .reassurance-home-grid { grid-template-columns:repeat(2,1fr); }
  
  /* 11. Boutique : empilée */
  .boutique-inner { grid-template-columns:1fr; }
  .boutique-map { height:200px; order:2; }
  .boutique-info { order:1; }
  
  /* 12. Avis : 1 colonne */
  .avis-grid { grid-template-columns:1fr !important; }
  
  /* 13. Footer : 1 colonne */
  .footer-grid { grid-template-columns:1fr !important; gap:24px; }
  /* Footer mobile : pleine largeur + bottom centré */
  .site-footer { width:100% !important; box-sizing:border-box !important; overflow:hidden !important; }
  .site-footer .container { padding:0 20px !important; width:100% !important; max-width:100% !important; box-sizing:border-box !important; }
  .footer-bottom {
    flex-direction:column-reverse !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    gap:14px !important;
    padding-bottom:12px !important;
  }
  .footer-bottom span { text-align:center !important; display:block !important; width:100% !important; }
  .footer-bottom a { font-weight:700 !important; }
  .footer-brand { text-align:left !important; }
  .footer-brand .logo-fallback { justify-content:flex-start !important; flex-direction:column !important; align-items:flex-start !important; }
  .footer-brand .logo-name { text-align:left !important; }
  .footer-brand .logo-tagline { text-align:left !important; }
  .footer-desc { text-align:left !important; margin:0 !important; }
  .footer-col { text-align:left !important; }
  .footer-col ul { padding-left:0 !important; }
  .footer-contact { text-align:left !important; }
  
  /* 14. Promo band : pas d'image */
  .promo-band-image { display:none; }
  .promo-band { padding:32px 0; }
}

/* Touch targets minimum sur mobile */
@media(max-width:1023px){
  .mob-brand-btn { min-height:48px; }
  .mob-link { min-height:48px; }
  .mob-brand-list a { min-height:40px; display:flex; align-items:center; }
  .tab-btn { min-height:40px; }
  .model-chip { min-height:40px; display:inline-flex; align-items:center; }
}

/* Téléphone hero caché sur mobile */
@media(max-width:767px){
  
  .hero-inner { grid-template-columns:1fr !important; }
  .hero-content { padding:32px 0 28px; }
}

/* Icônes téléphone dans les cards */


/* Téléphones SVG réalistes */
.phone-svg-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 130px;
  background: #ffffff;
}
.phone-svg-placeholder img {
  height: 110px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}
.phone-svg-placeholder svg {
  width: auto;
  height: 120px;
  max-width: 65px;
  filter: none;
  transition: transform .22s ease;
  overflow: visible;
}
.model-home-card:hover .phone-svg-placeholder img {
  height: 110px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}
.phone-svg-placeholder svg {
  transform: scale(1.04);
}
.model-home-card { min-height: 230px; }

/* Sur desktop : hero en 2 colonnes */
@media(min-width:1024px){
  .hero-inner {
    grid-template-columns: 1fr 1fr !important;
    min-height: 440px;
  }
  .hero { min-height: 440px; }
}
@media(max-width:1023px){
  
}
/* ── Hero SVG plein fond ── */
.hero-bg-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  z-index: 0;
}
.hero .hero-inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  min-height: 380px;
}
.hero-content {
  max-width: 780px;
  padding: 48px 0;
}
@media(min-width:1024px){
  .hero { min-height: 440px; }
  .hero .hero-inner { min-height: 440px; }
}


/* ══════════════════════════════════════
   BOUTON THÈME JOUR / NUIT
══════════════════════════════════════ */
.theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1.5px solid var(--gray-200);
  background: var(--gray-50);
  color: var(--gray-700);
  cursor: pointer;
  flex-shrink: 0;
  transition: background .18s, border-color .18s, color .18s, transform .12s;
}
.theme-toggle:hover {
  background: var(--blue-light);
  border-color: var(--blue);
  color: var(--blue);
  transform: scale(1.05);
}
.theme-toggle .icon-sun { display: block; }
.theme-toggle .icon-moon { display: none; }
[data-theme="dark"] .theme-toggle .icon-sun { display: none; }
[data-theme="dark"] .theme-toggle .icon-moon { display: block; }

/* ══════════════════════════════════════
   MODE SOMBRE
══════════════════════════════════════ */
[data-theme="dark"] {
  --white:      #111827;
  --gray-50:    #1f2937;
  --gray-100:   #1f2937;
  --gray-200:   #374151;
  --gray-400:   #9ca3af;
  --gray-600:   #d1d5db;
  --gray-700:   #e5e7eb;
  --gray-800:   #f9fafb;
  --blue-light: #0c2233;
  --blue-mid:   #0280B0;
  --green-light: #0a1e2e;
  --green-mid:  #0280B0;
}
[data-theme="dark"] body {
  background: #0f172a;
  color: #e2e8f0;
}
[data-theme="dark"] .site-header {
  background: #111827;
  border-bottom-color: #374151;
}
[data-theme="dark"] .mega-panel,
[data-theme="dark"] .search-results {
  background: #1f2937;
  border-color: #374151;
}
[data-theme="dark"] .mega-panel a,
[data-theme="dark"] .nav-link {
  color: #e2e8f0 !important;
}
[data-theme="dark"] .mega-panel a:hover,
[data-theme="dark"] .mega-panel a:focus {
  color: var(--blue) !important;
  background: rgba(3,160,214,.1);
}
[data-theme="dark"] .mega-group-title { color: var(--blue); }
[data-theme="dark"] .card,
[data-theme="dark"] .tarif-card,
[data-theme="dark"] .model-home-card,
[data-theme="dark"] .service-card,
[data-theme="dark"] .review-card,
[data-theme="dark"] .related-card {
  background: #1f2937;
  border-color: #374151;
}
[data-theme="dark"] .tarif-card:hover,
[data-theme="dark"] .service-card:hover,
[data-theme="dark"] .related-card:hover {
  border-color: var(--blue);
}
/* ── Logo blanc en mode sombre (header + drawer mobile) ── */
[data-theme="dark"] .logo-img,
[data-theme="dark"] .mob-drawer-logo-img {
  filter: brightness(0) invert(1);
}
[data-theme="dark"] .topbar { background: #1e3a5f; }
[data-theme="dark"] .tabs-nav { background: #1f2937; border-color: #374151; }
[data-theme="dark"] .tab-btn { color: #9ca3af; }
[data-theme="dark"] .tab-btn.active { background: var(--blue); color: #fff; }
[data-theme="dark"] .finder-card { background: #1e293b; box-shadow: 0 8px 40px rgba(0,0,0,.35); }
[data-theme="dark"] .finder-select { background: #0f172a; color: #e2e8f0; border-color: #334155; }
[data-theme="dark"] .finder-select:focus { border-color: var(--blue); }
[data-theme="dark"] .finder-label { color: #94a3b8; }
[data-theme="dark"] .finder-divider { background: #334155; }
[data-theme="dark"] .finder-select-wrap::after { border-top-color: #94a3b8; }
[data-theme="dark"] .seo-band { background: #0c1a29; border-color: #1e3a5f; }
[data-theme="dark"] .promo-band { background: #0c1a29; border-color: #1e3a5f; }
[data-theme="dark"] .reassurance-band { background: #0a1628; }
[data-theme="dark"] .site-footer { background: #0a1628 !important; color: #e2e8f0; }
[data-theme="dark"] .footer-bottom { background: #060f1e; }
[data-theme="dark"] .footer-bottom::before { background: #1e3a5f; }
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] .header-search input {
  background: #1f2937;
  color: #e2e8f0;
  border-color: #374151;
}
[data-theme="dark"] .search-item {
  border-color: #374151;
  color: #e2e8f0;
}
[data-theme="dark"] .search-item:hover { background: #374151; }
[data-theme="dark"] .mob-drawer { background: #111827; }
[data-theme="dark"] .mob-drawer-header { border-color: #374151; }
[data-theme="dark"] .mob-link { color: #e2e8f0; border-color: #374151; }
[data-theme="dark"] .mob-brand-group-title { color: #9ca3af; }
[data-theme="dark"] section { background-color: inherit; }
[data-theme="dark"] .section-alt { background: #111827; }

/* ── Ajustements pour max-width 1376px ── */
@media(min-width:1280px) {
  .services-grid { grid-template-columns: repeat(3,1fr); }
  .promo-band-inner { gap: 60px; }
  .section { padding: 64px 0; }
  .boutique-inner { gap: 48px; }
  .boutique-map { min-height: 380px; }
  .tarif-card { padding: 22px; }
  .hero-content { padding: 56px 0; }
}

/* ══════════════════════════════════════
   BOUTON RECHERCHE + PANNEAU FLOTTANT
══════════════════════════════════════ */
.search-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1.5px solid var(--gray-200);
  background: var(--gray-50);
  color: var(--gray-700);
  cursor: pointer;
  flex-shrink: 0;
  transition: background .18s, border-color .18s, color .18s, transform .12s;
}
.search-toggle:hover {
  background: var(--blue-light);
  border-color: var(--blue);
  color: var(--blue);
  transform: scale(1.05);
}
.search-toggle.active {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
}

/* Panneau de recherche flottant */
.search-flyout {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 500;
  background: #fff;
  box-shadow: 0 4px 32px rgba(3,100,180,.15);
  padding: 18px 24px;
  transform: translateY(-100%);
  transition: transform .25s cubic-bezier(.4,0,.2,1);
  display: flex;
  align-items: center;
  gap: 12px;
}
.search-flyout.open {
  transform: translateY(0);
}
.search-flyout-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
}
.search-flyout input {
  flex: 1;
  padding: 12px 18px;
  font-size: 1rem;
  font-family: var(--font);
  border: 2px solid var(--blue);
  border-radius: var(--r-xl);
  outline: none;
  background: var(--gray-50);
  color: var(--gray-800);
  transition: box-shadow .15s;
}
.search-flyout input:focus {
  box-shadow: 0 0 0 4px rgba(3,160,214,.15);
}
.search-flyout input::placeholder { color: var(--gray-400); }
.search-flyout-close {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1.5px solid var(--gray-200);
  background: none;
  color: var(--gray-600);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
  transition: background .15s, color .15s;
}
.search-flyout-close:hover { background: var(--gray-100); color: var(--gray-800); }
.search-flyout-results {
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  background: #fff;
  border-top: 1px solid var(--gray-100);
  max-height: 60vh;
  overflow-y: auto;
  padding: 8px 0;
}
.search-flyout-results a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 24px;
  font-size: .9rem;
  color: var(--gray-800);
  text-decoration: none;
  transition: background .1s;
}
.search-flyout-results a:hover { background: var(--blue-light); color: var(--blue); }
.search-flyout-price { font-weight: 700; color: var(--blue); font-size: .85rem; }
/* Overlay sombre derrière le panneau */
.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.3);
  z-index: 499;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
.search-overlay.open { opacity: 1; pointer-events: auto; }

[data-theme="dark"] .search-flyout {
  background: #111827;
  border-bottom: 1px solid #374151;
}
[data-theme="dark"] .search-flyout input {
  background: #1f2937;
  color: #e2e8f0;
  border-color: var(--blue);
}
[data-theme="dark"] .search-flyout-results { background: #111827; border-color: #374151; }
[data-theme="dark"] .search-flyout-results a { color: #e2e8f0; }
[data-theme="dark"] .search-flyout-results a:hover { background: #0c2233; }
[data-theme="dark"] .search-toggle { background: #1f2937; border-color: #374151; color: #e2e8f0; }
[data-theme="dark"] .theme-toggle { background: #1f2937; border-color: #374151; color: #e2e8f0; }

/* ═══════════════════════════════════════════════════
   CORRECTIONS MODE SOMBRE — visibilité complète
═══════════════════════════════════════════════════ */

/* Titres de sections */
[data-theme="dark"] .section-title-home { color: #f1f5f9; }
[data-theme="dark"] .section-sub { color: #94a3b8; }
[data-theme="dark"] h1, [data-theme="dark"] h2, [data-theme="dark"] h3,
[data-theme="dark"] h4, [data-theme="dark"] h5 { color: #f1f5f9; }
[data-theme="dark"] p { color: #cbd5e1; }

/* Cartes modèles accueil */
[data-theme="dark"] .model-home-card {
  background: #1e293b;
  border-color: #334155;
}
[data-theme="dark"] .model-home-card:hover {
  border-color: var(--blue);
  background: #1e3a5f;
}
[data-theme="dark"] .model-home-card-name { color: #1e293b !important; }
[data-theme="dark"] .model-home-card-price { color: var(--blue); }
[data-theme="dark"] .model-home-card-new { color: #fff; background: var(--blue); }
[data-theme="dark"] .model-home-card-cta {
  background: #0c2233;
  border-color: var(--blue);
  color: var(--blue);
}
[data-theme="dark"] .model-home-card:hover .model-home-card-cta {
  background: var(--blue);
  color: #fff;
}

/* SVG téléphones dans les cartes — rendre visibles */
[data-theme="dark"] .phone-svg-placeholder svg rect,
[data-theme="dark"] .phone-svg-placeholder svg path,
[data-theme="dark"] .phone-svg-placeholder svg line,
[data-theme="dark"] .phone-svg-placeholder svg circle {
  stroke: #64748b;
}
[data-theme="dark"] .phone-svg-placeholder svg [fill="#1e3545"],
[data-theme="dark"] .phone-svg-placeholder svg [fill="#2d4a60"] {
  fill: #334155;
}
[data-theme="dark"] .phone-svg-placeholder {
  filter: brightness(1.8) contrast(0.9);
}

/* Onglets modèles */
[data-theme="dark"] .models-home-tabs,
[data-theme="dark"] .tabs-nav {
  background: #1e293b;
  border-color: #334155;
}
[data-theme="dark"] .tab-btn { color: #94a3b8; background: transparent; }
[data-theme="dark"] .tab-btn.active { background: var(--blue); color: #fff; }
[data-theme="dark"] .tab-btn:hover:not(.active) { color: var(--blue); background: #0c2233; }

/* Model chips */
[data-theme="dark"] .model-chip {
  background: #1e293b;
  border-color: #334155;
  color: #e2e8f0;
}
[data-theme="dark"] .model-chip:hover,
[data-theme="dark"] .model-chip.active {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
}

/* Section SEO / copy */
[data-theme="dark"] .seo-copy-block { color: #cbd5e1; }
[data-theme="dark"] .seo-copy-card {
  background: #1e293b;
  border-color: #334155;
  color: #cbd5e1;
}
[data-theme="dark"] .seo-copy-card h3 { color: #e2e8f0; }
[data-theme="dark"] .seo-copy-links a { color: var(--blue); }
[data-theme="dark"] .seo-copy-grid { color: #cbd5e1; }
[data-theme="dark"] .seo-copy-side { color: #cbd5e1; }

/* FAQ */
[data-theme="dark"] .faq-item {
  background: #1e293b;
  border-color: #334155;
}
[data-theme="dark"] .faq-item summary { color: #e2e8f0; }
[data-theme="dark"] .faq-item p,
[data-theme="dark"] .faq-item div { color: #94a3b8; }
[data-theme="dark"] .faq-home { background: inherit; }

/* Avis clients */
[data-theme="dark"] .avis-card {
  background: #1e293b;
  border-color: #334155;
}
[data-theme="dark"] .avis-text { color: #cbd5e1; }
[data-theme="dark"] .avis-author { color: #e2e8f0; }
[data-theme="dark"] .avis-source { color: #94a3b8; }
[data-theme="dark"] .avis-stars { color: #fbbf24; }

/* Boutique section */
[data-theme="dark"] .boutique-section { background: #0f172a; }
[data-theme="dark"] .boutique-info { color: #cbd5e1; }
[data-theme="dark"] .boutique-detail { color: #94a3b8; }
[data-theme="dark"] .boutique-detail strong { color: #e2e8f0; }
[data-theme="dark"] .boutique-map { border-color: #334155; }

/* Bande réassurance */
[data-theme="dark"] .reassurance-band { background: #0c1a2e; }
[data-theme="dark"] .reassurance-home { background: #0c1a2e !important; color: #e2e8f0 !important; }
[data-theme="dark"] .reassurance-home-item strong { color: #e2e8f0 !important; }
[data-theme="dark"] .reassurance-home-item p { color: #94a3b8 !important; opacity: 1 !important; }
[data-theme="dark"] .reassurance-home-item { color: #e2e8f0; }
[data-theme="dark"] .reassurance-home-icon {
  color: var(--blue);
  background: rgba(3,160,214,.15);
}
[data-theme="dark"] .reassurance-home-item strong,
[data-theme="dark"] .reassurance-home-item p { color: #e2e8f0; }

/* Bande promo RDV */
[data-theme="dark"] .rdv-band h2 { color: #fff; }
[data-theme="dark"] .rdv-band p { color: rgba(255,255,255,.85); }
[data-theme="dark"] .promo-circle { border-color: rgba(255,255,255,.3); color: #fff; }
[data-theme="dark"] .promo-band-inner { color: #e2e8f0; }
[data-theme="dark"] .promo-tag-label { color: rgba(255,255,255,.75); }
[data-theme="dark"] .promo-tag-amount { color: #fff; }

/* Services */
[data-theme="dark"] .services-section { background: #0f172a; }
[data-theme="dark"] .service-card {
  background: #1e293b;
  border-color: #334155;
}
[data-theme="dark"] .service-card h3 { color: #e2e8f0; }
[data-theme="dark"] .service-card p { color: #94a3b8; }
[data-theme="dark"] .service-card-price strong { color: var(--blue); }
[data-theme="dark"] .service-card-icon { color: var(--blue); }
[data-theme="dark"] .service-card-link { color: var(--blue); }

/* Hero badges */
[data-theme="dark"] .hero-badge-pill {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.15);
  color: #e2e8f0;
}

/* Zones géographiques MEL */
[data-theme="dark"] .local-strip { background: #0c1a2e; }
[data-theme="dark"] .local-strip a { color: #60a5fa; }

/* Liens en général */
[data-theme="dark"] a { color: #60a5fa; }
[data-theme="dark"] .btn-primary { color: #fff; }
[data-theme="dark"] .btn-tel { color: #fff !important; background: #161c2c !important; border-color: #161c2c !important; }
[data-theme="dark"] .btn-tel:hover { background: #1e2640 !important; color: #fff !important; }
[data-theme="dark"] .btn-tel svg { stroke: #fff !important; }
[data-theme="dark"] .btn-outline { border-color: #334155; color: #e2e8f0; }
[data-theme="dark"] .btn-white { background: #1e293b; color: var(--blue); }

/* Liens de navigation hero/seo */
[data-theme="dark"] .seo-band a { color: var(--blue); }
[data-theme="dark"] .seo-band strong { color: #e2e8f0; }

/* See all link */
[data-theme="dark"] .see-all-link { color: var(--blue); }
[data-theme="dark"] .mega-see-all { color: var(--blue) !important; }

/* Footer */
[data-theme="dark"] .footer-desc { color: #94a3b8; }
[data-theme="dark"] .footer-col h3 { color: var(--blue); }
[data-theme="dark"] .footer-col a { color: #94a3b8; }
[data-theme="dark"] .footer-col a:hover { color: #e2e8f0; }
[data-theme="dark"] .footer-contact { color: #94a3b8; }
[data-theme="dark"] .footer-bottom { color: #e2e8f0; }
[data-theme="dark"] .footer-bottom a { color: #ffffff !important; font-weight: 700 !important; }
[data-theme="dark"] .footer-bottom a:hover { color: var(--blue) !important; }

/* Topbar */
[data-theme="dark"] .topbar { color: #e2e8f0; }
[data-theme="dark"] .topbar a { color: #fff; }
[data-theme="dark"] .topbar-tel { color: #fff; }
[data-theme="dark"] .topbar-mail { color: #fff; }
[data-theme="dark"] .topbar-mail a { color: #fff; }
[data-theme="dark"] .topbar-promo { color: rgba(255,255,255,.85); }

/* Menu hamburger spans en mode sombre */
[data-theme="dark"] .menu-toggle span { background: #ffffff !important; }

/* Sections blanches alternées */
[data-theme="dark"] .section-alt,
[data-theme="dark"] .avis-section,
[data-theme="dark"] .boutique-section,
[data-theme="dark"] .faq-home { background: #111827; }

/* Bande SEO du bas */
[data-theme="dark"] .seo-band { background: #0c1a2e; color: #cbd5e1; }
[data-theme="dark"] .seo-band h2 { color: #e2e8f0; }

/* Horaires */
[data-theme="dark"] .horaires-grid { color: #94a3b8; }
[data-theme="dark"] .horaires-grid strong { color: #e2e8f0; }


/* header buttons group */
.header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

a[href^="tel"]{text-decoration:none}
a[href^="mailto"]{text-decoration:none}

/* Pages produit réparation */
.hero-model-inner {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 48px;
  align-items: center;
  padding: 48px 0 36px;
}
.hero-model-content h1 {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 800;
  color: var(--gray-800);
  line-height: 1.2;
  margin: 12px 0 16px;
}
.hero-model-content h1 em {
  font-style: normal;
  color: var(--blue);
}
.hero-sub {
  font-size: .95rem;
  color: var(--gray-600);
  line-height: 1.7;
  margin-bottom: 24px;
}
.hero-price-badge {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  background: var(--green-light);
  border: 1.5px solid var(--green-mid);
  border-radius: var(--r-md);
  padding: 12px 20px;
  margin-bottom: 20px;
}
.hero-price-label {
  font-size: .85rem;
  color: var(--gray-600);
  font-weight: 600;
}
.hero-price-amount {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--blue);
}
.hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.btn-lg {
  padding: 13px 24px;
  font-size: .9rem;
}
.hero-model-image {
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-phone-img {
  width: 100%;
  max-width: 260px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,.15));
}

/* Tarifs */
.tarifs-section { padding: 52px 0; background: var(--gray-50); }
.tarifs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
  margin-top: 28px;
}
.tarif-card--active {
  border-color: var(--blue);
  box-shadow: var(--sh-blue);
}
.tarif-card-icon { color: var(--blue); margin-bottom: 8px; }
.tarif-card-name { font-weight: 700; font-size: .9rem; color: var(--gray-800); }
.tarif-card-desc { font-size: .78rem; color: var(--gray-500); margin-top: 4px; }
.tarif-card-price { font-size: 1.4rem; font-weight: 800; color: var(--blue); white-space: nowrap; }

/* Description */
.desc-section { padding: 52px 0; background: var(--white); }
.desc-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
}
.desc-content h2 { font-size: 1.4rem; font-weight: 800; color: var(--gray-800); margin-bottom: 16px; }
.desc-content h3 { font-size: 1.1rem; font-weight: 700; color: var(--gray-800); margin: 28px 0 12px; }
.desc-content p { color: var(--gray-600); line-height: 1.8; margin-bottom: 14px; }
.desc-list { list-style: none; padding: 0; }
.desc-list li { padding: 6px 0 6px 24px; position: relative; color: var(--gray-600); font-size: .9rem; }
.desc-list li::before { content: "✓"; position: absolute; left: 0; color: var(--green); font-weight: 700; }
.desc-aside-card {
  background: var(--white);
  border: 1.5px solid var(--gray-200);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: var(--sh-sm);
  position: sticky;
  top: 90px;
}
.desc-aside-title { font-weight: 700; font-size: .9rem; color: var(--gray-800); margin-bottom: 16px; }
.desc-aside-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.desc-aside-list li { display: flex; align-items: flex-start; gap: 10px; font-size: .85rem; color: var(--gray-600); }
.desc-aside-list li svg { flex-shrink: 0; color: var(--blue); margin-top: 2px; }
.desc-aside-list a { color: var(--blue); text-decoration: none; }

/* FAQ page produit */
.faq-home { padding: 52px 0; background: var(--gray-50); }
.faq-list { margin: 28px auto 0; display: flex; flex-direction: column; gap: 12px; }
.faq-btn {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; background: none; border: none; font-family: var(--font);
  font-size: .9rem; font-weight: 600; color: var(--gray-800); cursor: pointer; text-align: left;
}
.faq-btn svg { flex-shrink: 0; transition: transform .2s; }
.faq-btn[aria-expanded="true"] svg { transform: rotate(180deg); }
.faq-answer { display: none; padding: 0 20px 16px; }
.faq-answer p { color: var(--gray-600); font-size: .9rem; line-height: 1.7; margin: 0; }
.faq-btn[aria-expanded="true"] + .faq-answer { display: block; }

/* Responsive */
@media (max-width: 768px) {
  .hero-model-inner { grid-template-columns: 1fr; gap: 24px; padding: 32px 0 24px; }
  .hero-model-image { order: -1; }
  .hero-phone-img { max-width: 180px; }
  .desc-grid { grid-template-columns: 1fr; }
  .desc-aside { display: none; }
  .hero-ctas { flex-direction: column; }
  .hero-ctas .btn { width: 100%; justify-content: center; }
}

/* Dark mode pages produit */
[data-theme="dark"] .tarifs-section { background: var(--gray-50); }
[data-theme="dark"] .faq-home { background: var(--gray-50); }
[data-theme="dark"] .desc-content h2,
[data-theme="dark"] .desc-content h3 { color: #f1f5f9; }
[data-theme="dark"] .desc-content p,
[data-theme="dark"] .desc-list li { color: #cbd5e1; }
[data-theme="dark"] .desc-aside-card { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .desc-aside-title { color: #f1f5f9; }
[data-theme="dark"] .faq-btn { color: #f1f5f9; }
[data-theme="dark"] .faq-answer p { color: #cbd5e1; }

/* Pages produit — classes complémentaires */
.container-narrow { max-width: 820px; margin: 0 auto; padding: 0 20px; }
.page-section { padding: 52px 0; background: var(--white); }
.page-section-alt { background: var(--gray-50); }
.page-section h2 { font-size: clamp(1.2rem,2.5vw,1.6rem); font-weight: 800; color: var(--gray-800); margin-bottom: 20px; }
.page-section p { color: var(--gray-600); line-height: 1.8; margin-bottom: 14px; }

.hero-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.hero-price-detail { font-size: .75rem; color: var(--gray-500); }
.hero-mention { font-size: .72rem; color: var(--gray-600); margin-top: 4px; }

.breadcrumb-list { list-style: none; display: flex; flex-wrap: wrap; gap: 4px; font-size: .75rem; color: var(--gray-500); padding: 0; margin: 0 0 12px; }
.breadcrumb-list li + li::before { content: "›"; margin-right: 4px; }
.breadcrumb-list a { color: var(--blue); text-decoration: none; }
.breadcrumb-list a:hover { text-decoration: underline; }

.repair-steps { display: flex; flex-direction: column; gap: 14px; margin-top: 28px; }
.repair-step { display: flex; align-items: flex-start; gap: 16px; background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--r-lg); padding: 16px 20px; }
.repair-step-num { flex-shrink: 0; width: 32px; height: 32px; background: var(--blue); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .85rem; font-weight: 800; }
.repair-step strong { display: block; font-size: .9rem; margin-bottom: 4px; color: var(--gray-800); }
.repair-step p { font-size: .82rem; color: var(--gray-500); margin: 0; line-height: 1.6; }

.repair-type-grid { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; }

.avis-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: 16px; margin-top: 24px; }
.avis-stars { color: #F59E0B; font-size: 1rem; margin-bottom: 10px; }
.avis-text { font-size: .84rem; color: var(--gray-600); line-height: 1.7; margin-bottom: 12px; }
.avis-author { font-weight: 700; font-size: .82rem; color: var(--gray-800); }
.avis-source { font-size: .72rem; color: var(--gray-600); margin-top: 2px; }

.faq-list { display: flex; flex-direction: column; gap: 0; margin-top: 24px; }
.faq-home { padding: 52px 0; background: var(--white); }

/* Mode sombre pages produit */
[data-theme="dark"] .page-section { background: #111827; }
[data-theme="dark"] .page-section h2 { color: #f1f5f9; }
[data-theme="dark"] .page-section p { color: #cbd5e1; }
[data-theme="dark"] .page-section-alt { background: #1f2937; }
[data-theme="dark"] .repair-step { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .repair-step strong { color: #f1f5f9; }
[data-theme="dark"] .avis-grid .avis-card { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .avis-text { color: #cbd5e1; }
[data-theme="dark"] .avis-author { color: #f1f5f9; }
[data-theme="dark"] .faq-home { background: #111827; }

/* Page marque niveau 1 */
.hero-marque {
  background: linear-gradient(135deg, var(--blue-light) 0%, var(--white) 65%);
  padding: 40px 0 48px;
  border-bottom: 1px solid var(--blue-mid);
}
.hero-marque-inner {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 48px;
  align-items: center;
}
.hero-marque-content h1 {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 800;
  color: var(--gray-800);
  line-height: 1.2;
  margin: 12px 0 16px;
}
.hero-marque-content h1 em { font-style: normal; color: var(--blue); }
.hero-marque-logo {
  display: flex;
  align-items: center;
  justify-content: center;
}
.marque-logo-img {
  height: 280px;
  width: auto;
  object-fit: contain;
}

/* Grille modèles */
.modeles-groupe { margin-bottom: 36px; }
.modeles-groupe-titre {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-600);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--blue-mid);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: .78rem;
}
.modeles-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.modele-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--white);
  border: 1.5px solid var(--gray-200);
  border-radius: var(--r-lg);
  text-decoration: none;
  color: var(--gray-700);
  font-size: .86rem;
  font-weight: 600;
  transition: border-color .14s, box-shadow .14s, color .14s;
  box-shadow: var(--sh-sm);
}
.modele-card:hover {
  border-color: var(--blue);
  color: var(--blue);
  box-shadow: var(--sh-blue);
}
.modele-card--active {
  border-color: var(--blue);
  background: var(--blue-light);
  color: var(--blue);
}
.modele-arrow {
  font-size: .8rem;
  color: var(--gray-600);
  flex-shrink: 0;
}
.modele-card:hover .modele-arrow { color: var(--blue); }

/* Responsive */
@media (max-width: 1024px) {
  .modeles-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .hero-marque-inner { grid-template-columns: 1fr; }
  .hero-marque-logo { display: none; }
  .modeles-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .modeles-grid { grid-template-columns: 1fr; }
}

/* Dark mode */
[data-theme="dark"] .hero-marque { background: linear-gradient(135deg, var(--blue-light) 0%, #111827 65%); }
[data-theme="dark"] .hero-marque-content h1 { color: #f1f5f9; }
[data-theme="dark"] .modele-card { background: #1e293b; border-color: #334155; color: #cbd5e1; }
[data-theme="dark"] .modele-card:hover { border-color: var(--blue); color: var(--blue); }

/* Page hub niveau 2 — grille prestations */
.prestations-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 28px;
}
.prestation-card {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 1.5px solid var(--gray-200);
  border-radius: var(--r-lg);
  padding: 24px 20px;
  box-shadow: var(--sh-sm);
  transition: border-color .14s, box-shadow .14s;
}
.prestation-card:hover { border-color: var(--blue); box-shadow: var(--sh-blue); }
.prestation-icon {
  width: 56px; height: 56px;
  background: var(--blue-light);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--blue);
  margin-bottom: 16px;
  flex-shrink: 0;
}
.prestation-card h3 {
  font-size: 1rem; font-weight: 700;
  color: var(--gray-800); margin-bottom: 10px;
}
.prestation-card p {
  font-size: .84rem; color: var(--gray-500);
  line-height: 1.7; margin-bottom: 14px; flex: 1;
}
.prestation-prix {
  font-size: 1.4rem; font-weight: 800;
  color: var(--blue); margin-bottom: 6px;
}
.prestation-prix strong { font-size: 1.6rem; }
.prestation-garantie {
  font-size: .72rem; color: var(--gray-600);
  margin-bottom: 16px;
}
.prestation-btn {
  width: 100%;
  text-align: center;
  justify-content: center;
}

/* Autres pannes — contact devis */
.contact-devis-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 28px;
}
.contact-devis-card {
  background: var(--white);
  border: 1.5px solid var(--gray-200);
  border-radius: var(--r-lg);
  padding: 24px 20px;
  text-align: center;
  box-shadow: var(--sh-sm);
}
.contact-devis-card svg {
  color: var(--blue);
  margin-bottom: 12px;
}
.contact-devis-card h3 {
  font-size: .9rem; font-weight: 700;
  color: var(--gray-800); margin-bottom: 8px;
}
.contact-devis-card p {
  font-size: .82rem; color: var(--gray-500);
  line-height: 1.6; margin-bottom: 16px;
}
.contact-devis-card .btn { width: 100%; justify-content: center; }

/* Responsive */
@media (max-width: 900px) {
  .prestations-grid { grid-template-columns: 1fr; }
  .contact-devis-grid { grid-template-columns: 1fr; }
}

/* Dark mode */
[data-theme="dark"] .prestation-card { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .prestation-card h3 { color: #f1f5f9; }
[data-theme="dark"] .prestation-icon { background: #0c2233; }
[data-theme="dark"] .contact-devis-card { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .contact-devis-card h3 { color: #f1f5f9; }

/* ===== REGLES PAGES PRODUIT / MARQUE / HUB — AJOUT DEFINITIF ===== */

/* Boutons flottants mobile — UNIQUEMENT sur mobile */
.mob-float-bar {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0; width: 100%;
  z-index: 9999;
  box-shadow: 0 -2px 12px rgba(0,0,0,.2);
}
.mob-float-btn {
  flex: 1;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px; padding: 12px 0;
  font-family: var(--font); font-size: .72rem; font-weight: 700;
  text-decoration: none; color: #fff !important; letter-spacing: .03em;
}
.mob-float-btn svg { color: #fff !important; stroke: #fff !important; }
.mob-float-call { background: #026a90; }
.mob-float-nav  { background: #15803d; }
[data-theme="dark"] .mob-float-btn { color: #fff !important; }
@media (max-width: 767px) {
  .mob-float-bar { display: flex; }
  body { padding-bottom: 64px; }
}
@media (min-width: 768px) {
  .mob-float-bar { display: none !important; }
}

/* Finder section label — VISIBLE obligatoire */
.finder-section-prod {
  background: var(--gray-50);
  border-bottom: 1px solid var(--gray-200);
  padding: 16px 0 20px;
}
.finder-prod-label {
  display: block;
  font-size: .75rem; font-weight: 600; color: var(--gray-600);
  text-transform: uppercase; letter-spacing: .06em;
  margin-bottom: 10px;
}
.finder-section-prod .finder-wrap { margin: 0; }
[data-theme="dark"] .finder-section-prod { background: #1f2937; border-color: #374151; }

/* Layout 2 colonnes */
.desc-layout { display: grid; grid-template-columns: 1fr 380px; gap: 48px; align-items: start; }
.desc-main h2 { font-size: clamp(1.2rem,2.5vw,1.55rem); font-weight: 800; color: var(--gray-800); margin-bottom: 20px; line-height: 1.3; }
.desc-main p { color: var(--gray-600); line-height: 1.8; margin-bottom: 14px; }
.desc-steps { display: flex; flex-direction: column; gap: 12px; }
@media (max-width: 768px) { .desc-layout { grid-template-columns: 1fr; } }

/* Autres réparations */
.autres-rep-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 20px; }
.rep-link-label { font-weight: 700; font-size: .88rem; color: var(--gray-800); display: block; }
.rep-link-prix  { font-size: .78rem; color: var(--blue); font-weight: 600; display: block; }
@media (max-width: 768px) { .autres-rep-grid { grid-template-columns: 1fr; } }

/* 5 avis en grille */
.avis-grid-prod { display: grid; grid-template-columns: repeat(5,1fr); gap: 14px; margin-top: 24px; }
@media (max-width: 1100px) { .avis-grid-prod { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 768px)  { .avis-grid-prod { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 480px)  { .avis-grid-prod { grid-template-columns: 1fr; } }

/* FAQ pleine largeur */
.faq-list-prod { max-width: 100%; }
.faq-list-prod .faq-item { border-bottom: 1px solid var(--gray-200); }
.faq-btn[aria-expanded="true"] svg { transform: rotate(180deg); }
.faq-btn svg { transition: transform .2s; }
[data-theme="dark"] .faq-list-prod .faq-item { border-color: #374151; }

/* Breadcrumb liste */
.breadcrumb-list { list-style: none; display: flex; flex-wrap: wrap; gap: 4px; font-size: .75rem; color: var(--gray-500); padding: 0; margin: 0; }
.breadcrumb-list li + li::before { content: "›"; margin-right: 4px; }
.breadcrumb-list a { color: var(--blue); text-decoration: none; }

/* Grille modèles page marque */
.modeles-groupe { margin-bottom: 36px; }
.modeles-groupe-titre { font-size: .78rem; font-weight: 700; color: var(--gray-500); margin-bottom: 14px; padding-bottom: 8px; border-bottom: 2px solid var(--blue-mid); text-transform: uppercase; letter-spacing: .04em; }
.modeles-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.modele-card { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--r-lg); text-decoration: none; color: var(--gray-700); font-size: .86rem; font-weight: 600; transition: border-color .14s, box-shadow .14s, color .14s; box-shadow: var(--sh-sm); }
.modele-card:hover { border-color: var(--blue); color: var(--blue); box-shadow: var(--sh-blue); }
.modele-nom { flex: 1; }
.modele-arrow { font-size: .8rem; color: var(--gray-600); flex-shrink: 0; }
.modele-card:hover .modele-arrow { color: var(--blue); }
[data-theme="dark"] .modele-card { background: #1e293b; border-color: #334155; color: #cbd5e1; }
@media (max-width: 1024px) { .modeles-grid { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 768px)  { .modeles-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 480px)  { .modeles-grid { grid-template-columns: 1fr; } }

/* Page hub niveau 2 — grille prestations */
.prestations-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 28px; }
.prestation-card { display: flex; flex-direction: column; background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--r-lg); padding: 24px 20px; box-shadow: var(--sh-sm); transition: border-color .14s, box-shadow .14s; }
.prestation-card:hover { border-color: var(--blue); box-shadow: var(--sh-blue); }
.prestation-icon { width: 56px; height: 56px; background: var(--blue-light); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--blue); margin-bottom: 16px; flex-shrink: 0; }
.prestation-card h3 { font-size: 1rem; font-weight: 700; color: var(--gray-800); margin-bottom: 10px; }
.prestation-card p { font-size: .84rem; color: var(--gray-500); line-height: 1.7; margin-bottom: 14px; flex: 1; }
.prestation-prix { font-size: 1.4rem; font-weight: 800; color: var(--blue); margin-bottom: 6px; }
.prestation-prix strong { font-size: 1.6rem; }
.prestation-garantie { font-size: .72rem; color: var(--gray-600); margin-bottom: 16px; }
.prestation-btn { width: 100%; text-align: center; justify-content: center; }
@media (max-width: 900px) { .prestations-grid { grid-template-columns: 1fr; } }
[data-theme="dark"] .prestation-card { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .prestation-card h3 { color: #f1f5f9; }
[data-theme="dark"] .prestation-icon { background: #0c2233; }

/* Contact devis page hub */
.contact-devis-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 28px; }
.contact-devis-card { background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--r-lg); padding: 24px 20px; text-align: center; box-shadow: var(--sh-sm); }
.contact-devis-card svg { color: var(--blue); margin-bottom: 12px; }
.contact-devis-card h3 { font-size: .9rem; font-weight: 700; color: var(--gray-800); margin-bottom: 8px; }
.contact-devis-card p { font-size: .82rem; color: var(--gray-500); line-height: 1.6; margin-bottom: 16px; }
.contact-devis-card .btn { width: 100%; justify-content: center; }
@media (max-width: 900px) { .contact-devis-grid { grid-template-columns: 1fr; } }
[data-theme="dark"] .contact-devis-card { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .contact-devis-card h3 { color: #f1f5f9; }

/* SVG smartphone */
.hero-phone-svg { display: block; }
.hero-phone-svg svg { display: block; width: 100%; height: 100%; }

.lien-interne a { text-decoration: underline; }
