﻿/**
 * Hatoum header — Osmo-style DOM (nav / nav-bar__*).
 * Open: pill width expands first; sheet follows (--mega-nav-sheet-open-delay).
 * Close (inverse): sheet collapses first; pill width shrinks after (--mega-nav-sheet-dur).
 */
[data-menu-wrap] {
	--mega-pill-top: 0.625rem;
	--mega-pill-gap: 1rem;
	/* Nav shell width animates first; sheet opens after (Osmo-style). */
	--mega-nav-width-dur: 0.38s;
	--mega-nav-width-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--mega-nav-sheet-open-delay: 0.24s;
	/* Sheet max-height duration — JS delays pill collapse on close by this amount */
	--mega-nav-sheet-dur: 0.36s;
	/* Closed pill spans this fraction of the viewport (fixed nav) */
	--mega-nav-closed-width: 40vw;
	/* Open panel width — 90% of the viewport */
	--mega-nav-open-width: 90vw;
	/* Open sheet: ~90% viewport height minus closed pill rail (max-height animates open/close). */
	--mega-nav-sheet-max-h: calc(92vh - var(--nav-bar-top-height) - 1.25rem);
	--mega-nav-sheet-link-pad-y: 0.5rem;
	--mega-nav-sheet-item-fs: 1.5em;
	--mega-machine-card-radius: 0.65rem;
	--mega-primary: var(--wp--preset--color--primary, #0066df);
	--mega-ink: #0a0a0a;
	--mega-sheet-bg: #ffffff;
	--mega-sheet-surface: #f0f3f8;
	--mega-sheet-muted: #5c6678;
	/* Pill row: fixed height (px) + padding. Logo is 2× inner band (may extend past row; JS measures extent). */
	--nav-bar-top-height: 80px;
	--nav-bar-top-padding: 10px;
	--mega-pill-logo-inner: calc(var(--nav-bar-top-height) - 2 * var(--nav-bar-top-padding));
	--mega-pill-logo-closed: calc(2 * var(--mega-pill-logo-inner));
	--mega-pill-logo-open: var(--mega-pill-logo-closed);
	/* Fallback stack ≈ logo span + divider (see JS for precise union of rail + logo). */
	--mega-pill-rail-height: calc(var(--mega-pill-logo-closed) + 2px);
	/* Fallback before JS measures the pill */
	--mega-pill-stack: var(--mega-pill-rail-height);
}

/*
 * Nav is fixed — do NOT pad body (that shows page background above the hero).
 * Reserve space on `main` instead; drop it when the first post block is the full-bleed hero.
 * `--mega-pill-stack-dynamic` is set on :root by mega-nav.js.
 */
:root {
	--mega-pill-top: 0.625rem;
	--mega-pill-gap: 1rem;
}

body.hatoum-mega-nav-pad {
	padding-top: 0;
}

html:has(body.hatoum-mega-nav-pad:not(.admin-bar)) {
	scroll-padding-top: calc(var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap));
}

html:has(body.admin-bar.hatoum-mega-nav-pad) {
	scroll-padding-top: calc(0px + var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap));
}

@media screen and (max-width: 782px) {
	html:has(body.admin-bar.hatoum-mega-nav-pad) {
		scroll-padding-top: calc(0px + var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap));
	}
}

/*
 * Reserve top space under the fixed pill on every page.
 * When the hero cover is the first block in `main`, pull it up by the same amount so the
 * image (not `body` background) fills that band — works even when :has() cannot zero padding.
 */
body.hatoum-mega-nav-pad:not(.admin-bar) main {
	padding-top: calc(var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap));
}

body.admin-bar.hatoum-mega-nav-pad main {
	padding-top: calc(0px + var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap));
}

@media screen and (max-width: 782px) {
	body.admin-bar.hatoum-mega-nav-pad main {
		padding-top: calc(46px + var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap));
	}
}

