/* ==========================================================================
   PX Winkel Page — single-winkels.php template styles
   ========================================================================== */

/* ── Hero ────────────────────────────────────────────────── */

.px-winkel-page__hero {
	position: relative;
	min-height: 400px;
	display: flex;
	align-items: flex-end;
	background-color: var(--navy);
	overflow: hidden;
}

.px-winkel-page__hero-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.px-winkel-page__hero-overlay {
	position: relative;
	z-index: 1;
	width: 100%;
	padding: var(--space-d5) 0 var(--space-d3);
	background: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, transparent 100%);
}

.px-winkel-page__hero .px-winkel-page__container {
	display: flex;
	flex-direction: column;
	gap: var(--space-d1);
}

.px-winkel-page__hero .heading {
	color: var(--white);
}

.px-winkel-page__hero .open-now {
	color: var(--white);
	font-family: var(--font-display);
	font-weight: var(--weight-semibold);
	font-size: var(--text-d125);
}


/* ── Container ───────────────────────────────────────────── */

.px-winkel-page__container {
	max-width: var(--row-width);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--space-d2);
	padding-right: var(--space-d2);
}


/* ── Sections ────────────────────────────────────────────── */

.px-winkel-page__section {
	padding: var(--space-d5) 0;
}

.px-winkel-page__section:nth-child(even) {
	background-color: var(--white);
}

.px-winkel-page__section > .px-winkel-page__container > .heading {
	margin-bottom: var(--space-d2);
}


/* ── Actueel ─────────────────────────────────────────────── */

.px-winkel-page__actueel-content {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-d2);
}

.px-winkel-page__actueel-foto img {
	width: 100%;
	height: auto;
	border-radius: var(--radius-s);
}

@media (min-width: 768px) {
	.px-winkel-page__actueel-content {
		grid-template-columns: 1fr 2fr;
	}
}


/* ── Contact & Openingstijden ────────────────────────────── */

.px-winkel-page__contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-d3);
}

@media (min-width: 768px) {
	.px-winkel-page__contact-grid {
		grid-template-columns: 1fr 1fr;
	}
}

.px-winkel-page__contact-info .heading {
	margin-bottom: var(--space-d1);
}

.px-winkel-page__address {
	font-style: normal;
	display: flex;
	flex-direction: column;
	margin-bottom: var(--space-d1);
}

.px-winkel-page__phone,
.px-winkel-page__email {
	margin: var(--space-d05) 0;
}

.px-winkel-page__phone a,
.px-winkel-page__email a {
	color: var(--action);
	text-decoration: none;
}

.px-winkel-page__phone a:hover,
.px-winkel-page__email a:hover {
	text-decoration: underline;
}

.px-winkel-page__hours .heading {
	margin-bottom: var(--space-d1);
}

.px-winkel-page__hours-alert {
	background-color: var(--coral);
	color: var(--white);
	padding: var(--space-d05) var(--space-d1);
	border-radius: var(--radius-xs);
	font-family: var(--font-display);
	font-weight: var(--weight-semibold);
	margin-bottom: var(--space-d1);
}

.px-ot-dag {
	display: inline-block;
	min-width: 7em;
}

.px-winkel-page__hours-table {
	width: 100%;
	border-collapse: collapse;
}

.px-winkel-page__hours-table td {
	padding: var(--space-d05) 0;
	border-bottom: 1px solid var(--sand-light);
}

.px-winkel-page__hours-table tr:last-child td {
	border-bottom: none;
}

.px-winkel-page__hours-table td:first-child {
	font-weight: var(--weight-medium);
	width: 40%;
}


/* ── FAQ ─────────────────────────────────────────────────── */

.px-winkel-page__faq-items,
.px-winkel-page__vacatures-items {
	margin-top: var(--space-d1);
}


/* ── Goederen / Spullen brengen ──────────────────────────── */

.px-winkel-page__goederen-text {
	margin-bottom: var(--space-d2);
}

.px-winkel-page__goederen-ot,
.px-winkel-page__goederen-bezorgen {
	margin-bottom: var(--space-d1);
}

.px-winkel-page__goederen-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-d2);
	margin-top: var(--space-d2);
}

@media (min-width: 768px) {
	.px-winkel-page__goederen-grid {
		grid-template-columns: 1fr 1fr;
	}
}

.px-winkel-page__goederen-list .heading {
	margin-bottom: var(--space-d075);
}

.px-winkel-page__goederen-list ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.px-winkel-page__goederen-list li {
	padding: var(--space-d025) 0;
	padding-left: var(--space-d15);
	position: relative;
}

.px-winkel-page__goederen-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.6em;
	width: 0.55em;
	height: 0.55em;
	border-radius: var(--radius-full);
}

