/* =========================================================
   HEADER & NAVIGATION
   ========================================================= */

/* ── Top bar (phone + hours) ──────────────────────────── */
.topbar {
  background: var(--teal-deep);
  color: rgba(255,255,255,.85);
  font-size: var(--fs-tiny);
}
.topbar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-sm);
  padding-top: 8px;
  padding-bottom: 8px;
}
.topbar a { color: var(--gold); font-weight: 700; }
.topbar a:hover { color: #fff; }
.topbar__item { display: flex; align-items: center; gap: 6px; }
.topbar__hours { display: none; }
@media (min-width: 640px) { .topbar__hours { display: flex; } }

/* ── Main header ──────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(251,250,247,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-sm);
  height: 76px;
}

/* ── Logo ─────────────────────────────────────────────── */
.site-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.3rem;
  color: var(--teal-deep);
  flex-shrink: 0;
}
.site-logo:hover { color: var(--teal-deep); }
.site-logo img { height: 44px; width: auto; }
.site-logo .logo-mark {
  width: 44px; height: 44px; border-radius: var(--radius-sm);
  background: var(--teal); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; flex-shrink: 0;
}
.site-logo .logo-text small {
  display: block; font-family: var(--font-body);
  font-weight: 600; font-size: .68rem; color: var(--ink-soft); letter-spacing: .04em;
}

/* ── Desktop nav ──────────────────────────────────────── */
.main-nav { display: none; }
@media (min-width: 1024px) {
  .main-nav {
    display: flex;
    align-items: center;
    gap: var(--sp-md);
    list-style: none;
    margin: 0; padding: 0;
  }
  .main-nav > li { position: relative; }
  .main-nav > li > a {
    display: flex; align-items: center; gap: 4px;
    font-family: var(--font-display); font-weight: 700; font-size: .95rem;
    color: var(--ink); padding: 10px 4px;
  }
  .main-nav > li > a:hover, .main-nav > li.current-menu-item > a { color: var(--teal); }

  .main-nav .sub-menu {
    position: absolute; top: 100%; right: 0;
    background: #fff; border: 1px solid var(--line);
    border-radius: var(--radius-md); box-shadow: var(--shadow-md);
    list-style: none; margin: 8px 0 0; padding: 10px;
    min-width: 240px;
    opacity: 0; visibility: hidden; transform: translateY(8px);
    transition: all var(--t-fast) var(--ease);
  }
  .main-nav li:hover > .sub-menu,
  .main-nav li:focus-within > .sub-menu {
    opacity: 1; visibility: visible; transform: translateY(0);
  }
  .main-nav .sub-menu a {
    display: block; padding: 9px 14px; border-radius: var(--radius-sm);
    font-family: var(--font-body); font-weight: 600; font-size: .9rem; color: var(--ink);
  }
  .main-nav .sub-menu a:hover { background: var(--teal-pale); color: var(--teal-deep); }
  .main-nav .menu-item-has-children > a::after {
    content: '▾'; font-size: .7em; margin-right: 4px; color: var(--ink-soft);
  }
}

/* ── Header CTAs ──────────────────────────────────────── */
.header-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.header-actions .btn--primary { display: none; }
@media (min-width: 640px) { .header-actions .btn--primary { display: inline-flex; } }
.header-actions .btn--sm { padding: 11px 18px; font-size: .9rem; }

.header-call {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--teal-pale); color: var(--teal-deep);
  font-size: 1.2rem; flex-shrink: 0;
}
.header-call:hover { background: var(--teal); color: #fff; }
@media (min-width: 640px) { .header-call { display: none; } }

/* ── Mobile menu toggle ───────────────────────────────── */
.menu-toggle {
  display: flex; flex-direction: column; justify-content: center; gap: 5px;
  width: 44px; height: 44px; background: transparent; border: none; cursor: pointer;
  flex-shrink: 0;
}
.menu-toggle span {
  display: block; width: 24px; height: 2.5px; background: var(--teal-deep);
  border-radius: 2px; transition: all var(--t-fast) var(--ease); margin: 0 auto;
}
.menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }
@media (min-width: 1024px) { .menu-toggle { display: none; } }

/* ── Mobile nav drawer ────────────────────────────────── */
.mobile-nav {
  position: fixed; inset: 76px 0 0 0;
  background: var(--cream);
  z-index: 999;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform var(--t-med) var(--ease);
  padding: var(--sp-md) var(--sp-sm) var(--sp-xl);
}
.mobile-nav.is-open { transform: translateX(0); }
@media (min-width: 1024px) { .mobile-nav { display: none; } }

.mobile-nav ul { list-style: none; margin: 0; padding: 0; }
.mobile-nav > ul > li { border-bottom: 1px solid var(--line); }
.mobile-nav > ul > li > a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 4px; font-family: var(--font-display); font-weight: 700; font-size: 1.1rem;
  color: var(--teal-deep);
}
.mobile-nav .sub-menu { display: none; padding-bottom: 10px; }
.mobile-nav .sub-menu a { display: block; padding: 10px 16px; font-size: .95rem; color: var(--ink-soft); font-weight: 600; }
.mobile-nav li.is-expanded > .sub-menu { display: block; }
.mobile-nav .submenu-toggle { background: none; border: none; font-size: 1.2rem; color: var(--teal); cursor: pointer; padding: 8px; }

.mobile-nav__cta { margin-top: var(--sp-md); display: flex; flex-direction: column; gap: 10px; }
.mobile-nav__contact {
  margin-top: var(--sp-md); padding-top: var(--sp-md); border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 10px; font-size: .95rem; color: var(--ink-soft);
}
.mobile-nav__contact a { color: var(--teal-deep); font-weight: 700; }

body.menu-open { overflow: hidden; }
