/* ==========================================================================
   LesnaMax - WooCommerce Style Overrides
   ========================================================================== */

/* --------------------------------------------------------------------------
   WooCommerce General
   -------------------------------------------------------------------------- */
.woocommerce-notices-wrapper,
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	margin-bottom: var(--space-lg);
	padding: var(--space-md) var(--space-lg);
	border-radius: var(--radius-md);
	font-size: var(--font-size-base);
}

.woocommerce-message {
	background-color: #e8f5e9;
	border-left: 4px solid var(--color-success);
	color: #2e7d32;
}

.woocommerce-info {
	background-color: #e3f2fd;
	border-left: 4px solid var(--color-primary);
	color: #1565c0;
}

.woocommerce-error {
	background-color: #fbe9e7;
	border-left: 4px solid var(--color-error);
	color: #c62828;
}

.woocommerce-error li {
	list-style: none;
}

/* --------------------------------------------------------------------------
   WooCommerce Buttons
   -------------------------------------------------------------------------- */
.woocommerce .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: 10px 24px;
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	font-family: var(--font-primary);
	line-height: 1.4;
	border-radius: 0;
	transition: all var(--transition-base);
	cursor: pointer;
	border: 2px solid transparent;
	background-color: var(--color-primary);
	color: var(--color-white);
}

.woocommerce .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
	background-color: var(--color-primary-dark);
	color: var(--color-white);
}

.woocommerce .button:disabled,
.woocommerce button.button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* --------------------------------------------------------------------------
   WooCommerce Forms
   -------------------------------------------------------------------------- */
.woocommerce form .form-row {
	margin-bottom: var(--space-md);
}

.woocommerce form .form-row label {
	display: block;
	margin-bottom: var(--space-xs);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	width: 100%;
	padding: 10px 16px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	color: var(--color-text);
	background-color: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: 0;
	transition: border-color var(--transition-fast);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

/* --------------------------------------------------------------------------
   Cart Page
   -------------------------------------------------------------------------- */
.woocommerce-cart .woocommerce {
	padding: var(--space-xl) 0 var(--space-2xl);
	max-width: var(--container-width);
	margin: 0 auto;
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

.woocommerce table.shop_table {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.woocommerce table.shop_table th {
	padding: var(--space-md) var(--space-lg);
	text-align: left;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
	background-color: var(--color-bg-light);
	border-bottom: 1px solid var(--color-border);
	text-transform: uppercase;
	letter-spacing: 0.3px;
}

.woocommerce table.shop_table td {
	padding: var(--space-md) var(--space-lg);
	vertical-align: middle;
	border-bottom: 1px solid var(--color-border-light);
	font-size: var(--font-size-base);
}

/* Cart product thumbnail */
.woocommerce table.shop_table img {
	width: 80px;
	height: 80px;
	object-fit: contain;
	border-radius: var(--radius-sm);
	background-color: var(--color-bg-light);
	padding: 4px;
}

/* Cart product name */
.woocommerce-cart table.shop_table .product-name a {
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
	transition: color var(--transition-fast);
}

.woocommerce-cart table.shop_table .product-name a:hover {
	color: var(--color-primary);
}

/* Cart remove item link */
.woocommerce-cart table.shop_table .product-remove a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: var(--radius-full);
	color: var(--color-text-muted);
	font-size: var(--font-size-lg);
	transition: all var(--transition-fast);
}

.woocommerce-cart table.shop_table .product-remove a:hover {
	background-color: var(--color-error);
	color: var(--color-white);
}

/* Cart quantity input */
.woocommerce-cart table.shop_table .quantity .qty {
	width: 60px;
	padding: 6px 8px;
	text-align: center;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	border: 1px solid var(--color-border);
	border-radius: 0;
	color: var(--color-text);
	background-color: var(--color-bg);
}

.woocommerce-cart table.shop_table .quantity .qty:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

/* Cart coupon row */
.woocommerce-cart table.shop_table td.actions {
	padding: var(--space-lg);
}

.woocommerce-cart .coupon {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
}

.woocommerce-cart .coupon label {
	display: none;
}

.woocommerce-cart .coupon .input-text {
	padding: 8px 14px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	border: 1px solid var(--color-border);
	border-radius: 0;
	color: var(--color-text);
	min-width: 200px;
}

.woocommerce-cart .coupon .input-text:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

/* Update cart button - outline style */
.woocommerce-cart table.shop_table .actions > .button {
	background-color: transparent;
	color: var(--color-dark);
	border: 2px solid var(--color-border);
}

.woocommerce-cart table.shop_table .actions > .button:hover {
	border-color: var(--color-dark);
	background-color: var(--color-dark);
	color: var(--color-white);
}

/* Cart totals */
.woocommerce .cart_totals {
	max-width: 420px;
	margin-left: auto;
	margin-top: var(--space-xl);
}

.woocommerce .cart_totals h2 {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border-light);
}

.woocommerce .cart_totals table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--space-lg);
}

.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
	padding: var(--space-md);
	border-bottom: 1px solid var(--color-border-light);
	font-size: var(--font-size-base);
}

.woocommerce .cart_totals table th {
	text-align: left;
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
}

.woocommerce .cart_totals table td {
	text-align: right;
}

.woocommerce .cart_totals table tr.order-total th,
.woocommerce .cart_totals table tr.order-total td {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
	border-top: 2px solid var(--color-dark);
	border-bottom: none;
}

/* Proceed to checkout button */
.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 14px 32px;
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-bold);
	background-color: var(--color-primary);
	color: var(--color-white);
	border: none;
	border-radius: 0;
	transition: background-color var(--transition-fast);
}

.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button:hover {
	background-color: var(--color-primary-dark);
	color: var(--color-white);
}

/* --------------------------------------------------------------------------
   Cart Page - Block-Based Cart (WooCommerce 8+)
   -------------------------------------------------------------------------- */

