/* =========================================================
   AS INSPECTION — Global stylesheet (shared by all pages)
   Conforme à la Charte Graphique Autoservice V1.0 — Mai 2026
   Palette: #173B5D / #6B9EC0 / #979798 / #3A3A3A / #FFFFFF
   Typo: Tahoma → Verdana → Arial → sans-serif
   ========================================================= */

:root{
  --marine:#173B5D;
  --marine-deep:#0F2A45;
  --marine-soft:#1F4A75;
  --sky:#6B9EC0;
  --sky-soft:#A6C2D6;
  --silver:#979798;
  --silver-light:#E5E7EA;
  --anthracite:#3A3A3A;
  --white:#FFFFFF;
  --paper:#F7F8FA;
  --paper-deep:#EEF1F5;
  --hairline:rgba(23,59,93,0.12);
  --hairline-strong:rgba(23,59,93,0.2);
  --success:#1F7A4D;
  --warning:#B85C00;
  --whatsapp:#25D366;

  --font-brand:"Tahoma","Verdana","Arial",sans-serif;

  --container:1240px;
  --gutter:clamp(20px, 4vw, 56px);
  --header-h:72px;

  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box}
*:focus-visible{outline:2px solid var(--sky);outline-offset:3px;border-radius:2px}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:var(--font-brand);
  color:var(--anthracite);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
  font-size:16px;
}
img{max-width:100%;display:block}
a{color:var(--marine);text-decoration:none;transition:color .25s var(--ease)}
a:hover{color:var(--sky)}
button{font-family:inherit;cursor:pointer}

/* ========== Utilities ========== */
.container{max-width:var(--container);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.eyebrow{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--sky);font-weight:bold;display:inline-block;
}
.eyebrow::before{
  content:"";display:inline-block;width:28px;height:1px;background:var(--sky);
  vertical-align:middle;margin-right:12px;transform:translateY(-2px);
}
.h1{font-size:clamp(36px,5vw,64px);line-height:1.05;font-weight:bold;color:var(--marine);letter-spacing:-.01em;margin:0}
.h2{font-size:clamp(28px,3.4vw,44px);line-height:1.1;font-weight:bold;color:var(--marine);letter-spacing:-.005em;margin:0 0 12px}
.h3{font-size:clamp(18px,1.6vw,22px);line-height:1.25;font-weight:bold;color:var(--marine);margin:0 0 8px}
.lede{font-size:clamp(15px,1.2vw,17px);color:var(--anthracite);max-width:62ch;line-height:1.6}
.section{padding:clamp(72px,9vw,128px) 0;position:relative}
.section.compact{padding:clamp(48px,6vw,80px) 0}
.divider-rule{height:1px;background:var(--sky);width:64px;margin:0 0 24px}
.divider-rule.light{background:var(--sky-soft)}

.cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--marine);color:var(--white);
  padding:13px 24px;font-size:12px;font-weight:bold;
  letter-spacing:.12em;text-transform:uppercase;
  border:1px solid var(--marine);
  transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .15s var(--ease);
  font-family:inherit;
}
.cta:hover{background:var(--sky);border-color:var(--sky);color:var(--white)}
.cta:active{transform:translateY(1px)}
.cta.ghost{background:transparent;color:var(--marine)}
.cta.ghost:hover{background:var(--marine);color:var(--white)}
.cta.ghost-light{background:transparent;color:var(--white);border-color:rgba(255,255,255,.45)}
.cta.ghost-light:hover{background:var(--white);color:var(--marine);border-color:var(--white)}
.cta.light{background:var(--white);color:var(--marine);border-color:var(--white)}
.cta.light:hover{background:var(--sky);color:var(--white);border-color:var(--sky)}
.cta.wa{background:var(--whatsapp);border-color:var(--whatsapp);color:#fff}
.cta.wa:hover{background:#1FB458;border-color:#1FB458}
.cta .arrow{display:inline-block;width:14px;height:1px;background:currentColor;position:relative}
.cta .arrow::after{
  content:"";position:absolute;right:-1px;top:-3px;width:7px;height:7px;
  border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg);
}

/* ========== Top bar ========== */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(255,255,255,.93);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--hairline);
  transition:box-shadow .3s var(--ease);
}
.topbar.scrolled{box-shadow:0 1px 0 rgba(23,59,93,.06), 0 10px 30px -22px rgba(23,59,93,.18)}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gutter);max-width:var(--container);margin:0 auto;
  min-height:var(--header-h);
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:44px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-size:13px;font-weight:bold;color:var(--marine);letter-spacing:.02em}
.brand-tag{font-size:9px;letter-spacing:.32em;color:var(--silver);text-transform:uppercase;margin-top:4px}
.nav{display:flex;gap:30px;align-items:center}
.nav > .nav-item{position:relative}
.nav a, .nav button.nav-trigger{
  font-size:13px;color:var(--anthracite);font-weight:bold;
  letter-spacing:.04em;text-transform:uppercase;
  position:relative;padding:8px 0;background:none;border:none;
  font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
}
.nav a.active, .nav a[aria-current="page"]{color:var(--marine)}
.nav a::after, .nav button.nav-trigger::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--sky);
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);
}
.nav a.active::after, .nav a[aria-current="page"]::after{transform:scaleX(1)}
.nav a:hover::after, .nav button.nav-trigger:hover::after, .nav-item:hover button.nav-trigger::after{transform:scaleX(1)}
.nav a:hover, .nav button.nav-trigger:hover{color:var(--marine)}
.nav-trigger .chev{
  width:8px;height:8px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
  transform:rotate(45deg);transform-origin:center;transition:transform .25s var(--ease);
  margin-top:-3px;
}
.nav-item:hover .chev{transform:rotate(225deg);margin-top:2px}

/* Mega menu (services) */
.megamenu{
  position:absolute;top:calc(100% + 8px);left:-24px;
  min-width:560px;background:#fff;border:1px solid var(--hairline);
  padding:24px;opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
  box-shadow:0 30px 60px -20px rgba(23,59,93,.18);
  display:grid;grid-template-columns:repeat(2,1fr);gap:6px 18px;
}
.nav-item:hover .megamenu, .nav-item:focus-within .megamenu{opacity:1;visibility:visible;transform:translateY(0)}
.megamenu a{
  display:flex;flex-direction:column;padding:12px 14px;text-transform:none;letter-spacing:0;
  font-size:13px;color:var(--marine);font-weight:bold;border-left:2px solid transparent;
  transition:background .2s var(--ease), border-color .2s var(--ease);
}
.megamenu a:hover{background:var(--paper);border-left-color:var(--sky)}
.megamenu a::after{display:none}
.megamenu a small{
  display:block;font-weight:normal;font-size:11px;color:var(--silver);letter-spacing:.04em;
  margin-top:3px;text-transform:none;
}

