/* =============================================
   BAUER'S HARDWARE — WOOCOMMERCE OVERRIDES
   ============================================= */

/* ---------- Variation Table ---------- */
.vartable-wrapper {
  width: 100%;
  overflow-x: auto;
  margin: 24px 0;
  border: 1px solid var(--color-border);
  border-radius: 2px;
}

.woocommerce-variation-add-to-cart-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  font-size: 14px;
}

.woocommerce-variation-add-to-cart-table thead {
  background: #1a2744;
  color: var(--color-white);
}

.woocommerce-variation-add-to-cart-table thead th {
  padding: 14px 16px;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: left;
  white-space: nowrap;
}

.woocommerce-variation-add-to-cart-table tbody td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}

.woocommerce-variation-add-to-cart-table tbody tr:last-child td {
  border-bottom: none;
}

.woocommerce-variation-add-to-cart-table tbody tr:hover {
  background: var(--color-grey);
}

.woocommerce-variation-add-to-cart-table .variation-price {
  font-weight: 500;
  color: var(--color-charcoal);
}

.woocommerce-variation-add-to-cart-table .variation-price del {
  color: var(--color-text-light);
  font-weight: 400;
  margin-right: 6px;
}

.woocommerce-variation-add-to-cart-table .variation-price ins {
  text-decoration: none;
  color: var(--color-sale);
  font-weight: 600;
}

.woocommerce-variation-add-to-cart-table .variation-sku {
  font-size: 12px;
  color: var(--color-text-light);
  font-family: monospace;
}

.woocommerce-variation-add-to-cart-table .button,
.woocommerce-variation-add-to-cart-table .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 18px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--color-brass);
  color: var(--color-white);
  border: 1px solid var(--color-brass);
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
}

.woocommerce-variation-add-to-cart-table .button:hover,
.woocommerce-variation-add-to-cart-table .btn:hover {
  background: var(--color-brass-hover);
  border-color: var(--color-brass-hover);
}

/* ---------- WooCommerce Notices / Messages ---------- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
p.no-comments {
  font-family: var(--font-body);
  font-size: 14px;
  padding: 16px 20px;
  margin-bottom: 24px;
  border-radius: 2px;
  line-height: 1.6;
}

.woocommerce-message {
  background: #f0f7f0;
  border-left: 3px solid #4caf50;
  color: #2e7d32;
}

.woocommerce-info {
  background: var(--color-grey);
  border-left: 3px solid var(--color-brass);
  color: var(--color-text);
}

.woocommerce-error {
  background: #fdf0ef;
  border-left: 3px solid var(--color-sale);
  color: var(--color-sale);
  list-style: none;
  padding-left: 20px;
}

.woocommerce-message a,
.woocommerce-info a {
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.woocommerce-message .button,
.woocommerce-info .button {
  float: right;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 8px 20px;
  background: var(--color-brass);
  color: var(--color-white);
  border: 1px solid var(--color-brass);
  border-radius: 2px;
  transition: all var(--transition);
}

.woocommerce-message .button:hover,
.woocommerce-info .button:hover {
  background: var(--color-brass-hover);
  border-color: var(--color-brass-hover);
}

/* ---------- Cart Page ---------- */
.woocommerce-cart-form {
  margin-bottom: 48px;
}

.woocommerce-cart-form table.shop_table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  font-size: 14px;
}

.woocommerce-cart-form table.shop_table thead {
  background: #1a2744;
  color: var(--color-white);
}

.woocommerce-cart-form table.shop_table thead th {
  padding: 14px 16px;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: left;
}

.woocommerce-cart-form table.shop_table td {
  padding: 16px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}

.woocommerce-cart-form table.shop_table td.product-thumbnail img {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 2px;
  border: 1px solid var(--color-border);
}

.woocommerce-cart-form table.shop_table td.product-name a {
  font-weight: 500;
  color: var(--color-charcoal);
  transition: color var(--transition-fast);
}

.woocommerce-cart-form table.shop_table td.product-name a:hover {
  color: var(--color-brass);
}

