/* ==========================================================================
   GrowDeshi — WooCommerce shop chrome
   Loaded ONLY on store pages (see inc/woocommerce.php → growdeshi_woo_enqueue_assets).
   Brand tokens come from style.css :root (forest / mint). Product-card grid styling
   intentionally mirrors .blog-card so the store feels native to the blog.
   ========================================================================== */

/* --------------------------------------------------------------------------
   Store layout — keep content within the theme container
   -------------------------------------------------------------------------- */
.woocommerce,
.woocommerce-page,
.wc-block-product-collection,
.wp-block-woocommerce-cart,
.wp-block-woocommerce-checkout {
	font-family: var(--font-ui);
	color: var(--c-ink);
}

/* The growdeshi/shop-hero pattern already supplies the page title + intro, so the
   legacy loop's own products-header (duplicate "Shop" / term title) is hidden. */
.woocommerce-products-header {
	display: none;
}

/* Result-count + ordering toolbar — sit on one branded row above the grid */
.woocommerce .woocommerce-result-count {
	float: left;
	margin: 0 0 28px;
	font-family: var(--font-ui);
	font-size: 14px;
	color: var(--c-ink-muted);
	line-height: 46px;
}
.woocommerce .woocommerce-ordering {
	float: right;
	margin: 0 0 28px;
}
.woocommerce .woocommerce-ordering select,
.woocommerce select.orderby {
	font-family: var(--font-ui);
	font-size: 14px;
	font-weight: 500;
	color: var(--c-ink);
	background-color: var(--c-white);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%232D6A4F' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	border: 1px solid var(--c-line-strong);
	border-radius: 12px;
	padding: 12px 42px 12px 16px;
	line-height: 1.2;
	cursor: pointer;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.woocommerce .woocommerce-ordering select:focus,
.woocommerce select.orderby:focus {
	border-color: var(--c-forest-soft);
	outline: 2px solid var(--c-mint);
	outline-offset: 1px;
}

/* --------------------------------------------------------------------------
   Product grid (classic ul.products + Product Collection block)
   -------------------------------------------------------------------------- */
.woocommerce ul.products,
.wc-block-product-template,
ul.wc-block-product-template {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
	margin: 0;
	padding: 0;
	list-style: none;
}
@media (min-width: 600px) {
	.woocommerce ul.products,
	.wc-block-product-template {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 1024px) {
	.woocommerce ul.products,
	.wc-block-product-template {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Product card — mirrors .blog-card */
.woocommerce ul.products li.product,
.wc-block-product,
li.wc-block-product {
	display: flex;
	flex-direction: column;
	/* Override WooCommerce's float/percentage grid (woocommerce-layout.css sets
	   li.product { float:left; width:22.05% }) so CSS Grid above controls sizing. */
	float: none;
	width: auto;
	background: var(--c-white);
	border: 0.5px solid var(--c-line);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: var(--c-card-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	margin: 0;
	padding: 0;
	text-align: left;
}
.woocommerce ul.products li.product:hover,
.wc-block-product:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(45, 106, 79, 0.12);
}

/* Product image — top of card, no rounding (card clips it) */
.woocommerce ul.products li.product a img,
.wc-block-product .wc-block-components-product-image img,
.wc-block-product img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	margin: 0;
	border-radius: 0;
	background: var(--c-base-alt);
}

/* The whole image+title is one link — keep it block + remove default underline */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: flex;
	flex-direction: column;
	text-decoration: none;
}
.woocommerce ul.products li.product a:hover .woocommerce-loop-product__title {
	color: var(--c-forest);
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.wc-block-product .wc-block-components-product-title,
.wc-block-product .wp-block-post-title {
	font-family: var(--font-bengali);
	font-size: 17px;
	font-weight: 700;
	line-height: 1.35;
	color: var(--c-ink);
	padding: 16px 18px 0;
	margin: 0;
}

/* Price — Bengali numerals already injected server-side */
.woocommerce ul.products li.product .price,
.wc-block-product .wc-block-components-product-price,
.price .woocommerce-Price-amount {
	font-family: var(--font-bengali);
	color: var(--c-forest);
	font-weight: 700;
	font-size: 16px;
	padding: 8px 18px 0;
}
.woocommerce ul.products li.product .price del,
.wc-block-components-product-price del {
	color: var(--c-ink-faint);
	font-weight: 500;
	opacity: 0.8;
}
.woocommerce ul.products li.product .price ins,
.wc-block-components-product-price ins {
	text-decoration: none;
	color: var(--c-forest);
}

/* Short description / rating spacing inside card */
.wc-block-product .wc-block-components-product-rating {
	padding: 6px 18px 0;
}

/* Add-to-cart sits at the bottom with breathing room.
   margin-top:auto pins it to the card base so cards with/without a price stay aligned. */
.woocommerce ul.products li.product .button,
.wc-block-product .wp-block-button__link,
.wc-block-product .add_to_cart_button {
	align-self: start;
	margin: auto 18px 18px;
}

/* Sale badge → amber pill, top-left */
.woocommerce span.onsale,
.wc-block-components-product-sale-badge {
	background: var(--c-amber);
	color: var(--c-ink);
	font-family: var(--font-ui);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: 0.02em;
	border-radius: 999px;
	padding: 5px 12px;
	min-height: 0;
	line-height: 1.4;
}
/* WooCommerce defaults this to the top-right corner — move it to top-left.
   The badge is nested inside the product link, positioned against li.product
   (which WooCommerce sets position:relative). */
.woocommerce ul.products li.product .onsale {
	position: absolute;
	top: 12px;
	left: 12px;
	right: auto;
	margin: 0;
	z-index: 2;
}

/* --------------------------------------------------------------------------
   Buttons — forest brand, 12px radius (matches theme.json button)
   -------------------------------------------------------------------------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.wc-block-components-button:not(.is-link),
.wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--c-forest);
	color: var(--c-white);
	font-family: var(--font-ui);
	font-weight: 600;
	font-size: 14px;
	border: none;
	border-radius: 12px;
	padding: 12px 22px;
	line-height: 1.2;
	cursor: pointer;
	transition: background 0.18s ease, transform 0.18s ease;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.wc-block-components-button:not(.is-link):hover,
.wp-block-button__link:hover {
	background: var(--c-forest-dark);
	color: var(--c-white);
}
.woocommerce a.button:active,
.wc-block-components-button:not(.is-link):active {
	transform: scale(0.98);
}

/* Secondary / alt buttons (e.g. "View cart", outlined) */
.woocommerce a.button.alt,
.woocommerce button.button.alt {
	background: var(--c-forest-dark);
}

/* --------------------------------------------------------------------------
   Single product
   -------------------------------------------------------------------------- */
.single-product div.product {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(24px, 4vw, 48px);
}
@media (min-width: 900px) {
	.single-product div.product {
		grid-template-columns: 1fr 1fr;
		align-items: start;
	}
}
.single-product div.product .woocommerce-product-gallery {
	margin: 0;
}
.single-product div.product .woocommerce-product-gallery img,
.single-product .wc-block-components-product-image img {
	border-radius: 20px;
}
.single-product div.product .product_title,
.single-product .wp-block-post-title {
	font-family: var(--font-bengali);
	font-weight: 800;
	font-size: clamp(26px, 4vw, 40px);
	line-height: 1.15;
	color: var(--c-ink);
	letter-spacing: -0.02em;
}
.single-product div.product p.price,
.single-product div.product span.price,
.single-product .wc-block-components-product-price {
	font-family: var(--font-bengali);
	color: var(--c-forest);
	font-weight: 800;
	font-size: clamp(20px, 3vw, 26px);
}
.single-product div.product .woocommerce-product-details__short-description {
	color: var(--c-soil);
	line-height: 1.8;
}
.single-product .quantity .qty {
	border: 1px solid var(--c-line-strong);
	border-radius: 10px;
	padding: 10px;
	font-family: var(--font-ui);
}

/* Product data tabs */
.woocommerce-tabs ul.tabs {
	border: none;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.woocommerce-tabs ul.tabs::before {
	display: none;
}
.woocommerce-tabs ul.tabs li {
	background: var(--c-base-alt);
	border: 1px solid var(--c-line);
	border-radius: 999px;
	margin: 0;
	padding: 0;
}
.woocommerce-tabs ul.tabs li.active {
	background: var(--c-mint);
	border-color: var(--c-mint-mid);
}
.woocommerce-tabs ul.tabs li a {
	color: var(--c-ink);
	font-weight: 600;
	padding: 8px 18px;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after {
	display: none;
}

/* Related products heading */
.related.products > h2,
.up-sells > h2 {
	font-family: var(--font-bengali);
	font-weight: 700;
	color: var(--c-ink);
}

/* --------------------------------------------------------------------------
   Cart & Checkout (block)
   -------------------------------------------------------------------------- */
.wc-block-components-text-input input,
.wc-block-components-text-input input.is-active,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	border: 1px solid var(--c-line-strong);
	border-radius: 10px;
}
.wc-block-components-text-input input:focus,
.woocommerce form .form-row input.input-text:focus {
	border-color: var(--c-forest-soft);
	outline: 2px solid var(--c-mint);
	outline-offset: 1px;
}
.wc-block-cart__totals-title,
.wc-block-components-totals-item__label,
.wc-block-checkout__main h2,
.wc-block-components-checkout-step__title {
	font-family: var(--font-bengali);
	color: var(--c-ink);
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	color: var(--c-forest);
	font-weight: 800;
}

/* --------------------------------------------------------------------------
   Notices — mint (success) / amber (info) / rust (error)
   -------------------------------------------------------------------------- */
.woocommerce-message,
.wc-block-components-notice-banner.is-success {
	border-top: none;
	border-left: 4px solid var(--c-forest-soft);
	background: var(--c-mint);
	color: var(--c-dark-green);
	border-radius: 12px;
}
.woocommerce-info,
.wc-block-components-notice-banner.is-info {
	border-left: 4px solid var(--c-amber);
	background: #FFF3E6;
	color: var(--c-rust);
	border-radius: 12px;
}
.woocommerce-error,
.wc-block-components-notice-banner.is-error {
	border-left: 4px solid var(--c-rust);
	background: #FBEAE0;
	color: var(--c-rust);
	border-radius: 12px;
}
.woocommerce-message .button,
.woocommerce-info .button {
	background: var(--c-forest);
}

/* --------------------------------------------------------------------------
   Breadcrumb (if WooCommerce default is used)
   -------------------------------------------------------------------------- */
.woocommerce-breadcrumb {
	font-family: var(--font-ui);
	font-size: 13px;
	color: var(--c-ink-muted);
}
.woocommerce-breadcrumb a {
	color: var(--c-forest);
	text-decoration: none;
}
