/**
 * Single Product Page — Almutaheda Pack
 *
 * RTL-first, mobile-first. All values reference tokens.css.
 * Load order: tokens → base → buttons → badges → cards → product-card → this file.
 */

/* ══════════════════════════════════════════════════════════════════════
   PAGE ROOT
   ══════════════════════════════════════════════════════════════════════ */

.single-product .alm-site-content,
body.single-product .alm-site-content {
	background: var(--alm-color-surface-page);
}

/* Remove WC's default outer wrapper padding if it fires */
.woocommerce-page.single-product #primary,
.woocommerce-page.single-product #main {
	padding: 0;
	margin: 0;
	width: 100%;
}

/* ══════════════════════════════════════════════════════════════════════
   BREADCRUMB STRIP
   Output by woocommerce_before_main_content, lives outside .alm-single-product.
   ══════════════════════════════════════════════════════════════════════ */

.single-product .woocommerce-breadcrumb {
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-muted);
	margin: 0;
	padding-block: var(--alm-space-3);
	padding-inline: var(--alm-container-padding-x);
	max-width: var(--alm-container-xl);
	margin-inline: auto;
}

.single-product .woocommerce-breadcrumb a {
	color: var(--alm-color-text-muted);
	text-decoration: none;
}

.single-product .woocommerce-breadcrumb a:hover {
	color: var(--alm-color-text-link-hover);
}

/* ══════════════════════════════════════════════════════════════════════
   PRODUCT ROOT SHELL
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product {
	overflow-x: hidden;
}

/* ══════════════════════════════════════════════════════════════════════
   HERO WRAP — BACKGROUND
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__hero-wrap {
	background: var(--alm-color-white);
	padding-block: var(--alm-space-6) var(--alm-space-8);
	border-bottom: var(--alm-border-standard);
}

/* ══════════════════════════════════════════════════════════════════════
   HERO GRID — TWO COLUMN
   Gallery (col 1) | Summary (col 2)  — RTL: summary is inline-start
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--alm-space-6);
	align-items: flex-start;
}

/* Tablet: equal columns */
@media (min-width: 768px) {
	.alm-single-product__hero {
		grid-template-columns: 1fr 1fr;
		gap: var(--alm-space-8);
	}
}

/* Desktop: gallery 48 / summary 52 */
@media (min-width: 1024px) {
	.alm-single-product__hero {
		grid-template-columns: 48fr 52fr;
		gap: var(--alm-space-10);
	}
}

/* ── Gallery column ───────────────────────────────────────────────── */

.alm-single-product__gallery {
	min-width: 0;
}

@media (min-width: 768px) {
	.alm-single-product__gallery {
		position: sticky;
		top: var(--alm-space-6);
	}
}

/* WooCommerce product gallery wrapper */
.alm-single-product__gallery .woocommerce-product-gallery {
	border-radius: var(--alm-radius-xl);
	overflow: hidden;
	background: var(--alm-color-ivory);
	border: var(--alm-border-standard);
	box-shadow: var(--alm-shadow-sm);
}

/* Main gallery image */
.alm-single-product__gallery .woocommerce-product-gallery__image img,
.alm-single-product__gallery .woocommerce-product-gallery .wp-post-image {
	display: block;
	width: 100%;
	height: auto;
	min-height: 260px;
	object-fit: contain;
	aspect-ratio: 1 / 1;
	padding: var(--alm-space-6);
}

@media (min-width: 768px) {
	.alm-single-product__gallery .woocommerce-product-gallery__image img,
	.alm-single-product__gallery .woocommerce-product-gallery .wp-post-image {
		min-height: 360px;
	}
}

@media (min-width: 1024px) {
	.alm-single-product__gallery .woocommerce-product-gallery__image img,
	.alm-single-product__gallery .woocommerce-product-gallery .wp-post-image {
		min-height: 420px;
	}
}

/* WooCommerce native placeholder (shown when no image) */
.alm-single-product__gallery .woocommerce-product-gallery .woocommerce-product-gallery__image--placeholder,
.alm-single-product__gallery .woocommerce-product-gallery a.woocommerce-product-gallery__image {
	display: block;
}

.alm-single-product__gallery .woocommerce-product-gallery__image--placeholder img {
	object-fit: contain;
	padding: var(--alm-space-10);
	opacity: 0.25;
	min-height: 260px;
}

@media (min-width: 1024px) {
	.alm-single-product__gallery .woocommerce-product-gallery__image--placeholder img {
		min-height: 420px;
	}
}

