/* Glassica WP bridge — bridges WooCommerce default markup to our design system.
 * Loaded after polish.css; defensively narrow selectors so we don't break Woo's logic.
 */

/* ─── WooCommerce loop columns: hand off to our .gx-grid layout ─── */
.gx-shop .woocommerce-products-header { display: none; }
.gx-shop ul.products,
.gx-shop .products.columns-1,
.gx-shop .products.columns-2,
.gx-shop .products.columns-3,
.gx-shop .products.columns-4,
.gx-shop .products.columns-5,
.related.products ul.products,
.up-sells.products ul.products,
.cross-sells.products ul.products {
	display: grid !important;
	/* Intrinsically responsive: fits as many ≥220px cards per row as the viewport allows,
	 * so the grid adapts on every device width without needing a fixed column count. */
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
	gap: 16px !important;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
.gx-shop ul.products li.product,
.related.products ul.products li.product,
.up-sells.products ul.products li.product,
.cross-sells.products ul.products li.product { width: auto !important; margin: 0 !important; padding: 0 !important; float: none !important; clear: none !important; min-width: 0; }
.gx-shop ul.products li.product::before, .gx-shop ul.products li.product::after,
.related.products ul.products li.product::before, .related.products ul.products li.product::after { display: none !important; }

/* Woo puts a float-clearfix ::before/::after on the products <ul> itself
 * (content:" "; display:table). Inside our CSS grid those pseudo-elements
 * become two stray empty grid cells. Suppress them — scoped to our grid
 * contexts only, so any other plugin's float-based loop keeps its clearfix. */
.gx-shop .products ul::before, .gx-shop .products ul::after,
.gx-shop ul.products::before, .gx-shop ul.products::after,
.related.products ul.products::before, .related.products ul.products::after,
.up-sells.products ul.products::before, .up-sells.products ul.products::after,
.cross-sells.products ul.products::before, .cross-sells.products ul.products::after {
	content: none !important;
	display: none !important;
}

/* Defensively hide any stray empty <li> or non-product list item that some Woo
 * hooks / plugins inject at the top of the loop — that's the "blank first card". */
.gx-shop ul.products > li:not(.product),
.gx-shop ul.products > li.product:empty,
.related.products ul.products > li:not(.product),
.related.products ul.products > li.product:empty,
.up-sells.products ul.products > li:not(.product),
.up-sells.products ul.products > li.product:empty,
.cross-sells.products ul.products > li:not(.product),
.cross-sells.products ul.products > li.product:empty { display: none !important; }

/* Explicit per-breakpoint caps so the column count stays predictable on common widths.
 * The minmax() rule above is the floor; these clamp the ceiling. */
@media (min-width: 1600px) {
	.gx-shop ul.products,
	.related.products ul.products,
	.up-sells.products ul.products,
	.cross-sells.products ul.products { grid-template-columns: repeat(5, 1fr) !important; }
}
@media (max-width: 1280px) {
	.gx-shop ul.products,
	.related.products ul.products,
	.up-sells.products ul.products,
	.cross-sells.products ul.products { grid-template-columns: repeat(4, 1fr) !important; }
}
@media (max-width: 1024px) {
	.gx-shop ul.products,
	.related.products ul.products,
	.up-sells.products ul.products,
	.cross-sells.products ul.products { grid-template-columns: repeat(3, 1fr) !important; gap: 12px !important; }
}
@media (max-width: 768px) {
	.gx-shop ul.products,
	.related.products ul.products,
	.up-sells.products ul.products,
	.cross-sells.products ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
}
/* Keep cards 2-up on phones — never let a single card fill the whole screen. */
@media (max-width: 380px) {
	.gx-shop ul.products,
	.related.products ul.products,
	.up-sells.products ul.products,
	.cross-sells.products ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; }
}

/* ─── Mobile filter drawer chrome ─── */
.gx-filters-head,
.gx-filters-apply { display: none; }

/* Hide WooCommerce's block-based "Product Filters Overlay" trigger + dialog.
 * The block adds a second "Filter products" button + its own drawer that
 * conflicts with ours — we use a single-tier drawer instead. */
.gx-shop .wp-block-woocommerce-product-filters-overlay-navigation,
.gx-shop .wc-block-product-filters-overlay-navigation,
.gx-shop .wp-block-woocommerce-product-filters-overlay,
.gx-shop .wc-block-product-filters-overlay,
.gx-shop .wc-block-product-filters-overlay-navigation__button,
.gx-shop [class*="product-filters-overlay-navigation"],
.gx-shop [class*="product-filters-overlay__"],
#gx-filters [class*="product-filters-overlay"],
body > .wc-block-product-filters-overlay,
body > .wp-block-woocommerce-product-filters-overlay,
body > .wc-block-product-filters-overlay-dialog,
.wc-block-product-filters-overlay-dialog { display: none !important; }

