/*
 * WooCommerce Shop Archive — OurChapter v2
 * Mobile-first. Depends on: main-v2.css (tokens, base, nav, footer).
 *
 * Sections:
 *  1. Shop header (midnight hero strip)
 *  2. Ordering bar (result count + sort select)
 *  3. Product grid
 *  4. Product card
 *  5. Card poster frame
 *  6. Card body (title, price, CTA)
 *  7. Pagination
 *  8. Empty state
 *  9. Responsive breakpoints
 */

/* ============================================================
   1. SHOP HEADER
   ============================================================ */
.pg-shop-header {
	background: var(--pg-paper);
	padding: clamp(100px, 14vw, 140px) 0 clamp(48px, 6vw, 72px);
	position: relative;
	overflow: hidden;
}

.pg-shop-header::before {
	content: '';
	position: absolute;
	inset: 0;
	background: none;
	pointer-events: none;
}

.pg-shop-header__inner {
	position: relative;
	z-index: 1;
}

.pg-shop-header__inner .pg-eyebrow {
	color: var(--pg-brass-text);
	margin-bottom: 14px;
}

.pg-shop-header__title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(36px, 7vw, 64px);
	line-height: 1.03;
	letter-spacing: -.01em;
	color: var(--pg-ink);
	margin: 0 0 14px;
	text-wrap: balance;
}

.pg-shop-header__count {
	font-size: 14px;
	color: var(--pg-warm-grey-text);
	letter-spacing: .04em;
	margin: 0;
}

/* ============================================================
   2. ORDERING BAR
   ============================================================ */
.pg-shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	padding-bottom: var(--space-6, 32px);
	border-bottom: 1px solid rgba(27,26,23,.08);
	margin-bottom: var(--space-6, 32px);
}

/* WC result count */
.pg-shop-toolbar .woocommerce-result-count {
	font-size: 13.5px;
	color: #7A7268;
	margin: 0;
	letter-spacing: .02em;
}

/* WC ordering form + select */
.pg-shop-toolbar .woocommerce-ordering {
	margin: 0;
}

.pg-shop-toolbar .woocommerce-ordering select,
.pg-shop-toolbar select.orderby {
	-webkit-appearance: none;
	appearance: none;
	background-color: var(--pg-card);
	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='%238C8478' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 13px center;
	border: 1.5px solid rgba(27,26,23,.18);
	border-radius: var(--radius-sm, 8px);
	color: var(--pg-ink);
	cursor: pointer;
	font-family: var(--font-body);
	font-size: 14px;
	font-weight: 600;
	outline: none;
	padding: 10px 36px 10px 13px;
	transition: border-color .2s ease, box-shadow .2s ease;
}

.pg-shop-toolbar .woocommerce-ordering select:focus,
.pg-shop-toolbar select.orderby:focus {
	border-color: var(--pg-brass);
	box-shadow: 0 0 0 3px rgba(182,137,63,.15);
}

@media (prefers-reduced-motion: reduce) {
	.pg-shop-toolbar .woocommerce-ordering select,
	.pg-shop-toolbar select.orderby {
		transition: none;
	}
}

/* ============================================================
   3. PRODUCT GRID
   ============================================================ */
.pg-shop-main {
	padding-block: clamp(48px, 6vw, 80px);
}

/* Override WooCommerce's default ul.products layout.
   woocommerce-layout.css sets float + width% on li.product (including
   .columns-3 = 30.75%). In a CSS grid those child widths become
   explicit column sizes, capping the tracks at the item width. We reset
   them all to auto / min-content so the fr units on the grid container win. */
ul.products.pg-shop-grid {
	display: grid !important;
	grid-template-columns: 1fr;
	grid-auto-flow: dense;
	gap: clamp(24px, 3vw, 36px);
	list-style: none;
	margin: 0;
	padding: 0;
	float: none !important;
}

/* Neutralise WC's per-item float and fixed % widths */
ul.products.pg-shop-grid li.product,
ul.products.pg-shop-grid li.product-category {
	width: auto !important;
	float: none !important;
	margin: 0 !important;
	clear: none !important;
}

/* WooCommerce adds a clearfix via ::before/::after { content:" "; display:table }
   on ul.products. In a CSS Grid those pseudo-elements become anonymous grid items
   and displace real product cards. Suppress them so auto-placement is clean. */
ul.products.pg-shop-grid::before,
ul.products.pg-shop-grid::after {
	display: none !important;
	content: none !important;
}

