/*
 * Vinduspesialisten product cards — premium discovery card.
 *
 * A floating white card with a soft warm shadow, edge-to-edge product
 * photo on the card's own white background, a slim mint accent
 * rule above a labelled price, bold near-black title, muted category
 * meta as the "description," and a full-width mint CTA pinned
 * to the card base.
 *
 * Scoped to `.woocommerce ul.products li.product` so it covers the
 * shop archive, taxonomy pages (e.g. /produktkategori/), and the
 * front-page sliders that wrap each slide in
 * `.swiper-slide.woocommerce`.
 */
:root {
	--vs-card-bg: #ffffff;
	--vs-card-ink: #1a1a1a;
	--vs-card-muted: #6b6b6b;
	--vs-card-title: #3f3f3f;
	--vs-card-price: #3f8065;
	--vs-card-faint: #a8a8a8;
	--vs-card-accent: #C8E6D7;
	--vs-card-accent-hover: #C8E6D7;
	--vs-card-shadow: 0 1px 2px rgba(20, 14, 4, 0.04), 0 12px 28px rgba(20, 14, 4, 0.06);
	--vs-card-shadow-hover: 0 2px 4px rgba(20, 14, 4, 0.06), 0 24px 48px rgba(20, 14, 4, 0.12);
	--vs-card-radius: 16px;
	--vs-card-cta-radius: 10px;
}

.woocommerce ul.products {
	column-gap: 28px;
	row-gap: 36px;
	align-items: stretch;
	list-style: none;
}

.woocommerce ul.products li.product {
	position: relative;
	display: grid !important;
	grid-template-columns: minmax(0, 1fr);
	grid-template-areas:
		"figure"
		"title"
		"price"
		"meta"
		"cta";
	grid-template-rows: auto auto auto 1fr auto;
	row-gap: 0;
	padding: 0 !important;
	background: var(--vs-card-bg);
	border: 0;
	border-radius: var(--vs-card-radius);
	box-shadow: var(--vs-card-shadow);
	overflow: hidden;
	isolation: isolate;
	transform: none;
	transition: box-shadow 280ms ease, transform 280ms ease;
	animation: vs-card-enter 700ms cubic-bezier(0.16, 1, 0.3, 1) backwards;
}

.woocommerce ul.products li.product:nth-child(1) { animation-delay: 0ms; }
.woocommerce ul.products li.product:nth-child(2) { animation-delay: 70ms; }
.woocommerce ul.products li.product:nth-child(3) { animation-delay: 140ms; }
.woocommerce ul.products li.product:nth-child(4) { animation-delay: 210ms; }
.woocommerce ul.products li.product:nth-child(n+5) { animation-delay: 280ms; }

