/* ============================================================================
   Checkout page | Moroccan Berber Carpets
   ========================================================================== */

.template-checkout { background: var(--mbc-paper); color: var(--mbc-ink); font-family: 'Archivo', system-ui, sans-serif; margin: 0; }

.checkout-page { max-width: 1240px; margin: 0 auto; padding: 48px 24px 96px; }

.checkout-grid { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 56px; }
@media (max-width: 920px) { .checkout-grid { grid-template-columns: 1fr; gap: 32px; } }

.checkout-form h1 { font-family: 'New York', serif; font-weight: 400; font-size: clamp(28px, 4vw, 38px); margin: 0 0 32px; }

/* Sections */
.checkout-section { border: 0; padding: 0; margin: 0 0 28px; }
.checkout-section legend { font-family: 'Archivo', sans-serif; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mbc-ink-mute); padding: 0 0 14px; }

.checkout-row { margin-bottom: 14px; }
.checkout-row--two { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.checkout-row--three { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
@media (max-width: 580px) {
  .checkout-row--two, .checkout-row--three { grid-template-columns: 1fr; }
}

.checkout-row label { display: block; font-size: 12px; color: var(--mbc-ink-soft); letter-spacing: 0.04em; margin-bottom: 4px; }
.checkout-row input[type="text"],
.checkout-row input[type="email"],
.checkout-row input[type="tel"],
.checkout-row select,
.checkout-row textarea {
  width: 100%; padding: 12px 14px; border: 1px solid var(--mbc-line); background: #fff; font-family: 'Archivo', sans-serif; font-size: 14px; color: var(--mbc-ink); border-radius: 0; box-sizing: border-box;
}
.checkout-row input:focus, .checkout-row select:focus, .checkout-row textarea:focus {
  outline: none; border-color: var(--mbc-ink);
}
.checkout-row textarea { resize: vertical; min-height: 80px; }
.checkout-row input::placeholder { color: var(--mbc-ink-mute); }

.checkout-hint { font-size: 12px; color: var(--mbc-ink-mute); margin: 6px 0 0; }
.checkout-hint a { color: var(--mbc-ink); text-decoration: underline; }

/* Discount input */
.checkout-discount input { text-transform: uppercase; letter-spacing: 0.06em; }

/* Shipping options */
.checkout-shipping { background: #fff; border: 1px solid var(--mbc-line); padding: 4px 0; }
.checkout-shipping .checkout-hint { padding: 16px; margin: 0; }
.checkout-shipping label.ship-opt { display: flex; align-items: center; gap: 12px; padding: 14px 18px; cursor: pointer; border-bottom: 1px solid var(--mbc-line); }
.checkout-shipping label.ship-opt:last-child { border-bottom: 0; }
.checkout-shipping label.ship-opt:has(input:checked) { background: var(--mbc-paper-deep); }
.checkout-shipping label.ship-opt input { margin: 0; accent-color: var(--mbc-ink); }
.checkout-shipping .ship-name { flex: 1; font-size: 14px; }
.checkout-shipping .ship-eta { font-size: 12px; color: var(--mbc-ink-mute); }
.checkout-shipping .ship-cost { font-family: 'New York', serif; font-size: 16px; }

/* Drop-in container */
.checkout-dropin { background: #fff; border: 1px solid var(--mbc-line); padding: 16px; min-height: 120px; }
.checkout-dropin__placeholder { text-align: center; padding: 28px 16px; color: var(--mbc-ink-soft); }
.checkout-dropin__placeholder i { font-size: 28px; color: var(--mbc-ink-mute); margin-bottom: 12px; display: block; }
.checkout-dropin__placeholder p { margin: 0; font-size: 13px; }

#dropInElement { min-height: 320px; }

/* Alerts */
.checkout-alert { padding: 14px 18px; margin: 0 0 24px; font-size: 13px; line-height: 1.5; border-left: 3px solid var(--mbc-ink); background: #fff; }
.checkout-alert--err { border-left-color: var(--mbc-danger); background: #fcf3f0; color: var(--mbc-danger); }
.checkout-alert--warn { border-left-color: #b8862c; background: #fbf6e8; color: #6f5818; }
.checkout-alert i { margin-right: 8px; }
.checkout-alert a { color: inherit; text-decoration: underline; }

/* Submit button */
.checkout-cta { width: 100%; margin-top: 24px; }
.checkout-cta[disabled] { opacity: 0.5; cursor: not-allowed; }

.checkout-trust { font-size: 11px; color: var(--mbc-ink-mute); text-align: center; margin: 14px 0 0; letter-spacing: 0.04em; }
.checkout-trust i { margin: 0 6px 0 12px; color: var(--mbc-success); }
.checkout-trust i:first-child { margin-left: 0; }

/* ============================================================================
   Summary aside
   ========================================================================== */

.checkout-summary { position: sticky; top: 24px; align-self: start; }
.checkout-summary__inner { background: #fff; border: 1px solid var(--mbc-line); padding: 28px 26px; }
.checkout-summary h2 { font-family: 'New York', serif; font-weight: 400; font-size: 18px; margin: 0 0 18px; padding-bottom: 14px; border-bottom: 1px solid var(--mbc-line); }

.checkout-summary__items { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 14px; }
.checkout-summary__items li { display: grid; grid-template-columns: 64px 1fr auto; gap: 14px; align-items: center; }
.checkout-summary__thumb { position: relative; display: block; aspect-ratio: 1; background: var(--mbc-paper-deep); border: 1px solid var(--mbc-line); }
.checkout-summary__thumb img { width: 100%; height: 100%; object-fit: cover; }
.checkout-summary__qty { position: absolute; top: -8px; right: -8px; min-width: 22px; height: 22px; padding: 0 6px; background: var(--mbc-ink); color: var(--mbc-paper); border-radius: 999px; font-size: 11px; line-height: 22px; text-align: center; }
.checkout-summary__name { font-size: 13px; line-height: 1.3; color: var(--mbc-ink); }
.checkout-summary__name small { color: var(--mbc-ink-mute); }
.checkout-summary__line { font-family: 'New York', serif; font-size: 14px; color: var(--mbc-ink); }

.checkout-summary__rows { margin: 0; padding-top: 16px; border-top: 1px solid var(--mbc-line); display: flex; flex-direction: column; gap: 10px; }
.checkout-summary__rows > div { display: flex; justify-content: space-between; align-items: center; font-size: 14px; color: var(--mbc-ink-soft); }
.checkout-summary__rows dd { margin: 0; font-family: 'New York', serif; color: var(--mbc-ink); font-size: 15px; }
.checkout-summary__total { margin-top: 8px; padding-top: 12px; border-top: 1px solid var(--mbc-line); }
.checkout-summary__total dt { font-size: 16px; color: var(--mbc-ink) !important; }
.checkout-summary__total dd { font-size: 22px !important; }

.checkout-summary__assure { font-size: 11px; color: var(--mbc-ink-mute); text-align: center; letter-spacing: 0.04em; margin: 16px 0 0; }
.checkout-summary__assure i { margin-right: 6px; color: var(--mbc-accent); }