@media (max-width: 768px) {
	/* Drawer chrome only matters when the aside is in mobile-drawer mode. */
	.gx-filters-head {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 14px 16px;
		margin: -16px -16px 12px;
		border-bottom: 1px solid var(--line-soft);
		background: var(--paper);
		position: sticky;
		top: 0;
		z-index: 1;
		font-family: 'Cormorant Garamond', serif;
		font-size: 18px;
		font-weight: 600;
		color: var(--cocoa);
	}
	.gx-filters-close {
		appearance: none;
		background: transparent;
		border: 1px solid var(--line-soft);
		color: var(--cocoa);
		width: 32px;
		height: 32px;
		border-radius: 999px;
		font-size: 14px;
		line-height: 1;
		cursor: pointer;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		padding: 0;
	}
	.gx-filters-close:hover,
	.gx-filters-close:focus-visible { background: var(--cocoa); color: var(--bone); border-color: var(--cocoa); outline: none; }

	.gx-filters-apply {
		display: block;
		width: calc(100% + 32px);
		margin: 16px -16px -16px;
		padding: 14px 16px;
		background: var(--cocoa);
		color: var(--bone);
		border: none;
		font-family: inherit;
		font-size: 13px;
		font-weight: 700;
		letter-spacing: 0.06em;
		text-transform: uppercase;
		cursor: pointer;
		position: sticky;
		bottom: 0;
		z-index: 1;
	}
	.gx-filters-apply:hover,
	.gx-filters-apply:focus-visible { background: var(--saffron); color: var(--cocoa); outline: none; }

	/* Keep drawer scroll behaviour clean with sticky header/footer. */
	#gx-filters { padding-bottom: 0 !important; }
}

/* ─── Price markup (Woo uses <span class="price"> with <ins>/<del>) ─── */
.gx-card-price .price { display: flex; gap: 6px; align-items: baseline; flex-wrap: wrap; }
.gx-card-price .price ins,
.gx-card-price .price > .amount { font-size: 18px; color: var(--danger); font-weight: 700; text-decoration: none; }
.gx-card-price .price del { font-size: 12px; color: var(--cocoa-soft); }
.gx-card-price .price del .amount { font-size: inherit; color: inherit; font-weight: 500; }

.gx-pdp-price .price { display: flex; gap: 10px; align-items: baseline; flex-wrap: wrap; }
.gx-pdp-price .price ins,
.gx-pdp-price .price > .amount { font-size: 32px; color: var(--danger); font-weight: 700; text-decoration: none; }
.gx-pdp-price .price del { font-size: 16px; color: var(--cocoa-soft); }

/* ─── Add-to-cart button (Woo emits <a class="add_to_cart_button">) ─── */
.gx-card-btns a.add_to_cart_button,
.gx-card-btns a.button.product_type_simple,
.gx-card-btns a.button.product_type_variable,
.gx-card-btns a.button.product_type_grouped,
.gx-card-btns a.button.product_type_external {
	flex: 1; padding: 8px 12px; background: var(--saffron); color: var(--cocoa); border: 1px solid var(--saffron); border-radius: 4px; font-size: 11px; font-weight: 700; cursor: pointer; letter-spacing: 0.04em; text-align: center; text-decoration: none; line-height: 1.2; display: inline-flex; align-items: center; justify-content: center; transition: all 0.15s;
}
.gx-card-btns a.add_to_cart_button:hover,
.gx-card-btns a.button:hover { background: var(--cocoa); color: var(--bone); border-color: var(--cocoa); }
.gx-card-btns a.added { background: var(--success); color: var(--bone); border-color: var(--success); }
.gx-card-btns a.added_to_cart { display: none; } /* hide woo's "View cart" link, we have cart drawer */
.gx-card-btns a.loading { opacity: 0.6; pointer-events: none; }

/* ─── PDP add-to-cart form ─── */
.gx-pdp-body form.cart { display: flex; align-items: center; gap: 10px; margin: 18px 0 14px; flex-wrap: wrap; }
.gx-pdp-body form.cart .quantity { display: flex; align-items: center; gap: 4px; border: 1px solid var(--line); border-radius: 6px; padding: 4px; }
.gx-pdp-body form.cart .quantity input.qty { width: 50px; padding: 8px 6px; border: none; background: transparent; text-align: center; font-family: inherit; font-size: 14px; color: var(--cocoa); -moz-appearance: textfield; }
.gx-pdp-body form.cart .quantity input.qty::-webkit-outer-spin-button,
.gx-pdp-body form.cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.gx-pdp-body form.cart button.single_add_to_cart_button {
	flex: 1; min-width: 200px; background: var(--saffron); color: var(--cocoa); border: none; padding: 14px 22px; border-radius: 6px; font-size: 13px; letter-spacing: 0.06em; cursor: pointer; font-family: inherit; font-weight: 700; transition: background 0.15s;
}
.gx-pdp-body form.cart button.single_add_to_cart_button:hover { background: var(--cocoa); color: var(--bone); }
.gx-pdp-body .product_meta { font-size: 12px; color: var(--cocoa-soft); padding-top: 12px; border-top: 1px solid var(--line-soft); margin-top: 12px; }
.gx-pdp-body .product_meta > span { display: block; padding: 3px 0; }
.gx-pdp-body .product_meta a { color: var(--cocoa); }

/* Variations table */
.gx-pdp-body table.variations { width: 100%; margin: 12px 0; border-collapse: collapse; }
.gx-pdp-body table.variations td { padding: 8px 0; border-top: 1px solid var(--line-soft); font-size: 13px; }
.gx-pdp-body table.variations td.label { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--cocoa-soft); font-weight: 600; width: 90px; }
.gx-pdp-body table.variations td select { padding: 8px 10px; border: 1px solid var(--line); border-radius: 4px; background: var(--paper); font-family: inherit; font-size: 13px; color: var(--cocoa); outline: none; min-width: 120px; }
.gx-pdp-body .reset_variations { font-size: 11px; color: var(--cocoa-soft); margin-left: 8px; }
.gx-pdp-body .single_variation_wrap .price { font-size: 28px; color: var(--danger); font-weight: 700; }
.gx-pdp-body .woocommerce-variation-availability { font-size: 12px; color: var(--success); padding: 6px 0; }