/* Page-level spacing for cart */
.woocommerce-cart .site-main {
	padding-top: var(--space-2xl);
	padding-bottom: var(--space-2xl);
}

/* Container: match header width */
.wc-block-cart,
.wp-block-woocommerce-cart {
	max-width: var(--container-width);
	margin: 0 auto;
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

/* Two-column layout: items + totals sidebar */
.wc-block-cart .wc-block-cart__main {
	flex: 1;
	min-width: 0;
}

/* Cart items table */
.wc-block-cart-items {
	width: 100%;
	border-collapse: collapse;
}

/* Table header */
.wc-block-cart-items .wc-block-cart-items__header {
	border-bottom: 2px solid var(--color-dark);
}

.wc-block-cart-items .wc-block-cart-items__header th {
	padding: var(--space-sm) 0;
	text-align: left;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-bold);
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.8px;
	background: transparent;
	border: none;
}

.wc-block-cart-items .wc-block-cart-items__header-total {
	text-align: right;
}

/* Cart item rows */
.wc-block-cart-items .wc-block-cart-items__row {
	border-bottom: 1px solid var(--color-border-light);
}

.wc-block-cart-items .wc-block-cart-items__row td {
	padding: var(--space-md) 0;
	vertical-align: top;
}

/* Product image cell */
.wc-block-cart-items .wc-block-cart-item__image {
	width: 100px;
	padding-right: var(--space-lg) !important;
}

.wc-block-cart-items .wc-block-cart-item__image a {
	display: block;
}

.wc-block-cart-items .wc-block-cart-item__image img {
	width: 100px;
	height: 100px;
	object-fit: contain;
	background-color: var(--color-white);
	border: 1px solid var(--color-border-light);
	padding: 6px;
	border-radius: 0;
}

/* Product details cell */
.wc-block-cart-item__product {
	vertical-align: top !important;
}

.wc-block-cart-item__wrap {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

/* Product name */
.wc-block-cart .wc-block-components-product-name {
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-medium);
	color: var(--color-dark);
	text-decoration: none;
	transition: color var(--transition-fast);
	line-height: 1;
}

.wc-block-cart .wc-block-components-product-name:hover {
	color: var(--color-primary);
}

/* Unit price */
.wc-block-cart .wc-block-cart-item__prices {
	margin-top: 0;
}

.wc-block-cart .wc-block-cart-item__prices .wc-block-components-product-price {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	color: var(--color-text-light);
	line-height: 0.3;
}

/* Product metadata (variations, etc.) */
.wc-block-cart .wc-block-components-product-metadata {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-top: 0;
}

.wc-block-cart .wc-block-components-product-metadata:empty {
	display: none;
}

/* Quantity + remove wrapper */
.wc-block-cart-item__quantity {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	margin-top: 0px;
}

/* Quantity selector */
.wc-block-cart .wc-block-components-quantity-selector {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--color-border);
	border-radius: 0;
	overflow: hidden;
}

.wc-block-cart .wc-block-components-quantity-selector__button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: transparent;
	border: none;
	font-size: var(--font-size-md);
	color: var(--color-text);
	cursor: pointer;
	transition: all var(--transition-fast);
	padding: 0;
	line-height: 1;
}

.wc-block-cart .wc-block-components-quantity-selector__button:hover {
	background-color: var(--color-dark);
	color: var(--color-white);
}

.wc-block-cart .wc-block-components-quantity-selector__button:disabled {
	color: var(--color-border);
	cursor: default;
}

.wc-block-cart .wc-block-components-quantity-selector__button:disabled:hover {
	background: transparent;
	color: var(--color-border);
}

.wc-block-cart .wc-block-components-quantity-selector__input {
	width: 44px;
	height: 36px;
	text-align: center;
	border: none;
	border-left: 1px solid var(--color-border);
	border-right: 1px solid var(--color-border);
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	font-weight: var(--font-weight-medium);
	color: var(--color-dark);
	background: transparent;
	-moz-appearance: textfield;
	appearance: textfield;
}

.wc-block-cart .wc-block-components-quantity-selector__input::-webkit-inner-spin-button,
.wc-block-cart .wc-block-components-quantity-selector__input::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Remove item link */
.wc-block-cart .wc-block-cart-item__remove-link {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	transition: color var(--transition-fast);
	background: none;
	border: none;
	cursor: pointer;
	text-decoration: none;
	padding: 0;
}

.wc-block-cart .wc-block-cart-item__remove-link:hover {
	color: var(--color-error);
}

/* Total price cell */
.wc-block-cart-item__total {
	text-align: right !important;
	vertical-align: top !important;
}

.wc-block-cart-item__total .wc-block-components-product-price {
	font-size: var(--font-size-md) !important;
	font-weight: var(--font-weight-bold) !important;
	color: var(--color-dark) !important;
}

/* Cart sidebar (totals) */
.wc-block-cart .wc-block-cart__sidebar {
	min-width: 320px;
	max-width: 420px;
}

.wc-block-cart__totals-title {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border-light);
}

/* Totals rows */
.wc-block-components-totals-wrapper {
	border-top: 0px !important;
	border-bottom: 1px solid var(--color-border-light);
}

.wc-block-components-totals-item {
	padding: var(--space-md) 0;
	display: flex;
	justify-content: space-between;
	font-size: var(--font-size-base);
}

.wc-block-components-totals-item__label {
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
}

.wc-block-components-totals-item__value {
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

/* Total row - prominent */
.wc-block-components-totals-footer-item {
	padding: var(--space-md) 0;
	font-size: var(--font-size-lg);
	border-top: 0px !important;
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

/* Proceed to checkout button */
.wc-block-cart__submit-button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 14px 32px;
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-bold);
	font-family: var(--font-primary);
	background-color: var(--color-primary);
	color: var(--color-white);
	border: none;
	border-radius: 0;
	cursor: pointer;
	transition: background-color var(--transition-fast);
	margin-top: var(--space-md);
}

