/* ================================================================
   DairyFresh — WooCommerce
   Shop · Single · Cart · Checkout · Order received
   ================================================================ */

/* ── Shop page wrapper ─────────────────────────────────────────── */

/* Clean main content wrapper — no sidebar, full width */
.df-wc-main {
	width: 100%;
}

/* Shop/archive loop content — added via PHP hook, acts as df-container */
.df-shop-loop {
	padding-top: 40px;
	padding-bottom: 80px;
}

/* Cart / account shortcode pages: the shortcode outputs <div class="woocommerce"> */
.woocommerce-cart .woocommerce,
.woocommerce-account .woocommerce {
	width: 100%;
	max-width: var(--df-container);
	margin-inline: auto;
	padding: 0 24px 80px;
}

/* Hide the default WC title/breadcrumb inside the container —
   replaced by our full-width df-page__hero injected via PHP hook */
.woocommerce-shop .page-title,
.tax-product_cat .page-title,
.tax-product_tag .page-title,
.woocommerce-shop .woocommerce-breadcrumb,
.tax-product_cat .woocommerce-breadcrumb,
.tax-product_tag .woocommerce-breadcrumb,
.woocommerce-shop .woocommerce-products-header,
.tax-product_cat .woocommerce-products-header,
.tax-product_tag .woocommerce-products-header {
	display: none !important;
}

/* ── Result count + ordering bar ──────────────────────────────── */
.woocommerce .woocommerce-result-count {
	font-size: .85rem;
	color: var(--df-muted);
	margin: 0;
	float: none;
}
.woocommerce .woocommerce-ordering {
	margin: 0;
	float: none;
}
.woocommerce .woocommerce-ordering select {
	border: 1.5px solid var(--df-border);
	border-radius: var(--df-radius-sm);
	padding: 9px 14px;
	font-family: var(--df-font-body);
	font-size: .88rem;
	color: var(--df-dark);
	background: var(--df-white);
	cursor: pointer;
}
.woocommerce .woocommerce-ordering select:focus {
	outline: none;
	border-color: var(--df-primary);
}
/* Flex toolbar for count + sort */
.woocommerce .woocommerce-result-count + .woocommerce-ordering {
	display: block;
}
.woocommerce > form ~ .woocommerce-result-count,
.woocommerce-page .woocommerce > .woocommerce-result-count {
	display: inline-block;
	margin-bottom: 20px;
}

/* ── Product grid ──────────────────────────────────────────────── */
.woocommerce ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
	float: none !important;
	clear: both;
	width: 100% !important;
}
.woocommerce ul.products.columns-2 { grid-template-columns: repeat(2,1fr) !important }
.woocommerce ul.products.columns-3 { grid-template-columns: repeat(3,1fr) !important }
.woocommerce ul.products.columns-4 { grid-template-columns: repeat(4,1fr) !important }