/* Single-product price overrides (avoid clash with prototype's gx-pdp-price) */
.gx-pdp-body .price { display: inline-flex; gap: 10px; align-items: baseline; flex-wrap: wrap; }
.gx-pdp-body .product_title { font-family: 'Cormorant Garamond', serif; font-size: 34px; color: var(--cocoa); margin: 6px 0 10px; font-weight: 600; line-height: 1.15; }
.gx-pdp-body .woocommerce-product-rating { display: flex; align-items: center; gap: 10px; font-size: 12px; color: var(--cocoa-soft); margin-bottom: 8px; }
.gx-pdp-body .woocommerce-product-rating .star-rating { color: var(--saffron); font-size: 13px; }

/* ─── PDP gallery (Woo's flexslider) ─── */
/* WC's gallery is a single block (main image + thumbs below via flexslider),
   not the prototype's 2-col thumb-left/image-right layout. Override the grid
   from pages.css so the gallery can use its own internal layout. */
.gx-pdp-gallery {
	display: block !important;
	position: relative !important;
	grid-template-columns: none !important;
}
.gx-pdp-gallery .woocommerce-product-gallery {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	float: none !important;
	position: relative;
}
.gx-pdp-gallery .woocommerce-product-gallery__wrapper {
	margin: 0 !important;
	padding: 0 !important;
}
.gx-pdp-gallery .woocommerce-product-gallery__image,
.gx-pdp-gallery .woocommerce-product-gallery__image--placeholder {
	display: block;
	margin: 0;
	padding: 0;
	background: var(--bone);
	border-radius: 8px;
	overflow: hidden;
	aspect-ratio: 1/1;
}
.gx-pdp-gallery .woocommerce-product-gallery__image a { display: block; height: 100%; }
.gx-pdp-gallery .woocommerce-product-gallery__image img,
.gx-pdp-gallery .woocommerce-product-gallery__image--placeholder img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	display: block;
	border: 1px solid var(--line-soft);
	border-radius: 8px;
}

/* Sale flash & badge — position relative to the gallery */
.gx-pdp-gallery > .gx-disc {
	position: absolute;
	top: 14px;
	left: 14px;
	z-index: 3;
	background: var(--danger);
	color: #fff;
	font-size: 13px;
	padding: 6px 12px;
	border-radius: 4px;
	font-weight: 700;
	letter-spacing: 0.02em;
}

/* Zoom trigger */
.gx-pdp-gallery .woocommerce-product-gallery__trigger {
	position: absolute;
	top: 14px;
	right: 14px;
	z-index: 3;
	background: var(--paper);
	border: 1px solid var(--line);
	padding: 6px 10px;
	font-size: 14px;
	border-radius: 50%;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--cocoa);
	text-decoration: none;
	box-shadow: var(--shadow-sm);
}
.gx-pdp-gallery .woocommerce-product-gallery__trigger:hover { background: var(--cocoa); color: var(--bone); border-color: var(--cocoa); }

/* Flexslider thumbnails (under main image) */
.gx-pdp-gallery .flex-control-nav,
.gx-pdp-gallery .flex-control-thumbs {
	margin: 12px 0 0 !important;
	padding: 0 !important;
	display: flex !important;
	flex-wrap: wrap;
	gap: 8px;
	list-style: none !important;
}
.gx-pdp-gallery .flex-control-thumbs li {
	flex: 0 0 calc(20% - 7px);
	margin: 0 !important;
	padding: 0 !important;
	width: auto !important;
	max-width: 100px;
}
.gx-pdp-gallery .flex-control-thumbs li::before, .gx-pdp-gallery .flex-control-thumbs li::after { display: none !important; }
.gx-pdp-gallery .flex-control-thumbs img {
	width: 100%;
	aspect-ratio: 1/1;
	object-fit: cover;
	border: 2px solid var(--line-soft);
	border-radius: 6px;
	opacity: 0.65;
	cursor: pointer;
	transition: all 0.18s;
	display: block;
}
.gx-pdp-gallery .flex-control-thumbs img:hover { opacity: 0.9; border-color: var(--saffron); }
.gx-pdp-gallery .flex-control-thumbs img.flex-active { opacity: 1; border-color: var(--cocoa); }

/* Hide flexslider's prev/next nav (we keep the thumb strip) */
.gx-pdp-gallery .flex-direction-nav { display: none !important; }

/* ─── PDP tabs ─── */
.gx-tabs .woocommerce-tabs ul.tabs { list-style: none; padding: 0; margin: 0 0 16px; display: flex; gap: 4px; border-bottom: 2px solid var(--line-soft); flex-wrap: wrap; }
.gx-tabs .woocommerce-tabs ul.tabs li { padding: 0; margin: 0; }
.gx-tabs .woocommerce-tabs ul.tabs li::before, .gx-tabs .woocommerce-tabs ul.tabs li::after { display: none !important; }
.gx-tabs .woocommerce-tabs ul.tabs li a { display: block; padding: 10px 20px; font-size: 13px; color: var(--cocoa-soft); text-decoration: none; border-bottom: 2px solid transparent; margin-bottom: -2px; font-weight: 600; letter-spacing: 0.04em; transition: all 0.15s; }
.gx-tabs .woocommerce-tabs ul.tabs li a:hover { color: var(--cocoa); }
.gx-tabs .woocommerce-tabs ul.tabs li.active a { color: var(--cocoa); border-bottom-color: var(--saffron); }
.gx-tabs .woocommerce-tabs .panel { background: var(--paper); border: 1px solid var(--line-soft); border-radius: 8px; padding: 24px 28px; }
.gx-tabs .woocommerce-tabs .panel h2,
.gx-tabs .woocommerce-tabs .panel h3 { font-family: 'Cormorant Garamond', serif; color: var(--cocoa); font-weight: 600; }