.wc-block-cart__submit-button:hover {
	background-color: var(--color-primary-dark);
	color: var(--color-white);
}

/* Coupon/discount section - always open */
.wc-block-components-totals-coupon {
	border-bottom: none;
	padding: var(--space-md) 0;
}

/* Remove border from the wrapper around coupon */
.wc-block-components-totals-wrapper:has(.wc-block-components-totals-coupon) {
	border-bottom: none;
}

/* Hide the panel toggle button ("Add coupons" accordion trigger) */
.wc-block-components-totals-coupon > .wc-block-components-panel__button {
	display: none !important;
}

/* Keep coupon panel content always visible */
.wc-block-components-totals-coupon .wc-block-components-panel__content {
	display: block !important;
	height: auto !important;
	overflow: visible !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.wc-block-components-totals-coupon__content .wc-block-components-text-input input {
	padding: 8px 14px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	border: 1px solid var(--color-border);
	border-radius: 0 !important;
	color: var(--color-text);
}

.wc-block-components-totals-coupon__content .wc-block-components-text-input {
	border-radius: 0 !important;
}

.wc-block-components-totals-coupon__content .wc-block-components-text-input input:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

/* Apply coupon button - black bg, white text */
.wc-block-components-totals-coupon__content .wc-block-components-button.wc-block-components-totals-coupon__button {
	background-color: var(--color-dark) !important;
	color: var(--color-white) !important;
	border: none;
	border-radius: 0;
	padding: 8px 20px;
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	font-family: var(--font-primary);
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.wc-block-components-totals-coupon__content .wc-block-components-button.wc-block-components-totals-coupon__button:hover {
	background-color: var(--color-text) !important;
}

/* ==========================================================================
   Empty Cart Page
   ========================================================================== */

/*
 * DOM structure (WooCommerce block editor):
 *
 * .wp-block-woocommerce-cart.alignwide
 *   └─ .wp-block-woocommerce-empty-cart-block
 *        ├─ h2.with-empty-cart-icon.wc-block-cart__empty-cart__title
 *        ├─ [.lesnamax-empty-cart-button — injected via PHP]
 *        ├─ hr.is-style-dots
 *        ├─ h2 "New in store"
 *        └─ .wc-block-grid.wp-block-woocommerce-product-new
 */

/* Empty cart block container */
.wp-block-woocommerce-empty-cart-block {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	text-align: center !important;
	padding: var(--space-2xl) var(--container-padding) 0 !important;
	max-width: var(--container-width) !important;
	margin: 0 auto !important;
}

/* Replace the WooCommerce sad-face icon on .with-empty-cart-icon::before */
.wp-block-woocommerce-empty-cart-block h2.with-empty-cart-icon::before {
	content: '' !important;
	display: block !important;
	width: 64px !important;
	height: 64px !important;
	margin: 0 auto var(--space-lg) !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b0b0b0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 2L3 6v14a2 2 0 002 2h14a2 2 0 002-2V6l-3-4z'/%3E%3Cline x1='3' y1='6' x2='21' y2='6'/%3E%3Cpath d='M16 10a4 4 0 01-8 0'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: contain !important;
	background-color: transparent !important;
	border-radius: 0 !important;
	font-size: 0 !important;
	color: transparent !important;
	-webkit-text-fill-color: transparent !important;
}

/* Title: "Your cart is currently empty!" */
.wp-block-woocommerce-empty-cart-block h2.wc-block-cart__empty-cart__title {
	font-size: var(--font-size-xl) !important;
	font-weight: var(--font-weight-bold) !important;
	color: var(--color-dark) !important;
	text-align: center !important;
	margin-bottom: var(--space-lg) !important;
	font-family: var(--font-primary) !important;
}

/* "Go to shop" button injected via PHP */
.lesnamax-empty-cart-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 36px;
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-bold);
	font-family: var(--font-primary);
	background-color: var(--color-primary);
	color: var(--color-white);
	border: none;
	border-radius: 0;
	text-decoration: none;
	cursor: pointer;
	transition: background-color var(--transition-fast);
	margin-bottom: var(--space-lg);
}

.lesnamax-empty-cart-button:hover {
	background-color: var(--color-primary-dark);
	color: var(--color-white);
}

/* Theme's product cards injected into empty cart via JS */
.lesnamax-empty-cart-products {
	width: 100%;
	padding-top: var(--space-lg);
	padding-bottom: var(--space-2xl);
	border-top: 1px solid var(--color-border-light);
	text-align: left;
}

.lesnamax-empty-cart-products__title {
	font-size: var(--font-size-lg) !important;
	font-weight: var(--font-weight-bold) !important;
	color: var(--color-dark) !important;
	text-align: center !important;
	margin-bottom: var(--space-lg) !important;
	font-family: var(--font-primary) !important;
}

/* The .products-grid and .product-card styles are inherited from style.css
   and responsive.css — no overrides needed since we use the real template. */

/* --------------------------------------------------------------------------
   Checkout Page
   -------------------------------------------------------------------------- */
.woocommerce-checkout .woocommerce {
	padding: var(--space-xl) 0 var(--space-2xl);
	max-width: var(--container-width);
	margin: 0 auto;
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

.woocommerce-checkout #customer_details {
	margin-bottom: var(--space-xl);
}

.woocommerce-checkout .col2-set {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-xl);
}

.woocommerce-checkout h3 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border-light);
}

#order_review_heading {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border-light);
}

/* Checkout form fields */
.woocommerce-checkout .form-row label {
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
	margin-bottom: var(--space-xs);
}

.woocommerce-checkout .form-row label .required {
	color: var(--color-error);
}

