/* STEPS */
.steps-bar { max-width: 700px !important; margin: 0 auto !important; padding: 32px 40px 16px !important; }
.steps { display: flex; align-items: center; gap: 0; }
.step { display: flex; align-items: center; gap: 9px; font-size: 12px; font-weight: 700; color: var(--ink-4); }
.step.on { color: var(--blue); }
.step.done { color: var(--green); }
.step-num { width: 24px; height: 24px; border-radius: 50%; border: 2px solid var(--ink-5); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 800; flex-shrink: 0; }
.step.on .step-num { border-color: var(--blue); background: var(--blue); color: white; }
.step.done .step-num { border-color: var(--green); background: var(--green); color: white; }
.step-line { flex: 1; height: 1.5px; background: var(--surf-3); margin: 0 12px; }
.step-line.done { background: var(--green); }

/* CART LAYOUT */
.cart-sec { padding: 44px 0 72px; }
.cart-sec > .w,
.checkout-sec > .w { padding-left: 100px; padding-right: 100px; }
.cart-grid { display: grid; grid-template-columns: 1fr 360px; gap: 28px; align-items: start; }
.page-title { font-size: clamp(22px,2.5vw,30px); font-weight: 900; letter-spacing: -.045em; color: var(--ink); margin-bottom: 24px; }

/* NOTICES inside cart/checkout */
.cart-sec .joopzy-notice,
.checkout-sec .joopzy-notice,
.cart-sec .woocommerce-error,
.cart-sec .woocommerce-message,
.cart-sec .woocommerce-info,
.checkout-sec .woocommerce-error,
.checkout-sec .woocommerce-message,
.checkout-sec .woocommerce-info { margin-bottom: 20px; border-radius: var(--r); }

/* Hide default WC coupon notice — replaced by joopzy-coupon-toggle */
.woocommerce-form-coupon-toggle { display: none !important; }

/* COUPON TOGGLE */
.joopzy-coupon-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 12px 18px;
  background: var(--blue-pale);
  border: 1px solid var(--blue-soft);
  border-radius: var(--r);
  margin-bottom: 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--blue);
}

.joopzy-coupon-toggle svg {
  flex-shrink: 0;
  opacity: .7;
}

.joopzy-coupon-toggle span {
  color: var(--ink-2);
}

.joopzy-coupon-toggle a {
  color: var(--blue);
  font-weight: 700;
  text-decoration: none;
  margin-left: 2px;
  transition: opacity .15s;
}

.joopzy-coupon-toggle a:hover {
  opacity: .7;
  text-decoration: underline;
}

/* COUPON FORM */
.joopzy-coupon-form {
  margin-bottom: 20px;
  border: none !important;
  padding: 0 !important;
  background: none !important;
}

.joopzy-coupon-form__inner {
  display: flex;
  gap: 0;
  border: 1.5px solid var(--border-md);
  border-radius: var(--r);
  overflow: hidden;
  background: var(--white);
  transition: border-color .15s, box-shadow .15s;
}

.joopzy-coupon-form__inner:focus-within {
  border-color: var(--blue-hi);
  box-shadow: 0 0 0 3px rgba(46,100,153,.1);
}

.joopzy-coupon-form__input {
  flex: 1;
  height: 42px;
  padding: 0 14px;
  border: none;
  outline: none;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  background: transparent;
  min-width: 0;
}

.joopzy-coupon-form__input::placeholder {
  color: var(--ink-4);
  font-weight: 400;
}

.joopzy-coupon-form__btn {
  flex-shrink: 0;
  height: 42px;
  padding: 0 22px;
  background: var(--ink);
  color: var(--white);
  border: none;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}

.joopzy-coupon-form__btn:hover {
  background: var(--blue);
}

@media (max-width: 480px) {
  .joopzy-coupon-form__inner {
    flex-direction: column;
    border-radius: var(--r);
  }
  .joopzy-coupon-form__input {
    border-bottom: 1px solid var(--border);
  }
  .joopzy-coupon-form__btn {
    border-radius: 0;
  }
}

