/**
 * AS Infocom — WooCommerce styling.
 *
 * Loaded after style.css, so all --asi-* design tokens are available.
 * Styles the shop loop, single product, cart, checkout, my-account,
 * notices and shop widgets to match the theme's design system.
 *
 * @package AS_Infocom
 */

/* =========================================================================
   0. Shared building blocks
   ========================================================================= */
.woocommerce .asi-page-title,
.woocommerce-products-header__title {
	margin-bottom: .35rem;
}
.woocommerce .term-description,
.woocommerce-products-header .woocommerce-archive-description {
	color: var(--asi-muted);
	max-width: 70ch;
	margin-bottom: 1.5rem;
}

/* Result count + ordering toolbar. WooCommerce prints these as bare siblings
   directly before the product grid, so they're laid out as a cleared row with
   clear breathing room below (the grid clears it via `clear: both`). */
.woocommerce-products-header { margin-bottom: 1rem; }
.woocommerce .woocommerce-result-count {
	float: left;
	margin: 0 0 1.5rem;
	color: var(--asi-muted);
	font-size: .9rem;
	line-height: 46px;
}
.woocommerce .woocommerce-ordering {
	float: right;
	margin: 0 0 1.5rem;
}
.woocommerce .woocommerce-ordering select {
	width: auto;
	min-width: 220px;
	padding-right: 2.25rem;
}
.asi-main > .woocommerce-notices-wrapper:empty { display: none; }

@media (max-width: 520px) {
	.woocommerce .woocommerce-result-count,
	.woocommerce .woocommerce-ordering { float: none; width: 100%; }
	.woocommerce .woocommerce-result-count { line-height: 1.5; margin-bottom: .6rem; }
	.woocommerce .woocommerce-ordering { margin-bottom: 1.25rem; }
	.woocommerce .woocommerce-ordering select { width: 100%; }
}

/* Shop toolbar wrapper (only applies if a theme wraps these in one). */
.woocommerce .asi-shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	margin-bottom: 1.5rem;
}

/* =========================================================================
   1. Product loop / grid
   ========================================================================= */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(14px, 2vw, 24px);
	clear: both;
	margin: 0 0 2.5rem;
	padding: 0;
	list-style: none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none; }

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

/* Force-override WooCommerce's inline float widths (padding is set on the card). */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product.last {
	width: 100% !important;
	margin: 0 !important;
	float: none !important;
	clear: none !important;
}

/* Product card — modern "framed" tile: minimal border, soft layered shadow,
   generous radius, with the product image inset as a rounded panel. */
.woocommerce ul.products li.product,
.asi-product-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--asi-surface);
	border: 1px solid rgba(15, 23, 42, .06);
	border-radius: 18px;
	padding: 10px 10px 14px;
	overflow: hidden;
	box-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 12px 28px -14px rgba(15, 23, 42, .14);
	transition: transform .25s var(--asi-ease), box-shadow .25s var(--asi-ease), border-color .25s var(--asi-ease);
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-6px);
	border-color: rgba(21, 89, 237, .28);
	box-shadow: 0 2px 4px rgba(15, 23, 42, .05), 0 26px 50px -18px rgba(11, 31, 58, .30);
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	color: inherit;
}
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product img {
	margin: 0;
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	background: var(--asi-surface-alt);
	border-radius: 14px;
	box-shadow: inset 0 0 0 1px rgba(15, 23, 42, .05);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-category__title {
	padding: .85rem .45rem .2rem;
	font-family: var(--asi-font);
	font-size: .98rem;
	font-weight: 600;
	line-height: 1.35;
	color: var(--asi-ink);
	min-height: 2.7em;
}

/* Brand / SKU eyebrow injected by the theme on cards */
.woocommerce ul.products li.product .asi-card-brand {
	padding: .75rem .45rem 0;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--asi-muted);
}

.woocommerce ul.products li.product .star-rating {
	margin: .15rem .45rem .35rem;
	font-size: .8rem;
	color: var(--asi-accent);
}

