/* WooCommerce integration for Metric Store. */

/* Shared WooCommerce page shell. */
.woocommerce .site-main,
.woocommerce-page .site-main {
	width: min(calc(100% - 40px), var(--metric-store-container));
	margin-inline: auto;
	padding: 48px 0 80px;
}

.woocommerce .woocommerce-breadcrumb {
	margin: 0 0 24px;
	color: #777;
	font-size: .86rem;
}

.woocommerce .woocommerce-result-count {
	margin: 0 0 24px;
	color: var(--metric-store-muted);
}

.woocommerce .woocommerce-ordering {
	margin: 0 0 28px;
}

.woocommerce .woocommerce-ordering select,
.woocommerce select {
	min-height: 46px;
	padding: 0 42px 0 14px;
	border: 1px solid #cbc4b5;
	border-radius: 12px;
	background-color: #fff;
	color: #111;
}

/* Product loops. */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 24px;
	clear: both;
	margin: 0;
	padding: 0;
	list-style: none;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	display: none;
}

.woocommerce ul.products li.product {
	position: relative;
	display: flex;
	flex-direction: column;
	width: auto !important;
	min-width: 0;
	margin: 0 !important;
	padding: 14px 14px 18px;
	list-style: none;
	border: 1px solid var(--metric-store-border);
	border-radius: 18px;
	background: #fff;
	box-shadow: 0 10px 30px rgba(0, 0, 0, .05);
	transition: transform .25s ease, box-shadow .25s ease;
}

.woocommerce ul.products li.product::marker {
	content: "";
}

.woocommerce ul.products li.product:hover {
	transform: translateY(-5px);
	box-shadow: 0 20px 45px rgba(0, 0, 0, .10);
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: block;
	text-decoration: none;
}

.woocommerce ul.products li.product a img {
	width: 100%;
	aspect-ratio: 1 / 1;
	margin: 0 0 16px;
	object-fit: contain;
	border-radius: 14px;
	background: #f7f5ef;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	padding: .25em 0;
	color: #111;
	font-size: 1rem;
	line-height: 1.35;
}

.woocommerce ul.products li.product .price {
	margin: 4px 0 14px;
	color: #111;
	font-size: 1.02rem;
	font-weight: 900;
}

.woocommerce ul.products li.product .price del {
	color: #999;
	font-weight: 500;
}

.woocommerce ul.products li.product .price ins {
	color: #9a7612;
	text-decoration: none;
}

.woocommerce ul.products li.product .button {
	align-self: flex-start;
	margin-top: auto;
}

/* Sale badge. */
.woocommerce span.onsale {
	z-index: 4;
	min-width: 0;
	min-height: 0;
	padding: 9px 11px;
	line-height: 1;
	border-radius: 999px;
	background: var(--metric-store-gold);
	color: #111;
	font-weight: 900;
}

.woocommerce ul.products li.product span.onsale {
	top: 24px;
	left: 24px;
}