/* CART ITEMS */
.joopzy-cart-items { background: var(--white); border-radius: var(--r-xl); border: 1px solid var(--border); overflow: hidden; }
.joopzy-cart-item { display: flex; align-items: center; gap: 16px; padding: 20px; border-bottom: 1px solid var(--border); }
.joopzy-cart-item:last-child { border-bottom: none; }
.ci-img { width: 72px; height: 72px; border-radius: var(--r-md); background: var(--blue-pale); flex-shrink: 0; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.ci-img img { width: 100%; height: 100%; object-fit: cover; }
.ci-info { flex: 1; min-width: 0; }
.ci-name { font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 4px; line-height: 1.35; }
.ci-name a { color: inherit; }
.ci-meta { font-size: 11px; font-weight: 600; color: var(--ink-4); margin-bottom: 10px; }
.ci-qty { display: flex; align-items: center; gap: 0; border: 1.5px solid var(--border-md); border-radius: var(--r); overflow: hidden; width: fit-content; }
.ci-qbtn { width: 32px; height: 30px; display: flex; align-items: center; justify-content: center; font-size: 16px; font-weight: 300; color: var(--ink-3); cursor: pointer; transition: background .15s; background: none; border: none; font-family: var(--font); }
.ci-qbtn:hover { background: var(--surf-2); }
.ci-qnum { width: 32px; text-align: center; font-size: 13px; font-weight: 700; color: var(--ink); }
.ci-right { text-align: right; flex-shrink: 0; }
.ci-price { font-size: 16px; font-weight: 800; color: var(--ink); letter-spacing: -.02em; margin-bottom: 8px; }
.ci-remove { font-size: 10px; font-weight: 700; color: var(--ink-4); cursor: pointer; transition: color .15s; background: none; border: none; font-family: var(--font); }
.ci-remove:hover { color: var(--red); }

/* PROMO */
.promo-row { background: var(--white); border-radius: var(--r-lg); border: 1px solid var(--border); padding: 16px 20px; margin-top: 12px; display: flex; gap: 10px; }
.promo-input { flex: 1; border: none; outline: none; font-family: var(--font); font-size: 13px; font-weight: 500; color: var(--ink); }
.promo-input::placeholder { color: var(--ink-4); }
.promo-btn { height: 36px; padding: 0 18px; background: var(--ink); color: white; border-radius: var(--r); font-size: 12px; font-weight: 700; transition: background .15s; border: none; cursor: pointer; font-family: var(--font); }
.promo-btn:hover { background: var(--blue); }

/* ORDER SUMMARY */
.joopzy-summary { background: var(--white); border-radius: var(--r-xl); border: 1px solid var(--border); padding: 24px; position: sticky; top: 90px; }
.admin-bar .joopzy-summary { top: 122px; }
@media (max-width: 782px) { .admin-bar .joopzy-summary { top: 136px; } }
.joopzy-summary h3 { font-size: 14px; font-weight: 800; letter-spacing: -.02em; color: var(--ink); margin-bottom: 20px; }
.sum-row { display: flex; justify-content: space-between; font-size: 13px; font-weight: 500; color: var(--ink-3); margin-bottom: 10px; }
.sum-row.total { font-size: 16px; font-weight: 800; color: var(--ink); margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border); }
.sum-row .green { color: var(--green); font-weight: 700; }
.checkout-btn { width: 100%; height: 52px; background: var(--ink); color: white; border-radius: var(--r); font-size: 14px; font-weight: 800; display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 20px; cursor: pointer; transition: background .15s, transform .15s; border: none; font-family: var(--font); }
.checkout-btn:hover { background: var(--blue); transform: translateY(-1px); }
.trust-list { margin-top: 18px; display: grid; gap: 7px; }
.tl { display: flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 600; color: var(--ink-4); }
.tl svg { width: 13px; height: 13px; flex-shrink: 0; color: var(--green); }