.woocommerce-checkout .form-row .input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
	width: 100%;
	padding: 10px 14px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	color: var(--color-text);
	background-color: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: 0;
	transition: border-color var(--transition-fast);
	appearance: none;
}

.woocommerce-checkout .form-row .input-text:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

.woocommerce-checkout .form-row select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	padding-right: 36px;
}

.woocommerce-checkout .form-row textarea {
	min-height: 80px;
	resize: vertical;
}

/* Two-column rows */
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
	width: 48%;
	float: left;
}

.woocommerce-checkout .form-row-last {
	float: right;
}

.woocommerce-checkout .form-row-wide {
	clear: both;
}

/* Order review table */
.woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--space-lg);
}

.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
	padding: var(--space-md);
	text-align: left;
	border-bottom: 1px solid var(--color-border-light);
	font-size: var(--font-size-base);
}

.woocommerce-checkout-review-order-table thead th {
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
	background-color: var(--color-bg-light);
	font-size: var(--font-size-sm);
	text-transform: uppercase;
	letter-spacing: 0.3px;
}

.woocommerce-checkout-review-order-table .cart_item td {
	vertical-align: middle;
}

.woocommerce-checkout-review-order-table .product-name {
	font-weight: var(--font-weight-medium);
}

.woocommerce-checkout-review-order-table .product-name .product-quantity {
	color: var(--color-text-muted);
	font-weight: var(--font-weight-normal);
}

.woocommerce-checkout-review-order-table tfoot th {
	font-weight: var(--font-weight-medium);
}

.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
	border-top: 2px solid var(--color-dark);
}

/* Payment section */
.woocommerce #payment {
	background: var(--color-bg-light);
	padding: var(--space-xl);
	border-radius: 0;
}

.woocommerce #payment .payment_methods {
	margin-bottom: var(--space-lg);
	list-style: none;
	padding: 0;
}

.woocommerce #payment .payment_methods li {
	padding: var(--space-md);
	margin-bottom: var(--space-sm);
	border: 1px solid var(--color-border);
	border-radius: 0;
	background: var(--color-bg);
}

.woocommerce #payment .payment_methods li label {
	font-weight: var(--font-weight-medium);
	cursor: pointer;
}

.woocommerce #payment .payment_box {
	padding: var(--space-md);
	margin-top: var(--space-sm);
	background: var(--color-bg-light);
	border-radius: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

.woocommerce #payment #place_order {
	width: 100%;
	padding: 14px 32px;
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-bold);
	margin-top: var(--space-md);
}

/* Checkout privacy and terms */
.woocommerce-terms-and-conditions-wrapper {
	margin-bottom: var(--space-md);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

.woocommerce-privacy-policy-text {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-bottom: var(--space-md);
}

.woocommerce-privacy-policy-text a {
	color: var(--color-primary);
}

/* Checkout coupon */
.woocommerce-checkout .checkout_coupon {
	display: flex;
	gap: var(--space-sm);
	margin-bottom: var(--space-xl);
	padding: var(--space-lg);
	background: var(--color-bg-light);
	border-radius: var(--radius-md);
}

.woocommerce-checkout .checkout_coupon .input-text {
	flex: 1;
}

/* Login form on checkout */
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info {
	margin-bottom: var(--space-md);
}

.woocommerce-checkout .login {
	padding: var(--space-lg);
	background: var(--color-bg-light);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-xl);
}

/* Select2 dropdown styling (WooCommerce uses it for country/state) */
.select2-container--default .select2-selection--single {
	height: 42px;
	border: 1px solid var(--color-border);
	border-radius: 0;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: 42px;
	padding-left: 14px;
	color: var(--color-text);
	font-size: var(--font-size-base);
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 40px;
}

.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
}

.select2-dropdown {
	border-color: var(--color-border);
	border-radius: 0;
}

.select2-results__option--highlighted[aria-selected] {
	background-color: var(--color-primary) !important;
}

/* --------------------------------------------------------------------------
   Checkout Page - Block-Based Checkout (WooCommerce 8+)
   -------------------------------------------------------------------------- */

/* 1. Page-level spacing & container */
.woocommerce-checkout .site-main {
	padding-top: var(--space-2xl);
	padding-bottom: var(--space-2xl);
}

.wp-block-woocommerce-checkout,
.wc-block-checkout {
	max-width: var(--container-width);
	margin: 0 auto;
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

.woocommerce-checkout .wp-block-woocommerce-checkout.alignwide {
	margin-left: 0;
	margin-right: 0;
}

/* Hide the default block page title if theme already shows one */
.woocommerce-checkout .wp-block-woocommerce-checkout .with-scroll-to-top__scroll-point + * h1 {
	display: none;
}

/* 2. Two-column layout */
.wc-block-checkout .wc-block-checkout__main {
	flex: 1;
	min-width: 0;
}

.wc-block-checkout .wc-block-checkout__sidebar {
	min-width: 320px;
	max-width: 420px;
}

/* 3. Section headings (checkout steps) */
.wc-block-checkout .wc-block-components-checkout-step {
	margin-bottom: var(--space-lg);
}

.wc-block-checkout .wc-block-components-checkout-step__heading {
	margin-bottom: var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border-light);
}

