/**
 * WooCommerce shop / categorie / product-zoek (?post_type=product)
 * Bon kopen — visueel gelijk; afhankelijk van page-kopen.css (+ base tokens).
 * Geen :has(); minimaal !important (alleen WC pseudo-clearfix).
 *
 * @package HelloElementorChild
 */

:root {
	--wjb-shop-content-max: 1005px;
}

main#content.wjb-shop-archive {
	width: 100%;
	max-width: none;
	box-sizing: border-box;
}

/* Zelfde max-breedte: hero · filter · grid (responsive = min(100%, var)) */
main#content.wjb-shop-archive .container,
main#content.wjb-shop-archive .winkel-layout.winkel-layout--wc {
	width: 100%;
	max-width: min(100%, var(--wjb-shop-content-max));
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

.winkel-layout.winkel-layout--wc .filter-sidebar.filter-sidebar--wc,
.winkel-layout.winkel-layout--wc .winkel-content.winkel-content--wc {
	min-width: 0;
}

.wjb-shop-archive .koop-hero__kop--wc {
	margin: 16px 0 12px;
}

.wjb-shop-breadcrumbs {
	margin-top: 12px;
	font-size: 13px;
	color: var(--subtekst);
}

.wjb-shop-breadcrumbs .woocommerce-breadcrumb {
	margin: 0;
	font-size: inherit;
	color: inherit;
}

.wjb-bc-sep {
	margin: 0 0.35em;
	opacity: 0.6;
}

.wjb-shop-breadcrumbs a {
	color: var(--blauw);
	text-decoration: underline;
	text-decoration-color: rgba(26, 46, 68, 0.25);
	text-underline-offset: 3px;
}

.wjb-shop-breadcrumbs a:hover {
	text-decoration-color: var(--goud);
}

.wjb-shop-toolbar-above-cards {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-bottom: 8px;
}

.wjb-shop-loop-meta {
	font-size: 14px;
	color: var(--subtekst);
}

.wjb-shop-loop-meta .woocommerce-result-count {
	font-size: 14px;
}

.filter-balk__wc-order-wrap {
	display: flex;
	align-items: center;
}

.filter-balk__wc-order-wrap .woocommerce-ordering {
	margin: 0;
}

.filter-balk__wc-order-wrap select.orderby {
	height: 44px;
	padding: 0 38px 0 18px;
	border-radius: var(--radius-pill);
	border: 1px solid var(--rand);
	background: var(--wit) url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3e%3cpath fill='%231A2E44' d='M6 8 0 2l1.4-1.4L6 5.2 10.6.6 12 2z'/%3e%3c/svg%3e") no-repeat right 16px center;
	font-size: 14px;
	color: var(--tekst);
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	font-family: var(--font-body);
	min-width: 200px;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.filter-balk__wc-order-wrap select.orderby:focus {
	outline: none;
	border-color: var(--blauw);
	box-shadow: 0 0 0 3px rgba(26, 46, 68, 0.08);
}

.filter-groep__lijst--links a.filter-pill {
	text-decoration: none;
}

/**
 * Loop: puur CSS Grid — overschrijf WC float-% zonder waar mogelijk !important.
 * body.woocommerce + main#content verhoogt specificiteit t.o.v. plugins/woocommerce.css
 */
body.woocommerce main#content.wjb-shop-archive ul.products,
body.woocommerce-page main#content.wjb-shop-archive ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 180px), 1fr));
	gap: 16px;
	width: 100%;
	list-style: none;
	margin: 0;
	padding: 0;
	clear: both;
	float: none;
	box-sizing: border-box;
}