/* ─── Related / Up-sells / Cross-sells sections ─── */
.gx-pdp .related.products,
.gx-pdp .up-sells.products,
.related.products,
.up-sells.products,
.cross-sells.products {
	max-width: 1280px;
	margin: 40px auto 0 !important;
	padding: 32px 16px 0;
	clear: both;
}
.related.products > h2,
.up-sells.products > h2,
.cross-sells.products > h2 {
	font-family: 'Cormorant Garamond', serif;
	font-size: 26px;
	color: var(--cocoa);
	margin: 0 0 16px;
	font-weight: 600;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--line-soft);
}

/* ─── Cart page ─── */
.gx-cart-page .woocommerce { padding: 24px 16px; max-width: 1280px; margin: 0 auto; }
.gx-cart-page table.cart { background: var(--paper); border: 1px solid var(--line-soft); border-radius: 8px; border-collapse: separate; overflow: hidden; }
.gx-cart-page table.cart th { background: var(--bone); padding: 14px 16px; font-family: inherit; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--cocoa-soft); font-weight: 600; border-bottom: 1px solid var(--line-soft); }
.gx-cart-page table.cart td { padding: 16px; border-bottom: 1px solid var(--line-soft); }
.gx-cart-page table.cart td.product-thumbnail img { width: 80px !important; border-radius: 6px; }
.gx-cart-page table.cart td.product-name a { color: var(--cocoa); text-decoration: none; font-weight: 600; }
.gx-cart-page .cart_totals { margin-top: 24px; }
.gx-cart-page .cart_totals h2 { font-family: 'Cormorant Garamond', serif; font-size: 22px; color: var(--cocoa); font-weight: 600; }
.gx-cart-page .checkout-button { width: 100%; background: var(--saffron) !important; color: var(--cocoa) !important; border: none; padding: 14px !important; border-radius: 6px !important; font-size: 13px !important; letter-spacing: 0.06em; font-family: inherit !important; font-weight: 700 !important; text-decoration: none; }
.gx-cart-page .checkout-button:hover { background: var(--cocoa) !important; color: var(--bone) !important; }

/* ─── Checkout page ─── */
.gx-checkout-page-body .woocommerce { padding: 24px 16px 60px; max-width: 1280px; margin: 0 auto; }
.gx-checkout-page-body form.checkout { display: grid; grid-template-columns: 1fr 380px; gap: 20px; align-items: flex-start; }
.gx-checkout-page-body #customer_details,
.gx-checkout-page-body .woocommerce-checkout-review-order { background: var(--paper); border: 1px solid var(--line-soft); border-radius: 8px; padding: 22px 24px; }
.gx-checkout-page-body .woocommerce-checkout-review-order { position: sticky; top: 12px; }
.gx-checkout-page-body h3 { font-family: 'Cormorant Garamond', serif; font-size: 20px; color: var(--cocoa); margin: 0 0 14px; font-weight: 600; }
.gx-checkout-page-body .form-row label { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cocoa-soft); font-weight: 600; }
.gx-checkout-page-body .form-row input, .gx-checkout-page-body .form-row select, .gx-checkout-page-body .form-row textarea { padding: 10px 12px !important; border: 1px solid var(--line) !important; border-radius: 6px !important; background: var(--paper) !important; font-family: inherit !important; font-size: 13px !important; color: var(--cocoa) !important; }
.gx-checkout-page-body .form-row input:focus, .gx-checkout-page-body .form-row select:focus { border-color: var(--cocoa) !important; outline: none !important; }
.gx-checkout-page-body #payment ul.payment_methods { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.gx-checkout-page-body #payment ul.payment_methods li { border: 2px solid var(--line); border-radius: 8px; padding: 14px; background: var(--paper); transition: border-color 0.15s; }
.gx-checkout-page-body #payment ul.payment_methods li.woocommerce-PaymentMethod--bkash:hover,
.gx-checkout-page-body #payment ul.payment_methods li:hover { border-color: var(--saffron); }
.gx-checkout-page-body #payment ul.payment_methods li input:checked + label { color: var(--cocoa); font-weight: 700; }
.gx-checkout-page-body .place-order .button { width: 100%; background: var(--saffron); color: var(--cocoa); border: none; padding: 16px; border-radius: 6px; font-size: 14px; letter-spacing: 0.06em; cursor: pointer; font-family: inherit; font-weight: 700; }
.gx-checkout-page-body .place-order .button:hover { background: var(--cocoa); color: var(--bone); }

@media (max-width: 1100px) {
	.gx-checkout-page-body form.checkout { grid-template-columns: 1fr 320px; }
}
@media (max-width: 768px) {
	.gx-checkout-page-body form.checkout { grid-template-columns: 1fr; }
	.gx-checkout-page-body #payment ul.payment_methods { grid-template-columns: 1fr; }
}

/* ─── Notices ─── */
.woocommerce-notices-wrapper { padding: 0 16px; max-width: 1280px; margin: 0 auto; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	background: var(--bone) !important; color: var(--cocoa) !important; border-top-color: var(--saffron) !important;
	border-radius: 6px !important; padding: 12px 16px !important; margin: 12px 0 !important;
}
.woocommerce-message a.button { background: var(--cocoa) !important; color: var(--bone) !important; padding: 6px 14px !important; border-radius: 4px !important; }

