/* ============================================================
   Checkout modal — Summer Perspective 20·26
   Inherits tokens from index.html (Scale20 system).
   ============================================================ */

.checkout-overlay {
  position: fixed; inset: 0; z-index: 150;
  background: rgba(12,12,12,0.72);
  backdrop-filter: blur(8px) saturate(1.1);
  display: flex; align-items: stretch; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 240ms cubic-bezier(0.22,1,0.36,1);
  overflow-y: auto;
  padding: 28px 24px;
}
.checkout-overlay.open { opacity: 1; pointer-events: auto; }

.checkout-modal {
  background: #fff;
  border-radius: var(--card-radius, 22px);
  width: 100%; max-width: 1080px;
  margin: auto;
  position: relative;
  transform: translateY(14px) scale(0.985);
  transition: transform 320ms cubic-bezier(0.22,1,0.36,1);
  overflow: hidden;
  display: grid;
  grid-template-columns: 380px 1fr;
  box-shadow: 0 60px 120px -40px rgba(0,0,0,0.5);
}
.checkout-overlay.open .checkout-modal { transform: translateY(0) scale(1); }

.checkout-close {
  position: absolute; top: 16px; right: 16px; z-index: 6;
  width: 36px; height: 36px; border-radius: 999px;
  background: #fff; border: 1px solid var(--hairline);
  display: grid; place-items: center; padding: 0;
  cursor: pointer; transition: background 200ms, color 200ms, border-color 200ms;
  color: #0c0c0c;
}
.checkout-close:hover { background: #0c0c0c; color: #fff; border-color: #0c0c0c; }
.checkout-close svg { width: 14px; height: 14px; }

/* ---------- Summary side (left) ---------- */
.checkout-summary {
  background: #0c0c0c; color: #fff;
  padding: 36px 30px 28px;
  display: flex; flex-direction: column; gap: 22px;
  position: relative;
  align-self: stretch;
}
.checkout-summary .eyebrow {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.checkout-thesis {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(26px, 2.4vw, 32px);
  letter-spacing: -0.028em;
  line-height: 1.04;
  margin: 0;
  text-wrap: balance;
}
.checkout-thesis .hl {
  background: #fef3a7;
  color: #0c0c0c;
  padding: 0 .14em;
}
.checkout-thesis em { font-style: italic; }

.summary-meta {
  display: grid; gap: 10px;
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,0.16);
  border-bottom: 1px solid rgba(255,255,255,0.16);
}
.summary-meta .row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.summary-meta .k {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.summary-meta .v { font-family: var(--font-sans); font-size: 14px; color: #fff; text-align: right; }

.summary-price { display: flex; align-items: baseline; gap: 4px; }
.summary-price .cur { font-family: var(--font-display); font-weight: 300; font-size: 22px; }
.summary-price .num { font-family: var(--font-display); font-weight: 300; font-size: 56px; letter-spacing: -0.04em; line-height: 0.9; }
.summary-price .per {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); margin-left: 8px;
}

/* Deposit + payment breakdown (dark summary) */
.deposit-block { display: grid; gap: 14px; }
.deposit-label {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.deposit-copy {
  margin: 0;
  font-family: var(--font-sans); font-size: 13.5px; line-height: 1.5;
  color: rgba(255,255,255,0.82);
}
.deposit-copy b { color: #fff; font-weight: 600; }
.payment-breakdown {
  display: grid; gap: 4px;
  padding: 14px 16px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
}
.payment-breakdown .pb-row {
  display: grid; grid-template-columns: 110px 1fr; gap: 12px; align-items: baseline;
  padding: 8px 0; border-bottom: 1px dashed rgba(255,255,255,0.12);
}
.payment-breakdown .pb-row:last-child { border-bottom: none; }
.payment-breakdown .pb-row .k {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.payment-breakdown .pb-row .v {
  font-family: var(--font-sans); font-size: 14px; color: #fff;
  text-align: right;
}
.payment-breakdown .pb-row .v .t {
  display: block;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.45); margin-top: 2px;
}
.payment-breakdown .pb-row.total { border-top: 1px solid rgba(255,255,255,0.18); padding-top: 12px; margin-top: 4px; }
.payment-breakdown .pb-row.total .k { color: #fff; }
.payment-breakdown .pb-row.total .v { font-family: var(--font-display); font-weight: 300; font-size: 18px; letter-spacing: -0.02em; }
.pb-fine {
  font-family: var(--font-sans); font-size: 11.5px; line-height: 1.5;
  color: rgba(255,255,255,0.5);
}

.section-sub {
  margin: -2px 0 18px;
  font-family: var(--font-sans); font-size: 14.5px; line-height: 1.55;
  color: var(--ink-mute);
  max-width: 56ch;
}

/* Tier picker (payment step) */
.tier-picker {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  margin: 14px 0 18px;
}
.tier-card {
  display: grid; gap: 6px;
  background: #fff;
  border: 1.5px solid var(--hairline);
  border-radius: 16px;
  padding: 18px 20px 16px;
  text-align: left;
  cursor: pointer;
  position: relative;
  transition: border-color 200ms, background 200ms, transform 100ms;
  font-family: inherit;
}
.tier-card:hover { border-color: #0c0c0c; }
.tier-card:active { transform: translateY(1px); }
.tier-card.selected {
  background: #0c0c0c;
  border-color: #0c0c0c;
  color: #fff;
}
.tier-card .tier-eyebrow {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute);
}
.tier-card.selected .tier-eyebrow { color: rgba(255,255,255,0.55); }
.tier-card .tier-title {
  font-family: var(--font-display); font-weight: 300; font-size: 22px;
  letter-spacing: -0.024em; line-height: 1.05;
  margin-top: 2px;
}
.tier-card .tier-price {
  display: flex; gap: 10px; align-items: baseline;
  margin-top: 10px;
}
.tier-card .tier-price .big {
  font-family: var(--font-display); font-weight: 300; font-size: 38px;
  letter-spacing: -0.035em; line-height: 1;
}
.tier-card .tier-price .meta {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-mute); line-height: 1.4;
}
.tier-card.selected .tier-price .meta { color: rgba(255,255,255,0.6); }
.tier-card .tier-total {
  margin-top: 4px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft);
}
.tier-card.selected .tier-total { color: rgba(255,255,255,0.55); }
.tier-card .tier-pick {
  position: absolute; top: 16px; right: 18px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-soft);
  padding: 5px 10px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  transition: all 200ms;
}
.tier-card.selected .tier-pick {
  background: #fef3a7; color: #0c0c0c; border-color: #fef3a7;
}
.tier-card.selected .tier-pick::before { content: "✓ "; }

@media (max-width: 540px) {
  .tier-picker { grid-template-columns: 1fr; }
  .tier-card .tier-pick { position: static; align-self: flex-end; margin-top: 4px; }
}

/* pay-header amount label */
.payment-step .pay-header .amount {
  flex-direction: column; align-items: flex-end; gap: 2px;
}
.payment-step .pay-header .amount-label {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.payment-step .pay-header .what b { color: #fff; font-weight: 600; }

.summary-toggle {
  display: grid;
  border: 1px solid rgba(255,255,255,0.28); border-radius: 999px;
  overflow: hidden;
}
.summary-toggle.two { grid-template-columns: 1fr 1fr; }
.summary-toggle button {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 10px 8px;
  background: transparent; color: rgba(255,255,255,0.72);
  border: none; cursor: pointer;
  transition: background 180ms, color 180ms;
}
.summary-toggle button.active { background: #fff; color: #0c0c0c; }

.toggle-stack { display: grid; gap: 8px; }
.toggle-stack .toggle-label {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}

.summary-incl { display: grid; gap: 0; }
.summary-incl div {
  font-family: var(--font-sans); font-size: 13px; color: rgba(255,255,255,0.82);
  padding: 8px 0;
  border-bottom: 1px dashed rgba(255,255,255,0.14);
}
.summary-incl div:last-child { border-bottom: none; }

.summary-signature {
  margin-top: auto; display: flex; gap: 12px; align-items: center;
  padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.16);
}
.summary-signature img { width: 38px; height: 38px; border-radius: 999px; object-fit: cover; flex: 0 0 auto; }
.summary-signature .who { display: flex; flex-direction: column; gap: 2px; }
.summary-signature .sig {
  font-family: var(--font-script); font-size: 22px; color: #fff;
  transform: rotate(-3deg); display: inline-block; line-height: 1;
}
.summary-signature .role {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}

/* ---------- Form side (right) ---------- */
.checkout-form-wrap {
  padding: 38px 44px 36px;
  max-height: calc(100vh - 56px);
  overflow-y: auto;
  position: relative;
}
.checkout-progress {
  display: flex; gap: 8px;
  margin-bottom: 26px;
  position: sticky; top: 0; background: linear-gradient(180deg, #fff 70%, rgba(255,255,255,0));
  padding-bottom: 14px;
  z-index: 2;
}
.checkout-progress .dot {
  flex: 1; height: 3px; background: #ebeae6; border-radius: 999px;
  position: relative; overflow: hidden;
}
.checkout-progress .dot::after {
  content: ""; position: absolute; inset: 0;
  transform-origin: left; transform: scaleX(0);
  transition: transform 320ms cubic-bezier(0.22,1,0.36,1);
  background: #0c0c0c;
}
.checkout-progress .dot.active::after { transform: scaleX(0.5); background: #d97757; }
.checkout-progress .dot.done::after { transform: scaleX(1); background: #0c0c0c; }

.checkout-section {
  padding: 22px 0 28px;
  border-top: 1px solid var(--hairline);
}
.checkout-section:first-of-type { border-top: none; padding-top: 0; }

.section-eyebrow {
  display: flex; align-items: baseline; justify-content: space-between; gap: 8px;
  margin-bottom: 16px;
}
.section-eyebrow .label {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-mute);
}
.section-eyebrow .check {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft);
  opacity: 0; transform: translateX(-4px);
  transition: opacity 220ms, transform 220ms, color 220ms;
  display: inline-flex; align-items: center; gap: 6px;
}
.section-eyebrow .check::before {
  content: ""; width: 6px; height: 6px; border-radius: 999px; background: currentColor;
}
.section-eyebrow.complete .check { opacity: 1; transform: translateX(0); color: #1f8a5b; }

.section-title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 30px;
  letter-spacing: -0.028em;
  line-height: 1.05;
  margin: 0 0 4px;
  text-wrap: balance;
}

.fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field { display: flex; flex-direction: column; gap: 6px; min-width: 0; position: relative; }
.field.span-2 { grid-column: span 2; }
.field > label {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-mute);
}
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field input[type="date"],
.field select,
.field .combo-input,
.field textarea {
  font-family: var(--font-sans); font-size: 15px;
  padding: 13px 16px;
  border: 1px solid var(--hairline);
  border-radius: 12px;
  background: #fff; color: var(--ink);
  width: 100%;
  transition: border-color 160ms, box-shadow 160ms, background 160ms;
  outline: none;
  -webkit-appearance: none; appearance: none;
}
.field textarea { resize: vertical; min-height: 84px; font-family: var(--font-sans); }
.field input::placeholder, .field textarea::placeholder { color: var(--ink-soft); }
.field input:focus, .field select:focus, .field .combo-input:focus, .field textarea:focus {
  border-color: #0c0c0c;
  box-shadow: 0 0 0 3px rgba(12,12,12,0.06);
}
.field .micro {
  font-family: var(--font-sans); font-size: 12px; color: var(--ink-soft); line-height: 1.4;
}
.field .err {
  font-family: var(--font-sans); font-size: 12px; color: #b03a2e;
  display: none;
}
.field.invalid input,
.field.invalid select,
.field.invalid .combo-input,
.field.invalid .phone-field { border-color: #b03a2e; }
.field.invalid .phone-field input { border-color: #b03a2e; }
.field.invalid .err { display: block; }

.field input[type="date"] {
  font-family: var(--font-sans);
  color: var(--ink);
}
.field input[type="date"]::-webkit-calendar-picker-indicator {
  opacity: 0.4; cursor: pointer;
}

/* ---------- Combobox (searchable country) ---------- */
.combo { position: relative; }
.combo-input {
  cursor: pointer;
  display: flex; align-items: center; gap: 10px;
  min-height: 48px;
}
.combo-input.empty { color: var(--ink-soft); }
.combo-input .flag-display { font-size: 18px; line-height: 1; }
.combo-input .chev {
  margin-left: auto; opacity: 0.5;
  transition: transform 200ms;
}
.combo.open .combo-input .chev { transform: rotate(180deg); }
.combo-input .value-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.combo-pop {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  background: #fff; border: 1px solid var(--hairline);
  border-radius: 14px;
  max-height: 300px; overflow: hidden;
  z-index: 5;
  box-shadow: 0 24px 50px -22px rgba(0,0,0,0.28);
  display: none;
  flex-direction: column;
}
.combo.open .combo-pop { display: flex; }
.combo-search {
  background: #fff; padding: 10px 12px;
  border-bottom: 1px solid var(--hairline);
  flex: 0 0 auto;
}
.combo-search input {
  width: 100%; border: 1px solid var(--hairline); border-radius: 8px;
  padding: 9px 12px; font-family: var(--font-sans); font-size: 14px;
  outline: none;
}
.combo-search input:focus { border-color: #0c0c0c; }
.combo-list { overflow-y: auto; flex: 1; min-height: 0; }
.combo-option {
  padding: 10px 14px; cursor: pointer;
  font-family: var(--font-sans); font-size: 14px;
  display: flex; align-items: center; gap: 12px;
  border-bottom: 1px dashed var(--hairline);
}
.combo-option:hover, .combo-option.active { background: #f7f6f3; }
.combo-option .flag { font-size: 18px; line-height: 1; flex: 0 0 auto; }
.combo-option .name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.combo-option .dial {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft);
  letter-spacing: 0.04em; flex: 0 0 auto;
}
.combo-empty {
  padding: 18px 14px; text-align: center;
  color: var(--ink-soft); font-family: var(--font-sans); font-size: 13px;
}

/* ---------- Phone field (country code + number) ---------- */
.phone-field {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 0;
  border: 1px solid var(--hairline);
  border-radius: 12px;
  overflow: visible;
  transition: border-color 160ms, box-shadow 160ms;
}
.phone-field:focus-within { border-color: #0c0c0c; box-shadow: 0 0 0 3px rgba(12,12,12,0.06); }
.phone-field .combo { border-right: 1px solid var(--hairline); }
.phone-field .combo-input {
  border: none; border-radius: 0;
  padding: 13px 12px 13px 14px;
  background: transparent;
  min-height: 46px;
}
.phone-field .combo-input:focus { box-shadow: none; }
.phone-field .combo-input .value-text { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.02em; }
.phone-field input[type="tel"] {
  border: none; border-radius: 0; padding: 13px 16px;
  background: transparent;
}
.phone-field input[type="tel"]:focus { box-shadow: none; border: none; }

/* ---------- Diet chips ---------- */
.diet-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.diet-chip {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--font-sans); font-size: 13.5px;
  color: var(--ink);
  transition: background 160ms, border-color 160ms, color 160ms;
  user-select: none;
  position: relative;
}
.diet-chip:hover { border-color: #0c0c0c; }
.diet-chip input { position: absolute; opacity: 0; pointer-events: none; }
.diet-chip .box {
  width: 14px; height: 14px; border-radius: 4px;
  border: 1.5px solid #b8b7b3;
  display: grid; place-items: center;
  flex: 0 0 auto;
  transition: background 160ms, border-color 160ms;
}
.diet-chip.checked { background: #0c0c0c; color: #fff; border-color: #0c0c0c; }
.diet-chip.checked .box { background: #fff; border-color: #fff; }
.diet-chip.checked .box::after { content: ""; width: 7px; height: 7px; background: #0c0c0c; border-radius: 2px; }

/* ---------- Terms + submit ---------- */
.terms-row {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 14px 16px;
  border: 1px solid var(--hairline);
  border-radius: 14px;
  cursor: pointer;
  transition: border-color 160ms, background 160ms;
}
.terms-row:hover { border-color: #0c0c0c; }
.terms-row input { margin-top: 3px; accent-color: #0c0c0c; transform: scale(1.15); flex: 0 0 auto; cursor: pointer; }
.terms-row label { font-family: var(--font-sans); font-size: 14px; line-height: 1.5; color: var(--ink); cursor: pointer; flex: 1; min-width: 0; }
.terms-row a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }
.field.invalid .terms-row { border-color: #b03a2e; }

.submit-btn {
  width: 100%; padding: 19px 22px;
  background: #0c0c0c; color: #fff;
  border: none; border-radius: 999px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 12px;
  transition: opacity 200ms, transform 100ms;
  margin-top: 18px;
}
.submit-btn:hover { opacity: 0.88; }
.submit-btn:active { transform: translateY(1px); }
.submit-btn[disabled] { opacity: 0.45; cursor: not-allowed; }
.submit-btn .arr { font-family: var(--font-mono); font-size: 14px; line-height: 1; }

.fineprint {
  margin-top: 12px;
  font-family: var(--font-sans); font-size: 12px; color: var(--ink-soft);
  line-height: 1.55;
}

/* ---------- Multi-step navigation ---------- */
.checkout-step { display: none; }
.checkout-step.active {
  display: block;
  animation: stepIn 360ms cubic-bezier(0.22,1,0.36,1);
}
@keyframes stepIn {
  from { opacity: 0; transform: translateX(18px); }
  to   { opacity: 1; transform: translateX(0); }
}

.step-nav {
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
  margin-top: 30px; padding-top: 24px;
  border-top: 1px solid var(--hairline);
}
.step-nav.no-back { justify-content: flex-end; }
.step-nav.hidden { display: none; }

.btn-back {
  background: transparent;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  padding: 13px 22px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink); cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
  transition: border-color 200ms, color 200ms, background 200ms;
}
.btn-back:hover { border-color: #0c0c0c; }
.btn-back .arr { font-size: 14px; line-height: 1; }
.step-nav.no-back .btn-back { visibility: hidden; }

.btn-continue {
  background: #0c0c0c; color: #fff;
  border: none; border-radius: 999px;
  padding: 15px 26px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 10px;
  transition: opacity 200ms, transform 100ms;
}
.btn-continue:hover { opacity: 0.88; }
.btn-continue:active { transform: translateY(1px); }
.btn-continue[disabled] { opacity: 0.45; cursor: not-allowed; }
.btn-continue .arr { font-family: var(--font-mono); font-size: 14px; line-height: 1; }

/* ---------- Review summary ---------- */
.review-summary {
  display: grid; gap: 18px;
  background: #faf9f6;
  border: 1px solid var(--hairline);
  border-radius: 14px;
  padding: 22px 24px;
  margin: 18px 0;
}
.review-block { display: grid; gap: 8px; }
.review-block-head {
  display: flex; justify-content: space-between; align-items: baseline; gap: 12px;
  padding-bottom: 8px; border-bottom: 1px solid var(--hairline);
}
.review-block-head h4 {
  margin: 0; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink);
}
.review-edit {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute); background: none; border: none; cursor: pointer;
  text-decoration: underline; text-underline-offset: 3px;
  padding: 0;
  transition: color 180ms;
}
.review-edit:hover { color: var(--ink); }
.review-block .row {
  display: flex; justify-content: space-between; gap: 14px; align-items: baseline;
  padding: 6px 0; border-bottom: 1px dashed var(--hairline);
}
.review-block .row:last-child { border-bottom: none; }
.review-block .row .k {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-soft);
  flex: 0 0 auto;
}
.review-block .row .v {
  font-family: var(--font-sans); font-size: 14px; color: var(--ink);
  text-align: right;
  word-break: break-word;
  max-width: 65%;
}
.review-block .row .v .flag { margin-right: 6px; }
.review-block .row .v.muted { color: var(--ink-soft); font-style: italic; }

/* ---------- Payment step ---------- */
.payment-step .pay-header {
  display: grid; grid-template-columns: 1fr auto; gap: 14px;
  padding: 18px 22px;
  border: 1px solid var(--hairline);
  border-radius: 14px;
  background: #0c0c0c; color: #fff;
  margin: 18px 0;
  align-items: center;
}
.payment-step .pay-header .left { display: grid; gap: 4px; }
.payment-step .pay-header .who {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.payment-step .pay-header .what {
  font-family: var(--font-sans); font-size: 14px; line-height: 1.4; color: #fff;
}
.payment-step .pay-header .amount {
  display: flex; align-items: baseline; gap: 4px;
}
.payment-step .pay-header .amount .cur { font-family: var(--font-display); font-weight: 300; font-size: 16px; }
.payment-step .pay-header .amount .num { font-family: var(--font-display); font-weight: 300; font-size: 32px; letter-spacing: -0.03em; line-height: 1; }

.payment-frame {
  position: relative;
  border: 1px solid var(--hairline);
  border-radius: 14px;
  overflow: hidden;
  min-height: 760px;
  background: #faf9f6;
  margin-bottom: 14px;
}
.payment-frame iframe {
  width: 100%; height: 760px; border: none; display: block; background: #fff;
}
.payment-frame .pay-loading {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px;
  background: #faf9f6;
  z-index: 2;
  transition: opacity 320ms;
}
.payment-frame.loaded .pay-loading { opacity: 0; pointer-events: none; }
.payment-frame.errored .pay-loading {
  opacity: 1; pointer-events: auto;
}
.pay-spinner {
  width: 28px; height: 28px;
  border: 2px solid var(--hairline);
  border-top-color: #0c0c0c;
  border-radius: 999px;
  animation: paySpin 800ms linear infinite;
}
@keyframes paySpin { to { transform: rotate(360deg); } }
.pay-loading-text {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-soft);
}
.pay-loading .errored-only { display: none; }
.payment-frame.errored .pay-spinner,
.payment-frame.errored .pay-loading-text { display: none; }
.payment-frame.errored .pay-loading .errored-only {
  display: flex; flex-direction: column; align-items: center; gap: 14px; max-width: 360px; text-align: center;
  padding: 24px;
}
.payment-frame.errored .pay-loading .errored-only .h {
  font-family: var(--font-display); font-weight: 300; font-size: 22px; letter-spacing: -0.02em; line-height: 1.1; color: var(--ink);
}
.payment-frame.errored .pay-loading .errored-only .b {
  font-family: var(--font-sans); font-size: 13.5px; line-height: 1.5; color: var(--ink-mute);
}
.payment-frame.errored .pay-loading .errored-only a {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  background: #0c0c0c; color: #fff;
  padding: 13px 22px; border-radius: 999px;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 10px;
  transition: opacity 200ms;
}
.payment-frame.errored .pay-loading .errored-only a:hover { opacity: 0.88; }

.pay-fallback {
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
  padding: 14px 18px;
  border: 1px solid var(--hairline);
  border-radius: 12px;
  flex-wrap: wrap;
}
.pay-fallback .text {
  font-family: var(--font-sans); font-size: 13px; color: var(--ink-mute); line-height: 1.45;
  flex: 1; min-width: 200px;
}
.pay-fallback a {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: #0c0c0c; text-decoration: none;
  border: 1px solid #0c0c0c; padding: 11px 16px; border-radius: 999px;
  transition: background 180ms, color 180ms;
  display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.pay-fallback a:hover { background: #0c0c0c; color: #fff; }
.pay-fallback .arr { font-size: 13px; line-height: 1; }

.pay-secure {
  margin-top: 14px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-soft);
  display: flex; align-items: center; gap: 8px;
  justify-content: center;
}
.pay-secure svg { width: 12px; height: 12px; opacity: 0.6; }

@media (max-width: 540px) {
  .payment-frame { min-height: 620px; }
  .payment-frame iframe { height: 620px; }
  .payment-step .pay-header { grid-template-columns: 1fr; }
  .payment-step .pay-header .amount { justify-content: flex-start; }
}

/* ---------- Success ---------- */
.checkout-success {
  display: none; flex-direction: column; gap: 18px; align-items: flex-start;
  padding: 0 4px;
}
.checkout-form-wrap.success-shown .checkout-form { display: none; }
.checkout-form-wrap.success-shown .checkout-progress { display: none; }
.checkout-form-wrap.success-shown .checkout-success { display: flex; }
.checkout-success .ok-stamp {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: #1f8a5b;
  padding: 8px 14px; border: 1.5px dashed #1f8a5b; border-radius: 999px;
}
.checkout-success h2 {
  font-family: var(--font-display); font-weight: 300;
  font-size: clamp(32px, 3.4vw, 48px); letter-spacing: -0.028em; line-height: 1.05;
  margin: 4px 0 0; max-width: 22ch;
}
.checkout-success .body { font-family: var(--font-sans); font-size: 15px; line-height: 1.6; color: var(--ink-mute); max-width: 56ch; }
.checkout-success .next { margin-top: 6px; display: grid; gap: 10px; width: 100%; max-width: 480px; }
.checkout-success .next .step {
  display: grid; grid-template-columns: 28px 1fr; gap: 12px; align-items: baseline;
  padding: 12px 0; border-bottom: 1px dashed var(--hairline);
}
.checkout-success .next .step .n { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); letter-spacing: 0.08em; }
.checkout-success .next .step .t { font-family: var(--font-sans); font-size: 14px; color: var(--ink); }

/* ---------- Investment tile button ---------- */
.secure-spot-btn {
  margin-top: 14px;
  width: 100%;
  padding: 13px 18px;
  background: #0c0c0c; color: #fff;
  border: none; border-radius: 999px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  transition: opacity 200ms, transform 100ms;
}
.secure-spot-btn:hover { opacity: 0.88; }
.secure-spot-btn:active { transform: translateY(1px); }
.secure-spot-btn .arr { font-size: 14px; line-height: 1; }

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  .checkout-modal { grid-template-columns: 1fr; max-width: 580px; }
  .checkout-summary { padding: 28px 24px 24px; }
  .checkout-summary .summary-signature { display: none; }
  .checkout-form-wrap { padding: 28px 24px; max-height: none; }
  .fields { grid-template-columns: 1fr; }
  .field.span-2 { grid-column: span 1; }
  .diet-grid { grid-template-columns: 1fr; }
}
@media (max-width: 540px) {
  .checkout-overlay { padding: 0; align-items: flex-start; }
  .checkout-modal { border-radius: 0; min-height: 100vh; }
  .checkout-close { top: 12px; right: 12px; }
  .section-title { font-size: 26px; }
  .phone-field { grid-template-columns: 116px 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .checkout-overlay, .checkout-modal, .checkout-progress .dot::after,
  .submit-btn, .field input, .combo, .combo-input .chev { transition: none !important; }
}
