/**
 * COMPONENTS — Hero, Product Cards, Utilities
 * Sections 4, 5, 9 of main.css (lines 564–943, 2112–2385)
 */

/* ===========================================================================
   4. HERO SECTION (Editorial & Immersive)
   =========================================================================== */

.hero {
	position: relative;
	min-height: 70vh;
	display: flex;
	align-items: center;
	background:
		linear-gradient(
			135deg,
			rgba(8, 8, 8, 0.82) 0%,
			rgba(20, 16, 12, 0.72) 48%,
			rgba(24, 18, 13, 0.82) 100%
		),
		url("/images/hero-perfume-tight.png")
			center 34%/cover no-repeat;
	overflow: hidden;
	color: var(--color-text-inverse);
}

/* Home Hero — Defined in pages/home.css (canonical source) */
/* kenBurns animation used by .home-hero-bg */
@keyframes kenBurns {
	0% { transform: scale(1); }
	100% { transform: scale(1.08); }
}


.hero-content {
	padding: var(--space-xl) var(--space-md);
	max-width: 650px;
}

/* Entrance Animations */
@keyframes fadeUp {
	0% { opacity: 0; transform: translateY(30px); }
	100% { opacity: 1; transform: translateY(0); }
}

.hero-title {
	font-family: var(--font-display);
	font-size: var(--text-5xl);
	font-weight: var(--weight-medium);
	color: var(--color-text-inverse);
	margin-bottom: var(--space-md);
	line-height: var(--leading-tight);
	text-shadow: 0 10px 40px rgba(0, 0, 0, 0.8);
	letter-spacing: var(--tracking-tight);
	opacity: 0;
	animation: fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards;
}

.hero-subtitle {
	font-size: var(--text-md);
	color: rgba(255, 255, 255, 0.85);
	max-width: 38rem;
	margin: 0 auto var(--space-xl) auto;
	line-height: var(--leading-relaxed);
	opacity: 0;
	animation: fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) 0.5s forwards;
}

.hero-actions {
	display: flex;
	gap: var(--space-md);
	justify-content: center;
	flex-wrap: wrap;
	opacity: 0;
	animation: fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) 0.7s forwards;
}

/* Ghost to Solid Gold Button — hero context only (dark background, gold passes AA here) */
.hero-actions .btn-primary {
	background: transparent;
	background-image: none;
	border: 1px solid var(--luxury-gold);
	color: var(--luxury-gold);
	transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
	position: relative;
	overflow: hidden;
}

.hero-actions .btn-primary::before {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--luxury-gold);
	z-index: var(--z-below);
	transform: scaleY(0);
	transform-origin: bottom;
	transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.hero-actions .btn-primary:hover,
.hero-actions .btn-primary:focus-visible {
	color: var(--luxury-black);
	border-color: var(--luxury-gold);
}

.hero-actions .btn-primary:hover::before {
	transform: scaleY(1);
}

.hero-actions .btn-outline-secondary.btn-luxury-secondary {
	color: var(--color-text-inverse);
	border-color: rgba(255, 255, 255, 0.72);
	background: rgba(10, 10, 10, 0.3);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.14);
	backdrop-filter: blur(8px);
}

.hero-actions .btn-outline-secondary.btn-luxury-secondary:hover,
.hero-actions .btn-outline-secondary.btn-luxury-secondary:focus-visible {
	color: var(--color-text-inverse);
	border-color: var(--luxury-gold-light);
	background: rgba(197, 163, 90, 0.18);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
}

/* Compact Hero for Inner Pages */
.hero-compact {
	min-height: 30vh;
	padding: 4.5rem 0 3.5rem;
	background:
		linear-gradient(
			135deg,
			rgba(16, 16, 16, 0.88) 0%,
			rgba(38, 26, 18, 0.84) 100%
		),
		url("/images/hero-home.png")
			center 30%/cover no-repeat;
}

.hero-compact .hero-title {
	font-size: var(--text-3xl);
	margin-bottom: 0.65rem;
	animation: none;
	opacity: 1;
}

