/* Correctif menu mobile — chargé en tout dernier.
   Objectif : menu mobile visible, compact, lisible, sans scroll obligatoire. */

@media (max-width:1080px){
  #site-header{
    position:sticky !important;
    top:0 !important;
    z-index:10000 !important;
    background:rgba(251,248,242,.96) !important;
    border-bottom:1px solid rgba(26,22,18,.10) !important;
    backdrop-filter:blur(14px) !important;
  }

  #site-header .nav{
    position:relative !important;
    z-index:10002 !important;
    min-height:64px !important;
  }

  #site-header .nav-toggle{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:40px !important;
    padding:0 14px !important;
    border:1px solid rgba(26,22,18,.18) !important;
    background:#fffaf2 !important;
    color:#1A1612 !important;
    -webkit-text-fill-color:#1A1612 !important;
    font:800 .72rem/1 Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif !important;
    letter-spacing:.07em !important;
    text-transform:uppercase !important;
    border-radius:0 !important;
  }

  #site-header .mobile-panel{
    position:fixed !important;
    top:64px !important;
    left:12px !important;
    right:12px !important;
    bottom:auto !important;
    z-index:10001 !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:0 !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
    transform:translateY(-8px) !important;
    max-height:calc(100svh - 76px) !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch !important;
    padding:10px 14px 14px !important;
    background:rgba(255,250,242,.985) !important;
    border:1px solid rgba(26,22,18,.12) !important;
    box-shadow:0 22px 54px rgba(26,22,18,.18) !important;
    backdrop-filter:blur(14px) !important;
    transition:opacity .16s ease, transform .16s ease, visibility .16s ease !important;
  }

  #site-header .mobile-panel.is-open{
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
    transform:translateY(0) !important;
  }

  #site-header .mobile-panel a{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    width:100% !important;
    min-height:42px !important;
    padding:9px 0 !important;
    border:0 !important;
    border-bottom:1px solid rgba(26,22,18,.10) !important;
    background:transparent !important;
    color:#1A1612 !important;
    -webkit-text-fill-color:#1A1612 !important;
    text-decoration:none !important;
    font-family:Fraunces,Georgia,serif !important;
    font-size:1.12rem !important;
    font-weight:800 !important;
    line-height:1.05 !important;
    letter-spacing:-.03em !important;
  }

  #site-header .mobile-panel a:hover,
  #site-header .mobile-panel a:focus-visible{
    color:#C8501A !important;
    -webkit-text-fill-color:#C8501A !important;
  }

  #site-header .mobile-panel .nav-phone-mobile,
  #site-header .mobile-panel .nav-audit-mobile,
  #site-header .mobile-panel .nav-cta-mobile{
    min-height:42px !important;
    margin-top:8px !important;
    padding:0 14px !important;
    justify-content:center !important;
    border:1px solid transparent !important;
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif !important;
    font-size:.70rem !important;
    font-weight:800 !important;
    letter-spacing:.06em !important;
    text-transform:uppercase !important;
    line-height:1 !important;
  }

  #site-header .mobile-panel .nav-phone-mobile{
    margin-top:12px !important;
    background:#fffaf2 !important;
    border-color:rgba(26,22,18,.22) !important;
    color:#1A1612 !important;
    -webkit-text-fill-color:#1A1612 !important;
  }

  #site-header .mobile-panel .nav-audit-mobile{
    background:#C8501A !important;
    border-color:#C8501A !important;
    color:#fff !important;
    -webkit-text-fill-color:#fff !important;
  }

  #site-header .mobile-panel .nav-cta-mobile{
    background:#1A1612 !important;
    border-color:#1A1612 !important;
    color:#fff !important;
    -webkit-text-fill-color:#fff !important;
  }

  .mobile-conversion-bar{
    z-index:9999 !important;
  }
}

@media (max-width:420px){
  #site-header .mobile-panel{
    left:10px !important;
    right:10px !important;
    padding:8px 12px 12px !important;
  }

  #site-header .mobile-panel a{
    min-height:39px !important;
    padding:8px 0 !important;
    font-size:1.04rem !important;
  }

  #site-header .mobile-panel .nav-phone-mobile,
  #site-header .mobile-panel .nav-audit-mobile,
  #site-header .mobile-panel .nav-cta-mobile{
    min-height:40px !important;
    margin-top:7px !important;
    font-size:.66rem !important;
  }
}

@media (min-width:1081px){
  #site-header .mobile-panel{
    display:none !important;
  }
}
