/*
Theme Name: Be Plantly
Theme URI: https://plantly.com
Author: Plantly
Author URI: https://plantly.com
Description: A custom WordPress theme for Be Plantly.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: be-plantly
Tags: custom, plant, e-commerce
*/

/* ═══════════════════════════════════════════════════════════════
   DESIGN TOKENS
   Botanical luxury — Unbounded × Outfit
   Palette: Forest green · Warm cream · Golden accent · Sage
═══════════════════════════════════════════════════════════════ */

:root {
	/* Colour */
	--forest:         #1B3A2D;
	--forest-mid:     #2A5240;
	--forest-light:   #3D6B50;
	--sage:           #5A8C6E;
	--leaf:           #7DB885;
	--leaf-pale:      #A8D4AF;
	--cream:          #F7F3EC;
	--cream-dark:     #EDE8DF;
	--cream-border:   #DDD5C5;
	--golden:         #C8A94E;
	--golden-light:   #E8CC7A;
	--golden-pale:    #F5E9C5;
	--bark:           #2C1F14;
	--mist:           #EAF2ED;
	--white:          #FFFFFF;
	--text:           #1E2B23;
	--text-muted:     #5C6B62;
	--text-light:     #8A9E92;

	/* Vibrant accents — drawn from product packaging */
	--rose:           #C4536A;
	--rose-mid:       #DD7A8E;
	--rose-light:     #F9E0E5;
	--sky:            #4E72BE;
	--sky-mid:        #7098D4;
	--sky-light:      #D8E8F8;

	/* Typography */
	--font-display: 'Unbounded', 'Plus Jakarta Sans', sans-serif;
	--font-body:    'Outfit', 'Plus Jakarta Sans', sans-serif;

	/* Spacing */
	--space-xs:  0.5rem;
	--space-sm:  1rem;
	--space-md:  2rem;
	--space-lg:  4rem;
	--space-xl:  7rem;
	--space-2xl: 11rem;

	/* Layout */
	--container: 1200px;
	--radius-sm: 6px;
	--radius-md: 14px;
	--radius-lg: 28px;
	--radius-xl: 60px;

	/* Motion */
	--ease-out:      cubic-bezier(0.16, 1, 0.3, 1);
	--ease-in-out:   cubic-bezier(0.45, 0, 0.55, 1);
	--dur-fast:      0.2s;
	--dur-med:       0.45s;
	--dur-slow:      0.7s;
}

/* ═══════════════════════════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════════════════════════ */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 16px;
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.65;
	color: var(--text);
	background-color: var(--cream);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: inherit;
	text-decoration: none;
}

ul, ol { list-style: none; }

/* ═══════════════════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════════════════ */

.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 5vw, 3rem);
}

/* ═══════════════════════════════════════════════════════════════
   GLOBAL HEADER
═══════════════════════════════════════════════════════════════ */

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 200;
	/* Start fully transparent */
	background: transparent;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	border-bottom: 1px solid transparent;
	transition:
		background   0.3s ease,
		backdrop-filter 0.3s ease,
		border-color 0.3s ease;
}

/* Hard blur kicks in once JS adds .is-scrolled */
.site-header.is-scrolled {
	background: rgba(247, 243, 236, 0.72);
	backdrop-filter: blur(32px) saturate(1.6);
	-webkit-backdrop-filter: blur(32px) saturate(1.6);
	border-bottom: 1px solid var(--cream-border);
}

.site-header__inner {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	padding-block: 1rem;
	gap: 1rem;
}

/* Nav sits in the centre column */
.site-header__inner .main-navigation {
	justify-self: center;
}

/* Actions column aligns to the right */
.site-header__actions {
	justify-self: end;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

/* Cart icon button */
.site-header__cart {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	color: var(--forest);
	transition: background 0.2s ease, color 0.2s ease;
}

.site-header__cart:hover {
	background: color-mix(in srgb, var(--forest) 10%, transparent);
}

/* Item count badge */
.site-header__cart-count {
	position: absolute;
	top: 2px;
	right: 2px;
	min-width: 17px;
	height: 17px;
	padding: 0 4px;
	border-radius: 99px;
	background: var(--forest);
	color: var(--cream);
	font-family: var(--font-product-body);
	font-size: 0.625rem;
	font-weight: 700;
	line-height: 17px;
	text-align: center;
}

/* Logo image — constrain height, let width be natural */
.site-branding .custom-logo {
	height: 40px;
	width: auto;
	display: block;
}

.site-branding a,
.site-title {
	font-family: var(--font-display);
	font-size: 1.6rem;
	font-weight: 600;
	color: var(--forest);
	letter-spacing: -0.02em;
}

.main-navigation ul {
	display: flex;
	align-items: center;
	gap: 2rem;
}

.main-navigation a {
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--text);
	transition: color var(--dur-fast) ease;
}

.main-navigation a:hover {
	color: var(--forest);
}

/* Push page content below the fixed header */
body {
	padding-top: 68px;
}

/* ═══════════════════════════════════════════════════════════════
   GLOBAL FOOTER
═══════════════════════════════════════════════════════════════ */

.site-footer {
	background: var(--forest);
	color: var(--leaf-pale);
	padding-block: var(--space-lg);
}

.site-footer .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
}

.footer-navigation ul {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
}

.footer-navigation a {
	font-size: 0.8125rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--leaf-pale);
	transition: color var(--dur-fast) ease;
}

.footer-navigation a:hover {
	color: var(--golden-light);
}

.copyright {
	font-size: 0.8125rem;
	color: var(--text-light);
	opacity: 0.6;
}

/* ═══════════════════════════════════════════════════════════════
   GLOBAL COMPONENTS
═══════════════════════════════════════════════════════════════ */

/* Buttons */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: var(--radius-xl);
	padding: 0.85em 2.2em;
	cursor: pointer;
	border: 2px solid transparent;
	transition: transform var(--dur-fast) var(--ease-out),
	            box-shadow var(--dur-fast) ease,
	            background var(--dur-fast) ease,
	            color var(--dur-fast) ease,
	            border-color var(--dur-fast) ease;
}

.btn:hover  { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
	background: var(--forest);
	color: var(--cream);
	border-color: var(--forest);
	box-shadow: 0 4px 20px rgba(27, 58, 45, 0.25);
}

.btn--primary:hover {
	background: var(--forest-mid);
	border-color: var(--forest-mid);
	box-shadow: 0 8px 30px rgba(27, 58, 45, 0.35);
}

.btn--ghost {
	background: transparent;
	color: var(--forest);
	border-color: var(--forest);
}

.btn--ghost:hover {
	background: var(--forest);
	color: var(--cream);
}

.btn--gold {
	background: var(--golden);
	color: var(--forest);
	border-color: var(--golden);
	box-shadow: 0 4px 20px rgba(200, 169, 78, 0.35);
}

.btn--gold:hover {
	background: var(--golden-light);
	border-color: var(--golden-light);
	box-shadow: 0 8px 30px rgba(200, 169, 78, 0.45);
}

.btn--large {
	font-size: 1rem;
	padding: 1em 2.8em;
}

/* Section tag */
.section-tag {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--sage);
	padding: 0.35em 1em;
	background: var(--mist);
	border-radius: var(--radius-xl);
	border: 1px solid var(--leaf-pale);
	margin-bottom: 1.25rem;
}

.section-tag--light {
	background: rgba(196, 83, 106, 0.18);
	color: #ffdde4;
	border-color: rgba(196, 83, 106, 0.4);
}

/* Stars */
.stars {
	display: flex;
	gap: 2px;
	align-items: center;
}

/* ═══════════════════════════════════════════════════════════════
   SCROLL REVEAL ANIMATIONS
═══════════════════════════════════════════════════════════════ */

.reveal-up,
.reveal-left,
.reveal-right {
	opacity: 0;
	transition: opacity var(--dur-slow) var(--ease-out),
	            transform var(--dur-slow) var(--ease-out);
	transition-delay: var(--delay, 0s);
}

.reveal-up    { transform: translateY(40px); }
.reveal-left  { transform: translateX(-50px); }
.reveal-right { transform: translateX(50px); }

.reveal-up--delay  { transition-delay: 0.18s; }

.is-visible {
	opacity: 1;
	transform: none;
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 1 · HERO
═══════════════════════════════════════════════════════════════ */

.hero {
	position: relative;
	min-height: 100svh;
	display: flex;
	align-items: center;
	overflow: hidden;
	background: linear-gradient(140deg, var(--forest) 0%, var(--sky) 100%);
}

.hero__bg-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center right;
}

.hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		100deg,
		rgba(27, 58, 45, 0.90) 0%,
		rgba(27, 58, 45, 0.52) 45%,
		rgba(78, 114, 190, 0.12) 100%
	);
}

.hero__inner {
	position: relative;
	z-index: 2;
	max-width: var(--container);
	margin-inline: auto;
	width: 100%;
	padding-inline: clamp(1.25rem, 5vw, 3rem);
	padding-block: clamp(7rem, 14vw, 11rem);
}

.hero__content {
	max-width: 560px;
}

.hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--leaf-pale);
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(163, 212, 175, 0.25);
	border-radius: var(--radius-xl);
	padding: 0.45em 1.1em;
	margin-bottom: 1.75rem;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.hero__badge-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--leaf);
	animation: pulse 2.5s ease-in-out infinite;
}

@keyframes pulse {
	0%, 100% { transform: scale(1); opacity: 1; }
	50%       { transform: scale(1.4); opacity: 0.6; }
}

.hero__headline {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3.8vw, 3.25rem);
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--white);
	margin-bottom: 1.25rem;
}

.hero__subtext {
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	line-height: 1.75;
	color: rgba(255, 255, 255, 0.75);
	max-width: 50ch;
	margin-bottom: 2.5rem;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 2rem;
}

.hero__trust-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.trust-pill {
	font-size: 0.75rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.65);
	background: rgba(255, 255, 255, 0.08);
	border-radius: var(--radius-xl);
	padding: 0.3em 0.75em;
	border: 1px solid rgba(255, 255, 255, 0.14);
}

@keyframes fadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

/* placeholder kept for animation ref only */
.hero__scroll-line {
	display: none;
	51%  { transform: scaleY(1); transform-origin: bottom; }
	100% { transform: scaleY(0); transform-origin: bottom; }
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 2 · TRUST BAR
═══════════════════════════════════════════════════════════════ */

.trust-bar {
	background: var(--sky);
	overflow: hidden;
	padding-block: 1.1rem;
	border-block: 1px solid rgba(255, 255, 255, 0.12);
}

.trust-bar__track {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	width: max-content;
	animation: marquee 32s linear infinite;
}

@keyframes marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

.trust-bar:hover .trust-bar__track {
	animation-play-state: paused;
}

.trust-bar__item {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	white-space: nowrap;
	color: rgba(255, 255, 255, 0.95);
	flex-shrink: 0;
}

.trust-bar__icon {
	display: flex;
	color: #fff;
	opacity: 0.85;
}

.trust-bar__label {
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.04em;
}

.trust-bar__sep {
	color: rgba(255, 255, 255, 0.35);
	font-size: 1.2rem;
	flex-shrink: 0;
	select: none;
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 3 · ABOUT
═══════════════════════════════════════════════════════════════ */

.about {
	background: var(--white);
	padding-block: var(--space-xl);
	position: relative;
	overflow: hidden;
}

.about::before {
	content: '';
	position: absolute;
	width: 600px;
	height: 600px;
	border-radius: 50%;
	background: radial-gradient(circle, var(--sky-light) 0%, transparent 70%);
	top: -200px;
	right: -200px;
	pointer-events: none;
}

.about::after {
	content: '';
	position: absolute;
	width: 400px;
	height: 400px;
	border-radius: 50%;
	background: radial-gradient(circle, var(--rose-light) 0%, transparent 70%);
	bottom: -150px;
	left: -100px;
	pointer-events: none;
}

.about__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(3rem, 7vw, 7rem);
	align-items: start;
}

.about__headline {
	font-family: var(--font-display);
	font-size: clamp(1.1rem, 2.2vw, 1.75rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.01em;
	color: var(--forest);
	margin-bottom: 1.5rem;
	max-width: 28ch;
}

.about__body {
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--text-muted);
	max-width: 54ch;
}

.about__body p + p { margin-top: 1em; }

.about__stats-col {
	display: flex;
	flex-direction: column;
	gap: 0;
	padding-top: 0.5rem;
}

.about__stat {
	display: flex;
	align-items: baseline;
	gap: 1rem;
	padding: 1.75rem 0;
	border-bottom: 1px solid var(--cream-border);
}

.about__stat:first-child { border-top: 1px solid var(--cream-border); }

.about__stat-number {
	font-family: var(--font-display);
	font-size: clamp(2rem, 3.5vw, 3rem);
	font-weight: 700;
	line-height: 1;
	color: var(--sky);
	letter-spacing: -0.02em;
	min-width: 5rem;
}

.about__stat-label {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--text-muted);
	line-height: 1.3;
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 4 · PRODUCT SHOWCASE
═══════════════════════════════════════════════════════════════ */

.product-showcase {
	background: var(--sky-light);
	padding-block: var(--space-xl);
	position: relative;
	overflow: hidden;
}

.product-showcase::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 5% 100%, rgba(78, 114, 190, 0.18) 0%, transparent 50%),
		radial-gradient(ellipse at 95% 0%, rgba(196, 83, 106, 0.10) 0%, transparent 50%);
	pointer-events: none;
}

.product-showcase__grid {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: clamp(2rem, 6vw, 6rem);
	align-items: center;
}

/* Image col */
.product-showcase__image-col { position: relative; }

.product-showcase__image-wrap {
	position: relative;
	border-radius: var(--radius-xl);
	background: linear-gradient(160deg, var(--sky-light) 0%, var(--sky-mid) 100%);
	aspect-ratio: 3/4;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.product-showcase__image-wrap::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 30% 30%, rgba(125, 184, 133, 0.15) 0%, transparent 60%),
		radial-gradient(circle at 80% 80%, rgba(200, 169, 78, 0.1) 0%, transparent 50%);
	pointer-events: none;
}

.product-showcase__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.product-showcase__placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.product-showcase__placeholder-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	color: var(--sage);
}

.product-showcase__badge-wrap {
	position: absolute;
	top: 1.5rem;
	left: 1.5rem;
	z-index: 2;
}

.product-showcase__badge {
	display: inline-block;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background: var(--golden);
	color: var(--forest);
	border-radius: var(--radius-xl);
	padding: 0.4em 1em;
}

/* Info col */
.product-showcase__name {
	font-family: var(--font-display);
	font-size: clamp(1.3rem, 2.5vw, 2rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--forest);
	margin-bottom: 0.5rem;
}

.product-showcase__price {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--golden);
	letter-spacing: -0.01em;
	margin-bottom: 1.5rem;
}

.product-showcase__desc {
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--text-muted);
	max-width: 50ch;
	margin-bottom: 2rem;
}

.product-showcase__ingredients {
	margin-bottom: 2.5rem;
}

.product-showcase__ingredients-label {
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-light);
	margin-bottom: 0.85rem;
}

.product-showcase__ingredients-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.5rem;
}

.product-showcase__ingredient {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--text-muted);
}

.product-showcase__actions { margin-bottom: 1rem; }

.product-showcase__note {
	font-size: 0.8125rem;
	color: var(--text-light);
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 5 · BENEFITS
═══════════════════════════════════════════════════════════════ */

.benefits {
	background: linear-gradient(135deg, var(--sky) 0%, #3A5EA8 100%);
	padding-block: var(--space-xl);
	position: relative;
	overflow: hidden;
}

.benefits::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 0% 0%, rgba(196, 83, 106, 0.22) 0%, transparent 50%),
		radial-gradient(ellipse at 100% 100%, rgba(200, 169, 78, 0.14) 0%, transparent 50%);
	pointer-events: none;
}

