:root {
	--jvh-ease: cubic-bezier(0.16, 1, 0.3, 1);
	--jvh-header-motion: 0.22s;
	--jv-line-soft: #d9d9d9;
}

.jvh-header-shell,
.jvh-header-shell * {
	box-sizing: border-box;
	letter-spacing: 0;
}

html,
body,
.wp-site-blocks {
	overflow-anchor: none;
}

html.jv-drawer-lock,
body.jv-drawer-lock {
	overflow: hidden;
	overscroll-behavior: contain;
}

.jvh-header-shell {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9000;
	width: 100%;
	background: #fff;
	color: #000;
	font-family: var(--jv-font-display, "Helvetica Neue", Arial, sans-serif);
	transform: translate3d(0, 0, 0);
	transition: transform var(--jvh-header-motion) var(--jvh-ease);
	will-change: transform;
	overflow-anchor: none;
}

body.admin-bar .jvh-header-shell {
	top: 32px;
}

.jvh-header-shell.is-header-hidden {
	transform: translateY(-100%);
}

.jvh-promo {
	width: 100%;
	height: 26px;
	overflow: hidden;
	background: var(--jvh-promo-bg, #000);
	color: var(--jvh-promo-color, #fff);
	transition:
		height var(--jvh-header-motion) var(--jvh-ease),
		opacity var(--jvh-header-motion) var(--jvh-ease),
		transform var(--jvh-header-motion) var(--jvh-ease);
}

.jvh-header-shell.is-promo-collapsed .jvh-promo {
	height: 0;
	opacity: 0;
	transform: translate3d(0, -100%, 0);
}

.jvh-promo__track {
	display: flex;
	width: max-content;
	height: 100%;
	animation: jvh-promo-rtl var(--jvh-promo-duration, 16s) linear infinite;
	will-change: transform;
}

.jvh-promo--ltr .jvh-promo__track {
	animation-name: jvh-promo-ltr;
}

.jvh-promo__group {
	display: flex;
	align-items: center;
	flex: 0 0 auto;
	gap: var(--jvh-promo-gap-desktop, 160px);
	padding-right: var(--jvh-promo-gap-desktop, 160px);
	font-size: 11px;
	font-weight: 400;
	line-height: 26px;
	text-transform: uppercase;
	white-space: nowrap;
}

.jvh-promo__item {
	display: block;
}

@keyframes jvh-promo-rtl {
	from {
		transform: translate3d(0, 0, 0);
	}

	to {
		transform: translate3d(calc(var(--jvh-marquee-distance, 0px) * -1), 0, 0);
	}
}

@keyframes jvh-promo-ltr {
	from {
		transform: translate3d(calc(var(--jvh-marquee-distance, 0px) * -1), 0, 0);
	}

	to {
		transform: translate3d(0, 0, 0);
	}
}

.jvh-site-header {
	position: relative;
	width: 100%;
	background: #fff;
	border-bottom: 0;
}

.jvh-site-header::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 4;
	height: 1px;
	background: #000;
	pointer-events: none;
}

.jvh-header-bar {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	align-items: center;
	width: 100%;
	min-height: 54px;
	padding: 0 22px;
}

.jvh-category-nav,
.jvh-utility-nav {
	min-width: 0;
}

.jvh-category-list {
	display: flex;
	align-items: center;
	gap: 24px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.jvh-category-item {
	display: flex;
	align-items: center;
	min-height: 54px;
}

.jvh-category-link,
.jvh-mega-panel__links a,
.jvh-utility-nav a,
.jvh-logo {
	color: #000;
	text-decoration: none;
}

.jvh-category-link {
	display: inline-flex;
	align-items: center;
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
	text-transform: uppercase;
	text-decoration-line: none;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}

.jvh-category-item:hover .jvh-category-link,
.jvh-category-item:focus-within .jvh-category-link,
.jvh-category-item.is-mega-open .jvh-category-link {
	text-decoration-line: underline;
}

.jvh-logo {
	justify-self: center;
	font-size: 20px;
	font-weight: 600;
	line-height: 22px;
	text-transform: uppercase;
}

.jvh-utility-nav {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 17px;
}

.jvh-utility-nav a,
.jvh-icon-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	color: #000;
	cursor: pointer;
	text-transform: uppercase;
}

.jvh-utility-nav svg {
	display: block;
	width: 20px;
	height: 20px;
	fill: none;
	stroke: currentColor;
	stroke-width: 1;
	stroke-linecap: square;
	stroke-linejoin: miter;
}

.jvh-utility-nav .jvh-bookmark-fill {
	fill: none;
	stroke: none;
}

.jvh-mega-panel {
	position: absolute;
	top: 100%;
	left: 0;
	display: none;
	width: 100%;
	background: #fff;
	border-top: 0;
	border-bottom: 1px solid #000;
	height: 270px;
	z-index: 3;
}

.jvh-category-item:hover .jvh-mega-panel,
.jvh-category-item:focus-within .jvh-mega-panel,
.jvh-category-item.is-mega-open .jvh-mega-panel {
	display: block;
}

.jvh-mega-panel__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 34vw);
	gap: 34px;
	width: 100%;
	height: 100%;
	padding: 26px 22px;
}

.jvh-mega-panel__links {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 16px;
	align-content: start;
	align-items: baseline;
	max-width: 760px;
}

.jvh-mega-link {
	width: max-content;
	max-width: 100%;
	font-size: 13px;
	font-weight: 400;
	line-height: 18px;
	text-transform: uppercase;
	text-decoration-line: none;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}