.wc-block-checkout .wc-block-components-checkout-step__title {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

.wc-block-checkout .wc-block-components-checkout-step__description {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-top: var(--space-xs);
}

/* Step number styling */
.wc-block-components-checkout-step--with-step-number .wc-block-components-checkout-step__container:after {
	color: var(--color-text-muted);
	font-weight: var(--font-weight-bold);
}

/* 4. Form inputs */
.wc-block-checkout .wc-block-components-text-input input,
.wc-block-checkout .wc-block-components-text-input textarea {
	width: 100%;
	padding: 12px 14px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	color: var(--color-text);
	border: 1px solid var(--color-border);
	border-radius: 0 !important;
	background-color: var(--color-white);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.wc-block-checkout .wc-block-components-text-input input:focus,
.wc-block-checkout .wc-block-components-text-input textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

.wc-block-checkout .wc-block-components-text-input label {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	font-family: var(--font-primary);
}

.wc-block-checkout .wc-block-components-text-input.is-active label {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
}

/* Validation error on inputs */
.wc-block-checkout .wc-block-components-text-input.has-error input {
	border-color: var(--color-error);
}

.wc-block-checkout .wc-block-components-text-input .wc-block-components-validation-error {
	font-size: var(--font-size-xs);
	color: var(--color-error);
	margin-top: var(--space-xs);
}

/* 5. Select dropdowns */
.wc-block-checkout .wc-block-components-combobox .wc-block-components-combobox-control input.components-combobox-control__input,
.wc-block-checkout .wc-blocks-components-select .wc-blocks-components-select__select {
	width: 100%;
	padding: 12px 40px 12px 14px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	color: var(--color-text);
	border: 1px solid var(--color-dark);
	border-radius: 0 !important;
	background-color: var(--color-white);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	appearance: none;
}

.wc-block-checkout .wc-block-components-address-form__country {
	margin-top: 10px !important;
}

.wc-block-checkout .wc-block-components-combobox .wc-block-components-combobox-control input:focus,
.wc-block-checkout .wc-blocks-components-select .wc-blocks-components-select__select:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

.wc-block-checkout .wc-blocks-components-select .wc-blocks-components-select__container {
	position: relative;
}

.wc-block-checkout .wc-blocks-components-select .wc-blocks-components-select__label {
	position: absolute;
	top: 4px;
	left: 14px;
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	pointer-events: none;
	z-index: 1;
}

.wc-block-checkout .wc-blocks-components-select .wc-blocks-components-select__select {
	padding-top: 22px;
	padding-bottom: 6px;
}

.wc-block-checkout .wc-blocks-components-select .wc-blocks-components-select__expand {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
	height: 20px;
	pointer-events: none;
	fill: var(--color-text-muted);
}

/* 6. Address card */
.wc-block-checkout .wc-block-components-address-card {
	background-color: var(--color-bg-light);
	border: 1px solid var(--color-border-light);
	padding: var(--space-md);
	border-radius: 0;
}

.wc-block-checkout .wc-block-components-address-card span {
	font-size: var(--font-size-base);
	color: var(--color-text);
}

.wc-block-checkout .wc-block-components-address-card__edit {
	font-size: var(--font-size-sm);
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.wc-block-checkout .wc-block-components-address-card__edit:hover {
	color: var(--color-primary-dark);
	text-decoration: underline;
}

/* 7. Checkboxes */
.wc-block-checkout .wc-block-components-checkbox .wc-block-components-checkbox__input[type="checkbox"] {
	border: 1px solid var(--color-border);
	border-radius: 0;
	width: 18px;
	height: 18px;
	transition: all var(--transition-fast);
}

.wc-block-checkout .wc-block-components-checkbox .wc-block-components-checkbox__input[type="checkbox"]:checked {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
}

.wc-block-checkout .wc-block-components-checkbox .wc-block-components-checkbox__input[type="checkbox"]:focus {
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

.wc-block-checkout .wc-block-components-checkbox .wc-block-components-checkbox__label {
	font-size: var(--font-size-base);
	color: var(--color-text);
	font-family: var(--font-primary);
}

/* 8. Payment section */
.wc-block-checkout .wc-block-components-radio-control__option {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm);
	padding: 14px 16px;
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	margin-bottom: var(--space-sm);
	border-radius: var(--radius-sm);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);
}

.wc-block-checkout .wc-block-components-radio-control__option:hover {
	border-color: var(--color-primary);
}

.wc-block-checkout .wc-block-components-radio-control__option:focus-within {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

.wc-block-checkout .wc-block-components-radio-control__option:has(input:checked) {
	border-color: var(--color-primary);
	box-shadow: inset 0 0 0 1px var(--color-primary);
	background-color: #f8fdff;
}

.wc-block-checkout .wc-block-components-radio-control__label {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	color: var(--color-dark);
	line-height: 1.35;
}

.wc-block-checkout .wc-block-components-radio-control__description {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-top: 6px;
	line-height: 1.45;
}

.wc-block-checkout .wc-block-components-radio-control__option-layout {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--space-sm);
	flex: 1;
	min-width: 0;
}

.wc-block-checkout .wc-block-components-radio-control__label-group {
	min-width: 0;
}

.wc-block-checkout .wc-block-components-radio-control__secondary-label,
.wc-block-checkout .wc-block-components-radio-control__option-layout > *:last-child {
	margin-left: auto;
	flex-shrink: 0;
	white-space: nowrap;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	font-weight: var(--font-weight-medium);
	text-align: right;
}

.wc-block-checkout .wc-block-components-radio-control__input {
	width: 20px;
	height: 20px;
	flex: 0 0 20px;
	margin: 1px 0 0;
	accent-color: var(--color-primary);
}

/* Payment notice banners */
.wc-block-checkout .wc-block-components-notice-banner {
	padding: var(--space-md);
	border-radius: 0;
	font-size: var(--font-size-sm);
	margin-bottom: var(--space-md);
}

.wc-block-checkout .wc-block-components-notice-banner.is-error {
	background-color: #fbe9e7;
	border-left: 4px solid var(--color-error);
	color: #c62828;
}

.wc-block-checkout .wc-block-components-notice-banner.is-success {
	background-color: #e8f5e9;
	border-left: 4px solid var(--color-success);
	color: #2e7d32;
}

.wc-block-checkout .wc-block-components-notice-banner.is-info {
	background-color: #e3f2fd;
	border-left: 4px solid var(--color-primary);
	color: #1565c0;
}

/* 9. Action buttons */
.wc-block-checkout .wc-block-checkout__actions_row {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	margin-top: var(--space-md);
}

.wc-block-checkout .wc-block-components-checkout-place-order-button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 14px 32px;
	font-size: var(--font-size-md);
	font-weight: var(--font-weight-bold);
	font-family: var(--font-primary);
	background-color: var(--color-primary) !important;
	color: var(--color-white) !important;
	border: none;
	border-radius: 0;
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.wc-block-checkout .wc-block-components-checkout-place-order-button:hover {
	background-color: var(--color-primary-dark) !important;
	color: var(--color-white) !important;
}

.wc-block-checkout .wc-block-components-checkout-place-order-button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.wc-block-checkout .wc-block-components-checkout-return-to-cart-button {
	display: none !important;
}

/* 10. Terms & order notes */
.wc-block-checkout .wc-block-checkout__terms {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	line-height: var(--line-height-relaxed);
}

.wc-block-checkout .wc-block-checkout__terms a {
	color: var(--color-primary);
	text-decoration: none;
}

.wc-block-checkout .wc-block-checkout__terms a:hover {
	text-decoration: underline;
}

.wc-block-checkout .wc-block-checkout__add-note {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
}

.wc-block-checkout .wc-block-checkout__add-note textarea {
	width: 100%;
	padding: 12px 14px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	border: 1px solid var(--color-border);
	border-radius: 0;
	resize: vertical;
	min-height: 80px;
}

.wc-block-checkout .wc-block-checkout__add-note textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 2px var(--color-primary-light);
	outline: none;
}

/* 11. Order summary sidebar */
.wc-block-checkout .wc-block-components-checkout-order-summary {
	border: none;
}

.wc-block-checkout .wc-block-components-checkout-order-summary .wc-block-components-panel__button {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border-light);
}

