/* ==========================================================================
   Wijnkoperij Joure — main.css
   Design system: Vintage Burgundy / Oak / Parchment. Editorial luxury.
   Tokens mirror DESIGN.md and are overridable via the Customizer
   (see inc/customizer.php -> :root --wkj-* variables).
   ========================================================================== */

:root {
	/* Colour tokens (Customizer fallbacks live here). */
	--wkj-primary: #3c030c;
	--wkj-primary-container: #58181f;
	--wkj-on-primary: #ffffff;
	--wkj-secondary: #735a3a;
	--wkj-secondary-container: #fddab1;
	--wkj-on-secondary-container: #785e3e;
	--wkj-tertiary: #1e1a18;
	--wkj-tertiary-fixed: #eae1dd;
	--wkj-tertiary-fixed-dim: #cdc5c1;
	--wkj-background: #fbf9f4;
	--wkj-surface: #fbf9f4;
	--wkj-surface-card: #ffffff;
	--wkj-surface-container-low: #f5f3ee;
	--wkj-surface-container: #f0eee9;
	--wkj-surface-container-high: #eae8e3;
	--wkj-on-surface: #1b1c19;
	--wkj-on-surface-variant: #544343;
	--wkj-outline: #867272;
	--wkj-outline-variant: #d9c1c1;
	--wkj-error: #ba1a1a;

	/* Typography. */
	--wkj-font-display: "Libre Caslon Text", Georgia, "Times New Roman", serif;
	--wkj-font-body: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

	/* Spacing scale (4px baseline). */
	--wkj-stack-sm: 8px;
	--wkj-stack-md: 24px;
	--wkj-stack-lg: 48px;
	--wkj-gutter: 24px;
	--wkj-margin-desktop: 64px;
	--wkj-margin-mobile: 20px;
	--wkj-container: 1280px;

	/* Shape. */
	--wkj-radius: 4px;
	--wkj-radius-lg: 8px;
}

/* --------------------------------------------------------------------------
   Reset & base
   -------------------------------------------------------------------------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	margin: 0;
	background-color: var(--wkj-background);
	color: var(--wkj-on-surface);
	font-family: var(--wkj-font-body);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--wkj-font-display);
	font-weight: 400;
	color: var(--wkj-primary);
	line-height: 1.2;
	margin: 0 0 var(--wkj-stack-sm);
}

a {
	color: var(--wkj-primary);
	text-decoration: none;
	transition: color .25s ease, opacity .25s ease;
}

a:hover {
	color: var(--wkj-primary-container);
}

img {
	max-width: 100%;
	height: auto;
}

:focus-visible {
	outline: 2px solid var(--wkj-primary);
	outline-offset: 2px;
}

.wkj-container {
	max-width: var(--wkj-container);
	margin-inline: auto;
	padding-inline: var(--wkj-margin-mobile);
}

@media (min-width: 768px) {
	.wkj-container {
		padding-inline: var(--wkj-margin-desktop);
	}
}

.screen-reader-text {
	position: absolute !important;
	clip-path: inset(50%);
	width: 1px;
	height: 1px;
	overflow: hidden;
	word-wrap: normal !important;
}

.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100000;
	background: var(--wkj-primary);
	color: var(--wkj-on-primary);
	padding: 12px 20px;
}

.skip-link:focus {
	left: 8px;
	top: 8px;
}

/* --------------------------------------------------------------------------
   Material Symbols
   -------------------------------------------------------------------------- */
.material-symbols-outlined {
	font-family: "Material Symbols Outlined";
	font-weight: normal;
	font-style: normal;
	line-height: 1;
	display: inline-block;
	font-variation-settings: "FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24;
	vertical-align: middle;
}

/* --------------------------------------------------------------------------
   Type utility classes
   -------------------------------------------------------------------------- */
.wkj-eyebrow,
.wkj-label {
	font-family: var(--wkj-font-body);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1;
}

.wkj-display { font-size: clamp(36px, 5vw, 48px); line-height: 1.1; letter-spacing: -0.02em; }
.wkj-headline-md { font-size: clamp(26px, 4vw, 32px); }
.wkj-headline-sm { font-size: 24px; line-height: 1.3; }

