/* ============================================================
   Donate by Xiotdev Technologies — Frontend Styles
   Design: FIRST-Network palette & typography system
   ============================================================ */

:root {
  --xd-navy:         #16253A;
  --xd-navy-deep:    #101D2E;
  --xd-carolina:     #84AFCF;
  --xd-carolina-soft:#B7D2E4;
  --xd-gold:         #D2A64A;
  --xd-gold-dark:    #b8902e;
  --xd-gold-soft:    #E8CF95;
  --xd-sage:         #A3B4A2;
  --xd-ivory:        #F5F2EB;
  --xd-ivory-warm:   #FBF8F1;
  --xd-charcoal:     #2D3748;
  --xd-muted:        #6b7280;
  --xd-white:        #fff;
  --xd-r-lg:         28px;
  --xd-r-md:         18px;
  --xd-r-sm:         12px;
  --xd-r-pill:       100px;
  --xd-shadow:       0 18px 44px -22px rgba(16,29,46,.28);
  --xd-shadow-lg:    0 24px 60px -28px rgba(16,29,46,.35);
  --xd-font-serif:   'Playfair Display', Georgia, serif;
  --xd-font-sans:    'Plus Jakarta Sans', 'Helvetica Neue', Arial, sans-serif;
  --xd-transition:   .25s cubic-bezier(.2,.8,.2,1);
}

/* ── Base ─────────────────────────────────────────────────── */
.xd-form-wrap,
.xd-receipt,
.xd-dashboard,
.xd-goal-widget,
.xd-donors-wall,
.xd-donation-history {
  font-family: var(--xd-font-sans);
  color: var(--xd-charcoal);
  -webkit-font-smoothing: antialiased;
}

/* ── Buttons ──────────────────────────────────────────────── */
.xd-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--xd-font-sans);
  font-weight: 700;
  font-size: .93rem;
  padding: 14px 26px;
  border-radius: var(--xd-r-pill);
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: transform var(--xd-transition), box-shadow var(--xd-transition), background var(--xd-transition), color var(--xd-transition);
  letter-spacing: .2px;
  line-height: 1;
}
.xd-btn:hover { transform: translateY(-2px); }
.xd-btn--gold {
  background: var(--xd-gold);
  color: var(--xd-navy-deep);
  box-shadow: 0 12px 28px -10px rgba(210,166,74,.55);
}
.xd-btn--gold:hover { background: #dcb45e; box-shadow: 0 18px 36px -10px rgba(210,166,74,.65); }
.xd-btn--outline {
  background: transparent;
  color: var(--xd-navy);
  border-color: rgba(22,37,58,.2);
}
.xd-btn--outline:hover { background: var(--xd-navy); color: var(--xd-ivory); border-color: var(--xd-navy); }
.xd-btn--sm { padding: 10px 18px; font-size: .82rem; }

/* ── Form wrapper ─────────────────────────────────────────── */
.xd-form-wrap {
  background: var(--xd-white);
  border-radius: var(--xd-r-lg);
  box-shadow: var(--xd-shadow-lg);
  overflow: hidden;
  max-width: 560px;
  margin: 0 auto;
}

/* ── Form header ──────────────────────────────────────────── */
.xd-form-header {
  background: var(--xd-navy);
  padding: 36px 36px 28px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.xd-form-header::before {
  content: '';
  position: absolute;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(132,175,207,.3), transparent 70%);
  top: -100px; right: -80px;
}
.xd-form-thumb {
  width: 80px; height: 80px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 16px;
  border: 3px solid rgba(255,255,255,.2);
}
.xd-form-thumb img { width: 100%; height: 100%; object-fit: cover; }
.xd-form-title {
  font-family: var(--xd-font-serif);
  font-size: 1.6rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 10px;
  line-height: 1.2;
  position: relative;
}
.xd-form-desc {
  color: rgba(245,242,235,.82);
  font-size: .92rem;
  margin: 0;
  max-width: 380px;
  margin-inline: auto;
  position: relative;
}

/* ── Steps ────────────────────────────────────────────────── */
.xd-form { padding: 0; }
.xd-step {
  padding: 28px 32px;
  border-bottom: 1px solid rgba(22,37,58,.07);
}
.xd-step:last-child { border-bottom: none; }
.xd-step__title {
  font-family: var(--xd-font-serif);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--xd-navy);
  margin: 0 0 20px;
}