/* Order summary product items */
.wc-block-checkout .wc-block-components-order-summary-item {
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border-light);
}

.wc-block-checkout .wc-block-components-order-summary-item:last-child {
	border-bottom: none;
}

.wc-block-checkout .wc-block-components-order-summary-item__image {
	width: 64px;
	height: 64px;
	border: 1px solid var(--color-border-light);
	background-color: var(--color-white);
	border-radius: 0;
	overflow: hidden;
	position: relative;
}

.wc-block-checkout .wc-block-components-order-summary-item__image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 4px;
}

/* Quantity badge on product image */
.wc-block-checkout .wc-block-components-order-summary-item__quantity {
	background-color: var(--color-dark);
	color: var(--color-white);
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-bold);
	min-width: 20px;
	height: 20px;
	line-height: 20px;
	text-align: center;
	border-radius: var(--radius-full);
	transform: none !important;
}

.wp-block-woocommerce-checkout-order-summary-totals-block {
	padding-bottom: 0 !important;
}

.wc-block-checkout .wc-block-components-order-summary-item__description {
	font-size: var(--font-size-base);
	color: var(--color-text);
}

.wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-product-name {
	font-weight: var(--font-weight-medium);
	color: var(--color-dark);
	font-size: var(--font-size-base);
	text-decoration: none;
}

.wc-block-checkout .wc-block-components-order-summary-item__total-price {
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

.wc-block-checkout .wc-block-components-order-summary-item__individual-price {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
}

/* Reuse totals styles from cart (subtotal, shipping, total rows) */
.wc-block-checkout .wc-block-components-totals-wrapper {
	border-top: 0 !important;
	border-bottom: 1px solid var(--color-border-light);
}

.wc-block-checkout .wc-block-components-totals-item {
	padding: var(--space-md) 0;
	display: flex;
	justify-content: space-between;
	font-size: var(--font-size-base);
}

.wc-block-checkout .wc-block-components-totals-item__label {
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
}

.wc-block-checkout .wc-block-components-totals-item__value {
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

/* Checkout total row - prominent */
.wc-block-checkout .wc-block-components-totals-footer-item {
	padding: var(--space-md) 0;
	font-size: var(--font-size-lg);
	border-top: 2px solid var(--color-dark);
}

.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-dark);
}

/* Checkout coupon section - reuse cart coupon styles */
.wc-block-checkout .wc-block-components-totals-coupon > .wc-block-components-panel__button {
	display: none !important;
}

