/**
 * WooCommerce Page Styler - Cart Page
 * Modern card-based layout for cart page
 */

/* Page background */
body.woocommerce-cart.wcps-styled {
  background: var(--wcps-background);
}

/* Main container */
body.woocommerce-cart.wcps-styled .woocommerce {
  max-width: 1200px;
  margin: 0 auto;
  padding: 28px 20px;
}

/* Classic Cart Layout */
body.woocommerce-cart.wcps-styled .woocommerce-cart-form {
  background: var(--wcps-card-bg);
  border-radius: var(--wcps-radius);
  box-shadow: var(--wcps-shadow);
  padding: 28px;
  margin-bottom: 28px;
  border: 1px solid var(--wcps-border-color);
}

/* Cart table */
body.woocommerce-cart.wcps-styled .shop_table.cart {
  border: none;
  box-shadow: none;
  background: transparent;
}

body.woocommerce-cart.wcps-styled .shop_table.cart thead th {
  background: #f9fafb;
  padding: 16px;
  font-weight: 600;
  color: var(--wcps-text-secondary);
  border-bottom: 1px solid var(--wcps-border-color);
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: 0.05em;
}

body.woocommerce-cart.wcps-styled .shop_table.cart tbody td {
  padding: 20px 16px;
  border-bottom: 1px solid #f3f4f6;
  vertical-align: middle;
}

body.woocommerce-cart.wcps-styled .shop_table.cart tbody tr:last-child td {
  border-bottom: none;
}

body.woocommerce-cart.wcps-styled .shop_table.cart tbody tr:hover {
  background: #f9fafb;
}

/* Product thumbnail */
body.woocommerce-cart.wcps-styled .shop_table.cart .product-thumbnail img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: var(--wcps-radius-sm);
  border: 1px solid var(--wcps-border-color);
}

/* Product name */
body.woocommerce-cart.wcps-styled .shop_table.cart .product-name a {
  color: var(--wcps-text-primary);
  font-weight: 600;
  text-decoration: none;
  font-size: 16px;
}

body.woocommerce-cart.wcps-styled .shop_table.cart .product-name a:hover {
  color: var(--wcps-primary);
}

body.woocommerce-cart.wcps-styled .shop_table.cart .product-name .variation {
  margin-top: 8px;
  font-size: 13px;
  color: var(--wcps-text-muted);
}

/* Product price */
body.woocommerce-cart.wcps-styled .shop_table.cart .product-price .woocommerce-Price-amount {
  font-weight: 600;
  color: var(--wcps-text-secondary);
}

/* Quantity selector */
body.woocommerce-cart.wcps-styled .shop_table.cart .quantity {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--wcps-border-color);
  border-radius: 4px;
  overflow: hidden;
}

body.woocommerce-cart.wcps-styled .shop_table.cart .quantity .qty {
  width: 50px;
  height: 36px;
  border: none;
  text-align: center;
  font-weight: 600;
  background: #fff;
  padding: 0;
  font-size: 14px;
}

/* Product subtotal */
body.woocommerce-cart.wcps-styled .shop_table.cart .product-subtotal .woocommerce-Price-amount {
  font-weight: 700;
  color: var(--wcps-text-primary);
  font-size: 16px;
}

/* Remove button */
body.woocommerce-cart.wcps-styled .shop_table.cart .product-remove a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: var(--wcps-error-bg);
  color: var(--wcps-error);
  border-radius: 50%;
  text-decoration: none;
  font-size: 18px;
  font-weight: 700;
  transition: var(--wcps-transition);
}

body.woocommerce-cart.wcps-styled .shop_table.cart .product-remove a:hover {
  background: var(--wcps-error);
  color: #fff;
}

/* Actions row */
body.woocommerce-cart.wcps-styled .shop_table.cart .actions {
  padding: 20px 0 0 0;
  border-top: 1px solid var(--wcps-border-color);
}

body.woocommerce-cart.wcps-styled .shop_table.cart .actions .coupon {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

body.woocommerce-cart.wcps-styled .shop_table.cart .actions .coupon label {
  display: none;
}

body.woocommerce-cart.wcps-styled .shop_table.cart .actions .coupon #coupon_code {
  min-width: 200px;
  padding: 12px 16px;
}