/* Caption over placeholder */
.alm-single-product__gallery .woocommerce-product-gallery__image--placeholder::after {
	content: attr(data-placeholder-label);
	display: none; /* label is in the alt text — no need for double text */
}

/* Gallery thumbnails */
.alm-single-product__gallery .flex-control-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--alm-space-2);
	margin-block-start: var(--alm-space-3);
	padding: 0 var(--alm-space-2) var(--alm-space-2);
	list-style: none;
}

.alm-single-product__gallery .flex-control-thumbs img {
	width: 3.5rem;
	height: 3.5rem;
	object-fit: contain;
	border-radius: var(--alm-radius-md);
	border: 2px solid var(--alm-color-border);
	cursor: pointer;
	padding: var(--alm-space-1);
	background: var(--alm-color-white);
	transition: border-color var(--alm-duration-base) var(--alm-easing-standard);
}

.alm-single-product__gallery .flex-control-thumbs li.flex-active img,
.alm-single-product__gallery .flex-control-thumbs img:hover {
	border-color: var(--alm-color-sand);
}

/* ── Summary / Purchase panel ─────────────────────────────────────── */

.alm-single-product__summary {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-4);
	min-width: 0;
}

@media (min-width: 768px) {
	.alm-single-product__summary {
		position: sticky;
		top: var(--alm-space-6);
	}
}

/* Category tag above title */
.alm-single-product__category {
	margin: 0;
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-muted);
}

.alm-single-product__category a {
	color: var(--alm-color-text-muted);
	text-decoration: none;
}

.alm-single-product__category a:hover {
	color: var(--alm-color-sand-dark);
}

/* ── WC title ─────────────────────────────────────────────────────── */

.alm-single-product .product_title.entry-title {
	font-size: var(--alm-text-2xl);
	font-weight: var(--alm-weight-bold);
	line-height: var(--alm-leading-tight);
	color: var(--alm-color-text-primary);
	margin: 0;
	letter-spacing: -0.02em;
}

@media (min-width: 1024px) {
	.alm-single-product .product_title.entry-title {
		font-size: var(--alm-text-3xl);
	}
}

/* ── Stock status ─────────────────────────────────────────────────── */

.alm-single-product .stock {
	display: inline-flex;
	align-items: center;
	gap: var(--alm-space-1-5);
	font-size: var(--alm-text-sm);
	font-weight: var(--alm-weight-medium);
	margin: 0;
}

.alm-single-product .stock.in-stock {
	color: var(--alm-color-success);
}

.alm-single-product .stock.out-of-stock {
	color: var(--alm-color-error);
}

.alm-single-product .stock.in-stock::before {
	content: '';
	display: inline-block;
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: currentColor;
	flex-shrink: 0;
}

/* ── Price ────────────────────────────────────────────────────────── */

.alm-single-product .price {
	margin: 0;
	line-height: 1.2;
}

.alm-single-product .price .woocommerce-Price-amount {
	font-size: var(--alm-text-2xl);
	font-weight: var(--alm-weight-bold);
	color: var(--alm-color-navy-primary);
	font-variant-numeric: tabular-nums;
}

.alm-single-product .price .woocommerce-Price-currencySymbol {
	font-size: var(--alm-text-lg);
}

.alm-single-product .price del .woocommerce-Price-amount {
	font-size: var(--alm-text-base);
	color: var(--alm-color-text-muted);
	font-weight: var(--alm-weight-regular);
}

.alm-single-product .price ins {
	text-decoration: none;
}

/* ── Short description ────────────────────────────────────────────── */

.alm-single-product .woocommerce-product-details__short-description {
	font-size: var(--alm-text-base);
	color: var(--alm-color-text-secondary);
	line-height: var(--alm-leading-relaxed);
	margin: 0;
}

.alm-single-product .woocommerce-product-details__short-description p:last-child {
	margin: 0;
}

/* ── Product badges injected by woocommerce.php ───────────────────── */

.alm-single-product__badges {
	display: flex;
	flex-wrap: wrap;
	gap: var(--alm-space-2);
}

/* ── Add-to-cart form ─────────────────────────────────────────────── */

.alm-single-product .cart {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-3);
	margin: 0;
}

/* Quantity row */
.alm-single-product .cart .quantity {
	display: flex;
	align-items: center;
	gap: var(--alm-space-2);
}

