/**
 * WooCommerce overrides — loaded only on WooCommerce pages.
 * Uses the theme's CSS custom properties from variables.css.
 */

/* ── General WooCommerce layout ───────────────────────────────────────────── */
.woocommerce-page .page-title,
.woocommerce .page-title {
	display: none;
	/* shop page uses our custom breadcrumb + filters heading */
}

/* ── Notices ──────────────────────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top-color: var(--color-primary);
	font-family: 'Montserrat', sans-serif;
	font-size: var(--text-sm);
}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	font-family: 'Montserrat', sans-serif;
	font-size: var(--text-sm);
	font-weight: var(--font-medium);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	background-color: var(--color-ui);
	color: var(--color-white);
	border: 1px solid var(--color-ui);
	padding: var(--space-3) var(--space-8);
	border-radius: 0;
	transition: background-color 0.25s, color 0.25s;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce button.button.alt:hover {
	background-color: transparent;
	color: var(--color-ui);
}

.woocommerce button.button.alt {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

/* ── Cart ─────────────────────────────────────────────────────────────────── */
.woocommerce-cart table.cart {
	font-family: 'Montserrat', sans-serif;
	font-size: var(--text-sm);
}

.woocommerce-cart table.cart th {
	font-weight: var(--font-semibold);
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	font-size: var(--text-xs);
}

.woocommerce-cart .cart_totals h2 {
	font-size: var(--text-lg);
	font-weight: var(--font-semibold);
	color: var(--color-text-secondary);
}

/* ── Checkout ─────────────────────────────────────────────────────────────── */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading {
	font-size: var(--text-lg);
	font-weight: var(--font-semibold);
	color: var(--color-text-secondary);
	margin-bottom: var(--space-5);
}

.woocommerce form .form-row label {
	font-family: 'Montserrat', sans-serif;
	font-size: var(--text-sm);
	font-weight: var(--font-medium);
	color: var(--color-text-secondary);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	font-family: 'Montserrat', sans-serif;
	font-size: var(--text-sm);
	border: 1px solid #d0d0ce;
	padding: var(--space-4) var(--space-5);
	border-radius: 0;
	width: 100%;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
	border-color: var(--color-ui);
	outline: none;
	box-shadow: none;
}

/* ── My Account ───────────────────────────────────────────────────────────── */
.woocommerce-account .woocommerce-MyAccount-navigation {
	font-family: 'Montserrat', sans-serif;
	font-size: var(--text-sm);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	color: var(--color-text-primary);
	text-decoration: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
	font-weight: var(--font-semibold);
	color: var(--color-text-secondary);
}

/* ── Product images in WC ─────────────────────────────────────────────────── */
.woocommerce div.product div.images .woocommerce-product-gallery__image {
	border: none;
}

/* ── Stars / Rating ───────────────────────────────────────────────────────── */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before {
	color: var(--color-primary);
}

/* ── Pagination ───────────────────────────────────────────────────────────── */
.woocommerce-pagination {
	padding-top: 40px;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	font-family: 'Montserrat', sans-serif;
	font-size: var(--text-sm);
	padding: .8em;
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background-color: var(--color-ui);
	color: var(--color-white);
}

/* ── Page wrapper (cart / checkout / account) ─────────────────────────────── */
.wc-main {
	padding: 140px 100px 80px;
	font-family: var(--font-primary);
}

@media (max-width: 1024px) {
	.wc-main {
		padding: 100px 60px 60px;
	}
}

@media (max-width: 768px) {
	.wc-main {
		padding: 100px 30px 48px;
	}
}

/* ════════════════════════════════════════════════════════════════════════════
   CART PAGE
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Cart table ───────────────────────────────────────────────────────────── */
.woocommerce-cart table.cart {
	width: 100%;
	border-collapse: collapse;
}

.woocommerce-cart table.cart th,
.woocommerce-cart table.cart td {
	padding: var(--space-5) var(--space-4);
	border-bottom: 1px solid #e8e8e6;
	vertical-align: middle;
}

.woocommerce-cart table.cart thead th {
	font-family: var(--font-primary);
	font-size: var(--text-xs);
	font-weight: var(--font-semibold);
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	border-bottom: 2px solid #e8e8e6;
}

/* Product thumbnail */
.woocommerce-cart table.cart td.product-thumbnail img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	display: block;
}

/* Product name */
.woocommerce-cart table.cart td.product-name {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
}

.woocommerce-cart table.cart td.product-name a {
	font-weight: var(--font-medium);
	color: var(--color-text-secondary);
	text-decoration: none;
	transition: color 0.2s;
}

.woocommerce-cart table.cart td.product-name a:hover {
	color: var(--color-text-primary);
}

/* Price & subtotal */
.woocommerce-cart table.cart td.product-price,
.woocommerce-cart table.cart td.product-subtotal {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	font-weight: var(--font-regular);
	color: var(--color-text-primary);
}