/* CHECKOUT FORM */
.checkout-sec { padding: 44px 0 72px; }
.checkout-grid { display: grid; grid-template-columns: 1fr 380px; gap: 28px; align-items: start; }
.form-card { background: var(--white); border-radius: var(--r-xl); border: 1px solid var(--border); padding: 28px 28px 32px; }
.form-card + .form-card { margin-top: 16px; }
.fc-title { font-size: 15px; font-weight: 800; letter-spacing: -.025em; color: var(--ink); margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
.fc-num { width: 24px; height: 24px; border-radius: 50%; background: var(--blue); color: white; font-size: 10px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* EXPRESS CHECKOUT (CheckoutWC / Stripe / PayPal) */
#cfw-payment-request-buttons {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-xl) !important;
  padding: 24px 28px 20px !important;
  margin-bottom: 0 !important;
  min-height: auto !important;
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

/* "Express Checkout" heading as floating label */
#cfw-payment-request-buttons h2 {
  position: absolute !important;
  top: -10px !important;
  left: 24px !important;
  transform: none !important;
  background: var(--bg, #f4f5f7) !important;
  padding: 0 10px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: var(--ink-3) !important;
  white-space: nowrap !important;
  margin: 0 !important;
}

/* Payment button wrappers */
#cfw-payment-request-buttons > div {
  max-width: 180px !important;
  min-width: 160px !important;
  max-height: 44px !important;
  min-height: 44px !important;
  border-radius: var(--r) !important;
  overflow: hidden !important;
  border: none !important;
  margin: 0 !important;
  flex: 1 1 160px !important;
}

/* Stripe button wrapper */
#cfw-payment-request-buttons > #wc-stripe-payment-request-wrapper,
#cfw-payment-request-buttons > #wcpay-payment-request-wrapper,
#cfw-payment-request-buttons > .wc-stripe-checkout-banner-gateway,
#cfw-payment-request-buttons > div[id*="stripe"] {
  border-radius: var(--r) !important;
  overflow: hidden !important;
}

/* PayPal button wrapper */
#cfw-payment-request-buttons > #checkout_paypal_message,
#cfw-payment-request-buttons > div[id*="paypal"],
#cfw-payment-request-buttons > div[class*="paypal"] {
  border-radius: var(--r) !important;
  overflow: hidden !important;
}

/* Stripe banner checkout list */
#cfw-payment-request-buttons ul.wc_stripe_checkout_banner_gateways {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  gap: 10px !important;
  width: 100% !important;
  justify-content: center !important;
}

#cfw-payment-request-buttons ul.wc_stripe_checkout_banner_gateways li {
  max-width: 180px !important;
  min-width: 160px !important;
  max-height: 44px !important;
  min-height: 44px !important;
  border-radius: var(--r) !important;
  overflow: hidden !important;
  flex: 1 1 160px !important;
  margin: 0 !important;
}

/* "OR" separator */
#payment-info-separator-wrap {
  margin: 16px 0 !important;
}

.pay-button-separator {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 0 !important;
  margin: 0 !important;
  position: static !important;
}

.pay-button-separator::before,
.pay-button-separator::after {
  content: '' !important;
  flex: 1 !important;
  height: 1px !important;
  background: var(--border-md) !important;
  display: block !important;
  position: static !important;
  top: auto !important;
  width: auto !important;
  z-index: auto !important;
  transform: none !important;
}

.pay-button-separator span {
  position: static !important;
  transform: none !important;
  background: none !important;
  padding: 0 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: var(--ink-4) !important;
  white-space: nowrap !important;
}

/* Also handle Stripe's own separator if rendered outside CheckoutWC */
.apple-pay-button-checkout-separator,
.wc-stripe-express-checkout-banner-separator {
  display: none !important;
}

/* Hide WC's own billing heading — our .fc-title replaces it */
.form-card .woocommerce-billing-fields > h3 { display: none; }