.woocommerce-cart-form table.shop_table td.product-remove a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  font-size: 18px;
  color: var(--color-text-light);
  border: 1px solid var(--color-border);
  border-radius: 2px;
  transition: all var(--transition-fast);
}

.woocommerce-cart-form table.shop_table td.product-remove a:hover {
  background: var(--color-sale);
  color: var(--color-white);
  border-color: var(--color-sale);
}

.woocommerce-cart-form .actions {
  padding: 20px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.woocommerce-cart-form .actions .coupon {
  display: flex;
  gap: 8px;
  align-items: center;
}

.woocommerce-cart-form .actions .coupon input[type="text"] {
  padding: 10px 14px;
  font-size: 13px;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  width: 200px;
  transition: border-color var(--transition-fast);
}

.woocommerce-cart-form .actions .coupon input[type="text"]:focus {
  outline: none;
  border-color: var(--color-brass);
}

.woocommerce-cart-form .actions .coupon .button,
.woocommerce-cart-form .actions > .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--color-charcoal);
  color: var(--color-white);
  border: 1px solid var(--color-charcoal);
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--transition);
}

.woocommerce-cart-form .actions .coupon .button:hover,
.woocommerce-cart-form .actions > .button:hover {
  background: var(--color-brass);
  border-color: var(--color-brass);
}

/* Cart totals */
.cart_totals {
  max-width: 480px;
  margin-left: auto;
}

.cart_totals h2 {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: 24px;
  margin-bottom: 20px;
}

.cart_totals table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin-bottom: 24px;
}

.cart_totals table th,
.cart_totals table td {
  padding: 14px 0;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}

.cart_totals table th {
  font-weight: 500;
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--color-text-mid);
  width: 40%;
}

.cart_totals table .order-total th,
.cart_totals table .order-total td {
  font-size: 16px;
  font-weight: 600;
  color: var(--color-charcoal);
  border-bottom: none;
}

.cart_totals .wc-proceed-to-checkout .checkout-button {
  display: block;
  width: 100%;
  padding: 16px 32px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  background: var(--color-brass);
  color: var(--color-white);
  border: 1px solid var(--color-brass);
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--transition);
}

.cart_totals .wc-proceed-to-checkout .checkout-button:hover {
  background: var(--color-brass-hover);
  border-color: var(--color-brass-hover);
}

/* ---------- Checkout Form ---------- */
.woocommerce-checkout .col2-set {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: 40px;
}

.woocommerce-checkout .col2-set h3 {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: 22px;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-checkout .form-row {
  margin-bottom: 16px;
}

.woocommerce-checkout .form-row label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-mid);
  margin-bottom: 6px;
}

.woocommerce-checkout .form-row .required {
  color: var(--color-sale);
}

.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row .select2-container .select2-selection--single {
  width: 100%;
  padding: 12px 14px;
  font-size: 14px;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  background: var(--color-white);
  transition: border-color var(--transition-fast);
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row textarea:focus {
  outline: none;
  border-color: var(--color-brass);
}

.woocommerce-checkout #order_review_heading {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: 22px;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-checkout #order_review table.shop_table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin-bottom: 24px;
}

.woocommerce-checkout #order_review table.shop_table thead {
  background: #1a2744;
  color: var(--color-white);
}

.woocommerce-checkout #order_review table.shop_table thead th {
  padding: 12px 16px;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: left;
}

.woocommerce-checkout #order_review table.shop_table td,
.woocommerce-checkout #order_review table.shop_table th {
  padding: 12px 16px;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-checkout #order_review table.shop_table tfoot .order-total th,
.woocommerce-checkout #order_review table.shop_table tfoot .order-total td {
  font-size: 16px;
  font-weight: 600;
  color: var(--color-charcoal);
}

.woocommerce-checkout .woocommerce-checkout-payment {
  background: var(--color-grey);
  padding: 24px;
  border-radius: 2px;
  margin-top: 24px;
}

