/* =========================================================================
 * UK Shelving — Custom PDP
 * ========================================================================= */

.uks-pdp {
	--uks-navy: #122a6b;
	--uks-red: #d11f2d;
	--uks-border: #e3e6ee;
	--uks-muted: #6b7280;
	--uks-radius: 6px;
	max-width: 1280px;
	margin: 0 auto;
	padding: 16px;
	color: #1b1f2a;
}

.uks-pdp .woocommerce-breadcrumb {
	font-size: 13px;
	color: var(--uks-muted);
	margin-bottom: 18px;
}

/* ---- Top: gallery | main(config) | rail --------------------------------
 * The WooCommerce add-to-cart form is left intact (performance plugin),
 * so we use display:contents to let its two children — .variations and
 * .single_variation_wrap — flow into our grid areas.
 * ----------------------------------------------------------------------- */
.uks-pdp-top {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.35fr) minmax(280px, 0.95fr);
	grid-template-areas:
		"gallery heading rail-top"
		"gallery config  rail-bottom";
	column-gap: 30px;
	row-gap: 16px;
	align-items: start;
}
.uks-pdp-gallery               { grid-area: gallery; }
.uks-pdp-main                  { grid-area: heading; }
/* !important: the theme styles .cart.variations_form and otherwise overrides
   display:contents, which collapses the whole form into one column.
   A delivery-date plugin also wraps the table + single_variation_wrap in a
   <div data-product_id>, so we dissolve that wrapper too — otherwise it
   becomes a single grid item holding everything. */
.uks-pdp form.variations_form,
.uks-pdp form.variations_form > div[data-product_id] { display: contents !important; }
.uks-pdp .variations           { grid-area: config !important; margin: 0 !important; }
.uks-pdp .single_variation_wrap{ grid-area: rail-top !important; }
.uks-pdp-rail-extra            { grid-area: rail-bottom; display: flex; flex-direction: column; gap: 16px; }
/* Simple products: keep their form in the rail-top slot. */
.uks-pdp form.cart:not(.variations_form) { grid-area: rail-top; }

/* ---- Gallery ----------------------------------------------------------- */
.uks-gallery { display: flex; gap: 12px; }
.uks-gallery-thumbs {
	display: flex;
	flex-direction: column;
	gap: 10px;
	max-height: 460px;
	overflow-y: auto;
	flex: 0 0 70px;
}
.uks-gallery-thumb {
	border: 1px solid var(--uks-border);
	border-radius: var(--uks-radius);
	background: #fff;
	padding: 4px;
	cursor: pointer;
}
.uks-gallery-thumb.is-active { border-color: var(--uks-navy); }
.uks-gallery-thumb img { display: block; width: 100%; height: auto; }
.uks-gallery-main {
	flex: 1 1 auto;
	border: 1px solid var(--uks-border);
	border-radius: var(--uks-radius);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}
.uks-gallery-main img { max-width: 100%; height: auto; }

