/**
 * MebliU — WooCommerce pages
 */

/* Shop layout */
.shop-page { padding-bottom: 80px; }
.shop-page__head { margin-bottom: 32px; }
.shop-page__title { font-size: clamp(32px, 4vw, 48px); font-weight: 500; margin-bottom: 8px; font-family: var(--font-heading); text-transform: uppercase; color: var(--c-primary); }
.shop-page__desc { color: var(--c-muted); margin: 0; }

.shop-page__layout {
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	gap: 40px;
	align-items: start;
}
.shop-page__main { min-width: 0; }

/* Filters */
.filters { min-width: 0; }
.filters__toggle {
	display: none;
	width: 100%;
	margin-bottom: 16px;
	padding: 12px;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	font-weight: 600;
	cursor: pointer;
}
.filters__panel {
	background: #fff;
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
	padding: 24px;
	position: sticky;
	top: calc(var(--header-h) + 16px);
	overflow: hidden;
}
.filters__form { display: flex; flex-direction: column; gap: 0; }
.filters__block { margin-bottom: 24px; }
.filters__block--price { margin-bottom: 20px; }
.filters__label {
	font-family: var(--font-heading);
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--c-primary);
	margin-bottom: 12px;
}
.filters__cats { display: flex; flex-direction: column; gap: 4px; }
.filters__cats a {
	display: block;
	padding: 8px 10px;
	font-size: 14px;
	color: var(--c-text);
	border-radius: var(--radius-sm);
}
.filters__cats a.is-active,
.filters__cats a:hover { background: var(--c-surface); color: var(--c-primary); opacity: 1; }
.filters__price-row {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 8px;
	align-items: center;
}
.filters__price-sep { color: var(--c-muted); font-size: 13px; text-align: center; }
.filters__price-row input {
	width: 100%;
	min-width: 0;
	padding: 10px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	font-size: 14px;
	box-sizing: border-box;
}
.filters__colors { display: flex; flex-direction: column; gap: 8px; max-height: 280px; overflow-y: auto; }
.filters__color-item {
	display: grid;
	grid-template-columns: 22px 1fr;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	font-size: 13px;
	color: var(--c-text);
}
.filters__color-item input { position: absolute; opacity: 0; pointer-events: none; }
.filters__color-box {
	width: 22px;
	height: 22px;
	border-radius: 4px;
	border: 2px solid var(--c-border);
	background: var(--swatch, var(--c-surface));
	position: relative;
	transition: border-color var(--ease);
}
.filters__color-box--all {
	background: linear-gradient(135deg, #fff 45%, var(--c-border) 45%, var(--c-border) 55%, #fff 55%);
}
.filters__color-item input:checked + .filters__color-box {
	border-color: var(--c-primary);
}
.filters__color-item input:checked + .filters__color-box::after {
	content: '';
	position: absolute;
	inset: 3px;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath fill='none' stroke='%232F457B' stroke-width='2' d='M1 5l3 3 7-7'/%3E%3C/svg%3E") center / 10px no-repeat;
}
.filters__check {
	display: grid;
	grid-template-columns: 22px 1fr;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	margin-bottom: 16px;
	cursor: pointer;
}
.filters__check input { position: absolute; opacity: 0; pointer-events: none; }
.filters__check-box {
	width: 22px;
	height: 22px;
	border: 2px solid var(--c-border);
	border-radius: 4px;
	position: relative;
	transition: border-color var(--ease), background var(--ease);
}
.filters__check input:checked + .filters__check-box {
	border-color: var(--c-primary);
	background: var(--c-primary);
}
.filters__check input:checked + .filters__check-box::after {
	content: '';
	position: absolute;
	inset: 4px;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath fill='none' stroke='%23fff' stroke-width='2' d='M1 5l3 3 7-7'/%3E%3C/svg%3E") center / 10px no-repeat;
}
.filters__reset {
	display: block;
	text-align: center;
	margin-top: 12px;
	font-size: 13px;
	color: var(--c-muted);
}

.shop-page__toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 24px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--c-border);
}
.shop-page__toolbar .woocommerce-result-count {
	margin: 0;
	font-size: 13px;
	color: var(--c-muted);
}
.shop-page__toolbar .woocommerce-ordering select {
	padding: 8px 32px 8px 12px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	font-size: 13px;
	background: #fff;
	cursor: pointer;
}

.product-grid--shop {
	grid-template-columns: repeat(3, 1fr);
}

