/* ============================================================
   Single product — card-specific layout
   ============================================================ */

.scs-product {
	display: grid;
	gap: var(--scs-space-5);
	padding: var(--scs-space-4) 0;
}

@media (min-width: 768px) {
	.scs-product {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	}
}

.scs-product__gallery {
	display: grid;
	gap: var(--scs-space-3);
}

.scs-product__gallery-main {
	background-color: var(--scs-color-surface);
	border-radius: var(--scs-radius-md);
	overflow: hidden;
	aspect-ratio: 5 / 7;
}

.scs-product__gallery-main img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.scs-product__gallery-thumbs {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--scs-space-2);
}

.scs-product__gallery-thumbs img {
	border-radius: var(--scs-radius-sm);
	cursor: pointer;
}

/* ============================================================
   WooCommerce native gallery thumbnails — Flexslider control nav.
   Style the auto-generated <ol class="flex-control-thumbs"> that
   appears below the main image when the product has multiple
   gallery images (front + back + extras).
   ============================================================ */
.woocommerce-product-gallery .flex-control-thumbs {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
	gap: 10px;
	list-style: none;
	margin: 0 !important;
	padding: 32px 0 0 !important;
	clear: both;
}

/* Force a visible gap between the main image area and the thumbnail
   strip. WC core CSS adds rules that collapse margins and clear
   floats; padding on the wrapper is the only spacing that survives. */
.woocommerce div.product div.images .woocommerce-product-gallery__wrapper,
.woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
	margin: 0 0 24px !important;
}

.woocommerce-product-gallery .flex-control-thumbs li {
	margin: 0;
	width: auto !important;
	float: none !important;
}

.woocommerce-product-gallery .flex-control-thumbs li img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	border-radius: 6px;
	border: 1px solid var(--scs-color-gold-hairline, rgba(212, 175, 55, 0.25));
	background-color: var(--scs-color-surface, #14100a);
	opacity: 0.7;
	cursor: pointer;
	transition: opacity 0.25s, border-color 0.25s, transform 0.25s;
}

.woocommerce-product-gallery .flex-control-thumbs li img:hover {
	opacity: 0.95;
	border-color: var(--scs-color-gold, #D4AF37);
	transform: translateY(-2px);
}

.woocommerce-product-gallery .flex-control-thumbs li img.flex-active {
	opacity: 1;
	border-color: var(--scs-color-gold-bright, #f0ce6a);
	box-shadow: 0 0 0 1px var(--scs-color-gold-bright, #f0ce6a),
		0 4px 14px rgba(212, 175, 55, 0.18);
}

/* If the gallery wrapper has its own grid layout, ensure the
   thumbnail strip sits below the main image on full width. */
.woocommerce-product-gallery {
	position: relative;
	width: 100%;
}

.woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
	margin: 0;
}

@media (max-width: 480px) {
	.woocommerce-product-gallery .flex-control-thumbs {
		grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
		gap: 8px;
	}
}

.scs-product__summary {
	display: flex;
	flex-direction: column;
	gap: var(--scs-space-3);
}

.scs-product__title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	margin: 0;
}

.scs-product__price {
	font-size: 1.75rem;
	color: var(--scs-color-gold);
	font-weight: 700;
}

.scs-product__grade-chip {
	display: inline-block;
	padding: 4px 10px;
	border-radius: var(--scs-radius-sm);
	background-color: var(--scs-color-crimson);
	color: var(--scs-color-text);
	font-weight: 700;
	font-size: 0.85rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	width: fit-content;
}

.scs-card-meta {
	background-color: var(--scs-color-surface);
	padding: var(--scs-space-4);
	border-radius: var(--scs-radius-md);
	display: grid;
	gap: var(--scs-space-2);
}

.scs-card-meta__row {
	display: flex;
	justify-content: space-between;
	gap: var(--scs-space-3);
	border-bottom: 1px dashed rgba(168, 178, 216, 0.15);
	padding-bottom: var(--scs-space-2);
}

.scs-card-meta__row:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.scs-card-meta__label {
	color: var(--scs-color-text-muted);
	text-transform: uppercase;
	font-size: 0.75rem;
	letter-spacing: 0.08em;
}

.scs-card-meta__value {
	color: var(--scs-color-text);
	font-weight: 600;
	text-align: right;
}

.scs-product__add-to-cart {
	display: flex;
	gap: var(--scs-space-2);
	align-items: center;
	flex-wrap: wrap;
}

.scs-product__negotiate {
	margin-top: var(--scs-space-3);
	padding: var(--scs-space-3);
	border: 1px dashed rgba(245, 197, 24, 0.35);
	border-radius: var(--scs-radius-md);
	background-color: rgba(245, 197, 24, 0.04);
}

.scs-product__negotiate p {
	margin: 0 0 var(--scs-space-2);
	color: var(--scs-color-text-muted);
	font-size: 0.9rem;
}

/* ============================================================
   Related / Upsells / Cross-sells — horizontal swipe slider.
   Cards live on a single horizontal track that scroll-snaps,
   so users can flick sideways through the row at any width.
   ============================================================ */

.related.products,
.upsells.products,
.cross-sells.products,
section.related,
section.upsells,
section.cross-sells {
	margin-top: var(--scs-space-6);
	position: relative;
}

.related.products > h2,
.upsells.products > h2,
.cross-sells.products > h2,
section.related > h2,
section.upsells > h2,
section.cross-sells > h2 {
	font-family: var(--scs-font-display);
	font-size: clamp(1.1rem, 3.4vw, 1.6rem);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--scs-color-text);
	margin: 0 0 var(--scs-space-4);
}

