/* ============================================
   TRAINING REGISTRATION OVERLAY (.treg-*)
   Light theme: alabaster bg, charcoal text,
   gold accents. Vanilla JS multi-step wizard.
   ============================================ */

/* --- Overlay Shell --- */
.treg-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.treg-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(43, 43, 43, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.treg-overlay__panel {
  position: relative;
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--color-alabaster, #f8f6f1);
  padding: var(--space-8, 2rem);
  overscroll-behavior: contain;
}
.treg-overlay__close {
  position: absolute;
  top: var(--space-4, 1rem);
  right: var(--space-4, 1rem);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-text-tertiary, #6b6b6b);
  padding: var(--space-2, 0.5rem);
  transition: color 0.2s ease;
  z-index: 1;
}
.treg-overlay__close:hover { color: var(--color-text-primary, #2b2b2b); }

/* --- Header --- */
.treg-overlay__header {
  margin-bottom: var(--space-4, 1rem);
  padding-right: var(--space-8, 2rem);
}
.treg-overlay__title {
  font-family: var(--font-display, 'Playfair Display', serif);
  font-size: var(--text-xl, 1.5rem);
  font-weight: var(--weight-semibold, 600);
  color: var(--color-text-primary, #2b2b2b);
  line-height: var(--leading-tight, 1.2);
  margin: 0;
}
.treg-overlay__meta {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #4a4a4a);
  margin: var(--space-1, 0.25rem) 0 0;
}
.treg-overlay__price {
  font-family: var(--font-display, 'Playfair Display', serif);
  font-size: var(--text-lg, 1.25rem);
  color: var(--color-text-primary, #2b2b2b);
  font-weight: var(--weight-medium, 500);
}

/* --- Progress Bar --- */
.treg-overlay__progress {
  margin-bottom: var(--space-6, 1.5rem);
}
.treg-overlay__progress-track {
  height: 2px;
  background: var(--color-border-default, #d4d4d4);
  border-radius: 1px;
}
.treg-overlay__progress-fill {
  height: 2px;
  background: var(--color-gold, #D4AF37);
  border-radius: 1px;
  transition: width 0.3s ease;
  width: 0%;
}
.treg-overlay__steps {
  display: flex;
  justify-content: space-between;
  margin-top: var(--space-2, 0.5rem);
}
.treg-overlay__step-label {
  font-size: var(--text-xs, 0.75rem);
  color: var(--color-text-tertiary, #6b6b6b);
  font-weight: var(--weight-regular, 400);
  letter-spacing: var(--tracking-wide, 0.05em);
  text-transform: uppercase;
  transition: color 0.2s ease;
}
.treg-overlay__step-label--active {
  color: var(--color-gold, #D4AF37);
  font-weight: var(--weight-semibold, 600);
}
.treg-overlay__step-label--done {
  color: var(--color-text-primary, #2b2b2b);
}

/* --- Divider --- */
.treg-overlay__divider {
  height: 1px;
  background: var(--color-border-subtle, rgba(43, 43, 43, 0.08));
  margin-bottom: var(--space-6, 1.5rem);
}

/* --- Step Containers --- */
.treg-step__fieldset {
  border: none;
  padding: 0;
  margin: 0;
}
.treg-step__legend {
  font-family: var(--font-display, 'Playfair Display', serif);
  font-size: var(--text-lg, 1.25rem);
  color: var(--color-text-primary, #2b2b2b);
  font-weight: var(--weight-medium, 500);
  margin-bottom: var(--space-2, 0.5rem);
  display: block;
  width: 100%;
}
.treg-step__description {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #4a4a4a);
  margin-bottom: var(--space-6, 1.5rem);
  line-height: var(--leading-normal, 1.6);
}

/* --- Form Controls ---
   Form container + field styles now come from forms-base.css
   (.sarovyn-form / .form-group / .sarovyn-input / .form-row / .field-error).
   Only overlay-specific adjustments live here.
*/
.treg-overlay .sarovyn-form {
  gap: var(--space-3, 0.75rem);
}
.treg-overlay .form-group label {
  font-size: var(--text-xs, 0.75rem);
  color: var(--color-input-label, #4a4a4a);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide, 0.05em);
  font-weight: var(--weight-medium, 500);
}
.treg-overlay .treg-required {
  color: var(--color-burgundy, #800020);
  margin-left: 2px;
}

/* --- Error & Info Messages --- */
.treg-overlay__error {
  background: rgba(128, 0, 32, 0.06);
  border-left: 3px solid var(--color-burgundy, #800020);
  color: var(--color-burgundy, #800020);
  padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
  margin-bottom: var(--space-4, 1rem);
  font-size: var(--text-sm, 0.875rem);
  line-height: var(--leading-normal, 1.6);
}
.treg-overlay__info {
  background: rgba(44, 95, 138, 0.06);
  border-left: 3px solid var(--color-info, #2c5f8a);
  color: var(--color-info, #2c5f8a);
  padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
  margin-bottom: var(--space-4, 1rem);
  font-size: var(--text-sm, 0.875rem);
  display: flex;
  align-items: center;
  gap: var(--space-2, 0.5rem);
}

/* --- Payment Plan Selector --- */
.treg-plan-selector {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 0.75rem);
  margin-bottom: var(--space-6, 1.5rem);
}
.treg-plan-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3, 0.75rem);
  padding: var(--space-4, 1rem);
  border: 1px solid var(--color-border-default, #d4d4d4);
  cursor: pointer;
  transition: border-color 0.2s ease;
  position: relative;
}
.treg-plan-card:hover {
  border-color: var(--color-text-secondary, #4a4a4a);
}
.treg-plan-card--selected {
  border-color: var(--color-gold, #D4AF37);
  background: rgba(212, 175, 55, 0.04);
}
.treg-plan-card input[type="radio"] {
  accent-color: var(--color-gold, #D4AF37);
  width: 18px;
  height: 18px;
  margin-top: 2px;
  flex-shrink: 0;
}
.treg-plan-card__label {
  font-weight: var(--weight-semibold, 600);
  color: var(--color-text-primary, #2b2b2b);
  font-size: var(--text-base, 1rem);
}
.treg-plan-card__desc {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #4a4a4a);
  margin-top: var(--space-1, 0.25rem);
  line-height: var(--leading-normal, 1.6);
}

/* --- Pricing Breakdown --- */
.treg-pricing {
  background: var(--color-surface-secondary, #f8f4e3);
  padding: var(--space-4, 1rem);
  margin-top: var(--space-4, 1rem);
}
.treg-pricing__row {
  display: flex;
  justify-content: space-between;
  padding: var(--space-1, 0.25rem) 0;
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #4a4a4a);
}
.treg-pricing__row--total {
  font-weight: var(--weight-semibold, 600);
  color: var(--color-text-primary, #2b2b2b);
  padding-top: var(--space-2, 0.5rem);
  border-top: 1px solid var(--color-border-default, #d4d4d4);
  margin-top: var(--space-2, 0.5rem);
}
.treg-pricing__row--highlight {
  color: var(--color-gold-dark, #a8891f);
  font-weight: var(--weight-semibold, 600);
}
.treg-pricing__divider {
  height: 1px;
  background: var(--color-border-default, #d4d4d4);
  margin: var(--space-3, 0.75rem) 0;
}
.treg-pricing__note {
  font-size: var(--text-xs, 0.75rem);
  color: var(--color-text-tertiary, #6b6b6b);
  margin-top: var(--space-2, 0.5rem);
  font-style: italic;
}

/* --- Agreement Toggle Switches (default: used by any non-overlay consumer) --- */
.treg-agreement {
  margin-bottom: var(--space-4, 1rem);
}
.treg-agreement--error .treg-toggle__track {
  background: rgba(128, 0, 32, 0.15);
}

/* --- Legal Agreements (scoped to training overlay) ---
   Override the shared toggle-switch rendering: render native checkboxes
   side-by-side on desktop, stacked on mobile. Other consumers of the
   shared legal module (e.g. campaign donations) are not affected.
*/
#treg-agreements-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 0.75rem);
  margin-bottom: var(--space-3, 0.75rem);
}
#treg-agreements-list .treg-agreement {
  flex: 1 1 0;
  min-width: 0;
  margin-bottom: 0;
}
#treg-agreements-list .treg-toggle {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-2, 0.5rem);
}
/* Hide the toggle-switch track — we're showing a native checkbox instead */
#treg-agreements-list .treg-toggle__track {
  display: none;
}
/* Reveal the native checkbox; style to match sitewide form aesthetic */
#treg-agreements-list .treg-toggle__input {
  position: static;
  opacity: 1;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin: 0;
  pointer-events: auto;
  cursor: pointer;
  accent-color: var(--color-gold, #D4AF37);
}
#treg-agreements-list .treg-toggle__input:focus-visible {
  outline: 2px solid var(--color-gold, #D4AF37);
  outline-offset: 2px;
}
#treg-agreements-list .treg-toggle__label {
  font-size: var(--text-sm, 0.875rem);
  line-height: 1.4;
  padding-left: var(--space-2, 0.5rem);
}
#treg-agreements-list .treg-agreement--error {
  color: var(--color-burgundy, #800020);
}

/* Toggle switch pattern removed — use .switch-* from forms-base.css.
   The treg-toggle__* classes below are generated by the SarovynLegal module
   (cssPrefix: 'treg') and overridden in #treg-agreements-list to native
   checkboxes. See docs/forms-stripe-contract.md. */
.treg-toggle__label {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-primary, #2b2b2b);
  line-height: var(--leading-normal, 1.6);
}
.treg-toggle__label a {
  color: var(--color-gold-dark, #a8891f);
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: var(--weight-medium, 500);
}
.treg-toggle__label a:hover {
  color: var(--color-text-primary, #2b2b2b);
}

/* Legacy checkbox label (payment consent) */
.treg-checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3, 0.75rem);
  cursor: pointer;
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-primary, #2b2b2b);
  line-height: var(--leading-normal, 1.6);
}
.treg-checkbox {
  accent-color: var(--color-gold, #D4AF37);
  width: 18px;
  height: 18px;
  margin-top: 2px;
  flex-shrink: 0;
  cursor: pointer;
}

/* --- Payment Step --- */
.treg-payment-summary {
  background: var(--color-surface-secondary, #f8f4e3);
  padding: var(--space-4, 1rem);
  margin-bottom: var(--space-5, 1.25rem);
}
.treg-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: var(--space-1, 0.25rem) 0;
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #4a4a4a);
}
.treg-summary-row + .treg-summary-row {
  border-top: 1px solid var(--color-border-subtle, rgba(43, 43, 43, 0.08));
}
.treg-summary-row__label {
  flex: 1;
  min-width: 0;
}
.treg-summary-row__amount {
  flex-shrink: 0;
  text-align: right;
  padding-left: var(--space-4, 1rem);
  font-variant-numeric: tabular-nums;
}
.treg-summary-row--total {
  font-weight: var(--weight-semibold, 600);
  color: var(--color-text-primary, #2b2b2b);
  padding-top: var(--space-2, 0.5rem);
  border-top: 1px solid var(--color-border-default, #d4d4d4);
  margin-top: var(--space-2, 0.5rem);
}
.treg-stripe-mount {
  min-height: 120px;
}
.treg-stripe-loading {
  text-align: center;
  padding: var(--space-8, 2rem);
  color: var(--color-text-tertiary, #6b6b6b);
  font-size: var(--text-sm, 0.875rem);
}
.treg-secure-note {
  display: flex;
  align-items: center;
  gap: var(--space-2, 0.5rem);
  font-size: var(--text-xs, 0.75rem);
  color: var(--color-text-tertiary, #6b6b6b);
  margin-top: var(--space-4, 1rem);
}

/* --- Navigation Footer ---
   Pay button: full width (via .form-submit--full from forms-base.css).
   Cancel: plain text link with sitewide animated-underline hover.
*/
.treg-overlay__nav {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-5, 1.25rem);
  margin-top: var(--space-5, 1.25rem);
  padding-top: var(--space-4, 1rem);
  border-top: 1px solid var(--color-border-subtle, rgba(43, 43, 43, 0.08));
}

/* Gold submit button now uses .form-submit--gold from forms-base.css.
   See docs/forms-stripe-contract.md. */

/* Cancel: plain text link with sitewide left-to-right animated underline */
.treg-cancel-link {
  align-self: center;
  position: relative;
  background: none;
  border: none;
  padding: var(--space-2, 0.5rem) var(--space-1, 0.25rem);
  margin: 0;
  font-family: var(--font-body, 'Source Sans 3', sans-serif);
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #6b6b6b);
  cursor: pointer;
  transition: color 0.2s ease;
  line-height: 1.4;
}
.treg-cancel-link::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: var(--space-1, 0.25rem);
  right: var(--space-1, 0.25rem);
  width: 0;
  height: 1px;
  background: currentColor;
  transition: width 0.3s ease;
}
.treg-cancel-link:hover:not(:disabled) {
  color: var(--color-text-primary, #2b2b2b);
}
.treg-cancel-link:hover:not(:disabled)::after {
  width: calc(100% - (var(--space-1, 0.25rem) * 2));
}
.treg-cancel-link:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* --- Loading Overlay --- */
.treg-overlay__loading {
  position: absolute;
  inset: 0;
  background: var(--color-alabaster-90);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4, 1rem);
  z-index: 10;
}
.treg-spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--color-border-default, #d4d4d4);
  border-top-color: var(--color-gold, #D4AF37);
  border-radius: 50%;
  animation: tregSpin 0.8s linear infinite;
}
@keyframes tregSpin {
  to { transform: rotate(360deg); }
}
.treg-overlay__loading-text {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #4a4a4a);
}

/* --- Already Registered / Success Overlays --- */
.treg-result {
  text-align: center;
  padding: var(--space-8, 2rem) 0;
}
.treg-result__icon {
  color: var(--color-sage, #77815c);
  margin-bottom: var(--space-4, 1rem);
}
.treg-result__icon--gold {
  color: var(--color-gold, #D4AF37);
}
.treg-result__title {
  font-family: var(--font-display, 'Playfair Display', serif);
  font-size: var(--text-xl, 1.5rem);
  color: var(--color-text-primary, #2b2b2b);
  margin: 0 0 var(--space-2, 0.5rem);
}
.treg-result__text {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary, #4a4a4a);
  margin: 0 0 var(--space-6, 1.5rem);
  line-height: var(--leading-normal, 1.6);
}
.treg-result__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 0.75rem);
  align-items: center;
}

/* --- Helper text --- */
.treg-note {
  font-size: var(--text-xs, 0.75rem);
  color: var(--color-text-tertiary, #6b6b6b);
  margin-top: var(--space-4, 1rem);
  line-height: var(--leading-normal, 1.6);
}

/* --- Stripe Element smooth fade-in --- */
.treg-stripe-element {
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 320ms ease, transform 320ms ease, max-height 320ms ease;
  max-height: 0;
  overflow: hidden;
}
.treg-stripe-element.is-ready {
  opacity: 1;
  transform: translateY(0);
  max-height: 400px;
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .treg-overlay__panel {
    max-width: 100%;
    max-height: 100%;
    height: 100dvh;
    padding: var(--space-4, 1rem);
  }
  .treg-form-row {
    flex-direction: column;
    gap: 0;
  }
  .treg-overlay__steps {
    display: none;
  }
  .treg-overlay__header {
    padding-right: var(--space-10, 2.5rem);
  }
  .treg-form-row,
  .treg-overlay .form-row {
    flex-direction: column;
    gap: 0;
  }
}
@media (max-width: 380px) {
  .treg-overlay__title {
    font-size: var(--text-lg, 1.25rem);
  }
}

/* ============================================
   GIFT MODE EXTENSIONS (.treg-overlay--gift)
   Adds buyer/recipient fieldsets, section
   legends, field hints, and a textarea style
   for the optional gift message. The Stripe
   element + agreements remain unchanged.
   ============================================ */

.treg-overlay__eyebrow {
  font-family: var(--font-body, 'Source Sans 3', sans-serif);
  font-size: var(--text-xs, 0.75rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-gold, #c4a052);
  margin: 0 0 var(--space-1, 0.25rem);
  font-weight: var(--weight-semibold, 600);
}

.treg-section {
  border: none;
  padding: 0;
  margin: 0 0 var(--space-6, 1.5rem);
}

.treg-section + .treg-section {
  padding-top: var(--space-5, 1.25rem);
  border-top: 1px solid var(--color-border-default, #d4d4d4);
}

.treg-section__legend {
  font-family: var(--font-display, 'Playfair Display', serif);
  font-size: var(--text-base, 1rem);
  font-weight: var(--weight-medium, 500);
  color: var(--color-text-primary, #2b2b2b);
  padding: 0;
  margin: 0 0 var(--space-3, 0.75rem);
}

.treg-field-hint {
  font-size: var(--text-xs, 0.75rem);
  color: var(--color-text-tertiary, #6b6b6b);
  margin: var(--space-1, 0.25rem) 0 0;
  line-height: var(--leading-snug, 1.35);
}

.treg-textarea {
  resize: vertical;
  min-height: 4rem;
  font-family: var(--font-body, 'Source Sans 3', sans-serif);
  font-size: var(--text-base, 1rem);
  line-height: var(--leading-normal, 1.5);
}

/* ============================================
   GIFT DARK MODE
   Charcoal panel with alabaster text. Uses
   form-theme-dark CSS variables instead of
   per-selector color overrides.
   See docs/forms-stripe-contract.md.
   ============================================ */
.treg-overlay--gift .treg-overlay__panel {
  background: var(--overlay-bg, #1a1a1a);
  color: var(--color-alabaster, #f8f6f1);

  /* Theme tokens — drive all form controls via forms-base.css variables */
  --form-text: rgba(248, 246, 241, 0.9);
  --form-border: rgba(248, 246, 241, 0.2);
  --form-focus: var(--color-gold, #c4a052);
  --form-placeholder: rgba(248, 246, 241, 0.35);
  --form-placeholder-focus: rgba(248, 246, 241, 0.2);
  --form-hint: rgba(248, 246, 241, 0.5);
  --form-error-bg: rgba(192, 57, 43, 0.15);
  --form-error-border: rgba(192, 57, 43, 0.5);
  --form-error-text: #ff9999;
  --form-switch-off: rgba(248, 246, 241, 0.15);

  /* Overlay-specific tokens (not form controls) */
  --gift-text-primary: var(--color-alabaster, #f8f6f1);
  --gift-text-secondary: rgba(248, 246, 241, 0.7);
  --gift-text-tertiary: rgba(248, 246, 241, 0.5);
  --gift-text-muted: rgba(248, 246, 241, 0.45);
  --gift-border-subtle: rgba(248, 246, 241, 0.12);
  --gift-surface-subtle: rgba(248, 246, 241, 0.06);
}

/* Autofill — must be scoped to the gift modifier, not token-drivable */
.treg-overlay--gift input:-webkit-autofill,
.treg-overlay--gift input:-webkit-autofill:hover,
.treg-overlay--gift input:-webkit-autofill:focus,
.treg-overlay--gift input:-webkit-autofill:active,
.treg-overlay--gift textarea:-webkit-autofill,
.treg-overlay--gift textarea:-webkit-autofill:hover,
.treg-overlay--gift textarea:-webkit-autofill:focus,
.treg-overlay--gift textarea:-webkit-autofill:active,
.treg-overlay--gift select:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px var(--overlay-bg, #1a1a1a) inset !important;
  -webkit-text-fill-color: var(--color-alabaster, #f8f6f1) !important;
  transition: background-color 5000s ease-in-out 0s;
  caret-color: var(--color-alabaster, #f8f6f1);
}
.treg-overlay--gift .form-group select option {
  background: var(--color-charcoal, #2b2b2b);
  color: var(--color-alabaster, #f8f6f1);
}

/* Typography — token-driven */
.treg-overlay--gift .treg-overlay__close { color: var(--gift-text-tertiary); }
.treg-overlay--gift .treg-overlay__close:hover { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-overlay__title { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-overlay__meta { color: rgba(248, 246, 241, 0.6); }
.treg-overlay--gift .treg-overlay__price { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-overlay__divider { background: var(--gift-border-subtle); }
.treg-overlay--gift .treg-section + .treg-section { border-top-color: var(--gift-border-subtle); }
.treg-overlay--gift .treg-section__legend { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-field-hint { color: var(--gift-text-tertiary); }
.treg-overlay--gift .form-group label { color: var(--gift-text-secondary); }
.treg-overlay--gift .treg-required { color: var(--color-gold, #c4a052); }

/* Error messages */
.treg-overlay--gift .treg-overlay__error {
  background: var(--form-error-bg);
  border-left-color: var(--form-error-text);
  color: var(--form-error-text);
}

/* Agreements */
.treg-overlay--gift .treg-toggle__label { color: rgba(248, 246, 241, 0.85); }
.treg-overlay--gift .treg-toggle__label a { color: var(--color-gold, #c4a052); }
.treg-overlay--gift .treg-checkbox-label { color: rgba(248, 246, 241, 0.85); }

/* Nav footer */
.treg-overlay--gift .treg-overlay__nav { border-top-color: var(--gift-border-subtle); }
.treg-overlay--gift .treg-cancel-link { color: var(--gift-text-tertiary); }
.treg-overlay--gift .treg-cancel-link:hover:not(:disabled) { color: var(--gift-text-primary); }

/* Payment summary */
.treg-overlay--gift .treg-payment-summary { background: var(--gift-surface-subtle); }
.treg-overlay--gift .treg-summary-row { color: rgba(248, 246, 241, 0.6); }
.treg-overlay--gift .treg-summary-row--total { color: var(--gift-text-primary); border-top-color: rgba(248, 246, 241, 0.15); }

/* Loading overlay */
.treg-overlay--gift .treg-overlay__loading { background: rgba(26, 26, 26, 0.92); }
.treg-overlay--gift .treg-overlay__loading-text { color: var(--gift-text-secondary); }
.treg-overlay--gift .treg-spinner { border-color: rgba(248, 246, 241, 0.15); border-top-color: var(--color-gold, #c4a052); }

/* Secure note */
.treg-overlay--gift .treg-secure-note { color: var(--gift-text-muted); }

/* Result screens */
.treg-overlay--gift .treg-result__title { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-result__text { color: var(--gift-text-secondary); }

/* Step legend/description */
.treg-overlay--gift .treg-step__legend { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-step__description { color: rgba(248, 246, 241, 0.6); }

/* Note text */
.treg-overlay--gift .treg-note { color: var(--gift-text-muted); }

/* Success / gift-sent screen */
.treg-overlay--gift .treg-success { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-success__title { color: var(--gift-text-primary); }
.treg-overlay--gift .treg-success__text { color: var(--gift-text-secondary); }
.treg-overlay--gift .treg-success__text strong { color: var(--gift-text-primary); }

/* Hint list above purchase button */
.treg-overlay__hints {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-4, 1rem);
}
.treg-overlay__hints li {
  position: relative;
  padding-left: 1.25rem;
  font-size: var(--text-xs, 0.75rem);
  color: rgba(248, 246, 241, 0.5);
  line-height: var(--leading-normal, 1.6);
  margin-bottom: var(--space-2, 0.5rem);
}
.treg-overlay__hints li::before {
  content: '+';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-gold, #c4a052);
  font-weight: var(--weight-semibold, 600);
}

