/* ============================================================
   apply.css — Participant application wizard + status view
   ============================================================ */

.apply-shell { padding: clamp(6rem, 12vh, 8rem) 0 var(--s-5); }
.apply-shell .container { max-width: 820px; }

/* ---------- Sign-in gate ---------- */
.apply-gate {
  background: var(--c-paper);
  border-radius: var(--radius-lg);
  padding: var(--s-5) var(--s-4);
  text-align: center;
  box-shadow: var(--shadow-soft);
  margin-top: var(--s-3);
}
.apply-gate h2 {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100;
  max-width: 22ch;
  margin-inline: auto;
}
.apply-gate p { color: var(--c-text-2); max-width: 44ch; margin: var(--s-2) auto var(--s-3); }
.apply-gate .btn { margin-top: var(--s-2); }

/* ---------- Stepper ---------- */
.stepper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-2);
  margin: var(--s-3) 0 var(--s-4);
}
.stepper__step {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.8em 1em;
  border-radius: var(--radius-md);
  background: var(--c-paper);
  box-shadow: var(--shadow-soft);
  font-family: var(--f-body);
  font-size: var(--type-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--c-text-mute);
  position: relative;
  transition: color var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}
.stepper__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  font-family: var(--f-display);
  font-size: 0.9rem;
  font-weight: 500;
  background: var(--c-limestone-2);
  color: var(--c-text-mute);
  flex-shrink: 0;
  transition: background var(--dur-base) var(--ease-out),
              color var(--dur-base) var(--ease-out);
}
.stepper__step.is-active {
  color: var(--c-espresso);
  box-shadow: inset 0 0 0 1.5px var(--c-terracotta), var(--shadow-soft);
}
.stepper__step.is-active .stepper__num {
  background: var(--c-terracotta);
  color: var(--c-paper);
}
.stepper__step.is-done .stepper__num {
  background: var(--c-turquoise);
  color: var(--c-paper);
}
.stepper__step.is-done .stepper__num::before {
  content: "✓";
}
.stepper__step.is-done .stepper__num span { display: none; }
@media (max-width: 700px) {
  .stepper { grid-template-columns: repeat(3, 1fr); }
  .stepper__step { font-size: 0.65rem; padding: 0.55em 0.6em; gap: 0.4em; }
  .stepper__num { width: 24px; height: 24px; font-size: 0.8rem; }
  .stepper__step-label { display: none; }
  .stepper__step.is-active .stepper__step-label { display: inline; }
}

/* ---------- Form panel ---------- */
.apply-form {
  background: var(--c-paper);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 4vw, 2.5rem);
  box-shadow: var(--shadow-soft);
}

.step-panel { display: none; }
.step-panel.is-active {
  display: block;
  animation: stepIn 320ms var(--ease-out) both;
}
@keyframes stepIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}

.step-panel__eyebrow {
  font-family: var(--f-body);
  font-size: var(--type-xs);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-terracotta);
  margin: 0 0 var(--s-1);
}
.step-panel__title {
  font-family: var(--f-display);
  font-style: italic;
  font-size: clamp(1.75rem, 3.4vw, 2.5rem);
  font-weight: 480;
  font-variation-settings: "opsz" 144, "SOFT" 100;
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--c-espresso);
  margin: 0 0 var(--s-1);
  max-width: 22ch;
}
.step-panel__lede {
  color: var(--c-text-2);
  margin: 0 0 var(--s-3);
  max-width: 54ch;
  font-size: var(--type-sm);
}

/* ---------- Fields ---------- */
.field { display: flex; flex-direction: column; gap: 0.4em; margin-bottom: var(--s-2); }
.field__label {
  font-family: var(--f-body);
  font-size: var(--type-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-text-mute);
}
.field__hint {
  font-size: var(--type-xs);
  color: var(--c-text-mute);
  margin-top: 0.25em;
}
.field__error {
  font-size: var(--type-xs);
  color: var(--c-bougainvillea);
  font-weight: 600;
  margin-top: 0.25em;
  display: none;
}
.field.is-invalid .field__error { display: block; }
.field.is-invalid input,
.field.is-invalid select,
.field.is-invalid textarea {
  border-color: var(--c-bougainvillea);
}