.hero-compact .hero-subtitle {
	margin-bottom: 0;
	font-size: var(--text-base);
	max-width: 38rem;
	color: rgba(255, 255, 255, 0.86);
	animation: none;
	opacity: 1;
}

/* ===========================================================================
   BUTTON OVERRIDES — Phase C
   Explicit component-level overrides for .btn-primary and .btn-outline-primary.
   These reinforce the base.css declarations with higher specificity where needed
   inside component contexts (product cards, modals, etc.)
   =========================================================================== */

/* Primary: solid gold, dark brown/black text */
.btn-primary {
	--bs-btn-bg: var(--luxury-gold);
	--bs-btn-border-color: var(--luxury-gold);
	--bs-btn-color: var(--luxury-black);
	--bs-btn-hover-bg: var(--luxury-gold-dark);
	--bs-btn-hover-border-color: var(--luxury-gold-dark);
	--bs-btn-hover-color: var(--luxury-black);
	--bs-btn-active-bg: var(--luxury-gold-dark);
	--bs-btn-active-border-color: var(--luxury-gold-dark);
	--bs-btn-active-color: var(--luxury-black);
	--bs-btn-disabled-bg: rgba(197, 163, 90, 0.4);
	--bs-btn-disabled-border-color: transparent;
	--bs-btn-disabled-color: rgba(26, 26, 26, 0.6);
	background-image: none;
	box-shadow: var(--shadow-luxury);
}

.btn-primary:hover,
.btn-primary:focus-visible {
	background-image: none;
	transform: translateY(-1px);
	box-shadow: 0 6px 15px rgba(197, 163, 90, 0.3);
}

/* Outline primary: 1px solid brown, fills to brown on hover */
.btn-outline-primary {
	--bs-btn-color: var(--color-charcoal-brown);
	--bs-btn-border-color: var(--color-charcoal-brown);
	--bs-btn-bg: transparent;
	--bs-btn-hover-bg: var(--color-charcoal-brown);
	--bs-btn-hover-border-color: var(--color-charcoal-brown);
	--bs-btn-hover-color: var(--color-text-inverse);
	--bs-btn-active-bg: var(--luxury-black);
	--bs-btn-active-border-color: var(--luxury-black);
	--bs-btn-active-color: var(--color-text-inverse);
	border-width: 1px;
	background-image: none;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus-visible {
	background-image: none;
}

/* btn-check active state (size selectors, radio cards) */
.btn-check:checked + .btn-outline-primary {
	background-image: none;
	background-color: var(--color-charcoal-brown);
	border-color: var(--color-charcoal-brown);
	color: var(--color-text-inverse);
}

/* ===========================================================================
   5. PRODUCT COMPONENTS — Full-Bleed Image Card (Phase D)
   =========================================================================== */

/* Card shell: no border, soft shadow only */
.product-card {
	border: none !important;
	box-shadow: 0 2px 12px rgba(43, 33, 27, 0.08);
	overflow: hidden;
	transition:
		box-shadow var(--transition-base),
		opacity 0.15s ease;
	background: var(--color-surface-card);
}

.product-card:hover {
	box-shadow: 0 8px 28px rgba(43, 33, 27, 0.14);
	border-color: transparent !important;
}

.product-card:focus-within {
	box-shadow: 0 8px 28px rgba(43, 33, 27, 0.14), var(--focus-ring-shadow);
}

.product-card a:focus-visible,
.product-card button:focus-visible {
	outline: none;
	box-shadow: var(--focus-ring-shadow);
	border-radius: var(--radius-sm);
}

/* Floating wishlist heart — standalone icon without border */
.product-card .wishlist-toggle-btn {
	width: 40px;
	height: 40px;
	background: transparent;
	border: none;
	color: var(--luxury-gold);
	font-size: var(--text-md);
	transition: all 0.2s ease;
	filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.4));
}

.product-card .wishlist-toggle-btn:hover {
	transform: scale(1.15);
	color: #fff;
}