.wc-block-checkout .wc-block-components-totals-coupon .wc-block-components-panel__content {
	display: block !important;
	height: auto !important;
	overflow: visible !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.wc-block-checkout .wc-block-components-totals-wrapper:has(.wc-block-components-totals-coupon) {
	border-bottom: none;
}

.wc-block-checkout .wc-block-components-totals-coupon__content .wc-block-components-text-input input {
	padding: 8px 14px;
	font-size: var(--font-size-base);
	font-family: var(--font-primary);
	border: 1px solid var(--color-border);
	border-radius: 0 !important;
	color: var(--color-text);
}

.wc-block-checkout .wc-block-components-totals-coupon__content .wc-block-components-button.wc-block-components-totals-coupon__button {
	background-color: var(--color-dark) !important;
	color: var(--color-white) !important;
	border: none;
	border-radius: 0;
	padding: 8px 20px;
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	font-family: var(--font-primary);
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.wc-block-checkout .wc-block-components-totals-coupon__content .wc-block-components-button.wc-block-components-totals-coupon__button:hover {
	background-color: var(--color-text) !important;
}

/* Shipping options in checkout */
.wc-block-checkout .wc-block-components-shipping-rates-control__package {
	border: none;
	padding: 0;
}

.wc-block-checkout .wc-block-components-shipping-rates-control .wc-block-components-radio-control__option {
	margin-bottom: var(--space-sm);
}

.wc-block-checkout .wc-block-components-shipping-rates-control .wc-block-components-radio-control__option:last-child {
	margin-bottom: 0;
}

/* 12. Guest checkout notice */
.wc-block-checkout .wc-block-checkout__login-prompt {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

.wc-block-checkout .wc-block-checkout__login-prompt a {
	color: var(--color-primary);
	text-decoration: none;
	font-weight: var(--font-weight-medium);
}

.wc-block-checkout .wc-block-checkout__login-prompt a:hover {
	text-decoration: underline;
}

/* Checkout responsive */
@media (max-width: 768px) {
	/* Keep only the bottom mobile order summary (inside checkout actions). */
	.wc-block-checkout .wc-block-components-sidebar-layout.is-mobile .wc-block-checkout__sidebar > .wp-block-woocommerce-checkout-order-summary-block {
		display: none !important;
	}

	.wc-block-checkout .wc-block-components-sidebar-layout.is-mobile {
		display: block;
	}

	.wc-block-checkout .wc-block-components-sidebar-layout.is-mobile .wc-block-checkout__main,
	.wc-block-checkout .wc-block-components-sidebar-layout.is-mobile .wc-block-checkout__sidebar {
		width: 100%;
		max-width: 100%;
		min-width: 0;
	}

	.wc-block-checkout .wc-block-checkout__sidebar {
		min-width: 100%;
		max-width: 100%;
	}

	.wc-block-checkout .wc-block-components-radio-control__option-layout {
		flex-wrap: wrap;
	}

	.wc-block-checkout .wc-block-components-radio-control__option {
		padding: 12px 14px;
	}

	.wc-block-checkout .wc-block-components-radio-control__secondary-label,
	.wc-block-checkout .wc-block-components-radio-control__option-layout > *:last-child {
		margin-left: 28px;
		white-space: normal;
		text-align: left;
	}
}

@media (max-width: 480px) {
	.wc-block-checkout .wc-block-components-radio-control__option-layout {
		flex-direction: column;
		gap: 6px;
	}

	.wc-block-checkout .wc-block-components-radio-control__option {
		padding: 10px 12px;
	}

	.wc-block-checkout .wc-block-components-radio-control__secondary-label,
	.wc-block-checkout .wc-block-components-radio-control__option-layout > *:last-child {
		margin-left: 0;
	}
}

/* --------------------------------------------------------------------------
   My Account Page
   -------------------------------------------------------------------------- */

/* -- Layout -- */
.woocommerce-account .page-title {
	padding-top: var(--space-2xl);
}


.woocommerce-account .woocommerce {
	padding: var(--space-xl) 0;
}

.woocommerce-account.logged-in .woocommerce {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: var(--space-xl);
}

/* -- Navigation (logged-in) -- */
.woocommerce-MyAccount-navigation {
	position: sticky;
	top: var(--space-xl);
	align-self: start;
}

.woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
	border: 1px solid var(--color-border);
}

.woocommerce-MyAccount-navigation ul li {
	border-bottom: 1px solid var(--color-border);
}

.woocommerce-MyAccount-navigation ul li:last-child {
	border-bottom: none;
}

.woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 12px 16px;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
	text-transform: uppercase;
	letter-spacing: 0.03em;
	transition: all var(--transition-fast);
	border-left: 3px solid transparent;
}

.woocommerce-MyAccount-navigation ul li a:hover {
	color: var(--color-primary);
	background: var(--color-bg-light);
}

.woocommerce-MyAccount-navigation ul li.is-active a {
	color: var(--color-primary);
	font-weight: var(--font-weight-semibold);
	border-left-color: var(--color-primary);
	background: var(--color-bg-light);
}

/* -- Content area (logged-in) -- */
.woocommerce-MyAccount-content {
	min-height: 300px;
}

/* Dashboard greeting */
.woocommerce-MyAccount-content > p:first-child {
	font-size: var(--font-size-base);
	line-height: 1.7;
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

/* -- Orders table -- */
.woocommerce-MyAccount-content .woocommerce-orders-table {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--color-border);
}

.woocommerce-orders-table thead th {
	background: var(--color-bg-light);
	padding: 12px 16px;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--color-text);
	text-align: left;
	border-bottom: 2px solid var(--color-border);
}

.woocommerce-orders-table tbody td {
	padding: 12px 16px;
	font-size: var(--font-size-sm);
	border-bottom: 1px solid var(--color-border);
	vertical-align: middle;
}

.woocommerce-orders-table tbody tr:hover {
	background: var(--color-bg-light);
}

.woocommerce-orders-table .woocommerce-button {
	display: inline-block;
	padding: 6px 14px;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--color-primary);
	border: 1px solid var(--color-primary);
	transition: all var(--transition-fast);
}

.woocommerce-orders-table .woocommerce-button:hover {
	background: var(--color-primary);
	color: var(--color-white);
}

/* No orders / info message */
.woocommerce-MyAccount-content .woocommerce-message--info,
.woocommerce-MyAccount-content .woocommerce-info {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-xl);
	text-align: center;
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
	border: 1px solid var(--color-border);
	background: var(--color-bg-light);
}

.woocommerce-MyAccount-content .woocommerce-info .button,
.woocommerce-MyAccount-content .woocommerce-info .woocommerce-Button {
	display: inline-block;
	padding: 10px 24px;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-white);
	background-color: var(--color-primary);
	border: 2px solid var(--color-primary);
	transition: all var(--transition-fast);
}

.woocommerce-MyAccount-content .woocommerce-info .button:hover,
.woocommerce-MyAccount-content .woocommerce-info .woocommerce-Button:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
}

/* -- Addresses -- */
.woocommerce-MyAccount-content .woocommerce-Addresses {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-lg);
}

.woocommerce-MyAccount-content .woocommerce-Address {
	border: 1px solid var(--color-border);
	padding: var(--space-lg);
}

