/* =============================================================================
   grnstore — "Earthy Modern" · WooCommerce layer  (Fase 1)
   Loaded AFTER redesign.css. Tokens come from redesign.css :root.
   Targets Astra's real markup (.astra-shop-thumbnail-wrap / -summary-wrap,
   li.product, .summary.entry-summary, .woocommerce-tabs, .related.products …).
   ============================================================================= */

/* -----------------------------------------------------------------------------
   1. Shop archive — container, header toolbar, category chip bar
   --------------------------------------------------------------------------- */
.woocommerce-products-header { margin-bottom: 8px; }
.woocommerce-products-header__title.page-title {
	font-size: clamp(1.9rem, 1.3rem + 2vw, 2.7rem);
	font-weight: 800;
	color: var(--ink);
	margin-bottom: 6px;
}

/* Toolbar: result count + ordering on one tidy row */
.woocommerce .ast-woocommerce-container > .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count { color: var(--muted); font-size: .95rem; margin: 0; }
.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
	border: 1px solid var(--line); border-radius: var(--r-pill);
	padding: 9px 38px 9px 16px; background-color: var(--surface-2);
	color: var(--ink); font-weight: 600; font-size: .92rem; cursor: pointer;
}

/* Category chip bar (injected via functions.php) */
.gs-cat-bar {
	display: flex; flex-wrap: wrap; gap: 10px;
	margin: 4px 0 30px; padding: 0; list-style: none;
}
.gs-cat-bar a {
	display: inline-flex; align-items: center;
	padding: 8px 18px; border-radius: var(--r-pill);
	border: 1px solid var(--line); background: var(--surface);
	color: var(--text); font-weight: 600; font-size: .9rem;
	transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
.gs-cat-bar a:hover { border-color: var(--forest); color: var(--forest); }
.gs-cat-bar a.is-active { background: var(--forest); border-color: var(--forest); color: #fff; }

/* -----------------------------------------------------------------------------
   2. Product grid — true CSS grid, even gaps, kill Astra float widths
   --------------------------------------------------------------------------- */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(18px, 2.2vw, 32px);
	margin: 0 !important; padding: 0 !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none !important; content: none !important; }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	width: auto !important; float: none !important; margin: 0 !important;
	padding: 0 !important; clear: none !important;
	display: flex; flex-direction: column;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--r);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow);
	border-color: #d6e3cc;
}

/* Thumbnail — fixed square ratio, zoom on hover */
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap {
	margin: 0; position: relative; overflow: hidden;
	background: var(--surface-2);
}
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap img {
	display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover;
	margin: 0; border-radius: 0;
	transition: transform .4s ease;
}
.woocommerce ul.products li.product:hover .astra-shop-thumbnail-wrap img { transform: scale(1.05); }

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
	position: absolute; top: 12px; left: 12px; margin: 0;
	min-height: 0; min-width: 0; line-height: 1;
	background: var(--lime); color: var(--ink);
	font-weight: 800; font-size: .72rem; letter-spacing: .03em;
	padding: 7px 12px; border-radius: var(--r-pill);
	box-shadow: var(--shadow-sm);
}

/* Summary block */
.woocommerce ul.products li.product .astra-shop-summary-wrap {
	display: flex; flex-direction: column; flex: 1 1 auto;
	padding: 18px 18px 20px; text-align: left !important;
	gap: 0;
}
.woocommerce ul.products li.product .ast-woo-product-category {
	order: 1; font-size: .72rem; font-weight: 700; letter-spacing: .1em;
	text-transform: uppercase; color: var(--forest); margin: 0 0 7px;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	order: 2; font-size: 1.06rem; font-weight: 700; line-height: 1.35;
	color: var(--ink); padding: 0; margin: 0 0 10px;
}
.woocommerce ul.products li.product a.ast-loop-product__link { display: block; }
.woocommerce ul.products li.product .price {
	order: 3; margin: 0 0 16px; color: var(--ink); font-weight: 800; font-size: 1.18rem;
}
.woocommerce ul.products li.product .price del {
	opacity: .55; font-weight: 600; font-size: .86rem; margin-right: 7px;
}
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.woocommerce ul.products li.product .price .woocommerce-Price-currencySymbol { font-weight: 600; }

