/* ============================================
   SJ Single Product — Responsive system
   (related / upsell rails unchanged in single-product.css)
   ============================================ */

/* Site bottom nav hidden on PDP (see sarajwelry_mnav_enabled) — safety fallback */
.sj-single-product-page .sj-mnav {
	display: none !important;
}

.sj-single-product-page.sj-has-mnav {
	padding-bottom: 0 !important;
}

.sj-pdp-wrap {
	--sj-pdp-rwd-pad: clamp(1rem, 3.5vw, 1.5rem);
	--sj-pdp-rwd-gap: clamp(1rem, 2.8vw, 1.75rem);
	--sj-pdp-rwd-touch: 44px;
	--sj-pdp-sticky-bar-h: 0px;
}

.sj-pdp-wrap.is-sticky-bar-visible {
	--sj-pdp-sticky-bar-h: calc(4.25rem + env(safe-area-inset-bottom, 0px));
}

/* ── Page shell ── */
.sj-single-product-page .woocommerce-notices-wrapper {
	padding-inline: max(var(--sj-space-6), env(safe-area-inset-left)) max(var(--sj-space-6), env(safe-area-inset-right));
}

.sj-pdp {
	padding-inline: max(var(--sj-space-6), env(safe-area-inset-left)) max(var(--sj-space-6), env(safe-area-inset-right));
	padding-bottom: max(clamp(3.5rem, 7vw, 5rem), calc(var(--sj-pdp-sticky-bar-h) + 1.5rem));
}

.sj-pdp__container {
	width: 100%;
	max-width: min(1180px, 100%);
}

/* ── Mobile sticky buy bar ── */
.sj-pdp-sticky-bar {
	position: fixed;
	inset-inline: 0;
	bottom: 0;
	z-index: 100090;
	padding-inline: max(0.75rem, env(safe-area-inset-left)) max(0.75rem, env(safe-area-inset-right));
	padding-bottom: max(0.55rem, env(safe-area-inset-bottom));
	pointer-events: none;
	transform: translateY(110%);
	opacity: 0;
	transition:
		transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.3s ease;
}

.sj-pdp-sticky-bar:not([hidden]) {
	display: block;
}

.sj-pdp-sticky-bar.is-visible {
	pointer-events: auto;
	transform: translateY(0);
	opacity: 1;
}

.sj-pdp-sticky-bar__inner {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	max-width: 1180px;
	margin-inline: auto;
	padding: 0.55rem 0.65rem;
	border-radius: 14px;
	border: 1px solid var(--sj-pdp-line-gold);
	background: rgba(255, 255, 255, 0.94);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.9) inset,
		0 -8px 32px -8px rgba(20, 17, 13, 0.18);
}

.sj-pdp-sticky-bar__info {
	flex: 1;
	min-width: 0;
}