.benefits::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
	pointer-events: none;
}

.benefits__header {
	text-align: center;
	margin-bottom: var(--space-lg);
	position: relative;
	z-index: 1;
}

.benefits__headline {
	font-family: var(--font-display);
	font-size: clamp(1.2rem, 2.5vw, 2rem);
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--white);
}

.benefits__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
	position: relative;
	z-index: 1;
}

.benefit-card {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--radius-lg);
	padding: 2.5rem 2rem;
	transition: background var(--dur-med) ease,
	            border-color var(--dur-med) ease,
	            transform var(--dur-med) var(--ease-out),
	            box-shadow var(--dur-med) ease;
}

.benefit-card:hover {
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.4);
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
}

.benefit-card__icon {
	margin-bottom: 1.5rem;
}

.benefit-card__title {
	font-family: var(--font-display);
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--white);
	margin-bottom: 0.75rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.benefit-card__text {
	font-size: 0.9375rem;
	line-height: 1.75;
	color: var(--leaf-pale);
	opacity: 0.85;
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 6 · INGREDIENTS GRID
═══════════════════════════════════════════════════════════════ */

.ingredients {
	background: var(--white);
	padding-block: var(--space-xl);
}

.ingredients__header {
	text-align: center;
	max-width: 640px;
	margin-inline: auto;
	margin-bottom: var(--space-lg);
}

.ingredients__headline {
	font-family: var(--font-display);
	font-size: clamp(1.1rem, 2.2vw, 1.75rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--forest);
	line-height: 1.2;
	margin-bottom: 1rem;
}

.ingredients__subtext {
	font-size: 1.0625rem;
	line-height: 1.7;
	color: var(--text-muted);
}

.ingredients__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 1rem;
}

.ingredient-card {
	border-radius: var(--radius-lg);
	aspect-ratio: 1;
	background: var(--card-color, #5A8C6E);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: default;
	transition: transform var(--dur-med) var(--ease-out),
	            box-shadow var(--dur-med) ease;
	position: relative;
	overflow: hidden;
}

.ingredient-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.2) 0%, transparent 60%);
}

.ingredient-card:hover {
	transform: scale(1.04) translateY(-3px);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.28);
}

.ingredient-card__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.4rem;
	padding: 1.25rem;
	position: relative;
	z-index: 1;
}

.ingredient-card__name {
	font-family: var(--font-display);
	font-size: 0.8125rem;
	font-weight: 700;
	color: var(--white);
	line-height: 1.2;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.ingredient-card__benefit {
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.75);
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 7 · TESTIMONIALS
═══════════════════════════════════════════════════════════════ */

.testimonials {
	background: var(--cream);
	padding-block: var(--space-xl);
	position: relative;
	overflow: hidden;
}

.testimonials::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 50% 0%, rgba(196, 83, 106, 0.10) 0%, transparent 55%),
		radial-gradient(ellipse at 10% 100%, rgba(78, 114, 190, 0.08) 0%, transparent 50%);
	pointer-events: none;
}

.testimonials__header {
	text-align: center;
	margin-bottom: var(--space-lg);
}

.testimonials__headline {
	font-family: var(--font-display);
	font-size: clamp(1.2rem, 2.5vw, 2rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--forest);
	line-height: 1.15;
	margin-bottom: 1.25rem;
}

.testimonials__rating-summary {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
}

.testimonials__rating-text {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--text-muted);
}

.testimonials__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 1.5rem;
}

.testimonial-card {
	background: var(--white);
	border-radius: var(--radius-lg);
	padding: 2.25rem 2rem;
	border: 1px solid var(--cream-border);
	position: relative;
	transition: border-color var(--dur-med) ease,
	            box-shadow var(--dur-med) ease,
	            transform var(--dur-med) var(--ease-out);
}

.testimonial-card::before {
	content: '\201C';
	position: absolute;
	top: 1.25rem;
	right: 1.75rem;
	font-family: var(--font-display);
	font-size: 5rem;
	line-height: 1;
	color: var(--rose-light);
	pointer-events: none;
}

.testimonial-card:hover {
	border-color: var(--leaf-pale);
	box-shadow: 0 8px 32px rgba(27, 58, 45, 0.08);
	transform: translateY(-3px);
}

.testimonial-card__stars {
	display: flex;
	gap: 2px;
	margin-bottom: 1.25rem;
}

.testimonial-card__quote {
	font-family: var(--font-display);
	font-size: 1.1875rem;
	font-weight: 400;
	font-style: italic;
	line-height: 1.6;
	color: var(--text);
	margin-bottom: 1.5rem;
	border: none;
}

.testimonial-card__footer {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.testimonial-card__name {
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--forest);
}

.testimonial-card__location {
	font-size: 0.8125rem;
	color: var(--text-light);
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 8 · CTA BANNER
═══════════════════════════════════════════════════════════════ */

.cta-banner {
	background: linear-gradient(135deg, var(--rose) 0%, #9C3250 100%);
	position: relative;
	overflow: hidden;
}

.cta-banner__inner {
	position: relative;
	padding-block: var(--space-xl);
}

.cta-banner__leaf {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 220px;
	display: flex;
	align-items: center;
	opacity: 0.5;
}

.cta-banner__leaf--left  { left: -60px; }
.cta-banner__leaf--right { right: -60px; transform: scaleX(-1); }

.cta-banner__leaf svg {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.cta-banner__content {
	position: relative;
	z-index: 1;
	text-align: center;
	max-width: 600px;
	margin-inline: auto;
}

.cta-banner__headline {
	font-family: var(--font-display);
	font-size: clamp(1.4rem, 3vw, 2.5rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--white);
	margin-bottom: 1.25rem;
}

.cta-banner__subtext {
	font-size: 1.0625rem;
	color: rgba(255, 255, 255, 0.88);
	margin-bottom: 2.5rem;
}

/* ═══════════════════════════════════════════════════════════════
   SECTION 3 · HOMEPAGE PRODUCTS GRID
═══════════════════════════════════════════════════════════════ */

.hp-products {
	background: var(--cream);
	padding-block: var(--space-xl);
	position: relative;
	overflow: hidden;
}

.hp-products::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 0% 100%, rgba(78, 114, 190, 0.07) 0%, transparent 50%),
		radial-gradient(ellipse at 100% 0%, rgba(196, 83, 106, 0.06) 0%, transparent 50%);
	pointer-events: none;
}

.hp-products__header {
	text-align: center;
	margin-bottom: var(--space-lg);
	position: relative;
	z-index: 1;
}

.hp-products__headline {
	font-family: var(--font-display);
	font-size: clamp(1.4rem, 2.8vw, 2.25rem);
	font-weight: 800;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--forest);
	line-height: 1.1;
	margin-bottom: 0.75rem;
}

.hp-products__sub {
	font-size: 1.0625rem;
	color: var(--text-muted);
	max-width: 46ch;
	margin-inline: auto;
	line-height: 1.7;
}

/* 3-column centered grid */
.hp-products__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.75rem;
	position: relative;
	z-index: 1;
}

/* Product card */
.hp-product-card {
	background: var(--white);
	border: 1.5px solid var(--cream-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: border-color var(--dur-med) ease,
	            box-shadow var(--dur-med) ease,
	            transform var(--dur-med) var(--ease-out);
}

.hp-product-card:hover {
	border-color: var(--sky-mid);
	box-shadow: 0 10px 40px rgba(78, 114, 190, 0.13);
	transform: translateY(-5px);
}

.hp-product-card__img-link { display: block; }

.hp-product-card__img-wrap {
	aspect-ratio: 4 / 3;
	background: linear-gradient(150deg, var(--sky-light) 0%, var(--cream-dark) 100%);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.hp-product-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--dur-slow) var(--ease-out);
}

.hp-product-card:hover .hp-product-card__img { transform: scale(1.05); }

.hp-product-card__img-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hp-product-card__sale {
	position: absolute;
	top: 0.85rem;
	left: 0.85rem;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: var(--rose);
	color: #fff;
	border-radius: var(--radius-xl);
	padding: 0.3em 0.85em;
}

.hp-product-card__body {
	padding: 1.4rem 1.5rem 1.75rem;
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 0.45rem;
}

.hp-product-card__cat {
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--sky);
}

.hp-product-card__name {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.2;
	color: var(--forest);
	text-transform: uppercase;
	letter-spacing: 0.01em;
	margin-bottom: 0.1rem;
}

.hp-product-card__name a {
	color: inherit;
	text-decoration: none;
	transition: color var(--dur-fast) ease;
}

.hp-product-card__name a:hover { color: var(--sky); }

.hp-product-card__price {
	font-family: var(--font-display);
	font-size: 1.0625rem;
	font-weight: 700;
	color: var(--rose);
}

.hp-product-card__price .woocommerce-Price-amount { color: inherit; }

.hp-product-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	margin-top: auto;
	padding-top: 0.75rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--sky);
	text-decoration: none;
	letter-spacing: 0.02em;
	transition: gap var(--dur-fast) ease, color var(--dur-fast) ease;
}

.hp-product-card__cta:hover {
	color: var(--forest);
	gap: 0.5rem;
}

/* Footer CTA */
.hp-products__footer {
	text-align: center;
	margin-top: var(--space-lg);
	position: relative;
	z-index: 1;
}

/* ═══════════════════════════════════════════════════════════════
   SHOP PAGE
═══════════════════════════════════════════════════════════════ */

.shop-page {
	background: var(--cream);
	min-height: 100vh;
}

/* Hero header */
.shop-page__hero {
	background: linear-gradient(160deg, var(--sky-light) 0%, var(--cream) 60%);
	padding-block: clamp(3rem, 7vw, 5rem);
	text-align: center;
	border-bottom: 1px solid var(--cream-border);
	position: relative;
	overflow: hidden;
}

.shop-page__hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 20% 0%, rgba(196, 83, 106, 0.08) 0%, transparent 50%),
		radial-gradient(ellipse at 80% 100%, rgba(78, 114, 190, 0.1) 0%, transparent 50%);
	pointer-events: none;
}

.shop-page__hero .container { position: relative; z-index: 1; }

.shop-page__title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: -0.02em;
	line-height: 1.05;
	color: var(--forest);
	margin-bottom: 1rem;
}

.shop-page__desc {
	font-size: 1.0625rem;
	color: var(--text-muted);
	max-width: 50ch;
	margin-inline: auto;
	margin-bottom: 1.25rem;
	line-height: 1.7;
}

.shop-page__count {
	display: inline-block;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--text-light);
	background: var(--white);
	border: 1px solid var(--cream-border);
	border-radius: var(--radius-xl);
	padding: 0.35em 1em;
}

/* Grid body */
.shop-page__body {
	padding-block: var(--space-lg);
}

/* 3-col grid */
.shop-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
}

/* Shop card */
.shop-card {
	background: var(--white);
	border-radius: var(--radius-lg);
	border: 1.5px solid var(--cream-border);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: border-color var(--dur-med) ease,
	            box-shadow var(--dur-med) ease,
	            transform var(--dur-med) var(--ease-out);
}

.shop-card:hover {
	border-color: var(--sky-mid);
	box-shadow: 0 12px 48px rgba(78, 114, 190, 0.14);
	transform: translateY(-6px);
}

.shop-card__img-link { display: block; }

.shop-card__img-wrap {
	aspect-ratio: 4 / 3;
	background: linear-gradient(150deg, var(--sky-light) 0%, var(--cream-dark) 100%);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.shop-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--dur-slow) var(--ease-out);
}

.shop-card:hover .shop-card__img { transform: scale(1.04); }

.shop-card__img-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.shop-card__badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: var(--radius-xl);
	padding: 0.3em 0.9em;
}

.shop-card__badge--sale {
	background: var(--rose);
	color: #fff;
}

.shop-card__badge--oos {
	background: var(--cream-dark);
	color: var(--text-muted);
	left: auto;
	right: 1rem;
}

.shop-card__body {
	padding: 1.5rem 1.5rem 1.75rem;
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 0.5rem;
}

.shop-card__cat {
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--sky);
}

.shop-card__name {
	font-family: var(--font-display);
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.01em;
	color: var(--forest);
}

.shop-card__name a {
	color: inherit;
	text-decoration: none;
	transition: color var(--dur-fast) ease;
}

.shop-card__name a:hover { color: var(--sky); }

.shop-card__desc {
	font-size: 0.9rem;
	line-height: 1.65;
	color: var(--text-muted);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.shop-card__price {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--rose);
	margin-top: 0.25rem;
}

.shop-card__price .woocommerce-Price-amount { color: inherit; }

.shop-card__actions {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: auto;
	padding-top: 1rem;
	flex-wrap: wrap;
}

.shop-card__view {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--text-muted);
	text-decoration: none;
	letter-spacing: 0.02em;
	transition: color var(--dur-fast) ease;
	white-space: nowrap;
}

.shop-card__view:hover { color: var(--sky); }

.shop-card__atc {
	flex: 1;
	text-align: center;
	font-size: 0.875rem;
	padding: 0.7em 1.4em;
}

.shop-card__oos-label {
	font-size: 0.8125rem;
	color: var(--text-light);
	font-weight: 500;
}

/* Empty state */
.shop-page__empty {
	text-align: center;
	padding-block: var(--space-xl);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
	color: var(--text-muted);
	font-size: 1.0625rem;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
	.hero__inner {
		padding-block: 5rem 4rem;
	}

	.hero__content {
		max-width: 100%;
	}

	.about__inner {
		grid-template-columns: 1fr;
		gap: 3rem;
	}

	.about__stats-col {
		flex-direction: row;
		flex-wrap: wrap;
	}

	.about__stat {
		flex: 1;
		min-width: 160px;
		flex-direction: column;
		gap: 0.25rem;
		padding: 1.25rem 0;
	}

	.product-showcase__grid {
		grid-template-columns: 1fr;
		gap: 3rem;
	}

	.product-showcase__image-wrap {
		aspect-ratio: 16/10;
		max-width: 520px;
		margin-inline: auto;
	}

	.product-showcase__ingredients-list {
		grid-template-columns: 1fr;
	}

	.cta-banner__leaf { display: none; }

	/* Products grids → 2 cols on tablet */
	.hp-products__grid,
	.shop-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	:root {
		--space-xl: 4.5rem;
	}

	.hero__actions {
		flex-direction: column;
		align-items: flex-start;
	}

	.benefits__grid {
		grid-template-columns: 1fr;
	}

	.ingredients__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.testimonials__grid {
		grid-template-columns: 1fr;
	}

	/* Products grids → 1 col on mobile */
	.hp-products__grid,
	.shop-grid {
		grid-template-columns: 1fr;
	}

	.shop-page__title { font-size: clamp(1.75rem, 8vw, 2.5rem); }
}

@media (prefers-reduced-motion: reduce) {
	.trust-bar__track,
	.hero__badge-dot { animation: none; }

	.reveal-up,
	.reveal-left,
	.reveal-right {
		opacity: 1;
		transform: none;
	}
}