@keyframes vs-card-enter {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.woocommerce ul.products li.product:hover {
	box-shadow: var(--vs-card-shadow-hover);
	transform: translateY(-2px);
	border-color: transparent;
}

/* Image area — edge-to-edge on the card's own white background. */
.woocommerce ul.products li.product figure {
	grid-area: figure;
	position: relative;
	margin: 0;
	padding: clamp(22px, 3vw, 36px);
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1 / 1;
	background: var(--vs-card-bg);
	border: 0;
	border-radius: 0;
	overflow: hidden;
}

.woocommerce ul.products li.product figure::after {
	content: none;
}

.woocommerce ul.products li.product .ct-media-container {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.woocommerce ul.products li.product img {
	width: auto;
	max-width: 100%;
	max-height: 100%;
	height: auto;
	object-fit: contain;
	transition: transform 700ms cubic-bezier(0.16, 1, 0.3, 1);
}

.woocommerce ul.products li.product:hover img {
	transform: scale(1.08);
}

/* Stock + sale badges — small pills stacked top-left over the image. */
.woocommerce ul.products li.product .onsale,
.woocommerce ul.products li.product .out-of-stock-badge,
.woocommerce ul.products li.product [class*="ct-woo-badge-"],
.woocommerce ul.products li.product.instock figure::after {
	position: absolute;
	top: 16px;
	left: 16px;
	z-index: 4;
	padding: 6px 11px;
	min-height: 0;
	border-radius: 999px;
	box-shadow: 0 6px 18px rgba(20, 14, 4, 0.18);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1;
	text-transform: uppercase;
	pointer-events: none;
}

.woocommerce ul.products li.product .out-of-stock-badge,
.woocommerce ul.products li.product [class*="ct-woo-badge-"] {
	background: var(--vs-card-ink);
	color: #ffffff;
}

.woocommerce ul.products li.product .onsale {
	background: #fbbf24;
	color: #1a1a1a;
	box-shadow: 0 6px 18px rgba(251, 191, 36, 0.30);
}

/* "SALE" → "Tilbud": hide the native string and supply the Norwegian
   label via ::before so we don't need a PHP filter. */
.woocommerce ul.products li.product .onsale {
	font-size: 0;
}

.woocommerce ul.products li.product .onsale::before {
	content: "Tilbud";
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1;
	text-transform: uppercase;
}

/* "Lagerført" badge — dark pill rendered on the figure for any
   product with the WooCommerce `.instock` class. When the product is
   also on sale, drop the badge below the Tilbud pill. */
.woocommerce ul.products li.product.instock figure::after {
	content: "Lagerført";
	background: #336666;
	color: #ffffff;
	box-shadow: 0 6px 18px rgba(51, 102, 102, 0.26);
}

.woocommerce ul.products li.product.instock.sale figure::after {
	top: 48px;
}

/* Price — muted label above the title, preceded by a slim accent rule
   that grows on card hover for a subtle editorial flourish. */
.woocommerce ul.products li.product .price {
	grid-area: price;
	position: relative;
	margin: 0;
	padding: 8px 22px 6px;
	display: block;
	color: var(--vs-card-price);
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.35;
	text-align: center;
	text-transform: none;
	white-space: nowrap;
}

.woocommerce ul.products li.product .price::before {
	content: "";
	display: block;
	width: 28px;
	height: 2px;
	margin: 0 auto 12px;
	background: var(--vs-card-price);
	transition: width 500ms cubic-bezier(0.16, 1, 0.3, 1);
}

.woocommerce ul.products li.product:hover .price::before {
	width: 52px;
}

.woocommerce ul.products li.product .price .amount {
	color: var(--vs-card-price);
	font-size: clamp(18px, 1.35vw, 22px);
	font-weight: 700;
	letter-spacing: 0;
	white-space: nowrap;
}

/* Variable-price products render WooCommerce's "kr X – kr Y" range
   in the loop. Collapse to "Fra kr. <min>" by hiding the dash, max
   price, and the inner currency symbol on the min price, then
   prepending "Fra kr." via a pseudo-element. The screen-reader-text
   sibling that carries the full range stays untouched. */
.woocommerce ul.products li.product .price:has(.amount ~ .amount) .amount:first-of-type::before {
	content: "Fra kr.\00a0";
	font-size: 0.72em;
	font-weight: 600;
}

.woocommerce ul.products li.product .price:has(.amount ~ .amount) .amount:first-of-type .woocommerce-Price-currencySymbol {
	display: none;
}

.woocommerce ul.products li.product .price:has(.amount ~ .amount) .amount ~ .amount,
.woocommerce ul.products li.product .price:has(.amount ~ .amount) > span[aria-hidden="true"]:not(.amount) {
	display: none;
}

.woocommerce ul.products li.product .price del {
	color: var(--vs-card-faint);
	font-weight: 400;
	margin-right: 4px;
}

.woocommerce ul.products li.product .price ins {
	background: transparent;
	color: var(--vs-card-muted);
	text-decoration: none;
}

/* Title — bold, larger, near-black. An overlay pseudo-element on the
   title link expands to cover the whole card so any click on the
   image/meta area follows the title's product link (except for the
   CTA and category meta links, which stack above the overlay). */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-category__title {
	grid-area: title;
	min-width: 0;
	margin: 0;
	padding: 0 22px;
	color: var(--vs-card-title);
	font-size: clamp(15px, 1.15vw, 17px);
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -0.005em;
	text-transform: none;
	word-break: normal;
	overflow-wrap: anywhere;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	overflow: hidden;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title a,
.woocommerce ul.products li.product .woocommerce-loop-category__title a {
	color: inherit;
	text-decoration: none;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title a::before,
.woocommerce ul.products li.product .woocommerce-loop-category__title a::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
}

/* Description proxy — category meta rendered as muted body text. */
.woocommerce ul.products li.product .entry-meta {
	grid-area: meta;
	display: block;
	margin: 0;
	padding: 10px 22px 4px;
	list-style: none;
	color: var(--vs-card-muted);
	font-size: 13px;
	font-weight: 400;
	line-height: 1.55;
	letter-spacing: 0;
	text-transform: none;
}

.woocommerce ul.products li.product .entry-meta li {
	display: inline;
	margin: 0;
	padding: 0;
}

.woocommerce ul.products li.product .entry-meta a {
	position: relative;
	z-index: 3;
	display: inline;
	margin: 0;
	padding: 0;
	border: 0;
	background: transparent;
	color: inherit;
	text-decoration: none;
}

.woocommerce ul.products li.product .entry-meta a:hover {
	background: transparent;
	color: var(--vs-card-ink);
}

/* Front-page carousels show a diverse mix of products, so the per-card
   category breadcrumb adds noise rather than context. Hide it on every
   swiper-slide card; archive/taxonomy pages keep it. */
.swiper-slide.woocommerce ul.products li.product .entry-meta {
	display: none;
}

/* CTA — full-width mint button pinned to the card base.
   Native WooCommerce text ("Velg alternativ" / "Les mer") is hidden
   with font-size: 0 and the visible label "Vis produkt →" is supplied
   by pseudo-elements, so the button's aria-label (e.g. "Velg
   innstillinger for «...»") remains intact for assistive tech. */
.woocommerce ul.products li.product .ct-woo-card-actions {
	grid-area: cta;
	position: relative;
	z-index: 3;
	display: block;
	margin: 0;
	padding: 18px 20px 22px;
	background: transparent;
	border-block: 0;
}

.woocommerce ul.products li.product .ct-woo-card-actions .button,
.woocommerce ul.products li.product a.button {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	width: 100%;
	min-height: 0;
	margin: 0;
	padding: 14px 18px;
	background: var(--vs-card-accent);
	color: #1a1a1a;
	border: 0;
	border-radius: var(--vs-card-cta-radius);
	box-shadow: 0 1px 2px rgba(200, 230, 215, 0.42), 0 8px 18px rgba(200, 230, 215, 0.34);
	font-size: 0;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	text-align: center;
	text-decoration: none;
	text-transform: none;
	cursor: pointer;
	transition: background-color 220ms ease, transform 220ms ease, box-shadow 220ms ease;
}

/* Blocksy uses `.button::before` for a blurred hover-glow shadow
   (position: absolute, opacity: 0, filter: blur). Reset those props
   so our visible label renders inline as flex content. */
.woocommerce ul.products li.product .ct-woo-card-actions .button::before,
.woocommerce ul.products li.product a.button::before {
	content: "Vis produkt";
	display: inline-block;
	position: static;
	inset: auto;
	z-index: auto;
	opacity: 1;
	filter: none;
	background: transparent;
	border-radius: 0;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.005em;
	transition: none;
}

.woocommerce ul.products li.product .ct-woo-card-actions .button::after,
.woocommerce ul.products li.product a.button::after {
	content: "→";
	font-size: 15px;
	font-weight: 500;
	margin-left: 6px;
	transition: transform 220ms cubic-bezier(0.16, 1, 0.3, 1);
}

.woocommerce ul.products li.product .ct-woo-card-actions .button:hover,
.woocommerce ul.products li.product a.button:hover {
	background: var(--vs-card-accent-hover);
	transform: translateY(-1px);
	box-shadow: 0 2px 4px rgba(200, 230, 215, 0.52), 0 14px 28px rgba(200, 230, 215, 0.44);
	color: #1a1a1a;
}

.woocommerce ul.products li.product .ct-woo-card-actions .button:hover::after,
.woocommerce ul.products li.product a.button:hover::after {
	transform: translateX(4px);
}

.woocommerce ul.products li.product .ct-woo-card-actions .button:focus-visible,
.woocommerce ul.products li.product a.button:focus-visible {
	outline: 2px solid var(--vs-card-accent);
	outline-offset: 3px;
}

@media (max-width: 689.98px) {
	.woocommerce ul.products {
		column-gap: 16px;
		row-gap: 20px;
	}

	.woocommerce ul.products li.product {
		border-radius: 14px;
	}

	.woocommerce ul.products li.product .price {
		padding: 8px 18px 4px;
		font-size: 12px;
	}

	.woocommerce ul.products li.product .price::before {
		width: 22px;
		margin: 0 auto 10px;
	}

	.woocommerce ul.products li.product .price .amount {
		font-size: 17px;
	}

	.woocommerce ul.products li.product .woocommerce-loop-product__title,
	.woocommerce ul.products li.product .woocommerce-loop-category__title {
		padding: 0 18px;
		font-size: 14px;
	}

	.woocommerce ul.products li.product .entry-meta {
		padding: 8px 18px 4px;
		font-size: 12px;
	}

	.woocommerce ul.products li.product .ct-woo-card-actions {
		padding: 14px 16px 18px;
	}

	.woocommerce ul.products li.product .ct-woo-card-actions .button,
	.woocommerce ul.products li.product a.button {
		padding: 12px 16px;
	}

	.woocommerce ul.products li.product .ct-woo-card-actions .button::before,
	.woocommerce ul.products li.product a.button::before {
		font-size: 13px;
	}

	.woocommerce ul.products li.product .ct-woo-card-actions .button::after,
	.woocommerce ul.products li.product a.button::after {
		font-size: 14px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.woocommerce ul.products li.product,
	.woocommerce ul.products li.product img,
	.woocommerce ul.products li.product .price::before,
	.woocommerce ul.products li.product .ct-woo-card-actions .button,
	.woocommerce ul.products li.product .ct-woo-card-actions .button::after {
		animation: none !important;
		transition: none !important;
	}

	.woocommerce ul.products li.product:hover {
		transform: none;
	}

	.woocommerce ul.products li.product:hover img {
		transform: none;
	}
}