body.woocommerce-cart.wcps-styled .shop_table.cart .actions button[name="update_cart"] {
  float: right;
}

/* Cart totals */
body.woocommerce-cart.wcps-styled .cart_totals {
  background: var(--wcps-card-bg);
  border-radius: var(--wcps-radius);
  box-shadow: var(--wcps-shadow);
  padding: 28px;
  border: 1px solid var(--wcps-border-color);
}

body.woocommerce-cart.wcps-styled .cart_totals h2 {
  font-size: 20px;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--wcps-border-color);
  color: var(--wcps-text-primary);
}

body.woocommerce-cart.wcps-styled .cart_totals table {
  box-shadow: none;
  background: transparent;
}

body.woocommerce-cart.wcps-styled .cart_totals table th {
  background: transparent;
  font-weight: 600;
  color: var(--wcps-text-secondary);
  padding: 12px 0;
  border: none;
}

body.woocommerce-cart.wcps-styled .cart_totals table td {
  padding: 12px 0;
  text-align: right;
  border: none;
}

body.woocommerce-cart.wcps-styled .cart_totals table tr.order-total th,
body.woocommerce-cart.wcps-styled .cart_totals table tr.order-total td {
  border-top: 2px solid var(--wcps-border-color);
  padding-top: 20px;
  font-size: 18px;
  font-weight: 700;
  color: var(--wcps-text-primary);
}

/* Shipping calculator */
body.woocommerce-cart.wcps-styled .cart_totals .shipping-calculator-button {
  color: var(--wcps-primary);
  font-size: 14px;
}

body.woocommerce-cart.wcps-styled .cart_totals .shipping-calculator-form {
  background: #f9fafb;
  padding: 20px;
  border-radius: var(--wcps-radius-sm);
  margin-top: 16px;
}

/* Proceed to checkout button */
body.woocommerce-cart.wcps-styled .cart_totals .wc-proceed-to-checkout a {
  display: block;
  width: 100%;
  padding: 16px 24px;
  margin-top: 20px;
  font-size: 16px;
  text-align: center;
  background: linear-gradient(135deg, var(--wcps-primary), #3b82f6);
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}

body.woocommerce-cart.wcps-styled .cart_totals .wc-proceed-to-checkout a:hover {
  box-shadow: 0 6px 20px rgba(37, 99, 235, 0.35);
  transform: translateY(-2px);
}

/* Block-based Cart Layout (WooCommerce Blocks) */
body.woocommerce-cart.wcps-styled .wp-block-woocommerce-cart .wp-block-woocommerce-filled-cart-block {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
}

@media (min-width: 768px) {
  body.woocommerce-cart.wcps-styled .wp-block-woocommerce-cart .wp-block-woocommerce-filled-cart-block {
    display: flex;
    gap: 40px;
    align-items: flex-start;
  }
}

/* Cart items block */
body.woocommerce-cart.wcps-styled .wp-block-woocommerce-filled-cart-block .wp-block-woocommerce-cart-items-block {
  background: var(--wcps-card-bg);
  border: 1px solid var(--wcps-border-color);
  border-radius: var(--wcps-radius-sm);
  padding: 20px;
  margin-bottom: 20px;
}

@media (min-width: 768px) {
  body.woocommerce-cart.wcps-styled .wp-block-woocommerce-filled-cart-block .wp-block-woocommerce-cart-items-block {
    flex: 0 0 65%;
    margin-bottom: 0;
  }
}

/* Cart totals block */
body.woocommerce-cart.wcps-styled .wp-block-woocommerce-cart-totals-block {
  background: #f9fafb;
  border: 1px solid var(--wcps-border-color);
  border-radius: var(--wcps-radius-sm);
  padding: 20px;
}

@media (min-width: 768px) {
  body.woocommerce-cart.wcps-styled .wp-block-woocommerce-cart-totals-block {
    flex: 0 0 30%;
  }
}

/* Individual cart items - Block based */
body.woocommerce-cart.wcps-styled .wc-block-cart-items__row {
  padding: 20px 0;
  border-bottom: 1px solid #f3f4f6;
}

body.woocommerce-cart.wcps-styled .wc-block-cart-items__row:last-child {
  border-bottom: none;
}

@media (min-width: 640px) {
  body.woocommerce-cart.wcps-styled .wc-block-cart-items__row {
    display: flex;
    align-items: center;
    gap: 20px;
  }
  
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__image {
    flex-shrink: 0;
  }
  
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__product {
    flex: 1;
  }
  
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__quantity {
    flex-shrink: 0;
    width: 120px;
  }
  
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__total {
    flex-shrink: 0;
    width: 100px;
    text-align: right;
  }
}

/* Product images - Block based */
body.woocommerce-cart.wcps-styled .wc-block-cart-item__image img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 6px;
  border: 1px solid var(--wcps-border-color);
}