/* ── Amount levels ────────────────────────────────────────── */
/* Frequency toggle — pill group matching the FIRST-Network nav style */
.xd-frequency {
  display: inline-flex;
  background: var(--xd-ivory-warm);
  border: 2px solid rgba(22,37,58,.12);
  border-radius: 100px;
  padding: 4px;
  gap: 4px;
  margin-bottom: 16px;
}
.xd-freq-btn {
  border: none;
  background: transparent;
  font-family: var(--xd-font-sans);
  font-size: .85rem;
  font-weight: 700;
  color: var(--xd-muted);
  padding: 9px 20px;
  border-radius: 100px;
  cursor: pointer;
  transition: background var(--xd-transition), color var(--xd-transition);
}
.xd-freq-btn:hover { color: var(--xd-navy); }
.xd-freq-btn.is-selected { background: var(--xd-navy); color: var(--xd-ivory); }
.xd-freq-note { font-size: .78rem; color: var(--xd-muted); margin: -6px 0 14px; }

.xd-levels {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.xd-level-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 14px 10px;
  border-radius: var(--xd-r-md);
  border: 2px solid rgba(22,37,58,.12);
  background: var(--xd-ivory-warm);
  cursor: pointer;
  transition: border-color var(--xd-transition), background var(--xd-transition), transform var(--xd-transition);
  font-family: var(--xd-font-sans);
}
.xd-level-btn:hover { border-color: var(--xd-gold); background: rgba(210,166,74,.06); transform: translateY(-2px); }
.xd-level-btn.is-selected {
  border-color: var(--xd-gold);
  background: rgba(210,166,74,.12);
  box-shadow: 0 0 0 3px rgba(210,166,74,.25);
}
.xd-level-amt {
  font-family: var(--xd-font-serif);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--xd-navy);
  line-height: 1;
}
.xd-level-lbl { font-size: .68rem; font-weight: 600; color: var(--xd-muted); letter-spacing: .5px; text-align: center; }
.xd-level-btn--custom .xd-level-amt { font-family: var(--xd-font-sans); font-size: .9rem; font-weight: 700; }

/* Custom amount input */
.xd-custom-amount { margin-top: 14px; }
.xd-input-wrap--currency {
  position: relative;
  display: flex;
  align-items: center;
}
.xd-currency-symbol {
  position: absolute;
  left: 16px;
  font-family: var(--xd-font-sans);
  font-size: .95rem;
  font-weight: 700;
  color: var(--xd-muted);
  pointer-events: none;
}
/* The custom amount input must match .xd-input — and never show the
   browser's native number spinners or default square border */
.xd-input-wrap--currency input {
  display: block;
  width: 100%;
  padding: 13px 16px 13px 36px;
  border: 2px solid rgba(22,37,58,.12);
  border-radius: var(--xd-r-sm);
  background: var(--xd-ivory-warm);
  font-family: var(--xd-font-sans);
  font-size: .95rem;
  font-weight: 600;
  color: var(--xd-charcoal);
  box-sizing: border-box;
  transition: border-color var(--xd-transition), box-shadow var(--xd-transition);
  -moz-appearance: textfield;
  appearance: textfield;
}
.xd-input-wrap--currency input::-webkit-outer-spin-button,
.xd-input-wrap--currency input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.xd-input-wrap--currency input:focus {
  outline: none;
  border-color: var(--xd-gold);
  box-shadow: 0 0 0 3px rgba(210,166,74,.2);
}

/* Currency symbol inside large serif amounts: small superscript in the sans
   face — the serif $ glyph looks dated at display sizes */
.xd-cur {
  font-family: var(--xd-font-sans);
  font-weight: 700;
  font-size: .62em;
  line-height: 1;
  position: relative;
  top: -.38em;
  margin-right: 1px;
  letter-spacing: 0;
}