/* Quantity input */
.woocommerce-cart table.cart td.product-quantity .qty {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	border: 1px solid #d0d0ce;
	padding: var(--space-2) var(--space-3);
	width: 64px;
	border-radius: 0;
	text-align: center;
	outline: none;
	transition: border-color 0.2s;
}

.woocommerce-cart table.cart td.product-quantity .qty:focus {
	border-color: var(--color-ui);
}

/* Remove × button */
.woocommerce-cart table.cart td.product-remove a {
	color: var(--color-text-muted) !important;
	font-size: 1.25rem;
	font-weight: var(--font-light);
	text-decoration: none;
	transition: color 0.2s;
}

.woocommerce-cart table.cart td.product-remove a:hover {
	color: var(--color-text-secondary) !important;
	background: none !important;
}

/* ── Cart actions row (coupon + update) ───────────────────────────────────── */
.woocommerce-cart table.cart td.actions {
	border-bottom: none;
	padding-top: var(--space-6);
}

.woocommerce-cart .coupon {
	display: flex;
	gap: var(--space-3);
	align-items: center;
}

.woocommerce-cart .coupon input#coupon_code {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	border: 1px solid #d0d0ce;
	padding: var(--space-3) var(--space-5);
	border-radius: 0;
	outline: none;
	transition: border-color 0.2s;
}

.woocommerce-cart .coupon input#coupon_code:focus {
	border-color: var(--color-ui);
}

/* Apply coupon */
.woocommerce-cart .coupon .button {
	font-family: var(--font-primary) !important;
	font-size: var(--text-xs) !important;
	font-weight: var(--font-medium) !important;
	letter-spacing: var(--tracking-wide) !important;
	text-transform: uppercase !important;
	background-color: transparent !important;
	color: var(--color-ui) !important;
	border: 1px solid var(--color-ui) !important;
	padding: var(--space-3) var(--space-5) !important;
	border-radius: 0 !important;
	transition: background-color 0.25s ease, color 0.25s ease !important;
}

.woocommerce-cart .coupon .button:hover {
	background-color: var(--color-ui) !important;
	color: var(--color-white) !important;
}

/* Update cart */
.woocommerce-cart table.cart td.actions .button[name="update_cart"] {
	float: right;
	font-family: var(--font-primary) !important;
	font-size: var(--text-xs) !important;
	font-weight: var(--font-medium) !important;
	letter-spacing: var(--tracking-wide) !important;
	text-transform: uppercase !important;
	background-color: transparent !important;
	color: var(--color-text-primary) !important;
	border: 1px solid #d0d0ce !important;
	padding: var(--space-3) var(--space-5) !important;
	border-radius: 0 !important;
	transition: border-color 0.2s, color 0.2s !important;
}

.woocommerce-cart table.cart td.actions .button[name="update_cart"]:hover {
	border-color: var(--color-text-secondary) !important;
	color: var(--color-text-secondary) !important;
	background-color: transparent !important;
}

/* ── Cart totals ──────────────────────────────────────────────────────────── */
.woocommerce-cart .cart-collaterals {
	margin-top: var(--space-10);
}

.woocommerce-cart .cart_totals {
	max-width: 420px;
	margin-left: auto;
}

.woocommerce-cart .cart_totals h2 {
	font-family: var(--font-primary);
	font-size: var(--text-xs);
	font-weight: var(--font-semibold);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--color-text-secondary);
	margin-bottom: var(--space-5);
}

.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-primary);
	font-size: var(--text-sm);
	padding: var(--space-4) 0;
	border-bottom: 1px solid #e8e8e6;
	color: var(--color-text-primary);
}

.woocommerce-cart .cart_totals table th {
	font-weight: var(--font-medium);
	color: var(--color-text-secondary);
	width: 40%;
}

.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
	font-size: var(--text-base);
	font-weight: var(--font-semibold);
	color: var(--color-text-secondary);
	border-bottom: none;
	padding-top: var(--space-5);
}

.woocommerce-cart .cart_totals .woocommerce-shipping-totals td {
	font-size: var(--text-sm);
}

/* ── "Proceed to checkout" button ─────────────────────────────────────────── */
.wc-proceed-to-checkout {
	padding: 0;
	margin-top: var(--space-5);
}

.wc-proceed-to-checkout .checkout-button.button {
	display: block;
	width: 100%;
	text-align: center;
	font-family: var(--font-primary) !important;
	font-size: var(--text-sm) !important;
	font-weight: var(--font-medium) !important;
	letter-spacing: var(--tracking-wide) !important;
	text-transform: uppercase !important;
	background-color: transparent !important;
	color: var(--color-primary) !important;
	border: 1px solid var(--color-primary) !important;
	padding: var(--space-4) var(--space-8) !important;
	border-radius: 0 !important;
	transition: background-color 0.25s ease, color 0.25s ease !important;
}

.wc-proceed-to-checkout .checkout-button.button:hover {
	background-color: var(--color-primary) !important;
	color: var(--color-white) !important;
}