/* ═══════════════════════════════════════════════════════════════
   BE PLANTLY — PRODUCT PAGE DESIGN SYSTEM
   ───────────────────────────────────────────────────────────────
   RULE: The background is ALWAYS --prod-bg (set per product via ACF).
   Everything on top uses the derived contrast tokens below.
   Never hardcode colours on product page sections — use tokens only.

   Token hierarchy:
     --prod-bg            → page/section background
     --prod-accent        → highlight: buttons, badges, icon rings
     --prod-on-bg         → primary text & icons on --prod-bg
     --prod-on-bg-muted   → secondary/body text on --prod-bg
     --prod-on-bg-subtle  → borders, dividers on --prod-bg
     --prod-on-accent     → text/icons on top of --prod-accent
     --prod-surface       → card/panel bg floating above --prod-bg
     --prod-surface-border→ card border colour

   Light bg  → on-bg is dark   (JS adds data-luminance="light")
   Dark bg   → on-bg is light  (JS adds data-luminance="dark")

   JS utility bpSetContrastTokens() in main.js computes these from
   the ACF hex value and writes them on .sp2-product-wrap at runtime.

   Typography:
     --font-product-display  Unbounded   (titles, CTA labels)
     --font-product-body     Outfit      (all other text)
═══════════════════════════════════════════════════════════════ */

/* ── Base product page tokens ───────────────────────────────────────────── */
.sp2-product-wrap {
	--font-product-display: 'Unbounded', 'Plus Jakarta Sans', sans-serif;
	--font-product-body:    'Outfit', 'Plus Jakarta Sans', sans-serif;

	/* Fallback contrast tokens — overwritten by JS based on actual bg colour */
	--prod-on-bg:           rgba(255, 255, 255, 1);
	--prod-on-bg-muted:     rgba(255, 255, 255, 0.70);
	--prod-on-bg-subtle:    rgba(255, 255, 255, 0.15);
	--prod-on-accent:       rgba(255, 255, 255, 1);
	--prod-surface:         rgba(255, 255, 255, 0.10);
	--prod-surface-border:  rgba(255, 255, 255, 0.20);
	--prod-card-shadow:     0 4px 24px rgba(0, 0, 0, 0.14);

	/* Legacy aliases kept for backwards compat with existing sp2 rules */
	--sp2-white:     var(--prod-on-bg);
	--sp2-white-80:  var(--prod-on-bg-muted);
	--sp2-white-50:  rgba(255, 255, 255, 0.50);
	--sp2-white-15:  var(--prod-on-bg-subtle);
	--sp2-white-08:  rgba(255, 255, 255, 0.08);
	--sp2-card-shadow: var(--prod-card-shadow);
}

/* Light-bg products (data-luminance="light" set by JS) */
.sp2-product-wrap[data-luminance="light"] {
	--prod-on-bg:          rgba(0,   0,   0,   0.85);
	--prod-on-bg-muted:    rgba(0,   0,   0,   0.55);
	--prod-on-bg-subtle:   rgba(0,   0,   0,   0.12);
	--prod-surface:        rgba(255, 255, 255, 0.75);
	--prod-surface-border: rgba(0,   0,   0,   0.10);
}

/* Dark-bg products (data-luminance="dark" set by JS — default) */
.sp2-product-wrap[data-luminance="dark"] {
	--prod-on-bg:          rgba(255, 255, 255, 1);
	--prod-on-bg-muted:    rgba(255, 255, 255, 0.70);
	--prod-on-bg-subtle:   rgba(255, 255, 255, 0.15);
	--prod-surface:        rgba(255, 255, 255, 0.10);
	--prod-surface-border: rgba(255, 255, 255, 0.20);
}