.alm-single-product .quantity .qty {
	width: 4.5rem;
	min-height: var(--alm-btn-height);
	text-align: center;
	font-size: var(--alm-text-base);
	font-weight: var(--alm-weight-semibold);
	border: var(--alm-border-standard);
	border-radius: var(--alm-radius-lg);
	padding: var(--alm-space-2) var(--alm-space-3);
	color: var(--alm-color-text-primary);
	background: var(--alm-color-white);
	-moz-appearance: textfield;
	appearance: textfield;
}

.alm-single-product .quantity .qty::-webkit-inner-spin-button,
.alm-single-product .quantity .qty::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.alm-single-product .quantity .qty:focus {
	outline: var(--alm-focus-ring-width) solid var(--alm-focus-ring-color);
	outline-offset: var(--alm-focus-ring-offset);
	border-color: var(--alm-color-navy-primary);
}

/* WooCommerce native add-to-cart button — override WC purple/default */
.alm-single-product .single_add_to_cart_button,
.alm-single-product button.single_add_to_cart_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--alm-space-2);
	width: 100%;
	min-height: var(--alm-btn-height);
	padding-block: var(--alm-btn-padding-y);
	padding-inline: var(--alm-btn-padding-x);
	font-family: var(--alm-font-arabic);
	font-size: var(--alm-btn-font-size);
	font-weight: var(--alm-btn-font-weight);
	border-radius: var(--alm-btn-radius);
	background-color: var(--alm-color-navy-primary) !important;
	color: var(--alm-color-white) !important;
	border: 2px solid var(--alm-color-navy-primary) !important;
	text-decoration: none;
	cursor: pointer;
	transition: var(--alm-btn-transition);
	box-shadow: 0 4px 14px rgba(14, 34, 58, 0.18);
	letter-spacing: -0.01em;
}

.alm-single-product .single_add_to_cart_button:hover:not(:disabled) {
	background-color: var(--alm-color-navy-primary-90) !important;
	border-color: var(--alm-color-navy-primary-90) !important;
	transform: translateY(-1px);
	box-shadow: 0 8px 22px rgba(14, 34, 58, 0.24);
}

.alm-single-product .single_add_to_cart_button:active:not(:disabled) {
	transform: translateY(0);
	box-shadow: 0 2px 6px rgba(14, 34, 58, 0.14);
}

.alm-single-product .single_add_to_cart_button:disabled,
.alm-single-product .single_add_to_cart_button.disabled {
	opacity: 0.5;
	cursor: not-allowed;
	transform: none;
}

.alm-single-product .single_add_to_cart_button:focus-visible {
	outline: var(--alm-focus-ring-width) solid var(--alm-focus-ring-color);
	outline-offset: var(--alm-focus-ring-offset);
}

/* ── WhatsApp CTA ─────────────────────────────────────────────────── */

.alm-single-product__wa-cta {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-1-5);
}

.alm-single-product__wa-btn {
	width: 100%;
}

.alm-single-product__wa-note {
	font-size: var(--alm-text-xs);
	color: var(--alm-color-text-muted);
	text-align: center;
	margin: 0;
}

/* ── Price note ───────────────────────────────────────────────────── */

.alm-single-product__price-note {
	font-size: var(--alm-text-xs);
	color: var(--alm-color-text-muted);
	margin: 0;
	padding: var(--alm-space-2-5) var(--alm-space-3);
	background: var(--alm-color-surface-subtle);
	border-radius: var(--alm-radius-md);
	border-inline-start: 3px solid var(--alm-color-sand);
}

/* ══════════════════════════════════════════════════════════════════════
   REASSURANCE STRIP
   ══════════════════════════════════════════════════════════════════════ */

.alm-product-reassurance {
	background: var(--alm-color-surface-subtle);
	border-block: var(--alm-border-standard);
	padding-block: var(--alm-space-5);
}

.alm-product-reassurance__inner {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--alm-space-4);
}

@media (min-width: 768px) {
	.alm-product-reassurance__inner {
		grid-template-columns: repeat(4, 1fr);
		gap: var(--alm-space-3);
	}
}

.alm-product-reassurance__item {
	display: flex;
	align-items: flex-start;
	gap: var(--alm-space-2);
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-secondary);
	line-height: var(--alm-leading-snug);
}

.alm-product-reassurance__icon {
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	display: flex;
	align-items: center;
	color: var(--alm-color-sand-dark);
	margin-block-start: 0.1rem;
}

