/* ── Stripe Payment Form v2 – Healthcare Design ─────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ── Variables ───────────────────────────────────────────────────────────── */
#spf-page {
  --teal: #29bec8;
  --teal-light: #e5f8fa;
  --teal-dark: #1a9fab;
  --teal-bg: #d6f1f3;
  --text: #1a1a2a;
  --text-mid: #444;
  --text-muted: #888;
  --border: #d8eef0;
  --input-bg: #f0f9fa;
  --white: #ffffff;
  --red: #e53935;
  --green: #00897b;
  --yellow: #f59e0b;
  --radius: 8px;
  --radius-lg: 14px;
  --shadow: 0 2px 12px rgba(0, 0, 0, .07);

  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 15px;
  color: var(--text);
  max-width: 1140px;
  margin: 0 auto;
  padding: 1rem 0 3rem;
  background: transparent;
  position: relative;
}

/* ── Required note ───────────────────────────────────────────────────────── */
.spf-required-note {
  text-align: right;
  font-size: .82rem;
  color: var(--text-muted);
  margin: 0 0 1.2rem;
}

.spf-req {
  color: var(--red);
  font-weight: 600;
}

/* ── Section titles ──────────────────────────────────────────────────────── */
.spf-section-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--text);
  margin: 4rem 0 .8rem;
  display: flex;
  align-items: center;
  gap: .3rem;
}

.spf-section-num {
  color: var(--text);
}

/* ── Card containers ─────────────────────────────────────────────────────── */
.spf-card {
  background: var(--teal-light);
  border-radius: var(--radius-lg);
  padding: 1.6rem 1.6rem 1rem;
  margin-bottom: .5rem;
  border: 1px solid var(--border);
}

/* Payment card has no top-padding (header flush) */
.spf-card-payment {
  padding: 0;
  overflow: hidden;
}

/* ── Payment header bar ──────────────────────────────────────────────────── */
.spf-payment-header {
  background: var(--teal);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .85rem 1.4rem;
  flex-wrap: wrap;
  gap: .6rem;
}

.spf-payment-title {
  font-weight: 700;
  font-size: .95rem;
  color: #1B2446;
  letter-spacing: .01em;
}

.spf-card-logos {
  display: flex;
  align-items: center;
  gap: .35rem;
  flex-wrap: wrap;
}

.spf-logo-card {
  display: inline-flex;
  align-items: center;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .25);
  flex-shrink: 0;
}

.spf-logo-card svg {
  display: block;
}

/* ── Card inner padding ──────────────────────────────────────────────────── */
.spf-card-inner {
  padding: 1.2rem 1.6rem 1.2rem;
}

.spf-card-notice {
  font-size: .85rem;
  color: var(--text-muted);
  margin: 0 0 1.2rem;
}

.spf-card-payment .spf-grid-2,
.spf-card-payment .spf-field {
  padding: 1.2rem 0 0 0;
}

.spf-card-payment .spf-field:last-child {
  padding-bottom: 0;
}

/* Special: first grid inside payment card needs top spacing */
.spf-card-payment .spf-card-notice {
  padding: 1rem 0rem 0;
  margin-bottom: 0;
}

.spf-card-payment .spf-grid-2 {
  padding: 0;
}

.spf-card-payment>.spf-grid-2 {
  margin-top: 1rem;
}

/* ── Grids ───────────────────────────────────────────────────────────────── */
.spf-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.4rem;
  margin-bottom: 0;
}

.spf-grid-half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.4rem;
  margin-bottom: 1rem;
}

@media (max-width: 640px) {

  .spf-card-inner {
    padding-left: 0;
    padding-right: 0;
  }

  .spf-grid-2,
  .spf-grid-half {
    grid-template-columns: 1fr;
  }

  .spf-card-payment .spf-field {
    padding-top: 0;
  }

  #spf-page {
    padding: .5rem 0 2rem;
  }

  .card-expiry {
    margin-top: 1rem;
  }

  .spf-card {
    padding: 1.2rem 1rem .8rem;
  }

  .spf-card-payment .spf-grid-2 {
    padding: 0;
  }

  .spf-card-payment>.spf-grid-2 {
    padding: 0 1rem;
  }

  .spf-card-payment .spf-card-notice {
    padding: 1rem 0 0;
    margin-bottom: 15px;
  }
}

/* ── Fields ──────────────────────────────────────────────────────────────── */
.spf-field {
  margin-bottom: .2rem;
}

.spf-field label {
  display: block;
  font-size: .82rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: .42rem;
}

.spf-field input[type="text"],
.spf-field input[type="email"],
.spf-field input[type="tel"],
.spf-field input[type="number"] {
  width: 100%;
  padding: .72rem 1rem;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-family: inherit;
  font-size: .92rem;
  outline: none;
  transition: border-color .18s, box-shadow .18s;
  box-sizing: border-box;
}