/* ── sp2-page wrapper (body-level) ──────────────────────────────────────── */
.sp2-page {
	background: var(--prod-bg, #2A4494);
	min-height: 100vh;
}

.sp2-page .woocommerce-notices-wrapper { display: none; }

/* ── Stage: 2-col grid ──────────────────────────────────────────────────── */
.sp2-stage {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: start;
	min-height: calc(100svh - 70px);
	max-width: 1400px;
	margin-inline: auto;
	padding: clamp(1rem, 2vw, 2rem) clamp(1rem, 3vw, 2.5rem);
	gap: clamp(2rem, 5vw, 4rem);
}

/* ── Left col: image stack ──────────────────────────────────────────────── */
.sp2-visual-stack {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	position: sticky;
	top: 90px;
}

/* Image wrap — holds halo + gallery + nav zones */
.sp2-visual-wrap {
	position: relative;
	width: 100%;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 0;
	/* Overflow visible so the halo circle can bleed out if needed */
	overflow: visible;
}

/* Translucent circle halo */
.sp2-halo {
	position: absolute;
	width: 90%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
	pointer-events: none;
	/* Anchor halo to bottom so it doesn't push the image down */
	bottom: 0;
	top: auto;
}

.sp2-gallery {
	/* Square container — matches product image dimensions exactly so the
	   nav hover zone never extends beyond the visible image. */
	position: relative;
	z-index: 1;
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: 16px;
}

/* ── Glow circle behind product image ───────────────────────────────────── */
.sp2-glow-splatter {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

.sp2-glow-splatter::after {
	content: '';
	position: absolute;
	width: 78%;
	aspect-ratio: 1 / 1;
	left: 50%;
	top: 58%;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	background: radial-gradient(
		circle at center,
		color-mix(in srgb, var(--prod-accent, #1B3A2D) 25%, white) 0%,
		color-mix(in srgb, var(--prod-accent, #1B3A2D) 65%, white) 40%,
		var(--prod-accent, #1B3A2D) 70%,
		transparent 100%
	);
	filter: blur(28px);
	opacity: 0.5;
}

.sp2-gallery__img {
	/* Absolute fill — object-fit:cover ensures every image fills the box */
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	opacity: 0;
	transition: opacity 0.42s ease;
	pointer-events: none;
	user-select: none;
	-webkit-user-drag: none;
}

.sp2-gallery__img.is-active {
	opacity: 1;
}

.sp2-gallery__placeholder {
	position: absolute;
	inset: 0;
	background: rgba(255,255,255,0.08);
}

/* ── Gallery navigation halves ──────────────────────────────────────────── */
/* Each button covers exactly 50% of the container.
   Cursor is a product-accent-coloured circle arrow, set by JS.
   Fallback cursors keep it usable before JS runs. */
.sp2-nav-prev,
.sp2-nav-next {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 50%;
	z-index: 4;
	background: transparent;
	border: none;
	padding: 0;
	appearance: none;
	-webkit-appearance: none;
	/* Fallback cursors before JS injects the SVG ones */
	cursor: w-resize;
}

.sp2-nav-prev { left: 0;  cursor: w-resize; }
.sp2-nav-next { right: 0; cursor: e-resize; }

/* No overlay on hover — cursor change is the only interaction cue */
.sp2-nav-prev:hover,
.sp2-nav-next:hover {
	background: transparent;
}

.sp2-gallery__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.5;
}


/* ── Bottom thumbnail strip ─────────────────────────────────────────────── */
.sp2-thumbs-strip {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: center;
	padding: 0;
	margin-top: 0;
}

.sp2-thumb {
	width: 68px;
	height: 68px;
	border-radius: 10px;
	border: 2px solid var(--sp2-white-15);
	background: var(--sp2-white-08);
	overflow: hidden;
	cursor: pointer;
	padding: 0;
	transition: border-color 0.2s ease, transform 0.2s ease;
	flex-shrink: 0;
}

.sp2-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sp2-thumb.is-active {
	border-color: var(--sp2-white);
	transform: scale(1.08);
	box-shadow: 0 2px 10px rgba(0,0,0,0.2);
}

.sp2-thumb:hover:not(.is-active) {
	border-color: var(--sp2-white-50);
	transform: scale(1.04);
}

.sp2-gallery__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.5;
}

/* ── Col 3: Product info ────────────────────────────────────────────────── */
.sp2-info {
	padding: 1rem 0 1rem 1.5rem;
	color: var(--sp2-white);
}

/* Category */
.sp2-category {
	font-family: var(--font-product-body);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--prod-accent);
	margin-bottom: 0.5rem;
}

.sp2-category a { color: inherit; }

/* Product title — Unbounded ExtraBold uppercase */
.sp2-title {
	font-family: var(--font-product-display);
	font-size: clamp(1.75rem, 3.2vw, 2.875rem);
	font-weight: 900;
	line-height: 1.02;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--prod-accent);
	margin-bottom: 0.4rem;
}

/* Subtitle (short description / product type) */
.sp2-subtitle {
	font-family: var(--font-product-body);
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--sp2-white-80);
	margin-bottom: 0.5rem;
}

/* Ingredients italic tagline */
.sp2-ingredients {
	font-family: var(--font-product-body);
	font-size: 0.9375rem;
	font-style: italic;
	color: var(--sp2-white-80);
	margin-bottom: 1.25rem;
	line-height: 1.4;
}

/* Rating */
.sp2-rating {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1.5rem;
}

.sp2-rating .star-rating,
.sp2-rating .woocommerce-product-rating {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	color: #FFD166;
}

.sp2-rating__count {
	font-size: 0.875rem;
	color: var(--sp2-white-80);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* ── Benefit boxes (from WC attributes) ─────────────────────────────────── */
.sp2-benefit-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.65rem;
	margin-bottom: 1.75rem;
}

.sp2-benefit-box {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	background: color-mix(in srgb, var(--prod-accent, #1B3A2D) 8%, white);
	border: 1px solid color-mix(in srgb, var(--prod-accent, #1B3A2D) 18%, white);
	border-radius: 12px;
	padding: 0.8rem 1rem;
	box-shadow: 0 2px 12px color-mix(in srgb, var(--prod-accent, #1B3A2D) 15%, transparent);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.sp2-benefit-box:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px color-mix(in srgb, var(--prod-accent, #1B3A2D) 22%, transparent);
}

.sp2-benefit-box__ring {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--prod-accent, #1B3A2D) 15%, white);
	border: 2px solid color-mix(in srgb, var(--prod-accent, #1B3A2D) 28%, white);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--prod-accent, #1B3A2D);
	flex-shrink: 0;
}

.sp2-benefit-box__label {
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--prod-accent, #1B3A2D);
	line-height: 1.3;
}

/* ── Pincode delivery estimator ─────────────────────────────────────────── */
.sp2-pincode-wrap {
	margin-bottom: 1.25rem;
	border: 1px solid var(--prod-on-bg-subtle, rgba(0,0,0,0.1));
	border-radius: 14px;
	padding: 1rem 1.1rem;
	background: color-mix(in srgb, var(--prod-accent, #1B3A2D) 5%, white);
}

.sp2-pincode-header {
	display: flex;
	align-items: flex-start;
	gap: 0.45rem;
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.4;
	color: var(--prod-on-bg, #1B3A2D);
	margin-bottom: 0.75rem;
}

.sp2-pincode-header svg {
	flex-shrink: 0;
	margin-top: 2px;
	color: var(--prod-accent, #1B3A2D);
}

.sp2-pincode-header strong {
	color: var(--prod-accent, #1B3A2D);
	font-weight: 700;
}

.sp2-pincode-row {
	display: flex;
	gap: 0.5rem;
}

.sp2-pincode-input {
	flex: 1;
	font-family: var(--font-product-body);
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	color: var(--prod-on-bg, #1B3A2D);
	background: transparent;
	border: 2px solid var(--prod-on-bg-subtle, rgba(0,0,0,0.15));
	border-radius: 10px;
	padding: 0.6rem 0.85rem;
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	-moz-appearance: textfield;
}

.sp2-pincode-input::placeholder {
	letter-spacing: 0.04em;
	font-weight: 400;
	color: var(--prod-on-bg-muted, rgba(0,0,0,0.4));
}

.sp2-pincode-input::-webkit-outer-spin-button,
.sp2-pincode-input::-webkit-inner-spin-button { -webkit-appearance: none; }

.sp2-pincode-input:focus {
	border-color: var(--prod-accent, #1B3A2D);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--prod-accent, #1B3A2D) 18%, transparent);
}

.sp2-pincode-input.is-error {
	border-color: #e53e3e;
	animation: pinShake 0.4s ease;
}

@keyframes pinShake {
	0%, 100% { transform: translateX(0); }
	25%       { transform: translateX(-5px); }
	75%       { transform: translateX(5px); }
}

.sp2-pincode-btn {
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 0 1.2rem;
	border-radius: 10px;
	border: none;
	background: var(--prod-accent, #1B3A2D);
	color: var(--prod-on-accent, #fff);
	cursor: pointer;
	white-space: nowrap;
	transition: filter 0.2s ease;
	min-width: 72px;
}

.sp2-pincode-btn:hover  { filter: brightness(1.15); }
.sp2-pincode-btn:disabled { opacity: 0.6; cursor: default; }

/* Result states */
.sp2-pincode-result {
	margin-top: 0.75rem;
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
}

.sp2-pincode-checking {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--prod-on-bg-muted, rgba(0,0,0,0.55));
}

.sp2-pincode-dots {
	display: inline-flex;
	gap: 3px;
}

.sp2-pincode-dots span {
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: currentColor;
	animation: pinDot 1.1s ease-in-out infinite;
}

.sp2-pincode-dots span:nth-child(2) { animation-delay: 0.18s; }
.sp2-pincode-dots span:nth-child(3) { animation-delay: 0.36s; }

@keyframes pinDot {
	0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
	40%           { transform: scale(1);   opacity: 1;   }
}

/* ── Delivery timeline tracker ───────────────────────────────────────────── */
@keyframes pinFadeUp {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

.sp2-delivery-track {
	display: flex;
	align-items: center;
	background: var(--prod-accent, #1B3A2D);
	border-radius: 12px;
	padding: 1.1rem 1.25rem;
	animation: pinFadeUp 0.4s ease both;
	margin-top: 0.1rem;
}

/* Step */
.sp2-dt__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.45rem;
	flex: 0 0 auto;
}

/* Connecting line between steps */
.sp2-dt__line {
	flex: 1;
	height: 2px;
	background: rgba(255, 255, 255, 0.35);
	margin-bottom: 2rem; /* offset to align with icon centres */
}

/* Icon circle */
.sp2-dt__icon {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: #fff;
	color: var(--prod-accent, #1B3A2D);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.sp2-dt__label {
	font-family: var(--font-product-body);
	font-size: 0.75rem;
	font-weight: 700;
	color: #fff;
	text-align: center;
	white-space: nowrap;
}

.sp2-dt__date {
	font-family: var(--font-product-body);
	font-size: 0.6875rem;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.75);
	text-align: center;
	white-space: nowrap;
}

/* Confirm line below tracker */
.sp2-pincode-confirm {
	font-family: var(--font-product-body);
	font-size: 0.75rem;
	color: var(--prod-on-bg-muted, rgba(0,0,0,0.55));
	margin-top: 0.55rem;
	line-height: 1.4;
}

.sp2-pincode-confirm strong {
	color: var(--prod-accent, #1B3A2D);
	font-weight: 700;
}

/* ── WooCommerce cart form ──────────────────────────────────────────────── */
.sp2-cart-wrap {
	margin-bottom: 1.25rem;
}

/* Variations table label */
.sp2-cart-wrap .variations {
	border: none;
	width: 100%;
	margin-bottom: 0.75rem;
}

.sp2-cart-wrap .variations td,
.sp2-cart-wrap .variations th {
	padding: 0;
	display: block;
	border: none;
}

.sp2-cart-wrap .variations .label {
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	font-weight: 700;
	color: var(--sp2-white);
	margin-bottom: 0.55rem;
}

.sp2-cart-wrap .variations .label label::after {
	content: ' :';
}

/* Hide raw WC select — JS replaces with .sp2-swatches */
.sp2-cart-wrap .variations select,
.sp2-cart-wrap .reset_variations {
	display: none;
}

/* Variation availability text */
.sp2-cart-wrap .woocommerce-variation-availability p {
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	color: var(--sp2-white-80);
	margin-bottom: 0.75rem;
}

/* Pill swatch button group (injected by JS) */
.sp2-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1.25rem;
}

.sp2-swatch-btn {
	font-family: var(--font-product-body);
	font-size: 0.875rem;
	font-weight: 600;
	padding: 0.5em 1.4em;
	border-radius: var(--radius-xl);
	border: 2px solid var(--sp2-white-50);
	background: transparent;
	color: var(--sp2-white);
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.sp2-swatch-btn:hover {
	border-color: var(--sp2-white);
	background: var(--sp2-white-15);
}

.sp2-swatch-btn.is-active {
	background: var(--sp2-white);
	border-color: var(--sp2-white);
	color: var(--prod-bg, #2A4494);
}

/* Quantity + Add to Cart row */
.sp2-cart-wrap .cart,
.sp2-cart-wrap .woocommerce-variation-add-to-cart {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0;
}

/* Quantity control — hidden; cart button spans full width */
.sp2-cart-wrap .quantity {
	display: none;
}

.sp2-cart-wrap .qty-btn {
	width: 44px;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	color: var(--sp2-white);
	cursor: pointer;
	font-size: 1.1rem;
	transition: background 0.15s ease;
}

.sp2-cart-wrap .qty-btn:hover {
	background: var(--sp2-white-15);
}

.sp2-cart-wrap .input-text.qty {
	width: 48px;
	height: 100%;
	text-align: center;
	border: none;
	border-inline: 1px solid var(--sp2-white-50);
	background: transparent;
	font-family: var(--font-product-body);
	font-size: 1rem;
	font-weight: 700;
	color: var(--sp2-white);
	-moz-appearance: textfield;
}

.sp2-cart-wrap .input-text.qty::-webkit-outer-spin-button,
.sp2-cart-wrap .input-text.qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

/* Add to Cart button — accent colour */
.sp2-cart-wrap .single_add_to_cart_button,
.sp2-cart-wrap button[type="submit"].button {
	flex: 1;
	font-family: var(--font-product-display);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0 2em;
	height: 52px;
	border-radius: var(--radius-xl);
	border: none;
	background: var(--prod-accent, #1B3A2D);
	color: #fff;
	cursor: pointer;
	transition: filter 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
	white-space: nowrap;
}

.sp2-cart-wrap .single_add_to_cart_button:hover {
	filter: brightness(1.07);
	box-shadow:
		0 4px 20px rgba(0, 0, 0, 0.25),
		0 0 0 4px color-mix(in srgb, var(--prod-accent, #1B3A2D) 20%, transparent);
}

.sp2-cart-wrap .single_add_to_cart_button:active {
	transform: translateY(0);
	filter: brightness(0.95);
}

/* ── Related products mini-slider ───────────────────────────────────────── */
.sp2-mini-slider {
	position: relative;
	padding: 1.5rem 3rem;
	background: color-mix(in srgb, var(--prod-bg, #EAF2ED) 85%, black);
}

.sp2-mini-slider__track {
	display: flex;
	gap: 0.85rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding: 0.5rem 0.25rem;
}

.sp2-mini-slider__track::-webkit-scrollbar { display: none; }

/* Each related product item — image only */
.sp2-mini-item {
	position: relative;
	flex-shrink: 0;
	width: 72px;
	height: 72px;
	border-radius: 50%;
	overflow: visible; /* tooltip needs to escape */
	display: block;
	scroll-snap-align: start;
	transition: transform 0.2s ease;
}

.sp2-mini-item img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	border: 2px solid rgba(255,255,255,0.25);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.sp2-mini-item__fallback {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-product-display);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--sp2-white);
	background: var(--sp2-white-15);
	border: 2px solid rgba(255,255,255,0.25);
	text-transform: uppercase;
}

.sp2-mini-item:hover {
	transform: translateY(-4px) scale(1.06);
}

.sp2-mini-item:hover img {
	border-color: rgba(255,255,255,0.9);
	box-shadow: 0 6px 20px rgba(0,0,0,0.2);
}

/* Tooltip — pure CSS via data-tooltip attribute */
.sp2-mini-item::after {
	content: attr(data-tooltip);
	position: absolute;
	bottom: calc(100% + 10px);
	left: 50%;
	transform: translateX(-50%) translateY(6px);
	background: var(--bark, #2C1F14);
	color: #fff;
	font-family: var(--font-product-body);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	white-space: nowrap;
	padding: 0.4em 0.85em;
	border-radius: 6px;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.18s ease, transform 0.18s ease;
	z-index: 20;
}

.sp2-mini-item::before {
	content: '';
	position: absolute;
	bottom: calc(100% + 4px);
	left: 50%;
	transform: translateX(-50%) translateY(6px);
	border: 5px solid transparent;
	border-top-color: var(--bark, #2C1F14);
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.18s ease, transform 0.18s ease;
	z-index: 20;
}

.sp2-mini-item:hover::after,
.sp2-mini-item:hover::before {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

/* Prev / Next arrow buttons */
.sp2-mini-slider__btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,0.2);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.15s ease;
	z-index: 2;
	backdrop-filter: blur(8px);
}

.sp2-mini-slider__btn:hover {
	background: rgba(255,255,255,0.35);
	transform: translateY(-50%) scale(1.08);
}

.sp2-mini-slider__btn--prev { left: 0.5rem; }
.sp2-mini-slider__btn--next { right: 0.5rem; }

/* ── Price row ──────────────────────────────────────────────────────────── */
.sp2-price-row {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1rem;
	margin-top: 1.25rem;
	flex-wrap: wrap;
}

.sp2-price-figures {
	display: flex;
	align-items: baseline;
	flex-direction: column;
	gap: 0.2rem;
}

.sp2-price-figures .price {
	font-family: var(--font-product-display);
	font-size: 1.625rem;
	font-weight: 700;
	color: #000;
	display: flex;
	align-items: baseline;
	gap: 0.6rem;
}

.sp2-price-figures .price del {
	font-size: 1rem;
	font-weight: 400;
	color: #000;
	text-decoration: line-through;
}

.sp2-price-figures .price ins {
	text-decoration: none;
	color: #000;
}

.sp2-tax-note {
	font-family: var(--font-product-body);
	font-size: 0.75rem;
	color: #000;
}

/* Sale badge — prominent, bright */
.sp2-sale-badge {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-product-display);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	padding: 0.4em 1em;
	border-radius: 6px;
	background: #FF3D5A;
	color: #fff;
	box-shadow: 0 3px 12px rgba(255, 61, 90, 0.4);
	white-space: nowrap;
	animation: badgePop 0.4s var(--ease-out) both;
}

@keyframes badgePop {
	from { transform: scale(0.8); opacity: 0; }
	to   { transform: scale(1);   opacity: 1; }
}

/* ── Subscribe & Save row ───────────────────────────────────────────────── */
.sp2-subscribe-row {
	display: flex;
	gap: 0.6rem;
	margin-bottom: 1.25rem;
	flex-wrap: wrap;
}

.sp2-sub-option {
	flex: 1;
	min-width: 160px;
	display: flex;
	align-items: center;
	gap: 0.7rem;
	padding: 0.75rem 1rem;
	border-radius: 10px;
	border: 2px solid var(--sp2-white-15);
	cursor: pointer;
	transition: border-color 0.2s ease, background 0.2s ease;
	flex-wrap: wrap;
}

.sp2-sub-option:hover {
	border-color: var(--sp2-white-50);
}

.sp2-sub-option.is-selected {
	border-color: var(--sp2-white);
	background: var(--sp2-white-08);
}

.sp2-sub-option__dot {
	width: 16px;
	height: 16px;
	border-radius: 50%;
	border: 2px solid var(--sp2-white-50);
	flex-shrink: 0;
	position: relative;
	transition: border-color 0.2s ease;
}

.sp2-sub-option.is-selected .sp2-sub-option__dot {
	border-color: var(--sp2-white);
}

.sp2-sub-option.is-selected .sp2-sub-option__dot::after {
	content: '';
	position: absolute;
	inset: 3px;
	border-radius: 50%;
	background: var(--sp2-white);
}

.sp2-sub-option__label {
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--sp2-white);
	flex: 1;
}

.sp2-sub-option__label strong {
	color: #FFD166;
}

.sp2-sub-option__note {
	display: block;
	width: 100%;
	font-size: 0.6875rem;
	color: var(--sp2-white-50);
	padding-left: calc(16px + 0.7rem);
}

/* ── Shipping note ──────────────────────────────────────────────────────── */
.sp2-shipping-note {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	color: var(--sp2-white-80);
	margin-top: 0.85rem;
}

/* ── Sticky buy bar ─────────────────────────────────────────────────────── */
.sp2-sticky-bar {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 190;
	/* Hidden below the viewport by default */
	transform: translateY(100%);
	transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
	pointer-events: none;
}

.sp2-sticky-bar.is-visible {
	transform: translateY(0);
	pointer-events: auto;
}

.sp2-sticky-bar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.85rem 1.5rem;
	background: color-mix(in srgb, var(--prod-bg, #EAF2ED) 82%, transparent);
	backdrop-filter: blur(28px) saturate(1.5);
	-webkit-backdrop-filter: blur(28px) saturate(1.5);
	border-top: 1px solid var(--prod-on-bg-subtle, rgba(0,0,0,0.1));
	border-radius: 20px 20px 0 0;
	max-width: var(--container);
	margin-inline: auto;
}

.sp2-sticky-bar__product {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	min-width: 0;
}

.sp2-sticky-bar__img {
	width: 52px;
	height: 52px;
	border-radius: 10px;
	overflow: hidden;
	flex-shrink: 0;
	background: transparent;
}

.sp2-sticky-bar__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sp2-sticky-bar__meta {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 0;
}

.sp2-sticky-bar__name {
	font-family: var(--font-product-display);
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--prod-accent, #1B3A2D);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.sp2-sticky-bar__price {
	font-family: var(--font-product-body);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--prod-on-bg, #1B3A2D);
}

.sp2-sticky-bar__price .price {
	font-size: inherit;
	color: inherit;
}

/* USPs — centre column, desktop only */
.sp2-sticky-bar__usps {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	flex-shrink: 0;
}

.sp2-sticky-bar__usp {
	display: flex;
	align-items: center;
	gap: 0.45rem;
}

.sp2-sticky-bar__usp-icon {
	color: var(--prod-accent, #1B3A2D);
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.sp2-sticky-bar__usp-label {
	font-family: var(--font-product-body);
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--prod-on-bg, #1B3A2D);
	white-space: nowrap;
}

@media (max-width: 768px) {
	.sp2-sticky-bar__usps { display: none; }
}

.sp2-sticky-bar__cta {
	font-family: var(--font-product-display);
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.7em 1.8em;
	border-radius: var(--radius-xl);
	border: none;
	background: var(--prod-accent, #1B3A2D);
	color: var(--prod-on-accent, #fff);
	cursor: pointer;
	white-space: nowrap;
	flex-shrink: 0;
	transition: filter 0.2s ease, transform 0.15s ease;
}

.sp2-sticky-bar__cta:hover {
	filter: brightness(1.15);
	transform: translateY(-1px);
}

@media (max-width: 520px) {
	.sp2-sticky-bar__inner {
		padding: 0.75rem 1rem;
		gap: 0.75rem;
	}
	.sp2-sticky-bar__img { display: none; }
	.sp2-sticky-bar__name { font-size: 0.8125rem; }
}

/* ── Trust badges strip ─────────────────────────────────────────────────── */
.sp2-trust-strip {
	background: var(--prod-bg, #EAF2ED);
	padding: 3rem 0 2.5rem;
	border-top: 1px solid var(--prod-on-bg-subtle, rgba(0,0,0,0.08));
}

.sp2-trust-strip__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem 1.5rem;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 5vw, 3rem);
}

.sp2-trust-badge {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.85rem;
}

.sp2-trust-badge__icon {
	width: 64px;
	height: 64px;
	color: var(--prod-on-bg, #1B3A2D);
	flex-shrink: 0;
}

.sp2-trust-badge__icon svg {
	width: 100%;
	height: 100%;
}

.sp2-trust-badge__title {
	font-family: var(--font-product-body);
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--prod-on-bg, #1B3A2D);
	margin: 0;
	line-height: 1.3;
}

.sp2-trust-badge__desc {
	font-family: var(--font-product-body);
	font-size: 0.875rem;
	font-weight: 400;
	color: var(--prod-on-bg-muted, rgba(0,0,0,0.6));
	line-height: 1.55;
	margin: 0;
}

@media (max-width: 768px) {
	.sp2-trust-strip__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 2rem;
	}
}

@media (max-width: 480px) {
	.sp2-trust-strip__grid {
		grid-template-columns: 1fr 1fr;
		gap: 1.5rem;
	}
	.sp2-trust-badge__icon { width: 52px; height: 52px; }
	.sp2-trust-badge__desc { display: none; }
}

/* ── Tabs section ───────────────────────────────────────────────────────── */
.sp2-tabs-section {
	background: var(--prod-bg);
	padding-block: var(--space-lg);
}

.sp2-tabs-section .woocommerce-tabs ul.tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--prod-on-bg-subtle);
	margin-bottom: 2.5rem;
	padding: 0;
	list-style: none;
}

.sp2-tabs-section .woocommerce-tabs ul.tabs li a {
	display: block;
	font-family: var(--font-product-body);
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--prod-on-bg-muted);
	padding: 0.85rem 1.5rem;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color 0.2s ease, border-color 0.2s ease;
}

.sp2-tabs-section .woocommerce-tabs ul.tabs li.active a,
.sp2-tabs-section .woocommerce-tabs ul.tabs li a:hover {
	color: var(--prod-on-bg);
	border-bottom-color: var(--prod-accent);
}

.sp2-tabs-section .woocommerce-tabs .panel {
	max-width: 780px;
	font-family: var(--font-product-body);
	font-size: 1rem;
	line-height: 1.8;
	color: var(--prod-on-bg-muted);
}

.sp2-tabs-section .woocommerce-tabs .panel h2 {
	font-family: var(--font-product-display);
	font-size: 1.1rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--prod-on-bg);
	margin-bottom: 1rem;
}

.sp2-tabs-section .woocommerce-tabs .panel p,
.sp2-tabs-section .woocommerce-tabs .panel li {
	color: var(--prod-on-bg-muted);
}

.sp2-tabs-section .woocommerce-tabs .panel a {
	color: var(--prod-accent);
}

/* Product benefits list (from description) */
.product-benefits-list {
	list-style: none;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.product-benefits-list li {
	padding: 1rem 1.25rem;
	background: var(--prod-surface);
	border-radius: var(--radius-md);
	border-left: 3px solid var(--prod-accent);
	font-size: 0.9375rem;
	line-height: 1.7;
	color: var(--prod-on-bg-muted);
}

.product-benefits-list li strong {
	display: block;
	color: var(--prod-on-bg);
	font-size: 1rem;
	margin-bottom: 0.2rem;
}

/* Additional info (attributes) table */
.sp2-tabs-section .woocommerce-product-attributes {
	width: 100%;
	border-collapse: collapse;
}

.sp2-tabs-section .woocommerce-product-attributes th,
.sp2-tabs-section .woocommerce-product-attributes td {
	padding: 0.75rem 1rem;
	text-align: left;
	font-family: var(--font-product-body);
	font-size: 0.9375rem;
	border-bottom: 1px solid var(--prod-on-bg-subtle);
}

.sp2-tabs-section .woocommerce-product-attributes th {
	font-weight: 700;
	color: var(--prod-on-bg);
	width: 35%;
	background: var(--prod-surface);
}

.sp2-tabs-section .woocommerce-product-attributes td {
	color: var(--prod-on-bg-muted);
}

/* ── Reviews tab ─────────────────────────────────────────────────────────── */

.sp2-tabs-section #reviews {
	max-width: 780px;
}

.sp2-tabs-section #reviews h2,
.sp2-tabs-section #reviews .woocommerce-Reviews-title {
	font-family: var(--font-product-display);
	font-size: 1.1rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--prod-on-bg);
	margin-bottom: 2rem;
}

/* Review list */
.sp2-tabs-section #comments .commentlist {
	list-style: none;
	padding: 0;
	margin: 0 0 3rem;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.sp2-tabs-section #comments .comment_container {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
}

.sp2-tabs-section #comments .comment_container .avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	flex-shrink: 0;
	object-fit: cover;
	border: 2px solid var(--prod-on-bg-subtle);
}

.sp2-tabs-section #comments .comment-text {
	flex: 1;
	background: var(--prod-surface);
	border: 1px solid var(--prod-on-bg-subtle);
	border-radius: var(--radius-md);
	padding: 1.25rem 1.5rem;
}

.sp2-tabs-section #comments .star-rating {
	margin-bottom: 0.6rem;
}

.sp2-tabs-section #comments .star-rating::before,
.sp2-tabs-section #comments .star-rating span::before {
	color: var(--prod-accent);
}

.sp2-tabs-section #comments p.meta {
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	color: var(--prod-on-bg-muted);
	margin-bottom: 0.75rem;
}

.sp2-tabs-section #comments p.meta strong.woocommerce-review__author {
	color: var(--prod-on-bg);
	font-weight: 700;
	font-size: 0.9375rem;
}

.sp2-tabs-section #comments .description p {
	font-family: var(--font-product-body);
	font-size: 0.9375rem;
	line-height: 1.75;
	color: var(--prod-on-bg-muted);
	margin: 0;
}

.sp2-tabs-section .woocommerce-noreviews {
	font-family: var(--font-product-body);
	color: var(--prod-on-bg-muted);
	font-size: 0.9375rem;
	padding: 1.5rem 0;
}

/* Review form */
.sp2-tabs-section #review_form_wrapper {
	border-top: 1px solid var(--prod-on-bg-subtle);
	padding-top: 2.5rem;
	margin-top: 1rem;
}

.sp2-tabs-section #review_form #reply-title {
	font-family: var(--font-product-display);
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--prod-on-bg);
	margin-bottom: 1.5rem;
}

.sp2-tabs-section #review_form label {
	font-family: var(--font-product-body);
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--prod-on-bg-muted);
	display: block;
	margin-bottom: 0.4rem;
}

.sp2-tabs-section #review_form .comment-form-rating .stars {
	display: flex;
	gap: 0.25rem;
	margin-bottom: 1rem;
}

.sp2-tabs-section #review_form .comment-form-rating .stars a {
	font-size: 1.5rem;
	color: var(--prod-on-bg-subtle);
	transition: color 0.15s ease;
}

.sp2-tabs-section #review_form .comment-form-rating .stars a:hover,
.sp2-tabs-section #review_form .comment-form-rating .stars a.active,
.sp2-tabs-section #review_form .comment-form-rating .stars.selected a {
	color: var(--prod-accent);
}

.sp2-tabs-section #review_form input[type="text"],
.sp2-tabs-section #review_form input[type="email"],
.sp2-tabs-section #review_form textarea {
	width: 100%;
	background: var(--prod-surface);
	border: 1px solid var(--prod-on-bg-subtle);
	border-radius: var(--radius-sm);
	padding: 0.75rem 1rem;
	font-family: var(--font-product-body);
	font-size: 0.9375rem;
	color: var(--prod-on-bg);
	outline: none;
	transition: border-color 0.2s ease;
}

.sp2-tabs-section #review_form input[type="text"]:focus,
.sp2-tabs-section #review_form input[type="email"]:focus,
.sp2-tabs-section #review_form textarea:focus {
	border-color: var(--prod-accent);
}

.sp2-tabs-section #review_form input[type="text"]::placeholder,
.sp2-tabs-section #review_form input[type="email"]::placeholder,
.sp2-tabs-section #review_form textarea::placeholder {
	color: var(--prod-on-bg-muted);
	opacity: 0.6;
}

.sp2-tabs-section #review_form .comment-form-comment,
.sp2-tabs-section #review_form .comment-form-author,
.sp2-tabs-section #review_form .comment-form-email {
	margin-bottom: 1.25rem;
}

.sp2-tabs-section #review_form input[type="submit"] {
	font-family: var(--font-product-display);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background: var(--prod-accent);
	color: var(--prod-on-accent);
	border: 2px solid var(--prod-accent);
	border-radius: var(--radius-xl);
	padding: 0.85em 2.2em;
	cursor: pointer;
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.sp2-tabs-section #review_form input[type="submit"]:hover {
	opacity: 0.88;
	transform: translateY(-2px);
}

