/* IPTV Belgique Commerce Engine v2.7.19.121
   Final tunnel layout polish after real screenshot review.
   Scope: public cart + checkout only.
   Goal: wider, cleaner, premium alignment with IPTV Charleroi theme. */

/* Shell: less empty vertical space, more controlled centered tunnel. */
body .iptvbc-commerce-flow.iptvbc-cart,
body .iptvbc-commerce-flow.iptvbc-checkout {
  width: min(1180px, calc(100vw - 48px)) !important;
  max-width: 1180px !important;
  margin-top: clamp(24px, 3.6vw, 48px) !important;
  margin-bottom: clamp(56px, 7vw, 100px) !important;
  padding-inline: 0 !important;
}

/* Hero: premium but no longer oversized or detached from the tunnel. */
body .iptvbc-commerce-flow .iptvbc-section-head {
  width: min(760px, 100%) !important;
  max-width: 760px !important;
  margin-bottom: clamp(28px, 3.2vw, 38px) !important;
  padding: clamp(32px, 4.2vw, 48px) clamp(30px, 4.8vw, 56px) !important;
  border-radius: 30px !important;
}

body .iptvbc-commerce-flow .iptvbc-section-head h2 {
  font-size: clamp(44px, 4.65vw, 64px) !important;
  line-height: .90 !important;
  letter-spacing: -.064em !important;
}

body .iptvbc-commerce-flow .iptvbc-section-head p {
  max-width: 560px !important;
  font-size: clamp(16px, 1.22vw, 19px) !important;
}

/* Cart: the card should look complete and premium, not like two separated boxes. */
body .iptvbc-cart .iptvbc-cart-items,
body .iptvbc-cart .iptvbc-cart-total,
body .iptvbc-cart .iptvbc-cart-actions {
  max-width: 980px !important;
}

body .iptvbc-cart .iptvbc-cart-item {
  grid-template-columns: minmax(0, 1fr) minmax(250px, 300px) !important;
  gap: clamp(22px, 3vw, 34px) !important;
  padding: clamp(26px, 3.2vw, 38px) !important;
  border-radius: 28px !important;
}

body .iptvbc-cart .iptvbc-cart-item h3 {
  margin-bottom: 22px !important;
  font-size: clamp(27px, 2.55vw, 38px) !important;
}

body .iptvbc-cart .iptvbc-options {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px 12px !important;
}

body .iptvbc-cart .iptvbc-option-row {
  min-height: 46px !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,.80) !important;
}

body .iptvbc-cart .iptvbc-cart-price {
  justify-content: center !important;
  min-height: 100% !important;
  border-radius: 24px !important;
}

body .iptvbc-cart .iptvbc-cart-price strong {
  font-size: clamp(32px, 3.2vw, 44px) !important;
}

/* Cart total bar: cleaner footer rhythm. */
body .iptvbc-cart .iptvbc-cart-total {
  min-height: 72px !important;
  border-radius: 22px !important;
  padding: 18px 26px !important;
}

body .iptvbc-cart .iptvbc-cart-actions {
  gap: 14px !important;
}

body .iptvbc-cart .iptvbc-cart-actions .iptvbc-btn {
  min-width: 190px !important;
}

/* Checkout layout: wider, more balanced, closer to high-end SaaS checkout. */
body .iptvbc-checkout .iptvbc-checkout-layout {
  width: min(1120px, 100%) !important;
  max-width: 1120px !important;
  display: grid !important;
  grid-template-columns: minmax(640px, 1fr) minmax(320px, 370px) !important;
  gap: 28px !important;
  align-items: start !important;
  margin-inline: auto !important;
}

body .iptvbc-checkout .iptvbc-checkout-form {
  padding: clamp(28px, 3vw, 38px) !important;
  border-radius: 28px !important;
}

body .iptvbc-checkout .iptvbc-summary {
  padding: 30px !important;
  border-radius: 28px !important;
  min-height: 210px !important;
}

/* Checkout fields: stronger visibility and rhythm. */
body .iptvbc-checkout .iptvbc-form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px 20px !important;
}

body .iptvbc-checkout .iptvbc-field label {
  gap: 9px !important;
  color: #0f172a !important;
  font-size: 13.5px !important;
  font-weight: 950 !important;
}

body .iptvbc-checkout input[type="text"],
body .iptvbc-checkout input[type="email"],
body .iptvbc-checkout input[type="tel"],
body .iptvbc-checkout select {
  min-height: 52px !important;
  border-radius: 16px !important;
  padding-inline: 17px !important;
  background: rgba(255,255,255,.92) !important;
}

body .iptvbc-checkout textarea {
  min-height: 132px !important;
  border-radius: 18px !important;
  padding: 16px 17px !important;
  background: rgba(255,255,255,.92) !important;
}

