/* ═══════════════════════════════════════════════════════════════
   SEROTONIN — WOOCOMMERCE OVERRIDE
   Usklađuje WC default markup sa Serotonin dizajn sistemom.
   Conditional load (samo WC stranice). Zavisi od: design-system,
   components. Detaljni product/archive/cart stilovi: Koraci 6–8.
   ═══════════════════════════════════════════════════════════════ */

/* ───────────────────────────────────────────────
   WC DUGMAD → Serotonin primarni stil
   ─────────────────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-caps);
	text-transform: uppercase;
	background: var(--ser-crimson);
	color: var(--ser-ivory);
	border-radius: var(--radius-sm);
	padding: 1rem 2rem;
	transition: background-color var(--transition-base), transform var(--transition-fast);
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
	background: var(--ser-crimson-dark);
	color: var(--ser-ivory);
}
.woocommerce a.button:active,
.woocommerce button.button:active { transform: translateY(1px); }

/* ───────────────────────────────────────────────
   CENE
   ─────────────────────────────────────────────── */
.woocommerce .price,
.woocommerce ul.products li.product .price {
	font-family: var(--font-ui);
	font-weight: var(--fw-semibold);
	color: var(--ser-crimson);
	letter-spacing: var(--ls-ui);
}
.woocommerce .price del {
	color: var(--ser-stone);
	font-weight: var(--fw-regular);
	opacity: 1;
}
.woocommerce .price ins {
	text-decoration: none;
	color: var(--ser-crimson);
}

/* ───────────────────────────────────────────────
   NOTICES — usklađene sa brand bojama
   ─────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	border-top: none;
	border-radius: var(--radius-sm);
	border-left: 4px solid var(--ser-crimson);
	background: var(--ser-warm-white);
	color: var(--ser-slate);
}
.woocommerce-message { border-left-color: var(--ser-green); }
.woocommerce-message::before { color: var(--ser-green); }
.woocommerce-info::before { color: var(--ser-crimson); }
.woocommerce-error { border-left-color: var(--ser-error); }

/* ───────────────────────────────────────────────
   FORM FIELDS (checkout, account, reviews)
   ─────────────────────────────────────────────── */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce .select2-container .select2-selection {
	font-family: var(--font-ui);
	font-size: var(--text-base);
	border: 1px solid var(--ser-border-dark);
	border-radius: var(--radius-sm);
	padding: 0.85rem 1rem;
	background: var(--ser-warm-white);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	outline: none;
	border-color: var(--ser-crimson);
	box-shadow: 0 0 0 3px rgba(176, 30, 40, 0.12);
}

/* ───────────────────────────────────────────────
   SALE FLASH → Serotonin badge stil
   ─────────────────────────────────────────────── */
.woocommerce span.onsale {
	background: var(--ser-crimson);
	color: var(--ser-ivory);
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-ui);
	text-transform: uppercase;
	border-radius: var(--radius-sm);
	min-height: auto;
	min-width: auto;
	line-height: 1;
	padding: 0.4rem 0.7rem;
	top: var(--space-sm);
	left: var(--space-sm);
	right: auto;
	margin: 0;
}

/* ───────────────────────────────────────────────
   STAR RATINGS — crimson
   ─────────────────────────────────────────────── */
.woocommerce .star-rating span::before,
.woocommerce p.stars a::before {
	color: var(--ser-crimson);
}

/* ───────────────────────────────────────────────
   ARCHIVE GRID — osnovni razmaci (fino: Korak 7)
   ─────────────────────────────────────────────── */
.woocommerce ul.products {
	gap: var(--space-lg);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	margin: 0;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none; }
.woocommerce ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--font-heading);
	font-weight: var(--fw-regular);
	font-size: var(--text-md);
	color: var(--ser-obsidian);
}

@media (max-width: 1024px) {
	.woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
	.woocommerce ul.products { grid-template-columns: 1fr; }
}

/* ───────────────────────────────────────────────
   QUANTITY input usklađivanje
   ─────────────────────────────────────────────── */
.woocommerce .quantity input.qty {
	font-family: var(--font-ui);
	border: 1px solid var(--ser-border-dark);
	border-radius: var(--radius-sm);
	padding: 0.6rem;
}

/* ═══════════════════════════════════════════════
   KORAK 7 — SHOP / ARCHIVE
   ═══════════════════════════════════════════════ */

/* ─── ARCHIVE HEADER ──────────────────────────── */
.woocommerce-products-header {
	margin-bottom: var(--space-lg);
}
.woocommerce-products-header__title {
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	font-weight: var(--fw-light);
	color: var(--ser-obsidian);
	letter-spacing: var(--ls-tight);
	margin: 0 0 var(--space-xs);
}

