/* HEADER */
.site-header{
  position:fixed;top:0;left:0;right:0;
  z-index:var(--z-header);
  height:var(--header-h-mobile);
  display:flex;align-items:center;
  background:transparent;
  transition:background .3s ease, box-shadow .3s ease, border-color .3s ease, color .3s ease;
  border-bottom:1px solid transparent;
  color:#fff;
}
.site-header .brand{color:#fff;}
.site-header .brand-name em{color:var(--accent-soft);}
.site-header .brand-tag{color:rgba(255,255,255,.78);}
.site-header .brand-mark{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.32);color:#fff;}
.site-header.is-scrolled{
  background:color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--border);
  box-shadow:0 4px 18px -10px rgba(49,42,32,.20);
  color:var(--text);
}
.site-header.is-scrolled .brand{color:var(--text);}
.site-header.is-scrolled .brand-name em{color:var(--accent);}
.site-header.is-scrolled .brand-tag{color:var(--text-2);}
.site-header.is-scrolled .brand-mark{background:color-mix(in srgb, var(--accent) 18%, var(--bg));border-color:color-mix(in srgb, var(--accent) 32%, transparent);color:var(--accent);}
.site-header.is-scrolled .nav-desktop a{color:var(--text);}
.site-header .nav-desktop a{color:#fff;}
.site-header .nav-desktop a:hover{color:var(--accent-soft);}
.site-header.is-scrolled .nav-desktop a:hover{color:var(--accent);}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:16px;}
.brand{display:inline-flex;align-items:center;gap:12px;color:var(--text);}
.brand-mark{width:36px;height:36px;border-radius:50%;background:color-mix(in srgb, var(--accent) 18%, var(--bg));color:var(--accent);display:grid;place-items:center;flex-shrink:0;border:1px solid color-mix(in srgb, var(--accent) 32%, transparent);}
.brand-mark svg{width:22px;height:22px;}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-name{font-family:var(--ff-display);font-weight:600;font-size:1.08rem;letter-spacing:-.005em;}
.brand-name em{font-style:italic;color:var(--accent);font-weight:500;}
.brand-tag{font-family:var(--ff-ui);font-size:.62rem;letter-spacing:.18em;color:var(--text-2);text-transform:uppercase;margin-top:4px;}
@media (max-width:480px){.brand-tag{display:none;}}

.nav-desktop{display:none;}
.nav-desktop ul{display:flex;gap:28px;}
.nav-desktop a{font-family:var(--ff-ui);font-size:.92rem;color:var(--text);font-weight:500;letter-spacing:.005em;}
.nav-desktop a:hover{color:var(--accent);}

.header-cta{display:none;}

@media (min-width:992px){
  .site-header{height:var(--header-h);}
  .nav-desktop{display:flex;align-items:center;gap:32px;}
  .header-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--accent);color:#fff !important;border-radius:999px;font-family:var(--ff-ui);font-weight:600;font-size:.88rem;}
  .header-cta:hover{background:var(--accent-deep);color:#fff;}
  .header-cta svg{width:16px;height:16px;}
}

