/* =====================================================================
   HomeGym DXB — WooCommerce styling
   Styles WooCommerce's own default templates (cart, checkout, account,
   single product, archives) in the navy/gold theme. Gateway- and
   core-feature-safe: we only style, never replace WC structure.
   Color tokens (var(--navy) etc.) come from the compiled main.css :root.
   ===================================================================== */

:root {
  --hg-navy: var(--navy, oklch(0.24 0.06 265));
  --hg-navy-fg: var(--navy-foreground, oklch(0.98 0.01 80));
  --hg-gold: var(--gold, oklch(0.74 0.13 85));
  --hg-gold-fg: var(--gold-foreground, oklch(0.18 0.04 260));
  --hg-border: var(--border, oklch(0.9 0.01 80));
  --hg-muted: var(--muted-foreground, oklch(0.45 0.02 260));
  --hg-card: var(--card, #fff);
  --hg-secondary: var(--secondary, oklch(0.95 0.01 80));
  --hg-radius: 0.5rem;
}

/* ----- Layout container for Woo pages (matches theme max-w-7xl) ----- */
.hg-woo-wrap {
  max-width: 80rem;
  margin: 0 auto;
  padding: 2.5rem 1.25rem 4rem;
}
@media (min-width: 768px) {
  .hg-woo-wrap { padding-left: 2rem; padding-right: 2rem; }
}

.woocommerce .clear { clear: both; }

/* =====================================================================
   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,
.wc-block-components-button {
  background: var(--hg-navy);
  color: var(--hg-navy-fg);
  border: 0;
  border-radius: 9999px;
  padding: 0.7rem 1.6rem;
  font-weight: 600;
  font-size: 0.875rem;
  line-height: 1.2;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
  text-transform: none;
}
.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,
.wc-block-components-button:hover {
  background: var(--hg-gold);
  color: var(--hg-gold-fg);
}
.woocommerce a.button.disabled,
.woocommerce button.button:disabled,
.woocommerce button.button.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.woocommerce .button.added::after {
  margin-left: 0.4rem;
}

/* Quantity stepper */
.woocommerce .quantity .qty {
  width: 4.5rem;
  padding: 0.55rem 0.4rem;
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  text-align: center;
  background: var(--hg-card);
}

/* =====================================================================
   Archive / shop grid
   ===================================================================== */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
@media (min-width: 768px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
}
.woocommerce ul.products li.product::before { content: none; }

/* Result count + ordering bar */
.woocommerce .woocommerce-result-count {
  color: var(--hg-muted);
  font-size: 0.85rem;
  margin: 0 0 1rem;
}
.woocommerce .woocommerce-ordering select,
.woocommerce select {
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  padding: 0.5rem 0.75rem;
  background: var(--hg-card);
  font-size: 0.85rem;
}

/* =====================================================================
   Single product
   ===================================================================== */
.single-product div.product {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
@media (min-width: 900px) {
  .single-product div.product {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    align-items: start;
  }
}
.single-product div.product .woocommerce-product-gallery {
  width: 100% !important;
  margin: 0;
  float: none;
}
.single-product div.product .woocommerce-product-gallery__image img {
  border-radius: 0.75rem;
  border: 1px solid var(--hg-border);
}
.single-product div.product .summary {
  width: 100% !important;
  margin: 0;
  float: none;
}
.single-product div.product .product_title {
  font-size: clamp(1.6rem, 3vw, 2.25rem);
  line-height: 1.1;
  margin: 0 0 0.75rem;
}
.single-product .price,
.single-product div.product p.price {
  color: var(--hg-navy);
  font-size: 1.6rem;
  font-weight: 700;
  font-family: var(--font-display, inherit);
}
.single-product .price del {
  color: var(--hg-muted);
  font-weight: 400;
  font-size: 1.1rem;
  margin-right: 0.5rem;
}
.single-product .price ins { text-decoration: none; }
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 1rem; }
.woocommerce div.product form.cart { margin: 1.5rem 0; }
.woocommerce div.product form.cart .quantity { margin-right: 0.75rem; }
.woocommerce div.product .single_add_to_cart_button {
  padding: 0.85rem 2.2rem;
  font-size: 0.95rem;
}
.woocommerce div.product .product_meta {
  margin-top: 1.5rem;
  font-size: 0.8rem;
  color: var(--hg-muted);
  border-top: 1px solid var(--hg-border);
  padding-top: 1rem;
}

/* Stars */
.woocommerce .star-rating { color: var(--hg-gold); }
.woocommerce p.stars a { color: var(--hg-gold); }

/* Tabs (description / additional info / reviews -> spec table) */
.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1;
  margin-top: 1.5rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  border-bottom: 1px solid var(--hg-border);
  padding: 0 0 0.75rem;
  margin: 0 0 1.5rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { content: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent;
  border: 0;
  border-radius: 9999px;
  padding: 0;
  margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  padding: 0.5rem 1.1rem;
  border-radius: 9999px;
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--hg-muted);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  background: var(--hg-navy);
  color: var(--hg-navy-fg);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { content: none; }
.woocommerce table.shop_attributes {
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  overflow: hidden;
}
.woocommerce table.shop_attributes th {
  background: var(--hg-secondary);
  width: 35%;
}
.woocommerce table.shop_attributes th,
.woocommerce table.shop_attributes td {
  padding: 0.7rem 1rem;
  border-bottom: 1px solid var(--hg-border);
}

/* Related / upsell */
.woocommerce .related > h2,
.woocommerce .upsells > h2 {
  font-size: 1.5rem;
  margin: 2.5rem 0 1.25rem;
}

/* =====================================================================
   Cart
   ===================================================================== */
.woocommerce table.shop_table {
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
}
.woocommerce table.shop_table th {
  background: var(--hg-secondary);
  font-weight: 600;
  padding: 0.9rem 1rem;
}
.woocommerce table.shop_table td { padding: 0.9rem 1rem; }
.woocommerce table.cart img { width: 64px; border-radius: var(--hg-radius); }
.woocommerce a.remove {
  color: var(--hg-navy) !important;
  border: 1px solid var(--hg-border);
}
.woocommerce a.remove:hover {
  background: var(--hg-navy) !important;
  color: #fff !important;
}
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  padding: 1.25rem;
}
.woocommerce .cart-collaterals .cart_totals h2 { margin-top: 0; }
.woocommerce .wc-proceed-to-checkout a.checkout-button {
  display: block;
  text-align: center;
  font-size: 1rem;
}
.woocommerce .coupon .input-text {
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  padding: 0.6rem 0.85rem;
}

