/* ═══════════════════════════════════════════════════════════════════════════════
   GPS HOTFIX — CART / CHECKOUT / SHOP POLISH
   June 2026 — loads LAST via @import in style.css so it wins all ties.

   Root causes fixed:
   1. Authorize.Net plugin hardcodes inline margin-left:40px + width:90%!important
      on card fields  →  margin override + min-width:100% trick (min-width beats
      width in layout, even inline !important width).
   2. WooCommerce puts the payment radio as a SIBLING before the label, but the
      old CSS only flexed the label  →  radio floated detached top-left. Fixed
      with grid on the <li>.
   3. Flatsome nests a whole <table class="shipping__table"> inside the totals
      tfoot; "tfoot tr {display:flex}" was hitting the nested rows too  →  scoped.
   4. Phantom duplicate "Cart totals" header table in the cart sidebar markup
      →  hidden here (remove from template later).
   5. Cart item grid had no area for td.product-price + Flatsome injects a
      duplicate .mobile-product-price  →  stray lines / overlap. Cleaned.
   6. yellow-pencil-rescued.css typo: shipping__inner width:10% at ≤700px
      →  corrected to 100% here.
   ═══════════════════════════════════════════════════════════════════════════════ */


/* ═══════════════════════════════════════════════════════════════════════════════
   1. CHECKOUT — PAYMENT METHOD CARDS (radio + label + box alignment)
   ═══════════════════════════════════════════════════════════════════════════════ */

#payment .wc_payment_method {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  align-items: center !important;
  overflow: hidden !important;
}

#payment .wc_payment_method > input[type="radio"] {
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 22px !important;
  height: 22px !important;
  margin: 0 0 0 18px !important;
  accent-color: var(--color-accent) !important;
  flex-shrink: 0 !important;
}

#payment .wc_payment_method > label {
  grid-column: 2 !important;
  grid-row: 1 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 18px 18px 18px 14px !important;
  margin: 0 !important;
  min-height: 0 !important;
  background: transparent !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  cursor: pointer !important;
}

/* If the radio is hidden (e.g. $WEEDSEED on some breakpoints), keep label flush */
#payment .wc_payment_method > input[type="radio"][style*="display: none"] + label,
#payment .wc_payment_method > label:first-child {
  padding-left: 18px !important;
}

/* Card brand icons: group them on the right, vertically centered */
#payment .wc_payment_method > label img {
  max-height: 24px !important;
  width: auto !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
}
#payment .wc_payment_method > label img:first-of-type {
  margin-left: auto !important;
}

/* Payment box spans full card width below the radio/label row */
#payment .wc_payment_method .payment_box {
  grid-column: 1 / -1 !important;
  width: 100% !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   2. CHECKOUT — AUTHORIZE.NET CARD FIELDS (kills plugin inline styles)
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Plugin hardcodes style="margin-left: 40px;" — inline but NOT !important, so this wins */
#payment .payment_box .woocommerce-billing-fields__field-wrapper_credit_card {
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

/* Plugin hardcodes style="width: 90% !important;" on every input/select.
   min-width beats width in CSS layout — full-width fields restored. */
#payment .payment_box input.text-input-credit-card,
#payment .payment_box select.text-input-credit-card {
  min-width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Style the <select> dropdowns to match the inputs (old CSS only hit input) */
#payment .payment_box select {
  width: 100% !important;
  height: 50px !important;
  background: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 10px !important;
  padding: 0 14px !important;
  color: var(--color-text-primary) !important;
  font-family: var(--font-mono) !important;
  font-size: 16px !important; /* prevents iOS zoom */
}

#payment .payment_box select:focus {
  border-color: var(--color-accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15) !important;
}

/* Card number + CVV / Month + Year pairs: 2-up on desktop, stacked on mobile */
#payment .payment_box .form-row-pair {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0 14px !important;
  margin: 0 !important;
}