.burger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;
  background:none;border:none;
}
.burger span{width:24px;height:2px;background:var(--marine);transition:transform .25s var(--ease), opacity .25s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{
  position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
  background:#fff;z-index:49;
  transform:translateX(100%);transition:transform .35s var(--ease);
  overflow-y:auto;padding:24px var(--gutter) 40px;
  display:flex;flex-direction:column;gap:8px;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a, .mobile-menu .mm-group-title{
  display:block;padding:14px 4px;font-size:14px;font-weight:bold;color:var(--marine);
  border-bottom:1px solid var(--hairline);letter-spacing:.04em;text-transform:uppercase;
}
.mobile-menu .mm-group-title{color:var(--silver);font-size:11px;letter-spacing:.22em;border:none;padding-top:24px;padding-bottom:8px}
.mobile-menu .mm-sub{padding-left:16px;font-size:13px;text-transform:none;letter-spacing:0;color:var(--anthracite)}
.mobile-menu .cta{margin-top:24px;justify-content:center}

/* ========== Generic banner (sub-page headers) ========== */
.page-banner{
  background:var(--marine);color:var(--white);
  padding:calc(var(--header-h) + 80px) 0 80px;
  position:relative;overflow:hidden;
}
.page-banner::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(600px 350px at 90% 110%, rgba(107,158,192,.22), transparent 60%),
    radial-gradient(500px 400px at 0% -20%, rgba(107,158,192,.12), transparent 60%);
  pointer-events:none;
}
.page-banner .container{position:relative}
.page-banner h1{color:var(--white);max-width:20ch;margin-top:16px}
.page-banner .eyebrow{color:var(--sky-soft)}
.page-banner .eyebrow::before{background:var(--sky-soft)}
.page-banner .lede{color:#D8E2EC;margin-top:20px}
.breadcrumb{
  display:flex;gap:8px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.65);align-items:center;
}
.breadcrumb a{color:rgba(255,255,255,.85)}
.breadcrumb a:hover{color:#fff}
.breadcrumb .sep{color:var(--sky)}

/* ========== Trust band ========== */
.trust{
  background:var(--paper);
  border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  padding:28px 0;
}
.trust-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.trust-label{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--silver);font-weight:bold;
}
.trust-items{display:flex;gap:40px;flex-wrap:wrap;align-items:center}
.trust-items span{
  font-size:13px;color:var(--marine);font-weight:bold;letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:10px;
}
.trust-items span::before{
  content:"";width:8px;height:8px;border:2px solid var(--sky);transform:rotate(45deg);display:inline-block;
}

/* ========== Footer ========== */
.footer{
  background:var(--marine-deep);color:#C9D3DD;
  padding:80px 0 32px;position:relative;overflow:hidden;
}
.footer::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--sky);opacity:.55;
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.12);
}
.foot-brand img{height:52px;margin-bottom:18px}
.foot-brand p{font-size:13px;color:#A8B5C2;max-width:36ch;line-height:1.6}
.foot-col h5{
  color:var(--white);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  margin:0 0 18px;font-weight:bold;
}
.foot-col h5::after{content:"";display:block;width:24px;height:1px;background:var(--sky);margin-top:10px}
.foot-col a, .foot-col p{
  display:block;font-size:13px;color:#B8C4D0;margin-bottom:10px;line-height:1.5;
}
.foot-col a:hover{color:var(--white)}
.foot-col .agency-name{color:#fff;font-weight:bold;margin-bottom:4px}
.foot-bottom{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px;
  margin-top:28px;font-size:11px;letter-spacing:.06em;color:#7E8A98;
}
.foot-bottom .socials{display:flex;gap:14px}
.foot-bottom .socials a{
  width:34px;height:34px;border:1px solid rgba(255,255,255,.2);display:inline-flex;
  align-items:center;justify-content:center;
  transition:border-color .25s var(--ease), background .25s var(--ease);
}
.foot-bottom .socials a:hover{border-color:var(--sky);background:var(--sky)}
.foot-bottom .socials svg{width:14px;height:14px;fill:#B8C4D0;transition:fill .25s var(--ease)}
.foot-bottom .socials a:hover svg{fill:var(--white)}
.foot-bottom .legal-links{display:flex;gap:18px}
.foot-bottom .legal-links a{color:#7E8A98}
.foot-bottom .legal-links a:hover{color:#fff}

/* ========== WhatsApp floating button ========== */
.wa-fab{
  position:fixed;right:24px;bottom:24px;z-index:40;
  display:flex;align-items:center;gap:12px;
  background:var(--whatsapp);color:#fff;padding:14px 20px 14px 14px;
  border-radius:50px;
  box-shadow:0 10px 30px -8px rgba(37,211,102,.5), 0 4px 12px rgba(0,0,0,.15);
  font-weight:bold;font-size:13px;letter-spacing:.04em;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  border:none;cursor:pointer;font-family:inherit;
}
.wa-fab:hover{transform:translateY(-2px);box-shadow:0 16px 40px -10px rgba(37,211,102,.6), 0 6px 16px rgba(0,0,0,.18);color:#fff}
.wa-fab .wa-icon{
  width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.wa-fab svg{width:18px;height:18px;fill:#fff}
.wa-fab-label{display:inline-block}
.wa-fab .pulse{
  position:absolute;inset:0;border-radius:50px;border:2px solid var(--whatsapp);
  animation:waPulse 2.4s infinite var(--ease);pointer-events:none;
}
@keyframes waPulse{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(1.25);opacity:0}
}

/* WhatsApp dialog modal */
.modal-back{
  position:fixed;inset:0;background:rgba(15,42,69,.55);
  display:none;align-items:center;justify-content:center;z-index:60;padding:20px;
  opacity:0;transition:opacity .25s var(--ease);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.modal-back.show{display:flex;opacity:1}
.modal{
  background:#fff;max-width:440px;width:100%;
  position:relative;transform:translateY(20px);
  transition:transform .35s var(--ease);
}
.modal-back.show .modal{transform:translateY(0)}
.modal-head{
  background:var(--marine);color:#fff;padding:24px 28px;position:relative;
}
.modal-head::before{
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--sky);
}
.modal-head h3{color:#fff;margin:0;font-size:18px;letter-spacing:.01em}
.modal-head .subtitle{font-size:12px;color:var(--sky-soft);margin-top:4px;letter-spacing:.06em}
.modal-close{
  position:absolute;top:18px;right:18px;width:32px;height:32px;
  background:rgba(255,255,255,.1);border:none;color:#fff;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s var(--ease);
}
.modal-close:hover{background:rgba(255,255,255,.22)}
.modal-body{padding:28px}
.modal-body p{font-size:14px;color:var(--anthracite);margin:0 0 18px;line-height:1.55}
.modal-body .wa-options{display:flex;flex-direction:column;gap:10px}
.wa-option{
  display:flex;align-items:center;gap:14px;padding:16px;
  border:1px solid var(--hairline);background:#fff;text-align:left;width:100%;
  font-family:inherit;cursor:pointer;transition:border-color .25s var(--ease), background .25s var(--ease);
}
.wa-option:hover{border-color:var(--whatsapp);background:#F6FBF8}
.wa-option .wa-icon{
  width:42px;height:42px;background:var(--whatsapp);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex:none;
}
.wa-option .wa-icon svg{width:22px;height:22px;fill:#fff}
.wa-option .wa-meta{flex:1}
.wa-option .wa-meta strong{display:block;color:var(--marine);font-size:14px;margin-bottom:2px}
.wa-option .wa-meta span{font-size:12px;color:var(--silver);letter-spacing:.04em}
.wa-option .wa-arrow{color:var(--silver);font-size:18px;transition:transform .25s var(--ease), color .25s var(--ease)}
.wa-option:hover .wa-arrow{color:var(--whatsapp);transform:translateX(4px)}

/* ========== Cookie banner ========== */
.cookie-banner{
  position:fixed;left:24px;right:24px;bottom:24px;z-index:55;
  background:#fff;border:1px solid var(--hairline);
  padding:24px 28px;
  display:none;gap:24px;align-items:flex-start;flex-wrap:wrap;
  box-shadow:0 20px 50px -10px rgba(15,42,69,.25);
  max-width:920px;margin:0 auto;
  transform:translateY(20px);opacity:0;
  transition:transform .35s var(--ease), opacity .35s var(--ease);
}
.cookie-banner.show{display:flex;transform:translateY(0);opacity:1}
.cookie-banner::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--marine);
}
.cookie-content{flex:1;min-width:280px}
.cookie-content h4{
  margin:0 0 6px;color:var(--marine);font-size:13px;letter-spacing:.04em;
  text-transform:uppercase;font-weight:bold;
}
.cookie-content p{margin:0;font-size:13px;color:var(--anthracite);line-height:1.55;max-width:60ch}
.cookie-content p a{color:var(--marine);font-weight:bold;text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cookie-actions .cta{padding:10px 18px;font-size:11px}

.cookie-prefs{
  position:fixed;inset:0;background:rgba(15,42,69,.55);
  display:none;align-items:center;justify-content:center;z-index:60;padding:20px;
  backdrop-filter:blur(4px);
}
.cookie-prefs.show{display:flex}
.cookie-prefs .modal{max-width:520px}
.cookie-prefs .modal-body{max-height:60vh;overflow-y:auto}
.cookie-cat{
  border-top:1px solid var(--hairline);padding:18px 0;
}
.cookie-cat:first-child{border-top:none;padding-top:0}
.cookie-cat-head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:6px;
}
.cookie-cat-head strong{color:var(--marine);font-size:14px}
.cookie-cat p{font-size:12px;color:var(--silver);margin:0;line-height:1.5}
.toggle{
  position:relative;width:42px;height:22px;background:var(--silver-light);
  border-radius:999px;cursor:pointer;transition:background .25s var(--ease);
  border:none;flex:none;
}
.toggle::after{
  content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;
  background:#fff;border-radius:50%;transition:transform .25s var(--ease);
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle.on{background:var(--marine)}
.toggle.on::after{transform:translateX(20px)}
.toggle.locked{background:var(--sky);cursor:not-allowed;opacity:.7}
.toggle.locked::after{transform:translateX(20px)}

/* ========== Reveal animations ========== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease-out), transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
/* Force-show fallback (no-JS, prefers-reduced-motion, screenshots) */
.no-anim .reveal{opacity:1 !important;transform:none !important}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}

/* ========== Responsive ========== */
@media (max-width: 1024px){
  .nav, .topbar .cta{display:none}
  .burger{display:inline-flex}
}
@media (max-width: 720px){
  .foot-grid{grid-template-columns:1fr;gap:32px}
  .wa-fab-label{display:none}
  .wa-fab{padding:14px}
  .cookie-banner{padding:20px;left:12px;right:12px;bottom:12px;gap:14px}
  .cookie-actions{width:100%}
  .cookie-actions .cta{flex:1;justify-content:center}
}

/* Print fallback */
@media print{
  .topbar,.footer,.wa-fab,.cookie-banner,.modal-back{display:none !important}
  body{color:#000}
}

/* =========================================================
   ADDITIONS — WhatsApp multi-agences modal
   ========================================================= */

/* Agence block dans le modal WhatsApp */
.wa-agency-block {
  border: 1px solid var(--hairline);
  padding: 18px 20px;
  margin-bottom: 10px;
  transition: border-color .2s var(--ease);
}
.wa-agency-block:last-child { margin-bottom: 0; }
.wa-agency-block:hover { border-color: var(--whatsapp); }
.wa-agency-principal { border-left: 3px solid var(--marine); }

.wa-agency-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 12px;
}
.wa-agency-region {
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--silver);
  font-weight: bold;
}
.wa-agency-name {
  font-size: 15px;
  color: var(--marine);
  font-weight: bold;
}
.wa-agency-hours {
  font-size: 11px;
  color: var(--silver);
  letter-spacing: .04em;
}
.wa-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: bold;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: var(--marine);
  color: #fff;
  padding: 2px 7px;
  margin-left: 8px;
  vertical-align: middle;
  position: relative;
  top: -1px;
}

/* Boutons numéros */
.wa-agency-phones {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.wa-phone-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--whatsapp);
  color: #fff;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: bold;
  text-decoration: none;
  letter-spacing: .02em;
  transition: background .2s var(--ease), transform .15s var(--ease);
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.wa-phone-btn:hover {
  background: #1dbd5a;
  color: #fff;
  transform: translateY(-1px);
}
.wa-phone-btn svg {
  width: 16px;
  height: 16px;
  fill: #fff;
  flex-shrink: 0;
}

/* Modal élargi pour 3 agences */
#waModal .modal { max-width: 540px; }
