/* ── Forms ────────────────────────────────────────────────────── */
.form-group { margin-bottom: 1rem; }
.form-label {
  display: block; font-size: 0.8rem; font-weight: 600;
  color: var(--text-dim); margin-bottom: 0.3rem; text-transform: uppercase;
  letter-spacing: 0.05em;
}
.form-input, .form-select, .form-textarea {
  width: 100%; padding: 0.6rem 0.75rem;
  background: var(--bg-input); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius);
  font-family: var(--font-ui); font-size: 0.9rem;
  transition: border-color var(--transition);
}

/* iOS Safari auto-zooms on focus when input font-size < 16px.
 * Bump to 16px on touch devices (hover: none) to prevent that. */
@media (hover: none) and (pointer: coarse) {
  .form-input, .form-select, .form-textarea {
    font-size: 16px;
  }
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none; border-color: var(--accent);
}
.form-textarea { resize: vertical; min-height: 80px; }
.form-select { cursor: pointer; }
.form-hint { font-size: 0.75rem; color: var(--text-dim); margin-top: 0.2rem; }
.form-error { font-size: 0.75rem; color: var(--danger); margin-top: 0.2rem; }
.form-row { display: grid; gap: 1rem; grid-template-columns: 1fr 1fr; }

@media (max-width: 600px) {
  .form-row { grid-template-columns: 1fr; }
}

/* ── Wizard ───────────────────────────────────────────────────── */
.wizard-steps {
  display: flex; gap: 0; margin-bottom: 1.5rem;
  overflow-x: auto; border-bottom: 2px solid var(--border);
}
.wizard-step {
  padding: 0.6rem 1rem; font-size: 0.8rem; font-weight: 600;
  color: var(--text-dim); cursor: pointer; white-space: nowrap;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
  transition: all var(--transition);
}
.wizard-step:hover { color: var(--text); }
.wizard-step.active { color: var(--accent); border-bottom-color: var(--accent); }
.wizard-step.completed { color: var(--success); }

.wizard-nav {
  display: flex; justify-content: space-between; margin-top: 1.5rem;
  padding-top: 1rem; border-top: 1px solid var(--border);
}

/* ── Skill Checkbox Grid ──────────────────────────────────────── */
.skill-grid {
  display: grid; gap: 0.25rem;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}
.skill-item {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.35rem 0.5rem; border-radius: 4px; font-size: 0.85rem;
}
.skill-item:hover { background: var(--bg-input); }
.skill-item input[type="checkbox"] { accent-color: var(--accent); }
.skill-item-mod { color: var(--text-dim); font-size: 0.75rem; margin-left: auto; }
.skill-item.bg-skill { color: var(--success); }
.skill-item.bg-skill input { pointer-events: none; }

/* ── Inline Editable ──────────────────────────────────────────── */
.editable { cursor: pointer; border-bottom: 1px dashed var(--border); }
.editable:hover { border-bottom-color: var(--accent); }