/* "Ship to a different address?" checkbox heading */
.form-card #ship-to-different-address {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 4px;
}
.form-card #ship-to-different-address label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
}
.form-card #ship-to-different-address input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--blue);
}
/* Hide any other h3 inside shipping fields that isn't the checkbox */
.form-card .woocommerce-shipping-fields > h3:not(#ship-to-different-address) { display: none; }

/* Additional information / order notes section */
.form-card .woocommerce-additional-fields {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}
.form-card .woocommerce-additional-fields > h3 {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink-2);
  margin: 0 0 14px;
}

/* Order notes field — always full width */
#order_comments_field { grid-column: 1 / -1; }

/* Spacing above the shipping address fields when revealed */
.form-card .shipping_address { margin-top: 18px; }

/* Checkout field grid: 6-col for flexible 2-col and 3-col rows */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce-additional-fields__field-wrapper {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 18px 16px;
}

/* Reset WC float-based layout */
.checkout .form-row { margin: 0; padding: 0; float: none; width: auto; }
.checkout .form-row::before,
.checkout .form-row::after { display: none; }

/* Field sizing */
.checkout .form-row-wide { grid-column: span 6; }
.checkout .form-row-first { grid-column: span 3; }
.checkout .form-row-last { grid-column: span 3; }

/* Postcode + City + State: 3 across */
#billing_postcode_field,
#billing_city_field,
#billing_state_field,
#shipping_postcode_field,
#shipping_city_field,
#shipping_state_field { grid-column: span 2; }

/* Phone + Email: each full width */
#billing_phone_field,
#billing_email_field { grid-column: span 6; }

/* Labels */
.checkout .form-row label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink-2);
  margin-bottom: 6px;
  letter-spacing: .01em;
}
.checkout .form-row label .required { color: var(--red, #b83030); }
.checkout .form-row label .optional { font-weight: 500; color: var(--ink-4); font-size: 11px; }

/* Text inputs */
.checkout .form-row input.input-text,
.checkout .form-row textarea {
  width: 100%;
  height: 44px;
  border: 1.5px solid var(--border-md);
  border-radius: var(--r);
  padding: 0 14px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  background: var(--white);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.checkout .form-row textarea { height: auto; padding: 12px 14px; min-height: 80px; }
.checkout .form-row input.input-text:focus,
.checkout .form-row textarea:focus,
.checkout .form-row select:focus {
  border-color: var(--blue-hi);
  box-shadow: 0 0 0 3px rgba(46,100,153,.1);
}

/* Selects (country, state) */
.checkout .form-row select {
  width: 100%;
  height: 44px;
  border: 1.5px solid var(--border-md);
  border-radius: var(--r);
  padding: 0 14px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  background: var(--white);
  outline: none;
  transition: border-color .15s;
}

/* Select2 inside checkout fields */
.checkout .form-row .select2-container { width: 100% !important; }
.checkout .form-row .select2-container--default .select2-selection--single { height: 44px !important; }
.checkout .form-row .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 41px !important; }
.checkout .form-row .select2-container--default .select2-selection--single .select2-selection__arrow { height: 42px !important; }

/* Checkbox rows (create account, ship to different address) */
.checkout .woocommerce-form__label-for-checkbox { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--ink-2); cursor: pointer; }
.checkout .woocommerce-form__label-for-checkbox input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--blue); }
.checkout #ship-to-different-address { margin: 0; }
.checkout #ship-to-different-address label { font-size: 13px; font-weight: 700; color: var(--ink-2); display: flex; align-items: center; gap: 8px; cursor: pointer; }

/* Validation states */
.checkout .form-row.woocommerce-validated input.input-text { border-color: var(--green); }
.checkout .form-row.woocommerce-invalid input.input-text { border-color: var(--red); }

/* Payment card inside order summary sidebar — remove nested card styling */
.joopzy-summary .form-card {
  border: none;
  border-radius: 0;
  padding: 0;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  background: none;
}