/* Pull hero under `main` padding — JS sets `.hatoum-hero-pull-under-nav` when markup does not match :first-child fallbacks. */
body.hatoum-mega-nav-pad:not(.admin-bar) .hatoum-hero-pull-under-nav,
body.hatoum-mega-nav-pad:not(.admin-bar) main .wp-block-post-content > .wp-block-cover.hatoum-hero-cover--full:first-child,
body.hatoum-mega-nav-pad:not(.admin-bar) main > .wp-block-cover.hatoum-hero-cover--full:first-child {
	margin-top: calc(-1 * (var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap))) !important;
}

body.admin-bar.hatoum-mega-nav-pad .hatoum-hero-pull-under-nav,
body.admin-bar.hatoum-mega-nav-pad main .wp-block-post-content > .wp-block-cover.hatoum-hero-cover--full:first-child,
body.admin-bar.hatoum-mega-nav-pad main > .wp-block-cover.hatoum-hero-cover--full:first-child {
	margin-top: calc(-1 * (32px + var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap))) !important;
}

@media screen and (max-width: 782px) {
	body.admin-bar.hatoum-mega-nav-pad .hatoum-hero-pull-under-nav,
	body.admin-bar.hatoum-mega-nav-pad main .wp-block-post-content > .wp-block-cover.hatoum-hero-cover--full:first-child,
	body.admin-bar.hatoum-mega-nav-pad main > .wp-block-cover.hatoum-hero-cover--full:first-child {
		margin-top: calc(-1 * (46px + var(--mega-pill-top) + var(--mega-pill-stack-dynamic, 5.5rem) + var(--mega-pill-gap))) !important;
	}
}

/* --- Osmo-style shell (.nav) -------------------------------------------- */

.w-inline-block {
	max-width: 100%;
	display: inline-block;
}

.nav.hatoum-mega-nav {
	position: fixed;
	z-index: 100000;
	top: var(--mega-pill-top);
	left: 50%;
	transform: translateX(-50%);
	width: fit-content;
	max-width: min(90vw, 64rem);
	display: flex;
	flex-direction: column;
	align-items: stretch;
	transition:
		width var(--mega-nav-width-dur) var(--mega-nav-width-ease),
		max-width var(--mega-nav-width-dur) var(--mega-nav-width-ease);
}

/* Closed pill width — `data-nav-expanded` only (sheet uses `data-nav-open`). */
.nav:not([data-nav-expanded="true"]).hatoum-mega-nav {
	align-items: stretch;
	width: var(--mega-nav-closed-width);
	max-width: var(--mega-nav-closed-width);
	min-width: 0;
}

.nav[data-nav-expanded="true"].hatoum-mega-nav {
	width: var(--mega-nav-open-width);
	max-width: var(--mega-nav-open-width);
	min-width: 0;
	align-items: stretch;
}

body.admin-bar .nav.hatoum-mega-nav {
	top: calc(0px + var(--mega-pill-top));
}

@media screen and (max-width: 782px) {
	body.admin-bar .nav.hatoum-mega-nav {
		top: calc(46px + var(--mega-pill-top));
	}
}

/* --- Bar card ----------------------------------------------------------- */
.nav-bar__wrap {
	position: relative;
	z-index: 3;
	width: 100%;
	min-width: 0;
}

.nav-bar__width {
	width: 100%;
	max-width: 100%;
	margin: 0 auto;
}

.nav-bar {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	min-width: 0;
	min-height: 0;
	max-width: 100%;
	width: 100%;
	color: var(--mega-ink);
	border-radius: 5px;
	overflow-x: clip;
	overflow-y: visible;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	box-shadow:
		0 0 0 1px rgba(0, 0, 0, 0.08),
		0 8px 32px rgba(0, 11, 29, 0.12);
	transition: box-shadow 0.28s ease;
}

.nav[data-nav-expanded="true"] .nav-bar {
	box-shadow:
		0 0 0 1px rgba(0, 0, 0, 0.08),
		0 16px 48px rgba(0, 11, 29, 0.16);
}