/* Custom Tooltip Theme for dark product images */
.luxury-tooltip {
	--bs-tooltip-bg: rgba(255, 255, 255, 0.95);
	--bs-tooltip-color: var(--luxury-black);
	--bs-tooltip-opacity: 1;
	font-weight: var(--weight-medium);
	letter-spacing: var(--tracking-wide);
}

.luxury-tooltip .tooltip-inner {
	border: 1px solid var(--luxury-gold);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	backdrop-filter: blur(4px);
}

/* Image link wrapper — establishes the full-bleed image area */
.product-card-image-link {
	display: block;
	overflow: hidden;
}

/* Full-bleed image: edge-to-edge, no radius on top corners */
.product-card .card-img-top {
	aspect-ratio: 4 / 4.6;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	border-radius: 0;
	display: block;
	filter: contrast(1.04) saturate(0.94) brightness(0.97);
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), filter 0.5s ease;
}

.product-card:hover .card-img-top {
	transform: scale(1.03);
	filter: contrast(1.06) saturate(1) brightness(1);
}

/* Instant tap feedback */
@media (max-width: 767.98px) {
	.product-card:active {
		opacity: 0.9;
	}
}

/* Discover overlay — fades in on hover */
.product-overlay {
	opacity: 0;
	background: rgba(20, 15, 12, 0.62);
	transition: opacity var(--transition-base);
}

.product-card:hover .product-overlay {
	opacity: 1;
}

.product-overlay-cta {
	display: inline-block;
	padding: 0.5rem 1.5rem;
	border: 1px solid rgba(255, 255, 255, 0.85);
	border-radius: var(--radius-full);
	color: #ffffff;
	font-size: var(--text-xs);
	font-weight: var(--weight-semi);
	text-transform: uppercase;
	letter-spacing: var(--tracking-widest);
	background: rgba(20, 15, 12, 0.72);
	backdrop-filter: blur(4px);
}

/* Badge: frosted parchment on product image — contrast-safe on any background */
.product-badge {
	position: absolute;
	top: 0.85rem;
	left: 0.85rem;
	z-index: var(--z-local);
	display: inline-block;
	padding: 0.2rem 0.6rem;
	border-radius: var(--radius-lg);
	font-family: var(--bs-body-font-family);
	font-size: var(--text-xs);
	font-weight: var(--weight-semi);
	text-transform: uppercase;
	letter-spacing: var(--tracking-widest);
	white-space: nowrap;
	line-height: 1.4;
	background: rgba(250, 247, 240, 0.92);
	color: var(--color-ink);
	border: 1px solid rgba(197, 163, 90, 0.4);
}

.product-badge-new {
	background: rgba(250, 247, 240, 0.92);
	color: var(--color-ink);
	border: 1px solid rgba(197, 163, 90, 0.4);
}

.product-badge-bestseller {
	background: rgba(245, 250, 247, 0.92);
	color: var(--luxury-success);
	border: 1px solid rgba(13, 105, 85, 0.25);
}

/* Card body: clean white surface, structured typography */
.product-card .card-body {
	background: var(--color-surface-card);
	padding: 1rem 1.1rem 1.1rem;
	border-top: 1px solid var(--color-border-subtle);
}

/* Typography hierarchy: Kicker » Title » Notes » Price */

/* 1. Kicker — category label (Inter, uppercase, gold-dark) */
.product-kicker {
	display: block;
	font-family: var(--bs-body-font-family);
	font-size: var(--text-xs);
	font-weight: var(--weight-semi);
	text-transform: uppercase;
	letter-spacing: var(--tracking-widest);
	color: var(--luxury-gold-dark);
	margin-bottom: 0.35rem;
}

/* 2. Title — Playfair Display */
.product-card .card-title {
	font-family: var(--font-display);
	font-weight: var(--weight-medium);
	color: var(--color-ink);
	margin-bottom: 0.4rem;
	line-height: 1.3;
}