/* --------------------------------------------------------------------------
   Header / navigation
   -------------------------------------------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	width: 100%;
	background: var(--wkj-surface);
	border-bottom: 1px solid var(--wkj-outline-variant);
	transition: background-color .3s ease, box-shadow .3s ease;
}

.site-header.is-scrolled {
	background: rgba(251, 249, 244, 0.95);
	backdrop-filter: blur(10px);
	box-shadow: 0 1px 12px -6px rgba(60, 3, 12, 0.2);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 80px;
}

.site-title {
	font-family: var(--wkj-font-display);
	font-size: clamp(22px, 3vw, 30px);
	color: var(--wkj-primary);
	margin: 0;
}

.site-title a { color: inherit; }

.custom-logo { height: 48px; width: auto; }

.main-navigation { display: none; }

@media (min-width: 768px) {
	.main-navigation { display: block; }
}

.main-navigation ul {
	display: flex;
	align-items: center;
	gap: 32px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.main-navigation a {
	font-family: var(--wkj-font-body);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.05em;
	color: var(--wkj-on-surface-variant);
	padding-bottom: 4px;
}

.main-navigation a:hover,
.main-navigation .current-menu-item > a {
	color: var(--wkj-primary);
}

.main-navigation .current-menu-item > a {
	border-bottom: 2px solid var(--wkj-primary);
}

/* --------------------------------------------------------------------------
   Dropdown submenus (desktop)
   -------------------------------------------------------------------------- */
.main-navigation ul li {
	position: relative;
}

.main-navigation .wkj-sub-caret {
	display: inline-block;
	width: 0;
	height: 0;
	margin-left: 6px;
	vertical-align: middle;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 5px solid currentColor;
	transition: transform .2s ease;
	font-size: 0;
	line-height: 0;
}

.main-navigation .wkj-sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--wkj-surface-card);
	border: 1px solid var(--wkj-outline-variant);
	box-shadow: 0 12px 28px -12px rgba(60, 3, 12, 0.18);
	padding: 8px 0;
	margin: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(6px);
	transition: opacity .2s ease, transform .2s ease, visibility .2s;
	z-index: 60;
}

/* Reveal on hover or when a child has keyboard focus. */
.main-navigation li.menu-item-has-children:hover > .wkj-sub-menu,
.main-navigation li.menu-item-has-children:focus-within > .wkj-sub-menu,
.main-navigation li.menu-item-has-children.is-open > .wkj-sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.main-navigation li.menu-item-has-children:hover > a .wkj-sub-caret,
.main-navigation li.menu-item-has-children:focus-within > a .wkj-sub-caret,
.main-navigation li.menu-item-has-children.is-open > a .wkj-sub-caret {
	transform: rotate(180deg);
}

.main-navigation .wkj-sub-menu li {
	width: 100%;
}

.main-navigation .wkj-sub-menu a {
	display: block;
	padding: 10px 20px;
	border-bottom: 0;
	white-space: nowrap;
	color: var(--wkj-on-surface-variant);
}

.main-navigation .wkj-sub-menu a:hover,
.main-navigation .wkj-sub-menu .current-menu-item > a {
	color: var(--wkj-primary);
	background: var(--wkj-surface-container-low);
	border-bottom: 0;
}

/* Third level: open to the side. */
.main-navigation .wkj-sub-menu .wkj-sub-menu {
	top: 0;
	left: 100%;
}

/* --------------------------------------------------------------------------
   Mobile submenus (expand inline)
   -------------------------------------------------------------------------- */
.wkj-mobile-menu .sub-menu,
.wkj-mobile-menu .wkj-sub-menu {
	list-style: none;
	margin: 0;
	padding: 0 0 0 16px;
}

.wkj-mobile-menu .sub-menu a,
.wkj-mobile-menu .wkj-sub-menu a {
	padding: 10px var(--wkj-margin-mobile);
	font-weight: 500;
	opacity: 0.85;
}

.wkj-mobile-menu .wkj-sub-caret { display: none; }

.site-header__actions {
	display: flex;
	align-items: center;
	gap: 20px;
}

.site-header__actions button,
.site-header__actions a.wkj-icon-link {
	background: none;
	border: 0;
	cursor: pointer;
	color: var(--wkj-primary);
	padding: 8px;
	display: inline-flex;
	transition: background-color .2s ease;
}

.site-header__actions button:hover {
	background: var(--wkj-surface-container-low);
}

.menu-toggle { display: inline-flex; }

@media (min-width: 768px) {
	.menu-toggle { display: none; }
}

.wkj-mobile-menu {
	display: none;
	flex-direction: column;
	gap: 4px;
	padding: var(--wkj-stack-md) 0;
	border-top: 1px solid var(--wkj-outline-variant);
}

.wkj-mobile-menu.is-open { display: flex; }

.wkj-mobile-menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.wkj-mobile-menu a {
	display: block;
	padding: 12px var(--wkj-margin-mobile);
	font-family: var(--wkj-font-body);
	font-weight: 600;
	letter-spacing: 0.05em;
	color: var(--wkj-on-surface-variant);
}

/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.wkj-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 16px 32px;
	font-family: var(--wkj-font-body);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	border-radius: var(--wkj-radius);
	border: 1px solid transparent;
	cursor: pointer;
	transition: opacity .25s ease, background-color .25s ease, color .25s ease;
}

.wkj-btn--primary {
	background: var(--wkj-primary);
	color: var(--wkj-on-primary);
}