/* ─── Free delivery notice (custom from woocommerce.php) ─── */
.gx-free-notice { background: linear-gradient(95deg, var(--saffron), #f0c544); color: var(--cocoa); padding: 10px 16px; border-radius: 6px; margin: 0 16px 14px; font-size: 13px; text-align: center; }
.gx-free-notice b { font-weight: 700; }

/* ─── Blog grid (used on home/archive when no products) ─── */
.gx-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.gx-blog-card { background: var(--paper); border: 1px solid var(--line-soft); border-radius: 8px; overflow: hidden; }
.gx-blog-card .gx-blog-img { display: block; aspect-ratio: 16/9; overflow: hidden; background: var(--bone); }
.gx-blog-card .gx-blog-img img { width: 100%; height: 100%; object-fit: cover; }
.gx-blog-body { padding: 16px; }
.gx-blog-body h3 { font-family: 'Cormorant Garamond', serif; font-size: 18px; color: var(--cocoa); margin: 0 0 6px; }
.gx-blog-body h3 a { color: inherit; text-decoration: none; }
.gx-blog-meta { font-size: 11px; color: var(--cocoa-soft); letter-spacing: 0.04em; margin-bottom: 4px; }
.gx-blog-body p { font-size: 13px; color: var(--cocoa-soft); line-height: 1.6; margin: 0 0 8px; }
@media (max-width: 768px) { .gx-blog-grid { grid-template-columns: 1fr; } }

/* ─── Foot widget area ─── */
.gx-foot-widget ul, .gx-footer .menu { list-style: none; padding: 0; margin: 0; }
.gx-foot-widget li { padding: 5px 0; font-size: 13px; }
.gx-foot-widget a { color: var(--bone-soft); text-decoration: none; }
.gx-foot-widget a:hover { color: var(--saffron); }

/* ─── Quick view loading state ─── */
.gx-qv-loading { font-size: 13px; }

/* ─── Logo (custom-logo) ─── */
.custom-logo-link { text-decoration: none; }
.custom-logo { max-height: 56px; width: auto; display: block; }

/* ─── Hide WooCommerce's default columns toggle on PDP gallery if hidden ─── */
.gx-pdp-gallery .woocommerce-product-gallery__trigger { background: var(--paper); padding: 6px 10px; font-size: 12px; border-radius: 4px; }

/* ─── Accessibility helpers ─── */
.gx-sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ─── Toast notifications ─── */
.gx-toast {
	position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%) translateY(20px);
	background: var(--cocoa); color: var(--bone); padding: 12px 20px; border-radius: 999px;
	font-size: 13px; font-weight: 500; letter-spacing: 0.02em; box-shadow: var(--shadow-lg);
	z-index: 999999; opacity: 0; transition: opacity .22s, transform .22s; max-width: 92vw; text-align: center;
}
.gx-toast.in { opacity: 1; transform: translateX(-50%) translateY(0); }
.gx-toast-err { background: var(--danger); color: #fff; }

/* ─── Wishlist button on product cards ─── */
.gx-card-img-wrap { position: relative; }
.gx-wl-btn.gx-wl-card {
	position: absolute; top: 10px; right: 10px; z-index: 4;
	width: 38px; height: 38px; border-radius: 50%;
	background: rgba(251,248,241,0.94); border: 1px solid var(--line-soft);
	color: var(--cocoa); cursor: pointer; padding: 0;
	display: flex; align-items: center; justify-content: center;
	box-shadow: var(--shadow-sm); transition: all .15s;
	font-size: 18px; line-height: 1;
}
.gx-wl-btn.gx-wl-card .gx-wl-lbl { display: none; }
.gx-wl-btn.gx-wl-card:hover { background: var(--paper); border-color: var(--cocoa); transform: scale(1.06); }
.gx-wl-btn.gx-wl-card.on { background: var(--cocoa); color: var(--bone); border-color: var(--cocoa); }
.gx-wl-btn.gx-wl-card.on .gx-wl-ico { color: var(--blush); }

/* PDP wishlist row */
.gx-pdp-wishlist-row { margin: 6px 0 14px; }
.gx-wl-btn.gx-wl-pdp {
	display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px;
	background: transparent; border: 1px solid var(--line); color: var(--cocoa);
	border-radius: 999px; cursor: pointer; font-family: inherit; font-size: 13px;
	font-weight: 600; letter-spacing: 0.02em; transition: all .15s;
}
.gx-wl-btn.gx-wl-pdp .gx-wl-ico { font-size: 16px; line-height: 1; }
.gx-wl-btn.gx-wl-pdp:hover { background: var(--bone); border-color: var(--cocoa); }
.gx-wl-btn.gx-wl-pdp.on { background: var(--cocoa); color: var(--bone); border-color: var(--cocoa); }
.gx-wl-btn.gx-wl-pdp.on .gx-wl-ico { color: var(--blush); }

/* Header wishlist count badge */
.gx-icon-wl { position: relative; }
.gx-icon-wl .gx-wl-count {
	position: absolute; top: -4px; right: -6px; min-width: 18px; height: 18px;
	padding: 0 5px; border-radius: 999px; background: var(--saffron); color: var(--cocoa);
	font-size: 10px; font-weight: 700; font-style: normal;
	display: inline-flex; align-items: center; justify-content: center; line-height: 1;
}
.gx-mob-wl em { position: absolute; top: -6px; right: -6px; background: var(--saffron); color: var(--cocoa); border-radius: 999px; font-style: normal; font-size: 9px; padding: 1px 5px; font-weight: 700; }
.gx-mob-wl span { position: relative; }

/* ─── Wishlist page ─── */
.gx-wishlist-page { max-width: 1280px; margin: 0 auto; padding: 32px 16px 60px; }
.gx-wishlist-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; padding-bottom: 18px; border-bottom: 1px solid var(--line-soft); margin-bottom: 24px; flex-wrap: wrap; }
.gx-wishlist-head h2 { font-family: var(--font-display); font-size: 36px; color: var(--cocoa); margin: 0; font-weight: 600; }
.gx-wishlist-sub { font-size: 13px; color: var(--cocoa-soft); margin: 4px 0 0; }
.gx-wishlist-clear { background: transparent; border: 1px solid var(--line); color: var(--cocoa-soft); padding: 8px 14px; border-radius: 999px; font-family: inherit; font-size: 12px; cursor: pointer; letter-spacing: 0.04em; }
.gx-wishlist-clear:hover { border-color: var(--danger); color: var(--danger); }
.gx-wishlist-list { min-height: 240px; }
.gx-wishlist-list .gx-grid, .gx-wishlist-list .gx-wishlist-grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.gx-wishlist-loading { padding: 40px; text-align: center; color: var(--cocoa-soft); font-size: 13px; }
.gx-wishlist-empty { text-align: center; padding: 60px 20px; background: var(--paper); border: 1px solid var(--line-soft); border-radius: 12px; }
.gx-wishlist-empty .gx-empty-glyph { font-size: 48px; color: var(--line); margin-bottom: 12px; }
.gx-wishlist-empty h3 { font-family: var(--font-display); font-size: 26px; color: var(--cocoa); margin: 0 0 8px; font-weight: 600; }
.gx-wishlist-empty p { color: var(--cocoa-soft); margin: 0 auto 18px; max-width: 380px; line-height: 1.6; }
.gx-wishlist-empty .gx-btn-primary { display: inline-block; padding: 12px 22px; background: var(--cocoa); color: var(--bone); text-decoration: none; border-radius: 999px; font-size: 13px; font-weight: 600; letter-spacing: 0.04em; }
.gx-wishlist-empty .gx-btn-primary:hover { background: var(--saffron); color: var(--cocoa); }
@media (max-width: 1100px) { .gx-wishlist-list .gx-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .gx-wishlist-list .gx-grid { grid-template-columns: repeat(2, 1fr); } }

/* ─── Shop filters — see pages.css for the prototype-matched filter styles.
   Only the bits that don't live in pages.css go here: active-filter chips,
   loading state, and the mobile drawer overlay behaviour. ─── */

/* Active filter chips above grid (rendered by glassica_render_active_filters) */
.gx-active-filters { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 10px 0 14px; }
.gx-active-lbl { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--cocoa-soft); font-weight: 600; }