/* ============================================================
   4. PRODUCT CARD
   ============================================================ */
li.product.pg-shop-card {
	display: flex;
	flex-direction: column;
	background: var(--pg-bone, #FBF8F1);
	border-radius: var(--radius-md, 12px);
	overflow: hidden;
	box-shadow: var(--shadow-md, 0 12px 30px rgba(27,26,23,.12));
	border: 1px solid rgba(27,26,23,.06);
	transition: transform .25s ease, box-shadow .25s ease;
}

li.product.pg-shop-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 24px 52px rgba(27,26,23,.16);
}

@media (prefers-reduced-motion: reduce) {
	li.product.pg-shop-card,
	li.product.pg-shop-card:hover {
		transition: none;
		transform: none;
	}
}

/* Suppress WooCommerce's default card styles */
li.product.pg-shop-card a img {
	display: none; /* we render the frame ourselves */
}

/* ============================================================
   5. CARD POSTER FRAME
   ============================================================ */
.pg-shop-card__frame-wrap {
	padding: 20px 20px 0;
}

/* Dark frame variant (for cosmos/night posters) */
.pg-shop-card__frame {
	padding: 10px;
	border-radius: var(--radius-flat, 2px);
	box-shadow: var(--shadow-poster, 0 30px 70px rgba(8,11,24,.4));
}

.pg-shop-card__frame--dark {
	background: #14110d;
}

