/* =========================================================
   THEME GLUE — bridges WooCommerce's default output into the
   Sofira design system. Loaded last. Keep additive only.
   ========================================================= */

/* --- WooCommerce notices --- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notices-wrapper > * {
  background: var(--blush-50);
  border: 1px solid rgba(232, 143, 163, .25);
  border-left: 3px solid var(--pink-deep);
  border-radius: var(--r-sm);
  color: var(--ink);
  padding: 14px 18px;
  margin: 0 0 20px;
  font-size: 14px;
  list-style: none;
}
.woocommerce-error { border-left-color: #d35a6e; }
.woocommerce-message .button,
.woocommerce-info .button {
  background: var(--ink); color: #fff; border-radius: 999px;
  padding: 8px 16px; font-size: 12px; float: right; margin-left: 12px;
}

/* --- Cart drawer image thumbs (real product images) --- */
.cart-line .thumb--img {
  overflow: hidden; background: var(--gray-50);
}
.cart-line .thumb--img img {
  width: 100%; height: 100%; object-fit: cover; border-radius: inherit;
}

/* --- WooCommerce price markup inside design cards --- */
.shop-card .price ins,
.product-meta .price ins { text-decoration: none; }
.shop-card .price del,
.product-meta .price del { color: var(--muted-2); font-weight: 400; font-size: 13px; margin-left: 8px; }
.woocommerce-Price-amount { font-variant-numeric: tabular-nums; }

/* --- Quantity inputs (cart / pdp) styled to match the pills --- */
.quantity input.qty {
  width: 56px; height: 40px; text-align: center;
  border: 1px solid var(--line); border-radius: 10px; background: #fff;
  font-size: 14px; color: var(--ink);
}

/* --- Generic Woo button → design pill (fallback when no design class) --- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 24px; background: var(--ink); color: #fff;
  font-size: 13px; font-weight: 500; border-radius: 999px; border: 0;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), background .3s ease;
  cursor: pointer;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  transform: translateY(-2px); box-shadow: 0 14px 28px -16px rgba(32,32,32,.5);
}
.woocommerce a.button.alt,
.woocommerce button.button.alt { background: var(--pink-deep); }
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover { background: #de7d92; }

/* Keep design buttons exactly as designed even inside .woocommerce */
.woocommerce .btn,
.woocommerce .btn-lux { box-shadow: none; }
.woocommerce a.button.btn--white,
.woocommerce button.button.btn--white { background: #fff; color: var(--ink); border: 1px solid var(--line); }
.woocommerce a.button.btn--ghost,
.woocommerce button.button.btn--ghost { background: transparent; color: var(--ink); border: 1px solid var(--gray-300); }

/* --- Forms: WooCommerce account / checkout fields --- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-account .woocommerce form .input-text,
.select2-container .select2-selection {
  border: 1px solid var(--line); border-radius: 12px; padding: 13px 16px;
  font-size: 15px; color: var(--ink); background: #fff;
}
.woocommerce form .form-row label { font-size: 12px; font-weight: 600; letter-spacing: .04em; color: var(--ink-soft); }

/* --- My Account navigation as soft pills --- */
.woocommerce-account .woocommerce-MyAccount-navigation ul { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }
.woocommerce-account .woocommerce-MyAccount-navigation li a {
  display: inline-block; padding: 9px 16px; border: 1px solid var(--line);
  border-radius: 999px; font-size: 13px; font-weight: 500; color: var(--ink);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--ink); color: #fff; border-color: var(--ink); }
.woocommerce-account .woocommerce-MyAccount-content { background: #fff; }

/* --- Pagination --- */
.woocommerce nav.woocommerce-pagination ul { border: 0; display: flex; gap: 8px; justify-content: center; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border: 1px solid var(--line); border-radius: 999px; min-width: 40px; padding: 8px 12px;
}
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--ink); color: #fff; border-color: var(--ink); }

/* --- Breadcrumb --- */
.woocommerce .woocommerce-breadcrumb {
  font-size: 12px; color: var(--muted-2); letter-spacing: .02em;
  margin: 0 0 24px; padding-top: 24px;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--muted); }

/* --- Hide default Woo result count/ordering when our toolbar is present --- */
.shop-toolbar .woocommerce-result-count { margin: 0; }
.shop-toolbar .woocommerce-ordering { margin: 0; }
.shop-toolbar .woocommerce-ordering select { font: inherit; }

/* --- Related products heading --- */
.related.products > h2, .up-sells > h2, .cross-sells > h2 {
  font-family: var(--display); font-weight: 400; font-size: 28px; margin: 0 0 24px;
}

/* --- Shop-card price mapping (Woo price markup → design styling) --- */
.shop-card-meta .woocommerce-Price-amount { font-size: 16px; font-weight: 600; color: var(--ink); }
.shop-card-meta del { opacity: 1; }
.shop-card-meta del .woocommerce-Price-amount { color: var(--muted-2); font-weight: 400; font-size: 13px; text-decoration: line-through; }
.shop-card-meta ins { text-decoration: none; }
.product-meta .price .woocommerce-Price-amount { font-size: 16px; font-weight: 600; }
.pdp-price .woocommerce-Price-amount { font-size: inherit; }