/* Full-width grid override when the filter sidebar is hidden via Customizer */
.gx-shop-grid.gx-shop-grid--full { grid-template-columns: 1fr !important; }
.gx-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--bone); border: 1px solid var(--line-soft); border-radius: 999px; font-size: 12px; color: var(--cocoa); text-decoration: none; transition: all .12s; }
.gx-chip i { font-style: normal; font-size: 10px; color: var(--cocoa-soft); }
.gx-chip:hover { background: var(--cocoa); color: var(--bone); border-color: var(--cocoa); }
.gx-chip:hover i { color: var(--bone); }
.gx-chip-clear { font-size: 11px; color: var(--danger); text-decoration: underline; padding: 6px 8px; }

/* Loading state during AJAX filter swap */
.gx-loading { opacity: 0.4; pointer-events: none; transition: opacity .2s; position: relative; }
.gx-loading::after { content: '⟳ loading…'; position: absolute; top: 60px; left: 50%; transform: translateX(-50%); font-size: 13px; color: var(--cocoa); background: var(--paper); padding: 8px 16px; border-radius: 999px; box-shadow: var(--shadow); }

/* ─── Newsletter forms ─── */
.gx-newsletter { background: var(--bone-soft); padding: 60px 16px; }
.gx-news-row { display: grid; grid-template-columns: 1fr 1.2fr; gap: 48px; align-items: center; }
.gx-news-eyebrow { display: inline-block; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--saffron-dk); font-weight: 700; margin-bottom: 8px; }
.gx-newsletter h3 { font-family: var(--font-display); font-size: 36px; color: var(--cocoa); margin: 0 0 10px; font-weight: 600; line-height: 1.1; }
.gx-newsletter p { color: var(--cocoa-soft); margin: 0; line-height: 1.6; max-width: 480px; }

.gx-news-form { display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: stretch; }
.gx-news-field { display: flex; }
.gx-news-form input[type="email"] {
	width: 100%; padding: 16px 18px; border: 1px solid var(--line); border-radius: 8px;
	background: var(--paper); font-family: inherit; font-size: 14px; color: var(--cocoa); outline: none;
}
.gx-news-form input[type="email"]:focus { border-color: var(--cocoa); }
.gx-news-submit {
	background: var(--cocoa); color: var(--bone); border: 0; padding: 16px 22px;
	border-radius: 8px; cursor: pointer; font-family: inherit; font-size: 13px; font-weight: 700;
	letter-spacing: 0.06em; transition: background .15s;
}
.gx-news-submit:hover { background: var(--saffron); color: var(--cocoa); }
.gx-news-submit[disabled] { opacity: 0.7; cursor: wait; }
.gx-news-status { grid-column: 1 / -1; margin: 4px 0 0; font-size: 13px; min-height: 18px; }
.gx-news-status.ok  { color: var(--success); }
.gx-news-status.err { color: var(--danger); }
.gx-news-fine { grid-column: 1 / -1; font-size: 11px; color: var(--cocoa-soft); margin: 6px 0 0; line-height: 1.5; }
.gx-news-done input[type="email"] { background: var(--bone); }

/* ─────────────────────────────────────────────────────────── */
/* FOOTER — newsletter / trust band / 5-col body / pay row /   */
/* legal strip. Replaces the older minimal rules in storefront. */
/* ─────────────────────────────────────────────────────────── */

/* Container reset for footer */
.gx-footer { background: var(--cocoa); color: var(--bone-soft); }

