/* ============================================
   IPTV Xtream - Cart & Checkout Styles
   Panier, Paiement, Confirmation pages
   ============================================ */

/* ─────────────────────────────────────────
   Cart Page
   ───────────────────────────────────────── */

.cart-section {
  padding: var(--space-12) 0 var(--space-20);
}

.cart-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--space-8);
  align-items: start;
}

/* Cart Items */
.cart-items {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.cart-item {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: var(--space-6);
  align-items: center;
  padding: var(--space-6);
}

.cart-item-info h3 {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-1);
}

.cart-item-info p {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.cart-item-price {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--text-primary);
  text-align: right;
}

.cart-item-quantity {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.qty-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-glass);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-lg);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.qty-btn:hover {
  background: var(--bg-glass-hover);
  border-color: var(--accent-primary);
}

.qty-value {
  width: 40px;
  text-align: center;
  font-size: var(--text-base);
  font-weight: var(--font-medium);
}

.cart-item-remove {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.cart-item-remove:hover {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.3);
  color: #ef4444;
}

/* Empty Cart */
.cart-empty {
  text-align: center;
  padding: var(--space-16);
}

.cart-empty-icon {
  font-size: 64px;
  margin-bottom: var(--space-6);
  opacity: 0.5;
}

.cart-empty h2 {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-3);
}

.cart-empty p {
  color: var(--text-muted);
  margin-bottom: var(--space-6);
}

/* Cart Summary Sidebar */
.cart-summary {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
}

.cart-summary h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-primary);
}

.cart-summary-row {
  display: flex;
  justify-content: space-between;
  padding: var(--space-3) 0;
}

.cart-summary-row span:first-child {
  color: var(--text-muted);
}

.cart-summary-row span:last-child {
  font-weight: var(--font-medium);
}

.cart-summary-total {
  display: flex;
  justify-content: space-between;
  padding: var(--space-4) 0;
  margin-top: var(--space-4);
  border-top: 1px solid var(--border-primary);
}

.cart-summary-total span:first-child {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
}

.cart-summary-total span:last-child {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cart-checkout-btn {
  width: 100%;
  margin-top: var(--space-6);
}

.cart-continue {
  display: block;
  text-align: center;
  margin-top: var(--space-4);
  color: var(--text-muted);
  font-size: var(--text-sm);
  transition: color var(--transition-fast);
}

.cart-continue:hover {
  color: var(--text-primary);
}

/* ─────────────────────────────────────────
   Payment Page
   ───────────────────────────────────────── */

.checkout-section {
  padding: var(--space-12) 0 var(--space-20);
}

.checkout-grid {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: var(--space-8);
  align-items: start;
}

/* Checkout Steps */
.checkout-steps {
  display: flex;
  justify-content: center;
  gap: var(--space-8);
  margin-bottom: var(--space-12);
}

.checkout-step {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--text-muted);
}

.checkout-step.active {
  color: var(--text-primary);
}

.checkout-step.completed {
  color: var(--accent-success);
}

.checkout-step-number {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-glass);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
}

.checkout-step.active .checkout-step-number {
  background: var(--gradient-primary);
  border: none;
  color: var(--color-white);
}

.checkout-step.completed .checkout-step-number {
  background: var(--accent-success);
  border: none;
  color: var(--color-white);
}

.checkout-step-text {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
}

/* Checkout Form */
.checkout-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.checkout-form h2 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-2);
}

.checkout-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.checkout-form-grid .form-group.full-width {
  grid-column: span 2;
}

/* Order Summary */
.order-summary {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
}

.order-summary h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-6);
}

.order-item {
  display: flex;
  justify-content: space-between;
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--border-primary);
}

.order-item:last-of-type {
  border-bottom: none;
}

.order-item-name {
  font-weight: var(--font-medium);
}

.order-item-qty {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.order-item-price {
  font-weight: var(--font-medium);
}

/* ─────────────────────────────────────────
   Confirmation Page
   ───────────────────────────────────────── */

.confirmation-section {
  padding: var(--space-16) 0 var(--space-20);
}

.confirmation-card {
  max-width: 700px;
  margin: 0 auto;
  text-align: center;
  padding: var(--space-12);
}

.confirmation-icon {
  width: 100px;
  height: 100px;
  margin: 0 auto var(--space-8);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  font-size: 48px;
  animation: scaleIn 0.5s var(--ease-bounce);
}

.confirmation-card h1 {
  font-size: var(--text-3xl);
  margin-bottom: var(--space-4);
}

.confirmation-card > p {
  font-size: var(--text-lg);
  color: var(--text-secondary);
  margin-bottom: var(--space-8);
}

.order-number-box {
  background: var(--bg-tertiary);
  border: 1px dashed var(--border-secondary);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-8);
  font-family: monospace;
  font-size: var(--text-lg);
  color: var(--accent-primary);
}

/* Next Steps */
.confirmation-steps {
  text-align: left;
  margin-bottom: var(--space-8);
}

.confirmation-steps h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-4);
  text-align: center;
}

.confirmation-steps ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.confirmation-steps li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3);
  background: var(--bg-glass);
  border-radius: var(--radius-lg);
  color: var(--text-secondary);
  font-size: var(--text-sm);
}

.confirmation-steps li span:first-child {
  font-size: var(--text-lg);
}

.confirmation-note {
  background: rgba(245, 158, 11, 0.1);
  border: 1px solid rgba(245, 158, 11, 0.3);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-8);
  color: var(--accent-warning);
  font-size: var(--text-sm);
}

.confirmation-actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* Reassurance Section */
.reassurance-section {
  padding: var(--space-12) 0;
  max-width: 700px;
  margin: 0 auto;
}

.reassurance-section h2 {
  font-size: var(--text-xl);
  text-align: center;
  margin-bottom: var(--space-6);
}

.reassurance-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.reassurance-list li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--text-secondary);
}

.reassurance-list li::before {
  content: '✓';
  color: var(--accent-success);
  font-weight: bold;
}

/* ─────────────────────────────────────────
   Responsive
   ───────────────────────────────────────── */

@media (max-width: 1024px) {
  .cart-grid,
  .checkout-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .cart-summary,
  .order-summary {
    position: static;
    order: -1;
  }

  .checkout-form-grid {
    grid-template-columns: 1fr;
  }

  .checkout-form-grid .form-group.full-width {
    grid-column: auto;
  }
}

@media (max-width: 768px) {
  .cart-item {
    grid-template-columns: 1fr;
    gap: var(--space-4);
    text-align: center;
  }

  .cart-item-quantity {
    justify-content: center;
  }

  .cart-item-price {
    text-align: center;
  }

  .checkout-steps {
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
  }

  .confirmation-card {
    padding: var(--space-8);
  }

  .confirmation-actions {
    flex-direction: column;
  }

  .confirmation-actions .btn {
    width: 100%;
  }
}