/* Round the dropdown foot; clip so the sheet matches the pill radius */
.nav[data-nav-open="true"] .nav-bar {
	overflow: hidden;
}

.nav[data-nav-open="true"] .nav-bar__bottom {
	border-bottom-left-radius: inherit;
	border-bottom-right-radius: inherit;
}

.nav-bar__back {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	border-radius: inherit;
}

.nav-bar__outline {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
}

.nav-bar__bg {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background-color: #ffffff;
}

/* Top rail + divider — height from content + equal vertical padding (no empty band under logo). */
.nav-bar__rail {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	flex: 0 0 auto;
	min-height: 0;
	min-width: 0;
	overflow: visible;
}

/* Stray empty <p> from wpautop — only :empty (do not hide all <p>, breaks repaired DOM). */
.nav-bar__rail > p:empty,
.nav-bar > p:empty {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	height: 0 !important;
	overflow: hidden !important;
}

.nav-bar__top {
	position: relative;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	height: 80px;
	min-height: var(--nav-bar-top-height, 80px);
	max-height: var(--nav-bar-top-height, 80px);
	box-sizing: border-box;
	padding: var(--nav-bar-top-padding, 12px);
	gap: 0.35rem;
	flex: 0 0 auto;
	min-width: 0;
	overflow-x: clip;
	overflow-y: visible;
}

.nav-bar__menu {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	align-self: stretch;
	/* Do not shrink below hamburger + label — flex-shrink + min-width:0 was clipping the icon. */
	flex: 0 0 auto;
	min-width: min-content;
	min-height: 0;
}

.nav-bar__logo {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	max-width: min(46vw, 14rem);
	width: max-content;
	pointer-events: none;
}

.nav[data-nav-expanded="true"] .nav-bar__logo {
	max-width: min(58vw, 18rem);
}

.nav-bar__logo .nav-logo {
	display: inline-flex;
	align-items: center;
	line-height: 0;
	pointer-events: auto;
}

.nav-bar__buttons {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	align-self: stretch;
	flex: 0 1 auto;
	min-width: 0;
	min-height: 0;
	margin-left: auto;
}

.nav-bar__button-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.35rem;
}

/* --- Menu trigger — block flex on <button> so height + cross-axis center work. */
.nav.hatoum-mega-nav .nav-menu {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	white-space: nowrap;
	align-items: center;
	justify-content: flex-start;
	gap: 0.5rem;
	-webkit-appearance: none;
	appearance: none;
	background: transparent;
	border: 0;
	color: inherit;
	cursor: pointer;
	padding: 0 0.2rem;
	border-radius: 0.35rem;
	font-family: inherit;
	font-size: clamp(0.8125rem, 1.9vw, 0.9375rem);
	font-weight: 500;
	line-height: 1.2;
	flex: 0 0 auto;
	flex-shrink: 0;
	width: max-content;
	max-width: none;
	height: 100%;
	min-height: 0;
	overflow: visible;
	text-align: left;
	margin: 0;
	box-sizing: border-box;
}

.nav.hatoum-mega-nav .nav-menu:hover,
.nav.hatoum-mega-nav .nav-menu:focus-visible {
	background: rgba(0, 0, 0, 0.05);
	outline: none;
}


.nav-menu__icon {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: stretch;
	align-self: center;
	flex-shrink: 0;
	gap: 4px;
	width: 1.125rem;
	min-width: 1.125rem;
	min-height: 8px;
	box-sizing: border-box;
	line-height: 0;
	overflow: visible;
	margin: 0;
	transform: none;
}

.nav-menu__bar {
	display: block;
	flex-shrink: 0;
	height: 2px;
	min-height: 2px;
	width: 100%;
	background: currentColor;
	border-radius: 1px;
	transform-origin: center;
	transition: transform 0.2s ease;
}

.nav[data-nav-open="true"] .nav-menu__bar--top,
.nav-menu[aria-expanded="true"] .nav-menu__bar--top {
	transform: translateY(3px) rotate(45deg);
}

