/* ============================================================
   TBT WooCommerce Styles
   assets/css/woocommerce.css
============================================================ */

/* ---- Global WC body ---- */
.tbt-woo .woocommerce,
.tbt-woo .woocommerce-page {
  color: var(--tbt-cream);
}

/* ---- Breadcrumb ---- */
.tbt-breadcrumb {
  font-family: var(--tbt-font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tbt-muted);
  margin-bottom: var(--tbt-sp-8);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--tbt-sp-2);
}
.tbt-breadcrumb a { color: var(--tbt-muted); }
.tbt-breadcrumb a:hover { color: var(--tbt-brass); }
.tbt-breadcrumb__sep { color: var(--tbt-border-strong); }

/* ---- Shop loop ---- */
.tbt-woo-main {
  background: var(--tbt-purple-ink);
  padding-block: var(--tbt-sp-16);
}

.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--tbt-sp-6);
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.woocommerce ul.products li.product {
  background: var(--tbt-surface) !important;
  border: 1px solid var(--tbt-border) !important;
  border-radius: var(--tbt-r-xl) !important;
  padding: var(--tbt-sp-6) !important;
  margin: 0 !important;
  position: relative;
  overflow: hidden;
  transition: transform var(--tbt-ease), box-shadow var(--tbt-ease), border-color var(--tbt-ease);
}
.woocommerce ul.products li.product::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--tbt-brass-dark), var(--tbt-brass));
  opacity: 0.4;
  transition: opacity var(--tbt-ease);
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--tbt-shadow-lg) !important;
  border-color: var(--tbt-border-strong) !important;
}
.woocommerce ul.products li.product:hover::before { opacity: 1; }

.woocommerce ul.products li.product img {
  border-radius: var(--tbt-r-md) !important;
  margin-bottom: var(--tbt-sp-4) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--tbt-font-heading) !important;
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  color: var(--tbt-white) !important;
  padding: 0 !important;
  margin-bottom: var(--tbt-sp-2) !important;
}

.woocommerce ul.products li.product .price {
  font-family: var(--tbt-font-heading) !important;
  font-size: 1.25rem !important;
  color: var(--tbt-brass) !important;
  font-weight: 700 !important;
}

/* ---- Buttons ---- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .cart .button,
.woocommerce .cart input.button,
.woocommerce #payment #place_order {
  background: var(--tbt-brass) !important;
  color: var(--tbt-purple-ink) !important;
  font-family: var(--tbt-font-body) !important;
  font-weight: 700 !important;
  font-size: 0.8125rem !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  border-radius: var(--tbt-r-sm) !important;
  border: none !important;
  padding: 12px var(--tbt-sp-8) !important;
  transition: background var(--tbt-ease), transform var(--tbt-ease-fast), box-shadow var(--tbt-ease-fast) !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce #payment #place_order:hover {
  background: var(--tbt-brass-light) !important;
  color: var(--tbt-purple-ink) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(201,168,76,0.3) !important;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt {
  background: var(--tbt-purple-mid) !important;
  color: var(--tbt-white) !important;
  border: 1px solid var(--tbt-purple-light) !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: var(--tbt-purple-light) !important;
}

/* ---- Single product ---- */
.woocommerce div.product {
  background: transparent;
}
.woocommerce div.product .product_title {
  font-family: var(--tbt-font-heading) !important;
  font-size: clamp(1.75rem, 3.5vw, 2.25rem) !important;
  font-weight: 700 !important;
  color: var(--tbt-white) !important;
  letter-spacing: -0.01em !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--tbt-font-heading) !important;
  font-size: 2rem !important;
  color: var(--tbt-brass) !important;
  font-weight: 700 !important;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--tbt-cream-mid);
  font-size: 1.0625rem;
  line-height: 1.7;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  background: transparent !important;
  border-bottom: 1px solid var(--tbt-border) !important;
  padding: 0 !important;
  margin-bottom: var(--tbt-sp-8) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--tbt-font-mono) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--tbt-muted) !important;
  padding: var(--tbt-sp-3) var(--tbt-sp-6) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--tbt-brass) !important;
  border-bottom: 2px solid var(--tbt-brass) !important;
}
.woocommerce div.product .woocommerce-tabs .panel {
  background: var(--tbt-surface) !important;
  border: 1px solid var(--tbt-border) !important;
  border-radius: var(--tbt-r-lg) !important;
  padding: var(--tbt-sp-8) !important;
  color: var(--tbt-cream-mid) !important;
}

/* ---- Cart / Checkout ---- */
.woocommerce-cart table.cart,
.woocommerce-checkout table.shop_table {
  background: var(--tbt-surface) !important;
  border: 1px solid var(--tbt-border) !important;
  border-radius: var(--tbt-r-lg) !important;
  overflow: hidden !important;
}
.woocommerce-cart table.cart th,
.woocommerce-checkout table.shop_table th {
  background: var(--tbt-surface-raised) !important;
  color: var(--tbt-brass) !important;
  font-family: var(--tbt-font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid var(--tbt-border) !important;
  padding: var(--tbt-sp-4) var(--tbt-sp-6) !important;
}
.woocommerce-cart table.cart td,
.woocommerce-checkout table.shop_table td {
  border-bottom: 1px solid var(--tbt-border) !important;
  color: var(--tbt-cream-mid) !important;
  padding: var(--tbt-sp-4) var(--tbt-sp-6) !important;
}
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review {
  background: var(--tbt-surface) !important;
  border: 1px solid var(--tbt-border) !important;
  border-radius: var(--tbt-r-lg) !important;
  padding: var(--tbt-sp-8) !important;
}

/* ---- Form fields ---- */
.woocommerce form .form-row label {
  font-family: var(--tbt-font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--tbt-muted) !important;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: var(--tbt-surface) !important;
  border: 1px solid var(--tbt-border) !important;
  border-radius: var(--tbt-r-md) !important;
  color: var(--tbt-cream) !important;
  font-family: var(--tbt-font-body) !important;
  font-size: 1rem !important;
  padding: 10px var(--tbt-sp-4) !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--tbt-brass) !important;
  box-shadow: var(--tbt-shadow-brass) !important;
  outline: none !important;
}

/* ---- Notices ---- */
.woocommerce-message,
.woocommerce-info {
  background: var(--tbt-surface) !important;
  border-top-color: var(--tbt-brass) !important;
  color: var(--tbt-cream-mid) !important;
}
.woocommerce-error {
  background: rgba(192,57,43,0.1) !important;
  border-top-color: var(--tbt-danger) !important;
  color: var(--tbt-cream-mid) !important;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  .woocommerce ul.products {
    grid-template-columns: 1fr !important;
  }
}