.woocommerce-pagination {
	margin-top: 56px;
	padding-top: 32px;
	border-top: 1px solid var(--c-border);
}
.woocommerce-pagination ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.woocommerce-pagination li { margin: 0; padding: 0; list-style: none; }
.woocommerce-pagination a,
.woocommerce-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 14px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	font-size: 14px;
	font-weight: 600;
	color: var(--c-primary);
	background: #fff;
	transition: background var(--ease), color var(--ease), border-color var(--ease);
}
.woocommerce-pagination span.current {
	background: var(--c-primary);
	color: #fff;
	border-color: var(--c-primary);
}
.woocommerce-pagination a:hover {
	background: var(--c-primary);
	color: #fff;
	border-color: var(--c-primary);
	opacity: 1;
}
.woocommerce-pagination .prev,
.woocommerce-pagination .next {
	font-size: 13px;
	padding-inline: 18px;
}

/* Single product */
.product-page { padding-bottom: 80px; }
.product-layout__grid {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: 48px;
	align-items: start;
	margin-bottom: 48px;
}
.product-layout__gallery {
	width: 100%;
	min-width: 0;
}
.product-layout__buybox {
	position: sticky;
	top: calc(var(--header-h) + 24px);
	min-width: 0;
}

.woocommerce div.product .product_title {
	font-size: clamp(24px, 3vw, 36px);
	font-weight: 500;
	font-family: var(--font-heading);
	text-transform: uppercase;
	margin-bottom: 12px;
	line-height: 1.15;
	color: var(--c-primary);
}
.product-type-variable .summary > .price { display: none; }
.woocommerce div.product p.price {
	font-size: 28px;
	font-weight: 700;
	color: var(--c-primary);
	margin-bottom: 0;
}
.woocommerce div.product p.price del { font-size: 16px; color: var(--c-muted); font-weight: 400; }
.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: 15px;
	color: var(--c-muted);
	line-height: 1.6;
	margin-bottom: 24px;
}

/* Gallery — full width of column */
.woocommerce #content div.product div.images,
.woocommerce div.product div.images {
	float: none !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
}
.woocommerce div.product div.images .woocommerce-product-gallery {
	display: flex;
	flex-direction: column;
	width: 100%;
	background: var(--c-surface);
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--c-border);
}
.woocommerce div.product div.images .woocommerce-product-gallery__wrapper,
.woocommerce div.product div.images .flex-viewport {
	width: 100% !important;
	float: none !important;
}
.woocommerce div.product div.images .woocommerce-product-gallery__image {
	width: 100% !important;
	aspect-ratio: 1;
}
.woocommerce div.product div.images .woocommerce-product-gallery__image a,
.woocommerce div.product div.images .woocommerce-product-gallery__image img {
	width: 100% !important;
	height: 100%;
	object-fit: contain;
	padding: 20px;
	box-sizing: border-box;
}
.woocommerce div.product div.images .flex-control-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0;
	padding: 12px 16px 16px;
	list-style: none;
	order: 2;
}
.woocommerce div.product div.images .flex-control-thumbs li {
	width: 72px !important;
	float: none !important;
	margin: 0 !important;
}
.woocommerce div.product div.images .flex-control-thumbs img {
	width: 100%;
	height: 72px;
	object-fit: cover;
	border: 2px solid transparent;
	border-radius: var(--radius-sm);
	cursor: pointer;
	opacity: 0.75;
}
.woocommerce div.product div.images .flex-control-thumbs img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs img:hover {
	border-color: var(--c-primary);
	opacity: 1;
}
.woocommerce span.onsale {
	position: absolute;
	top: 16px;
	left: 16px;
	z-index: 2;
	background: var(--c-sale);
	color: #fff;
	padding: 6px 12px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	min-height: auto;
	line-height: 1;
}

/* Variations */
.variations { margin-bottom: 20px; }
.variation-row + .variation-row { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--c-border); }
.variation-row__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-bottom: 12px;
}
.variation-row__label {
	font-family: var(--font-heading);
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
	color: var(--c-primary);
}
.variation-row__picked {
	font-size: 14px;
	font-weight: 600;
	color: var(--c-muted);
	text-transform: none;
}
.variation-row__select { position: absolute; opacity: 0; pointer-events: none; width: 1px; height: 1px; }
.variation-row__picker { display: flex; flex-wrap: wrap; gap: 10px; }