/* --- Single product add-to-cart → design pill --- */
.woocommerce div.product form.cart { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 0; }
.woocommerce div.product form.cart .quantity { margin: 0; }
.woocommerce div.product form.cart .button.single_add_to_cart_button {
  display: inline-flex; align-items: center; justify-content: center; gap: 14px;
  padding: 18px 32px; font-size: 11px; font-weight: 600; letter-spacing: .2em;
  text-transform: uppercase; border-radius: 999px; background: var(--pink-deep); color: #fff;
  box-shadow: 0 12px 28px -12px rgba(232,143,163,.55); border: 0;
}
.woocommerce div.product form.cart .button.single_add_to_cart_button:hover {
  background: #de7d92; transform: translateY(-2px); box-shadow: 0 18px 36px -14px rgba(232,143,163,.7);
}
.woocommerce div.product .variations { margin-bottom: 16px; }
.woocommerce div.product .variations td, .woocommerce div.product .variations th { padding: 6px 0; }

/* =========================================================
   CART + CHECKOUT (overridden templates → design markup)
   The .cart-page / .checkout-grid / .summary-card / .form-card
   structure is styled by ecom.css; the rules below only bridge
   WooCommerce's own field / payment markup into that shell.
   ========================================================= */

/* Cart row qty input fallback + remove link */
.cart-row-qty span { min-width: 18px; text-align: center; }
.cart-update-hidden { display: none !important; }
.summary-mini-row .woocommerce-Price-amount { font-weight: 600; }

/* WooCommerce billing/shipping fields → design `.field` look inside form-cards */
.form-card .woocommerce-billing-fields h3,
.form-card .woocommerce-shipping-fields h3,
.form-card .woocommerce-additional-fields h3 {
  font-family: var(--display); font-weight: 400; font-size: 22px; margin: 0 0 22px;
}
.form-card .woocommerce-billing-fields__field-wrapper,
.form-card .woocommerce-shipping-fields .shipping_address,
.form-card .woocommerce-additional-fields__field-wrapper {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.form-card p.form-row { margin: 0; }
.form-card p.form-row-wide,
.form-card p.form-row.notes,
.form-card p.address-field,
.form-card p.form-row[class*="billing_email"],
.form-card p.form-row[class*="billing_phone"],
.form-card p.form-row[class*="_address_1"],
.form-card p.form-row[class*="_address_2"] { grid-column: 1 / -1; }
.form-card .form-row label {
  font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--muted-2); margin-bottom: 6px; display: block; font-weight: 600;
}
.form-card .form-row .required { color: var(--pink-deep); border: 0; }
.form-card .woocommerce-input-wrapper { width: 100%; }
.form-card .form-row .input-text,
.form-card .form-row select,
.form-card .select2-container .select2-selection,
.form-card textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 10px;
  padding: 12px 14px; font-size: 14px; font-family: var(--sans); background: #fff;
}
.form-card .form-row .input-text:focus { outline: none; border-color: var(--ink); }
.sofira-shipping-card { }
.woocommerce-shipping-fields h3 label { font-family: inherit; font-size: 13px; text-transform: none; letter-spacing: 0; }

/* Payment methods → bordered rows (like delivery-pick) */
.sofira-payment-card #payment { background: transparent; }
.sofira-payment-card #payment ul.payment_methods {
  list-style: none; margin: 0 0 18px; padding: 0; border: 0; display: grid; gap: 8px;
}
.sofira-payment-card #payment ul.payment_methods li {
  border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; background: #fff;
}
.sofira-payment-card #payment ul.payment_methods li:has(input:checked) { border-color: var(--ink); background: #fbf6f4; }
.sofira-payment-card #payment ul.payment_methods li label { font-weight: 500; cursor: pointer; }
.sofira-payment-card #payment ul.payment_methods li .payment_box {
  background: var(--gray-50); border-radius: 10px; padding: 14px 16px; margin-top: 10px; font-size: 13px;
}
.sofira-payment-card #payment ul.payment_methods li .payment_box::before { display: none; }
.sofira-payment-card #payment .place-order { padding: 18px 0 0; }
.sofira-payment-card #place_order,
.woocommerce #place_order {
  width: 100%; display: inline-flex; align-items: center; justify-content: center;
  background: var(--pink-deep); color: #fff; border: 0; border-radius: 999px;
  padding: 18px 32px; text-transform: uppercase; letter-spacing: .2em; font-size: 11px; font-weight: 600;
  box-shadow: 0 12px 28px -12px rgba(232,143,163,.55);
}
.sofira-payment-card #place_order:hover { background: #de7d92; }
.sofira-payment-card .woocommerce-terms-and-conditions-wrapper { margin-bottom: 14px; font-size: 12px; color: var(--muted); }

/* Order-review column spacing */
.checkout-summary #order_review { border: 0; padding: 0; background: transparent; }
.checkout-summary .woocommerce-checkout-review-order { margin: 0; }

/* --- Mobile nav fallback (mega-menu collapses) --- */
@media (max-width: 940px) {
  .nav-mega { display: none; }
}