/* ── Related products ───────────────────────────────────────────────────── */
.sp2-related-section {
	background: var(--prod-bg);
	padding-block: var(--space-lg);
	border-top: 1px solid var(--prod-on-bg-subtle);
}

.sp2-related-section .related h2 {
	font-family: var(--font-product-display);
	font-size: clamp(0.9rem, 1.8vw, 1.25rem);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--prod-on-bg);
	margin-bottom: 2rem;
}

.sp2-related-section ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1.5rem;
	list-style: none;
	padding: 0;
}

.sp2-related-section ul.products li.product {
	background: var(--prod-surface);
	border: 1px solid var(--prod-on-bg-subtle);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: transform 0.25s var(--ease-out), box-shadow 0.25s ease;
}

.sp2-related-section ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: var(--prod-card-shadow);
}

.sp2-related-section ul.products li.product a img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
}

.sp2-related-section ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--font-product-display);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--prod-on-bg);
	padding: 0.75rem 1rem 0.25rem;
}

.sp2-related-section ul.products li.product .price {
	font-family: var(--font-product-body);
	font-weight: 600;
	color: var(--prod-accent);
	padding: 0 1rem 1rem;
	display: block;
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
	.sp2-stage {
		grid-template-columns: 1fr 1fr;
		gap: 2rem;
	}
}

@media (max-width: 860px) {
	.sp2-stage {
		grid-template-columns: 1fr;
		min-height: unset;
		padding-top: 2rem;
	}

	.sp2-visual-stack {
		position: static; /* disable sticky on mobile */
	}

	.sp2-gallery {
		width: min(280px, 80vw);
	}

	.sp2-halo {
		width: min(320px, 88vw);
	}

	.sp2-info {
		padding: 0 0 2rem;
	}

	.sp2-benefit-grid {
		grid-template-columns: 1fr 1fr;
	}

}

@media (max-width: 520px) {
	.sp2-benefit-grid {
		grid-template-columns: 1fr;
	}

	.sp2-cart-wrap .cart,
	.sp2-cart-wrap .woocommerce-variation-add-to-cart {
		flex-wrap: wrap;
	}

	.sp2-cart-wrap .single_add_to_cart_button {
		width: 100%;
		text-align: center;
	}

	.sp2-title {
		font-size: 2rem;
	}
}

/* ═══════════════════════════════════════════════════════════════
   WOOCOMMERCE — SINGLE PRODUCT PAGE
   2-column OLIPOP-style layout.
   Accent colour driven by --prod-accent CSS var (set inline from ACF).
   Image panel bg driven by --prod-bg CSS var.
═══════════════════════════════════════════════════════════════ */

/* Strip WooCommerce's default notices/breadcrumb margin on product pages */
.single-product-page .woocommerce-notices-wrapper { display: none; }

/* ── Layout ──────────────────────────────────────────────────────────────── */

.single-product-page {
	background: var(--cream);
}

.sp-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: calc(100svh - 70px);
}

/* ── Left: image panel ───────────────────────────────────────────────────── */

.sp-image-panel {
	position: relative;
	background: var(--prod-bg, #EAF2ED);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: clamp(2rem, 6vw, 5rem) clamp(1.5rem, 4vw, 4rem);
	min-height: 520px;
	overflow: hidden;
}

.sp-image-panel::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 20% 20%, rgba(255,255,255,0.25) 0%, transparent 50%),
		radial-gradient(circle at 80% 80%, rgba(0,0,0,0.06) 0%, transparent 50%);
	pointer-events: none;
}

.sp-top-badge {
	position: absolute;
	top: 1.75rem;
	left: 50%;
	transform: translateX(-50%);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background: var(--prod-accent, #1B3A2D);
	color: #fff;
	border-radius: var(--radius-xl);
	padding: 0.4em 1.25em;
	white-space: nowrap;
	z-index: 2;
}

/* Gallery */
.sp-gallery {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.25rem;
	width: 100%;
	position: relative;
	z-index: 1;
}

.sp-gallery__main {
	width: min(400px, 90%);
	aspect-ratio: 3/4;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.sp-gallery__img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: none;
	drop-shadow: drop-shadow(0 20px 40px rgba(0,0,0,0.15));
	filter: drop-shadow(0 20px 40px rgba(0,0,0,0.15));
	transition: opacity 0.3s ease;
}

.sp-gallery__img.is-active { display: block; }

.sp-gallery__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.sp-gallery__thumbs {
	display: flex;
	gap: 0.6rem;
	justify-content: center;
	flex-wrap: wrap;
}

.sp-gallery__thumb {
	width: 56px;
	height: 56px;
	border-radius: var(--radius-sm);
	border: 2px solid rgba(255,255,255,0.4);
	background: rgba(255,255,255,0.2);
	overflow: hidden;
	cursor: pointer;
	padding: 0;
	transition: border-color 0.2s ease, transform 0.2s ease;
}

.sp-gallery__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sp-gallery__thumb.is-active {
	border-color: var(--prod-accent, #1B3A2D);
	transform: scale(1.08);
}

.sp-gallery__thumb:hover {
	border-color: rgba(255,255,255,0.9);
}

/* ── Right: info panel ───────────────────────────────────────────────────── */

.sp-info-panel {
	padding: clamp(2.5rem, 5vw, 4.5rem) clamp(1.5rem, 5vw, 4rem);
	display: flex;
	flex-direction: column;
	gap: 0;
	background: var(--cream);
	overflow-y: auto;
}

.sp-info-badge {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--prod-accent, #1B3A2D);
	text-decoration: underline;
	text-underline-offset: 3px;
	margin-bottom: 0.6rem;
}

.sp-title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 3.5vw, 3.25rem);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.025em;
	color: var(--forest);
	margin-bottom: 0.6rem;
}

.sp-tagline {
	font-size: 1rem;
	color: var(--text-muted);
	font-style: italic;
	margin-bottom: 0.85rem;
	line-height: 1.5;
}

/* Rating row */
.sp-rating-row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1.25rem;
}

.sp-rating-row .woocommerce-product-rating {
	display: flex;
	align-items: center;
	gap: 0.4rem;
}

.sp-rating-row .star-rating {
	font-size: 0.9rem;
	color: var(--golden);
}

.sp-rating-row .star-rating::before,
.sp-rating-row .star-rating span::before {
	color: var(--golden);
}

.sp-review-link {
	font-size: 0.875rem;
	color: var(--text-muted);
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: color 0.2s ease;
}

.sp-review-link:hover { color: var(--forest); }

.sp-divider {
	height: 1px;
	background: var(--cream-border);
	margin-block: 1.25rem;
}

/* Price */
.sp-price-wrap {
	margin-bottom: 1.5rem;
}

.sp-price-wrap .price {
	font-family: var(--font-display);
	font-size: 1.875rem;
	font-weight: 500;
	color: var(--forest);
	letter-spacing: -0.02em;
}

.sp-price-wrap .price del {
	font-size: 1.25rem;
	color: var(--text-light);
	margin-right: 0.5rem;
}

.sp-price-wrap .price ins {
	text-decoration: none;
}

/* ── WooCommerce cart form overrides ─────────────────────────────────────── */

/* Variations table → re-styled via JS swatches; hide the raw <select> */
.sp-cart-form-wrap .variations {
	border: none;
	margin-bottom: 1.25rem;
	width: 100%;
}

.sp-cart-form-wrap .variations td,
.sp-cart-form-wrap .variations th {
	padding: 0;
	display: block;
	border: none;
}

.sp-cart-form-wrap .variations .label {
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--text-muted);
	margin-bottom: 0.6rem;
}

.sp-cart-form-wrap .variations .label label {
	display: inline;
}

.sp-cart-form-wrap .variations select {
	display: none; /* hidden — replaced by .sp-swatches button group */
}

/* Variation swatch button group (injected by JS) */
.sp-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1.5rem;
}