/* WC gebruikt pseudo-clearfix op ul.products — uitschakelen i.v.m. grid */
body.woocommerce main#content.wjb-shop-archive ul.products::before,
body.woocommerce main#content.wjb-shop-archive ul.products::after {
	content: none !important;
	display: none !important;
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product {
	float: none;
	width: 100%;
	max-width: none;
	min-width: 0;
	clear: none;
	box-sizing: border-box;
	list-style: none;
	margin: 0;
	position: relative;
	background: var(--wit);
	border: 1px solid var(--rand);
	border-radius: var(--radius-md);
	transition:
		box-shadow 0.2s,
		transform 0.2s,
		border-color 0.2s;
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product.wjb-product-li--neutral,
body.woocommerce-page main#content.wjb-shop-archive ul.products li.product.wjb-product-li--neutral {
	transition:
		box-shadow 0.2s,
		border-color 0.2s;
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product:hover {
	box-shadow: var(--schaduw-md);
	transform: translateY(-3px);
	border-color: var(--goud);
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product:focus-within {
	box-shadow: 0 0 0 3px rgba(245, 200, 66, 0.35);
	border-color: var(--goud);
}

/* Geen bon_type: soberder kaart dan premium giftcard-variant */
body.woocommerce main#content.wjb-shop-archive ul.products li.product.wjb-product-li--neutral:hover,
body.woocommerce-page main#content.wjb-shop-archive ul.products li.product.wjb-product-li--neutral:hover {
	transform: none;
	box-shadow: var(--schaduw-sm);
	border-color: var(--rand);
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product.wjb-product-li--neutral:focus-within,
body.woocommerce-page main#content.wjb-shop-archive ul.products li.product.wjb-product-li--neutral:focus-within {
	box-shadow: 0 0 0 2px rgba(26, 46, 68, 0.1);
	border-color: var(--rand);
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product .woocommerce-loop-product__link {
	display: block;
	padding: 20px 16px;
	text-align: center;
	color: inherit;
}

main#content.wjb-shop-archive .woocommerce-loop-product__title {
	font-size: 14px;
	font-weight: 700;
	color: var(--blauw);
	margin: 0 0 8px;
	line-height: 1.3;
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product .price {
	display: block;
	font-size: 15px;
	font-weight: 700;
	color: var(--blauw);
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product .price del {
	opacity: 0.55;
	font-weight: 500;
	font-size: 13px;
	margin-right: 6px;
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product .price ins {
	text-decoration: none;
	color: var(--blauw);
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product img {
	max-height: 64px;
	width: auto;
	max-width: 100%;
	margin: 0 auto 12px;
	object-fit: contain;
}

body.woocommerce main#content.wjb-shop-archive ul.products li.product span.onsale {
	position: absolute;
	top: 10px;
	right: 10px;
	background: var(--blauw);
	color: var(--wit);
	font-size: 12px;
	font-weight: 700;
	padding: 3px 8px;
	border-radius: var(--radius-pill);
	letter-spacing: 0.02em;
	z-index: 1;
	line-height: 1.2;
	min-height: 0;
	min-width: 0;
	border: none;
	box-shadow: 0 2px 6px rgba(26, 46, 68, 0.18);
}

.winkel-leeg-tegel {
	padding: 24px 0 8px;
}

.wjb-shop-archive .woocommerce-info,
.wjb-shop-archive .woocommerce-message {
	border-radius: var(--radius-md);
}

.wjb-shop-archive nav.woocommerce-pagination {
	margin: 32px 0 0;
	text-align: center;
}

.wjb-shop-archive nav.woocommerce-pagination ul {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.wjb-shop-archive nav.woocommerce-pagination ul li {
	margin: 0;
}

.wjb-shop-archive nav.woocommerce-pagination a,
.wjb-shop-archive nav.woocommerce-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	min-height: 40px;
	padding: 0 12px;
	border-radius: var(--radius-pill);
	border: 1px solid var(--rand);
	background: var(--wit);
	color: var(--blauw);
	font-size: 14px;
	font-weight: 600;
}

.wjb-shop-archive nav.woocommerce-pagination a:hover {
	border-color: var(--blauw);
	box-shadow: var(--schaduw-sm);
}

.wjb-shop-archive nav.woocommerce-pagination span.current {
	background: var(--blauw);
	color: var(--wit);
	border-color: var(--blauw);
}

@media (max-width: 900px) {
	body.woocommerce main#content.wjb-shop-archive ul.products {
		grid-template-columns: repeat(auto-fill, minmax(min(100%, 150px), 1fr));
	}

	.filter-balk__wc-order-wrap select.orderby {
		width: 100%;
		min-width: 0;
	}
}