/* ── Product card (premium) ─────────────────────────────────────── */
.woocommerce ul.products li.product {
	background: #fff;
	border: 1px solid var(--df-border);
	border-radius: var(--df-radius-md);
	box-shadow: 0 1px 2px rgba(0,0,0,.03);
	overflow: hidden;
	transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
	position: relative;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	width: auto !important;
	display: flex;
	flex-direction: column;
}
.woocommerce ul.products li.product::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--df-primary), var(--df-accent));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .35s cubic-bezier(.4,0,.2,1);
	z-index: 2;
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-6px);
	box-shadow: 0 30px 60px -20px rgba(0,0,0,.18);
	border-color: transparent;
}
.woocommerce ul.products li.product:hover::before { transform: scaleX(1) }
.woocommerce ul.products li.product .woocommerce-loop-product__link img,
.woocommerce ul.products li.product a img {
	background: linear-gradient(135deg, #fffaee 0%, #fff 100%);
}
.woocommerce ul.products li.product .woocommerce-loop-product__link {
	display: block;
	overflow: hidden;
	flex-shrink: 0;
}
.woocommerce ul.products li.product a img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	display: block;
	border-radius: 0;
	transition: transform .4s ease;
}
.woocommerce ul.products li.product:hover a img { transform: scale(1.05) }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--df-font-head);
	font-size: .94rem;
	font-weight: 600;
	color: var(--df-dark);
	padding: 14px 16px 4px;
	margin: 0;
	line-height: 1.35;
}
.woocommerce ul.products li.product .price {
	display: block;
	padding: 4px 16px;
	font-weight: 700;
	font-size: 1rem;
	color: var(--df-primary);
}
.woocommerce ul.products li.product .price del {
	color: var(--df-muted);
	font-size: .85rem;
	font-weight: 400;
	margin-right: 5px;
}
.woocommerce ul.products li.product .price ins { text-decoration: none }
.woocommerce ul.products li.product .star-rating { margin: 2px 16px 4px; font-size: .78rem }
.woocommerce ul.products li.product .button {
	display: block !important;
	width: calc(100% - 32px) !important;
	margin: auto 16px 18px !important;
	padding: 12px 16px !important;
	border-radius: 999px !important;
	background: var(--df-primary) !important;
	color: var(--df-white) !important;
	font-family: var(--df-font-head) !important;
	font-weight: 700 !important;
	font-size: .88rem !important;
	border: 0 !important;
	text-align: center !important;
	transition: var(--df-transition) !important;
	cursor: pointer !important;
	letter-spacing: .02em !important;
	box-shadow: 0 6px 14px -4px rgba(46,125,50,.4) !important;
}
.woocommerce ul.products li.product .button:hover {
	background: var(--df-primary-dk) !important;
	transform: translateY(-1px);
	box-shadow: 0 10px 20px -4px rgba(46,125,50,.55) !important;
}
.woocommerce ul.products li.product .button.added { background: var(--df-accent) !important; color: var(--df-dark) !important }
.woocommerce ul.products li.product .onsale {
	background: var(--df-accent) !important;
	color: var(--df-dark) !important;
	border-radius: 999px !important;
	font-weight: 800 !important;
	font-size: .72rem !important;
	padding: 4px 12px !important;
	top: 12px !important;
	left: 12px !important;
	min-height: unset !important;
	min-width: unset !important;
	line-height: 1.4 !important;
	letter-spacing: .04em !important;
	box-shadow: 0 4px 10px -2px rgba(244,180,0,.5) !important;
	z-index: 3 !important;
}
.woocommerce ul.products li.product.outofstock::after {
	content: 'Out of Stock';
	position: absolute; top: 12px; right: 12px;
	background: rgba(0,0,0,.55); color: #fff;
	font-size: .7rem; font-weight: 700;
	padding: 4px 10px; border-radius: 999px;
}

/* ── Shop pagination ───────────────────────────────────────────── */
.woocommerce nav.woocommerce-pagination { margin-top: 48px; text-align: center }
.woocommerce nav.woocommerce-pagination ul { display: inline-flex; gap: 6px; border: 0; padding: 0 }
.woocommerce nav.woocommerce-pagination ul li { border: 0; padding: 0 }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	border: 1.5px solid var(--df-border);
	border-radius: var(--df-radius-sm);
	padding: 8px 14px;
	font-family: var(--df-font-body);
	font-size: .88rem;
	color: var(--df-dark);
	transition: var(--df-transition);
	display: block;
	line-height: 1.4;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--df-primary); border-color: var(--df-primary); color: var(--df-white);
}

/* ══════════════════════════════════════════════════════════════════
   SINGLE PRODUCT
   ══════════════════════════════════════════════════════════════════ */

/* Page container — single product has no hero, so constrain df-wc-main directly */
.single-product .df-wc-main {
	max-width: var(--df-container);
	margin-inline: auto;
	padding: 0 24px 80px;
}