.alm-product-reassurance__label {
	font-weight: var(--alm-weight-medium);
}

/* ══════════════════════════════════════════════════════════════════════
   SPECIFICATION BLOCK
   ══════════════════════════════════════════════════════════════════════ */

.alm-specs {
	border: var(--alm-border-standard);
	border-radius: var(--alm-radius-lg);
	overflow: hidden;
}

.alm-specs__title {
	font-size: var(--alm-text-xs);
	font-weight: var(--alm-weight-semibold);
	color: var(--alm-color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.07em;
	padding: var(--alm-space-2-5) var(--alm-space-4);
	background: var(--alm-color-surface-subtle);
	margin: 0;
	border-bottom: var(--alm-border-standard);
}

.alm-specs__grid {
	margin: 0;
	padding: 0;
}

.alm-specs__row {
	display: flex;
	align-items: baseline;
	gap: var(--alm-space-3);
	padding: var(--alm-space-2) var(--alm-space-4);
	border-bottom: var(--alm-border-standard);
}

.alm-specs__row:last-child {
	border-bottom: none;
}

.alm-specs__label {
	flex: 0 0 8rem;
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-muted);
	font-weight: var(--alm-weight-medium);
}

.alm-specs__value {
	flex: 1 1 auto;
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-primary);
	font-weight: var(--alm-weight-semibold);
	margin: 0;
	min-width: 0;
}

/* ══════════════════════════════════════════════════════════════════════
   WOOCOMMERCE PRODUCT TABS — RESKIN
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__details-wrap {
	background: var(--alm-color-white);
	padding-block: var(--alm-space-6) var(--alm-space-6);
}

.alm-single-product .woocommerce-tabs.wc-tabs-wrapper {
	margin: 0;
}

/* Tab nav */
.alm-single-product .woocommerce-tabs .tabs.wc-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--alm-space-1);
	margin: 0 0 0;
	padding: 0;
	list-style: none;
	border-bottom: 2px solid var(--alm-color-border);
}

.alm-single-product .woocommerce-tabs .tabs.wc-tabs li {
	margin: 0;
	border: none;
}

.alm-single-product .woocommerce-tabs .tabs.wc-tabs li a {
	display: inline-flex;
	align-items: center;
	padding: var(--alm-space-2-5) var(--alm-space-5);
	font-size: var(--alm-text-sm);
	font-weight: var(--alm-weight-semibold);
	color: var(--alm-color-text-muted);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	border-radius: var(--alm-radius-md) var(--alm-radius-md) 0 0;
	transition: color var(--alm-duration-base) var(--alm-easing-standard),
	            border-color var(--alm-duration-base) var(--alm-easing-standard);
	background: none;
}

.alm-single-product .woocommerce-tabs .tabs.wc-tabs li.active a,
.alm-single-product .woocommerce-tabs .tabs.wc-tabs li a:hover {
	color: var(--alm-color-navy-primary);
	border-bottom-color: var(--alm-color-navy-primary);
	background: none;
}

.alm-single-product .woocommerce-tabs .tabs.wc-tabs li a::before {
	display: none; /* WC adds a pseudo-content border trick we don't need */
}

.alm-single-product .woocommerce-tabs .tabs.wc-tabs li a:focus-visible {
	outline: var(--alm-focus-ring-width) solid var(--alm-focus-ring-color);
	outline-offset: var(--alm-focus-ring-offset);
}

/* Panel */
.alm-single-product .woocommerce-tabs .panel {
	padding: var(--alm-space-6) 0 0;
	background: transparent;
	border: none;
}

.alm-single-product .woocommerce-tabs .panel h2 {
	display: none;
}

/* Attributes table inside additional information tab */
.alm-single-product .shop_attributes {
	width: 100%;
	font-size: var(--alm-text-sm);
	border-collapse: collapse;
}

.alm-single-product .shop_attributes th,
.alm-single-product .shop_attributes td {
	padding: var(--alm-space-2) var(--alm-space-3);
	border-bottom: var(--alm-border-standard);
	text-align: start;
	vertical-align: top;
}

.alm-single-product .shop_attributes th {
	font-weight: var(--alm-weight-semibold);
	color: var(--alm-color-text-secondary);
	width: 38%;
	background: var(--alm-color-surface-subtle);
}

.alm-single-product .shop_attributes td p {
	margin: 0;
}