/* PAYMENT */
.pay-methods { display: grid; gap: 8px; margin-bottom: 16px; }
.pay-opt { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1.5px solid var(--border-md); border-radius: var(--r-md); cursor: pointer; transition: border-color .15s; }
.pay-opt.selected { border-color: var(--blue); background: var(--blue-pale); }
.pay-opt-radio { width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--ink-5); flex-shrink: 0; transition: border-color .15s; display: flex; align-items: center; justify-content: center; }
.pay-opt.selected .pay-opt-radio { border-color: var(--blue); }
.pay-opt.selected .pay-opt-radio::after { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--blue); }
.pay-opt-label { font-size: 13px; font-weight: 700; color: var(--ink); flex: 1; }
.pay-opt-icons { display: flex; gap: 4px; }
.pay-ic { background: var(--surf-2); border: 1px solid var(--border); border-radius: 3px; padding: 2px 6px; font-size: 8px; font-weight: 800; color: var(--ink-3); }
.card-fields { background: var(--bg); border-radius: var(--r-md); padding: 16px; margin-top: 12px; }
.place-btn { width: 100%; height: 54px; background: var(--ink); color: white; border-radius: var(--r); font-size: 14px; font-weight: 800; display: flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; transition: background .15s; border: none; font-family: var(--font); margin-top: 16px; }
.place-btn:hover { background: var(--blue); }
.order-lock { display: flex; align-items: center; justify-content: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--ink-4); margin-top: 10px; }
.order-lock svg { width: 12px; height: 12px; }

/* CHECKOUT REVIEW ORDER */
.joopzy-review-order { margin-bottom: 16px; }
.joopzy-review-items { display: flex; flex-direction: column; gap: 12px; margin-bottom: 16px; }
.joopzy-review-item { display: flex; gap: 12px; align-items: center; }
.ri-img { width: 48px; height: 48px; border-radius: 8px; background: var(--blue-pale); flex-shrink: 0; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.ri-img img { width: 100%; height: 100%; object-fit: cover; }
.ri-info { flex: 1; min-width: 0; }
.ri-name { font-size: 12px; font-weight: 600; color: var(--ink); line-height: 1.35; }
.ri-qty { font-size: 11px; font-weight: 500; color: var(--ink-4); margin-top: 2px; }
.ri-price { font-size: 13px; font-weight: 700; color: var(--ink); flex-shrink: 0; }
.joopzy-review-totals { border-top: 1px solid var(--border); padding-top: 12px; }

/* CONFIRMATION / THANK YOU */
.joopzy-ty { max-width: 520px; margin: 48px auto; text-align: center; padding: 0 var(--px); }
.joopzy-ty__icon { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.joopzy-ty__icon--success { background: var(--green-l); color: var(--green); }
.joopzy-ty__icon--fail { background: #fef0f0; color: var(--red); }
.joopzy-ty__title { font-size: 24px; font-weight: 900; letter-spacing: -.04em; color: var(--ink); margin: 0 0 8px; }
.joopzy-ty__desc { font-size: 14px; font-weight: 500; color: var(--ink-3); line-height: 1.7; margin: 0 0 24px; }
.joopzy-ty__actions { display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap; }
.joopzy-ty__summary { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-md); padding: 16px 20px; margin-bottom: 24px; text-align: left; }
.joopzy-ty__summary-row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; }
.joopzy-ty__summary-row--total { border-top: 1.5px solid var(--border-md); margin-top: 6px; padding-top: 12px; }
.joopzy-ty__summary-label { font-size: 13px; font-weight: 500; color: var(--ink-3); }
.joopzy-ty__summary-value { font-size: 13px; font-weight: 600; color: var(--ink); }
.joopzy-ty__summary-row--total .joopzy-ty__summary-label { font-size: 14px; font-weight: 700; color: var(--ink); }
.joopzy-ty__summary-row--total .joopzy-ty__summary-value { font-size: 16px; font-weight: 800; color: var(--ink); }
.joopzy-ty__details { max-width: 640px; margin: 32px auto 0; }
.joopzy-ty .joopzy-btn-ghost { display: inline-flex; align-items: center; justify-content: center; height: 44px; padding: 0 24px; border: 1.5px solid var(--border-md); border-radius: var(--r); font-family: var(--font); font-size: 14px; font-weight: 700; color: var(--ink-2); background: transparent; cursor: pointer; transition: border-color .15s, color .15s; text-decoration: none; }
.joopzy-ty .joopzy-btn-ghost:hover { border-color: var(--ink-3); color: var(--ink); }

/* CONTINUE SHOPPING */
.continue-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 16px; font-size: 13px; font-weight: 600; color: var(--blue-hi); transition: color .15s; }
.continue-link:hover { color: var(--blue); }

