/* ═══════════════════════════════════════
   ZAYOLI — Navigation Premium
   ═══════════════════════════════════════ */

.zb-nav {
  position: sticky;
  top: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 62px;
  padding: 0 clamp(20px, 4vw, 60px);
  background: rgba(245, 240, 232, 0.7);
  backdrop-filter: blur(24px) saturate(1.2);
  -webkit-backdrop-filter: blur(24px) saturate(1.2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 1px 3px rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.03);
  transition: all 0.4s var(--z-ease);
}

.zb-nav.scrolled {
  height: 56px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03), 0 4px 16px rgba(0,0,0,0.05), 0 12px 32px rgba(0,0,0,0.03);
  background: rgba(245, 240, 232, 0.85);
  backdrop-filter: blur(32px) saturate(1.3);
  -webkit-backdrop-filter: blur(32px) saturate(1.3);
}

/* Logo */
.zb-nav-logo {
  text-decoration: none;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.zb-nav-logo-img {
  height: 38px;
  width: auto;
  transition: height 0.4s var(--z-ease);
}
.zb-nav.scrolled .zb-nav-logo-img {
  height: 30px;
}

/* Links */
.zb-nav-links {
  display: flex;
  align-items: center;
  gap: 32px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.zb-nav-links > li {
  position: relative;
}
.zb-nav-links > li > a {
  font-family: var(--z-font-label);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--z-text-light);
  text-decoration: none;
  padding: 28px 0;
  display: block;
  position: relative;
  transition: color 0.3s ease;
}
.zb-nav-links > li > a::after {
  content: '';
  position: absolute;
  bottom: 22px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--z-olive), var(--z-gold));
  border-radius: 1px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.35s var(--z-ease-spring, cubic-bezier(0.34, 1.56, 0.64, 1));
}
.zb-nav-links > li > a:hover {
  color: var(--z-olive);
}
.zb-nav-links > li > a:hover::after {
  transform: scaleX(1);
}

/* Current page */
.zb-nav-links > li > a[aria-current="page"],
.zb-nav-links > li.current > a {
  color: var(--z-olive);
}

/* Dropdown */
.zb-sub {
  display: none;
  position: absolute;
  top: calc(100% - 4px);
  left: -16px;
  background: rgba(245, 240, 232, 0.8);
  backdrop-filter: blur(24px) saturate(1.2);
  -webkit-backdrop-filter: blur(24px) saturate(1.2);
  border-radius: var(--z-radius);
  padding: 12px 0;
  min-width: 220px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.06), 0 24px 48px rgba(0,0,0,0.06);
  border: 1px solid rgba(255,255,255,0.2);
  z-index: 20000;
  list-style: none;
  margin: 0;
  animation: zbDropIn 0.25s var(--z-ease);
}
@keyframes zbDropIn {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}
.zb-has-sub:hover .zb-sub {
  display: block;
}
.zb-sub li a {
  display: block;
  padding: 11px 28px;
  font-family: var(--z-font-label);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.8px;
  color: var(--z-text-light);
  text-decoration: none;
  transition: all 0.2s ease;
}
.zb-sub li a:hover {
  color: var(--z-olive);
  background: rgba(122, 140, 53, 0.06);
  padding-left: 32px;
}

/* Actions (panier + burger) */
.zb-nav-actions {
  display: flex;
  align-items: center;
  gap: 16px;
}
.zb-nav-cart {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--z-font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--z-gold);
  text-decoration: none;
  border: 1.5px solid var(--z-gold);
  padding: 9px 20px;
  border-radius: var(--z-radius-pill);
  transition: all 0.3s ease;
  position: relative;
}
.zb-nav-cart:hover {
  background: var(--z-gold);
  color: var(--z-white);
}
.zb-nav-cart svg { transition: inherit; }
.zb-nav-cart:hover svg { color: var(--z-white); }

.zb-cart-count {
  background: var(--z-olive);
  color: var(--z-white);
  font-size: 9px;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.zb-cart-count:empty { display: none; }

/* Burger (mobile) */
.zb-burger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  width: 28px;
  height: 20px;
  position: relative;
  z-index: 20001;
}
.zb-burger span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--z-text);
  border-radius: 2px;
  transition: all 0.3s var(--z-ease);
  position: absolute;
  left: 0;
}
.zb-burger span:nth-child(1) { top: 0; }
.zb-burger span:nth-child(2) { top: 9px; }
.zb-burger span:nth-child(3) { top: 18px; }

.zb-burger.open span:nth-child(1) { top: 9px; transform: rotate(45deg); }
.zb-burger.open span:nth-child(2) { opacity: 0; }
.zb-burger.open span:nth-child(3) { top: 9px; transform: rotate(-45deg); }

/* ═══════════════════════════════════════
   Mobile Menu Overlay
   ═══════════════════════════════════════ */
.zb-mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 19999;
  background: var(--z-beige);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s var(--z-ease);
}
.zb-mobile-menu.open {
  opacity: 1;
  visibility: visible;
}
.zb-mobile-inner {
  text-align: center;
  transform: translateY(20px);
  transition: transform 0.5s var(--z-ease);
}
.zb-mobile-menu.open .zb-mobile-inner {
  transform: translateY(0);
}
.zb-mobile-logo img {
  height: 60px;
  margin-bottom: 40px;
}
.zb-mobile-links {
  list-style: none;
  padding: 0;
  margin: 0 0 36px;
}
.zb-mobile-links li a {
  font-family: var(--z-font-display);
  font-size: 24px;
  font-weight: 400;
  color: var(--z-text);
  text-decoration: none;
  display: block;
  padding: 12px 0;
  transition: color 0.3s ease;
}
.zb-mobile-links li a:hover {
  color: var(--z-olive);
}
.zb-mobile-wa {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--z-olive);
  color: var(--z-white);
  font-family: var(--z-font-label);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 14px 32px;
  border-radius: var(--z-radius-pill);
  text-decoration: none;
}

/* ═══════════════════════════════════════
   Responsive
   ═══════════════════════════════════════ */
@media (max-width: 960px) {
  .zb-nav-links { display: none; }
  .zb-burger { display: block; }
  .zb-nav { height: 54px; }
  .zb-nav-logo-img { height: 34px; }
}
