/* Site header */

.site-header {
    position: sticky;
    top: 0;
    z-index: var(--z-header);
    background: var(--c-bg);
    border-bottom: 1px solid var(--c-border);
}

.site-header__bar {
    display: flex;
    align-items: center;
    gap: var(--s-4);
    min-height: var(--header-h);
}
@media (min-width: 900px) {
    .site-header__bar { min-height: var(--header-h-lg); }
}

.site-header__brand {
    flex: 0 0 auto;
    display: flex; align-items: center;
}

.site-header__brand .custom-logo {
    max-height: 44px;
    width: auto;
}
.site-header__brand .custom-logo-link { display: inline-flex; }

.site-title {
    font-weight: var(--fw-bold);
    font-size: var(--fs-lg);
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

/* Primary nav */
.nav-primary {
    display: none;
    flex: 1 1 auto;
    justify-content: center;
}
@media (min-width: 1024px) {
    .nav-primary { display: flex; }
}
.nav-primary__list {
    display: flex;
    gap: var(--s-5);
    flex-wrap: wrap;
    align-items: center;
    margin: 0; padding: 0; list-style: none;
}
.nav-primary__item {
    position: static;               /* positioning context for the mega panel */
}
.nav-primary__link {
    display: inline-block;
    padding: var(--s-2) 0;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border-bottom: 2px solid transparent;
    transition: border-color var(--t-fast) var(--ease-out);
}
.nav-primary__item:is(.current-menu-item, :hover, :focus-within) > .nav-primary__link {
    border-bottom-color: var(--c-fg);
    opacity: 1;
}

/* Megamenu hover continuity: nav items fill the header height so the hover
   target reaches the panel (no dead gap), and a transparent bridge strip sits
   just above the panel — moving the cursor into the panel never closes it. */
@media (min-width: 1024px) {
    .nav-primary { align-self: stretch; }
    .nav-primary__list { height: 100%; align-items: stretch; }
    .nav-primary__item { display: flex; align-items: center; }
}

/* Mega dropdown — appears under the header on hover/focus of a parent */
.nav-primary__mega {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    background: var(--c-bg);
    border-bottom: 1px solid var(--c-border);
    box-shadow: 0 10px 24px rgba(0,0,0,.06);
    padding: var(--s-6) 0 var(--s-7);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    pointer-events: none;
    transition:
        opacity 0.22s var(--ease-out),
        transform 0.22s var(--ease-out),
        visibility 0s linear 0.22s;
    z-index: 5;
}
.nav-primary__item:hover .nav-primary__mega,
.nav-primary__item:focus-within .nav-primary__mega {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
    transition-delay: 0s;
}
/* Invisible bridge over any residual gap between the link and the panel. */
.nav-primary__mega::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 100%;
    height: 1.75rem;
}
.nav-primary__mega-inner {
    max-width: var(--container-max);
    margin: 0 auto;
    padding-inline: var(--container-pad);
    display: flex;
    align-items: flex-start;
    gap: var(--s-6);
}

/* Items — flat list flowed into N columns set by --mega-cols inline. */
.nav-primary__mega-items {
    list-style: none;
    margin: 0;
    padding: 0;
    flex: 1 1 auto;
    min-width: 0;
    column-count: var(--mega-cols, 3);
    column-gap: var(--s-6);
}
.nav-primary__mega-item {
    margin: 0 0 8px;
    line-height: 1.5;
    break-inside: avoid-column;
}
.nav-primary__mega-item a {
    font-size: var(--fs-sm);
    letter-spacing: 0.03em;
    color: var(--c-muted);
    text-decoration: none;
}
.nav-primary__mega-item a:hover { color: var(--c-fg); opacity: 1; }

.nav-primary__mega-item--header {
    margin-top: var(--s-4);
    margin-bottom: var(--s-3);
    padding-bottom: var(--s-2);
    border-bottom: 1px solid var(--c-border);
}
.nav-primary__mega-item--header:first-child { margin-top: 0; }
.nav-primary__mega-item--header a {
    display: block;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--c-fg);
}
.nav-primary__mega-item--header a:hover { text-decoration: underline; text-underline-offset: 3px; }