.wkj-btn--primary:hover {
	opacity: 0.9;
	color: var(--wkj-on-primary);
}

.wkj-btn--outline {
	background: transparent;
	border-color: var(--wkj-secondary);
	color: var(--wkj-secondary);
}

.wkj-btn--outline:hover {
	background: var(--wkj-surface-container-low);
	color: var(--wkj-secondary);
}

.wkj-btn--dark {
	background: var(--wkj-tertiary);
	color: #fff;
}

.wkj-btn--dark:hover {
	background: var(--wkj-primary);
	color: #fff;
}

/* --------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */
.wkj-hero {
	position: relative;
	min-height: 640px;
	display: flex;
	align-items: center;
	overflow: hidden;
}

@media (min-width: 768px) {
	.wkj-hero { height: 780px; }
}

.wkj-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transform: scale(1.05);
	z-index: 0;
}

.wkj-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, rgba(251, 249, 244, 0.92), rgba(251, 249, 244, 0.45) 45%, transparent);
	z-index: 1;
}

.wkj-hero__content {
	position: relative;
	z-index: 2;
	max-width: 640px;
}

.wkj-hero__eyebrow {
	display: block;
	color: var(--wkj-secondary);
	letter-spacing: 0.2em;
	margin-bottom: 16px;
}

.wkj-hero__title {
	font-size: clamp(36px, 6vw, 64px);
	color: var(--wkj-primary);
	margin-bottom: var(--wkj-stack-md);
}

.wkj-hero__text {
	font-size: 18px;
	color: var(--wkj-on-surface-variant);
	max-width: 520px;
	margin-bottom: 40px;
}

.wkj-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

/* --------------------------------------------------------------------------
   Bento / feature grid
   -------------------------------------------------------------------------- */
.wkj-section { padding-block: var(--wkj-stack-lg); }

.wkj-section-head {
	display: flex;
	flex-direction: column;
	gap: 16px;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: var(--wkj-stack-md);
}

@media (min-width: 768px) {
	.wkj-section-head { flex-direction: row; align-items: flex-end; }
}

.wkj-section-head__eyebrow {
	color: var(--wkj-secondary);
	letter-spacing: 0.1em;
	display: block;
	margin-bottom: 8px;
}

.wkj-bento {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wkj-gutter);
}

@media (min-width: 768px) {
	.wkj-bento {
		grid-template-columns: repeat(12, 1fr);
		min-height: 600px;
	}
	.wkj-bento__main { grid-column: span 7; }
	.wkj-bento__side { grid-column: span 5; display: grid; grid-template-rows: 1fr 1fr; gap: var(--wkj-gutter); }
}

.wkj-bento__main {
	position: relative;
	overflow: hidden;
	border: 1px solid var(--wkj-outline-variant);
	min-height: 320px;
}

.wkj-bento__main-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform .7s ease;
}

.wkj-bento__main:hover .wkj-bento__main-bg { transform: scale(1.08); }

.wkj-bento__main-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.2);
}

.wkj-bento__main-text {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: var(--wkj-stack-md);
	color: #fff;
}

.wkj-bento__main-text h3 { color: #fff; }

.wkj-bento__card {
	padding: var(--wkj-stack-md);
	display: flex;
	flex-direction: column;
	justify-content: center;
	border: 1px solid var(--wkj-outline-variant);
}

.wkj-bento__card--primary {
	background: var(--wkj-primary);
	color: var(--wkj-on-primary);
	border-color: var(--wkj-primary-container);
}

.wkj-bento__card--primary h3 { color: #fff; }

.wkj-bento__card--surface { background: var(--wkj-surface-container-high); }

/* --------------------------------------------------------------------------
   Product cards
   -------------------------------------------------------------------------- */
.wkj-product-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wkj-gutter);
}

@media (min-width: 640px) { .wkj-product-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .wkj-product-grid { grid-template-columns: repeat(3, 1fr); } }
.wkj-product-grid--4 { }
@media (min-width: 1024px) { .wkj-product-grid--4 { grid-template-columns: repeat(4, 1fr); } }

.wkj-card {
	background: var(--wkj-surface-card);
	border: 1px solid var(--wkj-outline-variant);
	display: flex;
	flex-direction: column;
	transition: transform .4s cubic-bezier(0.165, 0.84, 0.44, 1),
		box-shadow .4s cubic-bezier(0.165, 0.84, 0.44, 1),
		border-color .3s ease;
}

.wkj-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px -15px rgba(60, 3, 12, 0.12);
	border-color: var(--wkj-primary);
}

.wkj-card__media {
	position: relative;
	aspect-ratio: 3 / 4;
	background: var(--wkj-surface-container-low);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.wkj-card__media img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 32px;
	transition: transform .5s ease;
}

.wkj-card:hover .wkj-card__media img { transform: scale(1.05); }