.nav[data-nav-open="true"] .nav-menu__bar--bottom,
.nav-menu[aria-expanded="true"] .nav-menu__bar--bottom {
	transform: translateY(-3px) rotate(-45deg);
}

.nav-menu__label {
	display: inline-block;
	flex: 0 0 auto;
	align-self: center;
	margin: 0;
	padding: 0;
	white-space: nowrap;
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
	letter-spacing: 0.02em;
	line-height: 1.2;
}

/* --- Logo image --------------------------------------------------------- */
.nav-bar__logo .nav-logo__img {
	width: auto;
	height: auto;
	max-width: 80%;
	display: block;
	object-fit: contain;
	max-height: var(--mega-pill-logo-closed);
	transition: max-height 0.32s ease, max-width 0.32s ease;
}

.nav[data-nav-expanded="true"] .nav-bar__logo .nav-logo__img {
	max-height: var(--mega-pill-logo-open);
}

/* SVG / vector logos: full asset scales inside pill (raster uses rules above). */
.nav-bar__logo .nav-logo__img.nav-logo__img--vector {
	width: auto;
	max-width: min(52vw, 15rem);
	height: auto;
	max-height: var(--mega-pill-logo-closed);
	object-fit: contain;
	object-position: center;
}

.nav[data-nav-expanded="true"] .nav-bar__logo .nav-logo__img.nav-logo__img--vector {
	max-height: var(--mega-pill-logo-open);
}

.nav .mega-nav__logo-fallback span {
	font-size: 0.95rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: var(--mega-ink);
}

.nav:not([data-nav-expanded="true"]) .mega-nav__logo-fallback span {
	font-size: clamp(0.85rem, 3vw, min(1.6rem, var(--mega-pill-logo-inner)));
	line-height: 1.05;
}

.nav[data-nav-expanded="true"] .mega-nav__logo-fallback span {
	font-size: clamp(0.9rem, 3vw, min(1.65rem, var(--mega-pill-logo-inner)));
	line-height: 1.05;
}

/* --- CTA — header context just tightens sizing; visuals come from components.css */
.nav .nav-bar__signup-button.hatoum-btn-primary {
	z-index: 2;
	font-size: 16px;
	padding: 12px 25px 12px 25px;
	border-radius: 5px;
}

.nav[data-nav-expanded="true"] .nav-bar__line {
	margin-left: clamp(0.75rem, 2vw, 1.25rem);
	margin-right: clamp(0.75rem, 2vw, 1.25rem);
}

/* --- Bottom sheet — closed: zero box; open: after width (staggered). ---- */
.nav-bar__bottom {
	position: relative;
	z-index: 2;
	flex: 0 0 auto;
	min-width: 0;
	min-height: 0;
	width: 100%;
	max-height: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	background: transparent;
	color: var(--mega-ink);
	border-top: 0 solid transparent;
	transition:
		max-height var(--mega-nav-sheet-dur) cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.14s ease,
		visibility 0.14s ease,
		border-color 0.22s ease;
	transition-delay: 0s, 0s, 0s, 0s;
}

.nav:not([data-nav-open="true"]) .nav-bar__bottom {
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	margin: 0;
	padding: 0;
	flex: none;
	max-height: 0;
	min-height: 0;
	border-top-width: 0;
}

.nav[data-nav-open="true"] .nav-bar__bottom {
	position: relative;
	left: auto;
	right: auto;
	top: auto;
	flex: 0 0 auto;
	max-height: var(--mega-nav-sheet-max-h);
	overflow: hidden;
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
	background-color: #ffffff;
	transition-delay:
		var(--mega-nav-sheet-open-delay),
		var(--mega-nav-sheet-open-delay),
		var(--mega-nav-sheet-open-delay),
		var(--mega-nav-sheet-open-delay);
}