.woocommerce-checkout .woocommerce-checkout-payment .payment_methods {
  margin-bottom: 20px;
}

.woocommerce-checkout .woocommerce-checkout-payment .payment_methods li {
  padding: 14px 0;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-checkout .woocommerce-checkout-payment .payment_methods li:last-child {
  border-bottom: none;
}

.woocommerce-checkout .woocommerce-checkout-payment .payment_methods li label {
  font-weight: 500;
  cursor: pointer;
}

.woocommerce-checkout .woocommerce-checkout-payment .payment_box {
  padding: 14px 0 0;
  font-size: 13px;
  color: var(--color-text-mid);
  line-height: 1.6;
}

.woocommerce-checkout #place_order {
  display: block;
  width: 100%;
  padding: 16px 32px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  background: var(--color-brass);
  color: var(--color-white);
  border: 1px solid var(--color-brass);
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--transition);
}

.woocommerce-checkout #place_order:hover {
  background: var(--color-brass-hover);
  border-color: var(--color-brass-hover);
}

/* ---------- My Account ---------- */
.woocommerce-MyAccount-navigation {
  width: 240px;
  float: left;
  margin-right: 48px;
}

.woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 14px 0;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-mid);
  transition: color var(--transition-fast);
}

.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  color: var(--color-brass);
}

.woocommerce-MyAccount-navigation ul li.is-active a {
  border-right: 2px solid var(--color-brass);
}

.woocommerce-MyAccount-content {
  overflow: hidden;
}

.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
  font-family: var(--font-heading);
  font-weight: 400;
  margin-bottom: 16px;
}

.woocommerce-MyAccount-content table.shop_table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.woocommerce-MyAccount-content table.shop_table thead {
  background: #1a2744;
  color: var(--color-white);
}

.woocommerce-MyAccount-content table.shop_table thead th {
  padding: 12px 16px;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: left;
}

.woocommerce-MyAccount-content table.shop_table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-MyAccount-content .button,
.woocommerce-MyAccount-content .woocommerce-Button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--color-brass);
  color: var(--color-white);
  border: 1px solid var(--color-brass);
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--transition);
}

.woocommerce-MyAccount-content .button:hover,
.woocommerce-MyAccount-content .woocommerce-Button:hover {
  background: var(--color-brass-hover);
  border-color: var(--color-brass-hover);
}

/* My Account login / register forms */
.woocommerce-form-login,
.woocommerce-form-register {
  max-width: 480px;
  margin: 0 auto;
}

.woocommerce-form-login .form-row,
.woocommerce-form-register .form-row {
  margin-bottom: 16px;
}

.woocommerce-form-login label,
.woocommerce-form-register label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-mid);
  margin-bottom: 6px;
}

.woocommerce-form-login input.input-text,
.woocommerce-form-register input.input-text {
  width: 100%;
  padding: 12px 14px;
  font-size: 14px;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  transition: border-color var(--transition-fast);
}

.woocommerce-form-login input.input-text:focus,
.woocommerce-form-register input.input-text:focus {
  outline: none;
  border-color: var(--color-brass);
}

.woocommerce-form-login .woocommerce-button,
.woocommerce-form-register .woocommerce-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 32px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--color-brass);
  color: var(--color-white);
  border: 1px solid var(--color-brass);
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--transition);
  margin-top: 8px;
}

.woocommerce-form-login .woocommerce-button:hover,
.woocommerce-form-register .woocommerce-button:hover {
  background: var(--color-brass-hover);
  border-color: var(--color-brass-hover);
}

/* ---------- Add to Cart Buttons (global) ---------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .button.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 14px 32px;
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
  background: var(--color-brass);
  color: var(--color-white);
  border: 1px solid var(--color-brass);
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce .button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background: var(--color-brass-hover);
  border-color: var(--color-brass-hover);
  color: var(--color-white);
}

.woocommerce a.button.disabled,
.woocommerce button.button.disabled,
.woocommerce input.button.disabled,
.woocommerce a.button:disabled,
.woocommerce button.button:disabled,
.woocommerce input.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ---------- Quantity Inputs ---------- */
.woocommerce .quantity {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  overflow: hidden;
}