/* Two-column layout: gallery left, summary right (replaces stripped WC default CSS) */
.woocommerce div.product {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: start;
	padding: 40px 0;
	clear: both;
}
.woocommerce div.product .woocommerce-product-gallery,
.woocommerce div.product div.images {
	grid-column: 1;
	grid-row: 1;
	float: none !important;
	width: auto !important;
}
.woocommerce div.product .summary.entry-summary {
	grid-column: 2;
	grid-row: 1;
	float: none !important;
	width: auto !important;
}
/* Tabs, related, upsells span full width */
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related.products,
.woocommerce div.product .upsells.products {
	grid-column: 1 / -1;
	float: none !important;
	width: auto !important;
}
/* Suppress WC's clearfix pseudo-element on div.product */
.woocommerce div.product::after { display: none !important }

/* Gallery images */
.woocommerce div.product .woocommerce-product-gallery,
.woocommerce div.product div.images {
	border-radius: var(--df-radius-md);
	overflow: hidden;
}
.woocommerce div.product .woocommerce-product-gallery figure,
.woocommerce div.product div.images img {
	border-radius: var(--df-radius-md);
	width: 100%;
	display: block;
}
/* Gallery thumbnails strip */
.woocommerce div.product .flex-control-thumbs {
	display: flex;
	gap: 8px;
	margin-top: 10px;
	padding: 0;
	list-style: none;
}
.woocommerce div.product .flex-control-thumbs li { flex: 0 0 calc(25% - 6px) }
.woocommerce div.product .flex-control-thumbs li img {
	border-radius: var(--df-radius-sm);
	border: 2px solid transparent;
	cursor: pointer;
	transition: var(--df-transition);
	opacity: .75;
}
.woocommerce div.product .flex-control-thumbs li img.flex-active,
.woocommerce div.product .flex-control-thumbs li img:hover {
	border-color: var(--df-primary);
	opacity: 1;
}

/* Product title, price */
.woocommerce div.product .product_title {
	font-family: var(--df-font-head);
	font-size: clamp(1.4rem,2.5vw,2.2rem);
	margin-bottom: 10px;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--df-primary); font-size: 1.8rem; font-weight: 700; display: block; margin: 12px 0;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
	color: var(--df-muted); font-size: 1.1rem; font-weight: 400;
}
.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: .95rem; color: var(--df-muted); line-height: 1.75; margin: 14px 0;
}

/* Star rating */
.woocommerce div.product .woocommerce-product-rating {
	display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.woocommerce div.product .woocommerce-review-link {
	font-size: .84rem; color: var(--df-muted);
}

/* Qty + ATC row */
.woocommerce div.product form.cart { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 20px 0 }
.woocommerce div.product .quantity { display: flex; align-items: center; gap: 0 }
.woocommerce div.product .quantity .qty {
	border: 1.5px solid var(--df-border); border-radius: var(--df-radius-sm);
	padding: 12px 14px; font-family: var(--df-font-body); font-size: 1rem;
	width: 72px; text-align: center;
}
.woocommerce div.product .quantity .qty:focus { outline: none; border-color: var(--df-primary) }
.woocommerce .single_add_to_cart_button {
	border-radius: 999px !important; background: var(--df-primary) !important;
	color: var(--df-white) !important; font-family: var(--df-font-head) !important;
	font-weight: 700 !important; font-size: 1rem !important;
	padding: 14px 36px !important; border: 0 !important;
	transition: var(--df-transition) !important;
}
.woocommerce .single_add_to_cart_button:hover {
	background: var(--df-primary-dk) !important; transform: translateY(-2px);
}
.df-buy-now {
	background: var(--df-accent) !important; color: var(--df-dark) !important;
	margin-left: 10px !important; border-radius: 999px !important;
	font-family: var(--df-font-head) !important; font-weight: 700 !important;
	font-size: 1rem !important; padding: 14px 36px !important; border: 0 !important;
	cursor: pointer; transition: var(--df-transition) !important;
}
.df-buy-now:hover { background: var(--df-accent-dk) !important; transform: translateY(-2px); }

/* Product meta (SKU, category) */
.woocommerce div.product .product_meta {
	font-size: .84rem; color: var(--df-muted); margin-top: 16px;
	padding-top: 16px; border-top: 1px solid var(--df-border);
}
.woocommerce div.product .product_meta a { color: var(--df-primary) }

/* Trust badges */
.df-product-trust { display: flex; flex-wrap: wrap; gap: 8px; margin: 14px 0 }
.df-product-trust__item {
	background: var(--df-primary-lt); color: var(--df-primary-dk);
	border-radius: 999px; padding: 6px 14px; font-size: .8rem; font-weight: 600;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs { padding-top: 48px }
.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding: 0; border-bottom: 2px solid var(--df-border); display: flex; gap: 0; list-style: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent; border: 0;
	border-bottom: 3px solid transparent; margin-bottom: -2px; border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	font-family: var(--df-font-head); font-weight: 600; font-size: .92rem;
	color: var(--df-muted); padding: 12px 20px; display: block;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { border-bottom-color: var(--df-primary) }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--df-primary) }
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none }
.woocommerce div.product .woocommerce-tabs .panel {
	padding: 28px 0;
	background: var(--df-white);
	border-radius: 0 0 var(--df-radius-md) var(--df-radius-md);
}
.woocommerce div.product .woocommerce-tabs .panel h2 { display: none }
.woocommerce div.product .woocommerce-tabs .panel p { color: var(--df-muted); line-height: 1.8; font-size: .95rem }

