/* ============================================================
   ShopGen — Cart & Checkout (Shopify-inspired)
   CSS custom properties are set inline from PHP/JSON config.
   Variables reference: --sgcc-* (sgcc = ShopGen Cart/Checkout)
   ============================================================ */

/* ── Reset & page base ─────────────────────────────────────── */
body.woocommerce-cart main.site-main,
body.woocommerce-checkout main.site-main {
	font-family: var(--sgcc-font, Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif);
	font-size: var(--sgcc-font-size, 15px);
	color: var(--sgcc-text, #111);
	background: var(--sgcc-bg, #fff);
}

/* ── Page container ─────────────────────────────────────────── */
body.woocommerce-cart main.site-main .woocommerce,
body.woocommerce-checkout main.site-main .woocommerce {
	max-width: var(--sgcc-max-width, 1200px);
	margin-left: auto;
	margin-right: auto;
	padding: 0 24px 56px;
	box-sizing: border-box;
}

/* ── Cart page: two-column grid ─────────────────────────────── */
body.woocommerce-cart main.site-main .woocommerce {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(300px, var(--sgcc-sum-width, 380px));
	gap: 0 48px;
	align-items: start;
	padding-top: 0;
}

body.woocommerce-cart main.site-main .woocommerce > form.woocommerce-cart-form {
	grid-column: 1;
	grid-row: 2;
	min-width: 0;
	overflow-x: auto;
}

body.woocommerce-cart main.site-main .woocommerce > .cart-collaterals {
	grid-column: 1 / -1;
	display: contents !important;
}

/* Notices span full width */
body.woocommerce-cart .woocommerce-notices-wrapper {
	grid-column: 1 / -1;
}

/* ── Cart page header ───────────────────────────────────────── */
.shopgen-cart-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	padding: 5px 0 22px;
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
	margin-bottom: 24px;
	grid-column: 1 / -1;
}

.shopgen-cart-header__title {
	font-family: var(--sgcc-heading-font, var(--sgcc-font, inherit));
	font-size: var(--sgcc-cart-title-size, 1.65rem);
	font-weight: 700;
	margin: 0;
	color: var(--sgcc-text, #111);
}

.shopgen-cart-header__continue {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.85rem;
	color: var(--sgcc-muted, #717171);
	text-decoration: none;
	transition: color 0.15s;
}

.shopgen-cart-header__continue:hover {
	color: var(--sgcc-text, #111);
}

/* ── Page heading (.entry-title) controls from admin/JSON ───── */
body.woocommerce-cart main.site-main .entry-header,
body.woocommerce-checkout main.site-main .entry-header {
	text-align: var(--sgcc-page-title-align, left);
	max-width: var(--sgcc-max-width, 1200px);
	margin-left: auto;
	margin-right: auto;
	padding-left: 24px;
	padding-right: 24px;
	box-sizing: border-box;
	margin-bottom: 20px;
}

body.woocommerce-cart main.site-main .entry-title,
body.woocommerce-checkout main.site-main .entry-title {
	font-family: var(--sgcc-page-title-font, var(--sgcc-heading-font, var(--sgcc-font, inherit)));
	font-size: var(--sgcc-page-title-size, 2.2rem);
	color: var(--sgcc-page-title-color, var(--sgcc-text, #111111));
	line-height: 1.2;
	margin: 0;
}

/* ── Cart table ─────────────────────────────────────────────── */
body.woocommerce-cart table.shop_table.cart {
	border: none !important;
	border-collapse: collapse;
	width: 100%;
	table-layout: fixed;
	font-size: inherit;
}

body.woocommerce-cart table.shop_table.cart thead th {
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--sgcc-label, #555555);
	padding: 0 10px 14px;
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5) !important;
	background: transparent;
	white-space: nowrap;
}

body.woocommerce-cart table.shop_table.cart tbody tr {
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
}

body.woocommerce-cart table.shop_table.cart tbody tr:last-child {
	border-bottom: none;
}

body.woocommerce-cart table.shop_table.cart td {
	padding: 20px 10px;
	vertical-align: middle;
	border: none !important;
	background: transparent !important;
}

/* Product thumbnail */
body.woocommerce-cart table.shop_table .product-thumbnail {
	width: 92px;
	padding-right: 0;
}

body.woocommerce-cart table.shop_table .product-name {
	min-width: 0;
	overflow-wrap: anywhere;
}

body.woocommerce-cart table.shop_table .product-thumbnail img {
	width: 80px !important;
	height: 80px !important;
	object-fit: cover;
	border-radius: var(--sgcc-img-radius, 8px);
	display: block;
	border: 1px solid var(--sgcc-border, #e5e5e5);
}

/* Product name */
body.woocommerce-cart table.shop_table .product-name a {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--sgcc-text, #111);
	text-decoration: none;
	display: block;
	margin-bottom: 3px;
	line-height: 1.4;
}

body.woocommerce-cart table.shop_table .product-name a:hover {
	color: var(--sgcc-accent, #111);
	text-decoration: underline;
	text-underline-offset: 2px;
}

body.woocommerce-cart table.shop_table .product-name dl.variation {
	font-size: 0.8rem;
	color: var(--sgcc-muted, #717171);
	margin: 5px 0 0;
	padding: 0;
	border: none;
}

body.woocommerce-cart table.shop_table .product-name dl.variation dt,
body.woocommerce-cart table.shop_table .product-name dl.variation dd {
	display: inline;
	margin: 0;
	padding: 0;
}

body.woocommerce-cart table.shop_table .product-name dl.variation dt::after { content: ': '; }
body.woocommerce-cart table.shop_table .product-name dl.variation dd::after { content: ' · '; }
body.woocommerce-cart table.shop_table .product-name dl.variation dd:last-child::after { content: ''; }

/* Price columns */
body.woocommerce-cart table.shop_table .product-price,
body.woocommerce-cart table.shop_table .product-subtotal {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--sgcc-text, #111);
	white-space: nowrap;
}

body.woocommerce-cart table.shop_table .product-price {
	width: 110px;
}

body.woocommerce-cart table.shop_table .product-quantity {
	width: 98px;
}

body.woocommerce-cart table.shop_table .product-subtotal {
	width: 118px;
}

body.woocommerce-cart table.shop_table .product-subtotal {
	font-weight: 700;
}

/* Remove button */
body.woocommerce-cart table.shop_table .product-remove {
	width: 44px;
	text-align: center;
	padding-left: 4px;
	padding-right: 4px;
}

body.woocommerce-cart table.shop_table .product-remove a.remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: transparent;
	color: var(--sgcc-muted, #aaa) !important;
	font-size: 1.25rem;
	line-height: 1;
	text-decoration: none;
	border: 1px solid var(--sgcc-border, #e5e5e5);
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

body.woocommerce-cart table.shop_table .product-remove a.remove:hover {
	background: #fee2e2;
	color: #dc2626 !important;
	border-color: #fca5a5;
}

/* ── Quantity stepper ───────────────────────────────────────── */
body.woocommerce-cart .quantity .qty {
	width: 60px;
	height: 40px;
	border: 1px solid var(--sgcc-input-border, #d1d5db);
	border-radius: var(--sgcc-inp-radius, 4px);
	background: var(--sgcc-input-bg, #fff);
	color: var(--sgcc-text, #111);
	font-size: 0.9rem;
	font-family: inherit;
	text-align: center;
	padding: 4px 8px;
	-moz-appearance: textfield;
	appearance: textfield;
	transition: border-color 0.15s;
}

body.woocommerce-cart .quantity .qty::-webkit-outer-spin-button,
body.woocommerce-cart .quantity .qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

body.woocommerce-cart .quantity .qty:focus {
	outline: none;
	border-color: var(--sgcc-input-focus, #111);
	box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.08);
}

/* ── Cart actions row (coupon + update) ─────────────────────── */
body.woocommerce-cart .actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	padding-top: 20px;
	border-top: 1px solid var(--sgcc-border, #e5e5e5);
	margin-top: 4px;
}

body.woocommerce-cart .coupon {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	flex: 1 1 auto;
	min-width: 260px;
}

body.woocommerce-cart .coupon label { display: none; }

body.woocommerce-cart .coupon #coupon_code {
	height: 40px;
	padding: 0 14px;
	border: 1px solid var(--sgcc-input-border, #d1d5db);
	border-radius: var(--sgcc-inp-radius, 4px);
	background: var(--sgcc-input-bg, #fff);
	color: var(--sgcc-input-text, #111);
	font-size: var(--sgcc-input-size, 0.9375rem);
	font-family: inherit;
	width: 240px;
	max-width: 100%;
	transition: border-color 0.15s;
}

body.woocommerce-cart .coupon .input-text {
	width: 240px !important;
	max-width: 100%;
}

body.woocommerce-cart .coupon #coupon_code::placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af);
	opacity: 1;
}

body.woocommerce-cart .coupon #coupon_code::-webkit-input-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af);
	opacity: 1;
}

body.woocommerce-cart .coupon #coupon_code::-moz-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af);
	opacity: 1;
}

body.woocommerce-cart .coupon #coupon_code:-ms-input-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af);
}

body.woocommerce-cart .coupon #coupon_code:focus {
	outline: none;
	border-color: var(--sgcc-input-focus, #111);
}

body.woocommerce-cart .coupon .button,
body.woocommerce-cart .actions button[name="update_cart"] {
	height: 40px;
	padding: 0 18px;
	min-width: 148px;
	font-size: var(--sgcc-button-size, 0.9375rem);
	font-family: inherit;
	font-weight: 500;
	border: 1px solid var(--sgcc-border, #ccc);
	border-radius: var(--sgcc-btn-radius, 4px);
	background: transparent;
	color: var(--sgcc-text, #111);
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
	line-height: 1;
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

body.woocommerce-cart .actions button[name="update_cart"] {
	margin-left: auto;
	float: none !important;
	clear: none !important;
}

body.woocommerce-cart .actions button[name="update_cart"][disabled],
body.woocommerce-cart .actions button[name="update_cart"].disabled,
body.woocommerce-cart .actions button[name="update_cart"]:disabled {
	opacity: 0.65;
	cursor: not-allowed;
	background: var(--sgcc-surface, #f9f9fb);
	color: var(--sgcc-muted, #717171);
	border-color: var(--sgcc-border, #d1d5db);
}

body.woocommerce-cart .coupon .button:hover,
body.woocommerce-cart .actions button[name="update_cart"]:hover {
	background: var(--sgcc-surface, #f9f9fb);
	border-color: var(--sgcc-text, #111);
}

/* ── Cart totals / order summary ────────────────────────────── */
body.woocommerce-cart .cart-collaterals {
	display: contents !important;
	grid-template-columns: minmax(0, 1fr) minmax(300px, var(--sgcc-sum-width, 380px));
	gap: 0 48px;
	background: transparent;
	border: none;
	padding: 0;
}

body.woocommerce-cart .cart-collaterals > * {
	width: 100%;
	float: none;
	margin: 0;
}

/* Override WooCommerce default 48% float split in cart collaterals */
body.woocommerce-cart main.site-main .woocommerce .cart-collaterals .cross-sells,
body.woocommerce-cart main.site-main .woocommerce-page .cart-collaterals .cross-sells,
body.woocommerce-cart main.site-main .woocommerce .cart-collaterals .cart_totals,
body.woocommerce-cart main.site-main .woocommerce-page .cart-collaterals .cart_totals {
	width: 100% !important;
	float: none !important;
	clear: both;
	margin: 0 !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals {
	grid-column: 2;
	grid-row: 2;
	position: sticky;
	top: 90px;
	background: var(--sgcc-summary-bg, #f9f9fb);
	border: 1px solid var(--sgcc-border, #e5e5e5);
	border-radius: var(--sgcc-radius, 8px);
	padding: 24px;
}

body.woocommerce-cart .cart-collaterals > .cross-sells,
body.woocommerce-cart .cart-collaterals > :not(.cart_totals):not(.cross-sells) {
	grid-column: 1;
	grid-row: 3;
	background: var(--sgcc-surface, #f9f9fb);
	border: 1px solid var(--sgcc-border, #e5e5e5);
	border-radius: var(--sgcc-radius, 8px);
	padding: 16px;
}

body.woocommerce-cart .cart_totals h2 {
	font-size: 1.05rem;
	font-weight: 700;
	margin: 0 0 18px;
	color: var(--sgcc-text, #111);
	font-family: var(--sgcc-heading-font, var(--sgcc-font, inherit));
}

body.woocommerce-cart .cart_totals table.shop_table {
	border: none !important;
	width: 100%;
	margin-bottom: 16px;
}

body.woocommerce-cart .cart_totals table.shop_table th,
body.woocommerce-cart .cart_totals table.shop_table td {
	padding: 8px 0 !important;
	border: none !important;
	background: transparent !important;
	font-size: 0.9rem;
}

body.woocommerce-cart .cart_totals table.shop_table th {
	font-weight: 500;
	color: var(--sgcc-label, #555555);
	width: 50%;
}

body.woocommerce-cart .cart_totals .order-total th,
body.woocommerce-cart .cart_totals .order-total td {
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: var(--sgcc-text, #111) !important;
	padding-top: 14px !important;
	border-top: 1px solid var(--sgcc-border, #e5e5e5) !important;
}

/* Checkout button in cart */
body.woocommerce-cart .wc-proceed-to-checkout {
	padding: 4px 0 0;
	margin-top: 4px;
}

body.woocommerce-cart a.checkout-button,
body.woocommerce-cart a.checkout-button.button {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	background: var(--sgcc-accent, #111) !important;
	color: var(--sgcc-accent-text, #fff) !important;
	border: none !important;
	border-radius: var(--sgcc-btn-radius, 4px) !important;
	padding: 14px 24px !important;
	font-size: 0.9375rem !important;
	font-weight: 700 !important;
	font-family: var(--sgcc-font, inherit) !important;
	text-decoration: none !important;
	cursor: pointer;
	transition: background 0.2s;
	letter-spacing: 0.01em;
	box-shadow: 0 1px 6px rgba(0, 0, 0, 0.14);
}

body.woocommerce-cart a.checkout-button:hover {
	background: var(--sgcc-accent-hover, #333) !important;
}

/* Shipping calculator */
body.woocommerce-cart .woocommerce-shipping-calculator { margin-bottom: 8px; }

body.woocommerce-cart .woocommerce-shipping-calculator .shipping-calculator-button {
	font-size: 0.82rem;
	color: var(--sgcc-accent, #111);
	text-decoration: underline;
	text-underline-offset: 2px;
	cursor: pointer;
	background: none;
	border: none;
	padding: 0;
	font-family: inherit;
}

/* ── Checkout breadcrumb (Shopify-style steps) ──────────────── */
.shopgen-checkout-breadcrumb {
	padding: 0;
}

.shopgen-checkout-breadcrumb__list {
	display: flex;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 6px;
	font-size: 0.82rem;
	flex-wrap: wrap;
}

.shopgen-checkout-breadcrumb__list li {
	display: flex;
	align-items: center;
	gap: 6px;
	color: var(--sgcc-muted, #aaa);
}

.shopgen-checkout-breadcrumb__list li a {
	color: var(--sgcc-muted, #aaa);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.shopgen-checkout-breadcrumb__list li.is-done a {
	color: var(--sgcc-accent, #111);
}

.shopgen-checkout-breadcrumb__list li.is-done a:hover {
	color: var(--sgcc-accent-hover, #333);
}

.shopgen-checkout-breadcrumb__list li.is-active span {
	color: var(--sgcc-text, #111);
	font-weight: 600;
}

.shopgen-checkout-breadcrumb__sep {
	color: var(--sgcc-border, #ccc);
	flex-shrink: 0;
}

/* ── Checkout page layout ───────────────────────────────────── */
body.woocommerce-checkout main.site-main .woocommerce {
	padding-top: 4px;
}

/* 2-column Shopify-style checkout grid.
   After PHP rewiring the direct grid children are:
     col-1 row-1  → #customer_details  (billing + shipping stacked)
     col-2 rows-1+→ #order_review      (sticky order summary)
     col-1 row-2  → .shopgen-checkout-coupon-wrap  (coupon field)
     col-1 row-3  → #payment           (payment methods + place order)
   The WC default h3#order_review_heading is hidden (we use our own inside #order_review).
*/
body.woocommerce-checkout form.checkout {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
	gap: 0 48px !important;
	align-items: start !important;
}

/* Column 1: billing/shipping details ─── row 1 */
body.woocommerce-checkout form.checkout #customer_details {
	grid-column: 1 !important;
	grid-row: 1 !important;
	min-width: 0;
	background: var(--sgcc-checkout-left-bg, #ffffff);
}

/* Override WooCommerce's default float-based col-1 / col-2 inside #customer_details
   so billing and shipping stack vertically (full-width blocks) */
body.woocommerce-checkout form.checkout #customer_details::before,
body.woocommerce-checkout form.checkout #customer_details::after {
	display: none !important;
}

body.woocommerce-checkout form.checkout #customer_details .col-1,
body.woocommerce-checkout form.checkout #customer_details .col-2 {
	float: none !important;
	width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
	box-sizing: border-box;
}

body.woocommerce-checkout form.checkout #customer_details .col-2 {
	margin-top: 8px !important;
}

/* Hide WC's default order review heading — our PHP injects one inside #order_review */
body.woocommerce-checkout form.checkout h3#order_review_heading {
	display: none !important;
}

/* Column 2: order review (sticky) */
body.woocommerce-checkout form.checkout #order_review {
	grid-column: 2 !important;
	grid-row: 1 !important;
	position: sticky !important;
	top: 90px !important;
	min-width: 0;
	width: 100%;
}

/* ── Checkout section headings ──────────────────────────────── */
body.woocommerce-checkout .woocommerce-billing-fields > h3,
body.woocommerce-checkout .woocommerce-shipping-fields > h3,
body.woocommerce-checkout .woocommerce-additional-fields > h3 {
	font-size: var(--sgcc-heading-size, 1.05rem);
	font-weight: 700;
	color: var(--sgcc-text, #111);
	margin: 0 0 20px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
	font-family: var(--sgcc-heading-font, var(--sgcc-font, inherit));
}

/* "Ship to a different address?" — heading with inline checkbox
   Reset to a clean toggle row */
body.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address {
	display: flex !important;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	margin: 0 0 20px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
}

body.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address label {
	font-size: var(--sgcc-heading-size, 1.05rem);
	font-weight: 700;
	color: var(--sgcc-text, #111);
	margin: 0;
	cursor: pointer;
	font-family: var(--sgcc-heading-font, var(--sgcc-font, inherit));
	display: inline !important;
}

body.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address input[type="checkbox"] {
	width: 18px;
	height: 18px;
	order: 2;
	flex-shrink: 0;
	cursor: pointer;
	accent-color: var(--sgcc-accent, #111);
}

/* Additional / order notes heading only shows when notes field is present */
body.woocommerce-checkout .woocommerce-additional-fields > h3 {
	margin-top: 20px;
}

/* ── Checkout form inputs ───────────────────────────────────── */
body.woocommerce-checkout .form-row {
	margin: 0 0 14px !important;
	padding: 0 !important;
}

body.woocommerce-checkout form.checkout .form-row label,
body.woocommerce-checkout form.checkout .form-row label.required_field {
	display: block;
	font-size: var(--sgcc-label-size, 0.82rem) !important;
	font-weight: 500;
	color: var(--sgcc-label, #555555) !important;
	margin-bottom: 5px;
	text-transform: none;
	letter-spacing: 0;
}

/* Placeholder-mode checkout fields: hide visual labels for input/select/textarea rows */
body.woocommerce-checkout form.checkout .woocommerce-billing-fields .form-row > label,
body.woocommerce-checkout form.checkout .woocommerce-shipping-fields .form-row > label,
body.woocommerce-checkout form.checkout .woocommerce-additional-fields .form-row > label {
	display: none !important;
}

body.woocommerce-checkout .form-row label .required {
	color: #dc2626;
	font-weight: 700;
}

body.woocommerce-checkout .woocommerce-input-wrapper input[type="text"],
body.woocommerce-checkout .woocommerce-input-wrapper input[type="email"],
body.woocommerce-checkout .woocommerce-input-wrapper input[type="tel"],
body.woocommerce-checkout .woocommerce-input-wrapper input[type="password"],
body.woocommerce-checkout .woocommerce-input-wrapper input[type="number"],
body.woocommerce-checkout .woocommerce-input-wrapper select,
body.woocommerce-checkout .woocommerce-input-wrapper textarea {
	height: 44px !important;
	line-height: 44px !important;
	border: 1px solid var(--sgcc-input-border, #d1d5db) !important;
	border-radius: var(--sgcc-inp-radius, 4px) !important;
	background: var(--sgcc-input-bg, #fff) !important;
	color: var(--sgcc-input-text, #111) !important;
	font-size: var(--sgcc-input-size, 0.9375rem) !important;
	font-family: var(--sgcc-font, inherit) !important;
	padding: 0 14px !important;
	width: 100% !important;
	box-sizing: border-box;
	transition: border-color 0.15s, box-shadow 0.15s;
	box-shadow: none !important;
	outline: none;
}

body.woocommerce-checkout .woocommerce-input-wrapper input::placeholder,
body.woocommerce-checkout .woocommerce-input-wrapper textarea::placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
	opacity: 1;
}

body.woocommerce-checkout .woocommerce-input-wrapper input::-webkit-input-placeholder,
body.woocommerce-checkout .woocommerce-input-wrapper textarea::-webkit-input-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
	opacity: 1;
}

body.woocommerce-checkout .woocommerce-input-wrapper input::-moz-placeholder,
body.woocommerce-checkout .woocommerce-input-wrapper textarea::-moz-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
	opacity: 1;
}

body.woocommerce-checkout .woocommerce-input-wrapper input:-ms-input-placeholder,
body.woocommerce-checkout .woocommerce-input-wrapper textarea:-ms-input-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
}

body.woocommerce-checkout .woocommerce-input-wrapper textarea {
	height: auto !important;
	line-height: 1.55 !important;
	padding: 12px 14px !important;
	min-height: 88px;
}

body.woocommerce-checkout .woocommerce-input-wrapper input:focus,
body.woocommerce-checkout .woocommerce-input-wrapper select:focus,
body.woocommerce-checkout .woocommerce-input-wrapper textarea:focus {
	border-color: var(--sgcc-input-focus, #111) !important;
	box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.08) !important;
}

body.woocommerce-checkout .woocommerce-input-wrapper input.input-text.valid {
	border-color: #16a34a !important;
}

body.woocommerce-checkout .woocommerce-input-wrapper input.input-text.invalid {
	border-color: #dc2626 !important;
}

/* Select2 */
body.woocommerce-checkout .select2-container--default .select2-selection--single {
	height: 44px !important;
	border: 1px solid var(--sgcc-input-border, #d1d5db) !important;
	border-radius: var(--sgcc-inp-radius, 4px) !important;
	background: var(--sgcc-input-bg, #fff) !important;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
	 
	padding-left: 14px !important;
	color: var(--sgcc-input-text, #111) !important;
	font-size: var(--sgcc-input-size, 0.9375rem) !important;
	font-family: var(--sgcc-font, inherit) !important;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 44px !important;
	right: 12px !important;
}

body.woocommerce-checkout .select2-container--focus .select2-selection--single {
	border-color: var(--sgcc-input-focus, #111) !important;
	box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.08) !important;
}

/* ── Order review (right column on checkout) ────────────────── */
body.woocommerce-checkout #order_review {
	background: var(--sgcc-summary-bg, #f9f9fb);
	border: 1px solid var(--sgcc-border, #e5e5e5);
	border-radius: var(--sgcc-radius, 8px);
	padding: 24px;
}

body.woocommerce-checkout #order_review_heading {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--sgcc-text, #111);
	margin: 0 0 16px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
	font-family: var(--sgcc-heading-font, var(--sgcc-font, inherit));
}

/* Custom heading injected by PHP inside #order_review */
body.woocommerce-checkout #order_review h3.shopgen-order-review-title {
	font-size: var(--sgcc-heading-size, 1.05rem);
	font-weight: 700;
	color: var(--sgcc-text, #111);
	margin: 0 0 16px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
	font-family: var(--sgcc-heading-font, var(--sgcc-font, inherit));
}

/* ── Product thumbnails in checkout order review ────────────── */
/* Item cell: flex row with thumbnail + name */
body.woocommerce-checkout .woocommerce-checkout-order-review span.shopgen-checkout-item-cell {
	display: flex;
	align-items: center;
	gap: 12px;
}

body.woocommerce-checkout .woocommerce-checkout-order-review span.shopgen-checkout-item-img {
	flex-shrink: 0;
	width: var(--sgcc-checkout-thumb-size, 28px);
}

body.woocommerce-checkout .woocommerce-checkout-order-review img.shopgen-checkout-thumb {
	width: var(--sgcc-checkout-thumb-size, 28px) !important;
	height: var(--sgcc-checkout-thumb-size, 28px) !important;
	object-fit: cover;
	border-radius: var(--sgcc-img-radius, 6px);
	border: 1px solid var(--sgcc-border, #e5e5e5);
	display: block;
}

/* Fallback: if WooCommerce/default markup prints product image directly in product-name cell */
body.woocommerce-checkout .woocommerce-checkout-review-order-table td.product-name img {
	width: var(--sgcc-checkout-thumb-size, 28px) !important;
	height: var(--sgcc-checkout-thumb-size, 28px) !important;
	object-fit: cover;
	border-radius: var(--sgcc-img-radius, 6px);
	border: 1px solid var(--sgcc-border, #e5e5e5);
	vertical-align: middle;
	margin-right: 10px;
}

body.woocommerce-checkout .woocommerce-checkout-order-review span.shopgen-checkout-item-name {
	flex: 1;
	min-width: 0;
	font-weight: 500;
	line-height: 1.4;
	color: var(--sgcc-text, #111);
}

/* ── Coupon field on checkout (below billing, above payment) ─── */
body.woocommerce-checkout .shopgen-checkout-coupon-wrap {
	border-top: 1px solid var(--sgcc-border, #e5e5e5);
	margin-top: 12px;
	padding-top: 14px;
	margin-bottom: 10px;
	background: var(--sgcc-checkout-coupon-bg, #ffffff);
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .woocommerce-form-coupon-toggle {
	font-size: 0.875rem;
	margin-bottom: 10px;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	background: transparent !important;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon p {
	margin: 0;
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	width: 100%;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon input#coupon_code {
	height: 40px !important;
	padding: 0 14px !important;
	border: 1px solid var(--sgcc-input-border, #d1d5db) !important;
	border-radius: var(--sgcc-inp-radius, 4px) !important;
	background: var(--sgcc-input-bg, #fff) !important;
	color: var(--sgcc-input-text, #111) !important;
	font-size: var(--sgcc-input-size, 0.9375rem) !important;
	font-family: var(--sgcc-font, inherit) !important;
	flex: 1;
	min-width: 140px;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon input#coupon_code::placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
	opacity: 1;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon input#coupon_code::-webkit-input-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
	opacity: 1;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon input#coupon_code::-moz-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
	opacity: 1;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon input#coupon_code:-ms-input-placeholder {
	color: var(--sgcc-input-placeholder, #9ca3af) !important;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon .button {
	height: 40px;
	padding: 0 18px;
	border: 1px solid var(--sgcc-border, #ccc);
	border-radius: var(--sgcc-btn-radius, 4px);
	background: transparent;
	color: var(--sgcc-text, #111);
	font-size: var(--sgcc-button-size, 0.9375rem);
	font-weight: 500;
	font-family: var(--sgcc-font, inherit);
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
	flex-shrink: 0;
}

body.woocommerce-checkout .shopgen-checkout-coupon-wrap .checkout_coupon .button:hover {
	background: var(--sgcc-surface, #f9f9fb);
	border-color: var(--sgcc-text, #111);
}

body.woocommerce-checkout .woocommerce-checkout-order-review table.shop_table {
	border: none !important;
	width: 100%;
	font-size: 0.875rem;
}

body.woocommerce-checkout .woocommerce-checkout-order-review table th,
body.woocommerce-checkout .woocommerce-checkout-order-review table td {
	padding: 8px 0 !important;
	border: none !important;
	background: transparent !important;
}

body.woocommerce-checkout .woocommerce-checkout-order-review table .cart_item td.product-name {
	font-weight: 500;
	color: var(--sgcc-text, #111);
}

body.woocommerce-checkout .woocommerce-checkout-order-review table .cart_item td.product-total {
	font-weight: 600;
	color: var(--sgcc-text, #111);
}

body.woocommerce-checkout .woocommerce-checkout-order-review table tfoot tr:not(.order-total) th,
body.woocommerce-checkout .woocommerce-checkout-order-review table tfoot tr:not(.order-total) td {
	color: var(--sgcc-muted, #717171);
}

body.woocommerce-checkout .woocommerce-checkout-order-review table .order-total th,
body.woocommerce-checkout .woocommerce-checkout-order-review table .order-total td {
	font-weight: 700 !important;
	font-size: 1rem !important;
	color: var(--sgcc-text, #111) !important;
	padding-top: 14px !important;
	border-top: 1px solid var(--sgcc-border, #e5e5e5) !important;
}

/* ── Payment section ─────────────────────────────────────────── */
body.woocommerce-checkout #payment {
	background: var(--sgcc-checkout-payment-bg, #ffffff);
	padding: 0;
	margin-top: 24px;
	border: none;
}

body.woocommerce-checkout #payment ul.wc_payment_methods {
	border: 1px solid var(--sgcc-border, #e5e5e5);
	border-radius: var(--sgcc-inp-radius, 4px) var(--sgcc-inp-radius, 4px) 0 0;
	padding: 0;
	margin: 0;
	list-style: none;
	background: var(--sgcc-checkout-payment-bg, #fff);
	overflow: hidden;
}

body.woocommerce-checkout #payment ul.wc_payment_methods li.wc_payment_method {
	border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
	padding: 14px 18px;
}

body.woocommerce-checkout #payment ul.wc_payment_methods li.wc_payment_method:last-child {
	border-bottom: none;
}

body.woocommerce-checkout #payment ul.wc_payment_methods li.wc_payment_method > label {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	font-size: var(--sgcc-label-size, 0.9rem) !important;
	font-weight: 600;
	color: var(--sgcc-label, #555555) !important;
	margin: 0;
}

body.woocommerce-checkout #payment div.payment_box {
	background: var(--sgcc-checkout-notice-bg, #f9f9fb);
	border-top: 1px solid var(--sgcc-border, #e5e5e5);
	padding: 14px 18px;
	font-size: 0.84rem;
	color: var(--sgcc-muted, #717171);
	margin: 0;
	border-radius: 0;
}

body.woocommerce-checkout #payment div.place-order {
	padding: 0;
	border: none;
	background: transparent;
}

body.woocommerce-checkout #payment #place_order {
	display: block !important;
	width: 100% !important;
	background: var(--sgcc-accent, #111) !important;
	color: var(--sgcc-accent-text, #fff) !important;
	border: none !important;
	border-radius: var(--sgcc-btn-radius, 4px) !important;
	padding: 16px 24px !important;
	font-size: var(--sgcc-button-size, 0.9375rem) !important;
	font-weight: 700 !important;
	font-family: var(--sgcc-font, inherit) !important;
	cursor: pointer;
	text-align: center !important;
	transition: background 0.2s;
	margin-top: 16px;
	letter-spacing: 0.01em;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.16);
}

body.woocommerce-checkout #payment #place_order:hover {
	background: var(--sgcc-accent-hover, #333) !important;
}

/* ── Inline notices / alerts ────────────────────────────────── */
body.woocommerce-cart .woocommerce-notices-wrapper,
body.woocommerce-checkout .woocommerce-notices-wrapper {
	margin-bottom: 20px;
}

body.woocommerce-cart .woocommerce-message,
body.woocommerce-checkout .woocommerce-message,
body.woocommerce-cart .woocommerce-error,
body.woocommerce-checkout .woocommerce-error,
body.woocommerce-cart .woocommerce-info,
body.woocommerce-checkout .woocommerce-info {
	padding: var(--sgcc-notice-padding, 1em 2em 1em 3.5em) !important;
	margin: 0 0 var(--sgcc-notice-margin-bottom, 2em) !important;
	position: relative;
	background-color: var(--sgcc-notice-bg, #f6f5f8) !important;
	color: var(--sgcc-notice-text, #515151) !important;
	border-top: 3px solid var(--sgcc-notice-info-border, #720eec) !important;
	list-style: none outside !important;
	width: auto;
	word-wrap: break-word;
	border-radius: var(--sgcc-notice-radius, var(--sgcc-radius, 4px)) !important;
	font-size: var(--sgcc-notice-font-size, 0.9rem) !important;
	font-family: var(--sgcc-font, inherit) !important;
}

body.woocommerce-cart .woocommerce-message,
body.woocommerce-checkout .woocommerce-message {
	border-top-color: var(--sgcc-notice-success-border, #0f9d58) !important;
}

body.woocommerce-cart .woocommerce-error,
body.woocommerce-checkout .woocommerce-error {
	border-top-color: var(--sgcc-notice-error-border, #d63638) !important;
}

body.woocommerce-cart .woocommerce-info,
body.woocommerce-checkout .woocommerce-info {
	border-top-color: var(--sgcc-notice-info-border, #720eec) !important;
}

/* ── Empty cart ─────────────────────────────────────────────── */
body.woocommerce-cart .cart-empty {
	font-size: 1rem;
	color: var(--sgcc-muted, #717171);
	padding: 48px 0;
	text-align: center;
}

body.woocommerce-cart .return-to-shop {
	text-align: center;
}

body.woocommerce-cart .return-to-shop .button {
	display: inline-block;
	background: var(--sgcc-accent, #111);
	color: var(--sgcc-accent-text, #fff) !important;
	border-radius: var(--sgcc-btn-radius, 4px);
	padding: 12px 28px;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	margin-top: 16px;
	transition: background 0.2s;
	font-family: var(--sgcc-font, inherit);
}

body.woocommerce-cart .return-to-shop .button:hover {
	background: var(--sgcc-accent-hover, #333) !important;
	color: var(--sgcc-accent-text, #fff) !important;
}

/* ── Checkout login reminder ────────────────────────────────── */
body.woocommerce-checkout .woocommerce-form-login-toggle,
body.woocommerce-checkout .woocommerce-form-login.login {
	font-size: 0.875rem;
	margin-bottom: 20px;
}

/* ── Responsive: tablet / small desktop ────────────────────── */
@media (max-width: 1024px) {
	body.woocommerce-cart main.site-main .woocommerce {
		grid-template-columns: 1fr;
		gap: 32px 0;
	}

	body.woocommerce-cart main.site-main .woocommerce > .cart-collaterals {
		grid-column: 1;
		display: block;
	}

	body.woocommerce-cart .cart-collaterals {
		display: block;
	}

	body.woocommerce-cart .cart-collaterals .cart_totals {
		position: static;
		margin-top: 24px;
	}

	body.woocommerce-cart .cart-collaterals > :not(.cart_totals) {
		margin-top: 16px;
	}

	body.woocommerce-cart .shopgen-cart-header {
		grid-column: 1;
	}

	body.woocommerce-checkout form.checkout {
		grid-template-columns: 1fr !important;
		gap: 0 !important;
	}

	body.woocommerce-checkout form.checkout #customer_details {
		grid-column: 1 !important;
		grid-row: auto !important;
	}

	body.woocommerce-checkout form.checkout #order_review {
		grid-column: 1 !important;
		grid-row: auto !important;
		position: static !important;
		order: 2;
		margin-top: 20px;
	}
}

/* ── Responsive: mobile ─────────────────────────────────────── */
@media (max-width: 767px) {
	body.woocommerce-cart main.site-main .entry-header,
	body.woocommerce-checkout main.site-main .entry-header {
		padding-left: 14px;
		padding-right: 14px;
	}

	body.woocommerce-cart main.site-main .woocommerce,
	body.woocommerce-checkout main.site-main .woocommerce {
		padding-left: 14px;
		padding-right: 14px;
	}

	.shopgen-cart-header {
		padding-top: 20px;
		flex-direction: column;
		align-items: flex-start;
		gap: 6px;
	}

	.shopgen-cart-header__title {
		font-size: 1.35rem;
	}

	/* Mobile cart: hide default thead, use CSS grid row layout instead */
	body.woocommerce-cart table.shop_table.cart thead {
		display: none;
	}

	body.woocommerce-cart table.shop_table.cart,
	body.woocommerce-cart table.shop_table.cart tbody,
	body.woocommerce-cart table.shop_table.cart tr {
		display: block;
		width: 100%;
	}

	body.woocommerce-cart table.shop_table.cart tbody tr {
		display: grid;
		grid-template-columns: 90px 1fr 36px;
		grid-template-areas:
			"img name  remove"
			"img price  price"
			"img qty    subtotal";
		gap: 0 12px;
		padding: 18px 0;
		border-bottom: 1px solid var(--sgcc-border, #e5e5e5);
	}

	body.woocommerce-cart table.shop_table.cart tbody td {
		padding: 3px 0 !important;
		border: none !important;
	}

	body.woocommerce-cart table.shop_table.cart .product-thumbnail { grid-area: img; width: 80px; }
	body.woocommerce-cart table.shop_table.cart .product-name     { grid-area: name; font-size: 0.9rem; }
	body.woocommerce-cart table.shop_table.cart .product-remove   { grid-area: remove; width: auto; }
	body.woocommerce-cart table.shop_table.cart .product-price    { grid-area: price; font-size: 0.84rem; }
	body.woocommerce-cart table.shop_table.cart .product-quantity { grid-area: qty; }
	body.woocommerce-cart table.shop_table.cart .product-subtotal { grid-area: subtotal; font-size: 0.9rem; text-align: right; }

	body.woocommerce-cart .actions {
		flex-direction: column;
		gap: 10px;
		align-items: flex-start;
	}

	body.woocommerce-cart .coupon {
		width: 100%;
		min-width: 0;
	}

	body.woocommerce-cart .coupon #coupon_code {
		flex: 1;
		width: auto;
		min-width: 0;
	}

	body.woocommerce-cart .actions button[name="update_cart"] {
		margin-left: 0;
	}

	body.woocommerce-checkout .form-row-first,
	body.woocommerce-checkout .form-row-last {
		width: 100% !important;
		float: none !important;
	}
}
