/* ==========================================================================
   KATA Camperbox — WooCommerce Overrides
   ========================================================================== */

/* ─── WooCommerce Global ─────────────────────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  background-color: var(--c-gold);
  color: var(--c-dark);
  border: 2px solid var(--c-gold);
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.875rem 2rem;
  transition: background var(--dur-med) var(--ease-out), border-color var(--dur-med);
  cursor: pointer;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
  background-color: var(--c-gold-dark);
  border-color: var(--c-gold-dark);
  color: var(--c-dark);
}

/* Alt button */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background-color: var(--c-dark);
  color: var(--c-white);
  border-color: var(--c-dark);
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background-color: var(--c-dark-2);
  border-color: var(--c-dark-2);
}

/* Price */
.woocommerce .price,
.woocommerce-Price-amount {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--c-dark);
}

ins .woocommerce-Price-amount { color: var(--c-dark); }
del .woocommerce-Price-amount { color: rgba(41,41,41,0.45); font-weight: 400; }

/* ─── Product Archive ────────────────────────────────────────────────────── */
.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce ul.products li.product {
  background: var(--c-white);
  border: 1px solid var(--c-border-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--dur-med) var(--ease-out), box-shadow var(--dur-med);
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.1);
}

.woocommerce ul.products li.product img {
  width: 100%;
  height: 280px;
  object-fit: cover;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: var(--space-md) var(--space-md) 0.25rem;
}

.woocommerce ul.products li.product .price {
  padding: 0 var(--space-md) var(--space-md);
}

.woocommerce ul.products li.product .button {
  margin: 0 var(--space-md) var(--space-md);
}

/* ─── Single Product ─────────────────────────────────────────────────────── */
.woocommerce div.product .product_title {
  font-family: var(--font-display);
  font-size: var(--text-display);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.05;
  margin-bottom: var(--space-sm);
}

.woocommerce div.product p.price {
  font-size: var(--text-xl);
  margin-bottom: var(--space-md);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-bottom: 1px solid var(--c-border-dark);
  padding: 0;
  list-style: none;
  display: flex;
  gap: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 1rem 1.5rem;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(41,41,41,0.5);
  border-bottom: 2px solid transparent;
  transition: color var(--dur-fast), border-color var(--dur-fast);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--c-dark);
  border-bottom-color: var(--c-gold);
}

/* ─── Cart ───────────────────────────────────────────────────────────────── */
.woocommerce table.shop_table {
  border: 1px solid var(--c-border-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border-collapse: separate;
}

.woocommerce table.shop_table th {
  background: var(--c-off-white);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 1rem 1.5rem;
}

.woocommerce table.shop_table td {
  padding: 1.25rem 1.5rem;
  border-top: 1px solid var(--c-border-dark);
}

/* ─── Checkout ───────────────────────────────────────────────────────────── */
.woocommerce form .form-row label {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--c-dark);
  margin-bottom: 0.4rem;
  display: block;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  border: 1.5px solid rgba(41,41,41,0.2);
  border-radius: var(--radius-md);
  padding: 0.875rem 1rem;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--c-dark);
  width: 100%;
  transition: border-color var(--dur-fast);
  background: var(--c-white);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  outline: none;
  border-color: var(--c-gold);
  box-shadow: 0 0 0 3px rgba(254,197,62,0.15);
}

/* ─── Notices ────────────────────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: var(--radius-md);
  border-left-width: 4px;
  padding: 1rem 1.25rem;
  font-size: var(--text-sm);
}

.woocommerce-message { border-left-color: var(--c-gold); background: rgba(254,197,62,0.08); }
.woocommerce-info    { border-left-color: #3b82f6; background: rgba(59,130,246,0.06); }
.woocommerce-error   { border-left-color: #ef4444; background: rgba(239,68,68,0.06); }

/* ─── Star Ratings ───────────────────────────────────────────────────────── */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before { color: var(--c-gold); }