.variation-swatch {
	width: 52px;
	height: 52px;
	padding: 0;
	border: 2px solid var(--c-border);
	border-radius: var(--radius-sm);
	background-color: var(--c-surface);
	background-size: cover;
	background-position: center;
	cursor: pointer;
	transition: border-color var(--ease), box-shadow var(--ease);
}
.variation-swatch.is-light { border-color: #ccc; }
.variation-swatch.is-active {
	border-color: var(--c-primary);
	box-shadow: 0 0 0 2px rgba(47, 69, 123, 0.25);
}
.variation-swatch:hover { border-color: var(--c-primary); }

.variation-pill {
	padding: 10px 16px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	background: #fff;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--ease);
}
.variation-pill.is-active {
	background: var(--c-primary);
	border-color: var(--c-primary);
	color: #fff;
}
.variation-pill:hover { border-color: var(--c-primary); }

.reset_variations {
	font-size: 12px;
	color: var(--c-muted);
	text-decoration: underline;
}
.single_variation_wrap { margin-top: 24px; }

/* Purchase box */
.purchase-box {
	margin-top: 8px;
	padding: 24px;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
}
.purchase-box .woocommerce-variation-price,
.purchase-box > .price {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--c-border);
}
.purchase-box .woocommerce-variation-price .price,
.purchase-box > .price {
	font-size: clamp(26px, 3vw, 32px) !important;
	font-weight: 700 !important;
	color: var(--c-primary) !important;
	margin: 0 !important;
}
.purchase-box__row {
	display: flex;
	gap: 12px;
	align-items: stretch;
}
.purchase-box__qty .quantity {
	display: flex;
	align-items: stretch;
	height: 52px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	background: #fff;
	overflow: hidden;
}
.purchase-box__qty .qty {
	width: 56px;
	height: 100%;
	border: none;
	text-align: center;
	font-size: 16px;
	font-weight: 600;
	font-family: var(--font);
	-moz-appearance: textfield;
}
.purchase-box__qty .qty::-webkit-outer-spin-button,
.purchase-box__qty .qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.purchase-box__btn,
.woocommerce div.product form.cart .single_add_to_cart_button {
	flex: 1;
	min-height: 52px;
	padding: 14px 28px !important;
	background: var(--c-primary) !important;
	color: #fff !important;
	border: none !important;
	border-radius: var(--radius-sm) !important;
	font-family: var(--font) !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	cursor: pointer;
	transition: background var(--ease);
}
.purchase-box__btn:hover,
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
	background: var(--c-primary-dark) !important;
}
.purchase-box__actions { margin: 0; }
.woocommerce div.product form.cart .button { width: auto; }

/* Tabs */
.woocommerce div.product .woocommerce-tabs { margin-top: 48px; }
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	padding: 0;
	margin: 0 0 24px;
	border-bottom: 1px solid var(--c-border);
	list-style: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: 12px 20px;
	font-size: 14px;
	font-weight: 600;
	color: var(--c-muted);
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	color: var(--c-primary);
	border-bottom-color: var(--c-primary);
}
.woocommerce div.product .woocommerce-Tabs-panel {
	font-size: 15px;
	line-height: 1.7;
}
.woocommerce div.product .woocommerce-Tabs-panel h2 { display: none; }

.woocommerce table.shop_attributes {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	overflow: hidden;
}
.woocommerce table.shop_attributes th,
.woocommerce table.shop_attributes td {
	padding: 12px 16px;
	border-bottom: 1px solid var(--c-border);
	font-size: 14px;
}
.woocommerce table.shop_attributes th {
	background: var(--c-surface);
	font-weight: 600;
	width: 40%;
	text-align: left;
}

.related.products { margin-top: 64px; }
.related.products > h2 { font-size: clamp(22px, 3vw, 32px); margin-bottom: 24px; font-family: var(--font-heading); text-transform: uppercase; font-weight: 500; color: var(--c-primary); }
.related.products ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--gap);
	margin: 0;
	padding: 0;
	list-style: none;
}
.related.products ul.products::before,
.related.products ul.products::after { display: none; }
.related.products ul.products li { width: 100% !important; margin: 0 !important; padding: 0 !important; float: none !important; }

/* Cart & Checkout pages */
.wc-page { padding: 40px 0 80px; }
.wc-flow-page .site-main { padding-bottom: 80px; }

.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-account .woocommerce {
	max-width: none;
	width: 100%;
	margin: 0;
}
.woocommerce-account .woocommerce {
	display: flex;
	flex-wrap: wrap;
	gap: 32px;
	align-items: flex-start;
}
.woocommerce-account .woocommerce::before,
.woocommerce-account .woocommerce::after { display: none; }
.woocommerce-account .woocommerce-MyAccount-navigation {
	float: none;
	width: 240px;
	margin-right: 0;
}
.woocommerce-account .woocommerce-MyAccount-content {
	float: none;
	width: auto;
	flex: 1;
	min-width: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
	overflow: hidden;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	display: block;
	padding: 12px 16px;
	font-size: 14px;
	font-weight: 500;
	color: var(--c-text);
	border-bottom: 1px solid var(--c-border);
}
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child a { border-bottom: none; }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
	background: var(--c-surface);
	color: var(--c-primary);
}
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
	color: var(--c-primary);
	font-family: var(--font-heading);
	text-transform: uppercase;
}