/* Related / upsells */
.related.products, .upsells.products { padding-top: 48px }
.related.products > h2, .upsells.products > h2 {
	font-family: var(--df-font-head); font-size: 1.5rem; margin-bottom: 24px;
}
.related.products ul.products,
.upsells.products ul.products { grid-template-columns: repeat(4,1fr) !important }

/* ══════════════════════════════════════════════════════════════════
   CART PAGE
   ══════════════════════════════════════════════════════════════════ */

/* Two-column layout: table left, totals right */
.woocommerce-cart .woocommerce {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 40px;
	align-items: start;
}
/* Cart notices span full width */
.woocommerce-cart .woocommerce .woocommerce-message,
.woocommerce-cart .woocommerce .woocommerce-info,
.woocommerce-cart .woocommerce .woocommerce-error {
	grid-column: 1 / -1;
}
/* Cart form (table + coupon) */
.woocommerce-cart .woocommerce form.woocommerce-cart-form {
	grid-column: 1;
	min-width: 0;
}
/* Totals */
.woocommerce-cart .woocommerce .cart-collaterals {
	grid-column: 2;
	width: 100% !important;
	float: none !important;
}
.woocommerce-cart .woocommerce .cart_totals {
	float: none !important;
	width: 100% !important;
	background: var(--df-white);
	border-radius: var(--df-radius-md);
	padding: 28px;
	box-shadow: var(--df-shadow-sm);
	position: sticky;
	top: 90px;
}
.woocommerce-cart .cart_totals h2 { font-size: 1.15rem; margin-bottom: 20px }
.woocommerce-cart .cart_totals table { width: 100%; border-collapse: collapse }
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
	padding: 11px 0; border-top: 1px solid var(--df-border); font-size: .92rem; vertical-align: top;
}
.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
	font-weight: 700; font-size: 1.1rem; color: var(--df-primary); border-top: 2px solid var(--df-border);
}
.woocommerce-cart .wc-proceed-to-checkout { padding: 0 }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	display: block; border-radius: 999px !important;
	background: var(--df-primary) !important; color: var(--df-white) !important;
	font-family: var(--df-font-head) !important; font-weight: 700 !important;
	font-size: 1.05rem !important; padding: 16px 24px !important;
	border: 0 !important; text-align: center; margin-top: 16px;
	transition: var(--df-transition) !important;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
	background: var(--df-primary-dk) !important; transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(46,125,50,.3) !important;
}
/* Cart table */
.woocommerce-cart table.cart {
	border-collapse: collapse; width: 100%;
	background: var(--df-white); border-radius: var(--df-radius-md);
	box-shadow: var(--df-shadow-sm); overflow: hidden;
}
.woocommerce-cart table.cart thead tr { background: var(--df-light) }
.woocommerce-cart table.cart td,
.woocommerce-cart table.cart th {
	padding: 14px 16px; border-bottom: 1px solid var(--df-border);
	vertical-align: middle; font-size: .92rem;
}
.woocommerce-cart table.cart th {
	font-family: var(--df-font-head); font-weight: 600; font-size: .82rem;
	text-transform: uppercase; letter-spacing: .05em; color: var(--df-muted);
}
.woocommerce-cart table.cart img {
	border-radius: var(--df-radius-sm); width: 72px; height: 72px; object-fit: cover;
}
.woocommerce-cart table.cart .product-name a { font-weight: 600; color: var(--df-dark) }
.woocommerce-cart table.cart .product-name a:hover { color: var(--df-primary) }
.woocommerce-cart table.cart .product-remove a {
	color: var(--df-muted) !important; font-size: 1.2rem; font-weight: 400;
}
.woocommerce-cart table.cart .product-remove a:hover { color: #C62828 !important }
/* Cart qty input */
.woocommerce-cart .qty {
	border: 1.5px solid var(--df-border); border-radius: var(--df-radius-sm);
	padding: 8px 10px; width: 64px; text-align: center; font-family: var(--df-font-body);
}
.woocommerce-cart .qty:focus { outline: none; border-color: var(--df-primary) }
/* Coupon */
.woocommerce-cart .coupon { display: flex; gap: 10px; margin-top: 16px; align-items: center }
.woocommerce-cart .coupon input#coupon_code {
	border: 1.5px solid var(--df-border); border-radius: var(--df-radius-sm);
	padding: 11px 16px; font-family: var(--df-font-body); font-size: .92rem; flex: 1;
}
.woocommerce-cart .coupon input#coupon_code:focus { outline: none; border-color: var(--df-primary) }
.woocommerce-cart .coupon .button,
.woocommerce-cart .actions .button {
	border-radius: 999px !important; background: var(--df-light) !important;
	color: var(--df-dark) !important; font-family: var(--df-font-head) !important;
	font-weight: 600 !important; font-size: .88rem !important;
	padding: 11px 20px !important; border: 1.5px solid var(--df-border) !important;
	cursor: pointer; transition: var(--df-transition) !important;
}
.woocommerce-cart .coupon .button:hover,
.woocommerce-cart .actions .button:hover {
	background: var(--df-primary) !important; color: var(--df-white) !important;
	border-color: var(--df-primary) !important;
}