/* ─── ARCHIVE TOOLBAR ─────────────────────────── */
.ser-archive-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: var(--space-sm) 0;
	border-bottom: 1px solid var(--ser-border);
	margin-bottom: var(--space-lg);
	flex-wrap: wrap;
}

.woocommerce-result-count {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-stone);
	margin: 0;
}

/* ─── ORDERBY ─────────────────────────────────── */
.ser-orderby {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}

.ser-orderby__label {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-stone);
}

.ser-orderby__select {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-obsidian);
	background: var(--ser-warm-white);
	border: 1px solid var(--ser-border-dark);
	border-radius: var(--radius-sm);
	padding: 0.5rem 2rem 0.5rem 0.875rem;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A7A7A' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
	cursor: pointer;
	transition: border-color var(--transition-fast);
}

.ser-orderby__select:focus {
	outline: none;
	border-color: var(--ser-crimson);
	box-shadow: 0 0 0 3px rgba(176, 30, 40, 0.12);
}

/* ─── PRODUCT GRID (archive) ──────────────────── */
.ser-product-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
	list-style: none;
	margin: 0;
	padding: 0;
}

.ser-product-grid::before,
.ser-product-grid::after { content: none; }

.ser-product-grid li.product {
	margin: 0 !important;
	float: none;
	width: auto !important;
}

/* ─── PAGINATION ──────────────────────────────── */
.woocommerce-pagination {
	margin-top: var(--space-2xl);
	text-align: center;
}
.woocommerce-pagination ul {
	display: inline-flex;
	gap: var(--space-xs);
	list-style: none;
	margin: 0;
	padding: 0;
}
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-slate);
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-sm);
	text-decoration: none;
	transition: border-color var(--transition-fast), color var(--transition-fast);
}
.woocommerce-pagination ul li a:hover {
	border-color: var(--ser-crimson);
	color: var(--ser-crimson);
}
.woocommerce-pagination ul li span.current {
	background: var(--ser-crimson);
	border-color: var(--ser-crimson);
	color: var(--ser-ivory);
}

/* ─── RESPONSIVE archive ──────────────────────── */
@media (max-width: 1024px) {
	.ser-product-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
	.ser-product-grid { grid-template-columns: 1fr; }
	.ser-archive-toolbar { flex-direction: column; align-items: flex-start; }
}

/* ═══════════════════════════════════════════════
   KORAK 8 — FREE SHIPPING BAR
   ═══════════════════════════════════════════════ */

.ser-free-shipping-bar {
	padding: var(--space-sm) var(--space-md);
	background: var(--ser-warm-white);
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-lg);
	margin-bottom: var(--space-md);
}

.ser-free-shipping-bar__track {
	height: 6px;
	background: var(--ser-border);
	border-radius: 999px;
	overflow: hidden;
	margin-bottom: var(--space-xs);
}

.ser-free-shipping-bar__fill {
	height: 100%;
	background: var(--ser-green);
	border-radius: 999px;
	width: 0;
	transition: width 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.ser-free-shipping-bar.is-achieved .ser-free-shipping-bar__fill {
	background: var(--ser-green);
}

.ser-free-shipping-bar__msg {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-slate);
}

.ser-free-shipping-bar.is-achieved .ser-free-shipping-bar__msg {
	color: var(--ser-green-dark);
	font-weight: var(--fw-semibold);
}

/* ═══════════════════════════════════════════════
   KORAK 8 — CART PAGE
   ═══════════════════════════════════════════════ */

.ser-cart-page {
	padding-block: var(--space-xl);
}

.ser-cart-page__inner {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: var(--space-xl);
	align-items: start;
}

/* ─── CART TABLE ──────────────────────────────── */
.ser-cart-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--font-ui);
}

.ser-cart-th {
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	color: var(--ser-stone);
	text-transform: uppercase;
	letter-spacing: var(--ls-caps);
	padding: var(--space-sm) var(--space-sm);
	border-bottom: 2px solid var(--ser-border);
	text-align: left;
	white-space: nowrap;
}

.ser-cart-row {
	border-bottom: 1px solid var(--ser-border);
	transition: background-color var(--transition-fast);
}

.ser-cart-row:hover {
	background: var(--ser-warm-white);
}

.ser-cart-row td {
	padding: var(--space-sm);
	vertical-align: middle;
	font-size: var(--text-sm);
	color: var(--ser-slate);
}

.ser-cart-row__thumb img {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border-radius: var(--radius-md);
	display: block;
}