.spf-field input:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(41, 190, 200, .14);
}

.spf-field input::placeholder {
  color: #bbbbbb !important;
}

/* ── Stripe element containers ───────────────────────────────────────────── */
.spf-stripe-field {
  padding: .72rem 1rem;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  transition: border-color .18s, box-shadow .18s;
  min-height: 44px;
  /* display: flex; */
  align-items: center;
}

.spf-stripe-field.StripeElement--focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(41, 190, 200, .14);
}

.spf-stripe-field.StripeElement--invalid {
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(229, 57, 53, .1);
}

/* ── Radio group (gender) ────────────────────────────────────────────────── */
.spf-radio-group {
  display: flex;
  align-items: center;
  gap: 1.4rem;
  padding: .65rem 0;
}

.spf-radio-label {
  display: flex;
  align-items: center;
  gap: .5rem;
  cursor: pointer;
  font-size: .92rem;
  color: var(--text-mid);
  user-select: none;
}

.spf-radio-label input[type="radio"] {
  display: none;
}

.spf-radio-custom {
  width: 18px;
  height: 18px;
  border: 2px solid #b0cdd1;
  border-radius: 50%;
  background: var(--white);
  display: inline-block;
  position: relative;
  flex-shrink: 0;
  transition: border-color .2s;
}

.spf-radio-label input:checked+.spf-radio-custom {
  border-color: var(--teal);
  background: var(--white);
}

.spf-radio-label input:checked+.spf-radio-custom::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal);
}

/* ── DOB datepicker wrapper ──────────────────────────────────────────────── */
.spf-dob-wrap {
  position: relative;
}

.spf-dob-wrap input {
  padding-right: 2.4rem;
  cursor: pointer;
}

.spf-dob-icon {
  position: absolute;
  right: .75rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--teal-dark);
  pointer-events: none;
  display: flex;
  align-items: center;
}

/* ── Phone number ────────────────────────────────────────────────────────── */
.spf-phone-wrap {
  display: flex;
  gap: .5rem;
}

.spf-phone-code {
  width: 145px;
  flex-shrink: 0;
  padding: .72rem .6rem;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font-family: inherit;
  font-size: .88rem;
  color: var(--text);
  outline: none;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2388aab0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
  padding-right: 28px;
}

.spf-phone-code:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(41, 190, 200, .14);
}

.spf-phone-wrap input[type="tel"] {
  flex: 1;
}

/* ── Error messages ──────────────────────────────────────────────────────── */
.spf-error {
  display: block;
  color: var(--red);
  font-size: .78rem;
  margin-top: .3rem;
  min-height: .95em;
}

#spf-global-error {
  font-size: 1.3rem;
  margin-top: 20px;
  padding: 0 1.2rem;
  line-height: 1.8;
  background: var(--red);
  color: #fff;
  min-height: auto;
  margin: 20px auto !important;
}

/* ── Detecting ────────────────────────────────────────────────────────────── */
.spf-detecting {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .7rem 1.6rem;
  font-size: .82rem;
  color: var(--teal-dark);
  background: rgba(41, 190, 200, .06);
  border-top: 1px solid var(--border);
  margin-top: .5rem;
}

/* ── Secure badge ────────────────────────────────────────────────────────── */
.spf-secure-badge {
  display: flex;
  align-items: center;
  padding: .7rem 0 1.2rem;
  font-size: .8rem;
  color: #C01498;
  font-weight: 500;
}

/* ── Card badge (domestic / intl) ────────────────────────────────────────── */
.spf-card-badge {
  margin: .6rem 0 0;
  padding: .55rem .9rem;
  border-radius: var(--radius);
  font-size: .82rem;
  font-weight: 500;
}

.badge-domestic {
  background: rgba(0, 137, 123, .08);
  border: 1px solid rgba(0, 137, 123, .25);
  color: var(--green);
}

.badge-intl {
  background: rgba(245, 158, 11, .1);
  border: 1px solid rgba(245, 158, 11, .3);
  color: #b45309;
}

/* ── Summary card ─────────────────────────────────────────────────────────── */
.spf-card-summary {
  padding: 1.4rem 1.6rem;
}

.spf-sum-table {
  width: 100%;
}

.spf-sum-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .52rem 0;
  font-size: .9rem;
}

.spf-sum-row:last-child {
  border-bottom: none;
}

.spf-sum-label {
  color: var(--text-mid);
}

.spf-sum-value {
  font-weight: 600;
  color: var(--text);
}

.spf-sum-divider {
  height: 1px;
  background: var(--border);
  margin: .4rem 0;
}