/* ══════════════════════════════════════════════════════════════════
   CHECKOUT — focused two-column layout
   ══════════════════════════════════════════════════════════════════ */

/* Checkout step indicator (output by woocommerce.php hook) */
.df-checkout-steps {
	background: var(--df-white);
	border-bottom: 1px solid var(--df-border);
	padding: 0;
}
.df-checkout-steps__inner {
	max-width: var(--df-container);
	margin-inline: auto;
	padding: 0 24px;
	display: flex;
	align-items: stretch;
}
.df-checkout-steps__step {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 16px 24px;
	font-size: .82rem;
	font-weight: 600;
	color: var(--df-muted);
	position: relative;
	flex-shrink: 0;
}
.df-checkout-steps__step::after {
	content: '›';
	position: absolute;
	right: -2px;
	font-size: 1.2rem;
	color: var(--df-border);
}
.df-checkout-steps__step:last-child::after { display: none }
.df-checkout-steps__step-num {
	width: 26px; height: 26px;
	border-radius: 50%;
	border: 2px solid var(--df-border);
	display: flex; align-items: center; justify-content: center;
	font-size: .78rem; font-weight: 700; flex-shrink: 0;
}
.df-checkout-steps__step--done {
	color: var(--df-primary);
}
.df-checkout-steps__step--done .df-checkout-steps__step-num {
	background: var(--df-primary); border-color: var(--df-primary); color: var(--df-white);
}
.df-checkout-steps__step--active {
	color: var(--df-dark);
}
.df-checkout-steps__step--active .df-checkout-steps__step-num {
	background: var(--df-dark); border-color: var(--df-dark); color: var(--df-white);
}