.field input[type="text"],
.field input[type="email"],
.field input[type="number"],
.field select,
.field textarea {
  font-family: var(--f-body);
  font-size: var(--type-base);
  padding: 0.85em 1em;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--c-rule);
  background: var(--c-paper-2);
  color: var(--c-espresso);
  width: 100%;
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: 0;
  border-color: var(--c-terracotta);
  box-shadow: 0 0 0 4px rgba(242, 100, 48, 0.14);
}
.field textarea { min-height: 140px; resize: vertical; font-family: inherit; line-height: 1.55; }
.field__counter {
  font-size: var(--type-xs);
  color: var(--c-text-mute);
  text-align: right;
  font-feature-settings: "tnum";
}

/* ---------- Two-column row ---------- */
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-2);
}
@media (max-width: 600px) { .field-row { grid-template-columns: 1fr; } }

/* ---------- Radio cards (country) ---------- */
.radio-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-1);
}
@media (max-width: 600px) { .radio-cards { grid-template-columns: 1fr; } }
.radio-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.2em;
  padding: 0.85em 1em;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--c-rule);
  background: var(--c-paper-2);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.radio-card input {
  position: absolute;
  opacity: 0;
  inset: 0;
  cursor: pointer;
}
.radio-card:hover { border-color: var(--c-terracotta-lt); transform: translateY(-1px); }
.radio-card:has(input:checked) {
  border-color: var(--c-terracotta);
  background: rgba(242, 100, 48, 0.08);
  box-shadow: 0 4px 12px rgba(242, 100, 48, 0.10);
}
.radio-card__flag {
  font-family: var(--f-display);
  font-style: italic;
  font-size: var(--type-md);
  font-variation-settings: "opsz" 36, "SOFT" 100;
  color: var(--c-terracotta);
}
.radio-card__name {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: var(--type-lg);
  color: var(--c-espresso);
  line-height: 1;
}
.radio-card__sub {
  font-size: var(--type-xs);
  color: var(--c-text-mute);
  letter-spacing: 0.04em;
}

/* ---------- Checkbox grid ---------- */
.check-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5em;
}
@media (max-width: 600px) { .check-grid { grid-template-columns: 1fr; } }

.check-pill {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.55em;
  padding: 0.7em 0.95em;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--c-rule);
  background: var(--c-paper-2);
  cursor: pointer;
  font-family: var(--f-body);
  font-size: var(--type-sm);
  color: var(--c-espresso);
  transition: border-color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.check-pill input {
  appearance: none;
  -webkit-appearance: none;
  width: 18px; height: 18px;
  border: 1.5px solid var(--c-rule);
  border-radius: 4px;
  background: var(--c-paper-2);
  cursor: pointer;
  flex-shrink: 0;
  display: inline-grid;
  place-items: center;
  transition: border-color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.check-pill input:checked {
  background: var(--c-terracotta);
  border-color: var(--c-terracotta);
}
.check-pill input:checked::before {
  content: "";
  width: 5px; height: 9px;
  border: solid var(--c-paper);
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  margin-bottom: 2px;
}
.check-pill:hover { border-color: var(--c-terracotta-lt); }
.check-pill:has(input:checked) {
  border-color: var(--c-terracotta);
  background: rgba(242, 100, 48, 0.08);
}

/* ---------- Inline checkbox (single yes/no) ---------- */
.check-inline {
  display: flex;
  align-items: flex-start;
  gap: 0.65em;
  padding: var(--s-2);
  border-radius: var(--radius-md);
  background: var(--c-limestone-2);
  cursor: pointer;
}
.check-inline input {
  appearance: none;
  -webkit-appearance: none;
  width: 20px; height: 20px;
  flex-shrink: 0;
  margin-top: 0.15em;
  border: 1.5px solid var(--c-rule);
  border-radius: 4px;
  background: var(--c-paper-2);
  cursor: pointer;
  display: inline-grid;
  place-items: center;
}
.check-inline input:checked {
  background: var(--c-terracotta);
  border-color: var(--c-terracotta);
}
.check-inline input:checked::before {
  content: "";
  width: 5px; height: 10px;
  border: solid var(--c-paper);
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  margin-bottom: 2px;
}
.check-inline__text {
  font-size: var(--type-sm);
  line-height: 1.45;
  color: var(--c-text-2);
}
.check-inline__text strong { color: var(--c-espresso); }

/* ---------- Step controls ---------- */
.step-controls {
  display: flex;
  justify-content: space-between;
  gap: var(--s-2);
  margin-top: var(--s-3);
  padding-top: var(--s-2);
  border-top: 1px solid var(--c-rule);
}
.step-controls .btn { flex: 0 0 auto; }
.step-controls__spacer { flex: 1; }

/* ---------- Status view (after submit) ---------- */
.status-card {
  background: var(--c-paper);
  border-radius: var(--radius-lg);
  padding: clamp(1.75rem, 4vw, 2.5rem);
  box-shadow: var(--shadow-soft);
  margin-top: var(--s-3);
  position: relative;
  overflow: hidden;
}
.status-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(242, 100, 48, 0.08), transparent 60%);
  pointer-events: none;
}
.status-card > * { position: relative; z-index: 1; }