.sj-pdp-sticky-bar__title {
	margin: 0 0 0.15rem;
	font-size: 0.78rem;
	font-weight: 600;
	line-height: 1.35;
	color: var(--sj-pdp-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.sj-pdp-sticky-bar__price {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--sj-pdp-ink);
	line-height: 1.2;
}

.sj-pdp-sticky-bar__price del {
	font-size: 0.72rem;
	font-weight: 500;
	opacity: 0.65;
}

.sj-pdp-sticky-bar__price ins {
	text-decoration: none;
}

.sj-pdp-sticky-bar__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	flex-shrink: 0;
	min-height: var(--sj-pdp-rwd-touch);
	padding: 0.55rem 1rem;
	border: none;
	border-radius: 999px;
	font-family: inherit;
	font-size: 0.8rem;
	font-weight: 700;
	color: #fff;
	background-color: var(--sj-pdp-gold-dark, #8a6f47);
	background-image: linear-gradient(
		135deg,
		var(--sj-pdp-gold, #b79567) 0%,
		var(--sj-pdp-gold-dark, #8a6f47) 100%
	);
	box-shadow: 0 8px 20px -10px rgba(138, 111, 71, 0.55);
	cursor: pointer;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.sj-pdp-sticky-bar__cta:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.sj-pdp-sticky-bar__cta:not(:disabled):active {
	transform: scale(0.97);
}

/* ── Gallery thumb rail scroll hints ── */
.sj-pdp-gallery__thumbs {
	position: relative;
	scrollbar-width: none;
}

.sj-pdp-gallery__thumbs::-webkit-scrollbar {
	display: none;
}

.sj-pdp-gallery__thumbs.is-scrollable::before,
.sj-pdp-gallery__thumbs.is-scrollable::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0.35rem;
	width: 28px;
	z-index: 2;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

.sj-pdp-gallery__thumbs.is-scrollable::before {
	inset-inline-start: 0;
	background: linear-gradient(90deg, #fff 15%, transparent);
	opacity: 1;
}

.sj-pdp-gallery__thumbs.is-scrollable::after {
	inset-inline-end: 0;
	background: linear-gradient(270deg, #fff 15%, transparent);
	opacity: 1;
}

.sj-pdp-gallery__thumbs.is-scrollable.is-at-start::before {
	opacity: 0;
}

.sj-pdp-gallery__thumbs.is-scrollable.is-at-end::after {
	opacity: 0;
}

/* ═══════════════════════════════════════════
   Breakpoints
   ═══════════════════════════════════════════ */

/* Large tablet / small desktop */
@media (max-width: 1100px) {
	.sj-pdp__layout {
		grid-template-columns: minmax(0, 1fr) minmax(280px, 0.92fr);
		gap: var(--sj-pdp-rwd-gap);
	}

	.sj-pdp-summary__top .sj-pdp-summary__title {
		font-size: clamp(1.35rem, 3.2vw, 1.85rem);
	}
}

/* Tablet — stack layout */
@media (max-width: 960px) {
	.sj-single-product-page .woocommerce-notices-wrapper {
		padding-inline: max(var(--sj-space-4), env(safe-area-inset-left)) max(var(--sj-space-4), env(safe-area-inset-right));
	}

	.sj-pdp {
		padding-inline: max(var(--sj-space-4), env(safe-area-inset-left)) max(var(--sj-space-4), env(safe-area-inset-right));
	}

	.sj-pdp__layout {
		display: flex;
		flex-direction: column;
		gap: var(--sj-pdp-rwd-gap);
	}

	.sj-pdp__gallery-col,
	.sj-pdp__summary-col {
		position: static;
		width: 100%;
		max-width: none;
	}

	.sj-pdp-gallery__main-wrap {
		border-radius: calc(var(--sj-pdp-radius) + 4px);
	}

	.sj-pdp-gallery__main {
		aspect-ratio: 1;
		max-height: min(72vh, 520px);
	}

	.sj-pdp-gallery__zoom {
		width: var(--sj-pdp-rwd-touch);
		height: var(--sj-pdp-rwd-touch);
	}

	.sj-pdp-summary {
		border-radius: calc(var(--sj-pdp-radius) + 6px);
	}

	.sj-pdp-summary__price-box {
		padding: 0.9rem 1rem;
	}

	.sj-pdp-summary__price .amount,
	.sj-pdp-summary__price bdi {
		font-size: clamp(1.15rem, 4.5vw, 1.45rem);
	}

	.sj-pdp-reviews__head {
		flex-direction: column;
		align-items: flex-start;
	}

	.sj-pdp-sguide__body:has(.sj-pdp-sguide__figure) {
		grid-template-columns: 1fr;
	}
}

/* Tablet portrait */
@media (max-width: 768px) {
	.sj-pdp__crumb {
		padding: 0.55rem 0.75rem;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}

	.sj-pdp__crumb::-webkit-scrollbar {
		display: none;
	}

	.sj-pdp__crumb-list {
		flex-wrap: nowrap;
		white-space: nowrap;
		font-size: 0.75rem;
	}

	.sj-pdp-gallery__main {
		aspect-ratio: 4 / 5;
		max-height: min(68vh, 480px);
	}

	.sj-pdp-gallery__badge {
		font-size: 0.68rem;
		padding: 0.28rem 0.55rem;
	}

	.sj-pdp-summary__top .sj-pdp-summary__meta-row {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.5rem;
	}

	.sj-pdp-summary__top .sj-pdp-summary__sku {
		margin-inline-start: 0;
		width: auto;
	}

	.sj-pdp-summary__actions {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 0.45rem;
	}

	.sj-pdp-summary__action {
		min-height: var(--sj-pdp-rwd-touch);
		padding: 0.55rem 0.35rem;
		font-size: 0.72rem;
	}

	.sj-pdp-summary__action span {
		display: block;
		line-height: 1.25;
	}

	.sj-pdp-summary__cart-box form.cart {
		flex-direction: column;
		align-items: stretch;
	}

	.sj-pdp-summary__cart-box .quantity {
		width: 100%;
		justify-content: center;
	}

	.sj-pdp-summary__cart-box .single_add_to_cart_button,
	.sj-pdp-summary__cart-box button[type="submit"] {
		width: 100%;
		min-height: var(--sj-pdp-rwd-touch);
	}

	.sj-pdp-summary__cart-box table.variations {
		width: 100%;
	}

	.sj-pdp-summary__cart-box table.variations td,
	.sj-pdp-summary__cart-box table.variations th {
		display: block;
		width: 100%;
		padding: 0.35rem 0;
	}

	.sj-pdp-tabs {
		margin-bottom: 2rem;
	}

	.sj-pdp-tabs .woocommerce-product-attributes {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.sj-pdp-tabs .woocommerce-product-attributes table {
		min-width: 280px;
	}

	.sj-pdp-sguide {
		padding: 1rem;
	}

	.sj-pdp-sguide__head {
		flex-direction: column;
		align-items: stretch;
	}

	.sj-pdp-sguide__expand {
		width: 100%;
		justify-content: center;
	}

	.sj-pdp-sguide .sj-pdp-sg-table-wrap {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.sj-pdp-reviews__list .comment_container {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.65rem;
	}

	.sj-pdp-reviews__list .avatar {
		width: 40px;
		height: 40px;
	}

	.sj-pdp-lightbox__close {
		top: max(0.75rem, env(safe-area-inset-top));
		inset-inline-end: max(0.75rem, env(safe-area-inset-right));
		width: var(--sj-pdp-rwd-touch);
		height: var(--sj-pdp-rwd-touch);
	}
}

/* Phone */
@media (max-width: 520px) {
	.sj-pdp {
		padding-inline: max(var(--sj-space-3), env(safe-area-inset-left)) max(var(--sj-space-3), env(safe-area-inset-right));
	}

	.sj-pdp-gallery__main {
		aspect-ratio: 1;
		max-height: min(62vh, 400px);
	}

	.sj-pdp-gallery__thumb {
		flex: 0 0 56px;
		width: 56px;
		height: 56px;
	}

	.sj-pdp-summary__top {
		padding: 1rem 0.9rem 0.85rem;
	}

	.sj-pdp-summary__top-bar {
		flex-direction: column;
		align-items: stretch;
	}

	.sj-pdp-summary__top .sj-pdp-summary__cat {
		align-self: flex-start;
	}

	.sj-pdp-summary__top .sj-pdp-summary__title {
		font-size: 1.2rem;
	}

	.sj-pdp-summary__top .sj-pdp-summary__title::after {
		width: 48px;
		height: 2px;
		margin-top: 0.55rem;
	}

	.sj-pdp-summary__buy {
		padding: 0.9rem;
	}

	.sj-pdp-summary__actions {
		grid-template-columns: 1fr;
	}

	.sj-pdp-summary__action {
		flex-direction: row;
		justify-content: center;
		gap: 0.5rem;
		padding: 0.65rem 0.85rem;
	}

	.sj-pdp-trust {
		grid-template-columns: 1fr;
	}

	.sj-pdp-review-form {
		grid-template-columns: 1fr;
	}

	.sj-pdp-review-form__submit {
		width: 100%;
	}

	.sj-pdp-sguide .sj-pdp-sg-table {
		min-width: 320px;
		font-size: 0.74rem;
	}

	.sj-pdp-sguide__tips-grid {
		grid-template-columns: 1fr;
	}

	.sj-pdp-sticky-bar__inner {
		padding: 0.5rem 0.55rem;
		border-radius: 12px;
	}

	.sj-pdp-sticky-bar__cta span {
		display: none;
	}

	.sj-pdp-sticky-bar__cta {
		padding: 0.55rem 0.75rem;
	}

	.sj-pdp-sticky-bar__cta i {
		font-size: 1.15rem;
	}
}

/* Very small */
@media (max-width: 380px) {
	.sj-pdp-summary__top .sj-pdp-summary__badges {
		gap: 0.3rem;
	}

	.sj-pdp-summary__top .sj-pdp-summary__badge {
		padding: 0.28rem 0.55rem;
		font-size: 0.65rem;
	}

	.sj-pdp-tabs ul.tabs.wc-tabs li a,
	.sj-pdp-tabs .sj-pdp-wc-tabs__link {
		padding: 0.6rem 0.6rem !important;
		font-size: 0.75rem;
	}
}

/* Sticky bar only on touch / narrow viewports */
@media (min-width: 769px) {
	.sj-pdp-sticky-bar {
		display: none !important;
	}
}

/* Landscape phone — shorter gallery */
@media (max-width: 960px) and (max-height: 500px) and (orientation: landscape) {
	.sj-pdp__layout {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(260px, 0.95fr);
		align-items: start;
	}

	.sj-pdp-gallery__main {
		aspect-ratio: 4 / 3;
		max-height: 70vh;
	}

	.sj-pdp-gallery__thumbs {
		flex-wrap: wrap;
		overflow: visible;
	}
}

@media (prefers-reduced-motion: reduce) {
	.sj-pdp-sticky-bar,
	.sj-pdp-gallery__thumbs.is-scrollable::before,
	.sj-pdp-gallery__thumbs.is-scrollable::after {
		transition: none;
	}
}
