/*
 * ThaiNguyenPC WooCommerce Styles
 * Custom styling for WooCommerce pages
 */

/* ========================================
   SHOP PAGE
   ======================================== */

.woocommerce-page .site-main {
  padding: var(--space-8) 0;
}

/* Shop Header */
.shop-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: var(--border-width) solid var(--color-border);
}

.shop-title {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  margin: 0;
}

.shop-result-count {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

/* Shop Filters */
.shop-filters {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.woocommerce-ordering select {
  padding: var(--space-2) var(--space-4);
  padding-right: var(--space-10);
  font-size: var(--text-sm);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  background-color: var(--color-white);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}

/* Products Grid */
.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  list-style: none;
  padding: 0;
  margin: 0;
}

@media (max-width: 1200px) {
  .products {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .products {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }
}

@media (max-width: 480px) {
  .products {
    grid-template-columns: 1fr;
  }
}

/* Product Item in Grid */
.products .product {
  position: relative;
  background-color: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition-base);
}

.products .product:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-lg);
}

/* Product Image */
.products .product .woocommerce-loop-product__link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.products .product img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  background-color: var(--color-bg-alt);
  padding: var(--space-4);
  transition: transform var(--transition-slow);
}

.products .product:hover img {
  transform: scale(1.05);
}

/* Product Title */
.products .product .woocommerce-loop-product__title {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text);
  padding: 0 var(--space-4);
  margin: var(--space-3) 0 var(--space-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: var(--leading-snug);
  min-height: 2.75em;
}

/* Product Price */
.products .product .price {
  padding: 0 var(--space-4);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.products .product .price .woocommerce-Price-amount {
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-sale);
}

.products .product .price del {
  color: var(--color-text-light);
  font-size: var(--text-sm);
}

.products .product .price del .woocommerce-Price-amount {
  font-size: var(--text-sm);
  font-weight: var(--font-normal);
  color: var(--color-text-light);
}

.products .product .price ins {
  text-decoration: none;
}

/* Add to Cart Button */
.products .product .button {
  display: block;
  width: calc(100% - var(--space-8));
  margin: 0 var(--space-4) var(--space-4);
  padding: var(--space-3);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  text-align: center;
  text-decoration: none;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition-base);
}

.products .product .button:hover {
  background-color: var(--color-primary-hover);
  box-shadow: var(--shadow-primary);
}

.products .product .added_to_cart {
  display: block;
  text-align: center;
  font-size: var(--text-xs);
  color: var(--color-success);
  margin-top: var(--space-2);
  padding-bottom: var(--space-2);
}

/* Sale Badge */
.products .product .onsale {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  background-color: var(--color-sale);
  color: var(--color-white);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  z-index: 10;
}

/* ========================================
   SINGLE PRODUCT
   ======================================== */

.single-product .product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
}

@media (max-width: 768px) {
  .single-product .product {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}

/* Product Gallery */
.single-product .woocommerce-product-gallery {
  position: sticky;
  top: var(--space-4);
}

.single-product .woocommerce-product-gallery__wrapper {
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.single-product .woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.single-product .woocommerce-product-gallery__trigger {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  background-color: var(--color-white);
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
  z-index: 10;
}

/* Product Summary */
.single-product .summary {
  padding: var(--space-4) 0;
}

.single-product .product_title {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-4);
}

.single-product .price {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-sale);
  margin-bottom: var(--space-4);
}

.single-product .price del {
  font-size: var(--text-lg);
  color: var(--color-text-light);
  font-weight: var(--font-normal);
}

.single-product .woocommerce-product-details__short-description {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
  line-height: var(--leading-relaxed);
}

/* Stock Status */
.single-product .stock {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  margin-bottom: var(--space-4);
}

.single-product .in-stock {
  background-color: rgba(16, 185, 129, 0.1);
  color: var(--color-success);
}

.single-product .out-of-stock {
  background-color: rgba(239, 68, 68, 0.1);
  color: var(--color-error);
}

/* Quantity Selector */
.single-product .quantity {
  display: inline-flex;
  align-items: center;
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-right: var(--space-4);
}

.single-product .quantity .qty {
  width: 60px;
  height: 48px;
  text-align: center;
  border: none;
  font-size: var(--text-base);
  font-weight: var(--font-medium);
}

.single-product .quantity .qty:focus {
  outline: none;
}

