/* ==========================================================================
   v2 WooCommerce reskin: cart, checkout, my-account.
   Loads after v2-fixes.css. Reshapes WC's default table layouts into the
   v2 prototype's card-and-summary grid pattern.
   ========================================================================== */

/* --- CART -------------------------------------------------------------- */

.woocommerce-cart .woocommerce { padding: 24px 0 80px; }
.woocommerce-cart .woocommerce > h1,
.woocommerce-cart .entry-title {
	font-family: var(--font-display);
	font-size: clamp(32px, 4vw, 44px);
	color: var(--vp-ink);
	margin: 12px 0 18px;
}

.woocommerce-cart .woocommerce-cart-form,
.woocommerce-cart .cart-collaterals {
	margin: 0;
}

/* Two-column grid: cart list left, summary right. */
@media (min-width: 980px) {
	.woocommerce-cart .woocommerce {
		display: grid;
		grid-template-columns: 1.6fr 1fr;
		gap: 32px;
		align-items: start;
	}
	.woocommerce-cart .woocommerce > h1,
	.woocommerce-cart .entry-title {
		grid-column: 1 / -1;
	}
}

/* Cart line items table -> card-style rows. */
.woocommerce-cart-form table.cart {
	background: white;
	border: 1px solid var(--vp-line);
	border-collapse: collapse;
	width: 100%;
}
.woocommerce-cart-form table.cart thead {
	background: var(--vp-cream);
}
.woocommerce-cart-form table.cart thead th {
	font-family: var(--font-body);
	font-weight: 700;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--vp-muted);
	padding: 14px 16px;
	border-bottom: 1px solid var(--vp-line);
}
.woocommerce-cart-form table.cart tbody td {
	padding: 18px 16px;
	border-bottom: 1px solid var(--vp-line);
	vertical-align: middle;
}
.woocommerce-cart-form table.cart .product-thumbnail {
	width: 100px;
}
.woocommerce-cart-form table.cart .product-thumbnail img {
	width: 80px;
	height: 80px;
	object-fit: contain;
	background: var(--vp-cream);
	padding: 8px;
}
.woocommerce-cart-form table.cart .product-name a {
	font-family: var(--font-display);
	font-size: 18px;
	color: var(--vp-ink);
	line-height: 1.2;
	text-decoration: none;
}
.woocommerce-cart-form table.cart .product-name a:hover {
	color: var(--vp-link);
}
.woocommerce-cart-form table.cart .product-price,
.woocommerce-cart-form table.cart .product-subtotal {
	font-weight: 700;
	font-size: 16px;
	color: var(--vp-ink);
	font-variant-numeric: tabular-nums;
}
.woocommerce-cart-form table.cart .product-quantity .qty {
	width: 64px;
	text-align: center;
	border: 1.5px solid var(--vp-line-strong);
	border-radius: 8px;
	padding: 8px;
	font-weight: 700;
}
.woocommerce-cart-form table.cart .product-remove a.remove {
	color: var(--vp-muted);
	font-size: 22px;
	background: none;
}
.woocommerce-cart-form table.cart .product-remove a.remove:hover {
	color: var(--vp-error);
	background: none;
}

/* Coupon + update row at the bottom. */
.woocommerce-cart-form table.cart .actions {
	padding: 18px 16px;
	background: var(--vp-cream);
}
.woocommerce-cart-form table.cart .coupon { display: flex; gap: 8px; align-items: center; }
.woocommerce-cart-form table.cart .coupon input.input-text {
	border: 1.5px solid var(--vp-line-strong);
	border-radius: 6px;
	padding: 10px 12px;
	font-size: 14px;
	background: white;
	width: auto;
}