/* =====================================================================
   Checkout
   ===================================================================== */
.woocommerce form .form-row label { font-weight: 500; font-size: 0.85rem; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-page form .form-row input.input-text,
.woocommerce .input-text,
.select2-container .select2-selection {
  border: 1px solid var(--hg-border) !important;
  border-radius: var(--hg-radius) !important;
  padding: 0.65rem 0.85rem;
  background: var(--hg-card);
  min-height: 2.75rem;
}
.woocommerce #payment,
.woocommerce-checkout #payment {
  background: var(--hg-secondary);
  border-radius: var(--hg-radius);
}
.woocommerce #payment ul.payment_methods {
  border-bottom: 1px solid var(--hg-border);
}
.woocommerce #order_review,
.woocommerce-checkout #order_review {
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  padding: 1rem;
}
#place_order { width: 100%; }

/* =====================================================================
   My Account
   ===================================================================== */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0 0 1.5rem;
  padding: 0;
  border: 1px solid var(--hg-border);
  border-radius: var(--hg-radius);
  overflow: hidden;
}
.woocommerce-account .woocommerce-MyAccount-navigation li {
  border-bottom: 1px solid var(--hg-border);
}
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child { border-bottom: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li a {
  display: block;
  padding: 0.7rem 1rem;
  font-weight: 500;
  color: var(--hg-foreground, inherit);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
  background: var(--hg-navy);
  color: var(--hg-navy-fg);
}
@media (min-width: 768px) {
  .woocommerce-account .woocommerce-MyAccount-navigation { float: left; width: 25%; }
  .woocommerce-account .woocommerce-MyAccount-content { float: right; width: 72%; }
}

/* =====================================================================
   Breadcrumb
   ===================================================================== */
.woocommerce .woocommerce-breadcrumb {
  font-size: 0.8rem;
  color: var(--hg-muted);
  margin-bottom: 1.5rem;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--hg-navy); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--hg-gold); }

/* =====================================================================
   Sale flash / badges
   ===================================================================== */
.woocommerce span.onsale {
  background: var(--hg-gold);
  color: var(--hg-gold-fg);
  border-radius: 9999px;
  font-weight: 700;
  font-size: 0.7rem;
  padding: 0.3rem 0.7rem;
  min-height: 0;
  min-width: 0;
  line-height: 1.2;
  top: 0.75rem;
  left: 0.75rem;
  margin: 0;
}

/* =====================================================================
   Notices
   ===================================================================== */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews {
  border-radius: var(--hg-radius);
  border: 1px solid var(--hg-border);
  border-top: 3px solid var(--hg-gold);
  background: var(--hg-card);
  padding: 1rem 1.25rem;
  list-style: none;
}
.woocommerce-error { border-top-color: var(--destructive, #d33); }
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before { color: var(--hg-gold); }

/* =====================================================================
   Pagination
   ===================================================================== */
.woocommerce nav.woocommerce-pagination ul {
  border: 0;
  display: flex;
  gap: 0.4rem;
  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(--hg-border);
  border-radius: var(--hg-radius);
  padding: 0.5rem 0.85rem;
  min-width: 2.5rem;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--hg-navy);
  color: var(--hg-navy-fg);
  border-color: var(--hg-navy);
}

/* =====================================================================
   Widgets (shop sidebar)
   ===================================================================== */
.hg-shop-sidebar .widget { margin-bottom: 2rem; }
.hg-shop-sidebar .widget-title {
  font-family: var(--font-display, inherit);
  font-size: 1.05rem;
  margin-bottom: 0.75rem;
}
.woocommerce .widget_price_filter .ui-slider .ui-slider-range,
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  background: var(--hg-gold);
}

/* =====================================================================
   Mobile drawer sub-menu helpers (used by theme.js)
   ===================================================================== */
.hg-mobile-menu .menu li a {
  display: block;
  padding: 0.7rem 0.25rem;
  border-bottom: 1px solid var(--hg-border);
  font-weight: 500;
}
.hg-mobile-menu .menu li.menu-item-has-children { position: relative; }
.hg-mobile-menu .hg-sub-toggle {
  position: absolute;
  top: 0.35rem;
  right: 0;
  padding: 0.4rem;
  color: var(--hg-muted);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: transform 0.2s ease;
}
.hg-mobile-menu .hg-sub-toggle.hg-open { transform: rotate(180deg); }
.hg-mobile-menu .sub-menu {
  list-style: none;
  margin: 0 0 0 0.75rem;
  padding: 0;
  overflow: hidden;
}
.hg-mobile-menu .sub-menu.hg-sub-collapsed { display: none; }
.hg-mobile-menu .sub-menu li a {
  font-weight: 400;
  font-size: 0.9rem;
  color: var(--hg-muted);
}

/* =====================================================================
   Wishlist button active state (used by theme.js)
   ===================================================================== */
.hg-wish.hg-wish-active {
  background: var(--hg-gold) !important;
  color: var(--hg-gold-fg) !important;
}