.wkj-badge {
	position: absolute;
	top: 16px;
	left: 16px;
	background: var(--wkj-primary);
	color: #fff;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 4px 12px;
}

.wkj-badge--soft {
	background: var(--wkj-secondary-container);
	color: var(--wkj-on-secondary-container);
}

.wkj-card__body {
	padding: var(--wkj-stack-md);
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.wkj-card__origin {
	color: var(--wkj-on-surface-variant);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	opacity: 0.7;
	margin-bottom: 4px;
}

.wkj-card__title {
	font-size: 20px;
	color: var(--wkj-primary);
	margin-bottom: 8px;
}

.wkj-card__price {
	font-family: var(--wkj-font-display);
	color: var(--wkj-primary);
	font-size: 24px;
	margin-top: auto;
}

.wkj-card__price del {
	font-family: var(--wkj-font-body);
	font-size: 13px;
	color: var(--wkj-on-surface-variant);
	margin-left: 8px;
}

.wkj-card__tags { display: flex; gap: 8px; margin-bottom: 8px; flex-wrap: wrap; }

.wkj-chip {
	background: var(--wkj-surface-container);
	color: var(--wkj-secondary);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 2px 8px;
}

/* --------------------------------------------------------------------------
   Shop layout (archive)
   -------------------------------------------------------------------------- */
.wkj-shop {
	display: flex;
	flex-direction: column;
	gap: var(--wkj-gutter);
}

@media (min-width: 768px) {
	.wkj-shop { flex-direction: row; }
}

.wkj-shop__sidebar { width: 100%; flex-shrink: 0; }

@media (min-width: 768px) {
	.wkj-shop__sidebar { width: 256px; }
}

.wkj-filter-group {
	border-bottom: 1px solid var(--wkj-outline-variant);
	padding-bottom: var(--wkj-stack-md);
	margin-bottom: var(--wkj-stack-md);
}

.wkj-filter-group h3 { margin-bottom: 16px; }

.wkj-filter-group label {
	display: flex;
	align-items: center;
	cursor: pointer;
	margin-bottom: 12px;
}

.wkj-filter-group input[type="checkbox"] {
	width: 16px;
	height: 16px;
	border-radius: 2px;
	border: 1px solid var(--wkj-outline-variant);
	accent-color: var(--wkj-primary);
}

.wkj-filter-group label span {
	margin-left: 12px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--wkj-on-surface-variant);
}

.wkj-filter-group label:hover span { color: var(--wkj-primary); }

.wkj-breadcrumb {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--wkj-on-surface-variant);
	opacity: 0.7;
	margin-bottom: var(--wkj-stack-md);
}

/* --------------------------------------------------------------------------
   Newsletter
   -------------------------------------------------------------------------- */
.wkj-newsletter {
	padding-block: var(--wkj-stack-lg);
	border-block: 1px solid var(--wkj-outline-variant);
}

.wkj-newsletter__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wkj-stack-lg);
	align-items: center;
}

@media (min-width: 1024px) {
	.wkj-newsletter__grid { grid-template-columns: 1fr 1fr; }
}

.wkj-newsletter form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

@media (min-width: 640px) {
	.wkj-newsletter form { flex-direction: row; }
}

.wkj-newsletter input[type="email"] {
	flex-grow: 1;
	background: var(--wkj-surface-card);
	border: 1px solid var(--wkj-outline-variant);
	padding: 14px 16px;
	font-family: var(--wkj-font-body);
	border-radius: var(--wkj-radius);
}

.wkj-newsletter input[type="email"]:focus {
	outline: none;
	border-color: var(--wkj-primary);
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.site-footer {
	background: var(--wkj-tertiary);
	color: var(--wkj-tertiary-fixed);
	padding-block: var(--wkj-stack-lg);
}

.site-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wkj-gutter);
}

@media (min-width: 768px) {
	.site-footer__grid { grid-template-columns: repeat(4, 1fr); }
}

.site-footer h4 {
	color: var(--wkj-tertiary-fixed);
	font-size: 24px;
	margin-bottom: var(--wkj-stack-md);
}

.site-footer a { color: var(--wkj-tertiary-fixed-dim); }
.site-footer a:hover { color: #fff; }

.site-footer__brand-title {
	font-family: var(--wkj-font-display);
	font-size: clamp(28px, 4vw, 40px);
	color: var(--wkj-tertiary-fixed);
	margin-bottom: var(--wkj-stack-sm);
	display: block;
}

.site-footer ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }

.site-footer__hours li { display: flex; justify-content: space-between; gap: 16px; }

.site-footer__legal {
	margin-top: var(--wkj-stack-lg);
	padding-top: var(--wkj-stack-sm);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	text-align: center;
	font-size: 12px;
	letter-spacing: 0.05em;
	color: var(--wkj-tertiary-fixed-dim);
}

