/* MindGain Beta – Bewerbungsformular */
.mgb-wrap {
  --cyan:  #00F5FF;
  --amber: #F0A500;
  --black: #0A0A0A;
  --card:  #141414;
  --bdr:   rgba(0,245,255,0.12);
  --red:   #ef4444;
  max-width: 680px;
  margin: 0 auto;
  font-family: 'DM Sans', sans-serif;
}

/* Counter Bar */
.mgb-counter-bar {
  position: relative;
  background: #1a1a1a;
  border: 1px solid var(--bdr);
  border-radius: 4px;
  height: 44px;
  overflow: hidden;
  margin-bottom: 36px;
}

.mgb-counter-fill {
  position: absolute;
  top: 0; left: 0; bottom: 0;
  background: linear-gradient(90deg, rgba(0,245,255,0.15), rgba(0,245,255,0.08));
  transition: width 1s ease;
}

.mgb-counter-text {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding: 0 16px;
  font-size: 0.82rem;
  color: #aaa;
}

.mgb-spots-left {
  color: var(--cyan);
  font-weight: 700;
  letter-spacing: 0.04em;
}

/* Form sections */
.mgb-section {
  margin-bottom: 36px;
  padding-bottom: 36px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

.mgb-section:last-of-type { border-bottom: none; }

.mgb-section-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem;
  letter-spacing: 0.12em;
  color: var(--cyan);
  margin-bottom: 20px;
}

.mgb-section--health { background: rgba(240,165,0,0.04); border: 1px solid rgba(240,165,0,0.12); border-radius: 4px; padding: 24px; margin-bottom: 24px; }
.mgb-section--health .mgb-section-label { color: var(--amber); }
.mgb-section--consent { background: rgba(0,245,255,0.03); border: 1px solid var(--bdr); border-radius: 4px; padding: 24px; }

.mgb-health-info {
  font-size: 0.82rem;
  color: #888;
  line-height: 1.7;
  margin-bottom: 20px;
}

/* Grid */
.mgb-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.mgb-field { display: flex; flex-direction: column; gap: 8px; }
.mgb-field--full { grid-column: 1 / -1; }

.mgb-field label {
  font-size: 0.78rem;
  font-weight: 600;
  color: #999;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  line-height: 1.5;
}

.mgb-req { color: var(--cyan); }

.mgb-field input,
.mgb-field textarea,
.mgb-field select {
  padding: 13px 16px;
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 3px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9rem;
  color: #fff;
  outline: none;
  transition: border-color 0.2s ease;
  -webkit-appearance: none;
}

.mgb-field input:focus,
.mgb-field textarea:focus,
.mgb-field select:focus { border-color: var(--cyan); }

.mgb-field input::placeholder,
.mgb-field textarea::placeholder { color: #333; }

.mgb-field textarea { resize: vertical; min-height: 80px; }

.mgb-field select { cursor: pointer; }
.mgb-field select option { background: #1a1a1a; }

/* Radio */
.mgb-radio-group { display: flex; gap: 16px; }

.mgb-radio {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  padding: 12px 20px;
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 3px;
  flex: 1;
  transition: border-color 0.2s ease;
}

.mgb-radio:has(input:checked) { border-color: var(--cyan); background: rgba(0,245,255,0.05); }

.mgb-radio input[type="radio"] { accent-color: var(--cyan); width: 16px; height: 16px; }

.mgb-radio span { font-size: 0.9rem; color: #ccc; }

/* Checkboxes */
.mgb-checkboxes { display: flex; flex-direction: column; gap: 14px; }

.mgb-checkbox {
  display: flex;
  gap: 14px;
  cursor: pointer;
  align-items: flex-start;
}

.mgb-checkbox input[type="checkbox"] {
  accent-color: var(--cyan);
  width: 18px;
  height: 18px;
  min-width: 18px;
  margin-top: 2px;
  cursor: pointer;
}

.mgb-checkbox span {
  font-size: 0.875rem;
  color: #bbb;
  line-height: 1.65;
}

/* Buttons */
.mgb-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 16px 40px;
  background: var(--cyan);
  color: #0A0A0A;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.mgb-btn-primary:hover { background: #00d8e0; transform: translateY(-2px); }
.mgb-btn-primary:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* Submit area */
.mgb-submit-area { text-align: center; padding-top: 12px; }

.mgb-submit-note {
  font-size: 0.78rem;
  color: #555;
  margin-top: 12px;
  letter-spacing: 0.03em;
}

/* Messages */
.mgb-message {
  padding: 16px 20px;
  border-radius: 3px;
  font-size: 0.9rem;
  line-height: 1.65;
  margin-bottom: 20px;
}

.mgb-message.success {
  background: rgba(34,197,94,0.08);
  border: 1px solid rgba(34,197,94,0.25);
  color: #4ade80;
}

.mgb-message.pending {
  background: rgba(240,165,0,0.08);
  border: 1px solid rgba(240,165,0,0.25);
  color: var(--amber);
}

.mgb-message.rejected {
  background: rgba(239,68,68,0.08);
  border: 1px solid rgba(239,68,68,0.2);
  color: #fca5a5;
}

.mgb-message.error {
  background: rgba(239,68,68,0.08);
  border: 1px solid rgba(239,68,68,0.2);
  color: #fca5a5;
}

/* Full notice (no spots) */
.mgb-full-notice {
  text-align: center;
  padding: 48px 32px;
  background: var(--card);
  border: 1px solid var(--bdr);
  border-radius: 6px;
}

.mgb-full-icon { font-size: 3rem; margin-bottom: 16px; }
.mgb-full-notice h3 { font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem; color: #fff; margin-bottom: 12px; }
.mgb-full-notice p { font-size: 0.9rem; color: #888; line-height: 1.7; margin-bottom: 28px; }

.mgb-waitlist {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.mgb-input {
  padding: 13px 16px;
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 3px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9rem;
  color: #fff;
  outline: none;
  min-width: 200px;
}

.mgb-input:focus { border-color: var(--cyan); }

/* Responsive */
@media (max-width: 600px) {
  .mgb-form-grid { grid-template-columns: 1fr; }
  .mgb-radio-group { flex-direction: column; }
  .mgb-section--health,
  .mgb-section--consent { padding: 16px; }
}
