/* ============================================================================
   Nordic Luxury — Header CSS (submenu support, luxury icon ratios, scrollable drawer)
   ========================================================================== */

:root {
  --hdr-h-mobile: 64px;
  --hdr-h-desktop: 72px;
  --tap: 44px;
  --radius: 12px;
  --shadow-2: 0 18px 60px rgba(0,0,0,.12);
  --c-bg: #fff;
  --c-ink: #111;
  --c-line: #eee;
  --overlay-bg: rgba(0,0,0,.35);
  --z-header: 50;
  --z-overlay: 60;
  --z-drawer: 65;
}

/* Global lock when drawers/overlays are open */
body.nordic-lock { overflow: hidden; }

/* Header bar */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: var(--c-bg);
  border-bottom: 1px solid var(--c-line);
}
.header-container {
  height: var(--hdr-h-mobile);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
}
@media (min-width: 481px) {
  .header-container { height: var(--hdr-h-desktop); }
}
.header-left, .header-right { display: flex; align-items: center; }
.header-right { gap: 16px; } /* luxurious spacing */

/* Logo */
.site-header .custom-logo-link img { max-height: 36px; }
@media (min-width: 481px) { .site-header .custom-logo-link img { max-height: 40px; } }
.site-title { font-size: 18px; font-weight: 600; color: var(--c-ink); text-decoration: none; }

/* Icon buttons */
.header-icon, .mobile-menu-label {
  width: var(--tap); height: var(--tap);
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--radius);
  background: transparent; border: 0; cursor: pointer;
  color: var(--c-ink);
  line-height: 1;
}
.header-icon:hover, .mobile-menu-label:hover { background: rgba(0,0,0,.05); }

/* Size ratios: primary vs secondary */
.mobile-menu-label svg,
.header-search-toggle svg { width: 34px; height: 34px; }
@media (min-width: 1024px) {
  .mobile-menu-label svg,
  .header-search-toggle svg { width: 36px; height: 36px; }
}
.header-cart svg, .header-account svg { width: 24px; height: 24px; }

/* Cart count badge */
.header-cart { position: relative; }
.header-cart .cart-count {
  position: absolute; top: 6px; right: 6px;
  min-width: 16px; height: 16px; border-radius: 8px;
  background: var(--c-ink); color: #fff;
  font-size: 11px; line-height: 16px; text-align: center;
}

/* Announcement bar */
.site-announcement {
  background: #FAF7F2;
  color: #111;
  text-align: center;
  padding: 8px 16px;
  font-weight: 500;
  border-bottom: 1px solid #EEE;
}
.site-announcement .heart { color: #9B1C31; font-weight: 700; margin-right: 6px; }

/* Mobile Drawer */
.site-nav {
  position: fixed; inset: 0 auto 0 0;
  width: min(88vw, 360px);
  height: 100dvh;
  z-index: var(--z-drawer);
  background: var(--c-bg);
  border-right: 1px solid var(--c-line);
  box-shadow: var(--shadow-2);
  transform: translateX(-101%);
  transition: transform .28s ease;
  will-change: transform;
}
.site-nav[aria-hidden="false"] { transform: translateX(0); }

.site-nav__inner {
  position: relative;
  height: 100%;
  padding: 20px;
  padding-top: 64px;
  display: block;
}
.site-nav__content {
  height: 100%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* Drawer close button */
.mobile-menu-close {
  display: flex; align-items: center; justify-content: center;
  width: var(--tap); height: var(--tap);
  background: #fff; color: var(--c-ink);
  font-size: 28px; border: 0; border-radius: var(--radius);
  position: absolute; top: 10px; right: 10px;
  line-height: 1; cursor: pointer;
}

/* Menu */
.primary-nav .menu { list-style: none; margin: 0; padding: 0; }
.primary-nav .menu > li { margin-top: 12px; }
.primary-nav .menu > li > a {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px; border-radius: var(--radius);
  color: var(--c-ink); text-decoration: none; font-weight: 500;
}
.primary-nav .menu > li > a:hover { background: rgba(0,0,0,.05); }

/* Submenus */
.primary-nav .menu .sub-menu {
  display: none; margin: 6px 0 6px 12px; padding-left: 12px;
  border-left: 1px solid var(--c-line);
}
.primary-nav .menu li.open > .sub-menu { display: block; }
.primary-nav .menu .sub-menu li > a {
  font-weight: 400; font-size: 15px; color: #555; padding: 8px 8px 8px 0; display: block;
}

/* Caret */
.primary-nav .menu-item-has-children > a::after {
  content: "▸";
  margin-left: 10px; font-size: 14px; color: #888;
}
.primary-nav li.open > a::after { content: "▾"; }

/* Search overlay */
.search-overlay {
  position: fixed; inset: 0; z-index: var(--z-overlay);
  display: grid; place-items: center;
  background: var(--overlay-bg);
  opacity: 0; visibility: hidden;
  transition: opacity .2s ease, visibility .2s linear;
}
.search-overlay[aria-hidden="false"] { opacity: 1; visibility: visible; }
.search-overlay__inner {
  width: min(92vw, 720px);
  background: var(--c-bg);
  border: 1px solid var(--c-line);
  border-radius: 16px;
  box-shadow: var(--shadow-2);
  padding: 18px;
  position: relative;
}
.search-overlay .search-form {
  display: grid; grid-template-columns: 1fr auto; gap: 8px;
}
.search-overlay .search-field {
  border: 1px solid var(--c-line); border-radius: var(--radius); padding: 12px 14px;
}
.search-overlay .search-submit {
  background: var(--c-ink); color: #fff; border: 0; border-radius: var(--radius); padding: 12px 16px;
}

/* Screen reader text */
.screen-reader-text {
  position: absolute !important; height: 1px; width: 1px;
  overflow: hidden; clip: rect(1px, 1px, 1px, 1px);
}