/* --------------------------------------------------------------------------
   Age gate
   -------------------------------------------------------------------------- */
.wkj-age-gate {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--wkj-margin-mobile);
	background: rgba(30, 26, 24, 0.72);
	backdrop-filter: blur(8px);
}

.wkj-age-gate[hidden] { display: none; }

.wkj-age-gate__card {
	background: var(--wkj-surface-card);
	max-width: 460px;
	width: 100%;
	padding: var(--wkj-stack-lg);
	border-radius: var(--wkj-radius);
	box-shadow: 0 24px 60px -20px rgba(0, 0, 0, 0.5);
	text-align: center;
	border-top: 4px solid var(--wkj-primary);
}

.wkj-age-gate__title {
	font-size: clamp(26px, 4vw, 32px);
	margin-bottom: 12px;
}

.wkj-age-gate__text {
	color: var(--wkj-on-surface-variant);
	margin-bottom: var(--wkj-stack-md);
}

.wkj-age-gate__field {
	text-align: left;
	margin-bottom: var(--wkj-stack-md);
}

.wkj-age-gate__field label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--wkj-on-surface-variant);
	margin-bottom: 8px;
}

.wkj-age-gate__field input {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid var(--wkj-outline-variant);
	border-radius: var(--wkj-radius);
	font-family: var(--wkj-font-body);
	font-size: 16px;
}

.wkj-age-gate__field input:focus {
	outline: none;
	border-color: var(--wkj-primary);
}

.wkj-age-gate__actions {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.wkj-age-gate__error {
	color: var(--wkj-error);
	font-size: 14px;
	margin-top: var(--wkj-stack-sm);
	min-height: 1.2em;
}

.wkj-age-gate__deny {
	background: none;
	border: 0;
	color: var(--wkj-on-surface-variant);
	font-size: 14px;
	cursor: pointer;
	text-decoration: underline;
	padding: 8px;
}

body.wkj-age-locked { overflow: hidden; }

/* --------------------------------------------------------------------------
   Utilities & reduced motion
   -------------------------------------------------------------------------- */
.wkj-mt-lg { margin-top: var(--wkj-stack-lg); }
.wkj-text-center { text-align: center; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
	.wkj-card:hover { transform: none; }
}

/* --------------------------------------------------------------------------
   WooCommerce overrides
   -------------------------------------------------------------------------- */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--wkj-gutter);
	margin: 0;
	padding: 0;
	list-style: none;
}

/* WooCommerce adds ::before / ::after clearfix elements to ul.products for its
   legacy float layout. In a CSS grid these become real grid items and the
   ::before steals the first cell, leaving an empty box and shifting every
   product one position. Removing them fixes the blank first tile. */
.woocommerce ul.products::before,
.woocommerce ul.products::after {
	content: none !important;
	display: none !important;
}

@media (max-width: 1024px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .woocommerce ul.products { grid-template-columns: 1fr; } }

.woocommerce ul.products li.product {
	margin: 0 !important;
	width: auto !important;
	float: none !important;
	clear: none !important;
}

/* WooCommerce also marks every Nth item with .first / .last for floats; those
   classes must not force a clear inside a grid. */
.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product.last {
	clear: none !important;
}

/* The loop <li> carries the .wkj-card class and is the grid cell itself. */
.woocommerce ul.products li.product.wkj-card {
	display: flex;
	flex-direction: column;
	background: var(--wkj-surface-card);
	border: 1px solid var(--wkj-outline-variant);
}

.woocommerce ul.products li.product.wkj-card::before,
.woocommerce ul.products li.product.wkj-card::after {
	content: none !important;
	display: none !important;
}

.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .single_add_to_cart_button {
	background: var(--wkj-primary) !important;
	color: #fff !important;
	border-radius: var(--wkj-radius) !important;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: 600;
	padding: 14px 28px;
}

.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
	opacity: 0.9;
}

.woocommerce span.onsale {
	background: var(--wkj-primary);
	color: #fff;
	border-radius: 0;
	font-weight: 600;
}

.woocommerce nav.woocommerce-pagination ul {
	border: 0;
	display: flex;
	gap: 8px;
	justify-content: center;
}

.woocommerce nav.woocommerce-pagination ul li {
	border: 0;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--wkj-outline-variant);
	color: var(--wkj-on-surface-variant);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--wkj-primary);
	color: #fff;
	border-color: var(--wkj-primary);
}

/* Filter widgets in sidebar */
.wkj-shop__sidebar .widget { margin-bottom: var(--wkj-stack-md); }
.wkj-shop__sidebar .woocommerce-widget-layered-nav-list { list-style: none; padding: 0; margin: 0; }
.wkj-shop__sidebar .woocommerce-widget-layered-nav-list li { padding: 6px 0; }
.wkj-shop__sidebar a { color: var(--wkj-on-surface-variant); font-weight: 600; }
.wkj-shop__sidebar a:hover { color: var(--wkj-primary); }