.sp-swatch-btn {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 600;
	padding: 0.55em 1.4em;
	border-radius: var(--radius-xl);
	border: 2px solid var(--cream-border);
	background: transparent;
	color: var(--text);
	cursor: pointer;
	transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.sp-swatch-btn:hover {
	border-color: var(--prod-accent, #1B3A2D);
	color: var(--prod-accent, #1B3A2D);
}

.sp-swatch-btn.is-active {
	border-color: var(--prod-accent, #1B3A2D);
	background: var(--prod-accent, #1B3A2D);
	color: #fff;
}

/* Reset button for clearing variation */
.sp-cart-form-wrap .reset_variations {
	display: none; /* hidden in favour of swatch toggle */
}

/* Variation availability message */
.sp-cart-form-wrap .woocommerce-variation-availability {
	font-size: 0.8125rem;
	color: var(--text-muted);
	margin-bottom: 0.75rem;
}

/* Quantity + Add to Cart row */
.sp-cart-form-wrap .cart,
.sp-cart-form-wrap .woocommerce-variation-add-to-cart {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: 0.5rem;
}

/* Quantity control */
.sp-cart-form-wrap .quantity {
	display: flex;
	align-items: center;
	gap: 0;
	border: 2px solid var(--cream-border);
	border-radius: var(--radius-xl);
	overflow: hidden;
	flex-shrink: 0;
}

.sp-cart-form-wrap .qty-btn {
	width: 40px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	cursor: pointer;
	font-size: 1.2rem;
	color: var(--text);
	transition: background 0.15s ease;
	flex-shrink: 0;
}

.sp-cart-form-wrap .qty-btn:hover {
	background: var(--mist);
}

.sp-cart-form-wrap .input-text.qty {
	width: 44px;
	height: 44px;
	text-align: center;
	border: none;
	border-left: 1px solid var(--cream-border);
	border-right: 1px solid var(--cream-border);
	background: transparent;
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 600;
	color: var(--text);
	-moz-appearance: textfield;
}

.sp-cart-form-wrap .input-text.qty::-webkit-outer-spin-button,
.sp-cart-form-wrap .input-text.qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

/* Add to cart button */
.sp-cart-form-wrap .single_add_to_cart_button,
.sp-cart-form-wrap button[type="submit"].button {
	flex: 1;
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 0.9em 2em;
	border-radius: var(--radius-xl);
	border: none;
	background: var(--prod-accent, #1B3A2D);
	color: #fff;
	cursor: pointer;
	transition: filter 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	box-shadow: 0 4px 18px color-mix(in srgb, var(--prod-accent, #1B3A2D) 35%, transparent);
}

.sp-cart-form-wrap .single_add_to_cart_button:hover,
.sp-cart-form-wrap button[type="submit"].button:hover {
	filter: brightness(1.12);
	transform: translateY(-2px);
	box-shadow: 0 8px 28px color-mix(in srgb, var(--prod-accent, #1B3A2D) 45%, transparent);
}

.sp-cart-form-wrap .single_add_to_cart_button:active {
	transform: translateY(0);
}

/* ── Subscribe & Save row ────────────────────────────────────────────────── */

.sp-subscribe-row {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	margin-top: 1.25rem;
}

.sp-subscribe-option {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	padding: 0.9rem 1.15rem;
	border-radius: var(--radius-md);
	border: 2px solid var(--cream-border);
	cursor: pointer;
	transition: border-color 0.2s ease, background 0.2s ease;
	flex-wrap: wrap;
}

.sp-subscribe-option:hover {
	border-color: color-mix(in srgb, var(--prod-accent, #1B3A2D) 40%, transparent);
}

.sp-subscribe-option.is-selected {
	border-color: var(--prod-accent, #1B3A2D);
	background: color-mix(in srgb, var(--prod-accent, #1B3A2D) 6%, transparent);
}

.sp-subscribe-option__radio {
	width: 18px;
	height: 18px;
	border-radius: 50%;
	border: 2px solid var(--cream-border);
	flex-shrink: 0;
	position: relative;
	transition: border-color 0.2s ease;
}

.sp-subscribe-option.is-selected .sp-subscribe-option__radio {
	border-color: var(--prod-accent, #1B3A2D);
}

.sp-subscribe-option.is-selected .sp-subscribe-option__radio::after {
	content: '';
	position: absolute;
	inset: 3px;
	border-radius: 50%;
	background: var(--prod-accent, #1B3A2D);
}

.sp-subscribe-option__label {
	flex: 1;
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--text);
}

.sp-subscribe-option__label strong {
	color: var(--prod-accent, #1B3A2D);
}

.sp-subscribe-option__price {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 500;
	color: var(--forest);
}

.sp-subscribe-option__sub-note {
	display: block;
	width: 100%;
	font-size: 0.75rem;
	color: var(--text-light);
	padding-left: calc(18px + 0.85rem);
	margin-top: -0.2rem;
}

/* ── Icon trust boxes ────────────────────────────────────────────────────── */

.sp-icon-boxes {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.65rem;
	margin-top: 1.5rem;
}

.sp-icon-box {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.7rem 1rem;
	border-radius: var(--radius-md);
	background: color-mix(in srgb, var(--prod-accent, #1B3A2D) 8%, transparent);
	border: 1px solid color-mix(in srgb, var(--prod-accent, #1B3A2D) 15%, transparent);
}

.sp-icon-box__icon {
	display: flex;
	color: var(--prod-accent, #1B3A2D);
	flex-shrink: 0;
}

.sp-icon-box__label {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--prod-accent, #1B3A2D);
	line-height: 1.25;
}

/* ── Trust message ───────────────────────────────────────────────────────── */

.sp-trust-msg {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-top: 1.25rem;
	padding: 1rem 1.15rem;
	border-radius: var(--radius-md);
	background: var(--mist);
	border: 1px solid var(--leaf-pale);
}

.sp-trust-msg__icon {
	display: flex;
	color: var(--sage);
	flex-shrink: 0;
	margin-top: 2px;
}

.sp-trust-msg__text strong {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--forest);
	margin-bottom: 0.2rem;
}

.sp-trust-msg__text p {
	font-size: 0.8125rem;
	color: var(--text-muted);
	line-height: 1.5;
	margin: 0;
}

/* ── Product tabs (Description, Reviews, etc) ────────────────────────────── */

.sp-tabs-section {
	background: var(--white);
	padding-block: var(--space-lg);
}

.sp-tabs-section .woocommerce-tabs ul.tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--cream-border);
	margin-bottom: 2.5rem;
	padding: 0;
	list-style: none;
}

.sp-tabs-section .woocommerce-tabs ul.tabs li {
	margin: 0;
}

.sp-tabs-section .woocommerce-tabs ul.tabs li a {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--text-muted);
	padding: 0.85rem 1.5rem;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color 0.2s ease, border-color 0.2s ease;
}

.sp-tabs-section .woocommerce-tabs ul.tabs li.active a,
.sp-tabs-section .woocommerce-tabs ul.tabs li a:hover {
	color: var(--forest);
	border-bottom-color: var(--forest);
}

.sp-tabs-section .woocommerce-tabs .panel {
	max-width: 760px;
	font-size: 1rem;
	line-height: 1.8;
	color: var(--text-muted);
}

.sp-tabs-section .woocommerce-tabs .panel h2 {
	font-family: var(--font-display);
	font-size: 1.75rem;
	font-weight: 400;
	color: var(--forest);
	margin-bottom: 1rem;
}

/* ── Related products ────────────────────────────────────────────────────── */

.sp-related-section {
	background: var(--cream);
	padding-block: var(--space-lg);
}

.sp-related-section .related h2 {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 400;
	color: var(--forest);
	letter-spacing: -0.02em;
	margin-bottom: 2rem;
}

.sp-related-section ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1.5rem;
	list-style: none;
	padding: 0;
}

.sp-related-section ul.products li.product {
	background: var(--white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: transform 0.25s var(--ease-out), box-shadow 0.25s ease;
}

.sp-related-section ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 36px rgba(27, 58, 45, 0.1);
}

.sp-related-section ul.products li.product a img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
}

.sp-related-section ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 400;
	color: var(--forest);
	padding: 0.75rem 1rem 0.25rem;
}

.sp-related-section ul.products li.product .price {
	font-weight: 600;
	color: var(--golden);
	padding: 0 1rem 1rem;
	display: block;
}

/* ── Product page responsive ─────────────────────────────────────────────── */

@media (max-width: 900px) {
	.sp-layout {
		grid-template-columns: 1fr;
	}

	.sp-image-panel {
		min-height: 420px;
		padding-block: 3rem;
	}

	.sp-gallery__main {
		width: min(320px, 85%);
	}

	.sp-info-panel {
		padding: 2.5rem 1.5rem 3rem;
	}

	.sp-icon-boxes {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.sp-cart-form-wrap .cart,
	.sp-cart-form-wrap .woocommerce-variation-add-to-cart {
		flex-wrap: wrap;
	}

	.sp-cart-form-wrap .single_add_to_cart_button {
		width: 100%;
	}

	.sp-icon-boxes {
		grid-template-columns: 1fr 1fr;
	}
}


/* ═══════════════════════════════════════════════════════════════
   PAGE TRANSITIONS — color-morph between product pages
   Uses native View Transitions API (Chrome 126+) with a JS
   curtain fallback for other browsers.
═══════════════════════════════════════════════════════════════ */

/* Native cross-document view transition (no JS, zero added latency) */
@view-transition {
	navigation: auto;
}

/* The product background morphs between pages */
.sp2-product-wrap {
	view-transition-name: sp2-product-bg;
}

/* Outgoing page: scale up and fade out */
::view-transition-old(sp2-product-bg) {
	animation: vt-page-out 0.28s cubic-bezier(0.4, 0, 1, 1) forwards;
}

/* Incoming page: scale from slightly smaller, fade in */
::view-transition-new(sp2-product-bg) {
	animation: vt-page-in 0.38s cubic-bezier(0, 0, 0.2, 1) forwards;
}

@keyframes vt-page-out {
	0%   { opacity: 1; transform: scale(1); }
	100% { opacity: 0; transform: scale(1.04); }
}

@keyframes vt-page-in {
	0%   { opacity: 0; transform: scale(0.96); }
	100% { opacity: 1; transform: scale(1); }
}

/* JS curtain fallback (shown when View Transitions API is absent) */
#bp-curtain {
	position: fixed;
	inset: 0;
	z-index: 99999;
	pointer-events: none;
	background: var(--forest, #1B3A2D);
	opacity: 0;
	transition: opacity 0.22s ease;
	will-change: opacity;
}

#bp-curtain.is-entering { opacity: 1; pointer-events: all; }
#bp-curtain.is-leaving  { opacity: 0; }


/* ═══════════════════════════════════════════════════════════════
   PRODUCT PAGE — element entry animations
   Staggered fade-up on page load. Runs above the fold immediately.
   Respects prefers-reduced-motion.
═══════════════════════════════════════════════════════════════ */

@keyframes sp2-fade-up {
	from { opacity: 0; transform: translateY(22px); }
	to   { opacity: 1; transform: translateY(0); }
}

@keyframes sp2-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes sp2-fade-right {
	from { opacity: 0; transform: translateX(-18px); }
	to   { opacity: 1; transform: translateX(0); }
}

@media (prefers-reduced-motion: no-preference) {

	/* Left column — image slides up */
	.sp2-product-wrap .sp2-visual-stack {
		animation: sp2-fade-up 0.55s cubic-bezier(0.16, 1, 0.3, 1) 0.05s both;
	}

	/* Category label */
	.sp2-product-wrap .sp2-category {
		animation: sp2-fade-in 0.4s ease 0.12s both;
	}

	/* Title — slides in from left */
	.sp2-product-wrap .sp2-title {
		animation: sp2-fade-right 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0.15s both;
	}

	/* Subtitle + ingredients */
	.sp2-product-wrap .sp2-subtitle,
	.sp2-product-wrap .sp2-ingredients {
		animation: sp2-fade-in 0.4s ease 0.22s both;
	}

	/* Rating */
	.sp2-product-wrap .sp2-rating {
		animation: sp2-fade-in 0.4s ease 0.27s both;
	}

	/* Benefit boxes — staggered */
	.sp2-product-wrap .sp2-benefit-box:nth-child(1) {
		animation: sp2-fade-up 0.45s cubic-bezier(0.16, 1, 0.3, 1) 0.30s both;
	}
	.sp2-product-wrap .sp2-benefit-box:nth-child(2) {
		animation: sp2-fade-up 0.45s cubic-bezier(0.16, 1, 0.3, 1) 0.36s both;
	}
	.sp2-product-wrap .sp2-benefit-box:nth-child(3) {
		animation: sp2-fade-up 0.45s cubic-bezier(0.16, 1, 0.3, 1) 0.42s both;
	}
	.sp2-product-wrap .sp2-benefit-box:nth-child(4) {
		animation: sp2-fade-up 0.45s cubic-bezier(0.16, 1, 0.3, 1) 0.48s both;
	}

	/* Cart form */
	.sp2-product-wrap .sp2-cart-wrap {
		animation: sp2-fade-up 0.45s cubic-bezier(0.16, 1, 0.3, 1) 0.38s both;
	}

	/* Price row */
	.sp2-product-wrap .sp2-price-row {
		animation: sp2-fade-in 0.4s ease 0.45s both;
	}

}

/* ── Image skeleton shimmer ─────────────────────────────────────────────── */
.sp2-gallery-skeleton {
	position: absolute;
	inset: 0;
	z-index: 3;
	border-radius: 12px;
	background: linear-gradient(
		90deg,
		rgba(255, 255, 255, 0.06) 25%,
		rgba(255, 255, 255, 0.18) 50%,
		rgba(255, 255, 255, 0.06) 75%
	);
	background-size: 200% 100%;
	animation: shimmer-swipe 1.4s ease-in-out infinite;
	pointer-events: none;
}

.sp2-gallery-skeleton.is-hidden {
	opacity: 0;
	transition: opacity 0.35s ease;
}

@keyframes shimmer-swipe {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* ═══════════════════════════════════════════════════════════════
   CART & CHECKOUT — SHARED FOUNDATIONS
   White background, forest/golden palette, Unbounded × Outfit
═══════════════════════════════════════════════════════════════ */

/* Page background */
.woocommerce-cart,
.woocommerce-checkout {
	background: var(--white);
}

/* WooCommerce wrapper — centred, padded below fixed header */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
	max-width: var(--container);
	margin-inline: auto;
	padding: clamp(4rem, 7vw, 5rem) clamp(1.25rem, 5vw, 3rem) clamp(2rem, 4vw, 3rem);
}

/* Kill WC's own wide gutter table styles */
.woocommerce table.shop_table {
	border: none;
	border-collapse: collapse;
	border-radius: 0;
	background: transparent;
}

/* Shared section headings (h2/h3 inside WC pages) */
.woocommerce-cart h2,
.woocommerce-checkout h3 {
	font-family: var(--font-display);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-light);
	margin-bottom: 1.5rem;
}

/* Shared input / select / textarea */
.woocommerce-cart .input-text,
.woocommerce-checkout .input-text,
.woocommerce-checkout select,
.woocommerce-checkout textarea {
	font-family: var(--font-body);
	font-size: 0.9375rem;
	color: var(--text);
	background: var(--white);
	border: 1.5px solid var(--cream-border);
	border-radius: var(--radius-sm);
	padding: 0.75rem 1rem;
	width: 100%;
	outline: none;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
}

.woocommerce-checkout .input-text:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus {
	border-color: var(--forest);
	box-shadow: 0 0 0 3px rgba(27, 58, 45, 0.08);
}

.woocommerce-checkout .input-text.woocommerce-invalid,
.woocommerce-checkout select.woocommerce-invalid {
	border-color: #e05555;
	box-shadow: 0 0 0 3px rgba(224, 85, 85, 0.1);
}

/* Labels — visually hidden, preserved for screen readers */
.woocommerce-checkout .woocommerce-billing-fields label,
.woocommerce-checkout .woocommerce-shipping-fields label,
.woocommerce-checkout .woocommerce-additional-fields label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* WC form row — no bottom label gap needed */
.woocommerce-checkout .form-row {
	margin-bottom: 0.6rem;
	position: relative;
}

.woocommerce-checkout .form-row .woocommerce-input-wrapper {
	display: block;
}

/* WC inline validation message */
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-invalid-required-field label::after {
	color: #e05555;
	font-size: 0.75rem;
}

/* WC notices */
.woocommerce-checkout .woocommerce-NoticeGroup .woocommerce-error {
	background: #fff5f5;
	border: 1px solid #fca5a5;
	border-radius: var(--radius-md);
	color: #b91c1c;
	font-family: var(--font-body);
	font-size: 0.875rem;
	padding: 1rem 1.25rem;
	margin-bottom: 2rem;
	list-style: none;
}

/* ── Checkout trust bar (above the form) ────────────────────────────────── */
.bp-checkout-trust {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.5rem 1.5rem;
	background: var(--mist);
	border: 1px solid var(--cream-border);
	border-radius: var(--radius-md);
	padding: 0.85rem 1.5rem;
	margin-bottom: 2.5rem;
}

.bp-checkout-trust__item {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	font-family: var(--font-body);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--forest);
}

.bp-checkout-trust__sep {
	color: var(--cream-border);
	font-size: 1rem;
}

/* ═══════════════════════════════════════════════════════════════
   CART PAGE
═══════════════════════════════════════════════════════════════ */

/* Page title */
.woocommerce-cart .page-title {
	font-family: var(--font-display);
	font-size: clamp(1.2rem, 2.5vw, 1.875rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--forest);
	margin-bottom: 2.5rem;
}

/* Main layout: cart form left, totals right */
.woocommerce-cart .woocommerce {
	display: grid;
	grid-template-columns: 1fr 360px;
	grid-template-rows: auto auto;
	gap: 0 clamp(2rem, 5vw, 4rem);
	align-items: start;
}

.woocommerce-cart .woocommerce-cart-form {
	grid-column: 1;
}

.woocommerce-cart .cart-collaterals {
	grid-column: 2;
	grid-row: 1 / 3;
	position: sticky;
	top: calc(70px + 2rem);
}

/* Page title spans both columns */
.woocommerce-cart .page-title,
.woocommerce-cart .woocommerce-notices-wrapper {
	grid-column: 1 / -1;
}

/* Cart table */
.woocommerce-cart table.shop_table.cart {
	width: 100%;
}

.woocommerce-cart table.shop_table thead {
	border-bottom: 2px solid var(--cream-border);
}

.woocommerce-cart table.shop_table thead th {
	font-family: var(--font-display);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-light);
	padding: 0 1rem 0.85rem;
	text-align: left;
	border: none;
	background: none;
}

.woocommerce-cart table.shop_table thead th.product-thumbnail,
.woocommerce-cart table.shop_table thead th.product-remove {
	width: 1%;
	white-space: nowrap;
}

/* Cart rows */
.woocommerce-cart table.shop_table.cart tbody tr {
	border-bottom: 1px solid var(--cream-border);
	transition: background 0.15s ease;
}

.woocommerce-cart table.shop_table.cart tbody tr:hover {
	background: var(--cream);
}

.woocommerce-cart table.shop_table.cart td {
	padding: 1.5rem 1rem;
	vertical-align: middle;
	border: none;
	background: none;
}

/* Product thumbnail */
.woocommerce-cart .product-thumbnail {
	width: 88px;
}

.woocommerce-cart .product-thumbnail img {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border-radius: var(--radius-md);
	border: 1px solid var(--cream-border);
	display: block;
}

/* Product name */
.woocommerce-cart .product-name a {
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--forest);
	text-decoration: none;
	transition: color 0.15s ease;
}

.woocommerce-cart .product-name a:hover {
	color: var(--sage);
}

.woocommerce-cart .product-name .variation {
	font-size: 0.8125rem;
	color: var(--text-light);
	margin-top: 0.25rem;
}

/* Price cells */
.woocommerce-cart .product-price,
.woocommerce-cart .product-subtotal {
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 600;
	color: var(--text);
}

.woocommerce-cart .product-subtotal {
	color: var(--forest);
	font-weight: 700;
}

/* Quantity cell */
.woocommerce-cart .product-quantity .qty {
	width: 64px;
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 600;
	text-align: center;
	color: var(--text);
	background: var(--white);
	border: 1.5px solid var(--cream-border);
	border-radius: var(--radius-sm);
	padding: 0.55rem 0.5rem;
	outline: none;
	transition: border-color 0.18s ease;
	-moz-appearance: textfield;
}

.woocommerce-cart .product-quantity .qty:focus {
	border-color: var(--forest);
}

.woocommerce-cart .product-quantity .qty::-webkit-outer-spin-button,
.woocommerce-cart .product-quantity .qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

/* Remove button */
.woocommerce-cart .product-remove a.remove {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	color: var(--text-light);
	font-size: 1.25rem;
	font-weight: 400;
	line-height: 1;
	text-decoration: none;
	transition: background 0.15s ease, color 0.15s ease;
}

.woocommerce-cart .product-remove a.remove:hover {
	background: rgba(224, 85, 85, 0.1);
	color: #e05555;
}

/* Actions row (coupon + update) */
.woocommerce-cart .actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.75rem;
	padding-top: 1.5rem;
}

.woocommerce-cart .coupon {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex: 1;
	min-width: 0;
}

.woocommerce-cart .coupon #coupon_code {
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--text);
	background: var(--white);
	border: 1.5px solid var(--cream-border);
	border-radius: var(--radius-sm);
	padding: 0.65rem 1rem;
	width: min(220px, 100%);
	outline: none;
	transition: border-color 0.18s ease;
}

.woocommerce-cart .coupon #coupon_code:focus {
	border-color: var(--forest);
}

.woocommerce-cart .coupon .button,
.woocommerce-cart .actions .button[name="update_cart"] {
	font-family: var(--font-display);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: var(--radius-xl);
	padding: 0.7em 1.5em;
	border: 1.5px solid var(--forest);
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.woocommerce-cart .coupon .button {
	background: transparent;
	color: var(--forest);
}

.woocommerce-cart .coupon .button:hover {
	background: var(--forest);
	color: var(--cream);
}

.woocommerce-cart .actions .button[name="update_cart"] {
	background: transparent;
	color: var(--text-muted);
	border-color: var(--cream-border);
	margin-left: auto;
}

.woocommerce-cart .actions .button[name="update_cart"]:hover {
	border-color: var(--forest);
	color: var(--forest);
}

/* ── Cart totals (right column) ─────────────────────────────────────────── */
.woocommerce-cart .cart_totals h2 {
	font-family: var(--font-display);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-light);
	margin-bottom: 1.25rem;
}

.woocommerce-cart .cart_totals {
	background: var(--cream);
	border: 1px solid var(--cream-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
}

.woocommerce-cart .cart_totals table.shop_table {
	width: 100%;
}

.woocommerce-cart .cart_totals table.shop_table tr th,
.woocommerce-cart .cart_totals table.shop_table tr td {
	padding: 0.65rem 0;
	border: none;
	border-bottom: 1px solid var(--cream-border);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	vertical-align: middle;
	background: none;
}

.woocommerce-cart .cart_totals table.shop_table tr th {
	font-weight: 600;
	color: var(--text-muted);
	width: 45%;
}

.woocommerce-cart .cart_totals table.shop_table tr td {
	color: var(--text);
	font-weight: 500;
	text-align: right;
}

/* Order total row */
.woocommerce-cart .cart_totals table.shop_table tr.order-total th {
	font-family: var(--font-display);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--forest);
	border-bottom: none;
}

.woocommerce-cart .cart_totals table.shop_table tr.order-total td {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--forest);
	border-bottom: none;
}

/* Shipping methods */
.woocommerce-cart .cart_totals .shipping ul#shipping_method {
	list-style: none;
	padding: 0;
}

.woocommerce-cart .cart_totals .shipping ul#shipping_method li {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--text-muted);
	padding: 0.35rem 0;
}

.woocommerce-cart .cart_totals .shipping ul#shipping_method input[type="radio"] {
	accent-color: var(--forest);
	width: 16px;
	height: 16px;
	cursor: pointer;
}

/* Checkout button */
.woocommerce-cart .wc-proceed-to-checkout {
	margin-top: 1.5rem;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	display: block;
	width: 100%;
	text-align: center;
	font-family: var(--font-display);
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: var(--golden);
	color: var(--forest);
	border: 2px solid var(--golden);
	border-radius: var(--radius-xl);
	padding: 1em 2em;
	text-decoration: none;
	transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 4px 20px rgba(200, 169, 78, 0.35);
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
	background: var(--golden-light);
	border-color: var(--golden-light);
	transform: translateY(-2px);
	box-shadow: 0 8px 30px rgba(200, 169, 78, 0.45);
}

/* Cart trust micro-line below CTA */
.woocommerce-cart .wc-proceed-to-checkout::after {
	content: '🔒 Secure checkout · Free returns';
	display: block;
	text-align: center;
	font-family: var(--font-body);
	font-size: 0.75rem;
	color: var(--text-light);
	margin-top: 0.75rem;
}

/* Empty cart */
.woocommerce-cart .cart-empty {
	font-family: var(--font-body);
	font-size: 1.0625rem;
	color: var(--text-muted);
	padding: 3rem 0;
	text-align: center;
}

.woocommerce-cart .return-to-shop .button {
	font-family: var(--font-display);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: var(--forest);
	color: var(--cream);
	border-radius: var(--radius-xl);
	padding: 0.85em 2em;
	text-decoration: none;
	display: inline-block;
	margin-top: 1rem;
	transition: background 0.2s ease, transform 0.2s ease;
}

.woocommerce-cart .return-to-shop .button:hover {
	background: var(--forest-mid);
	transform: translateY(-2px);
}

/* ═══════════════════════════════════════════════════════════════
   CHECKOUT PAGE
═══════════════════════════════════════════════════════════════ */

/* Page title */
.woocommerce-checkout .page-title {
	font-family: var(--font-display);
	font-size: clamp(1.2rem, 2.5vw, 1.875rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--forest);
	margin-bottom: 0.5rem;
}

/* Two-column layout: form left | summary right */
.woocommerce-checkout form.checkout {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
	padding-bottom: 90px; /* clear the sticky payment bar */
}

.woocommerce-checkout form.checkout #customer_details {
	grid-column: 1;
	grid-row: 1 / span 2;
}

.woocommerce-checkout form.checkout #order_review_heading {
	grid-column: 2;
	grid-row: 1;
}

.woocommerce-checkout form.checkout #order_review {
	grid-column: 2;
	grid-row: 2;
	position: sticky;
	top: calc(70px + 1.5rem);
	/* height is controlled by inner flex container */
}

/* col2-set — stack both halves vertically (billing + notes) */
.woocommerce-checkout #customer_details {
	display: block;
}