.woocommerce-MyAccount-content .woocommerce-Address-title {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--space-md);
	padding-bottom: var(--space-md);
	border-bottom: 1px solid var(--color-border);
}

.woocommerce-MyAccount-content .woocommerce-Address-title h3 {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-semibold);
	margin: 0;
}

.woocommerce-MyAccount-content .woocommerce-Address-title a {
	font-size: var(--font-size-sm);
	color: var(--color-primary);
	font-weight: var(--font-weight-medium);
}

.woocommerce-MyAccount-content .woocommerce-Address address {
	font-style: normal;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text-muted);
}

/* -- Edit account / address forms -- */
.woocommerce-MyAccount-content .woocommerce-EditAccountForm,
.woocommerce-MyAccount-content .woocommerce-address-fields {
	max-width: 600px;
}

.woocommerce-MyAccount-content fieldset {
	border: none;
	padding: 0;
	margin: var(--space-lg) 0 0;
}

.woocommerce-MyAccount-content fieldset legend {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border);
	width: 100%;
}

.woocommerce-MyAccount-content button[type="submit"],
.woocommerce-MyAccount-content input[type="submit"] {
	display: inline-block;
	padding: 12px 32px;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	font-family: var(--font-primary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-white);
	background-color: var(--color-primary);
	border: 2px solid var(--color-primary);
	cursor: pointer;
	transition: all var(--transition-fast);
	margin-top: var(--space-md);
}

.woocommerce-MyAccount-content button[type="submit"]:hover,
.woocommerce-MyAccount-content input[type="submit"]:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
}

/* -- Logged-out state: Login / Register forms -- */
.woocommerce-account:not(.logged-in) #customer_login {
	max-width: 800px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-xl);
}

.woocommerce-account:not(.logged-in) #customer_login h2,
.woocommerce-account:not(.logged-in) .woocommerce > h2 {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--space-lg);
	text-align: center;
}

.woocommerce-account:not(.logged-in) #customer_login .u-column1,
.woocommerce-account:not(.logged-in) #customer_login .u-column2 {
	padding: var(--space-xl);
	border: 1px solid var(--color-border);
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit,
.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit {
	width: 100%;
	display: block;
	padding: 12px 32px;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	font-family: var(--font-primary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-white);
	background-color: var(--color-primary);
	border: 2px solid var(--color-primary);
	cursor: pointer;
	transition: all var(--transition-fast);
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit:hover,
.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login__rememberme {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-size: var(--font-size-sm);
	margin-bottom: var(--space-md);
}

.woocommerce-account:not(.logged-in) .lost_password {
	margin-top: var(--space-md);
}

.woocommerce-account:not(.logged-in) .lost_password a {
	font-size: var(--font-size-sm);
	color: var(--color-primary);
}

.woocommerce-account:not(.logged-in) .lost_password a:hover {
	color: var(--color-primary-dark);
}

/* Lost password / Reset password form (standalone) */
.woocommerce-account:not(.logged-in) .woocommerce > .woocommerce-ResetPassword,
.woocommerce-account:not(.logged-in) .woocommerce > form.woocommerce-form {
	max-width: 480px;
	margin: 0 auto;
	padding: var(--space-xl);
	border: 1px solid var(--color-border);
}

/* --------------------------------------------------------------------------
   Product Loop - Loading State
   -------------------------------------------------------------------------- */
.shop-products.is-loading {
	opacity: 0.5;
	pointer-events: none;
	position: relative;
}

.shop-products.is-loading::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 40px;
	height: 40px;
	margin: -20px 0 0 -20px;
	border: 3px solid var(--color-border);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

/* --------------------------------------------------------------------------
   Add to Cart Button Spinner
   -------------------------------------------------------------------------- */
.btn-spinner {
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: var(--color-white);
	border-radius: 50%;
	animation: spin 0.6s linear infinite;
	display: inline-block;
}

/* --------------------------------------------------------------------------
   Cart Count Animation
   -------------------------------------------------------------------------- */
.cart-count.is-updated,
.wishlist-count.is-updated {
	animation: bounce 0.4s ease;
}

@keyframes bounce {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.3); }
}

/* --------------------------------------------------------------------------
   No Products
   -------------------------------------------------------------------------- */
.no-products {
	grid-column: 1 / -1;
	text-align: center;
	padding: var(--space-3xl) var(--space-lg);
	color: var(--color-text-light);
	font-size: var(--font-size-md);
}

/* --------------------------------------------------------------------------
   WooCommerce Price Display
   -------------------------------------------------------------------------- */
.woocommerce .price {
	font-size: var(--font-size-base);
	color: var(--color-dark);
	font-weight: var(--font-weight-bold);
}

.woocommerce .price del {
	color: var(--color-text-muted);
	font-weight: var(--font-weight-normal);
	font-size: var(--font-size-sm);
}

.woocommerce .price ins {
	text-decoration: none;
	font-weight: var(--font-weight-bold);
}

/* --------------------------------------------------------------------------
   Star Ratings
   -------------------------------------------------------------------------- */
.woocommerce .star-rating {
	font-size: var(--font-size-sm);
	color: #ffc107;
}

/* --------------------------------------------------------------------------
   WooCommerce Pagination
   -------------------------------------------------------------------------- */
.woocommerce-pagination {
	text-align: center;
	padding: var(--space-xl) 0;
}

.woocommerce-pagination ul.page-numbers {
	display: inline-flex;
	gap: var(--space-xs);
}

.woocommerce-pagination .page-numbers li {
	list-style: none;
}

.woocommerce-pagination .page-numbers a,
.woocommerce-pagination .page-numbers span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 var(--space-sm);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	transition: all var(--transition-fast);
}

.woocommerce-pagination .page-numbers a:hover,
.woocommerce-pagination .page-numbers span.current {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}