.pg-shop-card__frame--light {
	background: var(--pg-bone, #FBF8F1);
	border: 1px solid rgba(27,26,23,.1);
	box-shadow: 0 18px 40px rgba(27,26,23,.16);
}

/* Poster inner (30:42 aspect ratio) */
.pg-shop-card__poster {
	position: relative;
	width: 100%;
	aspect-ratio: 30 / 42;
	overflow: hidden;
}

/* Inner border decoration */
.pg-shop-card__poster-border {
	position: absolute;
	inset: 10px;
	border: 1px solid rgba(217,201,168,.22);
	pointer-events: none;
	z-index: 1;
}

.pg-shop-card__frame--light .pg-shop-card__poster-border {
	border-color: rgba(27,26,23,.1);
}

/* Poster placeholder fills the card visual */
.pg-shop-card__poster .pg-poster-preview {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.pg-shop-card__poster .pg-poster-preview__svg {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Real thumbnail (when the product has a featured image) */
.pg-shop-card__poster img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* ============================================================
   6. CARD BODY (title, price, CTA)
   ============================================================ */
.pg-shop-card__body {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 22px 20px 24px;
	gap: 6px;
}

/* Category eyebrow */
.pg-shop-card__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: #5A6280;
	margin-bottom: 4px;
}

.pg-shop-card__eyebrow-dot {
	display: inline-block;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--pg-slate, #5A6280);
	flex-shrink: 0;
}

/* Product title */
.pg-shop-card__title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(19px, 2.5vw, 22px);
	line-height: 1.15;
	color: var(--pg-ink);
	margin: 0 0 4px;
	letter-spacing: -.005em;
}

/* Tagline / short description */
.pg-shop-card__tagline {
	font-size: 14px;
	line-height: 1.5;
	color: #5A554C;
	margin: 0 0 12px;
}

/* Price */
.pg-shop-card__price {
	font-size: 14px;
	color: #7A7268;
	margin: 0 0 16px;
}

.pg-shop-card__price .woocommerce-Price-amount {
	font-weight: 700;
	color: var(--pg-ink);
	font-size: 15px;
}

/* CTA button */
.pg-shop-card__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2, 8px);
	background: var(--pg-btn-brass, #906726);
	color: var(--pg-bone, #FBF8F1);
	padding: 13px 22px;
	border-radius: var(--radius-pill, 999px);
	font-family: var(--font-body);
	font-size: 14.5px;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
	margin-top: auto;
	align-self: flex-start;
}

.pg-shop-card__cta:hover {
	background: var(--pg-btn-brass-hover, #8A5E1A);
	color: var(--pg-bone, #FBF8F1);
	transform: translateY(-2px);
	box-shadow: var(--shadow-brass, 0 14px 40px rgba(182,137,63,.4));
}

.pg-shop-card__cta:focus-visible {
	outline: 2px solid var(--pg-midnight, #0E1426);
	outline-offset: 3px;
}

.pg-shop-card__cta:active {
	background: #9C7333;
	transform: translateY(1px);
	box-shadow: none;
}

@media (prefers-reduced-motion: reduce) {
	.pg-shop-card__cta {
		transition: none;
		transform: none;
	}
	.pg-shop-card__cta:hover {
		transform: none;
		box-shadow: none;
	}
}

/* ============================================================
   7. PAGINATION
   ============================================================ */
.pg-shop-pagination {
	margin-top: clamp(40px, 5vw, 64px);
}

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

.pg-shop-pagination .woocommerce-pagination ul li {
	margin: 0;
}

.pg-shop-pagination .woocommerce-pagination ul li a,
.pg-shop-pagination .woocommerce-pagination ul li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius-pill, 999px);
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	border: 1.5px solid rgba(27,26,23,.14);
	color: var(--pg-ink);
	transition: background .2s ease, border-color .2s ease, color .2s ease;
}

.pg-shop-pagination .woocommerce-pagination ul li a:hover {
	border-color: var(--pg-brass);
	color: var(--pg-brass-text, #8A621E);
	background: rgba(182,137,63,.06);
}

.pg-shop-pagination .woocommerce-pagination ul li span.current {
	background: var(--pg-btn-brass, #906726);
	color: var(--pg-bone, #FBF8F1);
	border-color: var(--pg-btn-brass, #906726);
}

@media (prefers-reduced-motion: reduce) {
	.pg-shop-pagination .woocommerce-pagination ul li a,
	.pg-shop-pagination .woocommerce-pagination ul li span {
		transition: none;
	}
}

/* ============================================================
   8. EMPTY / NO-RESULTS STATE
   ============================================================ */
.pg-shop-empty {
	text-align: center;
	padding: clamp(64px, 8vw, 96px) 0;
}

.pg-shop-empty .woocommerce-info {
	background: transparent;
	border: none;
	padding: 0;
	font-size: 18px;
	color: #7A7268;
	margin: 0 0 28px;
}

.pg-shop-empty .woocommerce-info::before {
	display: none;
}

/* ============================================================
   9. RESPONSIVE BREAKPOINTS
   ============================================================ */

/* Tablet: 2-up */
@media (min-width: 560px) {
	ul.products.pg-shop-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Desktop: 3-up */
@media (min-width: 960px) {
	ul.products.pg-shop-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Large desktop: keep max readable card size */
@media (min-width: 1280px) {
	ul.products.pg-shop-grid {
		gap: 40px;
	}
}

/* ============================================================
   10. CURATED LANDING -- 3 EDITORIAL ROWS
       (.pg-shop-main--landing + .pg-shop-landing + .pg-shop-row)
   ============================================================ */

/* Landing wrapper: generous vertical padding */
.pg-shop-main--landing {
	padding-block: clamp(48px, 6vw, 80px);
}

.pg-shop-landing {
	display: flex;
	flex-direction: column;
}

/* Row divider (brass gradient line between rows) */
.pg-shop-landing__divider {
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(182,137,63,.4), transparent);
	margin: clamp(52px, 7vw, 88px) 0;
}

/* ---- Single editorial row: mobile = stacked column ---- */
.pg-shop-row {
	display: flex;
	flex-direction: column;
	gap: clamp(28px, 5vw, 40px);
}

/* ---- Visual side ---- */
.pg-shop-row__visual {
	display: flex;
	justify-content: center;
}

.pg-shop-row__frame-wrap {
	width: 100%;
	max-width: 380px;
}

.pg-shop-row__frame {
	padding: 13px;
	border-radius: var(--radius-flat, 2px);
	box-shadow: var(--shadow-poster, 0 30px 70px rgba(8,11,24,.4));
	transition: box-shadow .3s ease;
}

.pg-shop-row__frame--dark {
	background: #14110d;
}

.pg-shop-row__frame--light {
	background: var(--pg-bone, #FBF8F1);
	border: 1px solid rgba(27,26,23,.08);
	box-shadow: 0 30px 70px rgba(27,26,23,.16);
}

/* Poster inner (30:42 = 3:4 aspect ratio) */
.pg-shop-row__poster {
	position: relative;
	width: 100%;
	aspect-ratio: 3 / 4;
	overflow: hidden;
}

.pg-shop-row__frame--dark .pg-shop-row__poster {
	border: 1px solid rgba(182,137,63,.18);
}

.pg-shop-row__frame--light .pg-shop-row__poster {
	border: 1px solid rgba(27,26,23,.12);
}

/* Placeholder SVG fills the poster */
.pg-shop-row__poster .pg-poster-preview {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.pg-shop-row__poster .pg-poster-preview__svg {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Inner border decoration */
.pg-shop-row__poster-border {
	position: absolute;
	inset: 12px;
	border: 1px solid rgba(217,201,168,.26);
	pointer-events: none;
	z-index: 1;
}

.pg-shop-row__frame--light .pg-shop-row__poster-border {
	border-color: rgba(27,26,23,.1);
}

/* ---- Text / body side ---- */
.pg-shop-row__body {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0;
}

/* Eyebrow label */
.pg-shop-row__label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
}

.pg-shop-row__label-dot {
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--pg-slate, #5A6280);
	flex-shrink: 0;
}

.pg-shop-row__label-text {
	font-size: 12px;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: #5A6280;
	font-weight: 700;
}

/* Product title (h2 styled like h3 in home rows) */
.pg-shop-row__title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(32px, 5vw, 52px);
	line-height: 1.05;
	letter-spacing: -.015em;
	margin: 0 0 16px;
	color: var(--pg-ink, #1B1A17);
	text-wrap: balance;
}

.pg-shop-row__title-link {
	color: inherit;
	text-decoration: none;
}

.pg-shop-row__title-link:hover {
	color: var(--pg-brass-text, #8A621E);
}

/* Short description tagline */
.pg-shop-row__tagline {
	font-size: clamp(15px, 2vw, 17px);
	line-height: 1.65;
	color: #4A4742;
	margin: 0 0 20px;
	max-width: 38em;
}

/* Price */
.pg-shop-row__price {
	font-size: 14.5px;
	color: #7A7268;
	margin: 0 0 28px;
}

.pg-shop-row__price .woocommerce-Price-amount {
	font-weight: 700;
	color: var(--pg-ink, #1B1A17);
	font-size: 16px;
}

/* CTA button (reuses pg-btn--brass, supplemented here) */
.pg-shop-row__cta {
	align-self: flex-start;
}

/* ---- Desktop: 2-col grid, alternate visual/body order ---- */
@media (min-width: 860px) {
	.pg-shop-row {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: clamp(56px, 6vw, 88px);
		align-items: center;
	}

	/* Reverse row: visual on right, body on left */
	.pg-shop-row--reverse .pg-shop-row__visual {
		order: 2;
	}
	.pg-shop-row--reverse .pg-shop-row__body {
		order: 1;
	}

	.pg-shop-row__frame-wrap {
		max-width: 440px;
		margin: 0 auto;
	}
}

/* Larger desktop: slightly larger poster cap */
@media (min-width: 1200px) {
	.pg-shop-row__frame-wrap {
		max-width: 500px;
	}
}

/* Hover lift on frame */
@media (hover: hover) {
	.pg-shop-row__frame-wrap a:hover .pg-shop-row__frame--dark {
		box-shadow: 0 40px 90px rgba(8,11,24,.55);
	}
	.pg-shop-row__frame-wrap a:hover .pg-shop-row__frame--light {
		box-shadow: 0 40px 90px rgba(27,26,23,.22);
	}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.pg-shop-row__frame {
		transition: none;
	}
}

/* ============================================================
   11. FLAGSHIP COLLECTION LANDING (.pg-coll-*)
       Cinematic hero + showcase rows + why + steps + CTA.
       Mobile-first. Supersedes the .pg-shop-row editorial rows.
   ============================================================ */

/* ---- 11.1 HERO ---- */
.pg-coll-hero {
	position: relative;
	overflow: hidden;
	background: var(--pg-midnight);
	color: var(--pg-bone);
	padding: clamp(120px, 16vw, 168px) 0 clamp(56px, 8vw, 96px);
}

.pg-coll-hero__glow {
	position: absolute;
	top: -20%;
	left: 50%;
	width: 80vw;
	max-width: 900px;
	aspect-ratio: 1;
	transform: translateX(-50%);
	background: radial-gradient(circle, rgba(212,168,90,.16) 0%, rgba(212,168,90,0) 62%);
	pointer-events: none;
	z-index: 0;
}

.pg-coll-hero__inner {
	position: relative;
	z-index: 1;
}

.pg-coll-hero__intro {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.pg-eyebrow--light {
	color: var(--pg-brass-glow) !important;
}

.pg-coll-hero__title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(40px, 8vw, 82px);
	line-height: 1.02;
	letter-spacing: -.02em;
	margin: 8px 0 0;
	text-wrap: balance;
}

.pg-coll-hero__script {
	font-size: clamp(48px, 9vw, 96px);
	margin-top: -.1em;
}

.pg-coll-hero__sub {
	font-size: clamp(15px, 2vw, 18px);
	line-height: 1.65;
	color: rgba(251,248,241,.72);
	max-width: 52ch;
	margin: 22px auto 0;
}

/* Triptych */
.pg-coll-hero__triptych {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(20px, 4vw, 32px);
	max-width: 360px;
	margin: clamp(48px, 7vw, 76px) auto 0;
}

.pg-coll-tile {
	display: block;
	text-decoration: none;
	color: inherit;
	transition: transform .4s cubic-bezier(.16,.84,.44,1);
	transform: translateY(0);
}

.pg-coll-tile__poster {
	position: relative;
	display: block;
	aspect-ratio: 3 / 4;
	border-radius: 3px;
	overflow: hidden;
	padding: 12px;
	box-shadow: 0 30px 70px rgba(8,11,24,.5);
}

.pg-coll-tile--dark .pg-coll-tile__poster { background: #14110d; }
.pg-coll-tile--light .pg-coll-tile__poster { background: var(--pg-bone); }

.pg-coll-tile__poster .pg-poster-preview {
	position: absolute;
	inset: 12px;
	width: auto;
	height: auto;
	border-radius: 1px;
}
.pg-coll-tile__poster .pg-poster-preview__svg { width: 100%; height: 100%; object-fit: cover; }

.pg-coll-tile__edge {
	position: absolute;
	inset: 20px;
	border: 1px solid rgba(217,201,168,.28);
	pointer-events: none;
	z-index: 2;
}
.pg-coll-tile--light .pg-coll-tile__edge { border-color: rgba(27,26,23,.12); }

.pg-coll-tile__cap {
	display: flex;
	flex-direction: column;
	gap: 2px;
	margin-top: 16px;
	text-align: center;
}
.pg-coll-tile__cap-label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--pg-brass-glow);
}
.pg-coll-tile__cap-title {
	font-family: var(--font-display);
	font-size: 21px;
	color: var(--pg-bone);
}

@media (hover: hover) {
	.pg-coll-tile:hover { transform: translateY(-10px); }
	.pg-coll-tile:hover .pg-coll-tile__poster { box-shadow: 0 44px 90px rgba(8,11,24,.62); }
}

/* Scroll cue */
.pg-coll-hero__scroll {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	width: max-content;
	margin: clamp(40px, 6vw, 64px) auto 0;
	color: rgba(251,248,241,.6);
	text-decoration: none;
	font-size: 12px;
	letter-spacing: .16em;
	text-transform: uppercase;
	font-weight: 700;
	transition: color .2s ease;
}
.pg-coll-hero__scroll:hover { color: var(--pg-brass-glow); }
.pg-coll-hero__scroll svg { animation: pg-coll-bob 1.8s ease-in-out infinite; }

@keyframes pg-coll-bob {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(4px); }
}

/* Desktop: fanned triptych */
@media (min-width: 760px) {
	.pg-coll-hero__triptych {
		grid-template-columns: repeat(3, 1fr);
		max-width: 880px;
		align-items: start;
		gap: clamp(24px, 3vw, 40px);
	}
	/* stagger middle tile down for a gallery-wall feel */
	.pg-coll-tile { transform: translateY(calc(var(--i, 0) * 0px)); }
	.pg-coll-tile[style*="--i:1"] { margin-top: 34px; }
	.pg-coll-tile[style*="--i:0"],
	.pg-coll-tile[style*="--i:2"] { margin-top: 0; }
}

/* ---- 11.2 SHOWCASE ROWS ---- */
.pg-coll-main { background: var(--pg-bone); }

.pg-coll-row {
	padding: clamp(56px, 9vw, 120px) 0;
}
.pg-coll-row + .pg-coll-row { border-top: 1px solid rgba(27,26,23,.06); }

.pg-coll-row__grid {
	display: flex;
	flex-direction: column;
	gap: clamp(36px, 6vw, 56px);
}

/* Visual side */
.pg-coll-row__visual {
	position: relative;
	width: 100%;
	max-width: 460px;
	margin: 0 auto;
	padding-left: 18px;
	padding-bottom: 56px;
}

.pg-coll-row__num {
	position: absolute;
	top: -.42em;
	left: -.12em;
	z-index: 0;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(120px, 22vw, 220px);
	line-height: 1;
	color: rgba(27,26,23,.05);
	pointer-events: none;
	user-select: none;
}

.pg-coll-row__frame {
	position: relative;
	z-index: 1;
	display: block;
	width: 78%;
	margin-left: auto;
	padding: 14px;
	border-radius: 3px;
	box-shadow: 0 36px 80px rgba(8,11,24,.4);
	transition: transform .35s ease, box-shadow .35s ease;
}
.pg-coll-row__frame--dark { background: #14110d; }
.pg-coll-row__frame--light { background: var(--pg-bone); border: 1px solid rgba(27,26,23,.1); box-shadow: 0 36px 80px rgba(27,26,23,.18); }

.pg-coll-row__poster {
	position: relative;
	display: block;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	border-radius: 1px;
}
.pg-coll-row__frame--dark .pg-coll-row__poster { border: 1px solid rgba(182,137,63,.18); }

.pg-coll-row__poster .pg-poster-preview { position: absolute; inset: 0; width: 100%; height: 100%; }
.pg-coll-row__poster .pg-poster-preview__svg { width: 100%; height: 100%; object-fit: cover; }

.pg-coll-row__poster-edge {
	position: absolute;
	inset: 12px;
	border: 1px solid rgba(217,201,168,.26);
	pointer-events: none;
	z-index: 1;
}
.pg-coll-row__frame--light .pg-coll-row__poster-edge { border-color: rgba(27,26,23,.1); }

/* In-situ interior inset photo, overlapping bottom-left */
.pg-coll-row__situ {
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 2;
	width: 52%;
	max-width: 240px;
	margin: 0;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 20px 44px rgba(8,11,24,.28);
	border: 4px solid var(--pg-bone);
}
.pg-coll-row__situ img { display: block; width: 100%; height: 100%; aspect-ratio: 4 / 3; object-fit: cover; }

@media (hover: hover) {
	.pg-coll-row__frame:hover { transform: translateY(-6px); }
	.pg-coll-row__frame--dark:hover { box-shadow: 0 48px 100px rgba(8,11,24,.55); }
}
@media (prefers-reduced-motion: reduce) {
	.pg-coll-row__frame { transition: none; }
	.pg-coll-hero__scroll svg { animation: none; }
	.pg-coll-tile { transition: none; }
}

/* Body side */
.pg-coll-row__body { max-width: 520px; }

.pg-coll-row__label {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: #5A6280;
	margin-bottom: 16px;
}
.pg-coll-row__label-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--pg-brass); }

.pg-coll-row__title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(34px, 5.5vw, 56px);
	line-height: 1.03;
	letter-spacing: -.018em;
	margin: 0 0 14px;
	color: var(--pg-ink);
	text-wrap: balance;
}
.pg-coll-row__title a { color: inherit; text-decoration: none; }
.pg-coll-row__title a:hover { color: var(--pg-brass-text); }

.pg-coll-row__lede {
	font-size: clamp(16px, 2vw, 19px);
	line-height: 1.6;
	color: #4A4742;
	margin: 0 0 24px;
}

.pg-coll-row__features {
	list-style: none;
	margin: 0 0 30px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.pg-coll-row__features li {
	display: flex;
	align-items: flex-start;
	gap: 11px;
	font-size: 15.5px;
	line-height: 1.45;
	color: #3A3733;
}
.pg-coll-row__features svg { flex-shrink: 0; margin-top: 1px; color: var(--pg-brass); }

.pg-coll-row__foot {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 20px;
}
.pg-coll-row__price {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	font-size: 15px;
	color: #7A7268;
}
.pg-coll-row__price span { font-size: 13px; }
.pg-coll-row__price .woocommerce-Price-amount { font-weight: 700; color: var(--pg-ink); font-size: 20px; }
.pg-coll-row__actions { display: flex; flex-wrap: wrap; gap: 12px; }

/* Desktop: two columns, alternating */
@media (min-width: 900px) {
	.pg-coll-row__grid {
		display: grid;
		grid-template-columns: 1.05fr 1fr;
		gap: clamp(56px, 7vw, 104px);
		align-items: center;
	}
	.pg-coll-row__visual { margin: 0; max-width: none; }
	.pg-coll-row--reverse .pg-coll-row__visual { order: 2; }
	.pg-coll-row--reverse .pg-coll-row__body { order: 1; }
}

/* ---- 11.3 WAAROM POSTERGEN ---- */
.pg-coll-why { padding: clamp(64px, 9vw, 110px) 0; }
.pg-coll-why__head { text-align: center; max-width: 620px; margin: 0 auto clamp(40px, 5vw, 60px); }
.pg-coll-why__title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(28px, 4.5vw, 44px);
	line-height: 1.08;
	color: var(--pg-ink);
	margin: 6px 0 0;
	text-wrap: balance;
}
.pg-coll-why__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(18px, 2.5vw, 28px);
}
.pg-coll-why__card {
	background: var(--pg-bone);
	border: 1px solid rgba(27,26,23,.07);
	border-radius: 14px;
	padding: clamp(24px, 3vw, 32px);
	box-shadow: 0 10px 30px rgba(27,26,23,.05);
}
.pg-coll-why__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: rgba(182,137,63,.1);
	color: var(--pg-brass-text);
	margin-bottom: 18px;
}
.pg-coll-why__card-title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 20px;
	color: var(--pg-ink);
	margin: 0 0 8px;
}
.pg-coll-why__card-text { font-size: 15px; line-height: 1.55; color: #5A554C; margin: 0; }

@media (min-width: 620px) { .pg-coll-why__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px) { .pg-coll-why__grid { grid-template-columns: repeat(4, 1fr); } }

/* ---- 11.4 PROCES STEPS ---- */
.pg-coll-steps { background: var(--pg-bone); padding: clamp(56px, 8vw, 100px) 0 clamp(64px, 9vw, 110px); }
.pg-coll-steps__title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(26px, 4vw, 40px);
	line-height: 1.1;
	color: var(--pg-ink);
	text-align: center;
	max-width: 16ch;
	margin: 0 auto clamp(40px, 5vw, 60px);
	text-wrap: balance;
}
.pg-coll-steps__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(28px, 4vw, 44px);
	counter-reset: none;
}
.pg-coll-steps__item { position: relative; text-align: center; }
.pg-coll-steps__num {
	display: block;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 44px;
	line-height: 1;
	color: var(--pg-brass);
	margin-bottom: 14px;
}
.pg-coll-steps__item-title { font-family: var(--font-display); font-weight: 600; font-size: 21px; color: var(--pg-ink); margin: 0 0 8px; }
.pg-coll-steps__item-text { font-size: 15px; line-height: 1.6; color: #5A554C; margin: 0 auto; max-width: 34ch; }

@media (min-width: 760px) {
	.pg-coll-steps__list { grid-template-columns: repeat(3, 1fr); gap: clamp(32px, 4vw, 56px); }
	/* connecting hairline between numerals */
	.pg-coll-steps__item:not(:last-child)::after {
		content: '';
		position: absolute;
		top: 22px;
		left: calc(50% + 40px);
		right: calc(-50% + 40px);
		height: 1px;
		background: linear-gradient(90deg, rgba(182,137,63,.4), rgba(182,137,63,.1));
	}
}

/* ---- 11.5 CLOSING CTA ---- */
.pg-coll-cta {
	position: relative;
	overflow: hidden;
	text-align: center;
	padding: clamp(72px, 10vw, 130px) 0;
	background: var(--pg-midnight);
}
.pg-coll-cta__glow {
	position: absolute;
	bottom: -30%;
	left: 50%;
	width: 70vw;
	max-width: 800px;
	aspect-ratio: 1;
	transform: translateX(-50%);
	background: radial-gradient(circle, rgba(212,168,90,.18) 0%, rgba(212,168,90,0) 60%);
	pointer-events: none;
}
.pg-coll-cta__inner { position: relative; z-index: 1; max-width: 640px; margin: 0 auto; }
.pg-coll-cta__script { font-size: clamp(40px, 7vw, 64px); margin-bottom: -.05em; }
.pg-coll-cta__title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(30px, 5vw, 52px);
	line-height: 1.05;
	color: var(--pg-bone);
	margin: 4px 0 16px;
	text-wrap: balance;
}
.pg-coll-cta__sub { font-size: clamp(15px, 2vw, 18px); line-height: 1.6; color: rgba(251,248,241,.72); margin: 0 auto 30px; max-width: 46ch; }
.pg-coll-cta__btn { font-size: 16px; padding: 16px 36px; }

/* ---- 11.6 SCROLL-REVEAL (uses global [data-reveal] / .is-visible) ---- */
.pg-coll-hero [data-reveal],
.pg-coll-row [data-reveal],
.pg-coll-why [data-reveal],
.pg-coll-steps [data-reveal],
.pg-coll-cta [data-reveal] {
	opacity: 0;
	transform: translateY(22px);
	transition: opacity .7s var(--ease-reveal, cubic-bezier(.16,.84,.44,1)), transform .7s var(--ease-reveal, cubic-bezier(.16,.84,.44,1));
}
.pg-coll-hero [data-reveal].is-visible,
.pg-coll-row [data-reveal].is-visible,
.pg-coll-why [data-reveal].is-visible,
.pg-coll-steps [data-reveal].is-visible,
.pg-coll-cta [data-reveal].is-visible {
	opacity: 1;
	transform: none;
}
@media (prefers-reduced-motion: reduce) {
	.pg-coll-hero [data-reveal],
	.pg-coll-row [data-reveal],
	.pg-coll-why [data-reveal],
	.pg-coll-steps [data-reveal],
	.pg-coll-cta [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   12. VOORBEELD-MODAL + MINI-SLIDER (.pg-ex-*)
   ============================================================ */
.pg-ex-src { display: none; }
.pg-ex-modal { position: fixed; inset: 0; z-index: 10050; display: flex; align-items: center; justify-content: center; padding: 24px; }
.pg-ex-modal[hidden] { display: none; }
.pg-ex-modal__backdrop { position: absolute; inset: 0; background: rgba(10,13,24,.72); backdrop-filter: blur(3px); }
.pg-ex-modal__card { position: relative; z-index: 1; background: var(--pg-bone); border-radius: 18px; width: min(560px, 100%); max-height: 92vh; padding: 26px; box-shadow: 0 40px 90px rgba(8,11,24,.55); display: flex; flex-direction: column; }
.pg-ex-modal__close { position: absolute; top: 14px; right: 14px; width: 36px; height: 36px; border-radius: 50%; border: none; background: rgba(27,26,23,.06); color: var(--pg-ink); display: flex; align-items: center; justify-content: center; cursor: pointer; }
.pg-ex-modal__close:hover { background: rgba(27,26,23,.12); }
.pg-ex-modal__title { font-family: var(--font-display); font-weight: 600; font-size: 22px; color: var(--pg-ink); margin: 0 0 18px; text-align: center; }
.pg-ex-modal__viewport { overflow: hidden; border-radius: 12px; }
.pg-ex-modal__track { display: flex; transition: transform .35s cubic-bezier(.16,.84,.44,1); }
.pg-ex-slide { flex: 0 0 100%; margin: 0; display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 6px 2px; }
.pg-ex-slide figcaption { font-size: 12.5px; letter-spacing: .04em; color: var(--pg-warm-grey-text); text-align: center; }
.pg-ex-poster { position: relative; display: block; width: 60%; max-width: 230px; aspect-ratio: 3/4; border-radius: 3px; overflow: hidden; padding: 11px; box-shadow: 0 24px 50px rgba(8,11,24,.32); }
.pg-ex-slide--dark .pg-ex-poster { background: #14110d; }
.pg-ex-slide--light .pg-ex-poster { background: var(--pg-bone); border: 1px solid rgba(27,26,23,.1); }
.pg-ex-poster .pg-poster-preview { position: absolute; inset: 11px; width: auto; height: auto; }
.pg-ex-poster .pg-poster-preview__svg { width: 100%; height: 100%; object-fit: cover; }
.pg-ex-poster__edge { position: absolute; inset: 18px; border: 1px solid rgba(217,201,168,.28); pointer-events: none; }
.pg-ex-slide--light .pg-ex-poster__edge { border-color: rgba(27,26,23,.12); }
.pg-ex-slide--photo img { width: 82%; max-width: 340px; aspect-ratio: 4/3; object-fit: cover; border-radius: 10px; box-shadow: 0 18px 40px rgba(8,11,24,.22); }
.pg-ex-modal__nav { position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(27,26,23,.12); background: #fff; color: var(--pg-ink); display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 0 6px 18px rgba(8,11,24,.18); }
.pg-ex-modal__nav--prev { left: 6px; } .pg-ex-modal__nav--next { right: 6px; }
.pg-ex-modal__nav:disabled { opacity: .28; cursor: default; }
.pg-ex-modal__dots { display: flex; justify-content: center; gap: 8px; margin-top: 16px; }
.pg-ex-dot { width: 8px; height: 8px; border-radius: 50%; border: none; background: rgba(27,26,23,.2); cursor: pointer; padding: 0; }
.pg-ex-dot[aria-current="true"] { background: var(--pg-brass); }
@media (prefers-reduced-motion: reduce) { .pg-ex-modal__track { transition: none; } }