.nav-bar__bottom-overflow {
	flex: 1 1 auto;
	min-height: 0;
	max-height: inherit;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.nav[data-nav-open="true"] .nav-bar__bottom-overflow {
	max-height: var(--mega-nav-sheet-max-h);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.nav-bar__bottom-inner {
	flex: 1 1 auto;
	min-height: 0;
	overflow: hidden;
	overscroll-behavior: none;
	font-size: 1rem;
}

.nav[data-nav-open="true"] .nav-bar__bottom-inner {
	overflow-y: auto;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
}

/* wpautop can inject empty <p> after the sheet row — kill layout gap */
.nav-bar__bottom-overflow > p:empty,
.nav-bar__bottom-inner > p:empty {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	height: 0 !important;
	overflow: hidden !important;
	border: 0 !important;
}

.nav-bar__bottom-row {
	display: grid;
	grid-template-columns: minmax(0, 3fr) minmax(0, 3fr) minmax(0, 4fr);
	gap: 0 2.5rem;
	align-content: stretch;
	align-items: stretch;
	padding: 1.35rem 1.85rem 1.2rem;
	min-width: 0;
}

.nav-bar__bottom-row--triple {
	grid-template-columns: minmax(0, 3fr) minmax(0, 3fr) minmax(0, 4fr);
}

.nav-bar__bottom-col {
	display: flex;
	flex-direction: column;
	min-width: 0;
	min-height: 0;
	padding: 0.15rem 0 0;
	background: transparent;
	border: 0;
	box-shadow: none;
}

.nav-bar__bottom-col--explore {
	align-self: stretch;
}

.nav-bar__bottom-col--preview {
	flex: 1;
	min-height: 0;
	align-self: stretch;
	display: flex;
	flex-direction: column;
	padding: 0.25rem 2rem;
	border-left: 1px solid rgba(0, 0, 0, 0.1);
	border-right: 1px solid rgba(0, 0, 0, 0.1);
}

.nav-bar__bottom-col--machines {
	flex: 1;
	min-height: 0;
	padding-left: 0.35rem;
	align-self: stretch;
}

.mega-nav__preview {
	flex: 1 1 auto;
	display: block;
	align-self: stretch;
	width: 100%;
	min-height: 14rem;
	height: 100%;
	max-height: none;
	margin: 0;
	background: #1a1d22;
	border-radius: 0.5rem;
	overflow: hidden;
	position: relative;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.05s ease 0s, visibility 0s linear 0.05s;
}

.nav[data-nav-open="true"] .mega-nav__preview {
	opacity: 1;
	visibility: visible;
	transition: opacity 0.22s ease var(--mega-nav-sheet-open-delay), visibility 0s linear 0s;
}

.nav:not([data-nav-open="true"]) .mega-nav__preview {
	transition: opacity 0.04s ease 0s, visibility 0s linear 0.04s;
}

.mega-nav__preview-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	max-width: none;
	max-height: none;
	margin: 0;
	object-fit: cover;
	object-position: center;
	display: block;
	background: transparent;
}

.mega-nav__preview-img[hidden] {
	display: none !important;
}

.eyebrow {
	margin: 0 0 0.35rem;
	padding: 0 0.1rem;
	font-size: 0.625rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--mega-sheet-muted);
}

.nav-bar__ul-explore,
.nav-bar__ul-machines {
	list-style: none;
	margin: 0;
	padding: 0;
	width: 100%;
}

/* Explore: single column + horizontal dividers between items */
.nav-bar__ul-explore {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0;
}

.nav-bar__explore-divider-li {
	display: block;
	margin: 0;
	padding: 0.2rem 0 0.35rem;
	list-style: none;
	pointer-events: none;
}

.nav-bar__explore-divider {
	display: block;
	height: 1px;
	margin: 0 0.1rem;
	background: rgba(0, 0, 0, 0.1);
	border-radius: 1px;
}

/* Machines: compact multi-column list (not cards) */
.nav-bar__ul-machines {
	flex: 1 1 auto;
	min-height: 0;
	align-self: stretch;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	column-gap: 1rem;
	row-gap: 0;
	align-content: start;
}

