/*
Theme Name:   Moishe Child
Theme URI:    https://moishepatisserie.nl
Description:  Child theme for Moi-she Patisserie, built on Twenty Twenty-Five.
Author:       Moi-she Patisserie
Template:     twentytwentyfive
Version:      1.0.0
Text Domain:  moishe-child
*/

/* ============================================================
   Header
   ============================================================ */

.moishe-header {
	z-index: 100;
	border-bottom: 1px solid transparent;
	transition: box-shadow 0.25s ease, border-color 0.25s ease;
}

.moishe-header.is-scrolled {
	box-shadow: 0 2px 12px rgb(164 14 38 / 0.1);
	border-bottom-color: var(--wp--preset--color--roze-achtergrond);
}

/* Nav links */
.moishe-header .wp-block-navigation-item__content {
	padding: 0.375rem 0.75rem;
	border-radius: 4px;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 0.9375rem;
	font-weight: 600;
	transition: background-color 0.15s ease, color 0.15s ease;
	text-decoration: none;
}

.moishe-header .wp-block-navigation-item__content:hover,
.moishe-header .wp-block-navigation-item__content:focus-visible {
	background-color: var(--wp--preset--color--roze-achtergrond);
	color: var(--wp--preset--color--bordeauxrood) !important;
	text-decoration: none;
	outline-offset: 0;
}