.ser-cart-row__link {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	color: var(--ser-obsidian);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.ser-cart-row__link:hover {
	color: var(--ser-crimson);
}

.ser-cart-row__remove-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	color: var(--ser-stone);
	background: transparent;
	border: 1px solid transparent;
	transition: color var(--transition-fast), border-color var(--transition-fast);
}

.ser-cart-row__remove-btn:hover {
	color: var(--ser-crimson);
	border-color: var(--ser-crimson);
}

/* ─── CART ACTIONS ────────────────────────────── */
.ser-cart-actions {
	display: flex;
	align-items: flex-end;
	gap: var(--space-md);
	padding-block: var(--space-md);
	flex-wrap: wrap;
}

.ser-cart-coupon {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
}

.ser-cart-coupon__label {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	color: var(--ser-obsidian);
}

.ser-cart-coupon__row {
	display: flex;
	gap: var(--space-xs);
}

.ser-cart-coupon__input {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	border: 1px solid var(--ser-border-dark);
	border-radius: var(--radius-sm);
	padding: 0.625rem 0.875rem;
	background: var(--ser-warm-white);
	min-width: 200px;
	transition: border-color var(--transition-fast);
}

.ser-cart-coupon__input:focus {
	outline: none;
	border-color: var(--ser-crimson);
	box-shadow: 0 0 0 3px rgba(176, 30, 40, 0.12);
}

.ser-cart-update-btn {
	font-size: var(--text-sm);
	padding: 0.625rem 1.25rem;
	align-self: flex-end;
}

/* ─── CART SIDEBAR (totals) ───────────────────── */
.ser-cart-sidebar {
	position: sticky;
	top: 100px;
}

.woocommerce-cart .cart_totals,
.ser-cart-sidebar .cart_totals {
	background: var(--ser-warm-white);
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-lg);
	padding: var(--space-lg);
}

.woocommerce-cart .cart_totals h2 {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: var(--fw-bold);
	color: var(--ser-obsidian);
	margin: 0 0 var(--space-md);
}

.woocommerce-cart .cart_totals table {
	width: 100%;
	border-collapse: collapse;
}

.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-slate);
	padding: var(--space-xs) 0;
	border-bottom: 1px solid var(--ser-border);
}

.woocommerce-cart .cart_totals table th {
	font-weight: var(--fw-medium);
	width: 40%;
}

.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
	font-family: var(--font-ui);
	font-size: var(--text-base);
	font-weight: var(--fw-bold);
	color: var(--ser-obsidian);
	border-bottom: none;
	padding-top: var(--space-sm);
}

.wc-proceed-to-checkout .checkout-button {
	display: block;
	width: 100%;
	text-align: center;
	margin-top: var(--space-md);
	padding-block: 1rem;
	font-size: var(--text-md);
}

/* ─── MINI CART ───────────────────────────────── */
.ser-mini-cart__list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-height: 320px;
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: var(--ser-border) transparent;
}

.ser-mini-cart__item {
	display: grid;
	grid-template-columns: 56px 1fr auto;
	grid-template-rows: auto auto;
	gap: 0.25rem var(--space-sm);
	padding: var(--space-sm) 0;
	border-bottom: 1px solid var(--ser-border);
	position: relative;
}

.ser-mini-cart__thumb-link img {
	width: 56px;
	height: 56px;
	object-fit: cover;
	border-radius: var(--radius-sm);
	grid-row: 1 / 3;
}

.ser-mini-cart__name {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	color: var(--ser-obsidian);
	text-decoration: none;
	grid-column: 2;
	grid-row: 1;
	line-height: 1.3;
}

.ser-mini-cart__meta {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ser-stone);
	grid-column: 2;
	grid-row: 2;
}

.ser-mini-cart__remove {
	font-size: 1.125rem;
	line-height: 1;
	color: var(--ser-stone);
	text-decoration: none;
	grid-column: 3;
	grid-row: 1;
	transition: color var(--transition-fast);
}

.ser-mini-cart__remove:hover {
	color: var(--ser-crimson);
}

.ser-mini-cart__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-sm) 0;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	color: var(--ser-obsidian);
	border-top: 2px solid var(--ser-border);
	margin-top: var(--space-xs);
}

.ser-mini-cart__buttons {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	margin-top: var(--space-sm);
}

.ser-mini-cart__buttons a {
	display: block;
	width: 100%;
	text-align: center;
}

.ser-mini-cart__empty {
	text-align: center;
	padding: var(--space-lg) 0;
	color: var(--ser-stone);
}

.ser-mini-cart__empty svg {
	opacity: 0.4;
	margin-bottom: var(--space-sm);
}

.ser-mini-cart__empty p {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
}