.product-card .card-title a {
	color: var(--color-ink);
	text-decoration: none;
	display: block;
	transition: color var(--transition-fast);
}

.product-card .card-title a:visited {
	color: var(--color-ink);
}

.product-card .card-title a:hover {
	color: var(--luxury-gold-dark);
}

/* 3. Notes / mood line — Inter, muted */
.product-mood {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: 1.55;
	margin-bottom: 0.75rem;
}

/* Product Category Label */
.product-category {
	color: var(--color-olive-gold);
}

/* Product spec tags — longevity, use-case */
.product-tag {
	display: inline-flex;
	align-items: center;
	font-family: var(--bs-body-font-family);
	font-size: 0.6875rem; /* 11px */
	font-weight: var(--weight-medium);
	color: var(--color-text-muted);
	background: var(--color-surface-section);
	padding: 0.15rem 0.5rem;
	border-radius: var(--radius-xs);
	letter-spacing: var(--tracking-wide);
	line-height: 1.4;
}

/* 4. Price — Playfair Display, gold-dark */
.product-price {
	font-variant-numeric: tabular-nums;
	font-family: var(--font-display);
	font-weight: var(--weight-bold);
	color: var(--luxury-gold-dark);
	font-size: var(--text-md);
}

.product-price-compare {
	font-variant-numeric: tabular-nums;
	color: var(--color-text-muted);
	text-decoration: line-through;
	font-weight: var(--weight-regular);
	font-size: var(--text-sm);
}

/* Product Rating */
.rating .star {
	color: var(--color-border-soft);
}

.rating .star.filled {
	color: #fbbf24; /* amber — semantic star color, not brand palette */
}

/* Fix textarea height in floating labels */
.form-floating textarea.form-control,
.form-floating textarea.form-control:focus,
.form-floating textarea.form-control:not(:placeholder-shown) {
	height: auto !important;
	min-height: 100px !important;
	padding-top: 1.625rem !important;
	padding-bottom: 0.625rem !important;
}

/* Product Actions — revealed on hover */
.product-actions {
	align-items: center;
	opacity: 0;
	transform: translateY(6px);
	transition: opacity 0.25s ease, transform 0.25s ease;
}

.product-card:hover .product-actions {
	opacity: 1;
	transform: translateY(0);
}

/* Always show on touch devices */
@media (hover: none) {
	.product-actions {
		opacity: 1;
		transform: translateY(0);
	}
}

.product-actions .btn {
	height: 2.75rem; /* 44px — WCAG SC 2.5.5 minimum touch target */
	font-size: 0.75rem;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	font-weight: var(--weight-semi);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	transition: all var(--transition-fast);
}