.related.products ul.products,
.related ul.products,
.upsells.products ul.products,
.upsells ul.products,
.cross-sells.products ul.products,
.cross-sells ul.products,
section.related ul.products,
section.upsells ul.products,
section.cross-sells ul.products {
	display: flex !important;
	flex-wrap: nowrap !important;
	gap: var(--scs-space-3);
	margin: 0;
	padding: 4px 4px 14px;
	list-style: none;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scroll-padding-left: 4px;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior-x: contain;
	scrollbar-width: thin;
	scrollbar-color: var(--scs-color-gold-hairline) transparent;
}

/* Webkit scrollbar — slim gold track that matches the rest of the UI. */
.related ul.products::-webkit-scrollbar,
.upsells ul.products::-webkit-scrollbar,
.cross-sells ul.products::-webkit-scrollbar {
	height: 6px;
}

.related ul.products::-webkit-scrollbar-track,
.upsells ul.products::-webkit-scrollbar-track,
.cross-sells ul.products::-webkit-scrollbar-track {
	background: transparent;
}

.related ul.products::-webkit-scrollbar-thumb,
.upsells ul.products::-webkit-scrollbar-thumb,
.cross-sells ul.products::-webkit-scrollbar-thumb {
	background: var(--scs-color-gold-hairline);
	border-radius: 999px;
}

/* Reset Woo's float-based li widths and pin each card to a fixed
   slide width that snaps as the user swipes/scrolls. */
.related ul.products > li.product,
.upsells ul.products > li.product,
.cross-sells ul.products > li.product {
	float: none !important;
	clear: none !important;
	margin: 0 !important;
	padding: 0 !important;
	max-width: none !important;
	flex: 0 0 auto !important;
	width: 70% !important;
	scroll-snap-align: start;
}

@media (min-width: 480px) {
	.related ul.products > li.product,
	.upsells ul.products > li.product,
	.cross-sells ul.products > li.product {
		width: 46% !important;
	}
}

@media (min-width: 768px) {
	.related ul.products > li.product,
	.upsells ul.products > li.product,
	.cross-sells ul.products > li.product {
		width: calc((100% - var(--scs-space-3) * 2) / 3) !important;
	}
	.related ul.products,
	.upsells ul.products,
	.cross-sells ul.products {
		gap: var(--scs-space-4);
	}
}

@media (min-width: 1024px) {
	.related ul.products > li.product,
	.upsells ul.products > li.product,
	.cross-sells ul.products > li.product {
		width: calc((100% - var(--scs-space-4) * 3) / 4) !important;
	}
}

/* Suppress Woo's legacy clearfix pseudo-elements that otherwise
   render as flex items and break the slider rhythm. */
.related ul.products::before,
.related ul.products::after,
.upsells ul.products::before,
.upsells ul.products::after,
.cross-sells ul.products::before,
.cross-sells ul.products::after {
	content: none !important;
	display: none !important;
}

/* Phone tile compaction so titles/prices/stock never clip in the
   narrow swipe-card width. */
@media (max-width: 480px) {
	.related ul.products .scs-card-tile__body,
	.upsells ul.products .scs-card-tile__body,
	.cross-sells ul.products .scs-card-tile__body {
		padding: 10px;
		gap: 4px;
	}
	.related ul.products .scs-card-tile__title,
	.upsells ul.products .scs-card-tile__title,
	.cross-sells ul.products .scs-card-tile__title {
		font-size: 0.85rem;
		min-height: 0;
		line-height: 1.3;
	}
	.related ul.products .scs-card-tile__eyebrow,
	.upsells ul.products .scs-card-tile__eyebrow,
	.cross-sells ul.products .scs-card-tile__eyebrow {
		font-size: 0.68rem;
	}
	.related ul.products .scs-card-tile__price,
	.upsells ul.products .scs-card-tile__price,
	.cross-sells ul.products .scs-card-tile__price {
		font-size: 1rem;
	}
	.related ul.products .scs-card-tile__stock,
	.upsells ul.products .scs-card-tile__stock,
	.cross-sells ul.products .scs-card-tile__stock {
		font-size: 0.72rem;
	}
	.related ul.products .scs-card-tile__actions,
	.upsells ul.products .scs-card-tile__actions,
	.cross-sells ul.products .scs-card-tile__actions {
		flex-direction: column;
		align-items: stretch;
		gap: 4px;
	}
	.related ul.products .scs-card-tile__actions .scs-button,
	.upsells ul.products .scs-card-tile__actions .scs-button,
	.cross-sells ul.products .scs-card-tile__actions .scs-button {
		width: 100%;
		text-align: center;
	}
}