/* Cart totals = "Order summary" card. */
.cart_totals {
	background: var(--vp-cream);
	border: 1px solid var(--vp-line);
	padding: 24px 26px;
	position: sticky;
	top: 80px;
}
.cart_totals h2 {
	font-family: var(--font-display);
	font-size: 22px;
	color: var(--vp-ink);
	margin: 0 0 14px;
}
.cart_totals table {
	width: 100%;
	border-collapse: collapse;
	border: 0;
}
.cart_totals table th,
.cart_totals table td {
	padding: 8px 0;
	font-size: 14px;
	color: var(--vp-body);
	font-variant-numeric: tabular-nums;
	border: 0;
	background: transparent;
}
.cart_totals table th { text-align: left; font-weight: 500; }
.cart_totals table td { text-align: right; }
.cart_totals table tr.order-total th,
.cart_totals table tr.order-total td {
	border-top: 1px solid var(--vp-line);
	padding-top: 14px;
	font-size: 18px;
	font-weight: 700;
	color: var(--vp-ink);
}
.cart_totals table tr.order-total td {
	font-family: var(--font-display);
	font-size: 26px;
}
.cart_totals .checkout-button {
	display: block;
	width: 100%;
	background: var(--vp-trade-green-700) !important;
	color: white !important;
	padding: 16px 24px !important;
	font-family: var(--font-body) !important;
	font-weight: 700 !important;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-align: center;
	margin-top: 16px !important;
	border-radius: 10px;
	border: 0;
	font-size: 14px !important;
}
.cart_totals .checkout-button:hover {
	background: var(--vp-trade-green) !important;
	color: white !important;
}

/* Empty cart state. */
.woocommerce-cart .cart-empty {
	font-family: var(--font-display);
	font-size: clamp(28px, 3.4vw, 40px);
	color: var(--vp-ink);
	text-align: center;
	padding: 64px 24px 16px;
	margin: 0;
}
.woocommerce-cart .return-to-shop {
	text-align: center;
	padding: 24px;
}
.woocommerce-cart .return-to-shop .wc-backward {
	background: var(--vp-orange) !important;
	color: var(--vp-ink) !important;
	padding: 14px 24px !important;
	font-weight: 700 !important;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-size: 14px !important;
	border-radius: 10px;
	display: inline-block;
}

/* --- CHECKOUT ---------------------------------------------------------- */

.woocommerce-checkout .woocommerce { padding: 24px 0 80px; }

.woocommerce-checkout #customer_details {
	background: white;
	border: 1px solid var(--vp-line);
	padding: 24px 28px;
}
.woocommerce-checkout #customer_details h3 {
	font-family: var(--font-display);
	font-size: 22px;
	color: var(--vp-ink);
	margin: 0 0 14px;
}
.woocommerce-checkout .form-row label {
	font-size: 13px;
	font-weight: 600;
	color: var(--vp-muted);
	margin-bottom: 6px;
}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .select2-selection {
	border: 1.5px solid var(--vp-line-strong) !important;
	background: white !important;
	border-radius: 6px !important;
	padding: 12px 14px !important;
	font-size: 14px;
	font-family: inherit;
}

#order_review_heading {
	font-family: var(--font-display);
	font-size: 22px;
	color: var(--vp-ink);
	margin: 24px 0 14px;
}
#order_review {
	background: var(--vp-cream);
	border: 1px solid var(--vp-line);
	padding: 24px 26px;
}
#order_review .shop_table {
	background: transparent;
	border: 0;
}
#order_review .shop_table th {
	font-family: var(--font-body);
	font-weight: 700;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--vp-muted);
	padding: 8px 0;
	border-bottom: 1px solid var(--vp-line);
}
#order_review .shop_table td {
	padding: 10px 0;
	font-size: 14px;
	color: var(--vp-body);
	border-bottom: 1px solid var(--vp-line);
	background: transparent;
}
#order_review .shop_table tr.order-total th,
#order_review .shop_table tr.order-total td {
	font-family: var(--font-display);
	font-size: 22px;
	font-weight: 700;
	color: var(--vp-ink);
	padding-top: 16px;
}