@media (min-width: 640px) {
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__image img {
    width: 90px;
    height: 90px;
  }
}

/* Product name - Block based */
body.woocommerce-cart.wcps-styled .wc-block-cart-item__product-name {
  font-weight: 600;
  color: var(--wcps-text-primary);
  font-size: 16px;
  margin: 0 0 8px 0;
  line-height: 1.4;
}

body.woocommerce-cart.wcps-styled .wc-block-cart-item__product-name a {
  color: inherit;
  text-decoration: none;
}

body.woocommerce-cart.wcps-styled .wc-block-cart-item__product-name a:hover {
  color: var(--wcps-primary);
}

body.woocommerce-cart.wcps-styled .wc-block-cart-item__product-metadata {
  font-size: 14px;
  color: var(--wcps-text-muted);
  margin-top: 4px;
}

/* Quantity controls - Block based */
body.woocommerce-cart.wcps-styled .wc-block-components-quantity-selector {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--wcps-border-color);
  border-radius: 4px;
  overflow: hidden;
}

body.woocommerce-cart.wcps-styled .wc-block-components-quantity-selector__button {
  width: 28px;
  height: 28px;
  border: none;
  background: #f9fafb;
  color: var(--wcps-text-secondary);
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--wcps-transition);
}

body.woocommerce-cart.wcps-styled .wc-block-components-quantity-selector__button:hover {
  background: var(--wcps-border-color);
}

body.woocommerce-cart.wcps-styled .wc-block-components-quantity-selector__input {
  width: 40px;
  height: 28px;
  border: none;
  text-align: center;
  font-weight: 600;
  background: #fff;
  font-size: 14px;
}

/* Remove button - Block based */
body.woocommerce-cart.wcps-styled .wc-block-cart-item__remove-link {
  color: var(--wcps-error);
  text-decoration: none;
  font-size: 14px;
  padding: 4px 8px;
  border-radius: 3px;
  transition: var(--wcps-transition);
}

body.woocommerce-cart.wcps-styled .wc-block-cart-item__remove-link:hover {
  background: var(--wcps-error-bg);
  color: #b91c1c;
}

/* Cart totals - Block based */
body.woocommerce-cart.wcps-styled .wp-block-woocommerce-cart-totals-block h2 {
  color: var(--wcps-text-primary);
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--wcps-border-color);
}

/* Checkout button - Block based */
body.woocommerce-cart.wcps-styled .wc-block-cart__submit-container .wc-block-cart__submit-button {
  width: 100%;
  padding: 14px 20px;
  background: linear-gradient(135deg, var(--wcps-primary), #3b82f6);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-weight: 600;
  font-size: 16px;
  cursor: pointer;
  margin-top: 15px;
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
  transition: var(--wcps-transition);
}

body.woocommerce-cart.wcps-styled .wc-block-cart__submit-container .wc-block-cart__submit-button:hover {
  box-shadow: 0 6px 20px rgba(37, 99, 235, 0.35);
  transform: translateY(-2px);
}

/* Empty cart */
body.woocommerce-cart.wcps-styled .cart-empty {
  background: var(--wcps-card-bg);
  border-radius: var(--wcps-radius);
  padding: 60px 40px;
  text-align: center;
  box-shadow: var(--wcps-shadow);
}

body.woocommerce-cart.wcps-styled .return-to-shop {
  margin-top: 24px;
}

body.woocommerce-cart.wcps-styled .return-to-shop a {
  background: var(--wcps-secondary);
  color: #fff;
  padding: 14px 28px;
  border-radius: var(--wcps-radius-sm);
  font-weight: 600;
  display: inline-block;
  transition: var(--wcps-transition);
}

body.woocommerce-cart.wcps-styled .return-to-shop a:hover {
  filter: brightness(0.92);
  transform: translateY(-1px);
}

/* Cross-sells section */
body.woocommerce-cart.wcps-styled .cross-sells {
  background: var(--wcps-card-bg);
  border-radius: var(--wcps-radius);
  box-shadow: var(--wcps-shadow);
  padding: 28px;
  margin-top: 28px;
  border: 1px solid var(--wcps-border-color);
}

body.woocommerce-cart.wcps-styled .cross-sells h2 {
  font-size: 20px;
  margin-bottom: 20px;
  color: var(--wcps-text-primary);
}

body.woocommerce-cart.wcps-styled .cross-sells ul.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}

