/* =============================================================================
   IT-Life Cart & Checkout Styles
   Pure WooCommerce — no Elementor conflicts.
   Colors = CSS variables (theme-switchable)
   ============================================================================= */

/* -----------------------------------------------------------------------------
   CART PAGE
   ----------------------------------------------------------------------------- */

.woocommerce-cart .woocommerce {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--il-space-2xl) var(--il-space-lg);
}

/* Cart table */
.woocommerce table.shop_table.cart,
.woocommerce-cart table.cart {
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius-lg) !important;
  overflow: hidden;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  background: var(--il-bg-card) !important;
}

html[data-theme="gradient"] .woocommerce table.shop_table.cart {
  background: var(--il-glass-bg) !important;
  border-color: var(--il-glass-border) !important;
  backdrop-filter: blur(10px);
}

/* Table header */
.woocommerce table.shop_table.cart thead th {
  background: var(--il-bg-tertiary) !important;
  color: var(--il-text-muted) !important;
  font-size: var(--il-font-size-xs) !important;
  font-weight: var(--il-font-weight-semibold) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  padding: 14px 20px !important;
  border-bottom: 1px solid var(--il-border-color) !important;
  font-family: var(--il-font-family) !important;
}

/* Table rows */
.woocommerce table.shop_table.cart td {
  padding: 20px !important;
  vertical-align: middle !important;
  border-bottom: 1px solid var(--il-border-light) !important;
  background: var(--il-bg-card) !important;
  color: var(--il-text-secondary) !important;
  font-family: var(--il-font-family) !important;
}

html[data-theme="gradient"] .woocommerce table.shop_table.cart td {
  background: transparent !important;
}

/* Product thumbnail in cart */
.woocommerce table.cart td.product-thumbnail img {
  width: 80px !important;
  height: 80px !important;
  object-fit: cover !important;
  border-radius: var(--il-border-radius) !important;
  border: 1px solid var(--il-border-color) !important;
}

/* Product name in cart */
.woocommerce table.cart td.product-name a {
  color: var(--il-text-primary) !important;
  font-weight: var(--il-font-weight-medium) !important;
  text-decoration: none !important;
  font-family: var(--il-font-family) !important;
}

.woocommerce table.cart td.product-name a:hover {
  color: var(--il-accent-primary) !important;
}

/* Remove item */
.woocommerce table.cart td.product-remove a.remove {
  color: var(--il-text-muted) !important;
  font-size: 20px;
  transition: color 0.2s ease;
}

.woocommerce table.cart td.product-remove a.remove:hover {
  color: var(--il-accent-danger) !important;
  background: var(--il-accent-danger-light) !important;
  border-radius: var(--il-border-radius-full);
}

/* Actions row (coupon + update) */
.woocommerce table.cart td.actions {
  background: var(--il-bg-secondary) !important;
  padding: 20px !important;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--il-space-md);
}

.woocommerce table.cart td.actions .coupon {
  display: flex;
  gap: var(--il-space-sm);
  align-items: center;
}

.woocommerce table.cart td.actions .coupon input[type="text"] {
  max-width: 200px;
}


/* -----------------------------------------------------------------------------
   CART TOTALS
   ----------------------------------------------------------------------------- */

.woocommerce .cart_totals {
  background: var(--il-bg-card) !important;
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius-lg) !important;
  padding: var(--il-space-xl) !important;
  max-width: 480px;
  margin-left: auto;
}

html[data-theme="gradient"] .woocommerce .cart_totals {
  background: var(--il-glass-bg) !important;
  border-color: var(--il-glass-border) !important;
  backdrop-filter: blur(10px);
}

.woocommerce .cart_totals h2 {
  font-family: var(--il-font-family) !important;
  font-weight: var(--il-font-weight-bold) !important;
  color: var(--il-text-primary) !important;
  font-size: var(--il-font-size-xl) !important;
  margin-bottom: var(--il-space-lg) !important;
}

.woocommerce .cart_totals table {
  border: none !important;
}

.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
  background: transparent !important;
  border-bottom: 1px solid var(--il-border-light) !important;
  padding: 14px 0 !important;
  color: var(--il-text-secondary) !important;
  font-family: var(--il-font-family) !important;
}

.woocommerce .cart_totals table th {
  color: var(--il-text-muted) !important;
  font-weight: var(--il-font-weight-medium) !important;
}

.woocommerce .cart_totals .order-total th {
  font-weight: var(--il-font-weight-bold) !important;
  color: var(--il-text-primary) !important;
}

.woocommerce .cart_totals .order-total .woocommerce-Price-amount {
  font-size: var(--il-font-size-2xl) !important;
  font-weight: var(--il-font-weight-bold) !important;
  color: var(--il-price-color) !important;
}