/* Newsletter band (light, sits above the dark body) */
.gx-foot-news { background: var(--bone); color: var(--cocoa); padding: 42px 16px; border-bottom: 1px solid rgba(0,0,0,0.04); }
.gx-foot-news-row { display: grid; grid-template-columns: 1.1fr 1fr; gap: 48px; align-items: center; max-width: 1280px; margin: 0 auto; }
.gx-foot-eyebrow { display: inline-block; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--saffron-dk); font-weight: 700; margin-bottom: 10px; }
.gx-foot-news h4 { font-family: var(--font-display); font-size: 28px; color: var(--cocoa); margin: 0 0 6px; font-weight: 600; line-height: 1.15; }
.gx-foot-news p { color: var(--cocoa-soft); margin: 0; font-size: 14px; line-height: 1.55; max-width: 460px; }
.gx-foot-news .gx-news-form { display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: stretch; }
.gx-foot-news .gx-news-form input[type="email"] {
	width: 100%; padding: 14px 16px; border: 1px solid var(--line);
	background: var(--paper); font-family: inherit; font-size: 14px;
	color: var(--cocoa); outline: none; border-radius: 6px;
	transition: border-color .15s;
}
.gx-foot-news .gx-news-form input[type="email"]:focus { border-color: var(--cocoa); }
.gx-foot-news .gx-news-form input[type="email"]::placeholder { color: var(--cocoa-soft); opacity: 0.55; }
.gx-foot-news .gx-news-submit { background: var(--cocoa); color: var(--bone); border: 0; padding: 14px 22px; border-radius: 6px; cursor: pointer; font-family: inherit; font-size: 13px; font-weight: 700; letter-spacing: 0.06em; transition: all .15s; }
.gx-foot-news .gx-news-submit:hover { background: var(--saffron); color: var(--cocoa); }
.gx-foot-news .gx-news-status { grid-column: 1 / -1; margin: 6px 0 0; font-size: 12px; min-height: 16px; color: var(--cocoa-soft); }
.gx-foot-news .gx-news-status.ok  { color: var(--success); }
.gx-foot-news .gx-news-status.err { color: var(--danger); }

/* Trust band (4 USPs across) */
.gx-foot-trust { background: var(--cocoa-ink); padding: 22px 16px; border-bottom: 1px solid rgba(241,236,224,0.08); }
.gx-foot-trust-row { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.gx-foot-trust-item { display: flex; align-items: flex-start; gap: 12px; color: var(--bone); }
.gx-foot-trust-item i { font-style: normal; font-size: 22px; line-height: 1; margin-top: 2px; opacity: 0.9; }
.gx-foot-trust-item b { display: block; font-size: 13px; font-weight: 700; color: var(--bone); letter-spacing: 0.01em; margin-bottom: 2px; }
.gx-foot-trust-item span { display: block; font-size: 11.5px; color: rgba(241,236,224,0.62); line-height: 1.45; }

/* 5-column main footer body */
.gx-footer-top {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
	gap: 36px;
	padding: 48px 16px 36px;
	border-bottom: 1px solid rgba(241,236,224,0.10);
}

/* Brand column */
.gx-foot-brand .custom-logo,
.gx-foot-brand .gx-logo img,
.gx-foot-brand img:not(.gx-pay img) { max-height: 44px; width: auto; margin-bottom: 16px; filter: brightness(0) invert(1); opacity: 0.95; }
.gx-foot-tagline { font-size: 13px; line-height: 1.65; color: rgba(241,236,224,0.72); margin: 0 0 18px; max-width: 320px; }

.gx-foot-contact-list { list-style: none; padding: 0; margin: 0 0 18px; display: flex; flex-direction: column; gap: 8px; }
.gx-foot-contact-list li { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--bone-soft); }
.gx-foot-contact-list li i { font-style: normal; font-size: 14px; opacity: 0.7; }
.gx-foot-contact-list li a { color: var(--bone-soft); text-decoration: none; transition: color .12s; }
.gx-foot-contact-list li a:hover { color: var(--saffron); }

/* Social icons */
.gx-socials { display: flex; gap: 8px; flex-wrap: wrap; }
.gx-socials a {
	display: inline-flex; align-items: center; justify-content: center;
	width: 34px; height: 34px; border-radius: 50%;
	background: rgba(241,236,224,0.08);
	color: var(--bone); text-decoration: none;
	font-size: 14px; transition: all .15s; border: 1px solid rgba(241,236,224,0.10);
}
.gx-socials a:hover { background: var(--saffron); color: var(--cocoa); border-color: var(--saffron); transform: translateY(-1px); }

/* Link columns */
.gx-foot-col { min-width: 0; }
.gx-footer h5 {
	font-family: var(--font-sans);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--bone);
	margin: 0 0 18px;
	opacity: 0.92;
}
.gx-foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.gx-foot-col li { padding: 0; font-size: 13px; line-height: 1.5; opacity: 1; cursor: default; }
.gx-foot-col li a { display: inline-block; padding: 5px 0; color: rgba(241,236,224,0.72); text-decoration: none; transition: color .12s, transform .12s; }
.gx-foot-col li a:hover { color: var(--saffron); transform: translateX(2px); }
.gx-foot-col li:hover { color: inherit; opacity: 1; }