/* ════════════════════════════════════════════════════════════════════════════
   CHECKOUT PAGE
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Two-column layout ────────────────────────────────────────────────────── */
.woocommerce-checkout form.checkout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 var(--space-16);
	align-items: start;
}

.woocommerce-checkout #customer_details {
	grid-column: 1;
}

.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review {
	grid-column: 2;
}

@media (max-width: 900px) {
	.woocommerce-checkout form.checkout {
		grid-template-columns: 1fr;
	}

	.woocommerce-checkout #customer_details,
	.woocommerce-checkout #order_review_heading,
	.woocommerce-checkout #order_review {
		grid-column: 1;
	}
}

/* ── Section headings ─────────────────────────────────────────────────────── */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading {
	font-family: var(--font-primary);
	font-size: var(--text-xs);
	font-weight: var(--font-semibold);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--color-text-secondary);
	margin-bottom: var(--space-6);
}

/* ── Form labels ──────────────────────────────────────────────────────────── */
.woocommerce-checkout form .form-row label,
.woocommerce-checkout form .form-row label abbr {
	font-family: var(--font-primary);
	font-size: var(--text-xs);
	font-weight: var(--font-medium);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--color-text-secondary);
}

/* ── Form inputs ──────────────────────────────────────────────────────────── */
.woocommerce-checkout form .form-row input.input-text,
.woocommerce-checkout form .form-row textarea,
.woocommerce-checkout form .form-row select {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	border: 1px solid #d0d0ce;
	padding: var(--space-3) var(--space-4);
	border-radius: 0;
	width: 100%;
	outline: none;
	transition: border-color 0.2s;
}

.woocommerce-checkout form .form-row input.input-text:focus,
.woocommerce-checkout form .form-row textarea:focus,
.woocommerce-checkout form .form-row select:focus {
	border-color: var(--color-ui);
	box-shadow: none;
}

/* Select2 — WooCommerce uses this for country/state dropdowns */
.woocommerce-checkout .select2-container .select2-selection--single {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	border: 1px solid #d0d0ce;
	border-radius: 0;
	height: auto;
	padding: var(--space-3) var(--space-4);
	outline: none;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: inherit;
	padding: 0;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
	top: 50%;
	transform: translateY(-50%);
}

.woocommerce-checkout .select2-container--default.select2-container--open .select2-selection--single {
	border-color: var(--color-ui);
}

/* ── Order review table ───────────────────────────────────────────────────── */
.woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--font-primary);
	font-size: var(--text-sm);
}

.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
	padding: var(--space-4) 0;
	border-bottom: 1px solid #e8e8e6;
	color: var(--color-text-primary);
}

.woocommerce-checkout-review-order-table thead th {
	font-size: var(--text-xs);
	font-weight: var(--font-semibold);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--color-text-secondary);
	border-bottom: 2px solid #e8e8e6;
}

.woocommerce-checkout-review-order-table .cart_item td.product-name {
	font-weight: var(--font-medium);
	color: var(--color-text-secondary);
}

.woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout-review-order-table .order-total td {
	font-size: var(--text-base);
	font-weight: var(--font-semibold);
	color: var(--color-text-secondary);
	border-bottom: none;
	padding-top: var(--space-5);
}

/* ── Payment section ──────────────────────────────────────────────────────── */
#payment {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	background: var(--color-bg-secondary);
	border-radius: 0;
	margin-top: var(--space-6);
}

#payment ul.payment_methods {
	border-bottom: 1px solid #e8e8e6;
	padding: var(--space-4) var(--space-6);
}

#payment ul.payment_methods li label {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	font-weight: var(--font-medium);
	color: var(--color-text-secondary);
}

#payment .payment_box {
	font-family: var(--font-primary);
	font-size: var(--text-sm);
	color: var(--color-text-primary);
	background: #f0f0ee;
}

#payment div.place-order {
	padding: var(--space-6);
}

/* ── "Place Order" button ─────────────────────────────────────────────────── */
#payment #place_order {
	display: block;
	width: 100%;
	text-align: center;
	font-family: var(--font-primary) !important;
	font-size: var(--text-sm) !important;
	font-weight: var(--font-medium) !important;
	letter-spacing: var(--tracking-wide) !important;
	text-transform: uppercase !important;
	background-color: transparent !important;
	color: var(--color-primary) !important;
	border: 1px solid var(--color-primary) !important;
	padding: var(--space-4) var(--space-8) !important;
	border-radius: 0 !important;
	cursor: pointer;
	transition: background-color 0.25s ease, color 0.25s ease !important;
}

#payment #place_order:hover {
	background-color: var(--color-primary) !important;
	color: var(--color-white) !important;
}

#ms-thumbs .splide__track--nav>.splide__list>.splide__slide.is-active {
	border: 2px solid var(--color-primary);
}

#ms-thumbs .splide__arrow--prev {
	left: 8px;
}

#ms-thumbs .splide__arrow--next {
	right: 8px;
}

.splide__arrow svg {
	width: 30px;
	height: 49px;
}

#ms-thumbs .splide__arrow svg {
	width: 24px;
	height: auto;
}