/* Banner tiles — sit to the right of the items area. */
.nav-primary__mega-banners {
    flex: 0 0 auto;
    display: flex;
    gap: var(--s-4);
}
.nav-primary__mega-banner {
    position: relative;
    display: block;
    width: 220px;
    aspect-ratio: 3 / 4;
    background-size: cover;
    background-position: center;
    color: #fff;
    text-decoration: none;
    overflow: hidden;
}
.nav-primary__mega-banner::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.55) 100%);
    transition: background var(--t-fast) var(--ease-out);
    pointer-events: none;
}
.nav-primary__mega-banner:hover::after {
    background: linear-gradient(180deg, rgba(0,0,0,0) 25%, rgba(0,0,0,.7) 100%);
}
.nav-primary__mega-banner-label {
    position: absolute;
    left: 0;
    right: 0;
    bottom: var(--s-3);
    padding-inline: var(--s-4);
    z-index: 1;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #fff;
}

/* Lock body scroll when mobile menu is open */
body.is-mobile-menu-open { overflow: hidden; }

/* Mobile menu — slide-in from right */
.mobile-menu {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    visibility: hidden;
    pointer-events: none;
}
body.is-mobile-menu-open .mobile-menu {
    visibility: visible;
    pointer-events: auto;
}
.mobile-menu__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.55);
    opacity: 0;
    transition: opacity 0.3s var(--ease-out);
}
body.is-mobile-menu-open .mobile-menu__backdrop { opacity: 1; }

.mobile-menu__panel {
    position: absolute;
    top: 0; right: 0;
    width: min(86vw, 420px);
    height: 100vh;
    height: 100dvh;
    background: var(--c-bg);
    color: var(--c-fg);
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform 0.32s var(--ease-out);
    display: flex;
    flex-direction: column;
}
body.is-mobile-menu-open .mobile-menu__panel { transform: translateX(0); }

.mobile-menu__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--s-3) var(--s-4);
    border-bottom: 1px solid var(--c-border);
    flex-shrink: 0;
}
.mobile-menu__brand img.custom-logo { max-height: 34px; width: auto; }
.mobile-menu__close {
    width: 40px; height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--c-fg);
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: 0;
}

.mobile-menu__nav { padding: var(--s-2) 0 var(--s-7); }
.mobile-menu__list { list-style: none; margin: 0; padding: 0; }
.mobile-menu__item {
    border-bottom: 1px solid var(--c-border);
}
.mobile-menu__link,
.mobile-menu__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-3);
    padding: var(--s-4);
    font-size: var(--fs-md);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--c-fg);
    text-decoration: none;
    cursor: pointer;
}
.mobile-menu__summary { list-style: none; }
.mobile-menu__summary::-webkit-details-marker { display: none; }
.mobile-menu__chevron {
    font-size: 22px;
    line-height: 1;
    font-weight: var(--fw-regular);
    transition: transform 0.2s var(--ease-out);
}
.mobile-menu__details[open] .mobile-menu__chevron { transform: rotate(45deg); }

.mobile-menu__sub {
    padding: 0 var(--s-4) var(--s-4);
    background: var(--c-surface);
    display: grid;
    gap: var(--s-4);
}
.mobile-menu__sub-all {
    display: inline-block;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--c-fg);
    border-bottom: 1px solid var(--c-fg);
    padding: var(--s-3) 0 4px;
    margin-bottom: var(--s-2);
    align-self: flex-start;
    text-decoration: none;
}
/* Flat submenu list rendered inside <details> for each parent. */
.mobile-menu__sub-items {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}
.mobile-menu__sub-item a {
    font-size: var(--fs-sm);
    color: var(--c-muted);
    text-decoration: none;
}
.mobile-menu__sub-item a:hover { color: var(--c-fg); }
.mobile-menu__sub-item--header {
    margin-top: var(--s-3);
    padding-bottom: var(--s-2);
    border-bottom: 1px solid var(--c-border);
}
.mobile-menu__sub-item--header:first-child { margin-top: 0; }
.mobile-menu__sub-item--header a {
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--c-fg);
}

/* Mobile banner tiles — stacked under the submenu list. */
.mobile-menu__banners {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-3);
    margin-top: var(--s-3);
}
.mobile-menu__banner {
    position: relative;
    display: block;
    aspect-ratio: 3 / 4;
    background-size: cover;
    background-position: center;
    color: #fff;
    text-decoration: none;
    overflow: hidden;
}
.mobile-menu__banner::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.55) 100%);
    pointer-events: none;
}
.mobile-menu__banner-label {
    position: absolute;
    left: 0;
    right: 0;
    bottom: var(--s-2);
    padding-inline: var(--s-3);
    z-index: 1;
    font-size: var(--fs-xs, 12px);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #fff;
}

