/**
 * steps.css – Lépés szekciók, step header, általános form elemek
 *
 * Felelős:
 *   - .form-step (lépés szekció show/hide)
 *   - .step-header (szám + cím + alcím)
 *   - .field-group, .field-label, .field-hint, .field-error
 *   - .input-field, .input-textarea
 *   - .info-note (tájékoztató kék sáv)
 *   - .required, .optional badge-ek
 */

/* ==========================================================================
   LÉPÉS SZEKCIÓK
   ========================================================================== */

/* Minden lépés alap állapotban rejtett */
.form-step {
  display: none;
  animation: fadeInStep 0.3s ease;
}

/* Csak az aktív lépés látható */
.form-step.active {
  display: block;
}

@keyframes fadeInStep {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ==========================================================================
   LÉPÉS FEJLÉC (szám + cím)
   ========================================================================== */

.step-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 20px;
}

/* Lépésszám kör */
.step-number {
  width: 40px;
  height: 40px;
  background: var(--red);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-title);
  font-size: 20px;
  font-weight: 700;
  color: white;
  flex-shrink: 0;
  box-shadow: var(--shadow-red);
}

/* Figyelmeztető ikon (ismeretlen terület kártyán) */
.step-icon-warn {
  width: 40px;
  height: 40px;
  background: var(--orange-light);
  border: 1.5px solid var(--orange);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  color: var(--orange);
  flex-shrink: 0;
}

.step-title {
  font-family: var(--font-title);
  font-size: clamp(18px, 5vw, 22px);
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: 1px;
  margin-bottom: 3px;
}

.step-subtitle {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.4;
}

/* ==========================================================================
   FORM MEZŐK ÁLTALÁNOS STÍLUSAI
   ========================================================================== */

.field-group {
  margin-bottom: 18px;
}

.field-group:last-child {
  margin-bottom: 0;
}

/* Mező cimke */
.field-label {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 8px;
}

.field-label i {
  color: var(--red);
  font-size: 12px;
}

/* Kötelező / opcionális jelzők */
.required {
  color: var(--red);
  font-size: 12px;
}

.optional {
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}

/* Tipp szöveg a mező alatt */
.field-hint {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 5px;
  line-height: 1.4;
}

/* Hibaüzenet */
.field-error {
  font-size: 12px;
  color: var(--text-red);
  margin-top: 5px;
  min-height: 16px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.field-error:not(:empty)::before {
  content: '\f071'; /* fa-exclamation-triangle */
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  font-size: 11px;
  flex-shrink: 0;
}

/* ==========================================================================
   BEVITELI MEZŐK
   ========================================================================== */

.input-field {
  width: 100%;
  padding: 13px 16px;
  background: var(--input-bg);
  border: 1.5px solid var(--input-border);
  border-radius: var(--radius-sm);
  font-size: 16px; /* 16px megakadályozza az iOS zoom-ot */
  font-family: var(--font-body);
  color: var(--input-text);
  transition: all var(--transition);
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

.input-field::placeholder {
  color: var(--input-placeholder);
}

.input-field:focus {
  background: var(--input-bg-focus);
  border-color: var(--input-border-focus);
  box-shadow: 0 0 0 3px rgba(200, 16, 46, 0.15);
}

.input-field.error {
  border-color: var(--red);
}

/* Textarea */
.input-textarea {
  width: 100%;
  padding: 13px 16px;
  background: var(--input-bg);
  border: 1.5px solid var(--input-border);
  border-radius: var(--radius-sm);
  font-size: 15px;
  font-family: var(--font-body);
  color: var(--input-text);
  resize: vertical;
  min-height: 90px;
  line-height: 1.6;
  transition: all var(--transition);
  outline: none;
  -webkit-appearance: none;
}

.input-textarea::placeholder {
  color: var(--input-placeholder);
}

.input-textarea:focus {
  background: var(--input-bg-focus);
  border-color: var(--input-border-focus);
  box-shadow: 0 0 0 3px rgba(200, 16, 46, 0.15);
}

/* Karakter számláló */
.char-counter {
  text-align: right;
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 4px;
}

/* ==========================================================================
   TÁJÉKOZTATÓ (INFO) SÁV
   ========================================================================== */

.info-note {
  background: var(--blue-light);
  border: 1px solid rgba(52, 152, 219, 0.3);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-size: 12px;
  color: rgba(52, 152, 219, 0.9);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.5;
  margin-top: 12px;
}

.info-note i {
  flex-shrink: 0;
  margin-top: 1px;
}
