/* ═══════════════════════════════════════════════════
   VIVIA STUDIO 2 — WooCommerce Extended Styles
═══════════════════════════════════════════════════ */

/* ── Shop Wrapper ── */
.vs2-woo-wrap {
  padding-top: calc(var(--nav-h) + 40px);
  min-height: 60vh;
}
.vs2-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 60px;
}

/* ── Shop Header ── */
.woocommerce-products-header {
  padding: 40px 0 32px;
}
.woocommerce-products-header__title {
  font-family: var(--font-display);
  font-size: clamp(40px, 5vw, 72px);
  color: var(--black);
  line-height: 1;
}

/* ── Product grid ── */
.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin: 0;
  padding: 0;
}
.woocommerce ul.products li.product {
  margin: 0;
  padding: 0;
  overflow: hidden;
}
.woocommerce ul.products li.product a.woocommerce-loop-product__link {
  display: block;
  overflow: hidden;
}
.woocommerce ul.products li.product a img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
}
.woocommerce ul.products li.product .button {
  width: 100%;
  text-align: center;
  margin-top: 8px;
}

/* ── Single product ── */
.woocommerce div.product .woocommerce-product-gallery {
  float: none;
  width: 100%;
  max-width: 600px;
}
.woocommerce div.product div.summary {
  float: none;
  width: 100%;
}
.woocommerce div.product .product_title {
  font-family: var(--font-display);
  font-size: 52px;
  line-height: 1;
  color: var(--black);
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--accent);
  font-size: 28px;
  font-weight: 700;
}

/* ── Notices ── */
.woocommerce-message,
.woocommerce-info {
  border-top-color: var(--accent);
}
.woocommerce-message::before,
.woocommerce-info::before { color: var(--accent); }

/* ── Checkout / Cart ── */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border-radius: 0;
  border: 1px solid var(--light);
  padding: 10px 14px;
  font-family: var(--font-body);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: none;
}

/* ── Pagination ── */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border-radius: 0;
  padding: 8px 14px;
}
.woocommerce nav.woocommerce-pagination ul li a:focus,
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--accent);
  color: var(--black);
}

/* ── Breadcrumb ── */
.woocommerce .woocommerce-breadcrumb {
  font-size: 12px;
  color: var(--gray);
  letter-spacing: 0.5px;
  padding: 16px 0;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--black); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--accent); }

/* ── Sale badge ── */
.woocommerce span.onsale {
  background: var(--accent);
  color: var(--black);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-radius: 0;
  min-height: unset;
  min-width: unset;
  padding: 4px 10px;
  line-height: 1.6;
}

@media (max-width: 1024px) {
  .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); }
  .vs2-container { padding: 0 40px; }
}
@media (max-width: 768px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .vs2-container { padding: 0 24px; }
}
@media (max-width: 480px) {
  .woocommerce ul.products { grid-template-columns: 1fr; }
}