/* Hamburger + close button */
.moishe-header .wp-block-navigation__responsive-container-open,
.moishe-header .wp-block-navigation__responsive-container-close {
	color: var(--wp--preset--color--bordeauxrood);
	min-width: 44px;
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Mobile overlay */
.moishe-header .wp-block-navigation__responsive-container.is-menu-open {
	background-color: #ffffff;
	color: var(--wp--preset--color--bordeauxrood);
	padding: 1.5rem clamp(1rem, 4vw, 3rem);
}

.moishe-header .wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation-item__content {
	font-size: 1.125rem;
	padding: 0.625rem 0.75rem;
	min-height: 44px;
	display: flex;
	align-items: center;
}

/* WooCommerce mini-cart button */
.moishe-header .wc-block-mini-cart__button {
	color: var(--wp--preset--color--bordeauxrood);
	background: none;
	border: none;
	padding: 0.375rem;
	border-radius: 4px;
	transition: background-color 0.15s ease;
	cursor: pointer;
	min-width: 44px;
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.moishe-header .wc-block-mini-cart__button:hover {
	background-color: var(--wp--preset--color--roze-achtergrond);
}

/* ============================================================
   Footer
   ============================================================ */

/* Column headings */
.moishe-footer__col-heading {
	font-family: var(--wp--preset--font-family--karla) !important;
	font-size: 0.75rem !important;
}

/* All links in footer: light pink, no underline */
.moishe-footer a {
	color: var(--wp--preset--color--roze-achtergrond);
	text-decoration: none;
	transition: color 0.15s ease;
}

.moishe-footer a:hover,
.moishe-footer a:focus-visible {
	color: var(--wp--preset--color--pistache);
	text-decoration: none;
}

/* Footer nav: vertical, no pill hover from header styles */
.moishe-footer__nav .wp-block-navigation-item__content {
	padding: 0.625rem 0;
	border-radius: 0;
	font-size: 0.9375rem;
	font-weight: 400;
	color: var(--wp--preset--color--roze-achtergrond);
	transition: color 0.15s ease;
}

.moishe-footer__nav .wp-block-navigation-item__content:hover,
.moishe-footer__nav .wp-block-navigation-item__content:focus-visible {
	background-color: transparent;
	color: var(--wp--preset--color--pistache) !important;
}

/* Social icons */
.moishe-footer__social .wp-social-link {
	background-color: transparent !important;
	padding: 0.625rem;
	transition: opacity 0.15s ease;
}

.moishe-footer__social .wp-social-link:hover {
	opacity: 1;
}

.moishe-footer__social .wp-social-link svg {
	fill: var(--wp--preset--color--roze-achtergrond);
	transition: fill 0.15s ease;
}

.moishe-footer__social .wp-social-link:hover svg {
	fill: var(--wp--preset--color--pistache);
}

/* Instagram placeholder */
.moishe-footer__instagram-placeholder {
	border: 1px dashed rgba(255, 235, 233, 0.25);
	border-radius: 6px;
	opacity: 0.75;
}

/* Copyright strip */
.moishe-footer__copyright {
	border-top: 1px solid rgba(255, 235, 233, 0.15);
	opacity: 0.7;
}

/* ============================================================
   Archive: productcatalogus
   ============================================================ */

/* Banner: breadcrumbs kleur (zelfde fix als single-product) */
.moishe-archive-banner .wc-block-breadcrumbs,
.moishe-archive-banner .woocommerce-breadcrumb,
.moishe-archive-banner .wp-block-woocommerce-breadcrumbs {
	color: rgba(255, 235, 233, 0.75);
}

.moishe-archive-banner a,
.moishe-archive-banner .woocommerce-breadcrumb a,
.moishe-archive-banner .wc-block-breadcrumbs a {
	color: rgba(255, 235, 233, 0.75) !important;
	text-decoration: none;
}

.moishe-archive-banner a:hover,
.moishe-archive-banner .woocommerce-breadcrumb a:hover,
.moishe-archive-banner .wc-block-breadcrumbs a:hover {
	color: var(--wp--preset--color--roze-achtergrond) !important;
}

/* Werkbalk: zorgt voor bodem-scheidingslijn */
.moishe-archive-toolbar {
	border-bottom: 1px solid rgba(164, 14, 38, 0.12);
	padding-bottom: 1rem;
}

/* Sortering-dropdown */
.moishe-catalog-sorting select,
.wp-block-woocommerce-catalog-sorting select {
	border: 1px solid rgba(164, 14, 38, 0.25);
	border-radius: 4px;
	padding: 0.4375rem 2rem 0.4375rem 0.75rem;
	color: var(--wp--preset--color--bordeauxrood);
	font-family: var(--wp--preset--font-family--karla);
	font-size: 0.9375rem;
	background-color: #ffffff;
	cursor: pointer;
	min-height: 44px;
}

/* ── Archive layout: sidebar + productgrid naast elkaar ── */

/* Breek uit de 645px constrained-layout begrenzing van TT5 */
.moishe-archive-layout.wp-block-columns {
	max-width: none !important;
	width: 100%;
	display: flex !important;
	flex-wrap: nowrap !important;
	gap: 2.5rem !important;
	align-items: flex-start;
	box-sizing: border-box;
}

/* Sidebar: vaste breedte 260px */
.moishe-filter-sidebar.wp-block-column {
	flex: 0 0 260px !important;
	width: 260px;
	max-width: 260px;
	min-width: 0;
}

/* Sidebar sticky */
.moishe-filter-sidebar {
	position: sticky;
	top: calc(var(--wp-admin--admin-bar--height, 0px) + 80px);
	align-self: flex-start;
}

/* Productkolom: vult resterende breedte */
.moishe-archive-layout > .wp-block-column:not(.moishe-filter-sidebar) {
	flex: 1 1 0 !important;
	min-width: 0;
}

/* Product grid: 3 kolommen op desktop */
.moishe-product-grid .wc-block-product-template,
.moishe-product-grid .wp-block-post-template {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 1.5rem !important;
}

/* Filteren toggle knop — standaard verborgen op desktop */
.moishe-filter-toggle {
	display: none;
	align-items: center;
	gap: 0.5rem;
	padding: 0.625rem 1.25rem;
	background-color: #ffffff;
	color: var(--wp--preset--color--bordeauxrood);
	border: 1.5px solid var(--wp--preset--color--bordeauxrood);
	border-radius: 4px;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 0.9375rem;
	font-weight: 600;
	cursor: pointer;
	margin-bottom: 1rem;
	transition: background-color 0.15s ease, color 0.15s ease;
	min-height: 44px;
	width: 100%;
	justify-content: center;
}

.moishe-filter-toggle:hover,
.moishe-filter-toggle[aria-expanded="true"] {
	background-color: var(--wp--preset--color--bordeauxrood);
	color: #ffffff;
}

.moishe-filter-group {
	border-bottom: 1px solid rgba(164, 14, 38, 0.1);
	padding-bottom: 1.375rem;
	margin-bottom: 1.375rem;
}

.moishe-filter-group:last-child {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

/* Prijs-filter: WC slider kleuren */
.wp-block-woocommerce-price-filter .wc-block-price-filter__range-input-wrapper {
	--range-color: var(--wp--preset--color--bordeauxrood);
}

.wp-block-woocommerce-price-filter input[type="range"]::-webkit-slider-thumb,
.wp-block-woocommerce-price-filter input[type="range"]::-moz-range-thumb {
	background: var(--wp--preset--color--bordeauxrood);
}

.wp-block-woocommerce-price-filter .wc-block-price-filter__range-input-progress {
	background: var(--wp--preset--color--bordeauxrood);
}

.wp-block-woocommerce-price-filter .wc-block-components-price-slider__range-input-progress {
	--range-color: var(--wp--preset--color--bordeauxrood);
}

/* Actieve filters: chips-stijl */
.wp-block-woocommerce-active-filters .wc-block-active-filters__list-item-plain,
.wp-block-woocommerce-active-filters .wc-block-active-filters__clear-all {
	color: var(--wp--preset--color--bordeauxrood);
	font-size: 0.875rem;
}

.wp-block-woocommerce-active-filters .wc-block-active-filters__list-item-remove {
	color: var(--wp--preset--color--bordeauxrood);
}

/* Productkaart in archief */
.moishe-product-grid .moishe-product-card {
	height: 100%;
	display: flex;
	flex-direction: column;
}

.moishe-product-grid .moishe-product-card .wp-block-group:last-child {
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* Productafbeelding: geforceerde verhouding 4:3 */
.moishe-product-grid .wp-block-woocommerce-product-image,
.moishe-product-grid .wc-block-components-product-image {
	display: block;
	overflow: hidden;
}

.moishe-product-grid .wp-block-woocommerce-product-image img,
.moishe-product-grid .wc-block-components-product-image img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
	width: 100%;
	display: block;
	transition: transform 0.3s ease;
}

.moishe-product-grid .moishe-product-card:hover img {
	transform: scale(1.04);
}

/* WC product-button als outline (secundaire actie) */
.moishe-wc-btn-outline .wp-block-woocommerce-product-button a,
.moishe-wc-btn-outline a.button,
.moishe-wc-btn-outline .wc-block-components-product-button__button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	text-align: center;
	background: transparent !important;
	color: var(--wp--preset--color--bordeauxrood) !important;
	border: 1px solid var(--wp--preset--color--bordeauxrood) !important;
	border-radius: 4px;
	padding: 0.75rem 1rem;
	min-height: 44px;
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	transition: background-color 0.15s ease, color 0.15s ease;
	box-sizing: border-box;
}

.moishe-wc-btn-outline .wp-block-woocommerce-product-button a:hover,
.moishe-wc-btn-outline a.button:hover,
.moishe-wc-btn-outline .wc-block-components-product-button__button:hover {
	background-color: var(--wp--preset--color--bordeauxrood) !important;
	color: #ffffff !important;
}

/* Paginering */
.moishe-archive-pagination .wp-block-query-pagination-numbers a,
.moishe-archive-pagination .wp-block-query-pagination-numbers span,
.moishe-archive-pagination a.wp-block-query-pagination-next,
.moishe-archive-pagination a.wp-block-query-pagination-previous {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: 0.4375rem 0.75rem;
	border: 1px solid rgba(164, 14, 38, 0.25);
	border-radius: 4px;
	color: var(--wp--preset--color--bordeauxrood);
	font-weight: 600;
	font-size: 0.9375rem;
	text-decoration: none;
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.moishe-archive-pagination .wp-block-query-pagination-numbers a:hover,
.moishe-archive-pagination a.wp-block-query-pagination-next:hover,
.moishe-archive-pagination a.wp-block-query-pagination-previous:hover {
	background-color: var(--wp--preset--color--bordeauxrood);
	color: #ffffff;
	border-color: var(--wp--preset--color--bordeauxrood);
}

.moishe-archive-pagination .wp-block-query-pagination-numbers span.current {
	background-color: var(--wp--preset--color--bordeauxrood);
	color: #ffffff;
	border-color: var(--wp--preset--color--bordeauxrood);
}

/* Tablet (768–1023px): 2 productkolommen, zijbalk achter toggle */
@media (max-width: 1023px) {
	.moishe-filter-toggle {
		display: flex;
	}

	.moishe-archive-layout.wp-block-columns {
		flex-direction: column !important;
		flex-wrap: wrap !important;
	}

	.moishe-filter-sidebar.wp-block-column {
		flex: none !important;
		width: 100% !important;
		max-width: none;
		position: static;
		display: none; /* verborgen totdat toggle wordt geklikt */
		border-bottom: 1px solid rgba(164, 14, 38, 0.12);
		padding-bottom: 1.5rem;
		margin-bottom: 0.5rem;
	}

	.moishe-filter-sidebar.is-open {
		display: block;
	}

	.moishe-archive-layout > .wp-block-column:not(.moishe-filter-sidebar) {
		flex: none !important;
		width: 100%;
	}

	.moishe-product-grid .wc-block-product-template,
	.moishe-product-grid .wp-block-post-template {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

/* Mobiel (<600px): 1 productkolom */
@media (max-width: 599px) {
	.moishe-product-grid .wc-block-product-template,
	.moishe-product-grid .wp-block-post-template {
		grid-template-columns: 1fr !important;
	}
}

/* ============================================================
   Mobile: stack columns, reduce top padding
   ============================================================ */

/* Mobile: stack columns, reduce top padding */
@media (max-width: 599px) {
	.moishe-footer {
		padding-top: 2.5rem !important;
	}

	.moishe-footer .wp-block-columns {
		flex-direction: column;
	}

	.moishe-footer .wp-block-column {
		flex-basis: 100% !important;
	}
}

/* ============================================================
   Shared: image placeholders
   ============================================================ */

.moishe-img-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}

/* ============================================================
   Front page
   ============================================================ */

/* Hero: gradient overlay voor leesbaarheid ongeacht welke foto erachter staat */
.moishe-hero .wp-block-cover__background {
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0.35) 0%,
		rgba(0, 0, 0, 0.15) 50%,
		rgba(0, 0, 0, 0.45) 100%
	) !important;
}

/* Featured cakes: brede, gebalanceerde desktopgrid zonder mobiele layout te breken */
.moishe-featured-cakes {
	padding-block: clamp(3.5rem, 6vw, 6rem) !important;
}

.moishe-featured-cakes__inner {
	width: min(calc(100% - 2rem), 1180px);
	max-width: none !important;
	margin-inline: auto;
}

.moishe-featured-cakes__intro {
	max-width: 42rem;
	margin-inline: auto;
	margin-bottom: clamp(2rem, 4vw, 3rem) !important;
}

.moishe-featured-cakes__grid.wp-block-columns {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
	gap: clamp(1.25rem, 2.4vw, 2rem);
	align-items: stretch;
	width: 100%;
	max-width: none !important;
	margin-block: 0;
}

.moishe-featured-cakes__grid.wp-block-columns > .wp-block-column {
	flex-basis: auto !important;
	min-width: 0;
}

.moishe-featured-cakes__grid .moishe-product-card {
	height: 100%;
	display: flex;
	flex-direction: column;
}

.moishe-featured-cakes__grid .moishe-img-placeholder {
	aspect-ratio: 5 / 4;
	min-height: 0 !important;
	overflow: hidden;
}

.moishe-featured-cakes__grid .moishe-product-card > .wp-block-group:last-child {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.moishe-featured-cakes__grid .moishe-product-card .wp-block-buttons {
	margin-top: auto;
}

.moishe-featured-cakes__cta {
	margin-top: clamp(1.75rem, 3vw, 2.5rem) !important;
}

.moishe-featured-cakes__cta a {
	text-underline-offset: 0.2em;
	transition: color 0.15s ease, text-decoration-color 0.15s ease;
}

.moishe-featured-cakes__cta a:hover,
.moishe-featured-cakes__cta a:focus-visible {
	color: var(--wp--preset--color--donkere-chocolade) !important;
}

/* Product cards */
.moishe-product-card {
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.moishe-product-card:hover {
	box-shadow: 0 8px 28px rgb(61 31 36 / 0.14);
	transform: translateY(-3px);
}

/* Occasion section: gecentreerd binnen de pagina.
   De inner wrapper heeft is-layout-constrained, wat via de globale WP-CSS
   alle directe children beperkt tot 645px (contentSize). Die 645px-constraint
   op het grid zelf moet hier worden opgeheven; de padding van has-global-padding
   (1.5rem per kant) zorgt daarna voor de juiste horizontale marge. */
.moishe-occasion-section__inner {
	max-width: 1200px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.moishe-occasion-section__inner > .moishe-occasion-grid {
	max-width: none !important;
	width: 100%;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* Occasion cards: even hoog via flexbox */
.moishe-occasion-card {
	overflow: hidden;
	border-radius: 12px;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 2px 12px rgb(61 31 36 / 0.08);
	display: flex;
	flex-direction: column;
	height: 100%;
}

.moishe-occasion-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 24px rgb(61 31 36 / 0.14);
}

/* Image inside each occasion card: fills width, locked to 4:3 ratio */
.moishe-occasion-card .moishe-occasion-card__img {
	margin: 0 !important;
	display: block;
	width: 100%;
	flex-shrink: 0;
}

.moishe-occasion-card .moishe-occasion-card__img img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
	margin: 0;
}

/* Info bar: vult resterende ruimte zodat alle kaarten even hoog zijn */
.moishe-occasion-card > .wp-block-group:not(.moishe-occasion-card__img) {
	flex: 1;
	display: flex;
	flex-direction: column;
	margin-top: 0 !important;
}

/* "Bekijk taarten →" link naar de onderkant duwen */
.moishe-occasion-card > .wp-block-group:not(.moishe-occasion-card__img) > p:last-child {
	margin-top: auto !important;
}

/* Occasions: 4 cols on desktop, 2 cols on tablet/mobile */
@media (max-width: 767px) {
	.moishe-occasion-grid.wp-block-columns {
		flex-wrap: wrap;
	}

	.moishe-occasion-grid.wp-block-columns > .wp-block-column {
		flex-basis: calc(50% - 0.75rem) !important;
		max-width: calc(50% - 0.75rem);
	}
}

@media (max-width: 399px) {
	.moishe-occasion-grid.wp-block-columns > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}
}

/* ============================================================
   Single product page
   ============================================================ */

/* Breadcrumbs balk — fix link-zichtbaarheid op bordeauxrood achtergrond.
   WC rendert als .wc-block-breadcrumbs > nav.woocommerce-breadcrumb.
   Globale link-kleur (bordeauxrood op bordeauxrood = onzichtbaar) wordt
   overschreven met !important. */
.moishe-product-breadcrumbs .wc-block-breadcrumbs,
.moishe-product-breadcrumbs .woocommerce-breadcrumb,
.moishe-product-breadcrumbs .wp-block-woocommerce-breadcrumbs {
	color: rgba(255, 235, 233, 0.85);
}

.moishe-product-breadcrumbs a,
.moishe-product-breadcrumbs .woocommerce-breadcrumb a,
.moishe-product-breadcrumbs .wc-block-breadcrumbs a {
	color: rgba(255, 235, 233, 0.85) !important;
	text-decoration: none;
}

.moishe-product-breadcrumbs a:hover,
.moishe-product-breadcrumbs .woocommerce-breadcrumb a:hover,
.moishe-product-breadcrumbs .wc-block-breadcrumbs a:hover {
	color: #ffffff !important;
	text-decoration: underline;
}

/* Productkaart (witte container) — max 1200px gecentreerd.
   De outer wrapper heeft layout:default (was :constrained = 645px). */
.moishe-product-card-full {
	box-shadow: 0 4px 24px rgb(61 31 36 / 0.06);
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}

/* Productkolommen: mogen de volledige kaartbreedte gebruiken */
.moishe-product-layout.wp-block-columns {
	max-width: none !important;
	width: 100%;
}

/* Tabssectie: zelfde max-breedte als de productkaart */
.moishe-product-tabs-section {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

/* Galerij: hoofdafbeelding volledig breed, thumbnails als strip */
.moishe-product-gallery .woocommerce-product-gallery {
	width: 100%;
}

.moishe-product-gallery .woocommerce-product-gallery__image img,
.moishe-product-gallery .wc-block-components-product-image img {
	width: 100%;
	height: auto;
	border-radius: 8px;
	object-fit: cover;
	aspect-ratio: 4 / 3;
}

/* Thumbnails onder de hoofdafbeelding */
.moishe-product-gallery .flex-control-thumbs {
	display: flex;
	gap: 0.5rem;
	margin-top: 0.75rem;
	padding: 0;
	list-style: none;
}

.moishe-product-gallery .flex-control-thumbs li {
	flex: 0 0 auto;
	width: calc(25% - 0.375rem);
}

.moishe-product-gallery .flex-control-thumbs img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 4px;
	border: 2px solid transparent;
	cursor: pointer;
	transition: border-color 0.15s ease;
}

.moishe-product-gallery .flex-control-thumbs .flex-active img {
	border-color: var(--wp--preset--color--bordeauxrood);
}

/* Productdetails kolom: stick to top naast de galerij */
.moishe-product-details-col {
	display: flex;
	flex-direction: column;
}

/* Sterrenbeoordeling */
.moishe-product-details-col .wc-block-components-product-rating .wc-block-components-product-rating__stars,
.moishe-product-details-col .star-rating {
	color: var(--wp--preset--color--bordeauxrood);
}

/* Prijs: geen dubbele marge van WC */
.moishe-product-details-col .wp-block-woocommerce-product-price {
	line-height: 1;
}

/* PRIMAIRE CTA: hover naar donkere chocolade */
.moishe-configurator-cta .wp-block-button__link:hover,
.moishe-configurator-cta .wp-block-button__link:focus-visible {
	background-color: var(--wp--preset--color--donkere-chocolade) !important;
}

/* SECUNDAIRE CTA: add-to-cart als outline-knop */
.moishe-add-to-cart-outline form.cart {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.moishe-add-to-cart-outline .quantity {
	display: none; /* eenvoudige taarten: geen hoeveelheid op productpagina */
}

.moishe-add-to-cart-outline .single_add_to_cart_button,
.moishe-add-to-cart-outline .wc-block-components-product-button__button {
	display: block;
	width: 100%;
	text-align: center;
	background: transparent !important;
	color: var(--wp--preset--color--bordeauxrood) !important;
	border: 2px solid var(--wp--preset--color--bordeauxrood) !important;
	border-radius: 6px;
	padding: 0.75rem 1.5rem;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
	box-sizing: border-box;
	line-height: 1.4;
}

.moishe-add-to-cart-outline .single_add_to_cart_button:hover,
.moishe-add-to-cart-outline .wc-block-components-product-button__button:hover {
	background-color: var(--wp--preset--color--bordeauxrood) !important;
	color: #ffffff !important;
}

/* Afhalen/bezorging info-blok */
.moishe-product-logistics p strong {
	color: var(--wp--preset--color--bordeauxrood);
}

/* ---- Tab-navigatie ---- */
.moishe-product-tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid rgba(164, 14, 38, 0.15);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.moishe-product-tabs::-webkit-scrollbar {
	display: none;
}

.moishe-product-tabs__tab {
	flex: 0 0 auto;
	padding: 0.875rem 1.5rem;
	background: transparent;
	border: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 0.9375rem;
	font-weight: 600;
	color: #888078;
	cursor: pointer;
	transition: color 0.15s ease, border-color 0.15s ease;
	white-space: nowrap;
}

.moishe-product-tabs__tab:hover {
	color: var(--wp--preset--color--bordeauxrood);
}

.moishe-product-tabs__tab.is-active {
	color: var(--wp--preset--color--bordeauxrood);
	border-bottom-color: var(--wp--preset--color--bordeauxrood);
}

/* ---- Tab-panelen ---- */
.moishe-product-tab-panel {
	display: none;
}

.moishe-product-tab-panel.is-active {
	display: block;
}

/* Beschrijvings-inhoud */
.moishe-product-tab-panel .wp-block-woocommerce-product-description h2,
.moishe-product-tab-panel .wp-block-woocommerce-product-description h3 {
	color: var(--wp--preset--color--bordeauxrood);
}

/* Allergenen: WC product-attributentabel */
.moishe-product-allergens .woocommerce-product-attributes {
	width: 100%;
	border-collapse: collapse;
}

.moishe-product-allergens .woocommerce-product-attributes th,
.moishe-product-allergens .woocommerce-product-attributes td {
	padding: 0.625rem 1rem;
	border: 1px solid rgba(164, 14, 38, 0.1);
	font-size: 0.9375rem;
	vertical-align: top;
}

.moishe-product-allergens .woocommerce-product-attributes th {
	background-color: var(--wp--preset--color--roze-achtergrond);
	color: var(--wp--preset--color--bordeauxrood);
	font-weight: 600;
	width: 40%;
}

.moishe-product-allergens .woocommerce-product-attributes td {
	color: #3d1f24;
}

/* Reviews */
.moishe-product-tab-panel .wp-block-woocommerce-product-reviews .woocommerce-review__author {
	color: var(--wp--preset--color--bordeauxrood);
	font-weight: 600;
}

.moishe-product-tab-panel .wp-block-woocommerce-product-reviews .star-rating {
	color: var(--wp--preset--color--bordeauxrood);
}

/* ---- Soortgelijke taarten carousel ---- */
.moishe-related-carousel-wrapper {
	overflow: hidden;
}

.moishe-related-carousel .related.products > ul,
.moishe-related-carousel .woocommerce-products-grid {
	display: flex;
	gap: 1.5rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 1rem;
	scrollbar-width: thin;
	scrollbar-color: rgba(164, 14, 38, 0.25) transparent;
}

.moishe-related-carousel .related.products > ul > li,
.moishe-related-carousel .woocommerce-products-grid .product {
	flex: 0 0 calc(25% - 1.125rem);
	min-width: 220px;
	scroll-snap-align: start;
	background: #ffffff;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 2px 12px rgb(61 31 36 / 0.06);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.moishe-related-carousel .related.products > ul > li:hover,
.moishe-related-carousel .woocommerce-products-grid .product:hover {
	box-shadow: 0 8px 28px rgb(61 31 36 / 0.14);
	transform: translateY(-3px);
}

.moishe-related-carousel .related.products > ul > li img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
}

/* Mobiel: kolommen stapelen, galerij boven details */
@media (max-width: 767px) {
	.moishe-product-layout.wp-block-columns {
		flex-direction: column;
	}

	.moishe-product-layout.wp-block-columns > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}

	.moishe-product-tabs__tab {
		padding: 0.75rem 1rem;
		font-size: 1rem;
		min-height: 44px;
	}

	.moishe-related-carousel .related.products > ul > li,
	.moishe-related-carousel .woocommerce-products-grid .product {
		flex: 0 0 calc(50% - 0.75rem);
	}
}

@media (max-width: 479px) {
	.moishe-related-carousel .related.products > ul > li,
	.moishe-related-carousel .woocommerce-products-grid .product {
		flex: 0 0 75vw;
	}
}

/* ============================================================
   Over-pagina
   ============================================================ */

/* Hero: placeholder-overlay absolute zodat cover-blok correct werkt */
.moishe-over-hero__placeholder {
	position: absolute !important;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

/* Verhaal: foto-kolom */
.moishe-over-story__photo {
	width: 100%;
	aspect-ratio: 3 / 4;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Verhaal: tekst-kolom verticaal gecentreerd op desktop */
@media (min-width: 768px) {
	.moishe-over-story.wp-block-columns {
		align-items: center;
	}
}

/* ---- Tijdlijn ---- */
.moishe-timeline {
	max-width: 680px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.moishe-timeline__item {
	display: grid;
	grid-template-columns: 5rem 2.5rem 1fr;
	gap: 0 1.25rem;
	align-items: stretch;
	position: relative;
}

.moishe-timeline__year-wrap {
	display: flex;
	align-items: flex-start;
	padding-top: 0.125rem;
	justify-content: flex-end;
}

.moishe-timeline__year {
	font-family: var(--wp--preset--font-family--karla) !important;
	white-space: nowrap;
}

.moishe-timeline__dot-col {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.moishe-timeline__dot-col::before,
.moishe-timeline__dot-col::after {
	content: "";
	flex: 1;
	width: 2px;
	background-color: rgba(164, 14, 38, 0.2);
}

.moishe-timeline__item:first-child .moishe-timeline__dot-col::before {
	background: transparent;
}

.moishe-timeline__item--last .moishe-timeline__dot-col::after {
	background: transparent;
}

.moishe-timeline__dot {
	flex: 0 0 auto;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: 2px solid var(--wp--preset--color--bordeauxrood);
	background-color: var(--wp--preset--color--roze-achtergrond);
	margin-block: 0.375rem;
}

.moishe-timeline__dot--active {
	background-color: var(--wp--preset--color--bordeauxrood);
	box-shadow: 0 0 0 4px rgba(164, 14, 38, 0.15);
}

.moishe-timeline__content {
	padding-top: 0;
	padding-bottom: 2.25rem;
}

.moishe-timeline__item--last .moishe-timeline__content {
	padding-bottom: 0;
}

/* Mobiel: tijdlijn simpel verticaal, zonder jaar-kolom naast tekst */
@media (max-width: 599px) {
	.moishe-timeline__item {
		grid-template-columns: 2rem 1fr;
	}

	.moishe-timeline__year-wrap {
		display: none;
	}

	.moishe-timeline__year {
		display: block;
		margin-bottom: 0.375rem;
	}

	.moishe-timeline__content .moishe-timeline__year {
		display: block;
	}
}

/* ---- Waarden-raster ---- */
.moishe-values-grid.wp-block-columns {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
}

.moishe-values-grid.wp-block-columns > .wp-block-column {
	flex-basis: auto !important;
	min-width: 0;
}

.moishe-value-card__inner {
	height: 100%;
	border-top: 3px solid var(--wp--preset--color--bordeauxrood);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.moishe-value-card__inner:hover {
	box-shadow: 0 6px 20px rgb(164 14 38 / 0.1);
	transform: translateY(-2px);
}

.moishe-value-card__icon {
	display: flex;
	align-items: center;
	height: 40px;
}

.moishe-value-card__icon svg {
	flex: 0 0 auto;
}

@media (max-width: 899px) {
	.moishe-values-grid.wp-block-columns {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 479px) {
	.moishe-values-grid.wp-block-columns {
		grid-template-columns: 1fr;
	}
}

/* ---- CTA-blok: winkel-info ---- */
.moishe-over-cta__btn .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--donkere-chocolade) !important;
	color: #ffffff !important;
}

/* Google Maps placeholder */
.moishe-maps-placeholder {
	width: 100%;
	height: 100%;
	min-height: 320px;
	border-radius: 8px;
	background-color: rgba(255, 255, 255, 0.12);
	border: 1px dashed rgba(255, 235, 233, 0.35);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 1.5rem;
	box-sizing: border-box;
}

.moishe-maps-placeholder__label {
	color: rgba(255, 235, 233, 0.6);
	font-size: 0.875rem;
	text-align: center;
	line-height: 1.6;
	margin: 0;
}

.moishe-maps-placeholder__label small {
	display: block;
	margin-top: 0.5rem;
	font-size: 0.75rem;
	word-break: break-all;
	opacity: 0.7;
}

/* Over-pagina kolommen op mobiel stapelen */
@media (max-width: 767px) {
	.moishe-over-story.wp-block-columns,
	.moishe-over-cta__cols.wp-block-columns {
		flex-direction: column;
	}

	.moishe-over-story.wp-block-columns > .wp-block-column,
	.moishe-over-cta__cols.wp-block-columns > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}

	.moishe-maps-placeholder {
		min-height: 240px;
	}
}

/* ============================================================
   Contactpagina
   ============================================================ */

/* Breadcrumbs in banner */
.moishe-contact-banner .wp-block-woocommerce-breadcrumbs,
.moishe-contact-banner .wp-block-woocommerce-breadcrumbs a {
	color: rgba(255, 235, 233, 0.7);
}

/* Contactgegevens: icoon-rijen */
.moishe-contact-detail-row {
	gap: 0.875rem;
}

.moishe-contact-detail-row__icon {
	flex: 0 0 auto;
	width: 20px;
	margin-top: 0.2rem;
}

/* Openingstijden-tabel */
.moishe-openingstijden {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9375rem;
}

.moishe-openingstijden th,
.moishe-openingstijden td {
	padding: 0.5rem 0;
	text-align: left;
	color: #3d1f24;
	border-bottom: 1px solid rgba(164, 14, 38, 0.08);
}

.moishe-openingstijden th {
	font-weight: 600;
	width: 55%;
	padding-right: 1rem;
}

.moishe-openingstijden tr:last-child th,
.moishe-openingstijden tr:last-child td {
	border-bottom: none;
}

.moishe-openingstijden__highlight th,
.moishe-openingstijden__highlight td {
	color: var(--wp--preset--color--bordeauxrood);
	font-weight: 600;
}

/* Google Maps embed placeholder (contactpagina) */
.moishe-maps-embed-placeholder {
	width: 100%;
	min-height: 220px;
	border-radius: 8px;
	background-color: var(--wp--preset--color--roze-achtergrond);
	border: 1px dashed rgba(164, 14, 38, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1.5rem;
	box-sizing: border-box;
}

.moishe-maps-embed-placeholder__label {
	color: rgba(61, 31, 36, 0.45);
	font-size: 0.875rem;
	text-align: center;
	line-height: 1.6;
	margin: 0;
}

.moishe-maps-embed-placeholder__label small {
	display: block;
	margin-top: 0.375rem;
	font-size: 0.75rem;
	word-break: break-all;
}

/* Echte Maps-embed (na placeholder verwijderd) */
.moishe-maps-embed-placeholder iframe {
	width: 100%;
	height: 220px;
	border: none;
	border-radius: 8px;
	display: block;
}

/* ---- Contact Form 7 styling ---- */
.moishe-contact-form-card .wpcf7 {
	font-family: var(--wp--preset--font-family--karla);
}

.moishe-contact-form-card .wpcf7 p {
	margin-top: 0;
	margin-bottom: 1.125rem;
}

.moishe-contact-form-card .wpcf7 label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--wp--preset--color--bordeauxrood);
	margin-bottom: 0.4rem;
}

.moishe-contact-form-card .wpcf7 abbr[title] {
	text-decoration: none;
	color: var(--wp--preset--color--bordeauxrood);
}

.moishe-contact-form-card .wpcf7-form-control:not(.wpcf7-submit) {
	display: block;
	width: 100%;
	padding: 0.6875rem 0.875rem;
	border: 1.5px solid rgba(164, 14, 38, 0.25);
	border-radius: 6px;
	background-color: #ffffff;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 1rem;
	color: #3d1f24;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}

.moishe-contact-form-card .wpcf7-form-control:not(.wpcf7-submit):focus {
	outline: none;
	border-color: var(--wp--preset--color--bordeauxrood);
	box-shadow: 0 0 0 3px rgba(164, 14, 38, 0.12);
}

.moishe-contact-form-card .wpcf7-form-control:not(.wpcf7-submit)::placeholder {
	color: rgba(61, 31, 36, 0.4);
}

.moishe-contact-form-card .wpcf7 textarea.wpcf7-form-control {
	resize: vertical;
	min-height: 130px;
}

/* Validatiefouten inline */
.moishe-contact-form-card .wpcf7-not-valid {
	border-color: #c0392b !important;
}

.moishe-contact-form-card .wpcf7-not-valid-tip {
	display: block;
	font-size: 0.8125rem;
	color: #c0392b;
	margin-top: 0.3rem;
}

/* Submit-knop */
.moishe-contact-form-card .moishe-cf7-submit {
	margin-bottom: 0 !important;
}

.moishe-contact-form-card .wpcf7-submit {
	display: inline-block;
	padding: 0.875rem 2.25rem;
	background-color: var(--wp--preset--color--bordeauxrood) !important;
	color: #ffffff !important;
	border: none;
	border-radius: 6px;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.15s ease;
	width: 100%;
}

.moishe-contact-form-card .wpcf7-submit:hover {
	background-color: var(--wp--preset--color--donkere-chocolade) !important;
}

/* Status-berichten */
.moishe-contact-form-card .wpcf7-response-output {
	margin: 1rem 0 0;
	padding: 0.875rem 1rem;
	border-radius: 6px;
	font-size: 0.9375rem;
	border: none !important;
}

.moishe-contact-form-card .wpcf7-mail-sent-ok {
	background-color: rgba(138, 157, 124, 0.15);
	color: #3a5c30;
}

.moishe-contact-form-card .wpcf7-mail-sent-ng,
.moishe-contact-form-card .wpcf7-aborted,
.moishe-contact-form-card .wpcf7-spam-blocked {
	background-color: rgba(192, 57, 43, 0.1);
	color: #c0392b;
}

.moishe-contact-form-card .wpcf7-validation-errors {
	background-color: rgba(164, 14, 38, 0.07);
	color: var(--wp--preset--color--bordeauxrood);
}

/* ---- FAQ accordeon (wp:details) ---- */
.moishe-faq .moishe-faq__item {
	border: 1px solid rgba(164, 14, 38, 0.1) !important;
	margin-bottom: 0.75rem;
}

.moishe-faq .moishe-faq__item summary {
	padding: 1.125rem 1.375rem;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 1rem;
	font-weight: 600;
	color: var(--wp--preset--color--bordeauxrood);
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: color 0.15s ease;
}

.moishe-faq .moishe-faq__item summary::-webkit-details-marker {
	display: none;
}

/* Chevron-icoon via CSS */
.moishe-faq .moishe-faq__item summary::after {
	content: "";
	flex: 0 0 auto;
	width: 0.625rem;
	height: 0.625rem;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	transition: transform 0.2s ease;
	margin-left: 1rem;
}

.moishe-faq .moishe-faq__item[open] summary::after {
	transform: rotate(-135deg);
}

.moishe-faq .moishe-faq__item[open] summary {
	border-bottom: 1px solid rgba(164, 14, 38, 0.1);
}

.moishe-faq .moishe-faq__item > *:not(summary) {
	padding: 1.125rem 1.375rem;
}

/* Mobiel: kolommen stapelen */
@media (max-width: 767px) {
	.moishe-contact-layout.wp-block-columns {
		flex-direction: column;
	}

	.moishe-contact-layout.wp-block-columns > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}

	.moishe-contact-form-card {
		padding: 1.75rem !important;
	}
}

/* ============================================================
   Zakelijk-pagina
   ============================================================ */

/* Hero: placeholder absoluut positioneren */
.moishe-zakelijk-hero__placeholder {
	position: absolute !important;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

/* Outline-knop in de hero (wit op donkere achtergrond) */
.moishe-hero-btn-outline .wp-block-button__link {
	background: transparent !important;
}

.moishe-hero-btn-outline .wp-block-button__link:hover {
	background: rgba(255, 235, 233, 0.15) !important;
	border-color: rgba(255, 235, 233, 0.9) !important;
}

/* ---- Service-kaarten ---- */
.moishe-zakelijk-services.wp-block-columns {
	align-items: stretch;
}

.moishe-zakelijk-services .wp-block-column {
	display: flex;
	flex-direction: column;
}

.moishe-service-card__inner {
	flex: 1;
	border-top: 3px solid var(--wp--preset--color--bordeauxrood);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.moishe-service-card__inner:hover {
	box-shadow: 0 8px 28px rgb(164 14 38 / 0.11);
	transform: translateY(-3px);
}

.moishe-service-card__icon {
	display: flex;
	align-items: center;
	height: 52px;
}

.moishe-service-card__features {
	margin: 0;
	padding-left: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.moishe-service-card__features li {
	font-size: 0.875rem;
	color: #3d1f24;
	padding-left: 1.25rem;
	position: relative;
	line-height: 1.45;
}

.moishe-service-card__features li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: var(--wp--preset--color--pistache);
}

/* ---- Logo-strook ---- */
.moishe-logo-strip {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1.5rem 2.5rem;
}

.moishe-logo-strip__item {
	flex: 0 0 auto;
}

.moishe-logo-placeholder {
	width: 140px;
	height: 56px;
	border-radius: 6px;
	background-color: rgba(164, 14, 38, 0.07);
	border: 1px dashed rgba(164, 14, 38, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(61, 31, 36, 0.35);
	font-size: 0.8125rem;
	font-weight: 600;
	font-family: var(--wp--preset--font-family--karla);
	letter-spacing: 0.05em;
	transition: opacity 0.2s ease;
}

/* Na placeholder verwijderd: echte logo's */
.moishe-logo-strip__item img {
	width: 140px;
	height: 56px;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.55;
	transition: opacity 0.2s ease, filter 0.2s ease;
}

.moishe-logo-strip__item img:hover {
	opacity: 1;
	filter: grayscale(0%);
}

/* ---- Case-kaarten ---- */
.moishe-cases-grid.wp-block-columns {
	align-items: stretch;
}

.moishe-case-card {
	display: flex;
	flex-direction: column;
}

.moishe-case-card__inner {
	flex: 1;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.moishe-case-card__inner:hover {
	box-shadow: 0 8px 28px rgb(61 31 36 / 0.12);
	transform: translateY(-3px);
}

.moishe-case-card__img {
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.moishe-case-card__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.moishe-case-card__inner:hover .moishe-case-card__img img {
	transform: scale(1.04);
}

.moishe-case-card__tag {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	background-color: var(--wp--preset--color--roze-achtergrond);
	color: var(--wp--preset--color--bordeauxrood);
	border-radius: 20px;
	font-size: 0.75rem;
	font-weight: 600;
	font-family: var(--wp--preset--font-family--karla);
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

/* ---- Offerte-formulier (CF7 B2B) ---- */
.moishe-offerte-card .wpcf7 {
	font-family: var(--wp--preset--font-family--karla);
}

/* Tweekoloms grid voor de formuliervelden */
.moishe-offerte-card .moishe-cf7-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 1.5rem;
}

.moishe-offerte-card .moishe-cf7-grid p {
	margin-top: 0;
	margin-bottom: 1.125rem;
}

.moishe-offerte-card .moishe-cf7-full {
	margin-top: 0;
	margin-bottom: 1.125rem;
}

.moishe-offerte-card .wpcf7 label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--wp--preset--color--bordeauxrood);
	margin-bottom: 0.4rem;
}

.moishe-offerte-card .wpcf7 abbr[title] {
	text-decoration: none;
}

.moishe-offerte-card .wpcf7-form-control:not(.wpcf7-submit) {
	display: block;
	width: 100%;
	padding: 0.6875rem 0.875rem;
	border: 1.5px solid rgba(164, 14, 38, 0.22);
	border-radius: 6px;
	background-color: #ffffff;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 1rem;
	color: #3d1f24;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}

/* select: pijl */
.moishe-offerte-card .wpcf7-select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a40e26' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.875rem center;
	padding-right: 2.5rem !important;
	cursor: pointer;
}

.moishe-offerte-card .wpcf7-form-control:not(.wpcf7-submit):focus {
	outline: none;
	border-color: var(--wp--preset--color--bordeauxrood);
	box-shadow: 0 0 0 3px rgba(164, 14, 38, 0.12);
}

.moishe-offerte-card .wpcf7-form-control:not(.wpcf7-submit)::placeholder {
	color: rgba(61, 31, 36, 0.38);
}

.moishe-offerte-card .wpcf7 textarea.wpcf7-form-control {
	resize: vertical;
	min-height: 110px;
}

/* date-input: verberg de spin-buttons */
.moishe-offerte-card input[type="date"]::-webkit-calendar-picker-indicator {
	opacity: 0.5;
	cursor: pointer;
}

.moishe-offerte-card .wpcf7-not-valid {
	border-color: #c0392b !important;
}

.moishe-offerte-card .wpcf7-not-valid-tip {
	display: block;
	font-size: 0.8125rem;
	color: #c0392b;
	margin-top: 0.3rem;
}

/* Submit */
.moishe-offerte-card .moishe-cf7-submit {
	margin-top: 0.5rem;
	margin-bottom: 0 !important;
}

.moishe-offerte-card .wpcf7-submit {
	display: inline-block;
	padding: 0.9375rem 2.5rem;
	background-color: var(--wp--preset--color--bordeauxrood) !important;
	color: #ffffff !important;
	border: none;
	border-radius: 6px;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 1.0625rem;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.15s ease;
	width: 100%;
}

.moishe-offerte-card .wpcf7-submit:hover {
	background-color: var(--wp--preset--color--donkere-chocolade) !important;
}

/* Status-berichten */
.moishe-offerte-card .wpcf7-response-output {
	margin: 1rem 0 0;
	padding: 0.875rem 1rem;
	border-radius: 6px;
	font-size: 0.9375rem;
	border: none !important;
}

.moishe-offerte-card .wpcf7-mail-sent-ok {
	background-color: rgba(138, 157, 124, 0.2);
	color: #3a5c30;
}

.moishe-offerte-card .wpcf7-mail-sent-ng,
.moishe-offerte-card .wpcf7-aborted,
.moishe-offerte-card .wpcf7-spam-blocked {
	background-color: rgba(192, 57, 43, 0.1);
	color: #c0392b;
}

.moishe-offerte-card .wpcf7-validation-errors {
	background-color: rgba(164, 14, 38, 0.07);
	color: var(--wp--preset--color--bordeauxrood);
}

/* Mobiel: alles op één kolom */
@media (max-width: 899px) {
	.moishe-cases-grid.wp-block-columns {
		flex-wrap: wrap;
	}

	.moishe-cases-grid.wp-block-columns > .wp-block-column {
		flex-basis: calc(50% - 1rem) !important;
		max-width: calc(50% - 1rem);
	}
}

@media (max-width: 767px) {
	.moishe-zakelijk-services.wp-block-columns,
	.moishe-cases-grid.wp-block-columns {
		flex-direction: column;
	}

	.moishe-zakelijk-services.wp-block-columns > .wp-block-column,
	.moishe-cases-grid.wp-block-columns > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}

	.moishe-offerte-card .moishe-cf7-grid {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   Taart-op-maat landingspagina
   ============================================================ */

/* Hero placeholder */
.moishe-tom-hero__placeholder {
	position: absolute !important;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

/* Hero CTA: pulse-animatie om aandacht te trekken */
@media (prefers-reduced-motion: no-preference) {
	.moishe-tom-cta-btn .wp-block-button__link {
		animation: moishe-pulse 3s ease-in-out 1.5s 3;
	}
}

@keyframes moishe-pulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(164, 14, 38, 0); }
	50%       { box-shadow: 0 0 0 10px rgba(164, 14, 38, 0); }
}

/* ---- Hoe werkt het: stappen ---- */
.moishe-steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	position: relative;
	max-width: 960px;
	margin-inline: auto;
}

/* Verbindingslijn achter de stap-bubbels */
.moishe-steps__connector {
	position: absolute;
	top: 44px; /* verticaal midden van de bubbel */
	left: calc(12.5% + 28px);
	right: calc(12.5% + 28px);
	height: 2px;
	background: linear-gradient(
		to right,
		var(--wp--preset--color--bordeauxrood) 0%,
		rgba(164, 14, 38, 0.2) 100%
	);
	z-index: 0;
}

.moishe-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 0 1rem;
	position: relative;
	z-index: 1;
}

/* Bubbel: bordeauxrood cirkel met stap-icoon */
.moishe-step__bubble {
	width: 88px;
	height: 88px;
	border-radius: 50%;
	background-color: var(--wp--preset--color--bordeauxrood);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	flex-shrink: 0;
	box-shadow: 0 4px 18px rgba(164, 14, 38, 0.3);
	margin-bottom: 1.375rem;
}

.moishe-step__num {
	position: absolute;
	top: -10px;
	right: -8px;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background-color: #ffffff;
	color: var(--wp--preset--color--bordeauxrood);
	font-size: 0.75rem;
	font-weight: 700;
	font-family: var(--wp--preset--font-family--karla);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid var(--wp--preset--color--roze-achtergrond);
	line-height: 1;
}

.moishe-step__icon {
	display: block;
}

.moishe-step__title {
	font-family: var(--wp--preset--font-family--gilda-display);
	font-size: 1.125rem;
	font-weight: 400;
	color: var(--wp--preset--color--bordeauxrood);
	margin: 0 0 0.625rem;
}

.moishe-step__desc {
	font-size: 0.9375rem;
	color: #3d1f24;
	line-height: 1.65;
	margin: 0;
	max-width: 200px;
}

/* Tablet: 2×2 grid */
@media (max-width: 767px) {
	.moishe-steps {
		grid-template-columns: repeat(2, 1fr);
		gap: 2.5rem 1rem;
	}

	.moishe-steps__connector {
		display: none;
	}
}

/* Mobiel: 1 kolom */
@media (max-width: 479px) {
	.moishe-steps {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.moishe-step {
		flex-direction: row;
		text-align: left;
		align-items: flex-start;
		gap: 1.25rem;
	}

	.moishe-step__bubble {
		margin-bottom: 0;
		flex-shrink: 0;
	}

	.moishe-step__desc {
		max-width: none;
	}
}

/* ---- Inspiratie-galerij: CSS masonry ---- */
.moishe-masonry {
	columns: 4;
	column-gap: 0.875rem;
}

.moishe-masonry__item {
	break-inside: avoid;
	margin-bottom: 0.875rem;
	position: relative;
	border-radius: 8px;
	overflow: hidden;
	display: block;
	cursor: pointer;
}

.moishe-masonry__bg {
	width: 100%;
	height: 100%;
	position: absolute;
	inset: 0;
}

/* Aspect-ratio per item via inline stijl; wrapper geeft de hoogte */
.moishe-masonry__item::before {
	content: "";
	display: block;
}

/* aspect-ratio werkt direct op het element — moderne browsers */

/* Hover-overlay */
.moishe-masonry__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(61, 31, 36, 0.82) 0%, transparent 55%);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 1rem;
	opacity: 0;
	transition: opacity 0.25s ease;
}

.moishe-masonry__item:hover .moishe-masonry__overlay,
.moishe-masonry__item:focus-within .moishe-masonry__overlay {
	opacity: 1;
}

.moishe-masonry__tag {
	display: inline-block;
	color: #ffffff;
	font-family: var(--wp--preset--font-family--karla);
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 1.3;
}

.moishe-masonry__sublabel {
	display: block;
	color: rgba(255, 235, 233, 0.55);
	font-family: var(--wp--preset--font-family--karla);
	font-size: 0.75rem;
	margin-top: 0.25rem;
}

@media (max-width: 1023px) {
	.moishe-masonry {
		columns: 3;
	}
}

@media (max-width: 699px) {
	.moishe-masonry {
		columns: 2;
	}
}

@media (max-width: 399px) {
	.moishe-masonry {
		columns: 1;
	}
}

/* FAQ op roze achtergrond (taart-op-maat specifiek) */
.moishe-tom-faq .moishe-faq__item {
	border: 1px solid rgba(164, 14, 38, 0.1) !important;
}

/* CTA-banner: banner-knop hover */
.moishe-tom-banner__btn .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--roze-achtergrond) !important;
	color: var(--wp--preset--color--bordeauxrood) !important;
}

.moishe-tom-banner__btn-sec .wp-block-button__link:hover {
	background-color: rgba(255, 235, 233, 0.12) !important;
}

/* Instagram squares: maintain aspect-ratio */
.moishe-insta-square {
	aspect-ratio: 1 / 1;
	min-height: unset !important;
}

/* Instagram row: on mobile hide second row to keep layout clean */
@media (max-width: 599px) {
	.moishe-insta-row .wp-block-column:nth-child(n+3) {
		display: none;
	}
}

/* ── Site logo — header ── */
.moishe-header .wp-block-site-logo a {
	display: block;
	line-height: 0;
}
.moishe-header .wp-block-site-logo img {
	height: auto;
	max-height: 82px;
	width: auto !important;
	/* The FullLogo PNG has transparent padding; negative margin trims it */
	margin: -14px -10px;
}

/* ── Logo — footer (invert to white on dark background) ── */
.moishe-footer-logo {
	margin-top: 0;
}
.moishe-footer-logo img {
	filter: brightness(0) invert(1);
	opacity: 0.92;
	display: block;
}
.moishe-footer-logo a {
	display: inline-block;
	line-height: 0;
}

/* ================================================================
   DESKTOP LAYOUT ENHANCEMENTS  (min-width breakpoints)
   Progressive enhancement above mobile.
   Goal: 3–4 column grids on desktop; cards never < 200 px wide;
   more breathing room at 1280 px+.
   ================================================================ */

/* ── 1. Min-width guard on all card/column elements ── */
/* (featured-cakes uses display:grid with minmax(18rem,1fr) — no guard needed) */
.moishe-occasion-grid > .wp-block-column,
.moishe-zakelijk-services > .wp-block-column,
.moishe-cases-grid > .wp-block-column {
	min-width: 200px;
}

.moishe-value-card {
	min-width: 180px;
}

.moishe-review-card {
	min-width: 200px;
}

/* ── 2. Occasion grid: 2-col op tablet, 4-col op desktop ──
   Kolommen even hoog (align-items: stretch) zodat kaarten stretchen. */
.moishe-occasion-grid.wp-block-columns {
	align-items: stretch !important;
}

.moishe-occasion-grid > .wp-block-column {
	display: flex;
	flex-direction: column;
}

@media (min-width: 768px) and (max-width: 1023px) {
	.moishe-occasion-grid.wp-block-columns {
		flex-wrap: wrap;
	}
	.moishe-occasion-grid > .wp-block-column {
		flex-basis: calc(50% - 0.75rem) !important;
		max-width: calc(50% - 0.75rem);
	}
}

@media (min-width: 1024px) {
	.moishe-occasion-grid.wp-block-columns {
		flex-wrap: nowrap;
	}
	.moishe-occasion-grid > .wp-block-column {
		flex-basis: 0 !important;
		flex-grow: 1;
	}
}

/* ── 3. Archive layout: handled in the archive section above ── */

/* ── 4. Single product: stack gallery above details on tablet ── */
@media (max-width: 899px) {
	.moishe-product-layout.wp-block-columns {
		flex-wrap: wrap;
	}
	.moishe-product-layout > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}
}

/* ── 5. Contact layout: stack info col above form on tablet ── */
@media (max-width: 899px) {
	.moishe-contact-layout.wp-block-columns {
		flex-wrap: wrap;
	}
	.moishe-contact-layout > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}
}

/* ── 6. /over CTA layout: stack on tablet ── */
@media (max-width: 899px) {
	.moishe-over-cta__cols.wp-block-columns {
		flex-wrap: wrap;
	}
	.moishe-over-cta__cols > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100%;
	}
}