/* ─── RESPONSIVE cart ─────────────────────────── */
@media (max-width: 960px) {
	.ser-cart-page__inner {
		grid-template-columns: 1fr;
	}
	.ser-cart-sidebar {
		position: static;
	}
}

@media (max-width: 640px) {
	.ser-cart-table thead {
		display: none;
	}
	.ser-cart-row td {
		display: block;
		text-align: right;
	}
	.ser-cart-row td::before {
		content: attr(data-title);
		float: left;
		font-weight: var(--fw-semibold);
		color: var(--ser-obsidian);
	}
	.ser-cart-coupon__input {
		min-width: 0;
		flex: 1;
	}
}

/* ═══════════════════════════════════════════════
   KORAK 8 — CHECKOUT
   ═══════════════════════════════════════════════ */

.ser-checkout-form {
	padding-block: var(--space-xl);
}

.ser-checkout-layout {
	display: grid;
	grid-template-columns: 1fr 400px;
	gap: var(--space-2xl);
	align-items: start;
}

.ser-checkout-layout__fields {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.ser-checkout-section__title {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: var(--fw-bold);
	color: var(--ser-obsidian);
	margin: 0 0 var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 2px solid var(--ser-border);
}

/* ─── CHECKOUT REVIEW / SUMMARY ───────────────── */
.ser-checkout-review {
	background: var(--ser-warm-white);
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-lg);
	padding: var(--space-lg);
	position: sticky;
	top: 100px;
}

.ser-checkout-review .ser-checkout-section__title {
	margin-bottom: var(--space-md);
}

/* Order review table */
.woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
}

.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
	padding: var(--space-xs) 0;
	border-bottom: 1px solid var(--ser-border);
	color: var(--ser-slate);
}

.woocommerce-checkout-review-order-table th {
	font-weight: var(--fw-semibold);
	color: var(--ser-obsidian);
}

.woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout-review-order-table .order-total td {
	font-size: var(--text-base);
	font-weight: var(--fw-bold);
	color: var(--ser-obsidian);
	border-bottom: none;
	padding-top: var(--space-sm);
}

/* Payment methods */
.woocommerce-checkout #payment {
	margin-top: var(--space-md);
}

.woocommerce-checkout #payment ul.payment_methods {
	list-style: none;
	margin: 0 0 var(--space-md);
	padding: 0;
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.woocommerce-checkout #payment ul.payment_methods li {
	padding: var(--space-sm) var(--space-md);
	border-bottom: 1px solid var(--ser-border);
	font-family: var(--font-ui);
	font-size: var(--text-sm);
}

.woocommerce-checkout #payment ul.payment_methods li:last-child {
	border-bottom: none;
}

.woocommerce-checkout #payment ul.payment_methods li label {
	font-weight: var(--fw-medium);
	color: var(--ser-obsidian);
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}

.woocommerce-checkout #payment .payment_box {
	background: var(--ser-cream);
	border-radius: var(--radius-sm);
	padding: var(--space-sm);
	margin-top: var(--space-xs);
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ser-stone);
}

#place_order {
	width: 100%;
	padding-block: 1.125rem;
	font-size: var(--text-md);
	margin-top: var(--space-md);
}

/* ─── RESPONSIVE checkout ─────────────────────── */
@media (max-width: 960px) {
	.ser-checkout-layout {
		grid-template-columns: 1fr;
	}
	.ser-checkout-review {
		position: static;
	}
}

/* ═══════════════════════════════════════════════
   KORAK 8 — THANK YOU PAGE
   ═══════════════════════════════════════════════ */

.ser-thankyou {
	padding-block: var(--space-2xl);
	max-width: 680px;
	margin: 0 auto;
}

.ser-thankyou__hero {
	text-align: center;
	margin-bottom: var(--space-2xl);
}

.ser-thankyou__icon {
	display: inline-block;
	color: var(--ser-green);
	margin-bottom: var(--space-md);
}

.ser-thankyou__heading {
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	font-weight: var(--fw-light);
	color: var(--ser-obsidian);
	letter-spacing: var(--ls-tight);
	margin: 0 0 var(--space-sm);
}

.ser-thankyou__sub {
	font-family: var(--font-body);
	font-size: var(--text-md);
	color: var(--ser-slate);
	margin: 0;
	line-height: var(--lh-body);
}

.ser-thankyou__details {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-sm);
	background: var(--ser-warm-white);
	border: 1px solid var(--ser-border);
	border-radius: var(--radius-lg);
	padding: var(--space-lg);
}

.ser-thankyou__meta-item {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.ser-thankyou__meta-label {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: var(--ls-caps);
	color: var(--ser-stone);
}

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

@media (max-width: 520px) {
	.ser-thankyou__details { grid-template-columns: 1fr; }
}
