/*
 * COAST LASER — WooCommerce Base Overrides
 * Targets core WooCommerce markup classes.
 */

/* ── WooCommerce Reset ────────────────────────────────────── */
.woocommerce,
.woocommerce-page {
  font-family: var(--cl-font-body);
}

/* Remove default WC star rating colouring — we style it ourselves */
.star-rating span::before,
.woocommerce-product-rating .star-rating::before {
  color: var(--cl-sand-dark);
}

/* ── Shop Layout ──────────────────────────────────────────── */
.woocommerce .woocommerce-breadcrumb {
  font-size: var(--cl-text-xs);
  color: var(--cl-text-muted);
  margin-bottom: 1.5rem;
  padding: 0;
  background: none;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--cl-teal); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--cl-teal-mid); }

/* Products toolbar (result count + orderby) */
.woocommerce .woocommerce-result-count {
  font-size: var(--cl-text-sm);
  color: var(--cl-text-muted);
  margin: 0;
}
.woocommerce .woocommerce-ordering select {
  padding: 0.55rem 2rem 0.55rem 0.875rem;
  border: 1.5px solid var(--cl-border-mid);
  border-radius: var(--cl-radius-sm);
  font-size: var(--cl-text-sm);
  color: var(--cl-text);
  background: var(--cl-white);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B8589' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.875rem center;
  cursor: pointer;
}

/* Products grid */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 1.5rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Individual product li */
.woocommerce ul.products li.product {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
  background: var(--cl-white);
  border-radius: var(--cl-radius);
  border: 1px solid var(--cl-border);
  overflow: hidden;
  transition: transform 0.28s var(--cl-ease), box-shadow 0.28s var(--cl-ease);
  position: relative;
  display: flex;
  flex-direction: column;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-6px);
  box-shadow: var(--cl-shadow-md);
}

/* Product image */
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product .woocommerce-loop-product__link img {
  aspect-ratio: 1;
  object-fit: cover;
  width: 100%;
  height: auto;
  transition: transform 0.45s var(--cl-ease);
  border-radius: 0;
  margin: 0 !important;
}
.woocommerce ul.products li.product:hover img { transform: scale(1.05); }

/* Onsale badge */
.woocommerce ul.products li.product .onsale {
  top: 10px;
  left: 10px;
  background: var(--cl-coral);
  color: #fff;
  border-radius: var(--cl-radius-pill);
  font-size: var(--cl-text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 3px 10px;
  border: none;
  min-height: auto;
  line-height: 1.6;
}

/* Product title & price wrapper */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  font-family: var(--cl-font-body) !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  color: var(--cl-navy) !important;
  padding: 1rem 1rem 0.3rem !important;
  margin: 0 !important;
  line-height: 1.35 !important;
}

.woocommerce ul.products li.product .price {
  font-family: var(--cl-font-body) !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: var(--cl-teal) !important;
  padding: 0 1rem 0 !important;
  margin: 0 0 0.25rem !important;
  display: block !important;
}
.woocommerce ul.products li.product .price del {
  color: var(--cl-text-muted) !important;
  font-size: 0.82rem !important;
  font-weight: 400 !important;
  margin-right: 4px !important;
}
.woocommerce ul.products li.product .price ins {
  text-decoration: none !important;
  font-weight: 700 !important;
}

/* Add to cart button on archive */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  background: var(--cl-navy) !important;
  color: #fff !important;
  border: none !important;
  padding: 0.875rem 1rem !important;
  font-size: var(--cl-text-xs) !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  margin-top: auto !important;
  transition: background var(--cl-transition) !important;
  box-shadow: none !important;
  opacity: 0 !important;
  transform: translateY(4px) !important;
  transition: background var(--cl-transition), opacity 0.2s, transform 0.2s !important;
}
.woocommerce ul.products li.product:hover .button,
.woocommerce ul.products li.product:hover a.button {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button:hover {
  background: var(--cl-teal) !important;
}

/* Always show on touch */
@media (hover: none) {
  .woocommerce ul.products li.product .button,
  .woocommerce ul.products li.product a.button {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* ── Pagination ───────────────────────────────────────────── */
.woocommerce nav.woocommerce-pagination {
  margin-top: 3rem;
  text-align: center;
}
.woocommerce nav.woocommerce-pagination ul {
  display: inline-flex;
  gap: 0.4rem;
  list-style: none;
  margin: 0;
  padding: 0;
  border: none;
}
.woocommerce nav.woocommerce-pagination ul li {
  display: block;
  border: none;
  float: none;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px; height: 38px;
  border-radius: var(--cl-radius-sm);
  border: 1.5px solid var(--cl-border-mid);
  color: var(--cl-text-mid);
  font-size: var(--cl-text-sm);
  font-weight: 500;
  transition: all var(--cl-transition);
  background: none;
}
.woocommerce nav.woocommerce-pagination ul li a:hover { border-color: var(--cl-teal); color: var(--cl-teal); background: var(--cl-teal-pale); }
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--cl-teal);
  border-color: var(--cl-teal);
  color: #fff;
}

/* ── WooCommerce Notices ──────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: var(--cl-radius-sm) !important;
  border-top: none !important;
  padding: 1rem 1.25rem 1rem 3rem !important;
  margin-bottom: 1.5rem !important;
  font-size: var(--cl-text-sm) !important;
}
.woocommerce-message {
  background: var(--cl-teal-pale) !important;
  color: var(--cl-teal) !important;
  border-left: 3px solid var(--cl-teal) !important;
}
.woocommerce-info {
  background: #EEF4FB !important;
  color: #3066BE !important;
  border-left: 3px solid #3066BE !important;
}
.woocommerce-error {
  background: var(--cl-coral-light) !important;
  color: var(--cl-coral) !important;
  border-left: 3px solid var(--cl-coral) !important;
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
  top: 1rem !important;
  color: inherit !important;
}

/* ── Shop Sidebar Widgets ─────────────────────────────────── */
.widget_layered_nav ul,
.widget_product_categories ul {
  list-style: none;
  margin: 0;
}
.widget_layered_nav ul li a,
.widget_product_categories ul li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 0;
  font-size: var(--cl-text-sm);
  color: var(--cl-text-mid);
  border-bottom: 1px solid var(--cl-border);
  transition: color var(--cl-transition);
}
.widget_layered_nav ul li a:hover,
.widget_product_categories ul li a:hover { color: var(--cl-teal); }
.widget_layered_nav ul li.chosen a { font-weight: 600; color: var(--cl-teal); }

/* Price filter */
.widget_price_filter .price_slider_wrapper .ui-widget-content { background: var(--cl-border-mid); }
.widget_price_filter .price_slider_wrapper .ui-slider-range { background: var(--cl-teal); }
.widget_price_filter .price_slider_wrapper .ui-slider-handle { background: var(--cl-teal); border: 3px solid #fff; box-shadow: var(--cl-shadow-sm); }

/* ── Star Ratings ─────────────────────────────────────────── */
.star-rating { color: var(--cl-sand-dark); }
.star-rating::before { color: var(--cl-grey-100); }
.woocommerce p.stars a { color: var(--cl-sand-dark); }
.woocommerce p.stars a:hover { color: var(--cl-sand-dark); }