.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
	width: 100%;
	float: none;
	padding: 0;
}

.woocommerce-checkout #customer_details .col-2 {
	margin-top: 2rem;
}

/* ── Billing / Shipping section wrappers ───────────────────────────────── */

.woocommerce-checkout .woocommerce-billing-fields > h3,
.woocommerce-checkout .woocommerce-shipping-fields > h3,
.woocommerce-checkout .woocommerce-additional-fields > h3 {
	font-family: var(--font-display);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-light);
	margin-bottom: 0.75rem;
	margin-top: 0;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--cream-border);
}

/* Form field grid: first + last side-by-side, rest full-width */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .woocommerce-additional-fields__field-wrapper {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 0.75rem;
}

.woocommerce-checkout .form-row-wide {
	grid-column: 1 / -1;
}

/* Override WC's legacy float layout — use !important to beat WC plugin specificity */
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
	float: none !important;
	width: 100% !important;
	clear: none !important;
	margin-right: 0 !important;
}

/* Ensure the input inside also fills its grid cell */
.woocommerce-checkout .form-row-first .input-text,
.woocommerce-checkout .form-row-last .input-text {
	width: 100% !important;
	box-sizing: border-box;
}

/* Select arrow */
.woocommerce-checkout select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235C6B62' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-right: 2.5rem;
	cursor: pointer;
}

/* ── Order Review Summary (right column) ───────────────────────────────── */

#order_review_heading {
	font-family: var(--font-display);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-light);
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--cream-border);
	margin-bottom: 0.75rem;
	margin-top: 0;
}

.woocommerce-checkout-review-order {
	background: var(--cream);
	border: 1px solid var(--cream-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	max-height: calc(100vh - 70px - 3rem);
}

/* Scrollable section — all content above the payment bar */
.bp-review-scroll {
	flex: 1 1 auto;
	min-height: 0;         /* critical: lets flex child shrink below content size */
	overflow-y: auto;
	overflow-x: hidden;
	scrollbar-width: thin;
	scrollbar-color: var(--cream-border) transparent;
}

.bp-review-scroll::-webkit-scrollbar {
	width: 4px;
}

.bp-review-scroll::-webkit-scrollbar-track {
	background: transparent;
}

.bp-review-scroll::-webkit-scrollbar-thumb {
	background: var(--cream-border);
	border-radius: 2px;
}

/* Payment section — pinned at the bottom, never scrolls away */
.bp-review-payment {
	flex-shrink: 0;
	background: var(--cream);
	border-top: 2px solid var(--cream-border);
}

/* Order review table */
table.woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
}

table.woocommerce-checkout-review-order-table thead th {
	font-family: var(--font-display);
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-light);
	padding: 1rem 1.25rem 0.75rem;
	border-bottom: 1px solid var(--cream-border);
	text-align: left;
	background: none;
	border-top: none;
}

table.woocommerce-checkout-review-order-table thead th:last-child {
	text-align: right;
}

table.woocommerce-checkout-review-order-table .cart_item td {
	padding: 1rem 1.25rem;
	border-bottom: 1px solid var(--cream-border);
	vertical-align: middle;
	background: none;
}

/* Product name in order review */
.woocommerce-checkout-review-order-table .product-name {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--text);
}

.woocommerce-checkout-review-order-table .product-name .product-quantity {
	font-weight: 400;
	color: var(--text-light);
}

.woocommerce-checkout-review-order-table .product-total {
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--forest);
	text-align: right;
}

/* Totals rows */
table.woocommerce-checkout-review-order-table .cart-subtotal td,
table.woocommerce-checkout-review-order-table .cart-subtotal th,
table.woocommerce-checkout-review-order-table .shipping td,
table.woocommerce-checkout-review-order-table .shipping th,
table.woocommerce-checkout-review-order-table .tax-rate td,
table.woocommerce-checkout-review-order-table .tax-rate th {
	padding: 0.6rem 1.25rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--text-muted);
	border-bottom: 1px solid var(--cream-border);
	background: none;
}

table.woocommerce-checkout-review-order-table .order-total th,
table.woocommerce-checkout-review-order-table .order-total td {
	padding: 1rem 1.25rem;
	font-family: var(--font-display);
	border-bottom: none;
	background: none;
}

table.woocommerce-checkout-review-order-table .order-total th {
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--forest);
}

table.woocommerce-checkout-review-order-table .order-total td {
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--forest);
	text-align: right;
}

/* ── Payment section ────────────────────────────────────────────────────── */

#payment {
	border-top: 1px solid var(--cream-border);
	padding: 1.5rem 1.25rem;
}

#payment ul.wc_payment_methods {
	list-style: none;
	padding: 0;
	margin: 0 0 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

#payment ul.wc_payment_methods li.wc_payment_method {
	border: 1.5px solid var(--cream-border);
	border-radius: var(--radius-md);
	transition: border-color 0.18s ease, background 0.18s ease;
	overflow: hidden;
}

#payment ul.wc_payment_methods li.wc_payment_method:has(input:checked) {
	border-color: var(--forest);
	background: rgba(27, 58, 45, 0.03);
}

#payment ul.wc_payment_methods li .wc_payment_method__inner,
#payment ul.wc_payment_methods li label {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.85rem 1rem;
	cursor: pointer;
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--text);
}

#payment ul.wc_payment_methods li input[type="radio"] {
	accent-color: var(--forest);
	width: 17px;
	height: 17px;
	cursor: pointer;
	flex-shrink: 0;
}

#payment .payment_box {
	padding: 0.75rem 1rem 1rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--text-muted);
	background: rgba(27, 58, 45, 0.03);
	border-top: 1px dashed var(--cream-border);
}

/* T&C */
#payment .woocommerce-terms-and-conditions-wrapper {
	margin-bottom: 1.25rem;
}

#payment .woocommerce-terms-and-conditions-wrapper p {
	font-family: var(--font-body);
	font-size: 0.8125rem;
	color: var(--text-light);
	line-height: 1.6;
}

#payment .woocommerce-terms-and-conditions-wrapper a {
	color: var(--forest);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* ── Place Order button ──────────────────────────────────────────────────── */

#place_order {
	display: block;
	width: 100%;
	text-align: center;
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	/* Vibrant botanical gradient: deep green → emerald */
	background: linear-gradient(135deg, #1a6b45 0%, #28c76f 100%);
	color: #ffffff;
	border: none;
	border-radius: var(--radius-xl);
	padding: 1.35em 2em;
	cursor: pointer;
	transition: filter 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 6px 28px rgba(40, 199, 111, 0.45);
}

#place_order:hover {
	filter: brightness(1.1);
	transform: translateY(-2px);
	box-shadow: 0 10px 36px rgba(40, 199, 111, 0.55);
}

/* Trust micro-copy below Place Order */
#payment::after {
	content: ''; /* trust signals are now in the sidebar trust bar below */
	display: none;
}

/* ── Returning customer / login notice ──────────────────────────────────── */

.woocommerce-checkout .woocommerce-info {
	background: var(--mist);
	border: 1px solid var(--leaf-pale);
	border-radius: var(--radius-md);
	color: var(--forest);
	font-family: var(--font-body);
	font-size: 0.875rem;
	padding: 0.85rem 1.25rem;
	margin-bottom: 1.5rem;
}

.woocommerce-checkout .woocommerce-info a {
	color: var(--forest);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Login / coupon collapsibles */
.woocommerce-checkout .login,
.woocommerce-checkout .checkout_coupon {
	background: var(--cream);
	border: 1px solid var(--cream-border);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
}

/* ── Cart & Checkout responsive ─────────────────────────────────────────── */

@media (max-width: 860px) {
	/* Cart: stack totals below table */
	.woocommerce-cart .woocommerce {
		grid-template-columns: 1fr;
	}

	.woocommerce-cart .cart-collaterals {
		grid-column: 1;
		grid-row: auto;
		position: static;
	}

	/* Checkout: single column */
	.woocommerce-checkout form.checkout {
		grid-template-columns: 1fr;
	}

	.woocommerce-checkout form.checkout #customer_details,
	.woocommerce-checkout form.checkout #order_review_heading,
	.woocommerce-checkout form.checkout #order_review {
		grid-column: 1;
		grid-row: auto;
		position: static;
	}

	/* Form fields: full width on mobile */
	.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
	.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
	.woocommerce-checkout .woocommerce-additional-fields__field-wrapper {
		grid-template-columns: 1fr;
	}

	.woocommerce-checkout .form-row-wide {
		grid-column: 1;
	}
}