/* Buttons. */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.wc-block-components-button {
	padding: .85em 1.35em !important;
	border-radius: 999px !important;
	background: #111 !important;
	color: #fff !important;
	font-weight: 800 !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.wc-block-components-button:hover {
	background: var(--metric-store-gold) !important;
	color: #111 !important;
}

/* Single product. Keep only the gallery and summary in the first grid row. */
.single-product .site-main {
	width: min(calc(100% - 40px), var(--metric-store-container));
	margin-inline: auto;
}

.single-product .woocommerce div.product {
	position: relative;
	display: grid;
	grid-template-columns: minmax(280px, .9fr) minmax(300px, 1.1fr);
	column-gap: clamp(28px, 4vw, 56px);
	row-gap: 48px;
	align-items: start;
}

.single-product .woocommerce div.product > .onsale {
	position: absolute;
	top: 18px;
	left: 18px;
	width: auto;
	height: auto;
	margin: 0;
}

.single-product .woocommerce div.product div.images,
.single-product .woocommerce div.product div.summary {
	float: none;
	width: auto;
	min-width: 0;
	margin: 0;
}

.single-product .woocommerce div.product div.images {
	grid-column: 1;
	grid-row: 1;
}

.single-product .woocommerce div.product div.summary {
	grid-column: 2;
	grid-row: 1;
	padding-top: 10px;
}

.single-product .woocommerce div.product div.summary {
	padding: clamp(20px, 3vw, 36px);
	border: 1px solid var(--metric-store-border);
	border-radius: 20px;
	background: #fff;
	box-shadow: 0 16px 42px rgba(0, 0, 0, .06);
}

.single-product .woocommerce div.product .woocommerce-product-details__short-description {
	color: #4f4f4f;
	font-size: .98rem;
}

.single-product .woocommerce div.product form.cart .single_add_to_cart_button {
	min-height: 48px;
}

.single-product .woocommerce div.product .woocommerce-tabs,
.single-product .woocommerce div.product .related,
.single-product .woocommerce div.product .upsells {
	grid-column: 1 / -1;
	width: 100%;
}

.single-product .woocommerce div.product div.images .woocommerce-product-gallery__wrapper {
	margin: 0;
}

.single-product .woocommerce div.product div.images img {
	width: 100%;
	max-height: 520px;
	object-fit: contain;
	border-radius: 18px;
	background: #f7f5ef;
}

.single-product .woocommerce div.product .woocommerce-product-gallery__trigger {
	top: 16px;
	right: 16px;
	left: auto;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 8px 24px rgba(0, 0, 0, .12);
}

.single-product .woocommerce div.product .product_title {
	margin-top: 0;
	font-size: clamp(2rem, 4vw, 3.6rem);
	line-height: 1.08;
	letter-spacing: -.04em;
}

.single-product .woocommerce div.product p.price,
.single-product .woocommerce div.product span.price {
	color: #9a7612;
	font-size: 1.45rem;
	font-weight: 900;
}

.single-product .woocommerce div.product form.cart {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.woocommerce .quantity .qty {
	min-height: 46px;
	border: 1px solid #d8d2c4;
	border-radius: 999px;
}

/* Tabs and related products. */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding-left: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	border-radius: 12px 12px 0 0;
}

.woocommerce .related.products > h2,
.woocommerce .upsells.products > h2 {
	margin-bottom: 28px;
	font-size: clamp(1.6rem, 3vw, 2.3rem);
}

/* Tables, forms and notices. */
.woocommerce table.shop_table {
	border-collapse: separate;
	overflow: hidden;
	border: 1px solid var(--metric-store-border);
	border-radius: 16px;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
	padding: 12px;
	border: 1px solid #cbc4b5;
	border-radius: 10px;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top-color: var(--metric-store-gold);
	background: #faf8f1;
}

.woocommerce-message::before,
.woocommerce-info::before {
	color: #9a7612;
}

/* Empty cart and account layouts. */
.woocommerce-cart .wc-empty-cart-message,
.woocommerce-cart .cart-empty,
.woocommerce-cart .return-to-shop {
	text-align: center;
}

.woocommerce-cart .wc-block-grid,
.woocommerce-cart .cross-sells {
	max-width: 980px;
	margin-inline: auto;
}

@media (max-width: 1050px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 900px) {
	.woocommerce .site-main,
	.woocommerce-page .site-main,
	.single-product .site-main {
		width: min(calc(100% - 28px), var(--metric-store-container));
	}

	.woocommerce ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

}


@media (max-width: 760px) {
	.single-product .woocommerce div.product {
		grid-template-columns: minmax(220px, .9fr) minmax(260px, 1.1fr);
		column-gap: 24px;
		row-gap: 32px;
	}

	.single-product .woocommerce div.product div.images img {
		max-height: 430px;
	}

	.single-product .woocommerce div.product .product_title {
		font-size: clamp(1.55rem, 4vw, 2.25rem);
	}
}

@media (max-width: 620px) {
	.single-product .woocommerce div.product {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.single-product .woocommerce div.product div.images,
	.single-product .woocommerce div.product div.summary {
		grid-column: 1;
		grid-row: auto;
	}

	.single-product .woocommerce div.product div.images img {
		max-height: 460px;
	}
}

@media (max-width: 520px) {
	.woocommerce ul.products {
		gap: 12px;
	}

	.woocommerce ul.products li.product {
		padding: 9px 9px 14px;
	}

	.woocommerce ul.products li.product .button {
		width: 100%;
		font-size: .82rem;
		text-align: center;
	}

	.woocommerce ul.products li.product span.onsale {
		top: 16px;
		left: 16px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.woocommerce ul.products li.product {
		transition: none;
	}
}


/* 1.0.5: robust single-product layout loaded after WooCommerce core CSS. */
body.single-product main#main.site-main {
	width: min(calc(100% - 48px), 1280px) !important;
	max-width: 1280px !important;
	margin-inline: auto !important;
	padding-block: 44px 76px;
}

body.single-product main#main .woocommerce-notices-wrapper,
body.single-product main#main > .woocommerce-breadcrumb {
	width: 100%;
}

body.single-product main#main div.product.type-product {
	position: relative !important;
	display: grid !important;
	grid-template-columns: minmax(300px, 520px) minmax(340px, 1fr) !important;
	gap: clamp(32px, 5vw, 72px) !important;
	align-items: start !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
}

