/* ============================================================
   Feeha Wears — WooCommerce bridge
   Makes WooCommerce's native markup (cart, checkout, account,
   product form, notices) adopt the Feeha design tokens.
   Loaded after styles.css, so all --tokens are available.
   ============================================================ */

/* ---------- Buttons ---------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce-page button.button {
  display: inline-flex; align-items: center; justify-content: center; gap: .6em;
  font-family: var(--font-sans);
  font-size: 13px; letter-spacing: .16em; text-transform: uppercase; font-weight: 500;
  padding: 15px 28px; border-radius: 999px;
  background: var(--ink); color: var(--bg);
  border: 1px solid var(--ink);
  transition: transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background: var(--accent-ink); border-color: var(--accent-ink); color: #fff;
  transform: translateY(-2px); box-shadow: var(--shadow-soft);
}
.woocommerce a.button.wc-backward,
.woocommerce .cart .button[name="update_cart"] {
  background: transparent; color: var(--ink); border-color: var(--ink);
}
.woocommerce a.button.wc-backward:hover,
.woocommerce .cart .button[name="update_cart"]:hover {
  background: var(--ink); color: var(--bg);
}

/* ---------- Form fields ---------- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce .select2-container .select2-selection,
.woocommerce-page form .form-row input.input-text,
.woocommerce table.cart td.actions .coupon .input-text,
.woocommerce #customer_details input,
.woocommerce #customer_details select,
.woocommerce #customer_details textarea {
  font-family: var(--font-sans); font-size: 15px; color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--line) !important; border-radius: var(--radius-sm);
  padding: 12px 15px; transition: border-color .2s;
  box-shadow: none;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce #customer_details input:focus,
.woocommerce #customer_details textarea:focus {
  outline: none; border-color: var(--accent) !important;
}
.woocommerce form .form-row label,
.woocommerce-checkout .form-row label {
  font-size: 12px; letter-spacing: .04em; color: var(--ink-soft); font-weight: 400;
}
.select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 26px; color: var(--ink); }
.select2-dropdown { border-color: var(--line); }

/* ---------- Quantity input ---------- */
.woocommerce .quantity .qty {
  font-family: var(--font-sans); font-size: 15px; color: var(--ink);
  width: 64px; height: 56px; text-align: center;
  border: 1px solid var(--line); border-radius: 999px; background: var(--surface);
  -moz-appearance: textfield;
}
.woocommerce .quantity .qty::-webkit-outer-spin-button,
.woocommerce .quantity .qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* ============================================================
   Single product — native add-to-cart form (.feeha-buyform)
   ============================================================ */
.feeha-buyform { margin: 30px 0 16px; }
.feeha-buyform form.cart { margin: 0; }
.feeha-buyform .quantity { flex: 0 0 auto; }

/* Simple product: qty + button on one line, like the design .buybar */
.feeha-buyform form.cart:not(.variations_form) {
  display: flex; gap: 12px; align-items: stretch; flex-wrap: wrap;
}
.feeha-buyform form.cart .single_add_to_cart_button {
  flex: 1; min-width: 200px; height: 56px;
  background: var(--ink); color: var(--bg); border-color: var(--ink);
}
.feeha-buyform form.cart .single_add_to_cart_button:hover {
  background: var(--accent-ink); border-color: var(--accent-ink);
}

/* Variable product: variation selectors, then qty + button row */
.feeha-buyform .variations { width: 100%; border-collapse: collapse; margin-bottom: 18px; }
.feeha-buyform .variations th,
.feeha-buyform .variations td { display: block; text-align: left; padding: 0 0 6px; }
.feeha-buyform .variations th.label label {
  font-size: 11.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink);
}
.feeha-buyform .variations td.value { padding-bottom: 16px; }
.feeha-buyform .variations select {
  width: 100%; max-width: 340px; font-family: var(--font-sans); font-size: 15px;
  border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 12px 15px;
  background: var(--surface); color: var(--ink); -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%239a8a90' d='M0 0h10L5 6z'/></svg>");
  background-repeat: no-repeat; background-position: right 15px center;
}
.feeha-buyform .woocommerce-variation-add-to-cart {
  display: flex; gap: 12px; align-items: stretch; flex-wrap: wrap;
}
.feeha-buyform .woocommerce-variation-price .price { font-family: var(--font-display); font-size: 26px; color: var(--ink); }
.feeha-buyform .reset_variations { align-self: center; font-size: 12px; color: var(--accent-ink); }