@media (max-width: 540px) {
	/* Cart: hide quantity column label, show inline */
	.woocommerce-cart table.shop_table thead th.product-price,
	.woocommerce-cart table.shop_table thead th.product-subtotal {
		display: none;
	}

	.woocommerce-cart .actions {
		flex-direction: column;
		align-items: stretch;
	}

	.woocommerce-cart .coupon {
		flex-direction: column;
	}

	.woocommerce-cart .coupon #coupon_code {
		width: 100%;
	}

	.woocommerce-cart .actions .button[name="update_cart"] {
		margin-left: 0;
	}
}

/* (mobile sticky #place_order removed — new sticky bar handles all screen sizes) */

/* ── Order Review Panel: custom template elements ───────────────────────── */

/* Product rows */
.bp-review-items {
	padding: 0.65rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	border-bottom: 1px solid var(--cream-border);
}

.bp-review-item {
	display: flex;
	align-items: center;
	gap: 0.85rem;
}

.bp-review-item__img-wrap {
	position: relative;
	flex-shrink: 0;
}

.bp-review-item__img-wrap img {
	width: 52px;
	height: 52px;
	object-fit: cover;
	border-radius: var(--radius-sm);
	border: 1px solid var(--cream-border);
	display: block;
}

.bp-review-item__qty {
	position: absolute;
	top: -6px;
	right: -6px;
	min-width: 18px;
	height: 18px;
	padding: 0 4px;
	border-radius: 99px;
	background: var(--forest);
	color: var(--cream);
	font-family: var(--font-body);
	font-size: 0.625rem;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
}

.bp-review-item__name {
	flex: 1;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--text);
	line-height: 1.3;
}

.bp-review-item__price {
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--forest);
	white-space: nowrap;
}

/* Totals */
.bp-review-totals {
	padding: 0.85rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0;
	border-bottom: 1px solid var(--cream-border);
}

.bp-review-total-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.4rem 0;
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--text-muted);
	border-bottom: 1px dashed var(--cream-border);
}

.bp-review-total-row:last-child {
	border-bottom: none;
}

.bp-review-total-row--discount {
	color: var(--forest);
}

.bp-review-total-row--total {
	padding-top: 0.7rem;
	margin-top: 0.35rem;
	border-top: 1.5px solid var(--cream-border);
	font-family: var(--font-display);
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--forest);
}

.bp-review-total-row--total span:last-child {
	font-size: 1.25rem;
	letter-spacing: 0;
	text-transform: none;
}

.bp-free-ship {
	color: var(--sage);
	font-weight: 700;
}

/* Applied coupon label within totals */
.bp-review-coupon-label {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.bp-review-coupon-code {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	background: rgba(27, 58, 45, 0.07);
	color: var(--forest);
	border-radius: 4px;
	padding: 0.15em 0.5em;
}

.bp-remove-coupon {
	color: var(--text-light);
	font-size: 0.75rem;
	text-decoration: none;
	transition: color 0.15s ease;
}

.bp-remove-coupon:hover { color: #e05555; }

/* Delivery date banner */
.bp-delivery-date {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.9rem 1.25rem;
	background: linear-gradient(135deg, rgba(27, 58, 45, 0.07) 0%, rgba(125, 184, 133, 0.08) 100%);
	border-top: 2px solid var(--leaf);
	border-bottom: 1px solid var(--cream-border);
	font-family: var(--font-body);
}

.bp-delivery-date__icon {
	flex-shrink: 0;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: var(--forest);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--white);
}

.bp-delivery-date__text {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
}

.bp-delivery-date__label {
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--text-light);
}

.bp-delivery-date__date {
	font-family: var(--font-display);
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--forest);
	letter-spacing: -0.01em;
}

/* Coupon input row */
.bp-coupon-input-wrap {
	padding: 0.85rem 1.25rem;
	border-bottom: 1px solid var(--cream-border);
}

/* Coupon row — inline input + button (NOT a <form> — avoids nested-form issue) */
.bp-coupon-row {
	display: flex;
	flex-wrap: nowrap;
	gap: 0.5rem;
	align-items: stretch;
}

.bp-coupon-input {
	flex: 1 1 auto;
	min-width: 0;
	font-family: var(--font-body);
	font-size: 0.875rem;
	padding: 0.6rem 0.85rem;
	border: 1.5px solid var(--cream-border);
	border-radius: var(--radius-sm);
	background: var(--white);
	color: var(--text);
	outline: none;
	transition: border-color 0.18s ease;
	box-sizing: border-box;
}

.bp-coupon-input:focus {
	border-color: var(--forest);
	box-shadow: 0 0 0 3px rgba(27, 58, 45, 0.08);
}

.bp-coupon-submit {
	font-family: var(--font-display);
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: var(--forest);
	color: var(--cream);
	border: none;
	border-radius: var(--radius-sm);
	padding: 0.6rem 1rem;
	cursor: pointer;
	white-space: nowrap;
	transition: background 0.18s ease;
}

.bp-coupon-submit:hover { background: var(--forest-mid); }

/* Public coupon offers panel */
.bp-public-coupons {
	padding: 0.85rem 1.25rem;
	border-bottom: 1px solid var(--cream-border);
}

.bp-public-coupons__heading {
	font-family: var(--font-display);
	font-size: 0.5625rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-light);
	margin-bottom: 0.65rem;
}

.bp-public-coupon {
	border: 1px solid var(--cream-border);
	border-radius: var(--radius-sm);
	padding: 0.6rem 0.75rem;
	margin-bottom: 0.5rem;
	transition: border-color 0.15s ease;
}

.bp-public-coupon:last-child { margin-bottom: 0; }

.bp-public-coupon.is-applicable {
	border-color: rgba(27, 58, 45, 0.2);
	background: rgba(27, 58, 45, 0.02);
}

.bp-public-coupon.is-locked {
	opacity: 0.65;
}

.bp-public-coupon.is-applied {
	border-color: var(--leaf);
	background: rgba(125, 184, 133, 0.07);
}

.bp-public-coupon__row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.bp-public-coupon__icon {
	flex-shrink: 0;
	color: var(--sage);
}

.bp-public-coupon.is-applied .bp-public-coupon__icon {
	color: var(--leaf);
}

.bp-public-coupon.is-locked .bp-public-coupon__icon {
	color: var(--text-light);
}

.bp-public-coupon__meta {
	flex: 1;
	display: flex;
	align-items: baseline;
	gap: 0.4rem;
	min-width: 0;
}

.bp-public-coupon__code {
	font-family: var(--font-display);
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	color: var(--forest);
}

.bp-public-coupon.is-locked .bp-public-coupon__code {
	color: var(--text-light);
}

.bp-public-coupon__discount {
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--text-muted);
}

.bp-coupon-quick-apply {
	font-family: var(--font-display);
	font-size: 0.5625rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: transparent;
	color: var(--forest);
	border: 1px solid var(--forest);
	border-radius: var(--radius-xl);
	padding: 0.3em 0.75em;
	cursor: pointer;
	white-space: nowrap;
	transition: background 0.15s ease, color 0.15s ease;
	flex-shrink: 0;
}

.bp-coupon-quick-apply:hover {
	background: var(--forest);
	color: var(--cream);
}

.bp-public-coupon__badge {
	font-family: var(--font-display);
	font-size: 0.5rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: var(--leaf);
	color: var(--white);
	border-radius: var(--radius-xl);
	padding: 0.3em 0.75em;
	flex-shrink: 0;
}

.bp-public-coupon__reason {
	font-family: var(--font-body);
	font-size: 0.75rem;
	color: var(--text-light);
	margin-top: 0.35rem;
	line-height: 1.5;
	padding-left: 1.5rem;
}

/* ── "Added to cart" floating toast notification ─────────────────────────── */

.is-checkout-page .woocommerce-notices-wrapper,
.is-cart-page .woocommerce-notices-wrapper {
	position: fixed;
	top: 82px;
	right: 20px;
	z-index: 600;
	width: min(360px, calc(100vw - 40px));
	pointer-events: none;
}

.is-checkout-page .woocommerce-notices-wrapper > *,
.is-cart-page .woocommerce-notices-wrapper > * {
	pointer-events: auto;
}

.is-checkout-page .woocommerce-message,
.is-cart-page .woocommerce-message {
	background: var(--white);
	border: 1px solid var(--cream-border);
	border-left: 3px solid var(--leaf);
	border-radius: var(--radius-md);
	padding: 0.85rem 1.1rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--text);
	box-shadow: 0 8px 32px rgba(27, 58, 45, 0.14);
	list-style: none;
	margin: 0;
	animation:
		bp-toast-in  0.32s cubic-bezier(0.16, 1, 0.3, 1) both,
		bp-toast-out 0.28s cubic-bezier(0.55, 0, 1, 0.45) 4.5s forwards;
}

@keyframes bp-toast-in {
	from { transform: translateX(calc(100% + 24px)); opacity: 0; }
	to   { transform: translateX(0); opacity: 1; }
}

@keyframes bp-toast-out {
	from { transform: translateX(0); opacity: 1; }
	to   { transform: translateX(calc(100% + 24px)); opacity: 0; }
}

/* Hide "View cart" button inside toast — user is already going to checkout */
.is-checkout-page .woocommerce-message .button.wc-forward,
.is-checkout-page .woocommerce-message .button {
	display: none;
}

/* ── Trust bar — sidebar variant (below Place Order) ────────────────────── */

.bp-checkout-trust--sidebar {
	border: none;
	border-radius: 0;
	background: transparent;
	padding: 0.85rem 1.25rem 1rem;
	justify-content: center;
	gap: 0.4rem 1rem;
	font-size: 0.6875rem;
}

.bp-checkout-trust--sidebar .bp-checkout-trust__item {
	font-size: 0.6875rem;
	color: var(--text-light);
}

.bp-checkout-trust--sidebar .bp-checkout-trust__item svg {
	color: var(--sage);
}

.bp-checkout-trust--sidebar .bp-checkout-trust__sep {
	color: var(--cream-border);
}

/* Sidebar: hide Place Order — sticky bar handles it */
.is-checkout-page #place_order {
	display: none !important;
}

/* Hide the form-row wrapper around place_order too */
.is-checkout-page #payment .form-row.place-order {
	padding: 0;
	margin: 0;
}

/* Payment methods: hide radio list — single gateway auto-selects */
.is-checkout-page #payment ul.wc_payment_methods {
	display: none !important;
}

/* ── Checkout tagline heading ─────────────────────────────────────────────── */

.bp-checkout-tagline {
	font-family: var(--font-body);
	font-size: clamp(0.9375rem, 1.5vw, 1.0625rem);
	font-weight: 500;
	font-style: italic;
	color: var(--text-muted);
	line-height: 1.55;
	margin-bottom: 1.5rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--cream-border);
	grid-column: 1 / -1;
}

/* ── Old sticky bar — disabled */
.bp-sticky-order-bar { display: none; }

/* ══════════════════════════════════════════════════════════════════════════
   STICKY PAYMENT + PLACE ORDER BAR
   Landscape strip fixed to bottom of viewport.
   Hides when footer enters view (.is-footer-visible added by JS).
══════════════════════════════════════════════════════════════════════════ */

.bp-sticky-pay-bar {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 400;
	background: var(--white);
	border-top: 1.5px solid var(--cream-border);
	box-shadow: 0 -6px 32px rgba(27, 58, 45, 0.12);
	padding: 0.85rem clamp(1rem, 4vw, 2.5rem);
	/* Hidden until JS adds .is-visible */
	transform: translateY(100%);
	transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
	pointer-events: none;
}

.bp-sticky-pay-bar.is-visible {
	transform: translateY(0);
	pointer-events: auto;
}

/* Slide away when footer enters viewport */
.bp-sticky-pay-bar.is-footer-visible {
	transform: translateY(100%);
	pointer-events: none;
}

.bp-sticky-pay-bar__inner {
	max-width: var(--container);
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
}

/* Left: payment method info */
.bp-sticky-pay-bar__left {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--text-muted);
	min-width: 0;
}

.bp-sticky-pay-bar__left svg {
	flex-shrink: 0;
	color: var(--sage);
}

.bp-sticky-pay-bar__pay-label {
	display: block;
	font-family: var(--font-body);
	font-size: 0.625rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-light);
}

.bp-sticky-pay-bar__pay-name {
	display: block;
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Right: Place Order CTA */
.bp-sticky-pay-bar__btn {
	flex-shrink: 0;
	font-family: var(--font-display);
	font-size: 0.9375rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	background: linear-gradient(135deg, #1a6b45 0%, #28c76f 100%);
	color: #ffffff;
	border: none;
	border-radius: var(--radius-xl);
	padding: 0.9em 2.5em;
	cursor: pointer;
	box-shadow: 0 4px 20px rgba(40, 199, 111, 0.4);
	transition: filter 0.2s ease, transform 0.18s ease, box-shadow 0.2s ease;
	white-space: nowrap;
}

.bp-sticky-pay-bar__btn:hover {
	filter: brightness(1.08);
	transform: translateY(-2px);
	box-shadow: 0 8px 28px rgba(40, 199, 111, 0.52);
}

@media (max-width: 540px) {
	.bp-sticky-pay-bar__inner {
		gap: 0.75rem;
	}

	.bp-sticky-pay-bar__pay-name {
		font-size: 0.8125rem;
		max-width: 140px;
	}

	.bp-sticky-pay-bar__btn {
		font-size: 0.8125rem;
		padding: 0.85em 1.5em;
	}
}

/* ══════════════════════════════════════════════════════════════════════════
   COUPON CONFETTI + SUCCESS TOAST
══════════════════════════════════════════════════════════════════════════ */

/* Confetti container */
.bp-confetti-wrap {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 9000;
	overflow: hidden;
}

.bp-confetti-piece {
	position: absolute;
	top: -16px;
	animation: bp-confetti-fall linear forwards;
}

@keyframes bp-confetti-fall {
	0%   { transform: translateY(0)       rotate(0deg)   scaleX(1);   opacity: 1; }
	50%  { transform: translateY(50vh)    rotate(300deg) scaleX(-1);  opacity: 1; }
	85%  { opacity: 1; }
	100% { transform: translateY(105vh)   rotate(720deg) scaleX(1);   opacity: 0; }
}

/* Success toast */
.bp-coupon-toast {
	position: fixed;
	top: 88px;
	left: 50%;
	transform: translateX(-50%) translateY(-12px);
	z-index: 8500;
	background: var(--white);
	border: 1.5px solid var(--leaf);
	border-radius: var(--radius-lg);
	padding: 0.9rem 1.5rem;
	display: flex;
	align-items: center;
	gap: 0.85rem;
	box-shadow: 0 12px 40px rgba(40, 199, 111, 0.22), 0 4px 16px rgba(0, 0, 0, 0.08);
	opacity: 0;
	transition: opacity 0.32s ease, transform 0.32s cubic-bezier(0.16, 1, 0.3, 1);
	pointer-events: none;
	white-space: nowrap;
}

.bp-coupon-toast.is-visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

.bp-coupon-toast__icon {
	font-size: 1.5rem;
	line-height: 1;
	flex-shrink: 0;
}

.bp-coupon-toast__text {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.bp-coupon-toast__text strong {
	font-family: var(--font-display);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--forest);
}

.bp-coupon-toast__text span {
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--text-muted);
}