/* ══════════════════════════════════════════════════════════════════════
   SHARED SECTION TITLES
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__section-title {
	font-size: var(--alm-text-xl);
	font-weight: var(--alm-weight-bold);
	color: var(--alm-color-text-primary);
	margin-block: 0 var(--alm-space-5);
	padding-block-end: var(--alm-space-3);
	border-bottom: 2px solid var(--alm-color-sand-light);
}

/* ══════════════════════════════════════════════════════════════════════
   SUITABLE USES
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__suitable {
	background: var(--alm-color-surface-subtle);
	border-block: var(--alm-border-standard);
	padding-block: var(--alm-space-8);
}

.alm-single-product__usage-note {
	font-size: var(--alm-text-base);
	color: var(--alm-color-text-secondary);
	margin-block-end: var(--alm-space-5);
	line-height: var(--alm-leading-relaxed);
}

.alm-suitable-uses {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--alm-space-2-5);
	margin: 0;
	padding: 0;
	list-style: none;
}

@media (min-width: 600px) {
	.alm-suitable-uses {
		grid-template-columns: repeat(2, 1fr);
	}
}

.alm-suitable-uses__item {
	display: flex;
	align-items: flex-start;
	gap: var(--alm-space-2);
	font-size: var(--alm-text-base);
	color: var(--alm-color-text-primary);
	margin: 0;
}

.alm-suitable-uses__check {
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	display: flex;
	align-items: center;
	color: var(--alm-color-success);
	margin-block-start: 0.15rem;
}

/* ══════════════════════════════════════════════════════════════════════
   COMPLEMENTARY PRODUCTS
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__crosssells-wrap {
	background: var(--alm-color-white);
	padding-block: var(--alm-space-8);
}

/* ══════════════════════════════════════════════════════════════════════
   RELATED PRODUCTS GRID
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__related-wrap {
	background: var(--alm-color-surface-subtle);
	padding-block: var(--alm-space-8);
	border-block: var(--alm-border-standard);
}

/* Override WC/loop grid to enforce max 4 columns */
.alm-single-product__related-grid.products {
	display: grid !important;
	list-style: none;
	padding: 0;
	margin: 0;
	gap: var(--alm-space-5);
	grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 1024px) {
	.alm-single-product__related-grid.products {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ══════════════════════════════════════════════════════════════════════
   FAQ ACCORDION
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__faq {
	background: var(--alm-color-white);
	padding-block: var(--alm-space-8);
}

.alm-faq {
	display: flex;
	flex-direction: column;
	border: var(--alm-border-standard);
	border-radius: var(--alm-radius-lg);
	overflow: hidden;
}

.alm-faq__item {
	border-bottom: var(--alm-border-standard);
}

.alm-faq__item:last-child {
	border-bottom: none;
}

.alm-faq__question {
	margin: 0;
}

.alm-faq__trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--alm-space-4);
	width: 100%;
	padding: var(--alm-space-4) var(--alm-space-5);
	font-family: var(--alm-font-arabic);
	font-size: var(--alm-text-base);
	font-weight: var(--alm-weight-semibold);
	color: var(--alm-color-text-primary);
	text-align: start;
	background: none;
	border: none;
	cursor: pointer;
	transition: background-color var(--alm-duration-base) var(--alm-easing-standard);
	min-height: 3rem;
}

.alm-faq__trigger:hover {
	background: var(--alm-color-surface-subtle);
}

.alm-faq__trigger:focus-visible {
	outline: var(--alm-focus-ring-width) solid var(--alm-focus-ring-color);
	outline-offset: var(--alm-focus-ring-offset);
}

.alm-faq__trigger[aria-expanded="true"] {
	color: var(--alm-color-navy-primary);
	background: var(--alm-color-navy-primary-10);
}

.alm-faq__icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	transition: transform var(--alm-duration-base) var(--alm-easing-standard);
}

.alm-faq__trigger[aria-expanded="true"] .alm-faq__icon {
	transform: rotate(180deg);
}

.alm-faq__answer {
	padding: 0 var(--alm-space-5) var(--alm-space-4);
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-secondary);
	line-height: var(--alm-leading-relaxed);
}

.alm-faq__answer[hidden] {
	display: none;
}

.alm-faq__answer p:last-child {
	margin: 0;
}