/* ---- Main column ------------------------------------------------------- */
.uks-pdp-title { font-size: 26px; line-height: 1.2; margin: 0 0 12px; color: #1b1f2a; }
.uks-pdp-short-desc { color: #444; font-size: 14px; margin-bottom: 18px; }

.uks-config-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 14px;
}
.uks-config-title { font-size: 16px; margin: 0; color: var(--uks-navy); }
.uks-options-guide-trigger {
	background: none;
	border: none;
	color: var(--uks-navy);
	cursor: pointer;
	font-size: 13px;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.uks-info-icon { font-size: 14px; }

/* Variation attributes — WooCommerce .variations table, restyled to pills */
.uks-pdp .variations select { display: none !important; }
.uks-pdp .variations,
.uks-pdp .variations tbody { display: block; width: 100%; }
.uks-pdp .variations tr { display: block; margin-bottom: 16px; }
.uks-pdp .variations th.label,
.uks-pdp .variations td.value { display: block; width: auto; padding: 0; text-align: left; }
.uks-pdp .variations th.label label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 6px;
}
.uks-pdp .variations .reset_variations {
	display: inline-block;
	margin-top: 4px;
	font-size: 13px;
	color: var(--uks-muted);
}

/* Variation Swatches plugin buttons (ul.button-variable-items-wrapper),
 * restyled to match the design's pills. */
.uks-pdp .woo-variation-items-wrapper .variable-items-wrapper {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.uks-pdp .variable-item.button-variable-item {
	border: 1px solid var(--uks-border) !important;
	background: #fff !important;
	border-radius: var(--uks-radius) !important;
	padding: 8px 14px !important;
	margin: 0 !important;
	min-width: 0 !important;
	width: auto !important;
	height: auto !important;
	box-shadow: none !important;
	cursor: pointer;
	transition: border-color .15s, background .15s;
}
.uks-pdp .variable-item.button-variable-item:hover { border-color: var(--uks-navy) !important; }
.uks-pdp .variable-item.button-variable-item.selected,
.uks-pdp .variable-item.button-variable-item[aria-checked="true"] {
	background: var(--uks-navy) !important;
	border-color: var(--uks-navy) !important;
}
.uks-pdp .variable-item.button-variable-item.selected .variable-item-span,
.uks-pdp .variable-item.button-variable-item[aria-checked="true"] .variable-item-span {
	color: #fff !important;
}
.uks-pdp .variable-item .variable-item-span-button { font-size: 13px; padding: 0; line-height: 1.2; }
.uks-pdp .variable-item.disabled,
.uks-pdp .variable-item.wvs-disabled-archive-term { opacity: .4 !important; }

/* ---- Price box — WooCommerce .single_variation_wrap -------------------- */
.uks-pdp .single_variation_wrap {
	border: 1px solid var(--uks-border);
	border-radius: var(--uks-radius);
	padding: 18px;
}
.uks-price-default { font-size: 26px; font-weight: 700; line-height: 1.1; }
.uks-price-default .uks-price-from { font-size: 13px; font-weight: 500; color: var(--uks-muted); display: block; }
.uks-pdp .single_variation { margin-bottom: 8px; }
.uks-pdp .single_variation .price { font-size: 26px; font-weight: 700; }

.uks-pdp .woocommerce-variation-add-to-cart {
	display: flex; gap: 10px; align-items: stretch; margin-top: 14px; flex-wrap: wrap;
}
.uks-pdp .woocommerce-variation-add-to-cart .quantity { flex: 0 0 auto; }
.uks-pdp .single_add_to_cart_button {
	flex: 1 1 auto;
	background: var(--uks-red);
	color: #fff;
	border: none;
	border-radius: var(--uks-radius);
	padding: 12px 18px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
}
.uks-pdp .single_add_to_cart_button:hover { filter: brightness(.94); }
.uks-pdp .single_add_to_cart_button.is-loading { opacity: .8; cursor: progress; }
.uks-pdp .woocommerce-variation-add-to-cart-disabled .single_add_to_cart_button { opacity: .45; pointer-events: none; }

/* We render our own stock message, so hide Woo's variation availability text. */
.uks-pdp .woocommerce-variation-availability { display: none; }

.uks-stock { margin-top: 12px; font-size: 14px; font-weight: 600; }
.uks-stock-in { color: #137333; }
.uks-stock-low { color: #b25e00; }
.uks-stock-out { color: var(--uks-red); }
.uks-delivery { margin-top: 10px; font-size: 13px; }
.uks-delivery-label { color: var(--uks-muted); display: block; }
.uks-delivery-date { font-weight: 600; }

/* ---- Generic rail blocks ----------------------------------------------- */
.uks-block {
	border: 1px solid var(--uks-border);
	border-radius: var(--uks-radius);
	padding: 16px;
}
.uks-block-title { font-size: 15px; color: var(--uks-navy); margin: 0 0 12px; }
.uks-git-desc { font-size: 13px; color: #444; }
.uks-git-phone a, .uks-git-email a { color: #444; text-decoration: none; }

/* ---- Carousel ---------------------------------------------------------- */
.uks-carousel { overflow: hidden; position: relative; }
.uks-carousel-track { display: flex; transition: transform .3s ease; }
.uks-carousel-slide { flex: 0 0 100%; }
.uks-carousel-slide img { display: block; width: 100%; height: auto; border-radius: var(--uks-radius); }
.uks-carousel-dots { display: flex; gap: 8px; justify-content: center; margin-top: 10px; }
.uks-carousel-dot { width: 10px; height: 10px; border-radius: 50%; border: none; background: #cbd0dc; cursor: pointer; padding: 0; }
.uks-carousel-dot.is-active { background: var(--uks-navy); }

/* ---- Bottom: tabs | recs ----------------------------------------------- */
.uks-pdp-bottom {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
	gap: 30px;
	margin-top: 40px;
}

/* Tabs */
.uks-tabs-nav { display: flex; gap: 24px; border-bottom: 1px solid var(--uks-border); margin-bottom: 18px; }
.uks-tab-btn {
	background: none; border: none; padding: 10px 0; cursor: pointer;
	font-size: 15px; color: var(--uks-navy); border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.uks-tab-btn.is-active { border-bottom-color: var(--uks-navy); font-weight: 600; }
.uks-tab-panel { font-size: 14px; line-height: 1.6; }

.uks-readmore { position: relative; }
.uks-readmore.is-collapsed .uks-readmore-content {
	max-height: var(--uks-readmore-max, 700px);
	overflow: hidden;
	-webkit-mask-image: linear-gradient(180deg, #000 70%, transparent);
	mask-image: linear-gradient(180deg, #000 70%, transparent);
}
.uks-readmore.is-expanded .uks-readmore-content { max-height: none; }
.uks-readmore-toggle {
	display: inline-flex; margin-top: 12px; background: none; border: none;
	color: var(--uks-navy); cursor: pointer; font-size: 14px; font-weight: 600;
}

/* Recommendations */
.uks-recs { margin-bottom: 28px; }
.uks-recs-title { font-size: 16px; color: #1b1f2a; margin: 0 0 14px; }
.uks-recs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.uks-rec-card {
	border: 1px solid var(--uks-border); border-radius: var(--uks-radius);
	padding: 12px; text-decoration: none; color: inherit; display: block;
}
.uks-rec-card:hover { border-color: var(--uks-navy); }
.uks-rec-img img { width: 100%; height: auto; }
.uks-rec-name { font-size: 13px; margin: 8px 0 4px; }
.uks-rec-price { font-size: 14px; font-weight: 700; }

/* Bespoke */
.uks-bespoke { margin-top: 30px; max-width: 520px; }
.uks-bespoke-video video { width: 100%; border-radius: var(--uks-radius); }
.uks-bespoke-link { display: inline-block; margin-top: 12px; }

/* ---- Modal ------------------------------------------------------------- */
.uks-modal { position: fixed; inset: 0; z-index: 99999; display: none; }
.uks-modal.is-open { display: block; }
.uks-modal-overlay { position: absolute; inset: 0; background: rgba(20, 24, 40, .5); }
.uks-modal-panel {
	position: absolute; top: 0; right: 0; height: 100%; width: 460px; max-width: 92vw;
	background: #fff; display: flex; flex-direction: column; box-shadow: -4px 0 24px rgba(0,0,0,.15);
}
.uks-modal-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--uks-border); }
.uks-modal-head h3 { margin: 0; color: var(--uks-navy); }
.uks-modal-close { background: none; border: none; font-size: 26px; line-height: 1; cursor: pointer; color: #1b1f2a; }
.uks-modal-body { padding: 8px 20px 24px; overflow-y: auto; }
body.uks-modal-open { overflow: hidden; }

.uks-og-accordion { border-bottom: 1px solid var(--uks-border); padding: 12px 0; }
.uks-og-acc-head { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 6px 0; }
.uks-og-acc-title { display: block; color: var(--uks-navy); font-size: 16px; font-weight: 600; }
.uks-og-acc-sub { display: block; color: var(--uks-muted); font-size: 13px; }
.uks-og-acc-body { display: flex; gap: 14px; padding-top: 10px; }
.uks-og-acc-img { flex: 0 0 120px; width: 120px; height: auto; border: 1px solid var(--uks-border); border-radius: var(--uks-radius); }
.uks-og-acc-text { font-size: 14px; line-height: 1.5; }

/* ---- Device visibility toggles ----------------------------------------- */
@media (min-width: 768px) { .uks-hide-desktop { display: none !important; } }
@media (max-width: 767px) { .uks-hide-mobile { display: none !important; } }

/* ---- Responsive -------------------------------------------------------- */
@media (max-width: 1024px) {
	.uks-pdp-top {
		grid-template-columns: 1fr;
		grid-template-areas:
			"gallery"
			"heading"
			"config"
			"rail-top"
			"rail-bottom";
	}
	.uks-pdp-bottom { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
	.uks-gallery { flex-direction: column-reverse; }
	.uks-gallery-thumbs { flex-direction: row; max-height: none; flex: 0 0 auto; }
	.uks-recs-grid { grid-template-columns: repeat(2, 1fr); }
}