body.single-product main#main div.product.type-product::before,
body.single-product main#main div.product.type-product::after {
	display: none !important;
	content: none !important;
}

body.single-product main#main div.product.type-product > .onsale {
	position: absolute !important;
	top: 16px !important;
	left: 16px !important;
	z-index: 5 !important;
	width: auto !important;
	min-width: 0 !important;
	height: auto !important;
	min-height: 0 !important;
	margin: 0 !important;
	padding: 8px 12px !important;
	line-height: 1 !important;
	border-radius: 999px !important;
}

body.single-product main#main div.product.type-product > div.images,
body.single-product main#main div.product.type-product > div.summary {
	float: none !important;
	clear: none !important;
	width: 100% !important;
	max-width: none !important;
	min-width: 0 !important;
	margin: 0 !important;
}

body.single-product main#main div.product.type-product > div.images {
	grid-column: 1 !important;
	grid-row: 1 !important;
}

body.single-product main#main div.product.type-product > div.summary {
	grid-column: 2 !important;
	grid-row: 1 !important;
	padding: clamp(24px, 3vw, 40px) !important;
	border: 1px solid var(--metric-store-border) !important;
	border-radius: 22px !important;
	background: #fff !important;
	box-shadow: 0 18px 48px rgba(0, 0, 0, .07) !important;
}

body.single-product main#main .woocommerce-product-gallery,
body.single-product main#main .woocommerce-product-gallery__wrapper,
body.single-product main#main .woocommerce-product-gallery__image {
	max-width: 520px !important;
	margin-inline: auto !important;
}

body.single-product main#main .woocommerce-product-gallery img,
body.single-product main#main div.product.type-product div.images img {
	display: block !important;
	width: 100% !important;
	height: auto !important;
	max-height: 560px !important;
	object-fit: contain !important;
	object-position: center !important;
	margin-inline: auto !important;
	border-radius: 18px !important;
	background: #f7f5ef !important;
}

body.single-product main#main div.product.type-product > .woocommerce-tabs,
body.single-product main#main div.product.type-product > .related,
body.single-product main#main div.product.type-product > .upsells {
	grid-column: 1 / -1 !important;
	width: 100% !important;
	max-width: none !important;
	margin-top: 8px !important;
}

body.single-product main#main div.product.type-product .product_title {
	margin: 0 0 18px !important;
	font-size: clamp(2rem, 3.5vw, 3.25rem) !important;
	line-height: 1.08 !important;
}