/* Checkout wrapper: 2-column */
.woocommerce-checkout .woocommerce {
	max-width: var(--df-container);
	margin-inline: auto;
	padding: 40px 24px 80px;
}
form.woocommerce-checkout {
	display: grid;
	grid-template-columns: 1fr 380px;
	column-gap: 48px;
	align-items: start;
}
form.woocommerce-checkout #customer_details {
	grid-column: 1;
	grid-row: 1;
}
form.woocommerce-checkout #order_review_heading {
	grid-column: 2;
	grid-row: 1;
	font-family: var(--df-font-head);
	font-size: 1.1rem;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--df-border);
	margin-bottom: 0;
	margin-top: 0;
}
form.woocommerce-checkout #order_review {
	grid-column: 2;
	grid-row: 2 / 10; /* span all rows */
	position: sticky;
	top: 90px;
}

/* Billing section heading */
.woocommerce-checkout h3 {
	font-family: var(--df-font-head);
	font-size: 1.1rem;
	font-weight: 700;
	margin: 0 0 20px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--df-border);
	color: var(--df-dark);
}
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
	float: none; width: 100%; padding: 0;
}
.woocommerce-checkout #customer_details .col-1 {
	background: var(--df-white);
	border-radius: var(--df-radius-md);
	padding: 28px 32px;
	box-shadow: var(--df-shadow-sm);
	margin-bottom: 24px;
}
.woocommerce-checkout #customer_details .col-2 {
	background: var(--df-white);
	border-radius: var(--df-radius-md);
	padding: 28px 32px;
	box-shadow: var(--df-shadow-sm);
}

/* Form rows */
.woocommerce form .form-row { margin-bottom: 16px }
.woocommerce form .form-row label {
	font-size: .84rem; font-weight: 600; margin-bottom: 6px; display: block; color: var(--df-dark);
}
.woocommerce form .form-row label .required { color: var(--df-primary); margin-left: 2px }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
	border-radius: var(--df-radius-sm) !important;
	border: 1.5px solid var(--df-border) !important;
	padding: 12px 16px !important;
	font-family: var(--df-font-body) !important;
	font-size: .94rem !important;
	color: var(--df-dark) !important;
	background: var(--df-white) !important;
	width: 100%;
	transition: var(--df-transition);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
	border-color: var(--df-primary) !important;
	box-shadow: 0 0 0 3px rgba(46,125,50,.1) !important;
	outline: none;
}

/* Order summary table (right column) */
#order_review .shop_table {
	width: 100%;
	border-collapse: collapse;
	background: var(--df-white);
	border-radius: var(--df-radius-md);
	overflow: hidden;
	box-shadow: var(--df-shadow-sm);
}
#order_review .shop_table th {
	font-family: var(--df-font-head);
	font-size: .82rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--df-muted);
	background: var(--df-light);
	padding: 12px 16px;
}
#order_review .shop_table td {
	padding: 12px 16px;
	border-top: 1px solid var(--df-border);
	font-size: .9rem;
	vertical-align: middle;
}
#order_review .shop_table .order-total th,
#order_review .shop_table .order-total td {
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--df-primary);
	border-top: 2px solid var(--df-border);
}
#order_review .shop_table .cart-subtotal td,
#order_review .shop_table .cart-subtotal th { font-weight: 500 }