#payment .payment_box .form-row-pair .form-row {
  width: 100% !important;
  margin: 0 0 14px 0 !important;
  padding: 0 !important;
  float: none !important;
}

#payment .payment_box .woocommerce-input-wrapper {
  display: block !important;
  width: 100% !important;
}

@media (max-width: 640px) {
  #payment .payment_box .form-row-pair {
    grid-template-columns: 1fr !important;
  }
  #payment .wc_payment_method > label img {
    max-height: 20px !important;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════════
   3. ORDER REVIEW TABLE — scope the flex rows, fix nested shipping table
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Reset the over-broad rule that was flexing nested shipping table rows */
.woocommerce-checkout-review-order-table tfoot tr {
  display: block !important;
  padding: 0 !important;
}

/* Only true total rows get the label-left / amount-right flex treatment */
.woocommerce-checkout-review-order-table tfoot tr.cart-subtotal,
.woocommerce-checkout-review-order-table tfoot tr.cart-discount,
.woocommerce-checkout-review-order-table tfoot tr.fee,
.woocommerce-checkout-review-order-table tfoot tr.tax-total,
.woocommerce-checkout-review-order-table tfoot tr.tax-rate,
.woocommerce-checkout-review-order-table tfoot tr.order-total {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  gap: 16px !important;
  padding: 12px 0 !important;
}

.woocommerce-checkout-review-order-table tfoot tr.order-total {
  border-top: 2px solid var(--color-border) !important;
  margin-top: 8px !important;
  padding-top: 16px !important;
}

/* Keep big totals from clipping at the container edge */
.woocommerce-checkout-review-order-table tfoot td {
  overflow: visible !important;
}
.woocommerce-checkout-review-order-table .order-total .amount {
  font-size: 24px !important;
  white-space: nowrap !important;
}

/* Product line items in the review: name left, price right, single clean rule */
.woocommerce-checkout-review-order-table tbody tr.cart_item {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 16px !important;
  padding: 12px 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--color-border) !important;
}

.woocommerce-checkout-review-order-table tbody td,
.woocommerce-checkout-review-order-table tfoot th,
.woocommerce-checkout-review-order-table tfoot td {
  border: none !important;
  padding: 0 !important;
  background: transparent !important;
}

.woocommerce-checkout-review-order-table td.product-name {
  flex: 1 !important;
  text-align: left !important;
  line-height: 1.45 !important;
}

.woocommerce-checkout-review-order-table td.product-total {
  white-space: nowrap !important;
  text-align: right !important;
}

/* Kill Flatsome's responsive-table data-title pseudo labels (duplicate text) */
.woocommerce-checkout-review-order-table td::before,
.cart_totals .shop_table_responsive td::before {
  display: none !important;
  content: none !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   4. NESTED SHIPPING TABLE (Flatsome wraps options in a table-in-a-table)
   Applies to BOTH cart totals and checkout review.
   ═══════════════════════════════════════════════════════════════════════════════ */

tr.woocommerce-shipping-totals,
tr.woocommerce-shipping-totals td.shipping__inner,
.shipping__table,
.shipping__table tbody,
.shipping__table tr,
.shipping__table td {
  display: block !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
}

tr.woocommerce-shipping-totals {
  margin: 16px 0 !important;
}

/* "Shipment" heading: small uppercase section label */
.shipping__table th {
  display: block !important;
  width: 100% !important;
  padding: 0 0 10px 0 !important;
  border: none !important;
  background: transparent !important;
  text-align: left !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--color-text-muted) !important;
}

/* Fixes the yellow-pencil width:10% typo at ≤700px (this file loads later, so it wins) */
@media (max-width: 700px) {
  body.page-id-61 .woocommerce-shipping-totals .shipping__inner {
    width: 100% !important;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════════
   5. SHIPPING OPTION CARDS — compact, name left + price right on ONE line
   ═══════════════════════════════════════════════════════════════════════════════ */

#shipping_method li,
.cart_totals #shipping_method li {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 13px 14px !important;
  margin: 0 0 8px 0 !important;
  min-height: 0 !important;
  background: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 12px !important;
  cursor: pointer !important;
}

#shipping_method li:last-child {
  margin-bottom: 0 !important;
}