.nav-bar__ul-machines .nav-bar__sheet-li {
	display: block;
	min-height: 0;
}

/* Full-width row divider between machine grid rows (same bar as Explore). */
.nav-bar__machine-divider-li {
	grid-column: 1 / -1;
	display: block;
	margin: 0;
	padding: 0.2rem 0 0.3rem;
	list-style: none;
	pointer-events: none;
}

.nav-bar__sheet-li {
	margin: 0;
	min-width: 0;
}

.nav-bar__sheet-a {
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: var(--mega-nav-sheet-link-pad-y) 0.2rem;
	color: var(--mega-ink);
	text-decoration: none;
	border-radius: 0;
	font-weight: 300;
}

.nav-bar__ul-explore .nav-bar__sheet-a {
	padding-left: 0.1rem;
	padding-right: 0.1rem;
}

.nav-bar__sheet-a:hover {
	color: inherit;
}

.nav-bar__sheet-label {
	font-size: var(--mega-nav-sheet-item-fs);
	font-weight: 300;
	line-height: 1.25;
	text-align: left;
	position: relative;
	display: inline-block;
	max-width: 100%;
	text-decoration: none;
}

.nav-bar__ul-explore .nav-bar__sheet-label {
	font-size: 16px;
}

/* Explore only: thin animated underline (machines use card shadow instead) */
.nav-bar__ul-explore .nav-bar__sheet-a .nav-bar__sheet-label::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 1px;
	background-color: var(--mega-ink);
	opacity: 0.55;
	transition: width 0.2s cubic-bezier(0.22, 1, 0.36, 1);
	pointer-events: none;
}

.nav-bar__ul-explore .nav-bar__sheet-a:hover .nav-bar__sheet-label::after,
.nav-bar__ul-explore .nav-bar__sheet-a:focus-visible .nav-bar__sheet-label::after {
	width: 100%;
	opacity: 0.9;
}

/* Machine rows — list look; preview image replaces hover styling */
.nav-bar__ul-machines .nav-bar__machine-a.nav-bar__sheet-a {
	display: block;
	width: 100%;
	min-height: 0;
	padding: 0.5rem 0.45rem;
	text-align: left;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
}

.nav-bar__ul-machines--list .nav-bar__machine-a .nav-bar__sheet-label {
	opacity: 1;
	transition: opacity 0.2s ease;
}

.nav-bar__ul-machines--list .nav-bar__machine-a:hover .nav-bar__sheet-label,
.nav-bar__ul-machines--list .nav-bar__machine-a:focus-visible .nav-bar__sheet-label {
	opacity: 0.55;
}

.nav-bar__ul-machines--list .nav-bar__machine-a:hover,
.nav-bar__ul-machines--list .nav-bar__machine-a:focus-visible {
	background: transparent;
	border-color: transparent;
	box-shadow: none;
}

.nav-bar__ul-machines--list .nav-bar__sheet-label {
	font-size: 16px;
	text-align: left;
}

/* No underline pseudo on machine labels */
.nav-bar__ul-machines .nav-bar__sheet-a .nav-bar__sheet-label::after {
	display: none;
}

.nav-bar__sheet-a:focus-visible {
	outline: 2px solid var(--mega-primary);
	outline-offset: 3px;
}

.nav-bar__sheet-empty {
	margin: 0;
	padding: 0.35rem 0.1rem 0.5rem;
	font-size: 1rem;
	line-height: 1.35;
	color: var(--mega-sheet-muted);
}