/* --------------------------------------------------------------------------
   Header extras: topbar, CTA, cart badge, menu cart
   -------------------------------------------------------------------------- */
.wkj-topbar {
	background: var(--wkj-tertiary);
	color: var(--wkj-tertiary-fixed-dim);
	font-size: 13px;
	letter-spacing: 0.04em;
	text-align: center;
	padding: 8px 0;
}

/* Sticky vs static header (Customizer toggle). */
.site-header.is-sticky { position: sticky; top: 0; }
.site-header.is-static { position: relative; }

.wkj-header__cta {
	padding: 10px 20px;
	font-size: 13px;
}

@media (max-width: 900px) {
	.wkj-header__cta { display: none; }
}

/* Cart link + live count badge */
.wkj-cart-link { position: relative; }

.wkj-cart-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 999px;
	background: var(--wkj-primary);
	color: #fff;
	font-family: var(--wkj-font-body);
	font-size: 11px;
	font-weight: 600;
	line-height: 1;
}

.wkj-cart-link .wkj-cart-count {
	position: absolute;
	top: 0;
	right: 0;
	transform: translate(25%, -25%);
}

.wkj-cart-count.is-empty { display: none; }

/* Cart item inside the nav menu */
.main-navigation .wkj-menu-cart a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--wkj-primary);
}

.main-navigation .wkj-menu-cart .wkj-cart-count { position: static; transform: none; }

/* Mobile cart row */
.wkj-mobile-cart {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px var(--wkj-margin-mobile);
	font-weight: 600;
	letter-spacing: 0.03em;
	color: var(--wkj-primary);
	border-top: 1px solid var(--wkj-outline-variant);
	margin-top: 8px;
}

.wkj-mobile-cart .wkj-cart-count { position: static; transform: none; }

/* --------------------------------------------------------------------------
   Product search (header panel + mobile)
   -------------------------------------------------------------------------- */
.wkj-search-panel {
	border-top: 1px solid var(--wkj-outline-variant);
	background: var(--wkj-surface);
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transition: max-height .25s ease, opacity .25s ease;
}

.wkj-search-panel[hidden] { display: none; }

.wkj-search-panel.is-open {
	max-height: 120px;
	opacity: 1;
}

.wkj-search-form {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 0;
}

.wkj-search-form__icon {
	color: var(--wkj-secondary);
	font-size: 24px;
	flex-shrink: 0;
}

.wkj-search-form__input {
	flex-grow: 1;
	border: 0;
	border-bottom: 1px solid var(--wkj-outline-variant);
	background: transparent;
	padding: 10px 4px;
	font-family: var(--wkj-font-display);
	font-size: clamp(18px, 3vw, 24px);
	color: var(--wkj-on-surface);
}

.wkj-search-form__input:focus {
	outline: none;
	border-bottom-color: var(--wkj-primary);
}

.wkj-search-form__input::placeholder {
	color: var(--wkj-on-surface-variant);
	opacity: 0.6;
}

.wkj-search-form__submit {
	flex-shrink: 0;
	background: var(--wkj-primary);
	color: #fff;
	border: 0;
	padding: 12px 24px;
	font-family: var(--wkj-font-body);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	cursor: pointer;
	border-radius: var(--wkj-radius);
	transition: background-color .2s ease;
}

.wkj-search-form__submit:hover { background: var(--wkj-primary-container); }

.wkj-search-form__close {
	flex-shrink: 0;
	background: none;
	border: 0;
	color: var(--wkj-on-surface-variant);
	cursor: pointer;
	display: inline-flex;
	padding: 8px;
}

.wkj-search-form__close:hover { color: var(--wkj-primary); }

@media (max-width: 600px) {
	.wkj-search-form__submit { padding: 12px 16px; }
}

/* Mobile menu search field */
.wkj-mobile-search {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px var(--wkj-margin-mobile);
	border-bottom: 1px solid var(--wkj-outline-variant);
	margin-bottom: 8px;
}

.wkj-mobile-search .material-symbols-outlined { color: var(--wkj-secondary); }

.wkj-mobile-search input {
	flex-grow: 1;
	border: 0;
	background: transparent;
	padding: 8px 4px;
	font-family: var(--wkj-font-body);
	font-size: 16px;
	color: var(--wkj-on-surface);
}

.wkj-mobile-search input:focus { outline: none; }

/* Footer social links */
.site-footer__social {
	display: flex;
	gap: 12px;
	margin-top: 20px;
}

.site-footer__social a {
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--wkj-tertiary-fixed-dim);
	border-radius: 999px;
	color: var(--wkj-tertiary-fixed-dim);
	transition: background-color .2s ease, color .2s ease;
}

.site-footer__social a:hover {
	background: #fff;
	color: var(--wkj-tertiary);
}