#shipping_method li:has(input:checked) {
  border-color: var(--color-accent) !important;
  background: rgba(34, 197, 94, 0.1) !important;
  box-shadow: 0 0 0 1px var(--color-accent) !important;
}

#shipping_method label,
.cart_totals #shipping_method label {
  flex: 1 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 4px 12px !important;
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  color: var(--color-text-body) !important;
  cursor: pointer !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

#shipping_method label .amount {
  margin-left: auto !important;
  white-space: nowrap !important;
  font-family: var(--font-mono) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--color-accent) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   6. CART TOTALS SIDEBAR
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Phantom duplicate "Cart totals" header table in the markup — hide it.
   (Permanent fix: delete it from the cart-totals template override.) */
.cart_totals > table:not(.shop_table) {
  display: none !important;
}

/* Let big numbers breathe — undo overflow clipping */
.cart-collaterals {
  overflow: visible !important;
  contain: none !important;
}

.cart_totals table.shop_table {
  display: block !important;
  width: 100% !important;
  table-layout: auto !important;
}
.cart_totals table.shop_table tbody {
  display: block !important;
  width: 100% !important;
}

.cart_totals table.shop_table tr.cart-subtotal,
.cart_totals table.shop_table tr.cart-discount,
.cart_totals table.shop_table tr.fee,
.cart_totals table.shop_table tr.order-total {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  gap: 16px !important;
  padding: 12px 0 !important;
  border: none !important;
  width: 100% !important;
}

.cart_totals table.shop_table th,
.cart_totals table.shop_table td {
  width: auto !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  text-align: left !important;
}

.cart_totals table.shop_table td {
  text-align: right !important;
}

.cart_totals tr.order-total {
  border-top: 1px solid var(--color-border) !important;
  margin-top: 10px !important;
  padding-top: 16px !important;
}