@media screen and (max-width: 1200px) {
	.nav-bar__ul-machines {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 900px) {
	/* Tablet: 50vw pill is too narrow once content stacks; widen the rail. */
	[data-menu-wrap] {
		--mega-nav-closed-width: 88vw;
	}

	.nav.hatoum-mega-nav .nav-bar__logo {
		max-width: min(48vw, 12rem);
	}

	.nav[data-nav-expanded="true"] .nav-bar__logo {
		max-width: min(54vw, 14rem);
	}

	.nav-bar__bottom-row,
	.nav-bar__bottom-row--triple {
		grid-template-columns: minmax(0, 1fr);
		gap: 0.65rem 0;
		padding: 0.75rem 1rem 0.95rem;
	}

	.nav-bar__bottom-col--preview {
		padding: 0.85rem 0.75rem 0;
		border-left: 0;
		border-right: 0;
		border-top: 1px solid rgba(0, 0, 0, 0.1);
		order: 2;
	}

	.nav-bar__bottom-col--explore {
		order: 1;
	}

	.nav-bar__bottom-col--machines {
		order: 3;
		padding-left: 0;
		padding-top: 0.35rem;
		border-top: 1px solid rgba(0, 0, 0, 0.1);
	}

	.mega-nav__preview {
		min-height: min(48vh, 22rem);
		height: min(48vh, 22rem);
		max-height: min(48vh, 22rem);
	}

	.nav-bar__ul-machines {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 520px) {
	/* Phone: pill is essentially full width so logo + menu + CTA can coexist. */
	[data-menu-wrap] {
		--mega-nav-closed-width: 94vw;
		--mega-nav-open-width: 96vw;
		--nav-bar-top-height: 64px;
		--nav-bar-top-padding: 8px;
		/* Logo fits inside the rail — 2× inner band overflows and misaligns the menu icon. */
		--mega-pill-logo-closed: var(--mega-pill-logo-inner);
		--mega-pill-logo-open: var(--mega-pill-logo-inner);
	}

	.nav-bar__top {
		height: var(--nav-bar-top-height);
		min-height: var(--nav-bar-top-height);
		max-height: var(--nav-bar-top-height);
		padding-left: max(0.5rem, env(safe-area-inset-left, 0px));
		padding-right: max(0.5rem, env(safe-area-inset-right, 0px));
		gap: 0.35rem;
		align-items: center;
	}

	/* Logo: cap by available pill space minus menu + CTA so it can't overlap. */
	.nav.hatoum-mega-nav .nav-bar__logo {
		max-width: min(38vw, 9rem);
	}

	.nav[data-nav-expanded="true"] .nav-bar__logo {
		max-width: min(42vw, 10rem);
	}

	.nav-menu__label {
		display: none;
	}

	/* Square touch target; icon centered (not stretched with the 80px desktop row). */
	.nav-bar__menu {
		display: flex;
		align-items: center;
		align-self: center;
		flex: 0 0 auto;
		min-width: 0;
		height: var(--nav-bar-top-height);
	}

	.nav.hatoum-mega-nav .nav-menu {
		display: inline-flex;
		justify-content: center;
		align-items: center;
		align-self: center;
		padding: 0;
		width: 2.75rem;
		height: 2.75rem;
		min-height: 0;
		max-height: none;
	}

	.nav.hatoum-mega-nav .nav-menu__icon {
		margin: 0 !important;
		transform: none !important;
		align-self: center;
		justify-content: center;
	}

	/* CTA: trim padding + size so it fits beside the logo. */
	.nav .nav-bar__signup-button.hatoum-btn-primary {
		font-size: 0.72rem;
		padding: 0.6rem 0.9rem;
		letter-spacing: 0.05em;
		gap: 0.4em;
	}

	.nav-bar__ul-machines {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (prefers-reduced-motion: reduce) {
	.nav.hatoum-mega-nav {
		transition: none;
	}

	.nav-bar__bottom {
		transition: none !important;
		transition-delay: 0s !important;
	}

	.nav-bar__ul-explore .nav-bar__sheet-a .nav-bar__sheet-label::after {
		transition: none;
	}

	.nav-bar__ul-machines--list .nav-bar__machine-a .nav-bar__sheet-label {
		transition: none;
	}

	.mega-nav__preview,
	.nav[data-nav-open="true"] .mega-nav__preview {
		transition: none;
	}
}

/* Template part: no layout chrome — nav is fixed */
.hatoum-mega-header-shell.wp-block-group.alignfull {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	min-height: 0;
}
