/**
 * commerce.css — Cart & Checkout. Loaded on is_cart()/is_checkout().
 * Styles WooCommerce's OWN classic markup (no template overrides).
 */

/* WooCommerce pages render via page.php > .entry-content (capped at 72ch for editorial
   reading). Cart/checkout/account need full width for their 2-column layouts. */
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content,
.woocommerce-account .entry-content { max-width: none; }

/* Shared trust bits (cart + checkout) */
.gfo-shipbar { background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 12px; padding: 16px 20px; margin-bottom: 16px; }
.gfo-shipbar__msg { font-size: 13px; font-weight: 500; color: var(--gfo-ink); margin-bottom: 9px; }
.gfo-shipbar__track { display: block; height: 8px; background: rgba(58,40,32,.1); border-radius: 6px; overflow: hidden; }
.gfo-shipbar__fill { display: block; height: 100%; background: var(--gfo-success); border-radius: 6px; }
.gfo-checkout-trust { display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 12px; font-size: 12.5px; font-weight: 500; color: var(--gfo-text-muted); }
.gfo-pay-marks { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.gfo-pay-marks .gfo-pay { font-family: var(--gfo-font-display); font-weight: 700; font-size: 9px; color: var(--gfo-text-hint); border: 1px solid rgba(58,40,32,.18); border-radius: 4px; padding: 4px 7px; }
.gfo-secure-note { text-align: center; font-family: var(--gfo-font-mono); font-size: 12px; color: var(--gfo-text-muted); margin-bottom: 20px; }

/* ---------------- Cart ---------------- */
.woocommerce-cart .woocommerce { display: grid; grid-template-columns: 1.5fr .85fr; gap: 32px; align-items: start; }
.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper { grid-column: 1 / -1; }
.woocommerce-cart .gfo-shipbar { grid-column: 1 / -1; } /* span both columns (injected before the cart grid) */
.woocommerce-cart form.woocommerce-cart-form { grid-column: 1; }
.woocommerce-cart .cart-collaterals { grid-column: 2; position: sticky; top: 24px; width: 100%; }

/* Line-item table → card list */
.woocommerce-cart table.cart { background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 12px; border-collapse: separate; border-spacing: 0; overflow: hidden; margin: 0; }
.woocommerce-cart table.cart thead { display: none; }
.woocommerce-cart table.cart td { border-top: 1px solid rgba(58,40,32,.1); padding: 18px 20px; vertical-align: middle; background: transparent; }
.woocommerce-cart table.cart tr:first-child td { border-top: 0; }
.woocommerce-cart table.cart td.product-thumbnail img { width: 72px; height: 72px; border-radius: 9px; object-fit: cover; border: 1px solid rgba(58,40,32,.1); }
.woocommerce-cart table.cart td.product-name a { font-family: var(--gfo-font-display); font-weight: 700; font-size: 16px; color: var(--gfo-ink); text-decoration: none; }
.woocommerce-cart td.product-name .variation { font-size: 12px; color: var(--gfo-text-muted); margin: 4px 0 0; }
.woocommerce-cart td.product-price, .woocommerce-cart td.product-subtotal { font-family: var(--gfo-font-display); font-weight: 700; color: var(--gfo-ink); text-align: right; }
.woocommerce-cart .product-remove a.remove { color: var(--gfo-text-hint) !important; font-size: 20px; }
.woocommerce-cart .quantity input.qty { width: 62px; padding: 10px 6px; border: 1px solid rgba(58,40,32,.2); border-radius: 8px; text-align: center; font-weight: 600; }
.woocommerce-cart .actions { padding: 16px 20px; }
.woocommerce-cart .actions .coupon { display: flex; gap: 8px; }
.woocommerce-cart .actions .coupon input#coupon_code { flex: 1; max-width: 220px; padding: 11px 13px; border: 1px solid rgba(58,40,32,.2); border-radius: 8px; }
.woocommerce-cart .actions .coupon button, .woocommerce-cart .actions > button[name="update_cart"] { background: var(--gfo-ink); color: #fff; border: 0; border-radius: 8px; padding: 11px 16px; font-weight: 600; font-size: 12px; cursor: pointer; }

/* Cross-sell under the items */
.woocommerce-cart .cross-sells { margin-top: 20px; }
.woocommerce-cart .cross-sells > h2 { font-size: var(--gfo-fs-h3); }
.woocommerce-cart .cross-sells ul.products { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; list-style: none; margin: 0; padding: 0; }

/* Order summary (cart totals) */
.woocommerce-cart .cart_totals { background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 14px; padding: 24px; }
.woocommerce-cart .cart_totals h2 { font-size: 18px; margin: 0 0 16px; }
.woocommerce-cart .cart_totals table { width: 100%; border: 0; margin: 0; }
.woocommerce-cart .cart_totals table th, .woocommerce-cart .cart_totals table td { border: 0; padding: 8px 0; font-size: 14px; text-align: left; }
.woocommerce-cart .cart_totals table td { text-align: right; }
.woocommerce-cart .cart_totals .order-total th, .woocommerce-cart .cart_totals .order-total td { font-family: var(--gfo-font-display); font-weight: 700; font-size: 18px; border-top: 1px solid rgba(58,40,32,.12); padding-top: 14px; }
.woocommerce-cart .wc-proceed-to-checkout { padding: 16px 0 0; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button { display: block; width: 100%; text-align: center; background: var(--gfo-terracotta); color: #fff; border-radius: 9px; padding: 16px; font-family: var(--gfo-font-body); font-weight: 700; font-size: 15px; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover { background: #a95930; }

/* Empty cart */
.woocommerce-cart .cart-empty.woocommerce-info, .woocommerce-cart .wc-empty-cart-message { background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 14px; padding: 48px 40px; text-align: center; font-size: 16px; }
.woocommerce-cart .return-to-shop { text-align: center; margin-top: 16px; }
.woocommerce-cart .return-to-shop a.button { display: inline-block; background: var(--gfo-terracotta); color: #fff; border-radius: 8px; padding: 14px 28px; font-weight: 600; text-decoration: none; }

/* ---------------- Checkout ---------------- */
.woocommerce-checkout form.checkout { display: grid; grid-template-columns: 1.4fr .9fr; gap: 32px; align-items: start; }
.woocommerce-checkout #customer_details { grid-column: 1; min-width: 0; }
/* Stack WooCommerce's internal billing/shipping columns so the page is a clean
   2-column layout (customer details | order review), not 3 cramped columns. */
.woocommerce-checkout #customer_details.col2-set { display: block; width: 100%; }
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 { width: 100%; float: none; margin: 0 0 18px; }
.woocommerce-checkout h3 { font-size: var(--gfo-fs-h3); }
.woocommerce-checkout .woocommerce-billing-fields, .woocommerce-checkout .woocommerce-shipping-fields, .woocommerce-checkout .woocommerce-additional-fields { background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 12px; padding: 22px; margin-bottom: 18px; }
.woocommerce-checkout .form-row input.input-text, .woocommerce-checkout .form-row textarea, .woocommerce-checkout .select2-container, .woocommerce-checkout .form-row select { width: 100%; }
.woocommerce-checkout .form-row input.input-text, .woocommerce-checkout .form-row textarea, .woocommerce-checkout .form-row select { padding: 12px 13px; border: 1px solid rgba(58,40,32,.22); border-radius: 8px; font: 500 14px var(--gfo-font-body); background: #fff; }
.woocommerce-checkout #order_review_heading { grid-column: 2; margin: 0 0 12px; font-size: 18px; }
.woocommerce-checkout #order_review { grid-column: 2; position: sticky; top: 24px; background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 14px; padding: 22px; }
.woocommerce-checkout #order_review .shop_table { width: 100%; }
.woocommerce-checkout #order_review .order-total .amount { font-family: var(--gfo-font-display); font-weight: 700; font-size: 18px; }
.woocommerce-checkout #payment { background: transparent; border-radius: 0; }
.woocommerce-checkout #payment ul.payment_methods { border: 0; padding: 0; }
.woocommerce-checkout #place_order { display: block; width: 100%; background: var(--gfo-terracotta); color: #fff; border: 0; border-radius: 9px; padding: 16px; font-family: var(--gfo-font-body); font-weight: 700; font-size: 15px; cursor: pointer; margin-top: 8px; }
.woocommerce-checkout #place_order:hover { background: #a95930; }
.woocommerce-checkout .woocommerce-order { max-width: 760px; } /* thank-you / confirmation */

/* ---------------- My Account ---------------- */
.woocommerce-account .woocommerce { display: grid; grid-template-columns: 240px 1fr; gap: 32px; align-items: start; }
.woocommerce-account.logged-in .woocommerce > .woocommerce-notices-wrapper { grid-column: 1 / -1; }
.woocommerce-account .woocommerce-MyAccount-navigation { background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 12px; padding: 10px; }
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 11px 14px; border-radius: 8px; color: var(--gfo-ink); text-decoration: none; font-weight: 500; font-size: 14px; }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a, .woocommerce-account .woocommerce-MyAccount-navigation li a:hover { background: var(--gfo-soft); color: var(--gfo-terracotta); }
.woocommerce-account .woocommerce-MyAccount-content { min-width: 0; }
/* Logged-out login/register forms */
.woocommerce-account:not(.logged-in) .woocommerce { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
.woocommerce-account .woocommerce form.login, .woocommerce-account .woocommerce form.register { background: var(--gfo-surface); border: 1px solid rgba(58,40,32,.14); border-radius: 12px; padding: 26px; }
.woocommerce-account .woocommerce form .input-text { width: 100%; padding: 12px 13px; border: 1px solid rgba(58,40,32,.22); border-radius: 8px; }
.woocommerce-account .woocommerce button.button, .woocommerce-account .woocommerce .button { background: var(--gfo-terracotta); color: #fff; border: 0; border-radius: var(--gfo-radius-btn); padding: 13px 20px; font-weight: 600; cursor: pointer; }

/* ---------------- Responsive ---------------- */
@media (max-width: 900px) {
  .woocommerce-cart .woocommerce, .woocommerce-checkout form.checkout, .woocommerce-account .woocommerce { grid-template-columns: 1fr; }
  .woocommerce-cart form.woocommerce-cart-form, .woocommerce-cart .cart-collaterals,
  .woocommerce-checkout #customer_details, .woocommerce-checkout #order_review, .woocommerce-checkout #order_review_heading { grid-column: 1; position: static; }
  .woocommerce-cart .cross-sells ul.products { grid-template-columns: 1fr; }
}