/* Proceed to checkout button */
.woocommerce .cart_totals .wc-proceed-to-checkout .checkout-button {
  width: 100% !important;
  padding: 16px 24px !important;
  font-size: var(--il-font-size-lg) !important;
  margin-top: var(--il-space-md) !important;
}


/* =============================================================================
   CHECKOUT PAGE
   ============================================================================= */

.woocommerce-checkout .woocommerce {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--il-space-2xl) var(--il-space-lg);
}

/* 2-column layout */
.woocommerce-checkout .col2-set {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--il-space-xl);
  margin-bottom: var(--il-space-xl);
}

/* Billing/Shipping columns */
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
  background: var(--il-bg-card) !important;
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius-lg) !important;
  padding: var(--il-space-xl) !important;
}

html[data-theme="gradient"] .woocommerce-checkout .col2-set .col-1,
html[data-theme="gradient"] .woocommerce-checkout .col2-set .col-2 {
  background: var(--il-glass-bg) !important;
  border-color: var(--il-glass-border) !important;
  backdrop-filter: blur(10px);
}

/* Checkout headings */
.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3 {
  font-family: var(--il-font-family) !important;
  font-size: var(--il-font-size-xl) !important;
  font-weight: var(--il-font-weight-bold) !important;
  color: var(--il-text-primary) !important;
  margin-bottom: var(--il-space-lg) !important;
  padding-bottom: var(--il-space-md) !important;
  border-bottom: 2px solid var(--il-accent-primary) !important;
}

/* Form rows */
.woocommerce-checkout .form-row {
  margin-bottom: var(--il-space-md) !important;
  padding: 0 !important;
}

.woocommerce-checkout .required {
  color: var(--il-accent-danger) !important;
}

/* Select2 dropdowns */
.woocommerce-checkout .select2-container .select2-selection--single {
  height: 48px !important;
  border: 1px solid var(--il-input-border) !important;
  border-radius: var(--il-border-radius) !important;
  background: var(--il-input-bg) !important;
  padding: 10px 14px !important;
}

.woocommerce-checkout .select2-container .select2-selection--single .select2-selection__rendered {
  color: var(--il-input-text) !important;
  line-height: 26px !important;
  padding: 0 !important;
}

.select2-dropdown {
  background: var(--il-bg-card) !important;
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius) !important;
  box-shadow: var(--il-shadow-lg) !important;
}

.select2-results__option {
  padding: 10px 14px !important;
  color: var(--il-text-secondary) !important;
  transition: all 0.15s ease;
}

.select2-results__option--highlighted {
  background: var(--il-accent-primary-light) !important;
  color: var(--il-accent-primary) !important;
}


/* -----------------------------------------------------------------------------
   ORDER REVIEW
   ----------------------------------------------------------------------------- */

.woocommerce-checkout #order_review_heading {
  font-family: var(--il-font-family) !important;
  font-size: var(--il-font-size-xl) !important;
  font-weight: var(--il-font-weight-bold) !important;
  color: var(--il-text-primary) !important;
  margin-bottom: var(--il-space-lg) !important;
}

.woocommerce-checkout #order_review {
  background: var(--il-bg-card) !important;
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius-lg) !important;
  padding: var(--il-space-xl) !important;
}

html[data-theme="gradient"] .woocommerce-checkout #order_review {
  background: var(--il-glass-bg) !important;
  border-color: var(--il-glass-border) !important;
  backdrop-filter: blur(10px);
}

.woocommerce-checkout #order_review table.shop_table {
  border: none !important;
  margin-bottom: var(--il-space-lg) !important;
}

.woocommerce-checkout #order_review table.shop_table th,
.woocommerce-checkout #order_review table.shop_table td {
  background: transparent !important;
  border-bottom: 1px solid var(--il-border-light) !important;
  color: var(--il-text-secondary) !important;
  font-family: var(--il-font-family) !important;
}


/* -----------------------------------------------------------------------------
   PAYMENT METHODS
   ----------------------------------------------------------------------------- */

.woocommerce-checkout #payment {
  background: var(--il-bg-secondary) !important;
  border-radius: var(--il-border-radius-lg) !important;
  padding: var(--il-space-lg) !important;
  border: 1px solid var(--il-border-color) !important;
}

html[data-theme="gradient"] .woocommerce-checkout #payment {
  background: var(--il-glass-bg) !important;
  border-color: var(--il-glass-border) !important;
}

.woocommerce-checkout #payment ul.payment_methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 var(--il-space-lg) !important;
  border-bottom: 1px solid var(--il-border-light) !important;
}

.woocommerce-checkout #payment ul.payment_methods li {
  padding: var(--il-space-md) !important;
  margin-bottom: var(--il-space-sm) !important;
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius) !important;
  background: var(--il-bg-card) !important;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.woocommerce-checkout #payment ul.payment_methods li:hover {
  border-color: var(--il-accent-primary) !important;
}