/* --------------------------------------------------------------------------
   Single product page (matches the supplied example)
   -------------------------------------------------------------------------- */

/* Hero: image left, details right. */
.woocommerce div.product {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wkj-gutter);
	align-items: start;
}

@media (min-width: 1024px) {
	.woocommerce div.product {
		grid-template-columns: 1fr 1fr;
	}
	.woocommerce div.product .woocommerce-product-gallery { grid-column: 1; }
	.woocommerce div.product .summary,
	.woocommerce div.product .entry-summary { grid-column: 2; }
	.woocommerce div.product .wkj-profile,
	.woocommerce div.product .wkj-single-section,
	.woocommerce div.product .related,
	.woocommerce div.product .upsells { grid-column: 1 / -1; }
}

/* --- Product gallery / image fix ------------------------------------------
   WooCommerce's flexslider sets inline pixel widths on the wrapper, the
   .__image slides and the <img> (e.g. width:25%) which shrinks the image.
   These rules override those inline widths so the single featured image
   always fills the framed 4:5 area. */
.woocommerce div.product .woocommerce-product-gallery {
	position: relative;
	background: var(--wkj-surface-card);
	border: 1px solid var(--wkj-outline-variant);
	box-shadow: 0 4px 20px -2px rgba(0, 0, 0, 0.05);
	padding: 0;
	margin: 0;
	float: none;
	width: 100% !important;
	opacity: 1 !important;
}

.woocommerce div.product .woocommerce-product-gallery .flex-viewport,
.woocommerce div.product .woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
	width: 100% !important;
	margin: 0;
	aspect-ratio: 4 / 5;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 32px;
	transform: none !important;
}

.woocommerce div.product .woocommerce-product-gallery .flex-viewport {
	padding: 0;
}

@media (min-width: 768px) {
	.woocommerce div.product .woocommerce-product-gallery .woocommerce-product-gallery__wrapper { padding: 64px; }
}

.woocommerce div.product .woocommerce-product-gallery__image,
.woocommerce div.product .woocommerce-product-gallery__image--placeholder {
	width: 100% !important;
	height: 100%;
	float: none !important;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 !important;
}

.woocommerce div.product .woocommerce-product-gallery__image a {
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
}

.woocommerce div.product .woocommerce-product-gallery__image img,
.woocommerce div.product .woocommerce-product-gallery img.wp-post-image {
	width: auto !important;
	max-width: 100%;
	max-height: 56vh;
	height: auto;
	margin: 0 auto;
	object-fit: contain;
	transition: transform .7s ease;
}

.woocommerce div.product .woocommerce-product-gallery:hover img.wp-post-image {
	transform: scale(1.05);
}

/* Gallery zoom/trigger button position. */
.woocommerce div.product .woocommerce-product-gallery .flex-viewport { width: 100%; }
.woocommerce div.product .woocommerce-product-gallery__trigger { top: 1rem; right: 1rem; z-index: 3; }

/* Badges over the image. */
.wkj-single__badges {
	position: absolute;
	top: 16px;
	left: 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	z-index: 4;
}

.wkj-badge,
.wkj-badge--soft,
.wkj-badge--dark {
	display: inline-block;
	padding: 4px 12px;
	font-family: var(--wkj-font-body);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #fff;
}

.wkj-badge { background: var(--wkj-primary); }
.wkj-badge--soft { background: var(--wkj-sale-red, #E63946); }
.wkj-badge--dark { background: var(--wkj-tertiary); }

/* --- Summary (right column) ----------------------------------------------- */
.woocommerce div.product .summary,
.woocommerce div.product .entry-summary {
	display: flex;
	flex-direction: column;
	gap: var(--wkj-stack-md);
	/* Override WooCommerce core's float:right; width:48% which otherwise
	   shrinks the summary to half of its grid column. */
	float: none !important;
	width: 100% !important;
	margin: 0 !important;
	clear: none;
}

@media (min-width: 1024px) {
	.woocommerce div.product .summary,
	.woocommerce div.product .entry-summary {
		/* Fill (almost) the full right column as requested. */
		width: 95% !important;
	}
}

.wkj-single__eyebrow {
	font-family: var(--wkj-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wkj-secondary);
}

.woocommerce div.product .product_title {
	font-size: clamp(28px, 5vw, 48px);
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--wkj-primary);
	margin: 0;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	display: flex;
	align-items: baseline;
	gap: 16px;
	font-family: var(--wkj-font-body);
	color: var(--wkj-on-surface);
	font-size: 20px;
	font-weight: 700;
	margin: 0;
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
	opacity: 1;
	font-weight: 400;
	font-size: 16px;
	color: var(--wkj-outline);
}

.woocommerce div.product p.price ins { text-decoration: none; }

.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: 18px;
	line-height: 1.7;
	color: var(--wkj-on-surface-variant);
}