.woocommerce ul.products li.product .price {
	padding: 0 .45rem;
	margin-top: auto;
	color: var(--asi-ink);
	font-size: 1.15rem;
	font-weight: 700;
	font-family: var(--asi-font-head);
}
.woocommerce ul.products li.product .price del {
	color: var(--asi-muted);
	font-weight: 500;
	font-size: .9rem;
	margin-right: .4rem;
	opacity: .8;
}
.woocommerce ul.products li.product .price ins {
	text-decoration: none;
	color: var(--asi-danger);
}
.woocommerce .price .woocommerce-Price-currencySymbol { font-weight: 600; }

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
	margin: .9rem .45rem 0;
	width: calc(100% - .9rem);
}
.woocommerce ul.products li.product .added_to_cart {
	background: var(--asi-surface-alt);
	color: var(--asi-ink);
	border: 1px solid var(--asi-line);
}

/* Sale / featured badges */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale,
.asi-badge--sale {
	position: absolute;
	top: 20px;
	left: 20px;
	z-index: 3;
	min-height: auto;
	min-width: auto;
	margin: 0;
	padding: .3rem .65rem;
	border-radius: 999px;
	background: var(--asi-danger);
	color: #fff;
	font-size: .72rem;
	font-weight: 700;
	line-height: 1;
}
.woocommerce ul.products li.product .asi-badge--featured {
	position: absolute;
	top: 20px;
	right: 20px;
	z-index: 3;
	background: var(--asi-success);
	color: #fff;
	padding: .3rem .6rem;
	border-radius: 999px;
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .03em;
}

/* On product cards: hide the top-corner sale flash and show a "SALE" pill
   right next to the price instead. */
.woocommerce ul.products li.product .onsale { display: none; }
.woocommerce ul.products li.product.sale .price::before {
	content: "SALE";
	display: inline-block;
	vertical-align: 2px;
	margin-right: .5rem;
	padding: .25em .55em;
	border-radius: 999px;
	background: var(--asi-danger);
	color: #fff;
	font-family: var(--asi-font);
	font-size: .6rem;
	font-weight: 700;
	letter-spacing: .05em;
	line-height: 1;
}

.woocommerce .products .star-rating,
.woocommerce .star-rating { color: var(--asi-accent); }

/* Out of stock dimming */
.woocommerce ul.products li.product.outofstock img { opacity: .55; filter: grayscale(.2); }

/* =========================================================================
   2. Single product
   ========================================================================= */
.woocommerce div.product {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(24px, 4vw, 56px);
	margin-bottom: 3rem;
}
.woocommerce div.product .woocommerce-product-gallery { width: 100% !important; margin: 0; float: none; }
.woocommerce div.product .summary { margin: 0 !important; width: 100% !important; float: none; }
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related,
.woocommerce div.product .upsells,
.woocommerce div.product .product_meta {
	grid-column: 1 / -1;
}

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

.woocommerce div.product .woocommerce-product-gallery__wrapper {
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius-lg);
	overflow: hidden;
	background: var(--asi-surface);
}
.woocommerce div.product .woocommerce-product-gallery img { border-radius: 0; }
.woocommerce div.product .flex-control-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	margin: .75rem 0 0;
	padding: 0;
	list-style: none;
}
.woocommerce div.product .flex-control-thumbs li { width: 72px !important; margin: 0; }
.woocommerce div.product .flex-control-thumbs img {
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius-sm);
	cursor: pointer;
	opacity: .65;
	transition: opacity .2s var(--asi-ease), border-color .2s var(--asi-ease);
}
.woocommerce div.product .flex-control-thumbs img.flex-active,
.woocommerce div.product .flex-control-thumbs img:hover { opacity: 1; border-color: var(--asi-primary); }