.product-actions .btn-primary {
	--bs-btn-bg: var(--luxury-gold, #c5a35a);
	--bs-btn-border-color: var(--luxury-gold, #c5a35a);
	--bs-btn-color: var(--luxury-black, #1a1a1a);
	--bs-btn-hover-bg: var(--luxury-gold-dark, #8a6c2d);
	--bs-btn-hover-border-color: var(--luxury-gold-dark, #8a6c2d);
	--bs-btn-hover-color: var(--luxury-black, #1a1a1a);
	--bs-btn-active-bg: var(--luxury-gold-dark, #8a6c2d);
	--bs-btn-active-border-color: var(--luxury-gold-dark, #8a6c2d);
	--bs-btn-active-color: var(--luxury-black, #1a1a1a);
	box-shadow: 0 4px 10px rgba(197, 163, 90, 0.15);
}

.product-actions .btn-primary:hover,
.product-actions .btn-primary:focus-visible {
	transform: translateY(-1px);
	box-shadow: 0 6px 14px rgba(197, 163, 90, 0.25);
}

.product-actions .btn-outline-secondary {
	--bs-btn-color: var(--luxury-gold-dark, #8a6c2d);
	--bs-btn-border-color: rgba(197, 163, 90, 0.35);
	--bs-btn-bg: transparent;
	--bs-btn-hover-bg: var(--luxury-gold, #c5a35a);
	--bs-btn-hover-border-color: var(--luxury-gold, #c5a35a);
	--bs-btn-hover-color: var(--luxury-black, #1a1a1a);
	--bs-btn-active-bg: var(--luxury-gold-dark, #8a6c2d);
	--bs-btn-active-border-color: var(--luxury-gold-dark, #8a6c2d);
	--bs-btn-active-color: var(--luxury-black, #1a1a1a);
	width: 2.75rem; /* 44px square — matches button height */
	flex-shrink: 0;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.product-actions .btn-outline-secondary:hover,
.product-actions .btn-outline-secondary:focus-visible {
	transform: translateY(-1px);
	box-shadow: 0 6px 14px rgba(197, 163, 90, 0.25);
}

/* Gold-tinted save badge */
.badge.bg-success {
	background-color: rgba(197, 163, 90, 0.12) !important;
	color: var(--luxury-gold-dark, #a8893d) !important;
	font-weight: var(--weight-semi);
}

.product-actions .btn-icon {
	flex: 0 0 auto;
}

.product-actions .btn-icon.in-cart {
	background: linear-gradient(135deg, var(--bs-success) 0%, #198754 100%) !important;
	border-color: var(--bs-success) !important;
	color: white !important;
	box-shadow: 0 2px 8px rgba(25, 135, 84, 0.3);
}

.product-actions .btn-icon.in-cart:hover {
	background: linear-gradient(135deg, #198754 0%, #157347 100%) !important;
	border-color: var(--bs-success) !important;
	transform: scale(1.05);
	box-shadow: 0 4px 12px rgba(25, 135, 84, 0.4);
}

/* Main product button in-cart state */
.btn-primary.in-cart {
	background: linear-gradient(135deg, var(--bs-success) 0%, #198754 100%) !important;
	border-color: var(--bs-success) !important;
	box-shadow: 0 4px 16px rgba(25, 135, 84, 0.3);
}

.btn-primary.in-cart:hover {
	background: linear-gradient(135deg, #198754 0%, #157347 100%) !important;
	border-color: var(--bs-success) !important;
	box-shadow: 0 6px 20px rgba(25, 135, 84, 0.4);
}

/* Icon button animations */
.btn-icon.loading {
	animation: pulse 1.5s ease-in-out infinite;
	opacity: 0.7;
}

.btn-icon.success {
	animation: success-pulse 0.6s ease-in-out;
}

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

@keyframes success-pulse {
	0% { transform: scale(1); }
	50% { transform: scale(1.1); }
	100% { transform: scale(1); }
}

/* Cart item fade out */
.cart-item-card.fade-out {
	opacity: 0;
	transform: translateX(-20px);
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.btn-icon {
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem !important;
	height: 3rem !important;
}

/* ===========================================================================
   9. UTILITY CLASSES
   =========================================================================== */

/* Letter Spacing Utility */
.letter-spacing-wide {
	letter-spacing: var(--tracking-wide);
}

/* Text Colors */
.text-luxury-gold {
	color: var(--luxury-gold-dark);
}

/* Background Colors */
.bg-luxury-cream {
	background-color: var(--color-surface-section);
}

/* Hover Lift Effect */
.hover-lift {
	transition:
		transform var(--transition-base),
		box-shadow var(--transition-base);
}

.hover-lift:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

/* Section Spacing */
.section-luxury {
	padding: 5rem 0; /* Base padding for massive negative space (The Gallery effect) */
	position: relative;
}

/* Luxury Micro Labels */
.lux-label,
.product-category {
	font-family: var(--bs-body-font-family);
	font-size: var(--text-xs);
	font-weight: var(--weight-semi);
	text-transform: uppercase;
	letter-spacing: var(--tracking-widest);
	color: var(--luxury-gold-dark); /* gold-dark passes AA on both white and parchment */
}

/* Luxury Semantic Colors */
.bg-luxury-success {
	background-color: var(--luxury-success) !important;
}

/* Consolidated luxury badge styles */
.badge-luxury-new,
.badge-luxury-bestseller {
	background: rgba(197, 163, 90, 0.12);
	color: var(--luxury-gold-dark);
	border: 1px solid rgba(197, 163, 90, 0.3);
	font-weight: var(--weight-medium);
}

.badge-luxury-sale {
	background: rgba(20, 15, 12, 0.74);
	color: var(--luxury-gold-light);
	border: 1px solid rgba(197, 163, 90, 0.48);
	font-weight: var(--weight-bold);
	box-shadow: 0 10px 22px rgba(0, 0, 0, 0.22);
	backdrop-filter: blur(6px);
}

.product-card-compact {
	border-radius: var(--radius-sm);
}

.product-card-compact .card-body {
	padding: 0.85rem 0.9rem 0.9rem;
}

.product-card-compact .product-kicker {
	font-size: var(--text-xs);
	letter-spacing: var(--tracking-widest);
}

.product-card-compact .card-title {
	margin-bottom: 0.4rem !important;
	min-height: calc(1.35em * 3);
}

.product-card-compact .card-title a {
	font-size: var(--text-sm);
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.product-card-compact .card-img-top {
	aspect-ratio: 4 / 4.6;
	object-fit: cover;
}

/* Featured Large Card (Shop Asymmetry) */
@media (min-width: 992px) {
	.product-card-featured-large {
		flex-direction: row;
		align-items: stretch;
	}
	.product-card-featured-large > a {
		flex: 0 0 55%;
		max-width: 55%;
	}
	.product-card-featured-large .card-img-top {
		height: 100%;
		min-height: 100%;
		border-radius: var(--radius-md) 0 0 var(--radius-md) !important;
	}
	.product-card-featured-large .card-body {
		flex: 1;
		padding: 3rem 2.5rem;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
	.product-card-featured-large .card-title {
		font-size: var(--text-2xl) !important;
		margin-bottom: 1rem !important;
	}
	.product-card-featured-large .card-title a {
		font-size: var(--text-2xl) !important;
	}
	.product-card-featured-large .product-notes {
		font-size: var(--text-md);
		margin-bottom: 2rem !important;
	}
	.product-card-featured-large .lux-label {
		font-size: var(--text-sm);
		margin-bottom: 1rem;
	}
	.product-card-featured-large .product-actions {
		justify-content: flex-start !important;
		margin-top: 1.5rem;
	}
	.product-card-featured-large .product-price {
		font-size: var(--text-xl);
	}
}

.product-card-compact .product-notes {
	font-size: var(--text-xs);
	margin-bottom: 0.75rem !important;
	color: var(--color-text-muted);
}

.product-card .product-scent-hint {
	font-size: var(--text-sm);
	font-weight: var(--weight-regular);
	text-transform: none;
	letter-spacing: normal;
	color: var(--color-text-secondary);
	line-height: var(--leading-normal);
}

.product-savings {
	font-variant-numeric: tabular-nums;
	font-size: var(--text-xs);
	font-weight: var(--weight-semi);
	color: var(--luxury-success);
}

.product-card-compact .product-price {
	font-size: var(--text-base);
}

.product-card-compact .product-card-spacing {
	margin-bottom: 0.85rem;
}

.product-card-compact .product-price-compare {
	font-size: var(--text-xs);
}

.product-card-compact .product-actions {
	gap: 0.4rem;
	justify-content: flex-start !important;
}

.product-card-compact .product-actions .btn-icon {
	width: 2.75rem !important;
	height: 2.75rem !important;
	border-radius: var(--radius-sm);
}

.home-testimonial-card {
	padding: calc(var(--space-md) + 0.5rem);
	background: var(--color-surface-card);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
}

.home-testimonial-rating {
	color: var(--luxury-gold-dark);
	font-size: var(--text-sm);
}

.home-testimonial-text {
	font-size: var(--text-sm);
	line-height: var(--leading-loose);
	color: var(--color-text-secondary);
	font-style: italic;
}

.home-testimonial-author strong {
	display: block;
	font-size: var(--text-sm);
	color: var(--color-ink);
	margin-bottom: 0.25rem;
}

.home-testimonial-author small {
	font-size: var(--text-xs);
}

.home-trust-metric {
	padding: var(--space-md);
}

.home-trust-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: 50%;
	background: rgba(197, 163, 90, 0.12);
	color: var(--color-link);
	font-size: var(--text-md);
}

.home-trust-metric strong {
	font-size: var(--text-sm);
	color: var(--color-ink);
}

.home-trust-metric small {
	font-size: var(--text-xs);
}

.home-cta-section {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(247, 243, 238, 0.86) 100%);
}

.home-cta-panel {
	padding: calc(var(--space-xl) + var(--space-sm)) var(--space-md);
	background: var(--gradient-premium-dark);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-premium);
	color: var(--color-text-inverse);
}

.home-cta-panel h2 {
	color: var(--color-text-inverse);
}

.home-cta-copy {
	max-width: 44rem;
	color: rgba(255, 255, 255, 0.8);
	line-height: var(--leading-loose);
}

/* Sticky Mobile Add to Cart */
.sticky-add-to-cart {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background: var(--luxury-white);
	padding: 0.75rem 1rem;
	box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
	z-index: var(--z-modal-backdrop);
	transform: translateY(100%);
	transition: transform 0.3s ease;
}

.sticky-add-to-cart.visible {
	transform: translateY(0);
}

/* ===========================================================================
   AVATAR UTILITIES
   =========================================================================== */

.avatar-circle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	flex-shrink: 0;
	text-align: center;
}

.avatar-circle-sm {
	width: 40px;
	height: 40px;
	line-height: 40px;
}

.avatar-circle-md {
	width: 48px;
	height: 48px;
	line-height: 48px;
}

.avatar-circle-xl {
	width: 80px;
	height: 80px;
	font-size: 2rem;
	line-height: 80px;
}

/* ===========================================================================
   PAGINATION
   =========================================================================== */
.pagination {
	--bs-pagination-color: var(--color-text-secondary);
	--bs-pagination-bg: var(--color-surface-card);
	--bs-pagination-border-color: var(--color-border-soft);
	--bs-pagination-hover-color: var(--luxury-gold);
	--bs-pagination-hover-bg: var(--color-surface-subtle);
	--bs-pagination-hover-border-color: var(--color-border-soft);
	--bs-pagination-active-color: var(--luxury-black);
	--bs-pagination-active-bg: var(--luxury-gold);
	--bs-pagination-active-border-color: var(--luxury-gold);
	--bs-pagination-disabled-color: var(--color-text-muted);
	--bs-pagination-disabled-bg: var(--color-surface-subtle);
	--bs-pagination-disabled-border-color: var(--color-border-soft);
}

.pagination .page-item.active .page-link {
	font-weight: var(--weight-semi);
	box-shadow: 0 4px 10px rgba(184, 157, 103, 0.25);
}

@keyframes pulse-opacity {
	0%, 100% { opacity: 1; }
	50%       { opacity: 0.7; }
}

@media (min-width: 992px) {
	.sticky-add-to-cart {
		display: none !important;
	}
}

@media (max-width: 767.98px) {
	.home-hero-bg {
		animation-duration: 45s;
	}

	.hero-actions .btn-outline-secondary.btn-luxury-secondary {
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.hero-title,
	.hero-subtitle,
	.hero-actions {
		animation: none;
		opacity: 1;
	}
}

.checkout-order-summary {
	top: 2rem;
	z-index: var(--z-sticky);
}

.checkout-items-scrollable {
	max-height: 400px;
	overflow-y: auto;
}

.checkout-item-name {
	max-width: 200px;
}

/* ===========================================================================
   WISHLIST PRODUCT IMAGE
   =========================================================================== */

.wishlist-product-img {
	aspect-ratio: 4/3;
	max-height: 220px;
	object-fit: cover;
}