/* PDP price block uses Woo's .price inside .pinfo__price */
.pinfo__price .price { font-family: var(--font-display); font-weight: 500; }
.pinfo__price del { color: var(--ink-faint); font-size: .7em; }
.pinfo__price ins { text-decoration: none; }

/* Stock / meta */
.woocommerce .pinfo .stock { color: var(--ink-soft); font-size: 13px; }
.woocommerce .pinfo .stock.out-of-stock { color: var(--accent-ink); }

/* ============================================================
   Cart page
   ============================================================ */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-account .woocommerce { padding-block: clamp(24px, 4vw, 48px); }

.woocommerce table.shop_table {
  border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden;
  border-collapse: separate; border-spacing: 0; background: var(--surface);
}
.woocommerce table.shop_table th {
  font-family: var(--font-sans); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-soft); font-weight: 500; padding: 16px 18px;
}
.woocommerce table.shop_table td { padding: 18px; border-top: 1px solid var(--line); color: var(--ink); }
.woocommerce table.shop_table img { width: 70px; border-radius: var(--radius-sm); }
.woocommerce a.remove {
  color: var(--ink-faint) !important; border-radius: 999px; font-weight: 400;
}
.woocommerce a.remove:hover { background: var(--accent) !important; color: #fff !important; }
.woocommerce-cart table.cart td.product-name a { font-family: var(--font-display); font-size: 18px; color: var(--ink); }
.woocommerce-cart table.cart td.product-name a:hover { color: var(--accent-ink); }

.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals { float: none; width: 100%; }
.cart_totals h2 { font-family: var(--font-display); font-weight: 600; font-size: 22px; margin-bottom: 16px; }
.cart_totals table.shop_table { background: var(--surface); }
.cart_totals .order-total .amount { font-family: var(--font-display); font-size: 22px; color: var(--ink); }
.wc-proceed-to-checkout a.checkout-button { width: 100%; }

/* ============================================================
   Checkout page
   ============================================================ */
.woocommerce-checkout h3 { font-family: var(--font-display); font-weight: 500; font-size: 23px; }
.woocommerce-checkout #customer_details { margin-bottom: 8px; }
.woocommerce-checkout #order_review_heading { font-family: var(--font-display); font-weight: 500; font-size: 23px; margin-top: 10px; }
.woocommerce-checkout #order_review {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px;
}
.woocommerce-checkout #payment {
  background: transparent; border-radius: var(--radius);
}
.woocommerce-checkout #payment ul.payment_methods {
  border-bottom: 1px solid var(--line); padding: 6px 0 16px;
}
.woocommerce-checkout #payment ul.payment_methods li {
  border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 14px 16px; margin-bottom: 10px;
  list-style: none; background: var(--surface);
}
.woocommerce-checkout #payment ul.payment_methods li label { font-size: 14.5px; color: var(--ink); }
.woocommerce-checkout #payment div.payment_box {
  background: var(--surface-2); color: var(--ink-soft); border-radius: var(--radius-sm); font-size: 13.5px;
}
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: var(--surface-2); }
.woocommerce-checkout #payment #place_order { width: 100%; height: 54px; margin-top: 14px; }
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper { font-size: 13px; color: var(--ink-soft); }

/* Order received / thank-you */
.woocommerce ul.order_details {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; margin-bottom: 28px;
}
.woocommerce ul.order_details li { border-right-color: var(--line); }