.woocommerce div.product .product_title {
	font-size: clamp(1.5rem, 3vw, 2.1rem);
	margin-bottom: .5rem;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--asi-ink);
	font-size: 1.7rem;
	font-weight: 800;
	font-family: var(--asi-font-head);
	margin: .25rem 0 1rem;
}
.woocommerce div.product p.price del { color: var(--asi-muted); font-size: 1.1rem; font-weight: 500; opacity: .75; }
.woocommerce div.product p.price ins { text-decoration: none; color: var(--asi-danger); }

.woocommerce div.product .woocommerce-product-rating { margin-bottom: 1rem; }
.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--asi-body);
	margin-bottom: 1.5rem;
}
.woocommerce div.product .woocommerce-product-details__short-description ul { padding-left: 1.1rem; }

.woocommerce div.product form.cart { margin: 1.5rem 0; display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }
.woocommerce div.product form.cart .quantity { margin: 0; }
.woocommerce div.product form.cart .button { padding: 1rem 2rem; }
.woocommerce div.product .stock { font-weight: 600; }
.woocommerce div.product .stock.in-stock { color: var(--asi-success); }
.woocommerce div.product .stock.out-of-stock { color: var(--asi-danger); }

.woocommerce .product_meta {
	margin-top: 1.5rem;
	padding-top: 1rem;
	border-top: 1px solid var(--asi-line);
	font-size: .9rem;
	color: var(--asi-muted);
}
.woocommerce .product_meta > span { display: block; margin-bottom: .35rem; }
.woocommerce .product_meta a { color: var(--asi-primary); }

/* Theme trust badges under summary */
.asi-product-trust {
	list-style: none;
	margin: 1.25rem 0 0;
	padding: 1.1rem 0 0;
	border-top: 1px solid var(--asi-line);
	display: grid;
	gap: .65rem;
}
.asi-product-trust li {
	display: flex;
	align-items: center;
	gap: .6rem;
	font-size: .9rem;
	color: var(--asi-body);
}
.asi-product-trust svg { width: 20px; height: 20px; color: var(--asi-primary); flex-shrink: 0; }