/* Header action icons */
.site-header__actions {
    display: flex;
    align-items: center;
    gap: var(--s-3);
    margin-left: auto;
}
.header__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px; height: 40px;
    color: var(--c-fg);
    position: relative;
}
.header__icon:hover .icon { transform: translateY(-1px); opacity: 1; }
.header__icon .icon { transition: transform var(--t-fast) var(--ease-out); }

.header__icon-count {
    position: absolute;
    top: 4px; right: 4px;
    min-width: 16px; height: 16px;
    padding: 0 4px;
    font-size: 10px; font-weight: var(--fw-bold);
    line-height: 16px;
    background: var(--c-fg); color: var(--c-bg);
    text-align: center;
}
.header__icon-count[data-count="0"] { display: none; }

.header__icon--mobile { display: inline-flex; }
@media (min-width: 1024px) {
    .header__icon--mobile { display: none; }
}

/* MOBILE ONLY (<1024px): header keeps just logo + cart + hamburger.
   Search / account / language / brand-switch are hidden here and live in the
   slide-in menu instead. Desktop (>=1024px) is intentionally untouched. */
@media (max-width: 1023.98px) {
    .site-header__actions { margin-left: auto; }
    /* Search stays visible on mobile (left of the cart); only lang/brand/account hide. */
    .site-header__actions .header__lang,
    .site-header__actions .brand-trigger,
    .site-header__actions > a.header__icon:not(.js-mini-cart) { display: none; }
}

/* Utilities inside the slide-in menu (only reachable on mobile). */
.mobile-menu__utils { padding: var(--s-4); border-top: 1px solid var(--c-border); display: flex; flex-direction: column; gap: var(--s-3); }
.mobile-menu__utils form,
.mobile-menu__utils .search-field,
.mobile-menu__utils input[type="search"] { width: 100%; }
.mobile-menu__util-link { display: inline-flex; align-items: center; gap: 10px; background: none; border: 0; padding: 6px 0; font: inherit; color: inherit; text-align: left; cursor: pointer; }
.mobile-menu__brandbtn .brand-trigger__grid { flex: 0 0 auto; }

/* Language switcher (GTranslate flags) — sits left of the search icon.
   The shortcode emits <div class="gtranslate_wrapper" id="gt-wrapper-*">
   and base.js injects two <a class="glink" data-gt-lang="*"><img></a>
   anchors inside it on page load. */
.header__lang {
    display: inline-flex;
    align-items: center;
    margin-right: var(--s-2);
    line-height: 0;
}
.header__lang .gtranslate_wrapper {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.header__lang a.glink {
    display: inline-flex;
    align-items: center;
    width: 22px;
    height: 22px;
    opacity: 0.65;
    transition: opacity var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
    border-radius: 2px;
    overflow: hidden;
}
.header__lang a.glink:hover,
.header__lang a.glink:focus-visible,
.header__lang a.glink.gt-current-lang {
    opacity: 1;
    transform: translateY(-1px);
}
.header__lang a.glink img {
    width: 22px;
    height: 22px;
    margin: 0;          /* override the plugin's inline margin-right:2px */
    display: block;
}
/* Google's own translate banner — kill it everywhere so the layout
   doesn't jump when a language is picked. */
.goog-te-banner-frame.skiptranslate { display: none !important; }
body { top: 0 !important; }

/* Logo menu item (e.g. Perfect Moment) — renders an image instead of text. */
.nav-primary__item--logo .nav-primary__link { display: inline-flex; align-items: center; }
.nav-primary__logo { display: block; height: 16px; width: auto; }
@media (min-width: 1000px) { .nav-primary__logo { height: 18px; } }

/* Announcement topbar (Icelandro → Topbar). Colors come inline from options. */
.site-topbar { width: 100%; font-size: var(--fs-sm); line-height: 1.3; }
.site-topbar__inner {
	display: flex; align-items: center; justify-content: center;
	gap: 8px; min-height: 38px; padding: 7px var(--s-4); text-align: center;
}
.site-topbar__text { color: inherit; text-decoration: none; letter-spacing: .02em; }
a.site-topbar__text:hover,
a.site-topbar__text:focus-visible { text-decoration: underline; }