body.woocommerce-cart.wcps-styled .cross-sells ul.products li.product {
  background: #f9fafb;
  border-radius: var(--wcps-radius-sm);
  padding: 16px;
  border: 1px solid var(--wcps-border-color);
  margin: 0;
  width: auto;
  float: none;
}

/* Mobile responsive */
@media (max-width: 1024px) {
  body.woocommerce-cart.wcps-styled .cross-sells ul.products {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  body.woocommerce-cart.wcps-styled .woocommerce {
    padding: 20px 16px;
  }
  
  body.woocommerce-cart.wcps-styled .woocommerce-cart-form,
  body.woocommerce-cart.wcps-styled .cart_totals {
    padding: 20px;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart thead {
    display: none;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart tbody tr {
    display: block;
    padding: 20px 0;
    border-bottom: 1px solid var(--wcps-border-color);
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart tbody td {
    display: block;
    padding: 8px 0;
    border: none;
    text-align: left;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .product-thumbnail {
    float: left;
    margin-right: 16px;
    margin-bottom: 10px;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .product-name {
    overflow: hidden;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .product-price::before,
  body.woocommerce-cart.wcps-styled .shop_table.cart .product-quantity::before,
  body.woocommerce-cart.wcps-styled .shop_table.cart .product-subtotal::before {
    content: attr(data-title) ": ";
    font-weight: 600;
    color: var(--wcps-text-secondary);
    margin-right: 8px;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .actions {
    flex-direction: column;
    gap: 16px;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .actions .coupon {
    width: 100%;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .actions .coupon #coupon_code {
    width: 100%;
    min-width: unset;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .actions button[name="update_cart"] {
    float: none;
    width: 100%;
    margin-top: 16px;
  }
  
  body.woocommerce-cart.wcps-styled .cross-sells ul.products {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  
  /* Block based mobile */
  body.woocommerce-cart.wcps-styled .wc-block-cart-items__row {
    padding: 15px 0;
  }
  
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__image {
    float: left;
    margin: 0 15px 10px 0;
  }
  
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__product {
    overflow: hidden;
    margin-bottom: 15px;
  }
  
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__quantity,
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__total {
    display: inline-block;
    margin: 10px 20px 10px 0;
    vertical-align: middle;
  }
}

@media (max-width: 480px) {
  body.woocommerce-cart.wcps-styled .woocommerce {
    padding: 12px 10px;
  }
  
  body.woocommerce-cart.wcps-styled .woocommerce-cart-form,
  body.woocommerce-cart.wcps-styled .cart_totals,
  body.woocommerce-cart.wcps-styled .wp-block-woocommerce-cart-items-block,
  body.woocommerce-cart.wcps-styled .wp-block-woocommerce-cart-totals-block {
    padding: 14px;
    border-radius: 10px;
  }
  
  body.woocommerce-cart.wcps-styled .cross-sells ul.products {
    grid-template-columns: 1fr;
  }
  
  body.woocommerce-cart.wcps-styled .cross-sells {
    padding: 16px;
  }
  
  body.woocommerce-cart.wcps-styled .shop_table.cart .product-thumbnail img,
  body.woocommerce-cart.wcps-styled .wc-block-cart-item__image img {
    width: 60px;
    height: 60px;
  }
}

/* Prevent horizontal overflow */
body.woocommerce-cart.wcps-styled,
body.woocommerce-cart.wcps-styled .woocommerce,
body.woocommerce-cart.wcps-styled .woocommerce * {
  max-width: 100%;
  box-sizing: border-box;
}

body.woocommerce-cart.wcps-styled .woocommerce {
  overflow-x: hidden;
}