/* Quantity input */
.woocommerce .quantity { display: inline-flex; align-items: stretch; }
.woocommerce .quantity .qty {
	width: 76px;
	text-align: center;
	padding: .8rem .4rem;
	border-radius: var(--asi-radius-sm);
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs { margin-top: 1rem; }
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	flex-wrap: wrap;
	gap: .25rem;
	margin: 0 0 1.5rem;
	padding: 0;
	border-bottom: 1px solid var(--asi-line);
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { content: none; border: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: .85rem 1.25rem;
	font-weight: 600;
	color: var(--asi-muted);
	border-bottom: 2px solid transparent;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover { color: var(--asi-primary); border-bottom-color: var(--asi-primary); }
.woocommerce div.product .woocommerce-Tabs-panel h2 { font-size: 1.3rem; }

/* Attribute/spec table */
.woocommerce table.shop_attributes {
	width: 100%;
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
}
.woocommerce table.shop_attributes th,
.woocommerce table.shop_attributes td {
	padding: .75rem 1rem;
	border-bottom: 1px solid var(--asi-line);
	font-style: normal;
}
.woocommerce table.shop_attributes th {
	width: 30%;
	background: var(--asi-surface-alt);
	color: var(--asi-ink);
	font-weight: 600;
	text-align: left;
}
.woocommerce table.shop_attributes tr:last-child th,
.woocommerce table.shop_attributes tr:last-child td { border-bottom: 0; }

/* Related products heading */
.woocommerce .related > h2,
.woocommerce .upsells > h2 {
	margin: 2.5rem 0 1.5rem;
	padding-top: 2rem;
	border-top: 1px solid var(--asi-line);
}

/* =========================================================================
   3. Cart
   ========================================================================= */
.woocommerce table.shop_table {
	width: 100%;
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
	margin-bottom: 1.5rem;
}
.woocommerce table.shop_table th {
	background: var(--asi-surface-alt);
	color: var(--asi-ink);
	font-family: var(--asi-font);
	font-weight: 600;
	padding: 1rem;
	text-align: left;
}
.woocommerce table.shop_table td {
	padding: 1rem;
	border-top: 1px solid var(--asi-line);
	vertical-align: middle;
}
.woocommerce table.cart img { width: 64px; border-radius: var(--asi-radius-sm); border: 1px solid var(--asi-line); }
.woocommerce a.remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	color: var(--asi-danger) !important;
	font-size: 1.1rem;
	line-height: 1;
	background: rgba(220, 38, 38, .08);
}
.woocommerce a.remove:hover { background: var(--asi-danger); color: #fff !important; }
.woocommerce .cart-collaterals,
.woocommerce-cart .cart-collaterals {
	display: flex;
	justify-content: flex-end;
	margin-top: 1rem;
}
.woocommerce .cart-collaterals .cart_totals {
	width: 100%;
	max-width: 420px;
	float: none;
}
.woocommerce .cart_totals h2 { font-size: 1.3rem; margin-bottom: 1rem; }
.woocommerce .cart_totals table { margin: 0; }
.woocommerce .wc-proceed-to-checkout { padding: 1rem 0 0; }
.woocommerce .wc-proceed-to-checkout a.checkout-button { width: 100%; padding: 1.1rem; font-size: 1.05rem; }
.woocommerce .cart .actions .coupon { display: flex; gap: .5rem; }
.woocommerce .cart .actions .coupon .input-text { width: auto; min-width: 160px; }

/* =========================================================================
   4. Checkout
   ========================================================================= */
.woocommerce-checkout .col2-set {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(20px, 3vw, 40px);
	width: 100%;
}
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 { width: 100%; float: none; }
@media (max-width: 800px) { .woocommerce-checkout .col2-set { grid-template-columns: 1fr; } }

.woocommerce form .form-row { margin-bottom: 1rem; padding: 0; }
.woocommerce form .form-row label { margin-bottom: .35rem; }
.woocommerce .woocommerce-billing-fields h3,
.woocommerce .woocommerce-shipping-fields h3,
#order_review_heading { font-size: 1.3rem; margin: .5rem 0 1.25rem; }

#order_review {
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	padding: 1.5rem;
	margin-top: 1rem;
}
.woocommerce-checkout #payment {
	background: transparent;
	border-radius: var(--asi-radius);
}
.woocommerce-checkout #payment ul.payment_methods {
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	padding: 1rem;
	background: var(--asi-surface-alt);
	list-style: none;
	margin: 0 0 1rem;
}
.woocommerce-checkout #payment ul.payment_methods li { margin-bottom: .5rem; }
.woocommerce-checkout #payment div.payment_box {
	background: var(--asi-surface);
	border-radius: var(--asi-radius-sm);
	color: var(--asi-body);
	font-size: .9rem;
}
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: var(--asi-surface); }
.woocommerce-checkout #payment .button#place_order { width: 100%; padding: 1.1rem; font-size: 1.05rem; }
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper { margin: 1rem 0; }

/* =========================================================================
   5. My Account
   ========================================================================= */