/* Star rating (if shown) */
.woocommerce ul.products li.product .star-rating { order: 2; margin: 0 0 10px; font-size: .9em; color: var(--lime); }

/* Add-to-cart on card → full-width pill, pinned to bottom */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.added_to_cart {
	order: 4; margin-top: auto; width: 100%;
	padding: 11px 18px; font-size: .92rem; font-weight: 700;
}
.woocommerce ul.products li.product a.added_to_cart {
	margin-top: 8px; background: transparent; color: var(--forest);
}

/* -----------------------------------------------------------------------------
   3. Single product
   --------------------------------------------------------------------------- */
.single-product div.product { margin-top: 8px; }
.single-product .woocommerce-product-gallery { border-radius: var(--r-lg); overflow: hidden; }
.single-product .woocommerce-product-gallery__image img { border-radius: var(--r-lg); }
.single-product .flex-control-thumbs { margin-top: 12px; gap: 10px; display: flex; }
.single-product .flex-control-thumbs li { margin: 0; }
.single-product .flex-control-thumbs img { border-radius: var(--r-sm); border: 1px solid var(--line); }

.single-product .summary.entry-summary { padding-left: clamp(0px, 2vw, 28px); }
.single-product .product_title.entry-title {
	font-size: clamp(1.7rem, 1.2rem + 1.6vw, 2.4rem); margin-bottom: 12px;
}
.single-product .summary .price,
.single-product .summary .price ins {
	color: var(--forest); font-weight: 800; font-size: 1.6rem; text-decoration: none;
}
.single-product .summary .price del { color: var(--muted); font-weight: 600; font-size: 1.05rem; margin-right: 10px; }
.single-product .woocommerce-product-details__short-description {
	color: var(--text); margin: 18px 0; line-height: 1.7;
	padding-bottom: 20px; border-bottom: 1px solid var(--line);
}

/* Qty + add-to-cart row */
.single-product form.cart { display: flex; flex-wrap: wrap; align-items: stretch; gap: 12px; margin: 22px 0; }
.single-product form.cart .quantity { margin: 0; }
.single-product form.cart .quantity .qty {
	height: 100%; min-height: 52px; width: 84px; text-align: center;
	border-radius: var(--r-pill); border: 1px solid var(--line); background: var(--surface-2);
	font-weight: 700; font-size: 1.05rem;
}
.single-product form.cart .single_add_to_cart_button {
	flex: 1 1 240px; min-height: 52px; font-size: 1.02rem; padding: 14px 30px;
}

/* Meta + payment trust row */
.single-product .product_meta {
	margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--line);
	font-size: .9rem; color: var(--muted);
}
.single-product .product_meta a { color: var(--forest); }
.single-product .ast-single-product-payments { margin-top: 18px; color: var(--muted); }

/* Tabs — flat, underline-active */
.single-product .woocommerce-tabs { margin-top: clamp(40px, 6vw, 72px); }
.single-product .woocommerce-tabs ul.tabs {
	display: flex; flex-wrap: wrap; gap: 6px; padding: 0 0 0 0 !important; margin: 0 0 0 0;
	border-bottom: 1px solid var(--line); list-style: none;
}
.single-product .woocommerce-tabs ul.tabs::before { display: none; }
.single-product .woocommerce-tabs ul.tabs li {
	background: transparent !important; border: 0 !important; border-radius: 0 !important;
	margin: 0 !important; padding: 0 !important; top: 1px;
}
.single-product .woocommerce-tabs ul.tabs li::before,
.single-product .woocommerce-tabs ul.tabs li::after { display: none !important; border: 0 !important; }
.single-product .woocommerce-tabs ul.tabs li a {
	display: block; padding: 14px 20px !important; font-weight: 700; color: var(--muted);
	border-bottom: 2px solid transparent; transition: color .15s ease, border-color .15s ease;
}
.single-product .woocommerce-tabs ul.tabs li.active a,
.single-product .woocommerce-tabs ul.tabs li a:hover { color: var(--ink); border-bottom-color: var(--forest); }
.single-product .woocommerce-tabs .woocommerce-Tabs-panel { padding-top: 26px; }
.single-product .woocommerce-tabs .woocommerce-Tabs-panel h2 { font-size: 1.4rem; }