/* Payment section */
#payment {
	margin-top: 16px;
	background: var(--df-white) !important;
	border-radius: var(--df-radius-md) !important;
	padding: 0 !important;
	overflow: hidden;
	box-shadow: var(--df-shadow-sm);
}
#payment ul.wc_payment_methods {
	padding: 0;
	margin: 0;
	list-style: none;
	border-bottom: 1px solid var(--df-border);
}
#payment ul.wc_payment_methods li.wc_payment_method {
	padding: 0;
	border-top: 1px solid var(--df-border);
}
#payment ul.wc_payment_methods li.wc_payment_method:first-child { border-top: 0 }
#payment ul.wc_payment_methods li label {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 20px;
	cursor: pointer;
	font-weight: 600;
	font-size: .92rem;
	color: var(--df-dark);
	transition: var(--df-transition);
}
#payment ul.wc_payment_methods li label:hover { background: var(--df-primary-lt) }
#payment ul.wc_payment_methods li input[type=radio] {
	width: 18px; height: 18px; accent-color: var(--df-primary); flex-shrink: 0;
}
#payment ul.wc_payment_methods li img {
	height: 28px; width: auto; display: inline-block;
}
#payment .payment_box {
	background: var(--df-primary-lt);
	padding: 14px 20px;
	font-size: .88rem;
	color: var(--df-primary-dk);
	border-top: 1px solid rgba(46,125,50,.12);
}
#payment .place-order {
	padding: 20px;
	background: var(--df-white);
}
#payment #place_order {
	display: block !important;
	width: 100% !important;
	border-radius: 999px !important;
	background: var(--df-primary) !important;
	color: var(--df-white) !important;
	font-family: var(--df-font-head) !important;
	font-weight: 700 !important;
	font-size: 1.05rem !important;
	padding: 17px 32px !important;
	border: 0 !important;
	cursor: pointer;
	transition: var(--df-transition) !important;
	letter-spacing: .02em;
}
#payment #place_order:hover {
	background: var(--df-primary-dk) !important;
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(46,125,50,.35) !important;
}

/* Security strip below Place Order */
.df-checkout-secure {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	font-size: .78rem;
	color: var(--df-muted);
	padding: 10px 20px 18px;
	background: var(--df-white);
	border-radius: 0 0 var(--df-radius-md) var(--df-radius-md);
}

/* WC checkout notices span full width */
.woocommerce-checkout .woocommerce-notices-wrapper {
	grid-column: 1 / -1;
}

/* ── Order received (thank you) ────────────────────────────────── */
.woocommerce-order-received .woocommerce {
	max-width: 720px;
	margin-inline: auto;
	padding: 40px 24px 80px;
}
.woocommerce-thankyou-section-title,
.woocommerce-order-received h2 {
	font-family: var(--df-font-head);
	font-size: 1.3rem;
	margin: 28px 0 16px;
}
.woocommerce-notice--success,
.woocommerce-thankyou .woocommerce-message {
	background: var(--df-primary-lt);
	border-left: 4px solid var(--df-primary);
	border-radius: 0 var(--df-radius-sm) var(--df-radius-sm) 0;
	padding: 16px 20px;
	color: var(--df-primary-dk);
	font-weight: 600;
	margin-bottom: 28px;
}
.woocommerce-order-details,
.woocommerce-customer-details {
	background: var(--df-white);
	border-radius: var(--df-radius-md);
	padding: 24px 28px;
	box-shadow: var(--df-shadow-sm);
	margin-bottom: 24px;
}
.woocommerce-order-overview {
	background: var(--df-primary-lt);
	border-radius: var(--df-radius-md);
	padding: 20px 24px;
	margin-bottom: 28px;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
}
.woocommerce-order-overview li {
	flex: 1;
	min-width: 130px;
	padding: 8px 16px;
	border-right: 1px solid rgba(46,125,50,.15);
	font-size: .88rem;
	color: var(--df-muted);
}
.woocommerce-order-overview li:last-child { border-right: 0 }
.woocommerce-order-overview li strong { display: block; color: var(--df-primary-dk); font-weight: 700 }

/* ── Ratings ───────────────────────────────────────────────────── */
.star-rating span::before,
.woocommerce .star-rating span::before { color: var(--df-accent) }
.woocommerce-product-rating .star-rating { margin: 0 8px 0 0 }

