/**
 * WooCommerce specific styles for Pretereo theme
 *
 * Contains styles for WooCommerce elements
 */

/* Shop Page */
.woocommerce-products-header {
  margin-bottom: var(--spacing-md);
}

.woocommerce-result-count,
.woocommerce-ordering {
  margin-bottom: var(--spacing-md);
}

.woocommerce-ordering select {
  padding: 0.5rem;
  border-radius: var(--border-radius-sm);
  border: 1px solid var(--color-gray);
}

/* Product Cards */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background-color: var(--color-white);
  border-radius: var(--border-radius-md);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  text-align: center;
  padding-bottom: 1rem;
  margin-bottom: 2rem;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  transform: translateY(-5px);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-category__title {
  padding: 0.5rem 1rem;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-dark);
}

.woocommerce ul.products li.product .price {
  color: var(--color-primary);
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}

.woocommerce ul.products li.product .price del {
  color: var(--color-gray);
  opacity: 0.7;
  margin-right: 0.5rem;
}

.woocommerce ul.products li.product .price ins {
  font-weight: 700;
  text-decoration: none;
}

.woocommerce ul.products li.product .button {
  margin-top: 0.5rem;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-weight: 500;
  border-radius: var(--border-radius-sm);
  transition: background-color var(--transition-fast);
}

.woocommerce ul.products li.product .button:hover {
  background-color: #7d3c98;
}

.woocommerce a.added_to_cart {
  padding-top: 0.5rem;
  color: var(--color-primary);
  font-weight: 500;
}

/* Sale Badge */
.woocommerce span.onsale {
  background-color: var(--color-secondary);
  color: var(--color-white);
  min-height: 3em;
  min-width: 3em;
  line-height: 3em;
  border-radius: 50%;
  font-weight: 700;
  font-size: 0.857em;
  z-index: 9;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination {
  margin: 2rem 0;
}

.woocommerce nav.woocommerce-pagination ul {
  border: none;
}

.woocommerce nav.woocommerce-pagination ul li {
  border-right: none;
  margin: 0 0.3rem;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  padding: 0.8em 1em;
  background-color: var(--color-light-gray);
  color: var(--color-dark);
  border-radius: var(--border-radius-sm);
}

.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-color: var(--color-primary);
  color: var(--color-white);
}

/* Single Product */
.woocommerce div.product div.images .woocommerce-product-gallery__trigger {
  background-color: var(--color-white);
}

.woocommerce div.product .product_title {
  font-size: 2rem;
  margin-bottom: 1rem;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--color-primary);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 1rem;
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
  opacity: 0.7;
  color: var(--color-gray);
  margin-right: 0.5rem;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
  font-weight: 700;
  text-decoration: none;
}

.woocommerce div.product form.cart div.quantity {
  margin-right: 1rem;
}

.woocommerce .quantity .qty {
  width: 5em;
  padding: 0.5rem;
  border-radius: var(--border-radius-sm);
}

.woocommerce div.product form.cart .button {
  background-color: var(--color-primary);
  color: var(--color-white);
  font-weight: 500;
  padding: 0.8em 2em;
  border-radius: var(--border-radius-sm);
  transition: background-color var(--transition-fast);
}

.woocommerce div.product form.cart .button:hover {
  background-color: #7d3c98;
}

/* Product Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0 0 0 5px;
  margin-bottom: 2rem;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border-radius: var(--border-radius-sm) var(--border-radius-sm) 0 0;
  background-color: var(--color-light-gray);
  border-color: #d3ced2;
  margin-right: 0.5rem;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-weight: 500;
  color: var(--color-dark);
  padding: 0.8em 1.5em;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  background-color: var(--color-white);
  border-bottom-color: var(--color-white);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--color-primary);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
  display: none;
}

.woocommerce div.product .woocommerce-tabs .panel {
  padding: 1.5rem;
  border: 1px solid #d3ced2;
  border-top: none;
  border-radius: 0 0 var(--border-radius-sm) var(--border-radius-sm);
}

.woocommerce div.product .woocommerce-tabs .panel h2:first-of-type {
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

/* Reviews */
.woocommerce #reviews #comments h2 {
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

.woocommerce #reviews #comments ol.commentlist li .comment-text {
  border-radius: var(--border-radius-sm);
}

.woocommerce #review_form #respond .form-submit input {
  background-color: var(--color-primary);
  color: var(--color-white);
  font-weight: 500;
  border-radius: var(--border-radius-sm);
  transition: background-color var(--transition-fast);
}

.woocommerce #review_form #respond .form-submit input:hover {
  background-color: #7d3c98;
}