/* ── Inputs ───────────────────────────────────────────────── */
.xd-label {
  display: block;
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .4px;
  color: var(--xd-navy);
  margin-bottom: 6px;
  text-transform: uppercase;
}
.xd-req { color: #e53e3e; }
.xd-input {
  display: block;
  width: 100%;
  padding: 13px 16px;
  border: 2px solid rgba(22,37,58,.12);
  border-radius: var(--xd-r-sm);
  background: var(--xd-ivory-warm);
  font-family: var(--xd-font-sans);
  font-size: .95rem;
  color: var(--xd-charcoal);
  transition: border-color var(--xd-transition), box-shadow var(--xd-transition);
  box-sizing: border-box;
}
.xd-input:focus {
  outline: none;
  border-color: var(--xd-gold);
  box-shadow: 0 0 0 3px rgba(210,166,74,.2);
}
.xd-input.is-error { border-color: #e53e3e; box-shadow: 0 0 0 3px rgba(229,62,62,.15); }
.xd-textarea { resize: vertical; min-height: 80px; }
.xd-field { margin-bottom: 16px; }
.xd-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.xd-field--sm { flex-basis: 120px; }
.xd-field--check { margin-top: 4px; }
.xd-field--check label { display: flex; align-items: flex-start; gap: 10px; font-size: .88rem; cursor: pointer; line-height: 1.5; }
.xd-field--check input[type="checkbox"] { margin: 1px 0 0; flex-shrink: 0; width: 16px; height: 16px; accent-color: var(--xd-gold); cursor: pointer; }
/* Fee + consent rows: separated card-like band inside the payment step */
.xd-fee-recovery, .xd-consent {
  margin-top: 16px;
  padding: 14px 16px;
  background: var(--xd-ivory-warm);
  border: 1px solid rgba(22,37,58,.08);
  border-radius: var(--xd-r-sm);
}
.xd-fee-recovery .xd-fee-amount { color: var(--xd-gold-dark); }

/* Address toggle */
.xd-address-toggle { border: none; }
.xd-address-toggle summary { cursor: pointer; font-size: .85rem; font-weight: 600; color: var(--xd-carolina); margin-bottom: 14px; user-select: none; }
.xd-address-toggle summary:hover { color: var(--xd-gold); }
.xd-address-fields { padding-top: 4px; }

/* ── Gateway tabs ─────────────────────────────────────────── */
.xd-gateway-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.xd-gateway-tab {
  padding: 10px 20px;
  border-radius: var(--xd-r-pill);
  border: 2px solid rgba(22,37,58,.14);
  background: transparent;
  font-family: var(--xd-font-sans);
  font-size: .84rem;
  font-weight: 700;
  cursor: pointer;
  color: var(--xd-charcoal);
  transition: all var(--xd-transition);
}
.xd-gateway-tab:hover { border-color: var(--xd-carolina); color: var(--xd-navy); }
.xd-gateway-tab.is-disabled { opacity: .4; cursor: not-allowed; pointer-events: none; }
.xd-gateway-tab.is-active { background: var(--xd-navy); color: var(--xd-ivory); border-color: var(--xd-navy); }
.xd-gateway-panel { display: none; }
.xd-gateway-panel.is-active { display: block; }

/* Stripe element */
.xd-stripe-element {
  padding: 14px 16px;
  border: 2px solid rgba(22,37,58,.12);
  border-radius: var(--xd-r-sm);
  background: var(--xd-ivory-warm);
  min-height: 46px;
  transition: border-color var(--xd-transition);
}
.xd-stripe-element.StripeElement--focus { border-color: var(--xd-gold); box-shadow: 0 0 0 3px rgba(210,166,74,.2); }
.xd-stripe-errors { color: #e53e3e; font-size: .84rem; margin-top: 8px; }
/* Square injects its own iframe card field — container needs no inner padding */
.xd-square-card-element {
  border: 2px solid rgba(22,37,58,.12);
  border-radius: var(--xd-r-sm);
  background: var(--xd-ivory-warm);
  padding: 6px 10px;
  min-height: 46px;
  transition: border-color var(--xd-transition);
}
.xd-square-card-element:focus-within { border-color: var(--xd-gold); box-shadow: 0 0 0 3px rgba(210,166,74,.2); }
.xd-test-badge {
  display: inline-block;
  background: rgba(210,166,74,.15);
  color: var(--xd-gold-dark);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: var(--xd-r-pill);
  margin-bottom: 14px;
}

/* PayPal info */
.xd-paypal-info {
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(0,156,222,.06);
  border: 1px solid rgba(0,156,222,.2);
  border-radius: var(--xd-r-sm);
  padding: 16px;
}
.xd-paypal-icon { width: 40px; height: 40px; flex-shrink: 0; }
.xd-paypal-info p { font-size: .88rem; margin: 0; color: var(--xd-charcoal); }

/* Offline instructions */
.xd-offline-instructions {
  background: var(--xd-ivory-warm);
  border-left: 3px solid var(--xd-carolina);
  padding: 14px 18px;
  border-radius: 0 var(--xd-r-sm) var(--xd-r-sm) 0;
  font-size: .9rem;
  margin: 0;
}

/* ── Submit ───────────────────────────────────────────────── */
.xd-submit-wrap { padding: 24px 32px 32px; }
.xd-submit-btn {
  width: 100%;
  font-size: 1.05rem;
  padding: 18px 30px;
  position: relative;
}
.xd-btn-amount { opacity: .8; }
.xd-spinner {
  display: inline-block;
  width: 16px; height: 16px;
  border: 2px solid rgba(22,37,58,.2);
  border-top-color: var(--xd-navy-deep);
  border-radius: 50%;
  animation: xd-spin .7s linear infinite;
  vertical-align: middle;
}
@keyframes xd-spin { to { transform: rotate(360deg); } }
.xd-secure-note {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: .78rem;
  color: var(--xd-muted);
  margin: 12px 0 0;
}
.xd-secure-note svg { width: 13px; height: 13px; flex-shrink: 0; }

/* ── Errors ───────────────────────────────────────────────── */
.xd-errors {
  margin: 0 32px 16px;
  background: #fff5f5;
  border: 1px solid #fed7d7;
  border-radius: var(--xd-r-sm);
  padding: 14px 18px;
}
.xd-error-item { color: #c53030; font-size: .88rem; margin: 4px 0; }
.xd-notice {
  background: var(--xd-ivory-warm);
  border: 1px solid rgba(22,37,58,.12);
  border-radius: var(--xd-r-sm);
  padding: 12px 16px;
  font-size: .9rem;
}
.xd-notice--warning { background: #fffbeb; border-color: #f6e05e; color: #744210; }
.xd-notice--error   { background: #fff5f5; border-color: #fed7d7; color: #c53030; }

/* ── Goal widget ──────────────────────────────────────────── */
.xd-goal {
  margin: 0 32px 20px;
  background: rgba(132,175,207,.08);
  border-radius: var(--xd-r-sm);
  padding: 16px 20px;
}
.xd-goal__header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; flex-wrap: wrap; gap: 4px; }
.xd-goal__raised { font-family: var(--xd-font-serif); font-size: 1.3rem; font-weight: 700; color: var(--xd-navy); }
.xd-goal__target { font-size: .84rem; color: var(--xd-muted); }
.xd-goal__bar { background: rgba(22,37,58,.1); border-radius: 100px; height: 10px; overflow: hidden; }
.xd-goal__fill { height: 100%; border-radius: 100px; background: linear-gradient(90deg, var(--xd-carolina), var(--xd-gold)); transition: width 1.2s cubic-bezier(.2,.8,.2,1); }
.xd-goal__footer { display: flex; justify-content: space-between; font-size: .78rem; color: var(--xd-muted); font-weight: 600; margin-top: 8px; }

/* standalone goal shortcode */
.xd-goal-widget {
  background: var(--xd-white);
  border-radius: var(--xd-r-lg);
  padding: 24px;
  box-shadow: var(--xd-shadow);
}
.xd-goal-widget .xd-goal-bar { background: rgba(22,37,58,.1); border-radius: 100px; height: 12px; overflow: hidden; }
.xd-goal-widget .xd-goal-fill { height: 100%; border-radius: 100px; background: linear-gradient(90deg, var(--xd-carolina), var(--xd-gold)); transition: width 1.2s ease; }
.xd-goal-widget .xd-goal-header { display: flex; justify-content: space-between; margin-bottom: 10px; }
.xd-goal-widget .xd-goal-raised { font-family: var(--xd-font-serif); font-size: 1.5rem; font-weight: 700; color: var(--xd-navy); }
.xd-goal-widget .xd-goal-label { font-size: .88rem; color: var(--xd-muted); }
.xd-goal-widget .xd-goal-footer { display: flex; justify-content: space-between; font-size: .8rem; color: var(--xd-muted); margin-top: 8px; }

/* ── Donors wall ──────────────────────────────────────────── */
.xd-recent-donors { padding: 20px 32px 28px; border-top: 1px solid rgba(22,37,58,.07); }
.xd-recent-donors h4 { font-family: var(--xd-font-serif); font-size: .95rem; color: var(--xd-navy); margin: 0 0 14px; }
.xd-donors-wall { display: flex; flex-wrap: wrap; gap: 10px; }
.xd-donor-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--xd-ivory-warm);
  border: 1px solid rgba(22,37,58,.09);
  border-radius: var(--xd-r-pill);
  padding: 8px 14px 8px 8px;
  font-size: .82rem;
}
.xd-donor-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--xd-carolina);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: .72rem;
  flex-shrink: 0;
}
.xd-donor-chip strong { display: block; font-weight: 700; color: var(--xd-navy); }
.xd-donor-chip span { color: var(--xd-muted); font-size: .78rem; }

/* ── Receipt ──────────────────────────────────────────────── */
.xd-receipt {
  max-width: 540px;
  margin: 0 auto;
  padding: 48px 24px;
  text-align: center;
}
.xd-receipt__icon {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: rgba(132,175,207,.15);
  border: 2px solid var(--xd-carolina);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
}
.xd-receipt__icon svg { width: 36px; height: 36px; stroke: var(--xd-carolina); }
.xd-receipt__title { font-family: var(--xd-font-serif); font-size: 2rem; color: var(--xd-navy); margin: 0 0 8px; }
.xd-receipt__subtitle { color: var(--xd-muted); margin: 0 0 24px; }
.xd-receipt__amount { font-family: var(--xd-font-serif); font-size: 2.8rem; font-weight: 700; color: var(--xd-navy); margin: 0 0 28px; }
.xd-receipt__details {
  background: var(--xd-white);
  border: 1px solid rgba(22,37,58,.1);
  border-radius: var(--xd-r-lg);
  padding: 6px 0;
  margin-bottom: 28px;
  text-align: left;
  box-shadow: var(--xd-shadow);
}
.xd-receipt__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 24px;
  border-bottom: 1px solid rgba(22,37,58,.06);
  font-size: .9rem;
}
.xd-receipt__row:last-child { border: none; }
.xd-receipt__row span:first-child { color: var(--xd-muted); font-weight: 600; }
.xd-receipt__row strong, .xd-receipt__row small { color: var(--xd-charcoal); }
.xd-receipt__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 20px; }
.xd-receipt__email-note { font-size: .82rem; color: var(--xd-muted); }