/* ── WC notices ────────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info {
	border-top-color: var(--df-primary) !important;
	border-radius: 0 var(--df-radius-sm) var(--df-radius-sm) 0;
}
.woocommerce-message::before { color: var(--df-primary) !important }
.woocommerce-error { border-top-color: #C62828 !important }

/* ── Responsive ────────────────────────────────────────────────── */
@media (max-width: 1024px) {
	.woocommerce ul.products,
	.woocommerce ul.products.columns-2,
	.woocommerce ul.products.columns-3,
	.woocommerce ul.products.columns-4,
	.woocommerce ul.products.columns-5,
	.woocommerce ul.products.columns-6 { grid-template-columns: repeat(3,1fr) !important }
	.related.products ul.products,
	.upsells.products ul.products { grid-template-columns: repeat(3,1fr) !important }
	form.woocommerce-checkout { grid-template-columns: 1fr }
	form.woocommerce-checkout #order_review_heading,
	form.woocommerce-checkout #order_review {
		grid-column: 1; position: static;
	}
	form.woocommerce-checkout #order_review_heading { grid-row: 3 }
	form.woocommerce-checkout #order_review { grid-row: 4 }
	/* Single product: reduce gap */
	.woocommerce div.product { gap: 32px }
}
@media (max-width: 768px) {
	.woocommerce ul.products,
	.woocommerce ul.products.columns-2,
	.woocommerce ul.products.columns-3,
	.woocommerce ul.products.columns-4,
	.woocommerce ul.products.columns-5,
	.woocommerce ul.products.columns-6 { grid-template-columns: repeat(2,1fr) !important; gap: 14px !important }
	.related.products ul.products,
	.upsells.products ul.products { grid-template-columns: repeat(2,1fr) !important }
	.woocommerce-cart .woocommerce { grid-template-columns: 1fr }
	.woocommerce-cart .woocommerce .cart-collaterals { grid-column: 1 }
	.woocommerce-cart .cart_totals { position: static }
	.woocommerce-checkout #customer_details .col-1,
	.woocommerce-checkout #customer_details .col-2 { padding: 20px }
	.df-buy-now { margin-left: 0 !important; margin-top: 10px !important }
	.woocommerce .single_add_to_cart_button,
	.df-buy-now { width: 100% !important; display: block !important }
	.df-checkout-steps__step-label { display: none }
	.woocommerce-order-overview { flex-direction: column }
	.woocommerce-order-overview li { border-right: 0; border-bottom: 1px solid rgba(46,125,50,.15) }
	/* Single product: stack to one column */
	.woocommerce div.product { grid-template-columns: 1fr; gap: 24px }
	.woocommerce div.product .woocommerce-product-gallery,
	.woocommerce div.product div.images,
	.woocommerce div.product .summary.entry-summary,
	.woocommerce div.product .woocommerce-tabs,
	.woocommerce div.product .related.products,
	.woocommerce div.product .upsells.products { grid-column: 1 }
	.single-product .df-wc-main { padding: 0 16px 60px }
	/* Product card text scale */
	.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .82rem; padding: 12px 12px 2px }
	.woocommerce ul.products li.product .price { font-size: .92rem; padding: 2px 12px }
	.woocommerce ul.products li.product .button {
		font-size: .76rem !important;
		padding: 10px 12px !important;
		margin: auto 12px 14px !important;
		width: calc(100% - 24px) !important;
	}
	.woocommerce ul.products li.product .onsale {
		font-size: .62rem !important;
		padding: 3px 9px !important;
		top: 8px !important;
		left: 8px !important;
	}
}
@media (max-width: 420px) {
	.woocommerce ul.products,
	.woocommerce ul.products.columns-2,
	.woocommerce ul.products.columns-3,
	.woocommerce ul.products.columns-4 { grid-template-columns: 1fr !important; gap: 16px !important }
	.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .95rem; padding: 14px 16px 4px }
	.woocommerce ul.products li.product .price { font-size: 1.05rem; padding: 4px 16px }
	.woocommerce ul.products li.product .button {
		font-size: .85rem !important;
		padding: 11px 16px !important;
		margin: auto 16px 16px !important;
		width: calc(100% - 32px) !important;
	}
}
@media (max-width: 480px) {
	.woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 12px !important }
	.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .82rem }
}