/* ══════════════════════════════════════════════════════════════════════
   FINAL CTA
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__final-cta {
	background: linear-gradient(135deg, var(--alm-color-navy-primary) 0%, var(--alm-color-navy-secondary) 100%);
	color: var(--alm-color-white);
	padding-block: var(--alm-space-10);
	margin-block-end: 0;
}

.alm-single-product__final-cta-inner {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-5);
	align-items: flex-start;
}

@media (min-width: 768px) {
	.alm-single-product__final-cta-inner {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		gap: var(--alm-space-8);
	}
}

.alm-single-product__final-cta-text h2 {
	font-size: var(--alm-text-xl);
	font-weight: var(--alm-weight-bold);
	color: var(--alm-color-white);
	margin: 0 0 var(--alm-space-2);
	line-height: var(--alm-leading-tight);
}

.alm-single-product__final-cta-text p {
	font-size: var(--alm-text-sm);
	color: rgba(255, 255, 255, 0.78);
	margin: 0;
	max-width: 34rem;
	line-height: var(--alm-leading-relaxed);
}

.alm-single-product__final-cta-actions {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-2-5);
	flex-shrink: 0;
	width: 100%;
}

@media (min-width: 768px) {
	.alm-single-product__final-cta-actions {
		flex-direction: row;
		width: auto;
	}
}

/* Final CTA buttons need to be full-width on mobile */
.alm-single-product__final-cta-actions .alm-btn {
	width: 100%;
	justify-content: center;
}

@media (min-width: 768px) {
	.alm-single-product__final-cta-actions .alm-btn {
		width: auto;
	}
}

/* ══════════════════════════════════════════════════════════════════════
   WC NOTICES
   ══════════════════════════════════════════════════════════════════════ */

.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	padding: var(--alm-space-3) var(--alm-space-5);
	border-radius: var(--alm-radius-lg);
	font-size: var(--alm-text-sm);
	margin-block-end: var(--alm-space-4);
	list-style: none;
	margin-inline: 0;
}

.woocommerce-message {
	background: var(--alm-color-success-bg);
	color: var(--alm-color-success);
	border-inline-start: 3px solid var(--alm-color-success);
}

.woocommerce-error {
	background: var(--alm-color-error-bg);
	color: var(--alm-color-error);
	border-inline-start: 3px solid var(--alm-color-error);
}

.woocommerce-info {
	background: var(--alm-color-info-bg);
	color: var(--alm-color-info);
	border-inline-start: 3px solid var(--alm-color-info);
}

/* ══════════════════════════════════════════════════════════════════════
   PLACEHOLDER LABEL
   Shown below the WC native placeholder when the product has no image.
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product__placeholder-label {
	text-align: center;
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-muted);
	margin: var(--alm-space-2) 0 0;
	padding-inline: var(--alm-space-4);
}

/* ══════════════════════════════════════════════════════════════════════
   SINGLE TAB — hide nav, show panel inline
   Applied when body.alm-single-tab is set by PHP (one tab remaining).
   ══════════════════════════════════════════════════════════════════════ */

/* Hide the tab navigation entirely */
.alm-single-tab .alm-single-product .woocommerce-tabs .tabs.wc-tabs {
	display: none;
}

/* Remove the top gap/border that separates nav from panel */
.alm-single-tab .alm-single-product .woocommerce-tabs .panel {
	padding-block-start: 0;
	border-top: none;
}

/* Show the panel heading (hidden by default) as a section label */
.alm-single-tab .alm-single-product .woocommerce-tabs .panel h2 {
	display: block;
	font-size: var(--alm-text-base);
	font-weight: var(--alm-weight-semibold);
	color: var(--alm-color-text-secondary);
	margin: 0 0 var(--alm-space-4);
	padding-block-end: var(--alm-space-2);
	border-bottom: var(--alm-border-standard);
}

/* ══════════════════════════════════════════════════════════════════════
   OVERFLOW / HORIZONTAL SCROLL GUARD
   ══════════════════════════════════════════════════════════════════════ */

.alm-single-product,
.alm-single-product__hero-wrap,
.alm-single-product__gallery,
.alm-single-product__summary,
.alm-product-reassurance,
.alm-single-product__details-wrap {
	overflow-x: hidden;
	max-width: 100%;
}

/* ══════════════════════════════════════════════════════════════════════
   REDUCED MOTION
   ══════════════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
	.alm-faq__icon,
	.alm-faq__trigger,
	.flex-control-thumbs img,
	.alm-single-product__wa-btn,
	.alm-single-product .single_add_to_cart_button,
	.alm-btn {
		transition: none !important;
		transform: none !important;
	}
}