/* Related Products */
.woocommerce .related.products h2 {
  font-size: 1.8rem;
  margin: 2rem 0 1.5rem;
}

/* Cart Page */
.woocommerce-cart table.cart td.actions .coupon .input-text {
  width: 150px;
  padding: 0.618em;
  border-radius: var(--border-radius-sm);
}

.woocommerce-cart table.cart img {
  width: 80px;
}

.woocommerce-cart table.cart th {
  background-color: var(--color-light-gray);
  padding: 1rem;
}

.woocommerce-cart table.cart td {
  padding: 1rem;
}

.woocommerce-cart .cart-collaterals .cart_totals h2 {
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  background-color: var(--color-primary);
  color: var(--color-white);
  font-weight: 500;
  border-radius: var(--border-radius-sm);
  transition: background-color var(--transition-fast);
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
  background-color: #7d3c98;
}

/* Checkout Page */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout #order_review_heading {
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

.woocommerce-checkout form .form-row input.input-text,
.woocommerce-checkout form .form-row textarea {
  padding: 0.618em;
  border-radius: var(--border-radius-sm);
}

.woocommerce-checkout #payment {
  background-color: var(--color-light-gray);
  border-radius: var(--border-radius-sm);
}

.woocommerce-checkout #payment div.payment_box {
  background-color: var(--color-white);
  border-radius: var(--border-radius-sm);
}

.woocommerce-checkout #payment div.payment_box::before {
  border-bottom-color: var(--color-white);
}

.woocommerce-checkout #place_order {
  background-color: var(--color-primary);
  color: var(--color-white);
  font-weight: 500;
  border-radius: var(--border-radius-sm);
  transition: background-color var(--transition-fast);
}

.woocommerce-checkout #place_order:hover {
  background-color: #7d3c98;
}

/* My Account Page */
.woocommerce-account .woocommerce-MyAccount-navigation {
  width: 25%;
}

.woocommerce-account .woocommerce-MyAccount-content {
  width: 73%;
}

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

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  margin-bottom: 0.5rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 0.8rem 1rem;
  background-color: var(--color-light-gray);
  color: var(--color-dark);
  border-radius: var(--border-radius-sm);
  transition: all var(--transition-fast);
}

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

.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

.woocommerce-account .addresses .title h3 {
  font-size: 1.3rem;
}

.woocommerce-account .woocommerce-EditAccountForm fieldset {
  margin-top: 2rem;
  padding: 1rem;
  border: 1px solid var(--color-gray);
  border-radius: var(--border-radius-sm);
}

.woocommerce-account .woocommerce-EditAccountForm fieldset legend {
  padding: 0 0.5rem;
  font-weight: 600;
}

/* Buttons */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background-color: var(--color-primary);
  color: var(--color-white);
  font-weight: 500;
  border-radius: var(--border-radius-sm);
  transition: background-color var(--transition-fast);
}

.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background-color: #7d3c98;
  color: var(--color-white);
}

.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background-color: var(--color-primary);
}

.woocommerce #respond input#submit.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background-color: #7d3c98;
}

/* Messages */
.woocommerce-message,
.woocommerce-info {
  border-top-color: var(--color-primary);
  border-radius: var(--border-radius-sm);
}

.woocommerce-message::before,
.woocommerce-info::before {
  color: var(--color-primary);
}

.woocommerce-error {
  border-top-color: var(--color-error);
  border-radius: var(--border-radius-sm);
}

.woocommerce-error::before {
  color: var(--color-error);
}

/* Responsive */
@media (max-width: 768px) {
  .woocommerce ul.products[class*=columns-] li.product,
  .woocommerce-page ul.products[class*=columns-] li.product {
    width: 48%;
    margin-right: 3.8%;
  }
  
  .woocommerce ul.products[class*=columns-] li.product:nth-child(2n),
  .woocommerce-page ul.products[class*=columns-] li.product:nth-child(2n) {
    margin-right: 0;
  }
  
  .woocommerce-account .woocommerce-MyAccount-navigation,
  .woocommerce-account .woocommerce-MyAccount-content {
    width: 100%;
    float: none;
  }
  
  .woocommerce-account .woocommerce-MyAccount-navigation {
    margin-bottom: 2rem;
  }
}

@media (max-width: 480px) {
  .woocommerce ul.products[class*=columns-] li.product,
  .woocommerce-page ul.products[class*=columns-] li.product {
    width: 100%;
    margin-right: 0;
  }
  
  .woocommerce-cart table.cart td.actions .coupon .input-text {
    width: 100%;
    margin-bottom: 0.5rem;
  }
  
  .woocommerce-cart table.cart td.actions .coupon .button {
    width: 100%;
  }
}