/* BURGER (toujours haut droite) */
.burger{
  position:fixed;
  top:calc((var(--header-h-mobile) - 44px) / 2);
  right:14px;
  width:44px;height:44px;
  display:grid;place-items:center;
  background:transparent;border:0;
  z-index:var(--z-burger);
  border-radius:50%;
}
.burger-bars{position:relative;width:22px;height:14px;}
.burger-bars span{position:absolute;left:0;width:22px;height:1.8px;background:#fff;border-radius:1px;transition:transform .3s ease, top .3s ease, opacity .2s ease, background .3s ease;box-shadow:0 0 6px rgba(0,0,0,.25);}
.site-header.is-scrolled ~ .burger .burger-bars span,
body.has-scrolled .burger .burger-bars span{background:var(--text);box-shadow:none;}
.burger.is-open .burger-bars span{background:var(--text) !important;box-shadow:none;}
.burger-bars span:nth-child(1){top:0;}
.burger-bars span:nth-child(2){top:6px;}
.burger-bars span:nth-child(3){top:12px;}
.burger.is-open .burger-bars span:nth-child(1){top:6px;transform:rotate(45deg);}
.burger.is-open .burger-bars span:nth-child(2){opacity:0;}
.burger.is-open .burger-bars span:nth-child(3){top:6px;transform:rotate(-45deg);}
@media (min-width:992px){.burger{display:none;}}

/* MENU MOBILE (enfant direct de body — voir HTML) */
.menu-mobile{
  position:fixed;
  top:0;left:0;
  width:100%;
  height:100dvh;
  background:var(--bg);
  z-index:var(--z-menu);
  padding:calc(var(--header-h-mobile) + 16px) 28px 40px;
  display:flex;flex-direction:column;gap:8px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  transform:translateY(-100%);
  opacity:0;
  visibility:hidden;
  transition:transform .4s cubic-bezier(.4,.0,.2,1), opacity .35s ease, visibility 0s linear .4s;
}
.menu-mobile.is-open{
  transform:translateY(0);
  opacity:1;
  visibility:visible;
  transition:transform .4s cubic-bezier(.4,.0,.2,1), opacity .35s ease;
}
.menu-mobile::before{
  content:"";display:block;width:48px;height:2px;background:var(--accent);margin-bottom:24px;
}
.menu-mobile a{
  font-family:var(--ff-display);
  font-size:1.7rem;
  font-weight:500;
  color:var(--text);
  padding:14px 0;
  border-bottom:1px solid var(--border);
}
.menu-mobile a:hover{color:var(--accent);}
.menu-mobile .mm-ctas{display:flex;flex-direction:column;gap:12px;margin-top:24px;}
.menu-mobile .mm-ctas .btn{width:100%;justify-content:center;}
.menu-mobile .mm-foot{margin-top:auto;padding-top:24px;font-size:.85rem;color:var(--text-2);}
.menu-mobile .mm-foot a{font-family:var(--ff-ui);font-size:.95rem;color:var(--accent);padding:0;border:0;}
@media (min-width:992px){.menu-mobile{display:none !important;}}

/* FOOTER */
.site-footer{
  background:var(--surface-deep);
  color:var(--on-dark);
  padding:48px 0 0;
  margin-top:0;
}
.site-footer h3{color:var(--on-dark);font-size:1.05rem;margin-bottom:14px;font-family:var(--ff-display);}
.footer-grid{display:grid;grid-template-columns:1fr;gap:36px;}
.footer-brand .brand-mark{background:color-mix(in srgb, var(--accent) 22%, transparent);border-color:color-mix(in srgb, var(--accent-2) 45%, transparent);color:var(--accent-soft);}
.footer-brand .brand-name{color:var(--on-dark);}
.footer-brand .brand-name em{color:var(--accent-soft);}
.footer-brand p{color:var(--on-dark-2);margin-top:14px;max-width:42ch;font-size:.95rem;line-height:1.55;}
.footer-contact ul{display:flex;flex-direction:column;gap:10px;}
.footer-contact a{color:var(--on-dark-2);display:inline-flex;gap:10px;align-items:center;}
.footer-contact a:hover{color:var(--accent-soft);}
.footer-contact svg{width:16px;height:16px;color:var(--accent-soft);flex-shrink:0;}
.footer-hours li{display:flex;justify-content:space-between;color:var(--on-dark-2);padding:6px 0;border-bottom:1px solid rgba(244,239,217,.08);font-size:.92rem;}
.footer-hours li:last-child{border-bottom:0;}
.footer-hours li span:first-child{color:var(--on-dark);font-weight:500;}
.footer-bottom{
  margin-top:36px;padding:18px 0;border-top:1px solid rgba(244,239,217,.12);
  display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:space-between;text-align:center;
  font-size:.82rem;color:var(--on-dark-2);
}
.footer-bottom button{color:var(--on-dark-2);text-decoration:underline;text-underline-offset:3px;font-size:.82rem;}
.footer-bottom button:hover{color:var(--accent-soft);}
@media (min-width:769px){
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr;gap:48px;}
  .footer-bottom{flex-direction:row;text-align:left;}
}

/* FAB Mobile (Appeler) */
.fab-call{
  position:fixed;bottom:20px;right:18px;
  z-index:1050;
  width:60px;height:60px;border-radius:50%;
  background:var(--accent);color:#fff !important;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 26px -10px rgba(106,118,58,.55), 0 0 0 4px color-mix(in srgb, var(--accent) 20%, transparent);
  opacity:0;transform:translateY(20px);pointer-events:none;
  transition:opacity .3s ease, transform .3s ease, background .2s ease;
}
.fab-call.is-shown{opacity:1;transform:none;pointer-events:auto;}
.fab-call:hover{background:var(--accent-deep);color:#fff;}
.fab-call svg{width:26px;height:26px;}
@media (min-width:992px){.fab-call{display:none;}}