.jvh-mega-link:hover,
.jvh-mega-link:focus-visible {
	text-decoration-line: underline;
	outline: 0;
}

.jvh-mega-group {
	display: contents;
}

.jvh-mega-link--parent {
	font-weight: 600;
}

.jvh-mega-panel__media {
	width: 100%;
	height: 100%;
	overflow: hidden;
	background: #f5f5f5;
}

.jvh-mega-panel__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.jvh-header-spacer {
	height: var(--jvh-header-height, 80px);
	transition: height var(--jvh-header-motion) var(--jvh-ease);
	overflow-anchor: none;
}

.jv-drawer-overlay {
	position: fixed;
	inset: 0;
	z-index: 9997;
	background: rgba(0, 0, 0, 0.34);
	backdrop-filter: none;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.24s var(--jvh-ease);
}

.jv-drawer-overlay.is-open {
	opacity: 1;
	pointer-events: auto;
}

.jv-drawer {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 9998;
	width: var(--jv-drawer-width, 30vw);
	min-width: 0;
	height: 100vh;
	background: #fff;
	color: #000;
	transform: translateX(100%);
	transition: transform 0.24s var(--jvh-ease);
	will-change: transform;
}

.jv-drawer.is-open {
	transform: translateX(0);
}

body.admin-bar .jv-drawer {
	top: 32px;
	height: calc(100vh - 32px);
}

.jv-drawer__close {
	position: absolute;
	top: 18px;
	right: 18px;
	z-index: 2;
	width: 28px;
	height: 28px;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	color: #000;
}

.jv-drawer__close span {
	position: absolute;
	top: 13px;
	left: 4px;
	width: 20px;
	height: 1px;
	background: currentColor;
}

.jv-drawer__close span:first-child {
	transform: rotate(45deg);
}

.jv-drawer__close span:last-child {
	transform: rotate(-45deg);
}

.jv-cart-drawer {
	height: 100%;
	padding: 56px 18px 18px;
	overflow-y: auto;
}

.jv-cart-drawer h2 {
	margin: 0 0 18px;
	font-size: 21px;
	font-weight: 400;
	line-height: 26px;
}

.jv-cart-empty,
.jv-cart-help,
.jvh-wishlist-empty {
	margin: 0;
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
}

.jv-cart-item {
	display: grid;
	grid-template-columns: 70px minmax(0, 1fr);
	gap: 12px;
	padding: 0 0 14px;
	border-bottom: 1px solid #000;
}

.jv-cart-item + .jv-cart-item {
	margin-top: 14px;
}

.jv-cart-item img {
	display: block;
	width: 70px;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	background: #f4f4f4;
}

.jv-cart-item__title {
	margin: 0;
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
}

.jv-cart-item__meta,
.jv-cart-item__price {
	margin: 5px 0 0;
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
	color: #555;
}

.jv-cart-summary {
	margin-top: 18px;
	padding-top: 14px;
	border-top: 1px solid #000;
}

.jv-cart-summary__row {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
}

.jv-checkout-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 40px;
	margin-top: 14px;
	border: 1px solid #000;
	background: #000;
	color: #fff;
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
	text-decoration: none;
}

.jvh-wishlist-page {
	width: 100%;
	padding: 32px 22px 72px;
}

.jvh-wishlist-grid {
	width: 100%;
}

.jvh-wishlist-product__size {
	margin: 4px 0 0;
	font-size: 12px;
	font-weight: 400;
	line-height: 16px;
	color: #555;
}

@media (max-width: 900px) {
	.jvh-header-bar {
		min-height: 50px;
		padding: 0 14px;
	}

	.jvh-category-list {
		gap: 14px;
		overflow-x: auto;
		scrollbar-width: none;
	}

	.jvh-category-list::-webkit-scrollbar {
		display: none;
	}

	.jvh-category-link,
	.jvh-category-item {
		min-height: 50px;
	}

	.jvh-logo {
		font-size: 16px;
		line-height: 18px;
	}

	.jvh-utility-nav {
		gap: 11px;
	}

	.jvh-utility-nav a,
	.jvh-icon-button {
		width: 20px;
		height: 20px;
	}

	.jvh-utility-nav svg {
		width: 18px;
		height: 18px;
	}

	.jvh-promo__group {
		gap: var(--jvh-promo-gap-mobile, 48px);
		padding-right: var(--jvh-promo-gap-mobile, 48px);
	}

	.jvh-mega-panel__inner {
		grid-template-columns: 1fr;
		gap: 20px;
		padding: 22px 14px 26px;
	}

	.jvh-mega-panel__links {
		max-width: none;
	}

	.jv-drawer,
	.jv-drawer--cart {
		top: auto;
		right: 0;
		bottom: 0;
		width: 100vw;
		min-width: 0;
		height: 100vh;
		transform: translateY(100%);
	}

	.jv-drawer.is-open {
		transform: translateY(0);
	}
}

@media (max-width: 782px) {
	body.admin-bar .jvh-header-shell {
		top: 46px;
	}

	body.admin-bar .jv-drawer {
		top: 46px;
		height: calc(100vh - 46px);
	}
}

@media (prefers-reduced-motion: reduce) {
	.jvh-header-shell,
	.jvh-promo,
	.jvh-promo__track,
	.jvh-header-spacer,
	.jv-drawer,
	.jv-drawer-overlay {
		animation: none !important;
		transition: none !important;
	}
}