/* Related / up-sells */
.single-product .related.products,
.single-product .up-sells.products { margin-top: clamp(48px, 7vw, 84px); }
.single-product .related.products > h2,
.single-product .up-sells.products > h2 { font-size: clamp(1.4rem, 1.1rem + 1vw, 1.9rem); margin-bottom: 26px; }

/* -----------------------------------------------------------------------------
   4. Cart page
   --------------------------------------------------------------------------- */
.woocommerce-cart table.cart,
.woocommerce-cart .cart-collaterals { font-size: .98rem; }
.woocommerce-cart table.shop_table {
	border: 1px solid var(--line); border-radius: var(--r); border-collapse: separate;
	overflow: hidden; background: var(--surface);
}
.woocommerce-cart table.shop_table thead th {
	background: var(--tint); color: var(--ink); font-weight: 700; border: 0;
	padding: 16px 14px; font-size: .8rem; letter-spacing: .06em; text-transform: uppercase;
}
.woocommerce-cart table.shop_table td { border-top: 1px solid var(--line); padding: 18px 14px; vertical-align: middle; }
.woocommerce-cart table.shop_table .product-thumbnail img { width: 72px; height: 72px; object-fit: cover; border-radius: var(--r-sm); }
.woocommerce-cart .product-name a { color: var(--ink); font-weight: 700; }
.woocommerce-cart .cart_totals h2 { font-size: 1.4rem; margin-bottom: 16px; }
.woocommerce-cart .cart_totals table { border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; background: var(--surface); }
.woocommerce-cart .cart_totals .order-total .amount { color: var(--forest); font-size: 1.25rem; }
.woocommerce-cart .wc-proceed-to-checkout .checkout-button { width: 100%; padding: 15px; font-size: 1.05rem; }
.woocommerce .quantity .qty {
	border: 1px solid var(--line); border-radius: var(--r-pill); background: var(--surface-2);
	padding: 9px 8px; width: 72px; text-align: center; font-weight: 700;
}
.woocommerce a.remove { color: var(--forest) !important; font-weight: 700; }
.woocommerce a.remove:hover { background: var(--forest) !important; color: #fff !important; }
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-cart .cart-collaterals .cart_totals { width: 100%; }

/* Coupon row */
.woocommerce-cart .coupon .input-text { max-width: 220px; }

/* -----------------------------------------------------------------------------
   5. Checkout
   --------------------------------------------------------------------------- */
.woocommerce-checkout h3, .woocommerce-checkout #order_review_heading { font-size: 1.3rem; color: var(--ink); margin-bottom: 16px; }
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 { float: none; width: 100%; }
.woocommerce-checkout #customer_details { margin-bottom: 8px; }
.woocommerce-checkout #order_review {
	background: var(--surface); border: 1px solid var(--line);
	border-radius: var(--r); padding: clamp(20px, 3vw, 30px); box-shadow: var(--shadow-sm);
}
.woocommerce-checkout #order_review table.shop_table { border: 0; }
.woocommerce-checkout #order_review .order-total .amount { color: var(--forest); font-size: 1.2rem; }
.woocommerce-checkout #payment { background: transparent; border-radius: var(--r-sm); }
.woocommerce-checkout #payment ul.payment_methods { border: 0; padding: 0; }
.woocommerce-checkout #payment ul.payment_methods li {
	background: var(--surface-2); border: 1px solid var(--line);
	border-radius: var(--r-sm); padding: 14px 16px; margin-bottom: 10px;
}
.woocommerce-checkout #payment div.payment_box { background: var(--tint); border-radius: var(--r-sm); }
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: var(--tint); }
.woocommerce-checkout #place_order { width: 100%; padding: 16px; font-size: 1.08rem; margin-top: 8px; }
.woocommerce form .form-row label { font-weight: 600; color: var(--ink); margin-bottom: 6px; }
.woocommerce form .form-row { padding: 3px 0; }