.woocommerce .quantity .qty-btn,
.woocommerce .quantity .minus,
.woocommerce .quantity .plus {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--color-grey);
  border: none;
  font-size: 16px;
  font-weight: 400;
  color: var(--color-text);
  cursor: pointer;
  transition: background var(--transition-fast);
  user-select: none;
  -webkit-user-select: none;
}

.woocommerce .quantity .qty-btn:hover,
.woocommerce .quantity .minus:hover,
.woocommerce .quantity .plus:hover {
  background: var(--color-stone);
}

.woocommerce .quantity input.qty {
  width: 48px;
  height: 36px;
  text-align: center;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  border: none;
  border-left: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border);
  background: var(--color-white);
  -moz-appearance: textfield;
  appearance: textfield;
}

.woocommerce .quantity input.qty::-webkit-inner-spin-button,
.woocommerce .quantity input.qty::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.woocommerce .quantity input.qty:focus {
  outline: none;
}

/* ---------- Sale Badge ---------- */
.woocommerce span.onsale {
  background: var(--color-sale);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 2px;
  min-width: auto;
  min-height: auto;
  line-height: 1.4;
}

/* ---------- Star Ratings ---------- */
.woocommerce .star-rating {
  color: var(--color-brass);
}

.woocommerce .star-rating::before {
  color: var(--color-border);
}

/* ---------- Breadcrumbs ---------- */
.woocommerce .woocommerce-breadcrumb {
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--color-text-light);
  padding: 16px 0;
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--color-text-mid);
  transition: color var(--transition-fast);
}

.woocommerce .woocommerce-breadcrumb a:hover {
  color: var(--color-brass);
}

/* ---------- Pagination ---------- */
.woocommerce nav.woocommerce-pagination {
  text-align: center;
  margin-top: 40px;
}

.woocommerce nav.woocommerce-pagination ul {
  display: inline-flex;
  gap: 4px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: 13px;
  font-weight: 500;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  color: var(--color-text);
  transition: all var(--transition-fast);
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
  border-color: var(--color-charcoal);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--color-charcoal);
  border-color: var(--color-charcoal);
  color: var(--color-white);
}

/* ---------- Responsive ---------- */
@media (max-width: 768px) {
  .woocommerce-checkout .col2-set {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .woocommerce-MyAccount-navigation {
    float: none;
    width: 100%;
    margin-right: 0;
    margin-bottom: 32px;
  }

  .woocommerce-MyAccount-navigation ul {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
  }

  .woocommerce-MyAccount-navigation ul li {
    border-bottom: none;
  }

  .woocommerce-MyAccount-navigation ul li a {
    padding: 8px 16px;
    font-size: 12px;
    border: 1px solid var(--color-border);
    border-radius: 2px;
  }

  .woocommerce-MyAccount-navigation ul li.is-active a {
    border-color: var(--color-brass);
    border-right-width: 1px;
    color: var(--color-brass);
  }

  .woocommerce-cart-form table.shop_table thead {
    display: none;
  }

  .woocommerce-cart-form table.shop_table tbody tr {
    display: flex;
    flex-wrap: wrap;
    padding: 16px 0;
    border-bottom: 1px solid var(--color-border);
    align-items: center;
    gap: 8px;
  }

  .woocommerce-cart-form table.shop_table td {
    border-bottom: none;
    padding: 4px 8px;
  }

  .woocommerce-cart-form .actions {
    flex-direction: column;
    align-items: stretch;
  }

  .woocommerce-cart-form .actions .coupon {
    flex-direction: column;
  }

  .woocommerce-cart-form .actions .coupon input[type="text"] {
    width: 100%;
  }

  .cart_totals {
    max-width: 100%;
  }

  .vartable-wrapper {
    margin: 16px -16px;
    width: calc(100% + 32px);
    border-radius: 0;
    border-left: none;
    border-right: none;
  }
}
