/* ============================================================================
   CHEMISTRY · NATIVE APPLICATION FORM
   Styled to sit inside .apply-form (dark oxblood card, gold hairlines).
   ============================================================================ */

:root {
  --apply-error: #E58C7A;
  --apply-line: rgba(201, 168, 76, 0.28);
  --apply-line-strong: rgba(201, 168, 76, 0.55);
}

/* ── layout ──────────────────────────────────────────────────────── */
.apply-form__body { text-align: left; }

.apply-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2.2vw, 1.5rem);
}

.apply-field { display: flex; flex-direction: column; gap: 0.5rem; }
.apply-field--full { grid-column: 1 / -1; }

@media (max-width: 560px) {
  .apply-fields { grid-template-columns: 1fr; }
}

/* ── labels ──────────────────────────────────────────────────────── */
.apply-field__label {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--champagne);
}

/* ── text inputs / select ────────────────────────────────────────── */
.apply-input,
.apply-select {
  width: 100%;
  background: rgba(250, 246, 238, 0.04);
  border: 1px solid var(--apply-line);
  border-radius: 4px;
  padding: 0.85rem 1rem;
  color: var(--cream);
  font-family: var(--sans);
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.apply-input::placeholder { color: rgba(250, 246, 238, 0.32); }

.apply-input:focus,
.apply-select:focus {
  outline: none;
  border-color: var(--apply-line-strong);
  box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.14);
  background: rgba(250, 246, 238, 0.06);
}

.apply-select { appearance: none; cursor: pointer; }
.apply-select option { color: var(--ink); }

/* ── gender pills ────────────────────────────────────────────────── */
.apply-radios { display: flex; flex-wrap: wrap; gap: 0.6rem; }

.apply-radio {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 0.6rem 1.1rem;
  border: 1px solid var(--apply-line);
  border-radius: 999px;
  cursor: pointer;
  color: rgba(250, 246, 238, 0.78);
  font-size: 0.9rem;
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}
.apply-radio input { position: absolute; opacity: 0; pointer-events: none; }
.apply-radio:hover { border-color: var(--apply-line-strong); }
.apply-radio:has(input:checked) {
  border-color: var(--gold);
  color: var(--champagne-glow);
  background: rgba(201, 168, 76, 0.12);
}

/* ── file upload ─────────────────────────────────────────────────── */
.apply-file { display: flex; flex-direction: column; gap: 0.35rem; }
.apply-file__hint { font-size: 0.8rem; color: rgba(250, 246, 238, 0.5); font-family: var(--serif); font-style: italic; }
.apply-file input[type="file"] { position: absolute; width: 1px; height: 1px; opacity: 0; overflow: hidden; }

.apply-file__btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  padding: 0.85rem 1rem;
  border: 1px dashed var(--apply-line-strong);
  border-radius: 4px;
  background: rgba(250, 246, 238, 0.03);
  color: rgba(250, 246, 238, 0.6);
  cursor: pointer;
  font-size: 0.95rem;
  transition: border-color 0.2s ease, color 0.2s ease;
}
.apply-file__btn:hover { color: var(--champagne); border-color: var(--gold); }
.apply-file__btn::after { content: "Browse"; color: var(--champagne); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; }
.apply-file__btn.is-filled { color: var(--cream); border-style: solid; }

/* ── errors ──────────────────────────────────────────────────────── */
.apply-error { min-height: 1rem; font-size: 0.8rem; color: var(--apply-error); font-family: var(--sans); }
.apply-form__error { margin-top: 1rem; color: var(--apply-error); text-align: center; min-height: 1rem; }

/* ── submit ──────────────────────────────────────────────────────── */
.apply-form__actions { margin-top: clamp(1.5rem, 3vw, 2rem); }

.apply-submit {
  width: 100%;
  padding: 1rem 1.5rem;
  border: none;
  border-radius: 4px;
  background: linear-gradient(180deg, var(--champagne), var(--gold));
  color: var(--oxblood-deep);
  font-family: var(--sans);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.85rem;
  cursor: pointer;
  transition: filter 0.2s ease, transform 0.1s ease;
}
.apply-submit:hover { filter: brightness(1.06); }
.apply-submit:active { transform: translateY(1px); }
.apply-submit:disabled { opacity: 0.65; cursor: default; }

/* ── gate (verify-first) + success ───────────────────────────────── */
.apply-gate, .apply-success { text-align: center; padding: clamp(1rem, 3vw, 2rem) 0; }
.apply-gate__msg, .apply-success__msg {
  font-family: var(--serif);
  font-style: italic;
  color: rgba(250, 246, 238, 0.82);
  font-size: clamp(1.1rem, 2.2vw, 1.4rem);
  margin-bottom: 1.5rem;
}
.apply-success__title {
  font-family: var(--serif);
  color: var(--champagne);
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  margin-bottom: 0.75rem;
}