body.single-product main#main div.product.type-product form.cart {
	display: flex !important;
	align-items: center !important;
	flex-wrap: wrap !important;
	gap: 12px !important;
}

@media (max-width: 900px) {
	body.single-product main#main div.product.type-product {
		grid-template-columns: minmax(250px, .9fr) minmax(300px, 1.1fr) !important;
		gap: 28px !important;
	}

	body.single-product main#main .woocommerce-product-gallery img,
	body.single-product main#main div.product.type-product div.images img {
		max-height: 460px !important;
	}
}

@media (max-width: 680px) {
	body.single-product main#main.site-main {
		width: min(calc(100% - 28px), 1280px) !important;
	}

	body.single-product main#main div.product.type-product {
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 28px !important;
	}

	body.single-product main#main div.product.type-product > div.images,
	body.single-product main#main div.product.type-product > div.summary {
		grid-column: 1 !important;
		grid-row: auto !important;
	}
}

/* Metric Store 1.0.7: restore WooCommerce base UI and refine product/cart presentation. */
body.single-product .woocommerce-product-gallery__trigger {
	position: absolute !important;
	top: 14px !important;
	right: 14px !important;
	left: auto !important;
	z-index: 12 !important;
	display: grid !important;
	place-items: center !important;
	width: 44px !important;
	height: 44px !important;
	min-width: 44px !important;
	min-height: 44px !important;
	padding: 0 !important;
	border: 1px solid rgba(0,0,0,.08) !important;
	border-radius: 50% !important;
	background: #fff !important;
	box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
	overflow: hidden !important;
	font-size: 0 !important;
}

body.single-product .woocommerce-product-gallery__trigger::before,
body.single-product .woocommerce-product-gallery__trigger::after {
	box-sizing: border-box !important;
}

body.single-product .woocommerce-product-gallery__trigger::before {
	position: static !important;
	display: block !important;
	width: 15px !important;
	height: 15px !important;
	border: 2px solid #111 !important;
	border-radius: 50% !important;
	background: transparent !important;
	content: "" !important;
}

body.single-product .woocommerce-product-gallery__trigger::after {
	position: absolute !important;
	top: 27px !important;
	left: 27px !important;
	width: 8px !important;
	height: 2px !important;
	border: 0 !important;
	border-radius: 2px !important;
	background: #111 !important;
	content: "" !important;
	transform: rotate(45deg) !important;
	transform-origin: left center !important;
}

body.single-product main#main div.product.type-product > div.images {
	position: relative !important;
	padding: 22px !important;
	border: 1px solid var(--metric-store-border) !important;
	border-radius: 22px !important;
	background: #fff !important;
	box-shadow: 0 16px 42px rgba(0,0,0,.05) !important;
}

body.single-product main#main .woocommerce-product-gallery__wrapper,
body.single-product main#main .woocommerce-product-gallery__image,
body.single-product main#main .woocommerce-product-gallery__image a {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
}

body.single-product main#main .flex-viewport {
	border-radius: 16px !important;
}

body.single-product main#main .flex-control-thumbs {
	display: grid !important;
	grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
	gap: 10px !important;
	margin: 14px 0 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

body.single-product main#main .flex-control-thumbs li {
	float: none !important;
	width: auto !important;
	margin: 0 !important;
}

body.single-product main#main .flex-control-thumbs img {
	aspect-ratio: 1 / 1 !important;
	height: auto !important;
	max-height: 90px !important;
	padding: 4px !important;
	border: 1px solid var(--metric-store-border) !important;
	border-radius: 10px !important;
	background: #fff !important;
	object-fit: contain !important;
}

/* Classic cart. */
.woocommerce-cart main#main.site-main,
.woocommerce-checkout main#main.site-main {
	width: min(calc(100% - 40px), var(--metric-store-container)) !important;
	margin-inline: auto !important;
	padding-block: 52px 84px !important;
}