/* Add to Cart */
.single-product .single_add_to_cart_button {
  padding: var(--space-4) var(--space-8);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
}

.single-product .single_add_to_cart_button:hover {
  background-color: var(--color-primary-hover);
  box-shadow: var(--shadow-primary);
  transform: translateY(-2px);
}

/* Product Meta */
.single-product .product_meta {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: var(--border-width) solid var(--color-border);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

.single-product .product_meta > span {
  display: block;
  margin-bottom: var(--space-2);
}

.single-product .product_meta a {
  color: var(--color-primary);
}

/* Product Tabs */
.single-product .woocommerce-tabs {
  margin-top: var(--space-12);
}

.single-product .woocommerce-tabs ul.tabs {
  display: flex;
  gap: var(--space-1);
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-6);
  border-bottom: var(--border-width) solid var(--color-border);
}

.single-product .woocommerce-tabs ul.tabs li {
  margin: 0;
}

.single-product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: all var(--transition-fast);
}

.single-product .woocommerce-tabs ul.tabs li.active a,
.single-product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

.single-product .woocommerce-tabs .panel h2 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-4);
}

/* Related Products */
.single-product .related.products {
  margin-top: var(--space-16);
  padding-top: var(--space-8);
  border-top: var(--border-width) solid var(--color-border);
}

.single-product .related.products > h2 {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-6);
}

/* ========================================
   CART PAGE
   ======================================== */

.woocommerce-cart .woocommerce {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-8);
  align-items: start;
}

@media (max-width: 1024px) {
  .woocommerce-cart .woocommerce {
    grid-template-columns: 1fr;
  }
}

/* Cart Table */
.woocommerce-cart-form {
  background-color: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.woocommerce-cart-form table.cart {
  width: 100%;
  border-collapse: collapse;
}

.woocommerce-cart-form table.cart th {
  background-color: var(--color-bg-alt);
  padding: var(--space-4);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  text-align: left;
  border-bottom: var(--border-width) solid var(--color-border);
}

.woocommerce-cart-form table.cart td {
  padding: var(--space-4);
  border-bottom: var(--border-width) solid var(--color-border);
  vertical-align: middle;
}

.woocommerce-cart-form table.cart tr:last-child td {
  border-bottom: none;
}

/* Cart Product Image */
.woocommerce-cart-form .product-thumbnail img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-md);
}

/* Cart Product Name */
.woocommerce-cart-form .product-name a {
  font-weight: var(--font-medium);
  color: var(--color-text);
}

.woocommerce-cart-form .product-name a:hover {
  color: var(--color-primary);
}

/* Cart Quantity */
.woocommerce-cart-form .product-quantity .quantity {
  display: inline-flex;
  align-items: center;
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
}

.woocommerce-cart-form .product-quantity .qty {
  width: 60px;
  height: 40px;
  text-align: center;
  border: none;
  font-size: var(--text-sm);
}

/* Cart Price */
.woocommerce-cart-form .product-price,
.woocommerce-cart-form .product-subtotal {
  font-weight: var(--font-semibold);
}

/* Remove Item */
.woocommerce-cart-form .product-remove a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  font-size: var(--text-lg);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.woocommerce-cart-form .product-remove a:hover {
  background-color: var(--color-error);
  color: var(--color-white);
}

/* Cart Actions */
.woocommerce-cart-form .actions {
  padding: var(--space-4);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.woocommerce-cart-form .coupon {
  display: flex;
  gap: var(--space-2);
}

.woocommerce-cart-form .coupon input {
  padding: var(--space-3) var(--space-4);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}

.woocommerce-cart-form .coupon button,
.woocommerce-cart-form button[name="update_cart"] {
  padding: var(--space-3) var(--space-6);
  background-color: var(--color-secondary);
  color: var(--color-white);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
}

.woocommerce-cart-form .coupon button:hover,
.woocommerce-cart-form button[name="update_cart"]:hover {
  background-color: var(--color-secondary-light);
}

/* Cart Totals */
.cart_totals {
  background-color: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: sticky;
  top: var(--space-4);
}

.cart_totals h2 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-6);
}

.cart_totals table {
  width: 100%;
  margin-bottom: var(--space-6);
}

.cart_totals table th,
.cart_totals table td {
  padding: var(--space-3) 0;
  border-bottom: var(--border-width) solid var(--color-border);
}

.cart_totals table th {
  font-weight: var(--font-medium);
  text-align: left;
}