.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
  accent-color: var(--il-accent-primary);
}

.woocommerce-checkout #payment ul.payment_methods li label {
  cursor: pointer !important;
  font-weight: var(--il-font-weight-medium) !important;
  color: var(--il-text-primary) !important;
}

.woocommerce-checkout #payment .payment_box {
  background: var(--il-bg-tertiary) !important;
  color: var(--il-text-secondary) !important;
  border-radius: var(--il-border-radius) !important;
  padding: var(--il-space-md) !important;
  margin-top: var(--il-space-sm) !important;
  font-size: var(--il-font-size-sm) !important;
}

.woocommerce-checkout #payment .payment_box::before {
  display: none !important;
}

/* Place order button */
.woocommerce-checkout #place_order {
  width: 100% !important;
  padding: 18px 32px !important;
  font-size: var(--il-font-size-lg) !important;
  font-weight: var(--il-font-weight-bold) !important;
  text-transform: none !important;
}

html[data-theme="gradient"] .woocommerce-checkout #place_order {
  background: linear-gradient(135deg, #f72585, #7209b7) !important;
  box-shadow: 0 4px 20px rgba(247, 37, 133, 0.4) !important;
}

/* Terms */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  margin-bottom: var(--il-space-lg) !important;
}

.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper label {
  font-size: var(--il-font-size-sm) !important;
  color: var(--il-text-muted) !important;
}


/* -----------------------------------------------------------------------------
   ORDER RECEIVED / THANK YOU
   ----------------------------------------------------------------------------- */

.woocommerce-order-received .woocommerce-thankyou-order-received {
  background: var(--il-accent-secondary-light) !important;
  color: var(--il-accent-secondary) !important;
  padding: var(--il-space-lg) var(--il-space-xl) !important;
  border-radius: var(--il-border-radius-lg) !important;
  font-size: var(--il-font-size-lg) !important;
  font-weight: var(--il-font-weight-semibold) !important;
  text-align: center;
  margin-bottom: var(--il-space-xl) !important;
}


/* -----------------------------------------------------------------------------
   MY ACCOUNT
   ----------------------------------------------------------------------------- */

.woocommerce-MyAccount-navigation {
  background: var(--il-bg-card) !important;
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius-lg) !important;
  overflow: hidden;
}

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

.woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--il-border-light) !important;
}

.woocommerce-MyAccount-navigation ul li:last-child {
  border-bottom: none !important;
}

.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 14px 20px !important;
  color: var(--il-text-secondary) !important;
  text-decoration: none !important;
  font-size: var(--il-font-size-sm) !important;
  font-weight: var(--il-font-weight-medium) !important;
  font-family: var(--il-font-family) !important;
  transition: all 0.15s ease;
}

.woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--il-accent-primary-light) !important;
  color: var(--il-accent-primary) !important;
}

.woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--il-accent-primary) !important;
  color: var(--il-text-inverse) !important;
  font-weight: var(--il-font-weight-semibold) !important;
}

.woocommerce-MyAccount-content {
  background: var(--il-bg-card) !important;
  border: 1px solid var(--il-border-color) !important;
  border-radius: var(--il-border-radius-lg) !important;
  padding: var(--il-space-xl) !important;
}


/* =============================================================================
   RESPONSIVE
   ============================================================================= */

@media (max-width: 1024px) {
  .woocommerce-checkout .col2-set {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .woocommerce-cart .woocommerce,
  .woocommerce-checkout .woocommerce {
    padding: var(--il-space-lg) var(--il-space-md);
  }

  /* Mobile cart table */
  .woocommerce table.shop_table.cart {
    display: block !important;
  }

  .woocommerce table.cart thead {
    display: none !important;
  }

  .woocommerce table.cart tr {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center;
    padding: var(--il-space-md) !important;
    border-bottom: 1px solid var(--il-border-color) !important;
    gap: var(--il-space-sm);
  }

  .woocommerce table.cart td {
    border: none !important;
    padding: 4px !important;
  }

  .woocommerce table.cart td.product-thumbnail {
    width: 64px !important;
  }

  .woocommerce table.cart td.product-thumbnail img {
    width: 64px !important;
    height: 64px !important;
  }

  .woocommerce table.cart td.product-name {
    flex: 1;
    min-width: 0;
  }

  .woocommerce table.cart td.actions {
    width: 100%;
    flex-direction: column;
  }

  .woocommerce table.cart td.actions .coupon {
    flex-direction: column;
    width: 100%;
  }

  .woocommerce table.cart td.actions .coupon input[type="text"] {
    max-width: none;
    width: 100%;
  }

  .woocommerce .cart_totals {
    max-width: none;
    margin-left: 0;
  }
}