/* Payment + locale row */
.gx-foot-pay-row { display: flex; align-items: center; gap: 18px; padding: 22px 16px; border-bottom: 1px solid rgba(241,236,224,0.10); flex-wrap: wrap; }
.gx-pay-label { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(241,236,224,0.55); font-weight: 600; }
.gx-pay { display: flex; gap: 6px; flex-wrap: wrap; margin: 0; }
.gx-pay span {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 6px 12px;
	background: rgba(241,236,224,0.06);
	color: var(--bone);
	border: 1px solid rgba(241,236,224,0.12);
	border-radius: 4px;
	font-size: 10.5px; font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1;
	min-height: 28px;
}
.gx-pay .gx-pay-bkash  { color: #e2136e; background: rgba(226,19,110,0.08);  border-color: rgba(226,19,110,0.25); }
.gx-pay .gx-pay-nagad  { color: #f5a623; background: rgba(245,166,35,0.08);  border-color: rgba(245,166,35,0.25); }
.gx-pay .gx-pay-rocket { color: #8e2ab7; background: rgba(142,42,183,0.10);  border-color: rgba(142,42,183,0.28); }
.gx-pay .gx-pay-visa   { color: #1a4a9c; background: rgba(26,74,156,0.10);   border-color: rgba(26,74,156,0.28); letter-spacing: 0.12em; }
.gx-pay .gx-pay-master { color: #eb4f1c; background: rgba(235,79,28,0.10);   border-color: rgba(235,79,28,0.28); }
.gx-pay .gx-pay-cod    { color: var(--bone); background: rgba(95,124,58,0.18); border-color: rgba(95,124,58,0.45); }

.gx-foot-locale { margin-left: auto; font-size: 12px; color: rgba(241,236,224,0.62); }
.gx-foot-locale b { color: var(--bone); font-weight: 600; }

/* Bottom legal strip */
.gx-foot-bottom { display: flex; align-items: center; justify-content: space-between; padding: 18px 16px 22px; gap: 16px; flex-wrap: wrap; }
.gx-foot-copy { font-size: 12px; color: rgba(241,236,224,0.55); }
.gx-foot-legal { display: flex; gap: 18px; flex-wrap: wrap; }
.gx-foot-legal a { font-size: 12px; color: rgba(241,236,224,0.62); text-decoration: none; transition: color .12s; }
.gx-foot-legal a:hover { color: var(--saffron); }

/* Responsive */
@media (max-width: 1100px) {
	.gx-footer-top { grid-template-columns: 1fr 1fr 1fr; gap: 28px; }
	.gx-foot-brand { grid-column: 1 / -1; }
	.gx-foot-trust-row { grid-template-columns: 1fr 1fr; gap: 18px; }
}
@media (max-width: 768px) {
	.gx-foot-news { padding: 32px 16px; }
	.gx-foot-news-row { grid-template-columns: 1fr; gap: 18px; }
	.gx-foot-news h4 { font-size: 22px; }
	.gx-foot-news .gx-news-form { grid-template-columns: 1fr; }
	.gx-foot-news .gx-news-submit { width: 100%; }
	.gx-footer-top { grid-template-columns: 1fr 1fr; gap: 22px; padding: 32px 12px 24px; }
	.gx-foot-brand { grid-column: 1 / -1; }
	.gx-foot-pay-row { padding: 16px 12px; gap: 12px; }
	.gx-foot-locale { margin-left: 0; width: 100%; }
	.gx-foot-bottom { padding: 14px 12px 80px; }
}
@media (max-width: 480px) {
	.gx-foot-trust-row { grid-template-columns: 1fr; }
	.gx-footer-top { grid-template-columns: 1fr; }
}

/* COD-only notice in checkout */
.gx-cod-only-notice {
	background: var(--bone); border: 1px dashed var(--line); padding: 14px 16px;
	border-radius: 8px; font-size: 13px; color: var(--cocoa-soft); margin-bottom: 14px;
	line-height: 1.5;
}
.gx-testimonials { padding: 72px 16px; background: var(--paper); }
.gx-tst-head { text-align: center; max-width: 600px; margin: 0 auto 36px; }
.gx-tst-eyebrow { display: inline-block; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--saffron-dk); font-weight: 700; margin-bottom: 10px; }
.gx-testimonials h2 { font-family: var(--font-display); font-size: 40px; color: var(--cocoa); margin: 0 0 10px; font-weight: 600; line-height: 1.1; }
.gx-testimonials .gx-tst-head p { color: var(--cocoa-soft); margin: 0; line-height: 1.6; }

.gx-tst-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: 1180px; margin: 0 auto; }
.gx-tst-card {
	background: var(--bone); border: 1px solid var(--line-soft); border-radius: 12px;
	padding: 26px 24px; margin: 0; display: flex; flex-direction: column; gap: 14px;
}
.gx-tst-stars { display: inline-flex; gap: 1px; }
.gx-tst-stars i { font-style: normal; color: var(--line); font-size: 15px; }
.gx-tst-stars i.on { color: var(--saffron); }
.gx-tst-text {
	font-family: var(--font-display); font-size: 19px; color: var(--cocoa);
	line-height: 1.45; margin: 0; font-style: italic; font-weight: 500;
}
.gx-tst-by { display: flex; flex-direction: column; gap: 2px; margin-top: auto; padding-top: 6px; border-top: 1px solid var(--line-soft); }
.gx-tst-by b   { color: var(--cocoa); font-weight: 700; font-size: 13px; letter-spacing: 0.02em; }
.gx-tst-by span{ font-size: 11px; color: var(--cocoa-soft); letter-spacing: 0.04em; text-transform: uppercase; }

@media (max-width: 900px)  { .gx-tst-grid { grid-template-columns: 1fr 1fr; } .gx-testimonials h2 { font-size: 32px; } }
@media (max-width: 600px)  { .gx-tst-grid { grid-template-columns: 1fr; } .gx-testimonials { padding: 56px 16px; } }

/* ─── Shop toolbar / filter-mobile / empty state — see pages.css for the
   prototype-matched styles. This file no longer overrides them. ─── */