.spf-sum-divider-heavy {
  height: 2px;
  background: var(--teal);
  margin: .5rem 0;
}

.spf-sum-fee-row .spf-sum-label {
  color: #b45309;
}

.spf-fee-val {
  color: #b45309 !important;
}

.spf-sum-total-row .spf-sum-label {
  font-weight: 700;
  font-size: 1rem;
  color: var(--text);
}

.spf-total-val {
  font-size: 2.18rem !important;
  font-weight: 800 !important;
  color: var(--teal-dark) !important;
}

.spf-sum-pending {
  margin: .9rem 0 0;
  padding: .7rem 1rem;
  background: rgba(41, 190, 200, .07);
  border-left: 3px solid var(--teal);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-size: .82rem;
  color: var(--teal-dark);
}

/* ── Terms & checkbox ────────────────────────────────────────────────────── */
.spf-terms-row {
  margin: 1.6rem 0 .5rem;
}

.spf-checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  cursor: pointer;
  font-size: .88rem;
  color: var(--text-mid);
  line-height: 1.4;
  user-select: none;
}

.spf-checkbox-label input[type="checkbox"] {
  display: none;
}

.spf-checkbox-custom {
  width: 18px;
  height: 18px;
  border: 2px solid #b0cdd1;
  border-radius: 4px;
  background: var(--white);
  flex-shrink: 0;
  margin-top: 1px;
  position: relative;
  transition: background .15s, border-color .15s;
}

.spf-checkbox-label input:checked+.spf-checkbox-custom {
  background: var(--teal);
  border-color: var(--teal);
}

.spf-checkbox-label input:checked+.spf-checkbox-custom::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 5px;
  width: 5px;
  height: 9px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}

/* ── Pay button ──────────────────────────────────────────────────────────── */
.spf-submit-row {
  margin-top: 1.2rem;
  display: flex;
  justify-content: center;
}

#spf-page .spf-btn-pay {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  width: auto;
  padding: .95rem 2.5rem;
  background: #C01498 !important;
  color: #fff !important;
  border: none;
  border-radius: 60px;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s, opacity .15s;
  box-shadow: 0 4px 18px rgba(41, 190, 200, .35);
  letter-spacing: .01em;
}

.spf-btn-pay:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(41, 190, 200, .45);
}

.spf-btn-pay:active:not(:disabled) {
  transform: translateY(0);
}

.spf-btn-pay:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* ── Spinners ─────────────────────────────────────────────────────────────── */
.spf-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, .3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spf-spin .7s linear infinite;
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}

.spf-spinner-teal {
  border-color: rgba(41, 190, 200, .2);
  border-top-color: var(--teal);
}

@keyframes spf-spin {
  to {
    transform: rotate(360deg);
  }
}

/* ── Success view ────────────────────────────────────────────────────────── */
.spf-success-wrap {
  text-align: center;
  padding: 3rem 1.5rem;
}

.spf-success-icon-wrap {
  margin-bottom: 1.2rem;
  animation: spf-pop .4s cubic-bezier(.175, .885, .32, 1.275);
}

@keyframes spf-pop {
  from {
    transform: scale(0);
    opacity: 0;
  }

  to {
    transform: scale(1);
    opacity: 1;
  }
}

.spf-success-heading {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 1.2rem;
}

.spf-success-detail {
  text-align: left;
  max-width: 420px;
  margin: 0 auto 1.8rem;
}

.spf-success-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}

.spf-success-table td {
  padding: .5rem .4rem;
  border-bottom: 1px solid #eee;
  color: var(--text-mid);
}

.spf-success-table td:first-child {
  color: var(--text-muted);
  width: 42%;
}

.spf-success-total td {
  color: var(--text) !important;
  font-size: .95rem;
}

.spf-btn-outline-teal {
  display: inline-block;
  padding: .75rem 2rem;
  border: 2px solid var(--teal);
  border-radius: var(--radius);
  background: transparent;
  color: var(--teal-dark);
  font-family: inherit;
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
}

.spf-btn-outline-teal:hover {
  background: var(--teal-light);
}

/* ── Decorative cross pattern (matches screenshot bg) ───────────────────── */
#spf-page::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image:
    radial-gradient(circle, rgba(41, 190, 200, .08) 1px, transparent 1px),
    radial-gradient(circle, rgba(41, 190, 200, .05) 1px, transparent 1px);
  background-size: 40px 40px, 20px 20px;
  pointer-events: none;
  z-index: -1;
}

.spf-field iframe {
  min-height: auto !important;
}

.spf-btn-arrow {
  vertical-align: bottom;
  width: 16px;
  margin-left: 3px;
}

.spf-radio-custom {
  vertical-align: middle;
}