/**
 * Homepage styles — hero, promo banners, product sections.
 */

.xm-homepage {
	background: var(--xm-color-bg);
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	overflow-x: clip;
}

/* Hero — full width without 100vw scrollbar overflow */
.xm-hero {
	position: relative;
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	min-height: clamp(220px, 33.33vw, 560px);
	overflow: hidden;
	background: #1a1a1a;
}

.xm-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
	background-color: #1a1a1a;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

.xm-hero__media picture {
	display: block;
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	margin: 0;
}

/* Override .xm-site img { max-width: 100% } so cover scaling stays sharp */
.xm-site .xm-hero__image {
	position: absolute;
	top: 50%;
	left: 50%;
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto;
	max-width: none;
	transform: translate3d(-50%, -50%, 0);
	object-fit: cover;
	object-position: center center;
	backface-visibility: hidden;
}

.xm-hero__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		90deg,
		rgba(0, 0, 0, 0.55) 0%,
		rgba(0, 0, 0, 0.28) 38%,
		rgba(0, 0, 0, 0.08) 62%,
		transparent 100%
	);
	pointer-events: none;
}

.xm-hero__content {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	width: 100%;
	max-width: var(--xm-container-max);
	min-height: clamp(220px, 33.33vw, 560px);
	margin: 0 auto;
	padding: clamp(1.25rem, 3vw, 3rem) var(--xm-container-padding);
	color: var(--xm-color-white);
	box-sizing: border-box;
}

.xm-hero__body {
	width: 100%;
	max-width: 100%;
}

.xm-hero__title {
	font-size: clamp(1.375rem, 4vw, 2.75rem);
	font-weight: var(--xm-font-weight-bold);
	line-height: 1.15;
	margin: 0 0 var(--xm-space-md);
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.45);
}

.xm-hero__title-line2 {
	display: inline;
}

@media (min-width: 768px) {
	.xm-hero__title-line2::before {
		content: ' ';
	}
}

.xm-hero__subtitle {
	font-size: clamp(0.9375rem, 2vw, 1.25rem);
	line-height: 1.45;
	margin: 0 0 var(--xm-space-lg);
	opacity: 0.95;
	text-shadow: 0 1px 8px rgba(0, 0, 0, 0.35);
}

.xm-hero__cta {
	align-self: flex-start;
	min-width: 140px;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}

/* Mobile poster ads — phone-only slider (1:1 square, matches xiaomistores.co.ke) */
.xm-mobile-posters {
	display: none;
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	background: #1a1a1a;
	overflow: hidden;
}

.xm-mobile-posters__viewport {
	width: 100%;
	overflow: hidden;
	aspect-ratio: 1 / 1;
}

.xm-mobile-posters__track {
	display: flex;
	width: 100%;
	height: 100%;
	will-change: transform;
}

.xm-mobile-posters__slide {
	flex: 0 0 100%;
	width: 100%;
	min-width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: stretch;
	justify-content: stretch;
	background: #1a1a1a;
	overflow: hidden;
}

.xm-mobile-posters__link {
	display: block;
	width: 100%;
	height: 100%;
	line-height: 0;
}

.xm-site .xm-mobile-posters__image {
	width: 100%;
	height: 100%;
	max-width: none;
	object-fit: cover;
	object-position: center center;
	display: block;
}

@media (max-width: 767px) {
	.xm-hero {
		min-height: clamp(160px, 42vw, 220px);
	}

	.xm-hero__content {
		min-height: clamp(160px, 42vw, 220px);
	}

	.xm-homepage--has-mobile-posters .xm-mobile-posters {
		display: block;
	}

	.xm-homepage--has-mobile-posters .xm-hero {
		display: none;
	}
}

@media (min-width: 768px) {
	.xm-mobile-posters {
		display: none !important;
	}
}

/* Category shortcut icons — responsive top row (4–8) + overflow row (up to 8) */
.xm-category-shortcuts {
	width: 100%;
	background: var(--xm-color-bg-alt);
	border-bottom: 1px solid var(--xm-color-border);
}

.xm-category-shortcuts--inline {
	border-top: 1px solid var(--xm-color-border);
}

.xm-category-shortcuts .xm-container {
	padding-top: var(--xm-space-md);
	padding-bottom: var(--xm-space-md);
}