.wc-page .entry-title,
.wc-page h1.page-title,
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title {
	font-family: var(--font-heading);
	text-transform: uppercase;
	color: var(--c-primary);
	font-size: clamp(28px, 3vw, 40px);
	margin-bottom: 24px;
}
.woocommerce-checkout-review-order-table,
.woocommerce table.shop_table {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
	overflow: hidden;
	margin-bottom: 24px;
}
.woocommerce-cart table.shop_table th,
.woocommerce-cart table.shop_table td,
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
	padding: 16px;
	border-bottom: 1px solid var(--c-border);
	font-size: 14px;
	vertical-align: middle;
}
.woocommerce-cart table.shop_table th {
	background: var(--c-surface);
	font-weight: 600;
	text-align: left;
}
.woocommerce-cart .product-thumbnail img { width: 80px; border-radius: var(--radius-sm); }
.woocommerce-cart .product-name a { font-weight: 600; color: var(--c-text); }
.woocommerce-cart .quantity input {
	width: 64px;
	padding: 8px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	text-align: center;
}
.woocommerce-cart .coupon {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 24px;
}
.woocommerce-cart .coupon input[type="text"] {
	flex: 1;
	min-width: 180px;
	padding: 12px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
}
.woocommerce-cart .actions .button,
.woocommerce #payment #place_order,
.woocommerce .checkout-button,
.woocommerce button.button.alt {
	background: var(--c-primary) !important;
	color: #fff !important;
	border: none !important;
	padding: 14px 28px !important;
	border-radius: var(--radius-sm) !important;
	font-weight: 600 !important;
	cursor: pointer;
}
.woocommerce-cart .cart-collaterals {
	margin-top: 32px;
}
.woocommerce-cart .cart_totals {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
	padding: 24px;
}
.woocommerce-cart .cart_totals h2,
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
	font-family: var(--font-heading);
	text-transform: uppercase;
	font-weight: 500;
}
.woocommerce-cart .cart_totals h2 { font-size: clamp(18px, 2vw, 24px); margin-bottom: 16px; }

/* Checkout */
.woocommerce-checkout .col2-set {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	margin-bottom: 32px;
}
.woocommerce-checkout .form-row {
	margin-bottom: 16px;
}
.woocommerce-checkout .form-row label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 6px;
}
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	font-family: var(--font);
	font-size: 14px;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus {
	outline: none;
	border-color: var(--c-primary);
}
.woocommerce-checkout #order_review_heading { font-size: clamp(20px, 2.5vw, 28px); margin: 32px 0 16px; }
.woocommerce-checkout #payment {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
	padding: 24px;
}
.woocommerce-checkout #payment ul.payment_methods {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
}
.woocommerce-checkout #payment ul.payment_methods li {
	padding: 12px 0;
	border-bottom: 1px solid var(--c-border);
}

.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error {
	padding: 14px 18px;
	border-radius: var(--radius-sm);
	margin-bottom: 20px;
	font-size: 14px;
	list-style: none;
}
.woocommerce-message { background: #ecfdf3; border: 1px solid #bbf7d0; color: #166534; }
.woocommerce-error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }

@media (max-width: 960px) {
	.shop-page__layout { grid-template-columns: 1fr; }
	.filters__toggle { display: block; }
	.filters__panel { display: none; position: static; }
	.filters.is-open .filters__panel { display: block; }
	.product-layout__grid { grid-template-columns: 1fr; }
	.product-layout__buybox { position: static; }
	.product-grid--shop { grid-template-columns: repeat(2, 1fr); }
	.related.products ul.products { grid-template-columns: repeat(2, 1fr); }
	.woocommerce-checkout .col2-set { grid-template-columns: 1fr; }
	.woocommerce-account .woocommerce { flex-direction: column; }
	.woocommerce-account .woocommerce-MyAccount-navigation { width: 100%; margin-right: 0; }
	.purchase-box__row { flex-direction: column; }
	.purchase-box__btn { width: 100%; }
}

@media (max-width: 560px) {
	.product-grid--shop { grid-template-columns: 1fr; }
	.related.products ul.products { grid-template-columns: 1fr; }
}