/* Quantity + add to cart. */
.woocommerce div.product form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
	margin: 0;
}

.woocommerce div.product form.cart .quantity {
	display: flex;
	align-items: center;
	border: 1px solid var(--wkj-outline);
	height: 52px;
}

.woocommerce div.product form.cart .quantity input.qty {
	width: 56px;
	height: 50px;
	border: 0;
	background: transparent;
	text-align: center;
	font-weight: 700;
	font-family: var(--wkj-font-body);
}

.woocommerce div.product form.cart .single_add_to_cart_button {
	flex-grow: 1;
	height: 52px;
	background: var(--wkj-primary);
	color: #fff;
	border-radius: 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	transition: background-color .2s ease;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover {
	background: var(--wkj-tertiary);
}

/* Feature row (direct leverbaar / verzending / bio). */
.wkj-features {
	margin-top: var(--wkj-stack-sm);
	border-top: 1px solid var(--wkj-outline-variant);
	padding-top: var(--wkj-stack-md);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}

@media (min-width: 768px) { .wkj-features { grid-template-columns: repeat(3, 1fr); } }

.wkj-features__item {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.wkj-features__item .material-symbols-outlined { color: var(--wkj-secondary); font-size: 22px; }

/* --- Profile section (3 columns) ------------------------------------------ */
.wkj-profile {
	margin-top: var(--wkj-stack-lg);
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wkj-gutter);
}

@media (min-width: 768px) { .wkj-profile { grid-template-columns: repeat(3, 1fr); } }

.wkj-profile__card {
	background: var(--wkj-surface-container-low);
	border: 1px solid var(--wkj-outline-variant);
	padding: 32px;
}

.wkj-profile__title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 24px;
	color: var(--wkj-primary);
	margin: 0 0 var(--wkj-stack-md);
}

.wkj-profile__title .material-symbols-outlined { color: var(--wkj-secondary); }

/* Taste rating rows with dots. */
.wkj-taste { list-style: none; margin: 0; padding: 0; }

.wkj-taste li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid var(--wkj-outline-variant);
	padding-bottom: 8px;
	margin-bottom: 12px;
}

.wkj-taste__label {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.wkj-taste__dots { display: flex; gap: 4px; }

.wkj-taste__dot {
	width: 16px;
	height: 16px;
	border-radius: 999px;
	background: var(--wkj-outline-variant);
}

.wkj-taste__dot.is-on { background: var(--wkj-secondary); }

/* Origin / map. */
.wkj-origin__map {
	height: 128px;
	position: relative;
	overflow: hidden;
	background-color: var(--wkj-surface-variant);
	background-size: cover;
	background-position: center;
}

.wkj-origin__map-label {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.1);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wkj-on-surface-variant);
	text-align: center;
	padding: 8px;
}

.wkj-origin__text { margin-top: 12px; color: var(--wkj-on-surface-variant); font-size: 16px; line-height: 1.6; }

/* Food pairing tiles. */
.wkj-pairing-tiles { display: flex; flex-wrap: wrap; gap: 16px; }

.wkj-pairing-tile {
	flex: 1;
	min-width: 80px;
	background: var(--wkj-surface-card);
	padding: 16px;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 8px;
}

.wkj-pairing-tile .material-symbols-outlined { color: var(--wkj-primary); }

.wkj-pairing-tile span:last-child {
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.wkj-pairing__quote { margin-top: 16px; font-style: italic; color: var(--wkj-on-surface-variant); }

/* --- Aanbevolen (related products) ---------------------------------------- */
.woocommerce .related,
.woocommerce .upsells {
	margin-top: var(--wkj-stack-lg);
	width: 100%;
}

.woocommerce .related > h2,
.woocommerce .upsells > h2 {
	font-size: clamp(28px, 4vw, 32px);
	color: var(--wkj-primary);
	border-bottom: 1px solid var(--wkj-outline-variant);
	padding-bottom: 16px;
	margin-bottom: var(--wkj-stack-md);
}

.woocommerce .related ul.products,
.woocommerce .upsells ul.products {
	grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1024px) {
	.woocommerce .related ul.products,
	.woocommerce .upsells ul.products { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
	.woocommerce .related ul.products,
	.woocommerce .upsells ul.products { grid-template-columns: 1fr; }
}

/* Hover "Voeg toe" overlay on product card media */
.wkj-card__media { position: relative; }

.wkj-card__add {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	transform: translateY(100%);
	background: var(--wkj-primary);
	color: #fff;
	text-align: center;
	padding: 10px 8px;
	font-family: var(--wkj-font-body);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	transition: transform .35s cubic-bezier(0.165, 0.84, 0.44, 1);
	z-index: 2;
}

.wkj-card:hover .wkj-card__add,
.wkj-card__media:hover .wkj-card__add {
	transform: translateY(0);
}
