/* ============================================
   WooCommerce — premier-medical-spa overrides
   All values reference CSS custom properties
   from style.css. No hardcoded colors/spacing.
   ============================================ */

.woocommerce-main { padding-top: var(--space-8); padding-bottom: var(--space-section); }
.woocommerce-main > .container { display: block; }
/* Breadcrumb + page title sit compactly at the top of WC pages. */
.woocommerce-main .woocommerce-breadcrumb,
.woocommerce-main .wc-breadcrumb { margin-bottom: var(--space-4); color: var(--color-muted); font-size: var(--text-sm); }
.woocommerce-products-header { margin-bottom: var(--space-6); }
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering { font-family: var(--font-body); color: var(--color-muted); font-size: var(--text-sm); }
.woocommerce-products-header__title,
.woocommerce-main h1 {
  font-family: var(--font-heading); font-weight: 500; color: var(--color-teal-900);
  font-size: var(--text-h2); line-height: var(--leading-snug); margin-bottom: var(--space-5);
}

/* --- Notices --- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews {
  border: var(--border-hair); border-left: 4px solid var(--color-teal-700);
  background: var(--color-notice-bg); color: var(--color-ink);
  border-radius: var(--radius-sm); padding: var(--space-4) var(--space-5);
  font-family: var(--font-body); list-style: none;
}
.woocommerce-error { border-left-color: var(--color-error); background: #f7e9e6; }
.woocommerce-message .button,
.woocommerce-info .button { background: var(--color-teal-700); color: var(--color-white); }

/* ============================================
   Shop archive — product grid
   1 col @375, 2 @768, 3 @1024+
   ============================================ */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid; gap: var(--space-6); margin: 0; padding: 0; list-style: none;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); } }
.woocommerce ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; }
.woocommerce ul.products li.product::before { display: none; }

.product-card {
  display: flex; flex-direction: column; height: 100%;
  background: var(--color-white); border: var(--border-hair);
  border-radius: var(--radius-md); overflow: hidden; transition: box-shadow var(--ease-default), transform var(--ease-default);
}
.product-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.product-card__media { position: relative; display: block; aspect-ratio: 4 / 3; overflow: hidden; background: var(--color-paper-alt); }
.product-card__img { width: 100%; height: 100%; object-fit: cover; }
.product-card__badge {
  position: absolute; top: var(--space-3); left: var(--space-3); z-index: 2;
  background: var(--color-accent); color: var(--color-ink); font-family: var(--font-body);
  font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-label);
  text-transform: uppercase; padding: 2px 10px; border-radius: var(--radius-sm);
}
.product-card__body { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-5); flex: 1; }
.product-card__title { font-family: var(--font-heading); font-size: var(--text-xl); font-weight: 500; margin: 0; line-height: var(--leading-snug); }
.product-card__title a { color: var(--color-teal-900); text-decoration: none; }
.product-card__title a:hover { color: var(--color-teal-700); }
.product-card__price { color: var(--color-ink); font-weight: 600; margin-top: auto; }
.product-card__price del { color: var(--color-muted); font-weight: 400; margin-right: var(--space-2); }
.product-card__price ins { text-decoration: none; color: var(--color-teal-700); }
.product-card__cart { margin-top: var(--space-3); text-align: center; }

/* ============================================
   Single product
   ============================================ */