/* ── 7. Review grid: 2-col on tablet (prevents overflow) ── */
@media (min-width: 540px) and (max-width: 767px) {
	.moishe-review-grid.wp-block-columns,
	/* reviews section uses generic wp-block-columns without extra class */
	.moishe-single-product .wp-block-columns:not([class*="moishe-product"]) {
		flex-wrap: wrap;
	}
}

/* ── 8. Section vertical padding: more breathing room on wide screens ── */
@media (min-width: 1280px) {
	.moishe-featured-cakes {
		padding-top: 6.5rem !important;
		padding-bottom: 6.5rem !important;
	}
	.moishe-occasion-section {
		padding-top: 6.5rem !important;
		padding-bottom: 6.5rem !important;
	}
	.moishe-zakelijk-cases {
		padding-top: 6.5rem !important;
		padding-bottom: 6.5rem !important;
	}
	.moishe-over-timeline-section {
		padding-top: 6.5rem !important;
		padding-bottom: 7rem !important;
	}
	.moishe-over-cta {
		padding-top: 6.5rem !important;
		padding-bottom: 7rem !important;
	}
	.moishe-related-section {
		padding-top: 5.5rem !important;
		padding-bottom: 6.5rem !important;
	}
	.moishe-contact-faq {
		padding-top: 6rem !important;
		padding-bottom: 6.5rem !important;
	}
	.moishe-contact-banner {
		padding-top: 5rem !important;
		padding-bottom: 5rem !important;
	}
}

/* Even more at 1440 px+ */
@media (min-width: 1440px) {
	.moishe-featured-cakes,
	.moishe-occasion-section,
	.moishe-zakelijk-cases {
		padding-top: 7.5rem !important;
		padding-bottom: 7.5rem !important;
	}
	.moishe-over-timeline-section,
	.moishe-over-cta {
		padding-top: 7.5rem !important;
		padding-bottom: 8rem !important;
	}
}

/* ── 9. Product archive grid + sidebar: handled in archive section above ── */

/* min-width guard on WC product cards in the archive */
.moishe-product-grid .moishe-product-card {
	min-width: 0;
}

/* ── 11. Product cards: equal-height images at desktop ── */
@media (min-width: 1024px) {
	.moishe-product-card .moishe-img-placeholder {
		min-height: 260px;
	}
}