/* Payment helper was visually too tiny and compressed. */
body .iptvbc-checkout .iptvbc-payment-help {
  margin-top: 10px !important;
  padding: 10px 12px !important;
  border-radius: 13px !important;
  background: rgba(255,245,246,.76) !important;
  color: #596579 !important;
  font-size: 12.2px !important;
  line-height: 1.42 !important;
}

/* Critical screenshot fix: terms checkbox no longer splits text into ugly columns. */
body .iptvbc-checkout .iptvbc-terms {
  display: block !important;
  padding: 16px 18px !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(239,18,30,.055), transparent 34%),
    rgba(255,255,255,.82) !important;
}

body .iptvbc-checkout .iptvbc-terms label {
  display: block !important;
  position: relative !important;
  min-height: 28px !important;
  padding-left: 38px !important;
  color: #10172a !important;
  font-size: 13.5px !important;
  font-weight: 850 !important;
  line-height: 1.55 !important;
  white-space: normal !important;
  text-align: left !important;
}

body .iptvbc-checkout .iptvbc-terms input[type="checkbox"] {
  position: absolute !important;
  left: 0 !important;
  top: 2px !important;
  float: none !important;
  display: block !important;
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  margin: 0 !important;
}

/* Summary: more premium and more readable. */
body .iptvbc-checkout .iptvbc-summary h3 {
  font-size: 24px !important;
  margin-bottom: 24px !important;
}

body .iptvbc-checkout .iptvbc-summary-product,
body .iptvbc-checkout .iptvbc-summary-line {
  padding: 16px 0 !important;
  gap: 18px !important;
}

body .iptvbc-checkout .iptvbc-summary-product span,
body .iptvbc-checkout .iptvbc-summary-line span {
  font-size: 14px !important;
}

body .iptvbc-checkout .iptvbc-summary-product strong {
  white-space: nowrap !important;
}

body .iptvbc-checkout .iptvbc-summary-line.total strong {
  font-size: clamp(36px, 3.8vw, 50px) !important;
  letter-spacing: -.06em !important;
  white-space: nowrap !important;
}

/* CTA: stronger final action and clearer hierarchy. */
body .iptvbc-checkout .iptvbc-btn-wide,
body .iptvbc-cart .iptvbc-btn-primary {
  min-height: 58px !important;
  border-radius: 16px !important;
  font-size: 15px !important;
}

body .iptvbc-cart .iptvbc-btn:not(.iptvbc-btn-primary) {
  background: rgba(255,255,255,.92) !important;
}

/* Better spacing before footer: avoid the tunnel feeling glued to the footer. */
body .iptvbc-checkout,
body .iptvbc-cart {
  padding-bottom: clamp(24px, 4vw, 46px) !important;
}

/* Responsive: tablet becomes stacked but still premium. */
@media (max-width: 1080px) {
  body .iptvbc-checkout .iptvbc-checkout-layout {
    grid-template-columns: 1fr !important;
    width: min(760px, 100%) !important;
  }

  body .iptvbc-checkout .iptvbc-summary {
    position: relative !important;
    top: auto !important;
  }

  body .iptvbc-cart .iptvbc-cart-item {
    grid-template-columns: 1fr !important;
  }

  body .iptvbc-cart .iptvbc-cart-price {
    align-items: flex-start !important;
  }
}

/* Mobile: avoid microscopic fields and broken text. */
@media (max-width: 720px) {
  body .iptvbc-commerce-flow.iptvbc-cart,
  body .iptvbc-commerce-flow.iptvbc-checkout {
    width: min(100% - 28px, 680px) !important;
    margin-top: 24px !important;
  }

  body .iptvbc-commerce-flow .iptvbc-section-head {
    padding: 28px 22px !important;
    border-radius: 24px !important;
  }

  body .iptvbc-commerce-flow .iptvbc-section-head h2 {
    font-size: clamp(34px, 11vw, 48px) !important;
    line-height: .94 !important;
  }

  body .iptvbc-checkout .iptvbc-form-grid,
  body .iptvbc-cart .iptvbc-options {
    grid-template-columns: 1fr !important;
  }

  body .iptvbc-cart .iptvbc-cart-item,
  body .iptvbc-checkout .iptvbc-checkout-form,
  body .iptvbc-checkout .iptvbc-summary {
    padding: 20px !important;
    border-radius: 22px !important;
  }

  body .iptvbc-cart .iptvbc-cart-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  body .iptvbc-cart .iptvbc-cart-actions .iptvbc-btn {
    min-width: 0 !important;
  }

  body .iptvbc-checkout .iptvbc-terms label {
    font-size: 13px !important;
    padding-left: 36px !important;
  }
}

@media (max-width: 420px) {
  body .iptvbc-checkout .iptvbc-summary-line.total {
    grid-template-columns: 1fr !important;
  }

  body .iptvbc-checkout .iptvbc-summary-line.total strong {
    font-size: 34px !important;
  }
}