/* ============================================================
   Notices
   ============================================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-top: none; border-radius: var(--radius-sm);
  background: var(--surface); color: var(--ink);
  border: 1px solid var(--line); padding: 16px 18px 16px 46px; font-size: 14.5px;
}
.woocommerce-message::before { color: #1a8044; }
.woocommerce-info::before { color: var(--accent-ink); }
.woocommerce-error { border-color: color-mix(in srgb, var(--accent) 50%, var(--line)); }
.woocommerce-message .button,
.woocommerce-info .button { padding: 9px 18px; }

/* ============================================================
   My Account
   ============================================================ */
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li {
  border-bottom: 1px solid var(--line);
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
  display: block; padding: 13px 4px; font-size: 14px; letter-spacing: .04em;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { color: var(--accent-ink); }

/* ============================================================
   Pagination (shop)
   ============================================================ */
/* ============================================================
   Pagination (shop)
   WooCommerce's own pagination CSS is more specific (the shop <body>
   carries a .woocommerce class), so we use !important here to take over
   and render a clean row of pill buttons.
   ============================================================ */
.shop-pagination,
nav.woocommerce-pagination { text-align: center; margin-top: clamp(32px, 4vw, 56px); }
nav.woocommerce-pagination ul {
  display: inline-flex !important; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: 8px; list-style: none; margin: 0 !important; padding: 0 !important; border: none !important;
}
nav.woocommerce-pagination ul li {
  border: none !important; margin: 0 !important; padding: 0 !important; display: flex;
}
nav.woocommerce-pagination ul li a,
nav.woocommerce-pagination ul li span {
  box-sizing: border-box;
  border: 1px solid var(--line) !important; border-radius: 999px !important;
  min-width: 44px !important; height: 44px !important; padding: 0 8px !important; margin: 0 !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  color: var(--ink); background: var(--surface);
  font-size: 14px; line-height: 1; text-decoration: none;
  transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
nav.woocommerce-pagination ul li span.current,
nav.woocommerce-pagination ul li a:hover,
nav.woocommerce-pagination ul li a:focus {
  background: var(--ink) !important; color: var(--bg) !important; border-color: var(--ink) !important;
}
nav.woocommerce-pagination ul li span.dots {
  border: none !important; background: transparent !important; color: var(--ink-faint);
}

/* ---------- Catalog ordering select (shop toolbar) ---------- */
.woocommerce-ordering { margin: 0 !important; }
.shop-sort .orderby {
  font-family: var(--font-sans); font-size: 13.5px; border: 1px solid var(--line); border-radius: 999px;
  padding: 10px 38px 10px 16px; background: var(--surface); color: var(--ink); cursor: pointer;
  -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%239a8a90' d='M0 0h10L5 6z'/></svg>");
  background-repeat: no-repeat; background-position: right 15px center;
}

/* ============================================================
   Hide the WhatsApp FAB / tab bar overlap on the cart & checkout
   so the place-order button stays reachable on mobile.
   ============================================================ */
@media (max-width: 860px) {
  .woocommerce-checkout .wa-fab,
  .woocommerce-cart .wa-fab { bottom: calc(64px + env(safe-area-inset-bottom, 0px) + 16px); }
  .feeha-buyform form.cart:not(.variations_form) { gap: 10px; }
  .feeha-buyform form.cart .single_add_to_cart_button { min-width: 0; }
}

/* Loading state */
.woocommerce .blockUI.blockOverlay { background: var(--bg) !important; }

/* ---------- Product card: image link fills the media box ---------- */
.card__media .card__imglink { position: absolute; inset: 0; display: block; }
.card__media .card__imglink img { width: 100%; height: 100%; object-fit: cover; }
/* WooCommerce loop "quick" add link (anchor) keeps the design's pill look */
.card__media a.quick { text-decoration: none; }
.card__media a.quick.loading { opacity: .6; }
.card__media a.quick.added { display: none; }
.card__media a.added_to_cart {
  position: absolute; left: 14px; right: 14px; bottom: 14px; z-index: 3;
  background: var(--accent-ink); color: #fff; border-radius: 999px; padding: 12px;
  font-size: 11px; letter-spacing: .18em; text-transform: uppercase; text-align: center;
}

/* ============================================================
   FIX: pin the loop "Add to cart" / "Select options" button to the
   BOTTOM of the card image for every product type, and give it the
   refined quick-add pill look (overrides the generic .button styling).
   ============================================================ */
.card__media .quick,
.card__media a.add_to_cart_button,
.card__media a.button {
  position: absolute !important;
  left: 12px; right: 12px; bottom: 12px; top: auto !important;
  width: auto !important; max-width: calc(100% - 24px); margin: 0 !important; z-index: 3;
  display: flex; align-items: center; justify-content: center; gap: .4em;
  height: auto; min-height: 0; padding: 12px 12px;
  border: none; border-radius: 999px;
  background: var(--surface); color: var(--ink);
  font-family: var(--font-sans); font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase; font-weight: 500; line-height: 1.15; text-align: center;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  box-shadow: var(--shadow-soft);
}
.card__media .quick:hover,
.card__media a.add_to_cart_button:hover,
.card__media a.button:hover {
  background: var(--ink); color: var(--bg); transform: none; box-shadow: var(--shadow-soft);
}
/* After an AJAX add, hide the duplicate state link inside the card */
.card__media a.button.added { display: none !important; }
.card__media a.added_to_cart { bottom: 12px; left: 12px; right: 12px; }

/* On narrow 2-up mobile grids, shrink the pill text so longer labels
   like "Select options" fit without being clipped. */
@media (max-width: 600px) {
  .card__media .quick,
  .card__media a.add_to_cart_button,
  .card__media a.button {
    left: 8px; right: 8px; bottom: 8px; padding: 10px 8px;
    font-size: 9.5px; letter-spacing: .05em;
  }
  .card__media a.added_to_cart { left: 8px; right: 8px; bottom: 8px; font-size: 9.5px; }
}

/* ============================================================
   Cart page — designed, not default
   ============================================================ */
.woocommerce-cart .shoppage,
.woocommerce-cart main.page-main { padding-top: clamp(18px, 3vw, 34px); }
.woocommerce-cart .cart-collaterals { display: flex; justify-content: flex-end; }
.woocommerce-cart .cart-collaterals .cart_totals {
  width: 100%; max-width: 460px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 26px;
}
.woocommerce-cart .cart-collaterals .cross-sells { width: 100%; margin-top: 40px; }
.woocommerce-cart table.cart td.actions { padding: 18px; }
.woocommerce-cart table.cart td.actions .coupon { display: flex; gap: 10px; }
.woocommerce-cart .quantity .qty { height: 46px; width: 58px; }
.woocommerce-cart table.shop_table.shop_table_responsive { margin-bottom: 28px; }

/* ============================================================
   Checkout — two-column layout with a sticky, carded summary
   (kept on WooCommerce's native form, so gateways/validation work)
   ============================================================ */
.woocommerce-checkout .checkout__head,
.woocommerce-checkout .page-header { margin-bottom: clamp(20px, 3vw, 36px); }

/* Section headings → elegant serif (acts like the design's numbered steps) */
.woocommerce-checkout #customer_details h3,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout .woocommerce-additional-fields h3 {
  font-family: var(--font-display); font-weight: 500; font-size: 23px; letter-spacing: -.01em;
}

.woocommerce-checkout #order_review {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px;
}
/* The order table sits inside the summary card, so drop its own border */
.woocommerce-checkout #order_review table.shop_table {
  border: none; background: transparent; margin: 0;
}
.woocommerce-checkout #order_review table.shop_table th,
.woocommerce-checkout #order_review table.shop_table td { padding: 12px 0; }
.woocommerce-checkout #order_review .order-total .amount {
  font-family: var(--font-display); font-size: 22px; color: var(--ink);
}
.woocommerce-checkout #payment { background: transparent; }

@media (min-width: 861px) {
  .woocommerce-checkout form.checkout.woocommerce-checkout {
    display: grid;
    grid-template-columns: 1.5fr .9fr;
    gap: clamp(32px, 4vw, 64px);
    align-items: start;
  }
  .woocommerce-checkout #customer_details { grid-column: 1; grid-row: 1 / span 2; min-width: 0; }
  .woocommerce-checkout #order_review_heading { grid-column: 2; grid-row: 1; margin-top: 0; }
  .woocommerce-checkout #order_review { grid-column: 2; grid-row: 2; position: sticky; top: 104px; }
  /* billing / shipping stack inside the left column for breathing room */
  .woocommerce-checkout #customer_details .col2-set .col-1,
  .woocommerce-checkout #customer_details .col2-set .col-2 { float: none; width: 100%; }
}

/* Order-received / thank-you page heading */
.woocommerce-order .woocommerce-order-received .entry-title,
.woocommerce-order h1 { font-family: var(--font-display); font-weight: 500; }