#payment.woocommerce-checkout-payment {
	background: white;
	border: 1px solid var(--vp-line);
	margin-top: 18px;
	padding: 0;
}
#payment ul.payment_methods {
	border: 0;
	padding: 24px 26px 0;
}
#payment ul.payment_methods li {
	background: transparent;
	margin-bottom: 12px;
}
#payment ul.payment_methods li label {
	font-weight: 700;
	color: var(--vp-ink);
}
#payment .form-row.place-order {
	padding: 24px 26px;
	border-top: 1px solid var(--vp-line);
	background: var(--vp-cream);
}
#payment .form-row.place-order #place_order {
	background: var(--vp-trade-green-700) !important;
	color: white !important;
	padding: 16px 32px !important;
	font-family: var(--font-body) !important;
	font-weight: 700 !important;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-size: 14px !important;
	border: 0;
	border-radius: 10px;
	width: 100%;
}

/* Prepaid notice (the only checkout-level messaging we keep, no Net-30). */
.vp-prepaid-notice {
	border-left: 4px solid var(--vp-link);
	background: rgba(47,107,65,0.06);
	padding: 14px 18px;
	margin-bottom: 24px;
	font-size: 14px;
	color: var(--vp-body);
	border-radius: 4px;
}
.vp-prepaid-notice strong { color: var(--vp-link-hover); font-weight: 700; }

/* --- MY ACCOUNT (refinements on top of woocommerce-overrides.css) ----- */

.woocommerce-account .woocommerce {
	padding: 24px 0 64px;
}
.woocommerce-account .woocommerce > h1,
.woocommerce-account .entry-title {
	font-family: var(--font-display);
	font-size: clamp(32px, 4vw, 44px);
	color: var(--vp-ink);
	margin: 12px 0 18px;
}

.woocommerce-MyAccount-navigation {
	background: white;
	border: 1px solid var(--vp-line);
	padding: 0;
}
.woocommerce-MyAccount-navigation ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
.woocommerce-MyAccount-navigation ul li {
	border-bottom: 1px solid var(--vp-line);
}
.woocommerce-MyAccount-navigation ul li:last-child { border-bottom: 0; }
.woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 14px 18px;
	color: var(--vp-ink);
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	transition: background 140ms;
}
.woocommerce-MyAccount-navigation ul li a:hover { background: var(--vp-cream); }
.woocommerce-MyAccount-navigation ul li.is-active a {
	background: var(--vp-cream);
	border-left: 3px solid var(--vp-link);
	padding-left: 15px;
	color: var(--vp-link-hover);
}

.woocommerce-MyAccount-content {
	background: white;
	border: 1px solid var(--vp-line);
	padding: 28px 32px;
}
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
	font-family: var(--font-display);
	color: var(--vp-ink);
	margin-top: 0;
}

/* Orders / invoices / payments tables. */
.woocommerce-MyAccount-content table.shop_table_responsive {
	background: white;
	border: 1px solid var(--vp-line);
	border-collapse: collapse;
	width: 100%;
}
.woocommerce-MyAccount-content table.shop_table_responsive thead {
	background: var(--vp-cream);
}
.woocommerce-MyAccount-content table.shop_table_responsive thead th {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--vp-muted);
	padding: 12px 16px;
	text-align: left;
}
.woocommerce-MyAccount-content table.shop_table_responsive tbody td {
	padding: 14px 16px;
	border-top: 1px solid var(--vp-line);
	font-size: 14px;
}

/* Status pills inside order tables. */
.woocommerce-orders-table__cell-order-status mark {
	background: transparent;
	color: var(--vp-link);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

/* --- BUTTONS in my-account ------------------------------------------- */

.woocommerce-MyAccount-content .button {
	background: var(--vp-orange);
	color: var(--vp-ink);
	padding: 10px 18px;
	font-weight: 700;
	font-size: 13px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: 8px;
	border: 0;
	cursor: pointer;
}
.woocommerce-MyAccount-content .button:hover {
	background: var(--vp-orange-700);
	color: white;
}