.px-winkel-page__goederen-list--wel li::before {
	background-color: var(--action);
}

.px-winkel-page__goederen-list--niet li::before {
	background-color: var(--coral);
}


/* ── Gallery ─────────────────────────────────────────────── */

.px-winkel-page__video {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: var(--radius-s);
	margin-bottom: var(--space-d2);
}

.px-winkel-page__video iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

.px-winkel-page__team-foto {
	margin-bottom: var(--space-d2);
}

.px-winkel-page__team-foto img {
	width: 100%;
	height: auto;
	border-radius: var(--radius-s);
}

.px-winkel-page__gallery-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-d1);
}

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

@media (min-width: 1200px) {
	.px-winkel-page__gallery-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.px-winkel-page__gallery-item {
	overflow: hidden;
	border-radius: var(--radius-xs);
	aspect-ratio: 1;
}

.px-winkel-page__gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--duration-normal) var(--ease-smooth);
}

.px-winkel-page__gallery-item:hover img {
	transform: scale(1.05);
}


/* ── Locatie / Map ───────────────────────────────────────── */

.px-winkel-page__map {
	border-radius: var(--radius-s);
	overflow: hidden;
}

.px-winkel-page__map iframe {
	display: block;
	width: 100%;
}


/* ── Social Media ────────────────────────────────────────── */

.px-winkel-page__social-links {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-d1);
	align-items: center;
}

.px-winkel-page__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: var(--radius-full);
	background-color: var(--navy);
	color: var(--white);
	transition: background-color var(--duration-normal) var(--ease-smooth);
	text-decoration: none;
}

.px-winkel-page__social-link:hover {
	background-color: var(--action);
}

.px-winkel-page__social-link svg {
	width: 1.25rem;
	height: 1.25rem;
	fill: currentColor;
}

.px-winkel-page__social-link img {
	width: 1.5rem;
	height: 1.5rem;
	object-fit: contain;
}


/* ── Winkel Links (shortcode) ───────────────────────────── */

.px-winkel-links {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-d05);
	padding-bottom: var(--space-d025);
}

/* Override .px-rich-text a:not(.px-menu-link) (0-2-1) met (0-2-1) + source order */
a.px-winkel-links__icon.btn--icon {
	text-decoration: none;
	color: var(--gray-dark);
	border-radius: var(--radius-full);
	padding: 0;
}

a.px-winkel-links__icon.btn--icon:hover {
	text-decoration: none;
	color: var(--gray-dark);
}

a.px-winkel-links__icon.btn--icon:active {
	padding: 0;
}

a.px-winkel-links__btn.btn--sec {
	text-decoration: none;
	color: var(--gray-dark);
	border-radius: var(--radius-s);
	display: inline-flex;
	align-items: center;
	gap: var(--space-d05);
}

a.px-winkel-links__btn.btn--sec:hover {
	text-decoration: none;
	color: var(--gray-dark);
}

a.px-winkel-links__btn.btn--sec:active {
	color: var(--gray-dark);
	padding: calc(var(--space-d075) - 3px) calc(var(--space-d1) - 3px);
}

@media (max-width: 767px) {
	a.px-winkel-links__icon.btn--icon {
		width: 2.75rem;
		height: 2.75rem;
	}

	a.px-winkel-links__icon.btn--icon svg {
		width: var(--space-d1);
		height: var(--space-d1);
	}
}


/* ── Partners ────────────────────────────────────────────── */

.px-winkel-page__partners-grid {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-d2);
	align-items: center;
}

.px-winkel-page__partner-logo img {
	max-height: 60px;
	width: auto;
}


/* ── Popup ────────────────────────────────────────────────── */

.px-winkel-page__popup {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-d2);
}

.px-winkel-page__popup[hidden] {
	display: none;
}

.px-winkel-page__popup-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
}

.px-winkel-page__popup-content {
	position: relative;
	background: var(--white);
	border-radius: var(--radius-m);
	padding: var(--space-d3);
	max-width: 600px;
	width: 100%;
	max-height: 80vh;
	overflow-y: auto;
}

.px-winkel-page__popup-close {
	position: absolute;
	top: var(--space-d075);
	right: var(--space-d075);
	background: none;
	border: none;
	font-size: 1.5rem;
	cursor: pointer;
	width: 2rem;
	height: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--gray-dark);
}


/* ── Mobile ──────────────────────────────────────────────── */

@media (max-width: 767px) {
	.px-winkel-page__hero {
		min-height: 280px;
	}

	.px-winkel-page__section {
		padding: var(--space-d3) 0;
	}

	.px-winkel-page__container {
		padding-left: var(--space-d1);
		padding-right: var(--space-d1);
	}
}