.woocommerce-account .woocommerce::after { content: ""; display: table; clear: both; }
.woocommerce-account .woocommerce-MyAccount-navigation {
	width: 24%;
	float: left;
	margin-bottom: 1.5rem;
}
.woocommerce-account .woocommerce-MyAccount-content {
	width: 72%;
	float: right;
}
@media (max-width: 768px) {
	.woocommerce-account .woocommerce-MyAccount-navigation,
	.woocommerce-account .woocommerce-MyAccount-content { width: 100%; float: none; }
}
.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; }
.woocommerce-MyAccount-navigation li {
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius-sm);
	margin-bottom: .5rem;
	overflow: hidden;
}
.woocommerce-MyAccount-navigation li a {
	display: block;
	padding: .8rem 1rem;
	color: var(--asi-ink);
	font-weight: 600;
}
.woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-MyAccount-navigation li a:hover { background: var(--asi-primary); color: #fff; }

/* =========================================================================
   6. Notices
   ========================================================================= */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
.woocommerce-store-notice {
	display: flex;
	align-items: center;
	gap: .75rem;
	padding: 1rem 1.25rem;
	border-radius: var(--asi-radius);
	border: 1px solid var(--asi-line);
	border-left-width: 4px;
	background: var(--asi-surface);
	color: var(--asi-ink);
	margin-bottom: 1.5rem;
	list-style: none;
}
.woocommerce-message { border-left-color: var(--asi-success); background: rgba(22, 163, 74, .06); }
.woocommerce-info { border-left-color: var(--asi-primary); background: rgba(21, 89, 237, .06); }
.woocommerce-error { border-left-color: var(--asi-danger); background: rgba(220, 38, 38, .06); flex-direction: column; align-items: flex-start; }
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before { position: static; margin: 0; }
.woocommerce-message a.button,
.woocommerce-info a.button { margin-left: auto; padding: .5rem 1rem; font-size: .85rem; }

/* Order received / thankyou */
.woocommerce-order .woocommerce-order-overview {
	list-style: none;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 1px;
	margin: 1.5rem 0;
	padding: 0;
	background: var(--asi-line);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	overflow: hidden;
}
.woocommerce-order .woocommerce-order-overview li {
	background: var(--asi-surface);
	padding: 1rem 1.25rem;
	border: 0;
	font-size: .85rem;
	color: var(--asi-muted);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.woocommerce-order .woocommerce-order-overview li strong {
	display: block;
	margin-top: .35rem;
	font-size: 1rem;
	color: var(--asi-ink);
	text-transform: none;
	letter-spacing: 0;
}

/* =========================================================================
   7. Shop widgets (sidebar)
   ========================================================================= */
.asi-sidebar .widget ul.product-categories,
.asi-sidebar .widget ul.cart_list,
.asi-sidebar .widget ul { list-style: none; padding: 0; margin: 0; }
.asi-sidebar .product-categories li {
	display: flex;
	justify-content: space-between;
	gap: .5rem;
	padding: .5rem 0;
	border-bottom: 1px dashed var(--asi-line);
}
.asi-sidebar .product-categories li a { color: var(--asi-body); }
.asi-sidebar .product-categories li a:hover { color: var(--asi-primary); }
.asi-sidebar .product-categories .count { color: var(--asi-muted); font-size: .85rem; }

.woocommerce .widget_price_filter .price_slider_wrapper { margin-top: .5rem; }
.woocommerce .widget_price_filter .ui-slider .ui-slider-range,
.woocommerce .widget_price_filter .price_slider_amount .button { background: var(--asi-primary); }
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle { background: var(--asi-primary); border-radius: 50%; }

.woocommerce ul.product_list_widget li { padding: .6rem 0; border-bottom: 1px dashed var(--asi-line); display: flex; gap: .6rem; align-items: center; }
.woocommerce ul.product_list_widget li img { width: 48px; height: 48px; object-fit: cover; border-radius: var(--asi-radius-sm); margin: 0; }
.woocommerce ul.product_list_widget li a { color: var(--asi-ink); font-weight: 600; font-size: .9rem; }

/* Active filters / ratings */
.woocommerce .widget_layered_nav ul li,
.woocommerce .widget_rating_filter ul li { padding: .4rem 0; }

/* =========================================================================
   8. Misc fixes
   ========================================================================= */
.woocommerce .blockUI.blockOverlay { border-radius: var(--asi-radius); }
.woocommerce form .form-row .required { color: var(--asi-danger); }
.woocommerce-form-login,
.woocommerce-form-register,
.woocommerce-ResetPassword {
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	padding: clamp(1.25rem, 3vw, 2rem);
	max-width: 480px;
}
.woocommerce-form-login__rememberme { display: inline-flex; align-items: center; gap: .4rem; }
.woocommerce .col2-set#customer_login { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
@media (max-width: 760px) { .woocommerce .col2-set#customer_login { grid-template-columns: 1fr; } }
.woocommerce-account .woocommerce > .col2-set#customer_login { float: none; width: 100%; }
