/* ================= CART WRAPPER ================= */
.cart-wrapper {
  max-width: 960px;
  margin: var(--space-3xl) auto;
  padding: var(--space-2xl);
  background: var(--bg-secondary);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

/* subtle gradient overlay */
.cart-wrapper::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--gradient-card);
  pointer-events: none;
}

/* ================= TITLE ================= */
.cart-title {
  font-size: var(--text-2xl);
  font-weight: 600;
  text-align: center;
  color: var(--text-primary);
  margin-bottom: var(--space-xl);
}

/* ================= EMPTY CART ================= */
.cart-empty {
  text-align: center;
  font-size: var(--text-base);
  color: var(--text-secondary);
  padding: var(--space-xl);
}

/* ================= CART TABLE ================= */
.cart-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border-muted);
}

/* HEAD */
.cart-table thead {
  background: var(--gradient-primary);
}
.cart-table th {
  padding: var(--space-md);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  font-weight: 600;
}

/* BODY */
.cart-table td {
  padding: var(--space-md);
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-primary);
  border-bottom: 1px solid var(--border-muted);
  transition: background var(--transition-fast);
}

.cart-table tbody tr:hover {
  background: var(--bg-tertiary);
}

/* SUBTOTAL */
.subtotal {
  color: var(--accent-success);
  font-weight: 600;
}

/* ================= FOOTER ================= */
.cart-table tfoot td {
  padding: var(--space-lg);
  font-size: var(--text-base);
  background: var(--bg-tertiary);
}

.total-label {
  text-align: right;
  color: var(--text-secondary);
  font-weight: 500;
}

.total-value {
  color: var(--accent-success);
  font-weight: 700;
  font-size: var(--text-lg);
}

/* ================= CHECKOUT BUTTON ================= */
.checkout-btn {
  display: block;
  margin: var(--space-2xl) auto 0;
  max-width: 280px;
  padding: var(--space-md) var(--space-xl);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-align: center;
  color: #fff;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  text-decoration: none;
  border: none;
  box-shadow: var(--shadow-glow);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);
}
.checkout-btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.1);
  box-shadow: 0 0 60px rgba(88, 166, 255, 0.45);
}
.checkout-btn:active {
  transform: translateY(0);
}

/* ================= REMOVE ITEM BUTTON ================= */
.remove-cell {
  display: flex;
  justify-content: center;
  align-items: center;
}
.remove-btn {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-full);
  background: transparent;
  border: 1px solid var(--border-muted);
  color: var(--accent-danger);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
}
.remove-btn:hover,
.remove-btn:focus-visible {
  background: rgba(248, 81, 73, 0.12);
  box-shadow: 0 0 14px rgba(248, 81, 73, 0.35);
  transform: scale(1.08);
  outline: none;
}
.remove-btn:active {
  transform: scale(0.95);
}

/* ================= CHECKOUT PAGE ================= */
.checkout-wrapper {
  max-width: var(--container-max);
  margin: var(--space-3xl) auto;
  padding: var(--space-xl);
}
.checkout-title {
  text-align: center;
  font-size: var(--text-2xl);
  margin-bottom: var(--space-2xl);
}
.checkout-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: var(--space-xl);
}
.checkout-card,
.checkout-summary {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-md);
}
.checkout-card h2,
.checkout-summary h2 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-md);
}
.checkout-card textarea,
.checkout-card select {
  width: 100%;
  padding: var(--space-md);
  background: var(--bg-elevated);
  border: 1px solid var(--border-muted);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-sm);
}
.checkout-card textarea {
  min-height: 120px;
  resize: vertical;
}
.payment-options label {
  display: block;
  padding: var(--space-sm) 0;
  cursor: pointer;
}
.payment-options input {
  margin-right: var(--space-sm);
}
.summary-row {
  display: flex;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}
.summary-row.total {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text-primary);
  border-top: 1px solid var(--border-muted);
  margin-top: var(--space-md);
  padding-top: var(--space-md);
}
.pay-btn {
  width: 100%;
  margin-top: var(--space-lg);
  padding: var(--space-md);
  font-size: var(--text-sm);
  font-weight: 600;
  color: #fff;
  background: var(--gradient-primary);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  box-shadow: var(--shadow-glow);
  transition: transform var(--transition-fast), filter var(--transition-fast);
}
.pay-btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.1);
}

/* ================= MOBILE (≤720px) ================= */
@media (max-width: 720px) {
  .checkout-grid {
    grid-template-columns: 1fr;
  }
}

/* ================= FULL MOBILE STACK (≤422px) ================= */
@media (max-width: 422px) {

  /* CART WRAPPER */
  .cart-wrapper {
    margin: var(--space-md);
    padding: var(--space-md);
    border-radius: var(--radius-md);
  }

  .cart-title {
    font-size: var(--text-lg);
    margin-bottom: var(--space-md);
  }

  /* CART TABLE → STACKED CARDS */
  .cart-table,
  .cart-table thead,
  .cart-table tbody,
  .cart-table tfoot,
  .cart-table tr,
  .cart-table th,
  .cart-table td {
    display: block;
    width: 100%;
  }
  .cart-table thead {
    display: none;
  }
  .cart-table tbody tr {
    background: var(--bg-elevated);
    border: 1px solid var(--border-muted);
    border-radius: var(--radius-md);
    padding: var(--space-sm);
    margin-bottom: var(--space-sm);
    box-shadow: var(--shadow-sm);
  }
  .cart-table td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-xs) 0;
    font-size: var(--text-xs);
    border: none;
  }
  .cart-table td::before {
    content: attr(data-label);
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-tertiary);
  }
  .subtotal {
    font-size: var(--text-sm);
  }

  /* REMOVE BUTTON */
  .remove-cell {
    justify-content: flex-end;
    margin-top: var(--space-xs);
  }
  .remove-btn {
    width: 44px;
    height: 44px;
    font-size: 1.1rem;
  }

  /* FOOTER TOTAL */
  .cart-table tfoot tr {
    background: var(--bg-tertiary);
    border-radius: var(--radius-md);
    padding: var(--space-sm);
  }
  .total-label {
    font-size: var(--text-xs);
  }
  .total-value {
    font-size: var(--text-base);
  }

  /* CHECKOUT BUTTON */
  .checkout-btn {
    width: 100%;
    max-width: none;
    padding: 14px;
    font-size: var(--text-base);
    border-radius: var(--radius-md);
  }

  /* CHECKOUT PAGE */
  .checkout-wrapper {
    margin: var(--space-md);
    padding: var(--space-md);
  }
  .checkout-title {
    font-size: var(--text-xl);
    margin-bottom: var(--space-md);
  }
  .checkout-card,
  .checkout-summary {
    padding: var(--space-md);
    border-radius: var(--radius-md);
  }
  .checkout-card h2,
  .checkout-summary h2 {
    font-size: var(--text-base);
  }
  .checkout-card textarea,
  .checkout-card select {
    font-size: var(--text-sm);
    padding: 12px;
  }
  .pay-btn {
    font-size: var(--text-base);
    padding: 16px;
    border-radius: var(--radius-md);
  }

  /* TOUCH TARGETS */
  button,
  a,
  input,
  select,
  textarea {
    min-height: 44px;
  }
}