.xm-category-shortcuts__grid {
	display: grid;
	grid-template-columns: repeat(var(--xm-shortcut-cols, 4), minmax(0, 1fr));
	gap: var(--xm-space-sm) var(--xm-space-xs);
	margin: 0;
	padding: 0;
	width: 100%;
	max-width: 100%;
}

.xm-category-shortcuts__grid--secondary {
	--xm-shortcut-cols: 4;
}

.xm-category-shortcuts__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	gap: 0.375rem;
	min-width: 0;
	padding: 0.25rem 0.125rem;
	color: var(--xm-color-text);
	text-decoration: none;
	text-align: center;
	transition: transform var(--xm-transition), color var(--xm-transition);
}

.xm-category-shortcuts__item:hover {
	color: var(--xm-color-primary);
	text-decoration: none;
	transform: translateY(-2px) scale(1.02);
}

.xm-category-shortcuts__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3.75rem;
	height: 3.75rem;
	max-width: 100%;
	flex-shrink: 0;
	margin: 0 auto;
}

.xm-category-shortcuts__icon--empty {
	background: rgba(0, 0, 0, 0.04);
	border: 1px dashed rgba(0, 0, 0, 0.08);
	border-radius: var(--xm-radius-md);
}

.xm-category-shortcuts__gif {
	width: 3.75rem;
	height: 3.75rem;
	max-width: 100%;
	max-height: 3.75rem;
	object-fit: contain;
	object-position: center center;
	display: block;
	pointer-events: none;
}