/* ── Badges ───────────────────────────────────────────────── */
.xd-badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: var(--xd-r-pill);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .8px;
  text-transform: uppercase;
}
.xd-badge--complete   { background: #d4edda; color: #155724; }
.xd-badge--pending    { background: #fff3cd; color: #856404; }
.xd-badge--processing { background: rgba(132,175,207,.2); color: #2c5282; }
.xd-badge--failed     { background: #fff5f5; color: #c53030; }
.xd-badge--refunded   { background: #e8ecef; color: #495057; }
.xd-badge--cancelled  { background: #f0f0f0; color: #6c757d; }

/* ── Donor Dashboard ──────────────────────────────────────── */
.xd-dashboard { max-width: 720px; margin: 0 auto; }
.xd-dashboard__header {
  display: flex;
  align-items: center;
  gap: 20px;
  background: var(--xd-navy);
  border-radius: var(--xd-r-lg);
  padding: 28px 32px;
  margin-bottom: 24px;
  color: var(--xd-ivory);
}
.xd-dashboard__avatar {
  width: 60px; height: 60px;
  border-radius: 50%;
  background: var(--xd-gold);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--xd-font-serif);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--xd-navy-deep);
  flex-shrink: 0;
}
.xd-dashboard__info h2 { font-family: var(--xd-font-serif); font-size: 1.4rem; color: #fff; margin: 0 0 4px; }
.xd-dashboard__info p { color: rgba(245,242,235,.7); font-size: .88rem; margin: 0; }
.xd-dashboard__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}
.xd-dashboard__stat {
  background: var(--xd-white);
  border-radius: var(--xd-r-md);
  padding: 20px;
  text-align: center;
  box-shadow: var(--xd-shadow);
}
.xd-dashboard__stat-value { font-family: var(--xd-font-serif); font-size: 1.6rem; font-weight: 700; color: var(--xd-navy); }
.xd-dashboard__stat-label { font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--xd-muted); margin-top: 4px; }
.xd-dashboard__section { background: var(--xd-white); border-radius: var(--xd-r-lg); padding: 28px; box-shadow: var(--xd-shadow); }
.xd-dashboard__section h3 { font-family: var(--xd-font-serif); font-size: 1.2rem; color: var(--xd-navy); margin: 0 0 20px; }

.xd-donation-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(22,37,58,.07);
}
.xd-donation-row:last-child { border: none; }
.xd-donation-row__icon {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: rgba(210,166,74,.12);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.xd-donation-row__icon svg { width: 18px; height: 18px; stroke: var(--xd-gold-dark); }
.xd-donation-row__icon--recurring svg { stroke: var(--xd-carolina); }
.xd-link--danger { color: #9c3838; background: none; border: none; cursor: pointer; font-family: var(--xd-font-sans); font-size: .85rem; font-weight: 700; }
.xd-link--danger:hover { text-decoration: underline; }
.xd-link--danger:disabled { opacity: .5; cursor: wait; }
.xd-donation-row__main { flex: 1; }
.xd-donation-row__main strong { font-size: 1rem; color: var(--xd-navy); }
.xd-donation-row__meta { display: flex; align-items: center; gap: 8px; flex-shrink: 0; font-size: .82rem; }
.xd-muted { color: var(--xd-muted); font-size: .85rem; }

/* Login prompt */
.xd-login-prompt {
  background: var(--xd-ivory-warm);
  border-radius: var(--xd-r-lg);
  padding: 40px;
  text-align: center;
  border: 1px solid rgba(22,37,58,.1);
}
.xd-login-prompt p { margin: 0 0 20px; color: var(--xd-charcoal); }

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 560px) {
  .xd-form-header { padding: 28px 20px 22px; }
  .xd-step { padding: 22px 20px; }
  .xd-submit-wrap { padding: 18px 20px 24px; }
  .xd-errors { margin: 0 20px 14px; }
  .xd-field-row { grid-template-columns: 1fr; }
  .xd-levels { grid-template-columns: repeat(2,1fr); }
  .xd-dashboard__stats { grid-template-columns: 1fr; }
  .xd-dashboard__header { flex-direction: column; text-align: center; }
  .xd-receipt { padding: 32px 16px; }
}

/* ============================================================
   Modern polish layer (v1.8) — micro-interactions & depth
   Additive only; later cascade refines the verified base.
   ============================================================ */

/* Card: softer depth + hairline ring + gentle entrance */
.xd-form-wrap {
  border: 1px solid rgba(22,37,58,.06);
  box-shadow: 0 1px 2px rgba(16,29,46,.04), 0 12px 28px -16px rgba(16,29,46,.22), 0 32px 64px -40px rgba(16,29,46,.30);
  animation: xd-rise .6s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes xd-rise { from { opacity:0; transform: translateY(14px); } to { opacity:1; transform:none; } }

/* Header: layered gradient + drifting aurora glow */
.xd-form-header {
  background: linear-gradient(150deg, var(--xd-navy-deep) 0%, var(--xd-navy) 55%, #27425f 100%);
}
.xd-form-header::after {
  content: '';
  position: absolute;
  inset: -40% -10% auto -10%;
  height: 220px;
  background: radial-gradient(60% 80% at 30% 0%, rgba(132,175,207,.28), transparent 70%);
  animation: xd-drift 9s ease-in-out infinite alternate;
  pointer-events: none;
}
@keyframes xd-drift { from { transform: translateX(-6%) } to { transform: translateX(8%) } }

/* Amount levels: lift + ring on hover, pop on select */
.xd-level-btn {
  transition: transform var(--xd-transition), border-color var(--xd-transition), box-shadow var(--xd-transition), background var(--xd-transition);
  will-change: transform;
}
.xd-level-btn:hover { transform: translateY(-3px); box-shadow: 0 10px 22px -12px rgba(16,29,46,.35); }
.xd-level-btn:active { transform: translateY(-1px) scale(.98); }
.xd-level-btn.is-selected {
  box-shadow: 0 0 0 3px var(--xd-gold-soft), 0 12px 24px -14px rgba(210,166,74,.7);
  transform: translateY(-2px);
}

/* Frequency pills: spring feel */
.xd-freq-btn { transition: background var(--xd-transition), color var(--xd-transition), transform var(--xd-transition); }
.xd-freq-btn.is-selected { box-shadow: 0 6px 16px -8px rgba(16,29,46,.5); }

/* Inputs: smoother focus halo */
.xd-input, .xd-input-wrap--currency input {
  transition: border-color var(--xd-transition), box-shadow var(--xd-transition), background var(--xd-transition);
}
.xd-input:hover { border-color: rgba(22,37,58,.22); }

/* Goal bar: rounded track, gradient fill + moving shimmer */
.xd-goal { background: linear-gradient(180deg, rgba(132,175,207,.10), rgba(132,175,207,.04)); }
.xd-goal__bar, .xd-goal-widget .xd-goal-bar { height: 12px; box-shadow: inset 0 1px 2px rgba(16,29,46,.12); }
.xd-goal__fill, .xd-goal-fill {
  background: linear-gradient(90deg, var(--xd-carolina), var(--xd-gold) 85%);
  position: relative;
  overflow: hidden;
}
.xd-goal__fill::after, .xd-goal-fill::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(100deg, transparent 30%, rgba(255,255,255,.55) 50%, transparent 70%);
  transform: translateX(-100%);
  animation: xd-shimmer 2.6s ease-in-out infinite;
}
@keyframes xd-shimmer { 0% { transform: translateX(-100%) } 60%,100% { transform: translateX(100%) } }

/* Submit: gradient, glow, and a shine sweep on hover */
.xd-submit-btn {
  background: linear-gradient(135deg, var(--xd-gold) 0%, #e0b85f 50%, var(--xd-gold) 100%);
  background-size: 200% 100%;
  box-shadow: 0 14px 30px -12px rgba(210,166,74,.65);
  position: relative;
  overflow: hidden;
  transition: transform var(--xd-transition), box-shadow var(--xd-transition), background-position .5s ease;
}
.xd-submit-btn:hover {
  transform: translateY(-2px);
  background-position: 100% 0;
  box-shadow: 0 20px 40px -14px rgba(210,166,74,.8);
}
.xd-submit-btn::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 40%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.5), transparent);
  transform: skewX(-20deg) translateX(-180%);
}
.xd-submit-btn:hover::before { animation: xd-sweep .8s ease; }
@keyframes xd-sweep { to { transform: skewX(-20deg) translateX(320%); } }

/* Receipt card: modern entrance + check pulse */
.xd-receipt { animation: xd-rise .6s cubic-bezier(.2,.8,.2,1) both; }
.xd-receipt__icon, .xd-receipt .xd-check { animation: xd-pop .5s cubic-bezier(.2,1.4,.5,1) both .15s; }
@keyframes xd-pop { from { opacity:0; transform: scale(.6) } to { opacity:1; transform: scale(1) } }

/* Dashboard rows: hover lift */
.xd-donation-row { transition: transform var(--xd-transition), box-shadow var(--xd-transition), background var(--xd-transition); }
.xd-donation-row:hover { transform: translateX(2px); box-shadow: -3px 0 0 0 var(--xd-gold); }

/* Donor wall chips: hover lift */
.xd-donor-chip { transition: transform var(--xd-transition), box-shadow var(--xd-transition); }
.xd-donor-chip:hover { transform: translateY(-3px); box-shadow: var(--xd-shadow); }

/* Respect reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .xd-form-wrap, .xd-receipt, .xd-receipt__icon,
  .xd-form-header::after, .xd-goal__fill::after, .xd-goal-fill::after,
  .xd-submit-btn::before { animation: none !important; }
  .xd-level-btn, .xd-submit-btn, .xd-donation-row, .xd-donor-chip { transition: none; }
}