.cart_totals .order-total .amount {
  font-size: 24px !important;
  white-space: nowrap !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   7. CART LINE ITEMS — assign the orphan price cell, kill duplicates & stray lines
   ═══════════════════════════════════════════════════════════════════════════════ */

/* td.product-price had no grid-area → it was auto-flowing and breaking the grid */
.shop_table.cart td.product-price {
  display: none !important;
}

/* Flatsome injects "1 x $150.00" under the name — duplicate of the subtotal cell */
.shop_table.cart .mobile-product-price {
  display: none !important;
}

/* No borders/lines inside item cards from responsive-table styles */
.shop_table.cart td,
.shop_table.cart .cart_item td {
  border: none !important;
  box-shadow: none !important;
}
.shop_table.cart td::before {
  display: none !important;
  content: none !important;
}

/* Remove (X) button: pinned neatly inside the card's top-right corner */
.shop_table.cart td.product-remove {
  grid-area: remove !important;
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 38px !important;
  height: 38px !important;
  margin: 0 !important;
}

.shop_table.cart .product-remove a.remove {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  border-radius: 10px !important;
  background: rgba(239, 68, 68, 0.08) !important;
  border: 1px solid rgba(239, 68, 68, 0.3) !important;
  color: #f87171 !important;
  font-size: 20px !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

/* Give the name room so it doesn't run under the X */
.shop_table.cart td.product-name {
  padding-right: 44px !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   8. CART ACTIONS — coupon + buttons, consistent heights
   ═══════════════════════════════════════════════════════════════════════════════ */

.shop_table.cart td.actions {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  background: linear-gradient(135deg, rgba(17, 24, 39, 0.95) 0%, rgba(30, 41, 59, 0.8) 100%) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 16px !important;
  padding: 20px !important;
}

.shop_table.cart .actions .coupon {
  margin: 0 !important;
}

.shop_table.cart .actions .coupon h3 {
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--color-text-muted) !important;
  margin: 0 0 10px 0 !important;
}

.shop_table.cart .actions .coupon .flex-row {
  align-items: stretch !important;
  gap: 10px !important;
}

.shop_table.cart .actions .coupon .input-text,
.shop_table.cart .actions .coupon button[name="apply_coupon"] {
  height: 48px !important;
  margin: 0 !important;
  border-radius: 10px !important;
  box-sizing: border-box !important;
}

.shop_table.cart .actions .coupon .input-text {
  font-size: 16px !important; /* prevents iOS zoom */
}

.shop_table.cart .actions .continue-shopping {
  float: none !important;
  width: 100% !important;
}

.shop_table.cart .actions .continue-shopping a,
.shop_table.cart .actions button[name="update_cart"] {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 48px !important;
  margin: 0 !important;
  border-radius: 10px !important;
  font-size: 14px !important;
}

@media (min-width: 850px) {
  .shop_table.cart .actions .continue-shopping a,
  .shop_table.cart .actions button[name="update_cart"] {
    width: auto !important;
    min-width: 220px !important;
    align-self: flex-start !important;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════════
   9. CHECKOUT — LOGIN / COUPON TOGGLE BOXES (kill the offset green tab)
   ═══════════════════════════════════════════════════════════════════════════════ */

.woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-form-coupon-toggle .woocommerce-info {
  display: block !important;
  background: linear-gradient(135deg, rgba(17, 24, 39, 0.95) 0%, rgba(30, 41, 59, 0.8) 100%) !important;
  border: 1px solid var(--color-border) !important;
  border-left: 1px solid var(--color-border) !important;
  border-radius: 16px !important;
  padding: 18px 20px !important;
  margin: 0 0 16px 0 !important;
  overflow: hidden !important;
  text-align: center !important;
  color: var(--color-text-secondary) !important;
  font-size: 14px !important;
}

.woocommerce-form-login-toggle .woocommerce-info::before,
.woocommerce-form-coupon-toggle .woocommerce-info::before {
  display: none !important;
  content: none !important;
}

.woocommerce-form-login-toggle .message-container {
  padding: 0 !important;
}

/* Match the login button to the coupon button */
.woocommerce-form-login-toggle .showlogin {
  display: block !important;
  width: 100% !important;
  padding: 14px 20px !important;
  margin-top: 12px !important;
  background: var(--color-accent) !important;
  border: none !important;
  border-radius: 10px !important;
  color: #000 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  text-decoration: none !important;
  text-align: center !important;
  cursor: pointer !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   10. PRODUCT PAGE — quantity stepper glyphs + accordion chevrons
   ═══════════════════════════════════════════════════════════════════════════════ */

/* +/- are <input type="button"> — make the value text bulletproof-visible */
.product .quantity .minus,
.product .quantity .plus,
.shop_table.cart .quantity .minus,
.shop_table.cart .quantity .plus,
.ux-quantity__button {
  text-indent: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
  font-size: 22px !important;
  font-weight: 600 !important;
  color: #f1f5f9 !important;
  -webkit-text-fill-color: #f1f5f9 !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

.product .quantity .minus:hover,
.product .quantity .plus:hover {
  color: var(--gps-green, #22c55e) !important;
  -webkit-text-fill-color: var(--gps-green, #22c55e) !important;
}

/* Accordion: reserve space for the chevron so it stops overlapping the title */
.product-page-accordian .accordion-title,
.accordion .accordion-title {
  position: relative !important;
  display: block !important;
  padding: 16px 18px 16px 50px !important;
  line-height: 1.4 !important;
}

.product-page-accordian .accordion-title .toggle,
.accordion .accordion-title .toggle {
  position: absolute !important;
  left: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 32px !important;
  height: 32px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   11. SHOP / CATEGORY — sort dropdown clipping + price alignment
   ═══════════════════════════════════════════════════════════════════════════════ */

.woocommerce-ordering {
  overflow: visible !important;
  margin: 0 auto 16px !important;
}

.woocommerce-ordering select,
select[name="orderby"] {
  height: 44px !important;
  line-height: normal !important;
  padding: 0 38px 0 14px !important;
  font-size: 14px !important;
  border-radius: 10px !important;
  background-color: var(--color-bg-surface, #111827) !important;
  border: 1px solid var(--color-border, #334155) !important;
  color: var(--color-text-primary, #f1f5f9) !important;
  box-sizing: border-box !important;
}

/* Consistent card price block: ranges that wrap don't shove the layout around */
.product-small .price-wrapper,
.product-small .price {
  min-height: 26px !important;
}

@media (max-width: 640px) {
  .product-small .price,
  .product-small .price .amount {
    font-size: 15px !important;
    line-height: 1.35 !important;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════════
   12. CHATBOT LAUNCHER — stop it covering cart totals / place-order on mobile
   (was sitting directly on top of the subtotal in cart screenshots)
   ═══════════════════════════════════════════════════════════════════════════════ */

@media (max-width: 849px) {
  body.woocommerce-cart #gps-chat-launcher,
  body.woocommerce-checkout #gps-chat-launcher {
    bottom: 96px !important;
    right: 14px !important;
    width: 48px !important;
    height: 48px !important;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════════
   13. CART TOTALS — tax rows were missing from the flex treatment
   ═══════════════════════════════════════════════════════════════════════════════ */

.cart_totals table.shop_table tr.tax-total,
.cart_totals table.shop_table tr.tax-rate {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  gap: 16px !important;
  padding: 12px 0 !important;
  border: none !important;
  width: 100% !important;
}

.cart_totals table.shop_table tr.tax-total th,
.cart_totals table.shop_table tr.tax-rate th {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   14. CART ACTIONS — desktop coupon row (input was collapsing, button overflowing)
   ═══════════════════════════════════════════════════════════════════════════════ */

.shop_table.cart td.actions,
.shop_table.cart td.actions * {
  box-sizing: border-box !important;
  max-width: 100% !important;
}

.shop_table.cart .actions .coupon h3 {
  border: none !important;
  padding: 0 !important;
}

.shop_table.cart .actions .coupon .flex-row {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch !important;
  gap: 10px !important;
  width: 100% !important;
}

.shop_table.cart .actions .coupon .flex-col.flex-grow {
  flex: 1 1 240px !important;
  min-width: 0 !important;
}

.shop_table.cart .actions .coupon .input-text {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  height: 48px !important;
  padding: 0 16px !important;
  background: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 10px !important;
  color: var(--color-text-primary) !important;
  font-size: 16px !important;
}

.shop_table.cart .actions .coupon .input-text:focus {
  border-color: var(--color-accent) !important;
  outline: none !important;
}

.shop_table.cart .actions .coupon button[name="apply_coupon"] {
  flex: 0 0 auto !important;
  white-space: nowrap !important;
  padding: 0 22px !important;
}

/* ── Desktop single-column checkout + card-field overflow fix ── */

/* THE actual bug: desktop payment inputs lacked box-sizing, so each
   50%-wide card field rendered 50% + 28px padding and the pair overflowed. */
#payment .payment_box input {
  box-sizing: border-box !important;
}

@media screen and (min-width: 850px) {

  /* Stack both columns into one centered column */
  .woocommerce-checkout .col-left,
  .woocommerce-checkout .large-7,
  .woocommerce-checkout .col-right,
  .woocommerce-checkout .large-5 {
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 760px !important;   /* ← raise this, or delete the line, for a wider / full-bleed column */
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    float: none !important;
  }

  /* Give the summary block air below the address form */
  .woocommerce-checkout .col-right,
  .woocommerce-checkout .large-5 {
    margin-top: 40px !important;
  }

  /* It no longer sits beside the form, so kill the sticky behavior */
  #order_review,
  .woocommerce-checkout-review-order {
    position: static !important;
    top: auto !important;
  }

}