.xm-category-shortcuts__label {
	display: block;
	width: 100%;
	max-width: 100%;
	font-size: 0.625rem;
	font-weight: var(--xm-font-weight-medium);
	line-height: 1.2;
	letter-spacing: 0.01em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

@media (min-width: 768px) {
	.xm-category-shortcuts {
		overflow: hidden;
	}

	.xm-category-shortcuts .xm-container {
		padding-top: var(--xm-space-lg);
		padding-bottom: var(--xm-space-lg);
	}

	.xm-category-shortcuts__grid {
		gap: var(--xm-space-md);
		max-width: var(--xm-container-max);
		margin-left: auto;
		margin-right: auto;
	}

	.xm-category-shortcuts--primary .xm-category-shortcuts__icon {
		width: 4rem;
		height: 4rem;
	}

	.xm-category-shortcuts--primary .xm-category-shortcuts__gif {
		width: 4rem;
		height: 4rem;
		max-height: 4rem;
	}

	.xm-category-shortcuts__label {
		font-size: var(--xm-font-size-sm);
		white-space: normal;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
		text-overflow: ellipsis;
	}
}

@media (min-width: 1024px) {
	.xm-category-shortcuts--primary .xm-category-shortcuts__icon {
		width: 3.75rem;
		height: 3.75rem;
	}

	.xm-category-shortcuts--primary .xm-category-shortcuts__gif {
		width: 3.75rem;
		height: 3.75rem;
		max-height: 3.75rem;
	}

	.xm-category-shortcuts__grid--secondary {
		grid-template-columns: repeat(var(--xm-shortcut-cols, 8), minmax(0, 1fr));
	}
}

.xm-promo-showcase {
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	background: var(--xm-color-bg);
}

@media (min-width: 768px) {
	.xm-promo-showcase {
		width: 100vw;
		max-width: 100vw;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		overflow-x: clip;
	}
}

.xm-promo-showcase--empty {
	width: auto;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
	padding: var(--xm-space-md) 0;
}

.xm-promo-showcase--empty .xm-notice {
	margin: 0;
}

.xm-promo-showcase__outer {
	width: 100%;
	max-width: none;
}

.xm-promo-showcase__banner {
	position: relative;
	width: 100%;
	height: auto;
	min-height: clamp(150px, 22vw, 220px);
	border-radius: 0;
	overflow: visible;
	background: linear-gradient(135deg, #f8f9fb 0%, #eef1f5 45%, #f5f6f8 100%);
	box-shadow: none;
}

.xm-promo-showcase__decor {
	position: absolute;
	inset: 0;
	pointer-events: none;
	overflow: hidden;
}

.xm-promo-showcase__decor::before,
.xm-promo-showcase__decor::after {
	content: '';
	position: absolute;
	border-radius: 50%;
	border: 1px solid rgba(0, 0, 0, 0.05);
}

.xm-promo-showcase__decor::before {
	width: clamp(280px, 55vw, 620px);
	height: clamp(280px, 55vw, 620px);
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.xm-promo-showcase__decor::after {
	width: clamp(200px, 40vw, 460px);
	height: clamp(200px, 40vw, 460px);
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	border-color: rgba(0, 0, 0, 0.035);
}

.xm-promo-showcase__track {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(var(--xm-promo-cols-base, 4), minmax(0, 1fr));
	align-items: end;
	width: 100%;
	height: auto;
	min-height: inherit;
	gap: clamp(0.25rem, 1vw, 0.75rem);
	padding: clamp(0.35rem, 0.9vw, 0.75rem) clamp(0.35rem, 1.2vw, 1rem);
	box-sizing: border-box;
	overflow: visible;
}

@media (min-width: 1300px) {
	.xm-promo-showcase__track {
		grid-template-columns: repeat(var(--xm-promo-cols-wide, 4), minmax(0, 1fr));
		padding-inline: clamp(0.5rem, 1.5vw, 1.25rem);
	}
}

.xm-promo-showcase__item {
	display: flex;
	flex-direction: column;
	min-width: 0;
	height: auto;
	min-height: 0;
	opacity: 1;
	transform: translate3d(0, 0, 0);
	transition: none;
}

.xm-promo-showcase__item--anim-flip {
	perspective: 900px;
}

.xm-promo-showcase__item.xm-promo-showcase__item--wide-only {
	display: none;
}

@media (min-width: 1300px) {
	.xm-promo-showcase__item.xm-promo-showcase__item--wide-only {
		display: flex;
	}
}

.xm-promo-showcase__rotator {
	position: relative;
	display: grid;
	width: 100%;
	isolation: isolate;
	--xm-promo-switch-ms: 1.15s;
	--xm-promo-switch-ease: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Forced switch animations — each column uses its own rotator--anim-* class */
@keyframes xmPromoExitSlideUp {
	from { opacity: 1; transform: translate3d(0, 0, 0); }
	to { opacity: 0; transform: translate3d(0, -40px, 0); }
}

@keyframes xmPromoEnterSlideUp {
	from { opacity: 0; transform: translate3d(0, 40px, 0); }
	to { opacity: 1; transform: translate3d(0, 0, 0); }
}

@keyframes xmPromoExitSlideDown {
	from { opacity: 1; transform: translate3d(0, 0, 0); }
	to { opacity: 0; transform: translate3d(0, 32px, 0); }
}

@keyframes xmPromoEnterSlideDown {
	0% {
		opacity: 0;
		transform: translate3d(0, -56px, 0);
	}
	55% {
		opacity: 1;
		transform: translate3d(0, 12px, 0);
	}
	72% {
		transform: translate3d(0, -7px, 0);
	}
	86% {
		transform: translate3d(0, 4px, 0);
	}
	100% {
		opacity: 1;
		transform: translate3d(0, 0, 0);
	}
}

@keyframes xmPromoExitSlideLeft {
	from { opacity: 1; transform: translate3d(0, 0, 0); }
	to { opacity: 0; transform: translate3d(-40px, 0, 0); }
}

@keyframes xmPromoEnterSlideLeft {
	from { opacity: 0; transform: translate3d(40px, 0, 0); }
	to { opacity: 1; transform: translate3d(0, 0, 0); }
}

@keyframes xmPromoExitSlideRight {
	from { opacity: 1; transform: translate3d(0, 0, 0); }
	to { opacity: 0; transform: translate3d(40px, 0, 0); }
}

@keyframes xmPromoEnterSlideRight {
	from { opacity: 0; transform: translate3d(-40px, 0, 0); }
	to { opacity: 1; transform: translate3d(0, 0, 0); }
}

@keyframes xmPromoExitFade {
	from { opacity: 1; }
	to { opacity: 0; }
}

@keyframes xmPromoEnterFade {
	from { opacity: 0; }
	to { opacity: 1; }
}

@keyframes xmPromoExitZoom {
	from { opacity: 1; transform: scale(1); }
	to { opacity: 0; transform: scale(1.12); }
}

@keyframes xmPromoEnterZoom {
	from { opacity: 0; transform: scale(0.82); }
	to { opacity: 1; transform: scale(1); }
}

@keyframes xmPromoExitFlip {
	from { opacity: 1; transform: rotateY(0deg); }
	to { opacity: 0; transform: rotateY(88deg); }
}

@keyframes xmPromoEnterFlip {
	from { opacity: 0; transform: rotateY(-88deg); }
	to { opacity: 1; transform: rotateY(0deg); }
}

@keyframes xmPromoExitGradient {
	from { opacity: 1; filter: brightness(1) saturate(1); }
	to { opacity: 0; filter: brightness(1.45) saturate(0.25); }
}

@keyframes xmPromoEnterGradient {
	from { opacity: 0; filter: brightness(1.45) saturate(0.25); }
	to { opacity: 1; filter: brightness(1) saturate(1); }
}

.xm-promo-showcase__slide {
	grid-area: 1 / 1;
	align-self: end;
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 0;
	opacity: 0;
	z-index: 1;
	pointer-events: none;
	transform: translate3d(0, 0, 0) scale(1);
	filter: none;
}

.xm-promo-showcase__slide.is-active {
	opacity: 1;
	z-index: 2;
	pointer-events: auto;
}

/* Idle hidden slides — only when NOT mid-switch */
.xm-promo-showcase__rotator:not(.is-switching) .xm-promo-showcase__slide:not(.is-active) {
	opacity: 0;
	pointer-events: none;
	z-index: 1;
}

.xm-promo-showcase__rotator.is-switching .xm-promo-showcase__slide {
	transition: none !important;
	animation-fill-mode: forwards;
}

.xm-promo-showcase__rotator.is-switching .xm-promo-showcase__slide.is-leaving {
	z-index: 3;
	pointer-events: none;
}

.xm-promo-showcase__rotator.is-switching .xm-promo-showcase__slide.is-entering {
	z-index: 2;
	pointer-events: none;
}

.xm-promo-showcase__rotator--anim-slide-up.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitSlideUp var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-slide-up.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterSlideUp var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-slide-down.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitSlideDown var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-slide-down.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterSlideDown var(--xm-promo-switch-ms) cubic-bezier(0.34, 1.45, 0.64, 1) forwards;
}

/* Always play switch animations — ignore OS "reduce motion" for this banner */
@media (prefers-reduced-motion: reduce) {
	.xm-promo-showcase__rotator.is-switching .xm-promo-showcase__slide.is-leaving,
	.xm-promo-showcase__rotator.is-switching .xm-promo-showcase__slide.is-entering {
		animation-duration: var(--xm-promo-switch-ms) !important;
		animation-play-state: running !important;
	}
}

.xm-promo-showcase__rotator--anim-slide-left.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitSlideLeft var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-slide-left.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterSlideLeft var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-slide-right.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitSlideRight var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-slide-right.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterSlideRight var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-fade.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitFade var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-fade.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterFade var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-zoom.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitZoom var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-zoom.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterZoom var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-flip {
	perspective: 1200px;
}

.xm-promo-showcase__rotator--anim-flip .xm-promo-showcase__slide {
	transform-style: preserve-3d;
	backface-visibility: hidden;
}

.xm-promo-showcase__rotator--anim-flip.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitFlip var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-flip.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterFlip var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-gradient.is-switching .xm-promo-showcase__slide.is-leaving {
	animation: xmPromoExitGradient var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-gradient.is-switching .xm-promo-showcase__slide.is-entering {
	animation: xmPromoEnterGradient var(--xm-promo-switch-ms) var(--xm-promo-switch-ease) forwards;
}

.xm-promo-showcase__rotator--anim-none .xm-promo-showcase__slide {
	transition: none;
}

.xm-promo-showcase__rotator[data-slide-count='1'] .xm-promo-showcase__slide {
	opacity: 1;
	z-index: 1;
	pointer-events: auto;
}

.xm-promo-showcase__item.is-visible {
	transition:
		transform 0.85s cubic-bezier(0.34, 1.45, 0.64, 1) var(--xm-promo-delay, 0ms),
		filter 0.85s cubic-bezier(0.22, 1, 0.36, 1) var(--xm-promo-delay, 0ms);
}

.xm-promo-showcase__item--anim-none.is-visible {
	opacity: 1;
}

.xm-promo-showcase__item--anim-slide-left {
	transform: translate3d(-36px, 0, 0);
}

.xm-promo-showcase__item--anim-slide-left.is-visible {
	transform: translate3d(0, 0, 0);
}

.xm-promo-showcase__item--anim-slide-right {
	transform: translate3d(36px, 0, 0);
}

.xm-promo-showcase__item--anim-slide-right.is-visible {
	transform: translate3d(0, 0, 0);
}

.xm-promo-showcase__item--anim-slide-up {
	transform: translate3d(0, 28px, 0);
}

.xm-promo-showcase__item--anim-slide-up.is-visible {
	transform: translate3d(0, 0, 0);
}

.xm-promo-showcase__item--anim-slide-down {
	transform: translate3d(0, -36px, 0);
}

.xm-promo-showcase__item--anim-slide-down.is-visible {
	transform: translate3d(0, 0, 0);
}

.xm-promo-showcase__item--anim-flip {
	transform: rotateY(-75deg);
	transform-origin: center center;
}

.xm-promo-showcase__item--anim-flip.is-visible {
	transform: rotateY(0deg);
}

.xm-promo-showcase__item--anim-fade {
	transform: scale(0.97);
}

.xm-promo-showcase__item--anim-fade.is-visible {
	transform: scale(1);
}

.xm-promo-showcase__item--anim-zoom {
	transform: scale(0.82);
}

.xm-promo-showcase__item--anim-zoom.is-visible {
	transform: scale(1);
}

.xm-promo-showcase__item--anim-gradient {
	filter: brightness(1.2) saturate(0.55);
}

.xm-promo-showcase__item--anim-gradient.is-visible {
	filter: brightness(1) saturate(1);
}

.xm-promo-showcase__link {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-end;
	width: 100%;
	height: auto;
	min-height: 0;
	padding: 0 clamp(0.15rem, 0.5vw, 0.35rem);
	text-decoration: none;
	color: inherit;
	border-radius: var(--xm-radius-md);
	transition: background-color var(--xm-transition);
}

.xm-promo-showcase__link:hover {
	background: rgba(255, 255, 255, 0.35);
}

.xm-promo-showcase__media {
	display: flex;
	flex: 1 1 auto;
	align-items: flex-end;
	justify-content: center;
	width: 100%;
	min-height: 0;
	padding-bottom: clamp(0.15rem, 0.5vw, 0.35rem);
}

.xm-site .xm-promo-showcase__image {
	width: auto;
	height: auto;
	max-width: min(100%, 260px);
	max-height: min(78%, clamp(110px, 18vw, 220px));
	object-fit: contain;
	object-position: center bottom;
	filter: drop-shadow(0 10px 20px rgba(0, 0, 0, 0.14));
	transition: transform 0.35s ease;
}

.xm-site .xm-promo-showcase__slide--graphic .xm-promo-showcase__image {
	display: block;
	width: 100%;
	height: auto;
	max-width: 100%;
	max-height: none;
	object-fit: contain;
	object-position: center bottom;
}

.xm-promo-showcase__link:hover .xm-promo-showcase__image {
	transform: translateY(-3px) scale(1.02);
}

.xm-promo-showcase__info {
	flex: 0 0 auto;
	width: 100%;
	text-align: center;
	padding-bottom: clamp(0.1rem, 0.35vw, 0.25rem);
}

.xm-promo-showcase__title {
	margin: 0;
	font-size: clamp(0.625rem, 1.15vw, 0.875rem);
	font-weight: var(--xm-font-weight-bold);
	line-height: 1.15;
	color: var(--xm-color-text);
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.xm-promo-showcase__spec {
	margin: 0.15em 0 0;
	font-size: clamp(0.5625rem, 1vw, 0.8125rem);
	font-weight: var(--xm-font-weight-bold);
	line-height: 1.2;
	color: var(--xm-color-primary);
}

.xm-promo-showcase__prices {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: center;
	gap: 0.25rem 0.4rem;
	margin-top: 0.15em;
	line-height: 1.2;
}

.xm-promo-showcase__price-now {
	font-size: clamp(0.5625rem, 1vw, 0.8125rem);
	font-weight: var(--xm-font-weight-bold);
	color: var(--xm-color-primary);
}

.xm-promo-showcase__price-now .woocommerce-Price-amount {
	color: inherit;
	font-weight: inherit;
}

.xm-promo-showcase__price-was {
	font-size: clamp(0.625rem, 1.05vw, 0.8125rem);
	font-weight: var(--xm-font-weight-normal);
	color: var(--xm-color-text-muted);
	text-decoration: line-through;
}

.xm-promo-showcase__price-was .woocommerce-Price-amount {
	color: inherit;
}

@media (prefers-reduced-motion: reduce) {
	.xm-promo-showcase__item.is-visible {
		transition: none;
	}
}

@media (max-width: 767px) {
	.xm-promo-showcase__title {
		font-size: clamp(0.5625rem, 2.8vw, 0.75rem);
	}

	.xm-promo-showcase__spec {
		font-size: clamp(0.5rem, 2.4vw, 0.6875rem);
	}

	.xm-promo-showcase__price-now {
		font-size: clamp(0.5625rem, 2.6vw, 0.75rem);
	}

	.xm-promo-showcase__price-was {
		font-size: clamp(0.5rem, 2.2vw, 0.6875rem);
	}

	.xm-site .xm-promo-showcase__image {
		max-height: min(68%, clamp(80px, 18vw, 140px));
	}

	.xm-site .xm-promo-showcase__slide--graphic .xm-promo-showcase__image {
		max-height: none;
	}
}

@media (min-width: 768px) and (max-width: 1023px) {
	.xm-site .xm-promo-showcase__image {
		max-width: min(100%, clamp(160px, 14vw, 320px));
		max-height: min(76%, clamp(100px, 20vw, 280px));
	}

	.xm-site .xm-promo-showcase__slide--graphic .xm-promo-showcase__image {
		max-height: none;
	}
}

/* Desktop — scale non-graphic images; graphic PNGs keep natural height */
@media (min-width: 1024px) {
	.xm-promo-showcase__banner {
		min-height: clamp(170px, 13vw, 260px);
	}

	.xm-promo-showcase__title {
		font-size: clamp(0.75rem, 0.85vw, 1.375rem);
	}

	.xm-promo-showcase__spec {
		font-size: clamp(0.6875rem, 0.72vw, 1.125rem);
	}

	.xm-promo-showcase__price-now {
		font-size: clamp(0.6875rem, 0.72vw, 1.125rem);
	}

	.xm-promo-showcase__price-was {
		font-size: clamp(0.625rem, 0.65vw, 1rem);
	}

	.xm-site .xm-promo-showcase__slide:not(.xm-promo-showcase__slide--graphic) .xm-promo-showcase__image {
		max-width: min(100%, max(200px, 15vw));
		max-height: min(86%, max(140px, 26vw));
	}
}

@media (min-width: 1300px) {
	.xm-promo-showcase__banner {
		min-height: clamp(180px, 11vw, 280px);
	}

	.xm-promo-showcase__track {
		gap: clamp(0.2rem, 0.6vw, 1rem);
	}

	.xm-site .xm-promo-showcase__slide:not(.xm-promo-showcase__slide--graphic) .xm-promo-showcase__image {
		max-width: min(100%, max(180px, 12vw));
		max-height: min(86%, max(130px, 24vw));
	}
}

@media (min-width: 1600px) {
	.xm-promo-showcase__banner {
		min-height: clamp(190px, 10vw, 300px);
	}

	.xm-site .xm-promo-showcase__slide:not(.xm-promo-showcase__slide--graphic) .xm-promo-showcase__image {
		max-width: min(100%, max(220px, 13vw));
		max-height: min(88%, max(160px, 25vw));
	}
}

@media (min-width: 1920px) {
	.xm-promo-showcase__banner {
		min-height: clamp(200px, 9vw, 320px);
	}

	.xm-site .xm-promo-showcase__slide:not(.xm-promo-showcase__slide--graphic) .xm-promo-showcase__image {
		max-width: min(100%, max(260px, 12vw));
		max-height: min(88%, max(200px, 24vw));
	}
}

@media (min-width: 2560px) {
	.xm-promo-showcase__banner {
		min-height: clamp(220px, 8vw, 360px);
	}

	.xm-promo-showcase__title {
		font-size: clamp(1rem, 0.75vw, 1.75rem);
	}

	.xm-promo-showcase__spec,
	.xm-promo-showcase__price-now {
		font-size: clamp(0.875rem, 0.62vw, 1.5rem);
	}

	.xm-site .xm-promo-showcase__slide:not(.xm-promo-showcase__slide--graphic) .xm-promo-showcase__image {
		max-width: min(100%, max(320px, 11vw));
		max-height: min(88%, max(260px, 22vw));
	}
}

@media (min-width: 3840px) {
	.xm-promo-showcase__banner {
		min-height: clamp(240px, 7vw, 400px);
	}

	.xm-site .xm-promo-showcase__slide:not(.xm-promo-showcase__slide--graphic) .xm-promo-showcase__image {
		max-width: min(100%, max(420px, 10vw));
		max-height: min(88%, max(340px, 20vw));
	}
}

.xm-promo-showcase__slide--graphic .xm-promo-showcase__media {
	flex: 0 0 auto;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: auto;
	padding: 0;
}

.xm-promo-showcase__slide--graphic .xm-promo-showcase__link {
	justify-content: flex-end;
	height: auto;
	padding: 0 clamp(0.15rem, 0.5vw, 0.35rem);
}

.xm-site .xm-promo-showcase__slide--graphic .xm-promo-showcase__image {
	display: block;
	width: 100%;
	height: auto;
	max-width: 100%;
	max-height: none;
	object-fit: contain;
	object-position: center bottom;
}

/* Homepage product sections */
.xm-home-section {
	padding: var(--xm-space-xl) 0;
}

.xm-home-section--alt {
	background: var(--xm-color-bg-alt);
}

.xm-home-section__empty {
	text-align: center;
	padding: var(--xm-space-xl);
	color: var(--xm-color-text-muted);
	font-size: var(--xm-font-size-sm);
}

@media (min-width: 768px) {
	.xm-hero__content {
		justify-content: flex-start;
		max-width: none;
		margin: 0;
		padding-left: clamp(1.25rem, 2.5vw, 2.75rem);
		padding-right: var(--xm-container-padding);
	}

	.xm-hero__body {
		max-width: min(520px, 46vw);
	}

	.xm-hero__title {
		margin-bottom: var(--xm-space-lg);
	}

	.xm-hero__subtitle {
		margin-bottom: var(--xm-space-xl);
	}

	.xm-hero__cta {
		min-width: 160px;
		padding-left: 1.75rem;
		padding-right: 1.75rem;
		font-size: var(--xm-font-size-base);
	}
}

@media (min-width: 1024px) {
	.xm-hero__content {
		padding-left: clamp(1.5rem, 3vw, 3.25rem);
	}

	.xm-hero__body {
		max-width: 560px;
	}

	.xm-hero__media,
	.xm-site .xm-hero__image {
		object-position: center center;
		background-position: center center;
	}

	.xm-hero__overlay {
		background: linear-gradient(
			90deg,
			rgba(0, 0, 0, 0.5) 0%,
			rgba(0, 0, 0, 0.22) 42%,
			transparent 72%
		);
	}
}

@media (min-width: 1200px) {
	.xm-hero__body {
		max-width: 600px;
	}
}

@media (max-width: 767px) {
	.xm-hero__media {
		background-position: 50% center;
	}

	.xm-site .xm-hero__image {
		object-position: 50% 30%;
	}

	.xm-hero__overlay {
		background: linear-gradient(
			180deg,
			rgba(0, 0, 0, 0.08) 0%,
			rgba(0, 0, 0, 0.35) 50%,
			rgba(0, 0, 0, 0.72) 100%
		);
	}

	.xm-hero__content {
		align-items: flex-end;
		padding-top: var(--xm-space-lg);
		padding-bottom: max(var(--xm-space-xl), env(safe-area-inset-bottom, 0px));
		padding-left: max(1.25rem, env(safe-area-inset-left, 0px));
		padding-right: max(1.25rem, env(safe-area-inset-right, 0px));
	}

	.xm-hero__body {
		padding-bottom: var(--xm-space-xs);
	}

	.xm-hero__title-line2 {
		display: block;
	}
}

@media (min-width: 768px) and (max-width: 1023px) {
	.xm-hero__media {
		background-position: 55% center;
	}

	.xm-site .xm-hero__image {
		object-position: 55% center;
	}
}