.single-product .product { display: grid; gap: var(--space-8); }
@media (min-width: 900px) { .single-product div.product { grid-template-columns: 1fr 1fr; align-items: start; } }
.single-product .product .woocommerce-product-gallery { margin: 0; position: relative; opacity: 1 !important; }
.single-product .product .woocommerce-product-gallery img { border-radius: var(--radius-md); }
.single-product .product .woocommerce-product-gallery__wrapper { border-radius: var(--radius-md); overflow: hidden; }
/* Themed zoom trigger (was a stray tiny magnifier) */
.woocommerce-product-gallery__trigger {
  top: var(--space-3) !important; right: var(--space-3) !important; left: auto !important;
  width: 40px; height: 40px; display: grid; place-items: center; background: var(--color-paper) !important;
  border: var(--border-hair); border-radius: 999px; box-shadow: var(--shadow-sm); opacity: 0.95; font-size: 0;
}
.woocommerce-product-gallery__trigger::after { content: "⤢"; font-size: 18px; color: var(--color-teal-900); }
.single-product .product .summary { display: flex; flex-direction: column; gap: var(--space-4); }
.single-product .product .summary > .price { margin: 0; }
.single-product .product form.cart { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; margin: var(--space-2) 0; }
.single-product .product .product_meta { font-size: var(--text-sm); color: var(--color-muted); border-top: var(--border-hair); padding-top: var(--space-4); }
.single-product .product .product_meta a { color: var(--color-teal-700); }
.single-product .product_title {
  font-family: var(--font-heading); font-weight: 500; color: var(--color-teal-900);
  font-size: var(--text-h1); line-height: var(--leading-tight);
}
.single-product .product .price,
.single-product .product span.price { color: var(--color-ink); font-size: var(--text-2xl); font-weight: 600; }
.single-product .product .price del { color: var(--color-muted); font-weight: 400; }
.single-product .woocommerce-product-details__short-description { color: var(--color-ink-soft); line-height: var(--leading-body); }
.woocommerce div.product .woocommerce-tabs ul.tabs {
  border: 0; padding: 0; display: flex; gap: var(--space-5); flex-wrap: wrap;
  border-bottom: var(--border-hair); margin-bottom: var(--space-6);
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: none; border: 0; border-radius: 0; padding: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-body); font-weight: 600; color: var(--color-muted);
  text-transform: uppercase; letter-spacing: var(--tracking-label); font-size: var(--text-sm);
  padding-block: var(--space-3); display: inline-block; border-bottom: 2px solid transparent;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover { color: var(--color-teal-900); border-bottom-color: var(--color-accent); }
.related.products > h2, .upsells > h2 { font-family: var(--font-heading); color: var(--color-teal-900); font-weight: 500; }