.cart_totals table td {
  text-align: right;
}

.cart_totals .order-total th,
.cart_totals .order-total td {
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  border-bottom: none;
}

.cart_totals .order-total .woocommerce-Price-amount {
  color: var(--color-sale);
}

.cart_totals .wc-proceed-to-checkout a {
  display: block;
  width: 100%;
  padding: var(--space-4);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  text-align: center;
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
}

.cart_totals .wc-proceed-to-checkout a:hover {
  background-color: var(--color-primary-hover);
  box-shadow: var(--shadow-primary);
}

/* ========================================
   CHECKOUT PAGE
   ======================================== */

.woocommerce-checkout .woocommerce {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: start;
}

@media (max-width: 1024px) {
  .woocommerce-checkout .woocommerce {
    grid-template-columns: 1fr;
  }
}

/* Checkout Form */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout .woocommerce-additional-fields {
  background-color: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-6);
}

.woocommerce-checkout h3 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-6);
}

.woocommerce-checkout .form-row {
  margin-bottom: var(--space-4);
}

.woocommerce-checkout .form-row label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  margin-bottom: var(--space-2);
}

.woocommerce-checkout .form-row label .required {
  color: var(--color-error);
}

.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  transition: all var(--transition-fast);
}

.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(255, 87, 34, 0.1);
}

/* Order Review */
.woocommerce-checkout #order_review_heading {
  font-size: var(--text-xl);
  margin-bottom: var(--space-4);
}

.woocommerce-checkout .woocommerce-checkout-review-order {
  background-color: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: sticky;
  top: var(--space-4);
}

.woocommerce-checkout .woocommerce-checkout-review-order-table {
  width: 100%;
  margin-bottom: var(--space-6);
}

.woocommerce-checkout .woocommerce-checkout-review-order-table th,
.woocommerce-checkout .woocommerce-checkout-review-order-table td {
  padding: var(--space-3) 0;
  border-bottom: var(--border-width) solid var(--color-border);
}

.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total td {
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
}

.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .woocommerce-Price-amount {
  color: var(--color-sale);
}

/* Payment Methods */
.woocommerce-checkout .woocommerce-checkout-payment {
  background-color: var(--color-bg-alt);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-6);
}

.woocommerce-checkout .wc_payment_methods {
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-checkout .wc_payment_method {
  padding: var(--space-3);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  background-color: var(--color-white);
}

.woocommerce-checkout .wc_payment_method label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-medium);
  cursor: pointer;
}

.woocommerce-checkout .payment_box {
  padding: var(--space-3);
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

/* Place Order Button */
.woocommerce-checkout #place_order {
  width: 100%;
  padding: var(--space-4);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
}

.woocommerce-checkout #place_order:hover {
  background-color: var(--color-primary-hover);
  box-shadow: var(--shadow-primary);
  transform: translateY(-2px);
}

/* ========================================
   MESSAGES
   ======================================== */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.woocommerce-message {
  background-color: rgba(16, 185, 129, 0.1);
  border-left: 4px solid var(--color-success);
  color: var(--color-success);
}

.woocommerce-info {
  background-color: rgba(59, 130, 246, 0.1);
  border-left: 4px solid #3B82F6;
  color: #3B82F6;
}

.woocommerce-error {
  background-color: rgba(239, 68, 68, 0.1);
  border-left: 4px solid var(--color-error);
  color: var(--color-error);
  list-style: none;
  padding-left: var(--space-4);
}

.woocommerce-message a,
.woocommerce-info a {
  margin-left: auto;
  padding: var(--space-2) var(--space-4);
  background-color: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  text-decoration: none;
}

/* ========================================
   PAGINATION
   ======================================== */

.woocommerce-pagination {
  margin-top: var(--space-8);
  display: flex;
  justify-content: center;
}

.woocommerce-pagination ul {
  display: flex;
  gap: var(--space-1);
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-pagination ul li {
  margin: 0;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-3);
  background-color: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.woocommerce-pagination ul li a:hover {
  border-color: var(--color-primary);
  background-color: var(--color-accent-soft);
}

.woocommerce-pagination ul li span.current {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}

/* ========================================
   BREADCRUMBS
   ======================================== */

.woocommerce-breadcrumb {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
}

.woocommerce-breadcrumb a {
  color: var(--color-text-secondary);
  text-decoration: none;
}

.woocommerce-breadcrumb a:hover {
  color: var(--color-primary);
}
