/* header */
:root{
  --site-header-h: 72px; /* ajuste si besoin (ex: 64px, 80px) */
}

/* Header fixe (sauf smartphone paysage) */
.site-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: rgba(0,0,0,.75);
  /* Effet "verre sablé" quand supporté (Prestige vibe), avec fallback déjà assuré */
@supports ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))){
  /* Plus spécifique -> gagne même si un autre .site-header est défini après */
  body .site-header{
    background: rgba(0,0,0,.35);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
  }

  /* Encore plus spécifique pour les pages non-prestige (au cas où) */
  body:not(.theme-prestige) .site-header{
    background: rgba(0,0,0,.35);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
  }
}

}

/* évite que le header recouvre le contenu */
body{
  padding-top: var(--site-header-h);
}

/* Exception : smartphone paysage -> header non fixe + pas de padding */
@media (max-width: 980px) and (orientation: landscape){
  .site-header{
    position: static;
  }
  body{
    padding-top: 0;
  }
}

.site-header-inner,
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  min-height:78px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand img,
.brand-logo{
  height:42px;
  width:auto;
  opacity:.95;
  transform: translate3d(0,0,0);
  transition: transform 450ms cubic-bezier(.55, 0, .12, 1), opacity 300ms ease;
  will-change: transform;
}

@media (hover: hover) and (pointer: fine){
  .brand:hover .brand-logo,
  .brand:hover img{
    transform: scale(1.035);
    opacity: 1;
  }
}

.toplinks,
.nav{ display:flex; gap:18px; align-items:center; }

.toplinks a,
.nav-link{
  color:var(--text);
  opacity:.9;
  text-decoration:none;
}
.toplinks a:hover{ opacity:1; }
.nav-link:hover{ opacity:1; }

/* ✅ MENU HEADER = FLAT (desktop) */
.nav-pill{
  padding:0;
  border:none;
  border-radius:0;
}
.nav-link-strong{
  padding:0;
  border:none;
  border-radius:0;
}

/* feedback moderne sur hover (desktop) */
.nav-link,
.nav-link-strong{
  position:relative;
}
.nav-link::after,
.nav-link-strong::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-8px;
  height:1px;
  background: rgba(255,255,255,.22);
  transform: scaleX(0);
  transform-origin:left;
  transition: transform .18s ease;
}
.nav-link:hover::after,
.nav-link-strong:hover::after{
  transform: scaleX(1);
}

/* tel (desktop) */
.tel-pill{
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.header-phone{
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
  color:var(--text);
  opacity:.9;
  text-decoration:none;
}
.header-phone:hover{ opacity:1; }

/* burger (desktop: caché) */
.nav-toggle{ display:none; }

/* --- Mobile header / burger --- */
@media (max-width: 700px){
  .header-inner{
    min-height:64px;
    gap:10px;
    position:relative;
  }

  .brand-logo{ height:34px; }

  /* ✅ Burger FLAT (sans pill/cadre), mais avec une zone tap confortable */
  .nav-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    width:44px;
    height:44px;

    border:none;
    border-radius:0;
    background: transparent;

    color: var(--text);
    opacity:.95;
    cursor:pointer;
    flex: 0 0 auto;
  }
  .nav-toggle:hover{ opacity:1; }

  /* Tel hors header en mobile */
  .header-phone{ display:none; }

  /* Nav panneau déroulant */
  .nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;

    padding:12px 16px;
    flex-direction:column;
    align-items:flex-start;
    gap:10px;

    background: rgba(123,82,45,.92);
    border-bottom:1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(12px);
  }
  .nav.is-open{ display:flex; }

  /* Liens simples */
  .nav-link,
  .nav-link-strong{
    display:block;
    padding:10px 0;
    border: none;
    border-radius: 0;
    width:100%;
    box-sizing:border-box;
    opacity:.95;
  }

  /* pas d'underline desktop dans le panneau mobile */
  .nav-link::after,
  .nav-link-strong::after{ display:none; }
}

/* footer */
.site-footer{
  padding: 44px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.35);
}
.footer-grid,
.footer-inner{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 26px;
}
.footer-grid a,
.footer-link{ color: var(--text); opacity:.9; text-decoration:none; }
.footer-grid a:hover{ opacity:1; }
.footer-link:hover{ opacity:1; }
.footer-col{ display:flex; flex-direction:column; gap:10px; }
.footer-title{ font-weight:700; }
.small{ opacity:.7; font-size:.95rem; }
@media (max-width: 860px){
  .footer-grid,
  .footer-inner{ grid-template-columns: 1fr; }
}

/* Footer mobile : moins aéré */
@media (max-width: 700px){
  .site-footer{
    padding: 18px 0;
  }

  .footer-grid,
  .footer-inner{
    gap: 12px;
  }

  .footer-col{
    gap: 6px;
  }

  .footer-title{
    margin-bottom: 2px;
  }
}

/* Dernier recours : couche "glass" indépendante des backgrounds écrasés ailleurs */
@supports ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))){
  .site-header{
    position: fixed;
  }

  .site-header::before{
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.20);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    pointer-events: none;
    z-index: 0;
  }

  /* remet le contenu du header au-dessus de la couche */
  .site-header > *{
    position: relative;
    z-index: 1;
  }
}
