/* ═══════════════════════════════════════════════════════════════
   SEROTONIN — PRODUCT PAGE
   Učitava se samo na single product stranicama (is_product()).
   ═══════════════════════════════════════════════════════════════ */

/* ─── LAYOUT ──────────────────────────────────────────────── */
.single-product .product {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto;
	gap: var(--space-lg) var(--space-xl);
	align-items: start;
	padding-block: var(--space-lg);
}

.woocommerce-product-gallery {
	grid-column: 1;
}

.summary.entry-summary {
	grid-column: 2;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

/* Full-width rows below the 2-col zone */
.woocommerce-tabs,
.ser-upsells,
.ser-related-products {
	grid-column: 1 / -1;
}

/* ─── GALLERY ─────────────────────────────────────────────── */
.ser-gallery__main {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--ser-warm-white);
	aspect-ratio: 1;
}

.ser-gallery__main-img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: opacity var(--transition-base);
}

.ser-gallery__thumbs {
	display: flex;
	gap: var(--space-xs);
	margin-top: var(--space-xs);
	flex-wrap: wrap;
}

.ser-gallery__thumb {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border-radius: var(--radius-md);
	border: 2px solid transparent;
	cursor: pointer;
	transition: border-color var(--transition-fast), opacity var(--transition-fast);
	opacity: 0.7;
}

.ser-gallery__thumb:hover {
	opacity: 1;
}

.ser-gallery__thumb.is-active {
	border-color: var(--ser-crimson);
	opacity: 1;
}

/* ─── TITLE ───────────────────────────────────────────────── */
.ser-product__title {
	font-family: var(--font-heading);
	font-size: clamp(var(--text-xl), 3vw, var(--text-3xl));
	font-weight: var(--fw-bold);
	line-height: var(--lh-heading);
	letter-spacing: var(--ls-tight);
	color: var(--ser-obsidian);
	margin: 0;
}

/* ─── PRICE ───────────────────────────────────────────────── */
.ser-product__price-wrap {
	display: flex;
	align-items: baseline;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.ser-product__price {
	font-family: var(--font-ui);
	font-size: var(--text-2xl);
	font-weight: var(--fw-bold);
	color: var(--ser-crimson); /* spec 17: cena = #B01E28 akcent, vidljiva odmah */
	margin: 0;
}

.ser-product__price ins {
	text-decoration: none;
	color: var(--ser-crimson);
}

.ser-product__price del {
	font-size: var(--text-lg);
	font-weight: var(--fw-regular);
	color: var(--ser-stone);
	opacity: 0.8;
}

.ser-product__savings {
	display: inline-flex;
	align-items: center;
	background: var(--ser-crimson);
	color: #fff;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	padding: 0.25rem 0.625rem;
	border-radius: var(--radius-md);
	letter-spacing: var(--ls-ui);
}

/* ─── SHORT DESCRIPTION ───────────────────────────────────── */
.ser-product__description {
	font-family: var(--font-body);
	font-size: var(--text-base);
	line-height: var(--lh-body);
	color: var(--ser-slate);
}

.ser-product__description p {
	margin: 0 0 0.75rem;
}

.ser-product__description p:last-child {
	margin-bottom: 0;
}

/* ─── ADD TO CART ─────────────────────────────────────────── */
.ser-product__cart-form {
	margin-top: var(--space-xs);
}

.ser-product__quantity-row {
	display: flex;
	gap: var(--space-sm);
	align-items: center;
}

.ser-product__quantity-row .quantity {
	display: flex;
	align-items: center;
	gap: 0;
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: #fff;
}

.ser-product__quantity-row .qty {
	width: 48px;
	text-align: center;
	border: none;
	font-family: var(--font-ui);
	font-size: var(--text-base);
	font-weight: var(--fw-semibold);
	color: var(--ser-obsidian);
	background: transparent;
	-moz-appearance: textfield;
	padding: 0.75rem 0.5rem;
}

.ser-product__quantity-row .qty::-webkit-outer-spin-button,
.ser-product__quantity-row .qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

.ser-product__atc-btn {
	flex: 1;
	min-width: 0;
	padding-block: 1rem;
	font-size: var(--text-md);
	white-space: nowrap;
}

/* ─── GUARANTEE BADGE ─────────────────────────────────────── */
.ser-guarantee-badge {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-sm) var(--space-md);
	background: color-mix(in srgb, var(--ser-green) 8%, transparent);
	border: 1px solid color-mix(in srgb, var(--ser-green) 25%, transparent);
	border-radius: var(--radius-lg);
}

.ser-guarantee-badge__icon {
	flex-shrink: 0;
	color: var(--ser-green);
}

.ser-guarantee-badge__years {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-base);
	font-weight: var(--fw-semibold);
	color: var(--ser-green-dark);
}

.ser-guarantee-badge__sub {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-stone);
}

/* ─── OFFICIAL IMPORTER ───────────────────────────────────── */
.ser-official-importer {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	padding: var(--space-xs) var(--space-sm);
	border-left: 3px solid var(--ser-crimson);
	background: color-mix(in srgb, var(--ser-crimson) 4%, transparent);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.ser-official-importer__seal {
	flex-shrink: 0;
	color: var(--ser-crimson);
}

.ser-official-importer__text {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-slate);
	margin: 0;
}

/* ─── TRUST SIGNALS ───────────────────────────────────────── */
.ser-trust-signals {
	list-style: none;
	margin: 0;
	padding: var(--space-sm) 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	border-top: 1px solid var(--ser-border);
	border-bottom: 1px solid var(--ser-border);
}

.ser-trust-signals__item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm);
}

.ser-trust-signals__icon {
	flex-shrink: 0;
	color: var(--ser-crimson);
	padding-top: 2px;
}