/* Hide Flatsome's "Continue shopping" button if it leaks through */
.continue-shopping { display: none !important; }

/* Checkout button — ensure it renders as a solid button, not a link */
a.checkout-btn { text-decoration: none; color: white; }
a.checkout-btn:visited { color: white; }

/* WooCommerce cart table override */
.woocommerce table.shop_table { border: none; border-collapse: collapse; }

/* Hide Flatsome's cart totals header injected via woocommerce_before_cart_totals */
.cart_totals > table.shop_table > thead { display: none; }

/* Quantity input in cart items — hide spinner arrows */
.ci-qnum { -moz-appearance: textfield; appearance: textfield; border: none; outline: none; background: transparent; font-family: var(--font); }
.ci-qnum::-webkit-outer-spin-button,
.ci-qnum::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .steps-bar { padding-left: 20px !important; padding-right: 20px !important; }
  .cart-sec > .w,
  .checkout-sec > .w { padding-left: 40px; padding-right: 40px; }
}

@media (max-width: 900px) {
  .cart-grid, .checkout-grid { grid-template-columns: 1fr; }
  .joopzy-summary { position: static; }
}

@media (max-width: 640px) {
  .steps-bar { padding: 20px 16px 12px !important; }
  .step { font-size: 0; gap: 0; }
  .step-num { font-size: 10px; }
  .step.on, .step.done { font-size: 11px; gap: 7px; }
  .step-line { margin: 0 8px; }
  .cart-sec { padding: 28px 0 48px; }
  .cart-sec > .w,
  .checkout-sec > .w { padding-left: 16px; padding-right: 16px; }
  .page-title { font-size: 22px; margin-bottom: 18px; }
  .joopzy-cart-item { padding: 14px; gap: 12px; }
  .ci-img { width: 60px; height: 60px; }
  .ci-name { font-size: 12px; }
  .ci-price { font-size: 14px; }
  .ci-qbtn { width: 28px; height: 28px; }
  .ci-qnum { width: 28px; font-size: 12px; }
  .joopzy-summary { padding: 20px; }
  .joopzy-summary h3 { font-size: 13px; }
  .checkout-btn { height: 48px; font-size: 13px; }
  .frow { grid-template-columns: 1fr; }
  .form-card { padding: 20px 18px 24px; }
  .fc-title { font-size: 14px; }
  .checkout-sec { padding: 32px 0 56px; }
  .place-btn { height: 50px; font-size: 13px; }
  .pay-opt { padding: 12px 14px; gap: 10px; }
  .pay-opt-label { font-size: 12px; }
  .joopzy-ty__title { font-size: 20px; }
  .joopzy-ty__actions { flex-direction: column; }
  .joopzy-ty__actions .joopzy-btn-primary,
  .joopzy-ty__actions .joopzy-btn-ghost { width: 100%; }

  /* Stack all checkout fields to single column */
  .woocommerce-billing-fields__field-wrapper,
  .woocommerce-shipping-fields__field-wrapper,
  .woocommerce-additional-fields__field-wrapper {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .checkout .form-row,
  .checkout .form-row-wide,
  .checkout .form-row-first,
  .checkout .form-row-last,
  #billing_postcode_field,
  #billing_city_field,
  #billing_state_field,
  #shipping_postcode_field,
  #shipping_city_field,
  #shipping_state_field,
  #billing_phone_field,
  #billing_email_field { grid-column: 1; }
}