/* ============================================
   Buttons — kill all default WC button styling
   ============================================ */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce .button {
  font-family: var(--font-body); font-weight: 600; font-size: var(--text-base);
  background: var(--color-teal-700); color: var(--color-white);
  border: 1px solid var(--color-teal-700); border-radius: var(--radius-sm);
  padding: 0.7em 1.4em; line-height: 1.2; text-transform: none; letter-spacing: 0;
  transition: background var(--ease-default), border-color var(--ease-default);
  text-shadow: none; box-shadow: none;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce .button:hover { background: var(--color-teal-900); border-color: var(--color-teal-900); color: var(--color-white); }
.woocommerce a.button.btn--outline,
.woocommerce .btn--outline {
  background: transparent; color: var(--color-teal-900); border-color: var(--color-teal-700);
}
.woocommerce a.button.btn--outline:hover,
.woocommerce .btn--outline:hover { background: var(--color-teal-700); color: var(--color-white); }
.woocommerce .added_to_cart { color: var(--color-teal-700); font-weight: 600; }

/* ============================================
   Cart
   ============================================ */
.woocommerce-cart table.shop_table {
  border: var(--border-hair); border-radius: var(--radius-md); border-collapse: separate; border-spacing: 0; overflow: hidden;
}
.woocommerce-cart table.shop_table th {
  font-family: var(--font-body); text-transform: uppercase; letter-spacing: var(--tracking-label);
  font-size: var(--text-xs); color: var(--color-muted); background: var(--color-paper-alt); padding: var(--space-4);
}
.woocommerce-cart table.shop_table td { padding: var(--space-4); border-top: var(--border-hair); }
.woocommerce-cart .product-name a { color: var(--color-teal-900); font-weight: 500; }
.woocommerce-cart table.shop_table td { vertical-align: middle; }
/* Constrain the cart product thumbnail (was rendering full-column width) */
.woocommerce-cart .product-thumbnail img,
.woocommerce-cart td.product-thumbnail img { width: 88px; height: 88px; object-fit: cover; border-radius: var(--radius-sm); }
.woocommerce-cart td.product-thumbnail { width: 110px; }
/* Cart layout: items + totals side-by-side on desktop */
@media (min-width: 980px) {
  .woocommerce-cart .woocommerce > .woocommerce-notices-wrapper { grid-column: 1 / -1; }
  .woocommerce-cart form.woocommerce-cart-form { margin-bottom: 0; }
  .woocommerce-cart .woocommerce { display: grid; grid-template-columns: 1.6fr 0.9fr; gap: var(--space-8); align-items: start; }
  .woocommerce-cart .cart-collaterals { width: 100%; float: none; }
  .woocommerce-cart .cart-collaterals .cart_totals { width: 100%; float: none; }
}
.woocommerce .quantity .qty,
.themed-qty-input {
  border: var(--border-hair); border-radius: var(--radius-sm); padding: 0.5em; background: var(--color-white);
  color: var(--color-ink); font-family: var(--font-body); width: 4.5em; text-align: center;
}
/* JS-added +/- quantity steppers */
.woocommerce .quantity { display: inline-flex; align-items: stretch; }
.woocommerce .quantity .qty-btn {
  width: 40px; min-height: 44px; border: var(--border-hair); background: var(--color-white);
  color: var(--color-teal-900); font-size: var(--text-lg); line-height: 1; cursor: pointer;
}
.woocommerce .quantity .qty-btn--minus { border-radius: var(--radius-sm) 0 0 var(--radius-sm); border-right: 0; }
.woocommerce .quantity .qty-btn--plus { border-radius: 0 var(--radius-sm) var(--radius-sm) 0; border-left: 0; }
.woocommerce .quantity .qty-btn:hover { background: var(--color-teal-100); }
.woocommerce .quantity input.qty { width: 3.5em; border-radius: 0; }
/* Password reveal toggle (login/checkout) */
.woocommerce form .password-input { display: block; position: relative; }
.woocommerce .show-password-input {
  position: absolute; right: 0.7em; top: 50%; transform: translateY(-50%);
  width: 28px; height: 28px; cursor: pointer; background: none; border: 0;
}
.woocommerce .show-password-input::after { content: "👁"; font-size: 16px; opacity: 0.55; }
.woocommerce .show-password-input.display-password::after { opacity: 1; }
.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce .cart_totals {
  background: var(--color-teal-100); border: var(--border-hair); border-radius: var(--radius-md); padding: var(--space-6);
}
.woocommerce-cart .cart_totals h2 { font-family: var(--font-heading); color: var(--color-teal-900); font-weight: 500; }
.woocommerce .coupon .input-text { border: var(--border-hair); border-radius: var(--radius-sm); padding: 0.6em; }

/* Tap targets: sort dropdown + cart remove link sized for mobile (>=44px). */
.woocommerce-ordering select {
  min-height: 44px; border: var(--border-hair); border-radius: var(--radius-sm);
  padding: 0.5em 2em 0.5em 0.8em; background: var(--color-white); color: var(--color-ink); font-family: var(--font-body);
}
.woocommerce a.remove {
  display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px;
  min-width: 44px; min-height: 44px; font-size: var(--text-xl); line-height: 1;
  color: var(--color-muted) !important; border-radius: 999px; background: transparent;
}
.woocommerce a.remove:hover { background: var(--color-teal-100); color: var(--color-error) !important; }
.wc-proceed-to-checkout a.checkout-button { font-size: var(--text-lg); text-align: center; }

/* ============================================
   Checkout
   ============================================ */
.woocommerce-checkout h3 { font-family: var(--font-heading); color: var(--color-teal-900); font-weight: 500; }
.woocommerce form .form-row label { font-family: var(--font-body); color: var(--color-ink-soft); font-weight: 500; font-size: var(--text-sm); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce .select2-container .select2-selection {
  border: var(--border-hair); border-radius: var(--radius-sm); padding: 0.75em 0.9em;
  background: var(--color-white); color: var(--color-ink); font-family: var(--font-body); font-size: var(--text-base);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus { outline: 2px solid var(--color-teal-500); outline-offset: 1px; border-color: var(--color-teal-700); }
/* Single teal review panel — inner table + payment are transparent (no nested boxes) */
.woocommerce-checkout #order_review,
.woocommerce-checkout .woocommerce-checkout-review-order {
  background: var(--color-teal-100); border: var(--border-hair); border-radius: var(--radius-md); padding: var(--space-6);
}
.woocommerce-checkout #order_review .woocommerce-checkout-review-order-table { background: transparent; border: 0; }
.woocommerce-checkout #order_review #payment { background: transparent; border: 0; border-top: var(--border-hair); border-radius: 0; padding: var(--space-5) 0 0; margin-top: var(--space-4); }
/* Checkout: billing form (col 1, spans both rows) + order review (col 2) on desktop.
   Spanning customer_details lets the heading + review stack in col 2 right at the
   top instead of being pushed below the tall billing form. */
@media (min-width: 980px) {
  .woocommerce-checkout form.checkout { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: var(--space-4) var(--space-8); align-items: start; }
  .woocommerce-checkout #customer_details { grid-column: 1; grid-row: 1 / span 2; }
  .woocommerce-checkout #order_review_heading { grid-column: 2; grid-row: 1; margin-top: 0; }
  .woocommerce-checkout #order_review { grid-column: 2; grid-row: 2; padding: var(--space-6); }
}
.woocommerce-checkout .col2-set .col-1, .woocommerce-checkout .col2-set .col-2 { width: 100%; float: none; }

/* --- Form rows: label stacked above a full-width field (WC's own layout CSS was
   dequeued with its stylesheet, so we provide it). --- */
.woocommerce form .form-row {
  display: flex; flex-direction: column; margin: 0 0 var(--space-4); padding: 0; width: 100%;
}
.woocommerce form .form-row label {
  display: block; margin: 0 0 var(--space-1); font-weight: 500; font-size: var(--text-sm); color: var(--color-ink-soft);
}
.woocommerce form .form-row label .required { color: var(--color-accent); border: 0; text-decoration: none; }
.woocommerce form .form-row .woocommerce-input-wrapper { width: 100%; display: block; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select:not(.select2-hidden-accessible),
.woocommerce form .form-row .select2-container { width: 100% !important; box-sizing: border-box; }
/* Keep Select2's hidden native <select> visually hidden (its width:1px clip was
   being overridden by the rule above, blowing it to full width and overflowing). */
.woocommerce .select2-hidden-accessible {
  position: absolute !important; width: 1px !important; height: 1px !important; overflow: hidden !important;
  clip: rect(0 0 0 0) !important; clip-path: inset(50%) !important; white-space: nowrap !important;
  border: 0 !important; padding: 0 !important; margin: -1px !important;
}

/* --- Select2 dropdowns (Country/State) — WC's Select2 CSS was dequeued with its
   stylesheet, so style the widget to match the theme's inputs. --- */
.select2-container--default .select2-selection--single {
  height: auto; min-height: 46px; display: flex; align-items: center;
  border: var(--border-hair); border-radius: var(--radius-sm); background: var(--color-white);
  padding: 0.4em 2em 0.4em 0.9em; box-sizing: border-box;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--color-ink); line-height: 1.4; padding: 0; font-family: var(--font-body);
}
.select2-container--default .select2-selection--single .select2-selection__placeholder { color: var(--color-muted); }
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100%; top: 0; right: 0.7em; width: 18px;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: var(--color-muted) transparent transparent; border-width: 6px 5px 0;
}
.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
  border-color: transparent transparent var(--color-muted); border-width: 0 5px 6px;
}
.select2-container--open .select2-selection--single { border-color: var(--color-teal-700); }
.select2-dropdown {
  border: var(--border-hair); border-radius: var(--radius-sm); background: var(--color-white);
  box-shadow: var(--shadow-md); overflow: hidden;
}
.select2-container--default .select2-search--dropdown .select2-search__field {
  border: var(--border-hair); border-radius: var(--radius-sm); padding: 0.5em 0.7em; font-family: var(--font-body);
}
.select2-container--default .select2-results__option {
  color: var(--color-ink); padding: 0.55em 0.9em; font-family: var(--font-body);
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted {
  background: var(--color-teal-700); color: var(--color-white);
}
.select2-container--default .select2-results__option[aria-selected=true] { background: var(--color-teal-100); color: var(--color-ink); }
.woocommerce form .form-row.woocommerce-invalid input.input-text { border-color: var(--color-error); }
.woocommerce form .form-row-first, .woocommerce form .form-row-last { width: 100%; }
/* Pair First / Last name (and similar) side-by-side on wider screens */
@media (min-width: 600px) {
  .woocommerce form .form-row-first { width: calc(50% - (var(--space-4) / 2)); float: left; }
  .woocommerce form .form-row-last { width: calc(50% - (var(--space-4) / 2)); float: right; }
  .woocommerce .woocommerce-billing-fields__field-wrapper,
  .woocommerce .woocommerce-shipping-fields__field-wrapper,
  .woocommerce .woocommerce-account-fields { overflow: hidden; }
}
/* Checkbox / radio rows shouldn't stretch the control full width */
.woocommerce form .form-row.woocommerce-validated label.checkbox,
.woocommerce form p.form-row input[type=checkbox],
.woocommerce form p.form-row input[type=radio] { width: auto !important; display: inline-block; margin-right: var(--space-2); }
.woocommerce-checkout #payment ul.payment_methods { list-style: none; margin: 0 0 var(--space-4); padding: 0; border: 0; }
.woocommerce-checkout #payment ul.payment_methods li { padding: var(--space-2) 0; display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); }
.woocommerce-checkout #payment ul.payment_methods li::before { display: none; }
.woocommerce-checkout #payment ul.payment_methods li input[type=radio] { width: 18px !important; height: 18px; margin: 0; accent-color: var(--color-teal-700); flex: 0 0 auto; }
.woocommerce-checkout #payment ul.payment_methods li label { display: inline; font-weight: 600; color: var(--color-ink); margin: 0; }
.woocommerce-checkout #payment ul.payment_methods li img { display: none; }
.woocommerce-checkout #payment div.payment_box {
  flex: 1 1 100%; background: rgba(255, 255, 255, 0.55); border-radius: var(--radius-sm);
  color: var(--color-ink-soft); font-size: var(--text-sm); margin: var(--space-1) 0 0; padding: var(--space-3) var(--space-4);
}
.woocommerce-checkout #payment div.payment_box p { margin: 0; max-width: none; }
.woocommerce-checkout #payment div.payment_box::before { display: none; }
.woocommerce-checkout #payment .place-order { padding: var(--space-4) 0 0; margin: 0; }
.woocommerce-checkout #payment .woocommerce-privacy-policy-text { font-size: var(--text-sm); color: var(--color-ink-soft); margin-bottom: var(--space-4); }
.woocommerce-checkout #payment #place_order { width: 100%; }
.woocommerce table.shop_table.woocommerce-checkout-review-order-table { border: 0; }

/* ============================================
   Thank you / order received
   ============================================ */
.woocommerce-order .woocommerce-order-overview {
  border: var(--border-hair); border-radius: var(--radius-md); background: var(--color-paper-alt);
  padding: var(--space-5); display: flex; flex-wrap: wrap; gap: var(--space-5);
  list-style: none; margin: 0;
}
.woocommerce-order .woocommerce-order-overview li { list-style: none; border: 0; }
.woocommerce-order .woocommerce-order-overview li::before { display: none; }
.woocommerce-order table.shop_table { border: var(--border-hair); border-radius: var(--radius-md); width: 100%; }
.woocommerce-order .woocommerce-customer-details address { border: var(--border-hair); border-radius: var(--radius-md); padding: var(--space-5); font-style: normal; }
.woocommerce-order .woocommerce-thankyou-order-received { font-family: var(--font-heading); font-size: var(--text-2xl); color: var(--color-teal-900); }

/* ============================================
   My Account
   ============================================ */
.woocommerce-account .woocommerce { display: grid; gap: var(--space-8); }
@media (min-width: 820px) { .woocommerce-account .woocommerce { grid-template-columns: 240px 1fr; align-items: start; } }
.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; border: var(--border-hair); border-radius: var(--radius-md); overflow: hidden; }
.woocommerce-MyAccount-navigation li { border-bottom: var(--border-hair); }
.woocommerce-MyAccount-navigation li:last-child { border-bottom: 0; }
.woocommerce-MyAccount-navigation li a { display: block; padding: var(--space-3) var(--space-4); color: var(--color-ink-soft); text-decoration: none; font-weight: 500; }
.woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-MyAccount-navigation li a:hover { background: var(--color-teal-100); color: var(--color-teal-900); }
.woocommerce-account .woocommerce form.login,
.woocommerce-account .woocommerce form.register {
  border: var(--border-hair); border-radius: var(--radius-md); padding: var(--space-6); background: var(--color-white);
}

/* Mini-cart styles live in main.css (global header chrome, loads on every page). */

/* --- Sale flash (single) --- */
.woocommerce span.onsale {
  background: var(--color-accent); color: var(--color-ink); border-radius: var(--radius-sm);
  font-family: var(--font-body); font-weight: 600; min-height: auto; min-width: auto; padding: 2px 12px; line-height: 1.6;
}