/* -----------------------------------------------------------------------------
   6. My Account dashboard (login/register cards already in style.css §11)
   --------------------------------------------------------------------------- */
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; background: var(--surface); }
.woocommerce-account .woocommerce-MyAccount-navigation li { border-bottom: 1px solid var(--line); }
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child { border-bottom: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 13px 18px; color: var(--text); font-weight: 600; }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover { background: var(--tint); color: var(--forest); }
.woocommerce-account .woocommerce-MyAccount-content { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); padding: clamp(20px, 3vw, 32px); }

/* -----------------------------------------------------------------------------
   7. Notices
   --------------------------------------------------------------------------- */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	border-radius: var(--r-sm); border: 1px solid var(--line);
	border-top: 3px solid var(--forest); background: var(--surface); padding: 16px 18px 16px 44px;
}
.woocommerce-message { border-top-color: var(--lime); }
.woocommerce-error { border-top-color: #c0392b; }
.woocommerce-message::before, .woocommerce-info::before { color: var(--forest); }

/* -----------------------------------------------------------------------------
   8. Responsive
   --------------------------------------------------------------------------- */
@media (max-width: 921px) {
	.woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 769px) {
	.woocommerce-checkout .col2-set { display: flex; gap: 28px; }
	.woocommerce-checkout .col2-set .col-1,
	.woocommerce-checkout .col2-set .col-2 { flex: 1; }
}
@media (max-width: 544px) {
	.woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: 1fr; }
	.single-product form.cart .single_add_to_cart_button { flex: 1 1 100%; }
}

/* =============================================================================
   Responsive hardening (2.6.1)
   Astra's `.ast-container .woocommerce ul.products:not(.elementor-grid)` is more
   specific than ours, so our tablet/phone grid never applied. Make ours win and
   add overflow safety across shop / product / cart / checkout / account.
   ============================================================================= */
.woocommerce ul.products,
.woocommerce-page ul.products,
.ast-woocommerce-container ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }

@media (max-width: 921px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products,
	.ast-woocommerce-container ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 544px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products,
	.ast-woocommerce-container ul.products { grid-template-columns: 1fr !important; }
}

/* Anti-overflow for every WooCommerce surface */
.woocommerce, .woocommerce-page, .ast-woocommerce-container { min-width: 0; }
.woocommerce *, .woocommerce-page * { min-width: 0; }
.woocommerce img { max-width: 100%; height: auto; }
.woocommerce table.shop_table { width: 100%; }

/* Single product: guarantee gallery + summary stack cleanly on tablet/phone */
@media (max-width: 921px) {
	.single-product div.product div.images,
	.single-product div.product div.summary { width: 100% !important; float: none !important; }
	.single-product .summary.entry-summary { padding-left: 0 !important; margin-top: 22px; }
	.single-product form.cart { flex-wrap: wrap; }
}

/* Cart / checkout never force a wider-than-screen layout */
@media (max-width: 768px) {
	.woocommerce-cart .cart-collaterals,
	.woocommerce-cart .cart_totals,
	.woocommerce-checkout #customer_details,
	.woocommerce-checkout #order_review { width: 100% !important; float: none !important; }
}

/* =============================================================================
   Mobile: 2 product cards per row (2.7.1) — user preference, overrides the
   earlier 1-col phone rule (same selector, later in file → wins).
   ============================================================================= */
@media (max-width: 544px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products,
	.ast-woocommerce-container ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 12px !important;
	}
	.woocommerce ul.products li.product .astra-shop-summary-wrap { padding: 12px 12px 14px; }
	.woocommerce ul.products li.product .ast-woo-product-category { font-size: .62rem; margin-bottom: 5px; }
	.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .92rem; margin-bottom: 7px; }
	.woocommerce ul.products li.product .price { font-size: 1rem; margin-bottom: 10px; }
	.woocommerce ul.products li.product .button,
	.woocommerce ul.products li.product a.add_to_cart_button { padding: 9px 10px; font-size: .82rem; }
}