.status-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.4em 0.95em;
  border-radius: var(--radius-pill);
  font-family: var(--f-body);
  font-size: var(--type-xs);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--c-honey);
  color: var(--c-espresso);
  margin-bottom: var(--s-2);
}
.status-card__badge::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
}
.status-card[data-status="pending"]   .status-card__badge { background: var(--c-honey); color: var(--c-espresso); }
.status-card[data-status="approved"]  .status-card__badge { background: var(--c-turquoise); color: var(--c-paper); }
.status-card[data-status="waitlisted"].status-card__badge,
.status-card[data-status="waitlisted"] .status-card__badge { background: var(--c-honey-dk); color: var(--c-paper); }
.status-card[data-status="rejected"]  .status-card__badge { background: var(--c-bougainvillea); color: var(--c-paper); }

.status-card h2 {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100;
  max-width: 22ch;
  margin: 0 0 var(--s-1);
}
.status-card p { color: var(--c-text-2); max-width: 56ch; }

.status-summary {
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px solid var(--c-rule);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-2) var(--s-3);
}
@media (max-width: 600px) { .status-summary { grid-template-columns: 1fr; } }
.status-summary dt {
  font-family: var(--f-body);
  font-size: var(--type-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-text-mute);
  margin-bottom: 0.2em;
}
.status-summary dd {
  margin: 0 0 var(--s-2);
  font-size: var(--type-sm);
  color: var(--c-espresso);
  word-break: break-word;
}

.status-review {
  margin-top: var(--s-3);
  padding: var(--s-2);
  border-radius: var(--radius-md);
  background: var(--c-limestone-2);
  border-left: 4px solid var(--c-turquoise);
}
.status-review__label {
  font-family: var(--f-body);
  font-size: var(--type-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-text-mute);
  margin-bottom: 0.3em;
}
.status-review__body {
  font-family: var(--f-display);
  font-style: italic;
  font-variation-settings: "opsz" 36, "SOFT" 100;
  font-size: var(--type-md);
  color: var(--c-espresso);
}

/* ---------- Submit success animation ---------- */
.submit-message {
  margin-top: var(--s-2);
  padding: 0.85em 1em;
  border-radius: var(--radius-md);
  font-size: var(--type-sm);
  font-weight: 500;
  display: none;
}
.submit-message[data-type="error"] {
  background: rgba(236, 72, 153, 0.12);
  color: #B91C5C;
  border: 1px solid rgba(236, 72, 153, 0.30);
  display: block;
}
.submit-message[data-type="info"] {
  background: rgba(91, 44, 156, 0.08);
  color: var(--c-turquoise-dk);
  display: block;
}