.woocommerce-cart table.shop_table,
.woocommerce-checkout table.shop_table {
	width: 100% !important;
	background: #fff !important;
	box-shadow: 0 14px 42px rgba(0,0,0,.05) !important;
}

.woocommerce-cart table.shop_table th,
.woocommerce-cart table.shop_table td,
.woocommerce-checkout table.shop_table th,
.woocommerce-checkout table.shop_table td {
	padding: 16px !important;
	border-color: var(--metric-store-border) !important;
}

.woocommerce-cart table.cart img {
	width: 82px !important;
	height: 82px !important;
	border-radius: 12px !important;
	background: var(--metric-store-cream) !important;
	object-fit: contain !important;
}

.woocommerce-cart .cart-collaterals {
	margin-top: 34px !important;
}

.woocommerce-cart .cart-collaterals .cart_totals {
	float: none !important;
	width: min(100%, 520px) !important;
	margin-left: auto !important;
	padding: 26px !important;
	border: 1px solid var(--metric-store-border) !important;
	border-radius: 20px !important;
	background: #fff !important;
	box-shadow: 0 16px 44px rgba(0,0,0,.06) !important;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 52px !important;
	background: var(--metric-store-gold) !important;
	color: #111 !important;
}

.woocommerce-cart .coupon {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 10px !important;
}

.woocommerce-cart .coupon .input-text {
	min-height: 46px !important;
	padding-inline: 14px !important;
	border: 1px solid #cbc4b5 !important;
	border-radius: 999px !important;
}

/* Cart and checkout blocks. */
.wc-block-cart,
.wc-block-checkout {
	width: min(calc(100% - 40px), var(--metric-store-container)) !important;
	margin-inline: auto !important;
	padding-block: 52px 84px !important;
}

.wc-block-cart-items,
.wc-block-components-sidebar,
.wc-block-checkout__main,
.wc-block-checkout__sidebar {
	border-color: var(--metric-store-border) !important;
	border-radius: 18px !important;
	background: #fff !important;
}

.wc-block-components-sidebar,
.wc-block-checkout__sidebar {
	padding: 22px !important;
	box-shadow: 0 16px 44px rgba(0,0,0,.06) !important;
}

.wc-block-components-product-name {
	color: #111 !important;
	font-weight: 800 !important;
	text-decoration: none !important;
}

.wc-block-cart-item__image img {
	border-radius: 12px !important;
	background: var(--metric-store-cream) !important;
	object-fit: contain !important;
}

.wc-block-components-totals-wrapper {
	border-color: var(--metric-store-border) !important;
}

.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button {
	min-height: 54px !important;
	border: 0 !important;
	border-radius: 999px !important;
	background: var(--metric-store-gold) !important;
	color: #111 !important;
	font-weight: 900 !important;
}

@media (max-width: 680px) {
	body.single-product main#main div.product.type-product > div.images,
	body.single-product main#main div.product.type-product > div.summary {
		padding: 18px !important;
	}

	.woocommerce-cart main#main.site-main,
	.woocommerce-checkout main#main.site-main,
	.wc-block-cart,
	.wc-block-checkout {
		width: min(calc(100% - 24px), var(--metric-store-container)) !important;
		padding-block: 32px 58px !important;
	}

	.woocommerce-cart table.shop_table_responsive tr td {
		padding: 12px 14px !important;
	}
}

/* Mini-cart AJAX refresh state. */
.metric-store-cart-drawer.is-refreshing #metric-store-mini-cart-content {
  opacity: .55;
  pointer-events: none;
  transition: opacity .18s ease;
}
.metric-store-cart-drawer.is-refreshing::after {
  content: "";
  position: absolute;
  top: 78px;
  right: 24px;
  width: 22px;
  height: 22px;
  border: 3px solid rgba(201, 162, 39, .25);
  border-top-color: var(--metric-store-gold);
  border-radius: 50%;
  animation: metric-store-cart-spin .7s linear infinite;
}
@keyframes metric-store-cart-spin { to { transform: rotate(360deg); } }