.ser-trust-signals__content {
	display: flex;
	flex-direction: column;
	gap: 1px;
}

.ser-trust-signals__title {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	color: var(--ser-obsidian);
}

.ser-trust-signals__sub {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ser-stone);
}

/* ─── SHIPPING CALCULATOR ─────────────────────────────────── */
.ser-shipping-calc {
	padding: var(--space-sm);
	background: var(--ser-warm-white);
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-lg);
}

.ser-shipping-calc__free {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	color: var(--ser-green-dark);
	margin: 0 0 var(--space-sm);
}

.ser-shipping-calc__free svg {
	flex-shrink: 0;
	color: var(--ser-green);
}

.ser-shipping-calc__threshold {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-slate);
	margin: 0 0 var(--space-sm);
}

.ser-shipping-calc__options {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.ser-shipping-calc__option {
	display: flex;
	align-items: flex-start;
	gap: var(--space-xs);
	color: var(--ser-stone);
}

.ser-shipping-calc__option-text {
	display: flex;
	flex-direction: column;
	gap: 1px;
}

.ser-shipping-calc__option strong {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	color: var(--ser-slate);
}

.ser-shipping-calc__meta {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ser-stone);
}

/* ─── EXPERT CONSULT ──────────────────────────────────────── */
.ser-expert-consult {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-sm) var(--space-md);
	background: var(--ser-cream);
	border-radius: var(--radius-lg);
}

.ser-expert-consult__icon {
	flex-shrink: 0;
	color: var(--ser-crimson);
}

.ser-expert-consult__text {
	flex: 1;
	min-width: 0;
}

.ser-expert-consult__title {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	color: var(--ser-obsidian);
}

.ser-expert-consult__body {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ser-stone);
	margin: 0;
}

.ser-expert-consult__cta {
	flex-shrink: 0;
	font-size: var(--text-sm);
	padding: 0.5rem 1rem;
}

/* ─── STICKY ATC BAR ──────────────────────────────────────── */
.ser-sticky-atc {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: var(--z-sticky-atc);
	background: #fff;
	border-top: 1px solid var(--ser-border);
	box-shadow: 0 -4px 24px rgba(13, 13, 13, 0.1);
	transform: translateY(100%);
	transition: transform var(--transition-slow);
	padding-block: var(--space-xs);
}

.ser-sticky-atc.is-visible {
	transform: translateY(0);
}

.ser-sticky-atc__inner {
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

.ser-sticky-atc__product {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	flex: 1;
	min-width: 0;
}

.ser-sticky-atc__thumb {
	width: 44px;
	height: 44px;
	object-fit: cover;
	border-radius: var(--radius-md);
	flex-shrink: 0;
}

.ser-sticky-atc__name {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	color: var(--ser-obsidian);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.ser-sticky-atc__price {
	font-family: var(--font-ui);
	font-size: var(--text-lg);
	font-weight: var(--fw-bold);
	color: var(--ser-obsidian);
	white-space: nowrap;
	flex-shrink: 0;
}

.ser-sticky-atc__price ins {
	text-decoration: none;
	color: var(--ser-crimson);
}

.ser-sticky-atc__btn {
	flex-shrink: 0;
	padding: 0.75rem 1.5rem;
}

/* ─── PRODUCT TABS ────────────────────────────────────────── */
.ser-product__tabs {
	margin-top: var(--space-xl);
}

.ser-product__tabs-nav {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	border-bottom: 2px solid var(--ser-border);
	gap: 0;
	overflow-x: auto;
	scrollbar-width: none;
}

.ser-product__tabs-nav::-webkit-scrollbar {
	display: none;
}

.ser-product__tab-btn {
	display: block;
	padding: var(--space-sm) var(--space-md);
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	color: var(--ser-stone);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	white-space: nowrap;
	transition: color var(--transition-fast), border-color var(--transition-fast);
}

.ser-product__tab-btn:hover {
	color: var(--ser-obsidian);
}

.ser-product__tab-btn.is-active {
	color: var(--ser-crimson);
	border-bottom-color: var(--ser-crimson);
}

.ser-product__tab-panel {
	padding: var(--space-lg) 0;
	font-family: var(--font-body);
	font-size: var(--text-base);
	line-height: var(--lh-body);
	color: var(--ser-slate);
}

/* ─── RELATED & UPSELLS ───────────────────────────────────── */
.ser-related-products,
.ser-upsells {
	margin-top: var(--space-2xl);
}

.ser-related-products__heading,
.ser-upsells__heading {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: var(--fw-bold);
	color: var(--ser-obsidian);
	margin-bottom: var(--space-md);
}

.ser-related-products .products,
.ser-upsells .products {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-md);
	list-style: none;
	margin: 0;
	padding: 0;
}

/* ─── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 1024px) {
	.ser-related-products .products,
	.ser-upsells .products {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 768px) {
	.single-product .product {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}

	.woocommerce-product-gallery,
	.summary.entry-summary,
	.woocommerce-tabs,
	.ser-upsells,
	.ser-related-products {
		grid-column: 1;
	}

	.ser-product__quantity-row {
		flex-direction: column;
		align-items: stretch;
	}

	.ser-product__atc-btn {
		width: 100%;
		text-align: center;
	}

	.ser-sticky-atc__product {
		display: none;
	}

	.ser-expert-consult {
		flex-direction: column;
		align-items: flex-start;
		text-align: left;
	}

	.ser-expert-consult__cta {
		width: 100%;
		text-align: center;
	}

	.ser-related-products .products,
	.ser-upsells .products {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.ser-sticky-atc__price {
		display: none;
	}

	.ser-related-products .products,
	.ser-upsells .products {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-sm);
	}
}
