/* ============================================================
   SEPA Club Fuencarral — Estilos del formulario público
   Wizard de 3 pasos · Validación IBAN · Responsive
   ============================================================ */


/* ── Wizard — indicador de pasos ────────────────────────────── */
.wizard-steps {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             0;
  margin-bottom:   var(--space-8);
  padding:         0 var(--space-4);
}

.wizard-step {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            var(--space-2);
  position:       relative;
  flex:           1;
  max-width:      200px;
}

/* Línea conectora entre pasos */
.wizard-step:not(:last-child)::after {
  content:    '';
  position:   absolute;
  top:        20px;
  left:       calc(50% + 20px);
  right:      calc(-50% + 20px);
  height:     2px;
  background: var(--wizard-step-pending);
  transition: background var(--transition-slow);
  z-index:    0;
}
.wizard-step.done:not(:last-child)::after {
  background: var(--wizard-step-done);
}

/* Círculo numerado */
.wizard-step__num {
  width:           40px;
  height:          40px;
  border-radius:   var(--radius-full);
  border:          2px solid var(--wizard-step-pending);
  background:      var(--color-bg);
  color:           var(--color-text-muted);
  font-size:       var(--text-sm);
  font-weight:     var(--font-bold);
  display:         flex;
  align-items:     center;
  justify-content: center;
  transition:      all var(--transition-slow);
  position:        relative;
  z-index:         1;
}

.wizard-step.active .wizard-step__num {
  border-color: var(--wizard-step-active);
  background:   var(--wizard-step-active);
  color:        #fff;
  box-shadow:   0 0 0 4px rgba(46, 153, 161, 0.18);
}

.wizard-step.done .wizard-step__num {
  border-color: var(--wizard-step-done);
  background:   var(--wizard-step-done);
  color:        #fff;
}

/* Reemplazar número por check en pasos completados */
.wizard-step.done .wizard-step__num-text { display: none; }
.wizard-step.done .wizard-step__num::after {
  content:     '';
  display:     block;
  width:       14px;
  height:      14px;
  background:  url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3E%3C/svg%3E") no-repeat center;
}

/* Etiqueta del paso */
.wizard-step__label {
  font-size:   var(--text-xs);
  font-weight: var(--font-bold);
  color:       var(--color-text-muted);
  text-align:  center;
  line-height: 1.3;
  transition:  color var(--transition);
}
.wizard-step.active .wizard-step__label { color: var(--color-primary); }
.wizard-step.done   .wizard-step__label { color: var(--color-success); }


/* ── Paneles de pasos (show/hide via JS) ────────────────────── */
.wizard-panel {
  display: none;
  animation: panelEntrada 0.22s ease;
}
.wizard-panel.active { display: block; }

@keyframes panelEntrada {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Título de sección dentro del formulario */
.form-section-title {
  font-size:     var(--text-lg);
  font-weight:   var(--font-bold);
  color:         var(--color-text);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-primary-light);
  display:       flex;
  align-items:   center;
  gap:           var(--space-3);
}
.form-section-title svg { color: var(--color-primary); flex-shrink: 0; }

/* Descripción de sección */
.form-section-desc {
  font-size:     var(--text-sm);
  color:         var(--color-text-muted);
  margin-bottom: var(--space-6);
  line-height:   1.6;
}

/* Grid de 2 columnas para campos del formulario */
.form-grid-2 {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   0 var(--space-5);
}
.form-grid-2 .form-group--full { grid-column: 1 / -1; }


/* ── Campo IBAN con indicador de validación ─────────────────── */
.iban-wrap {
  position: relative;
}

.iban-wrap .form-input {
  padding-right:  var(--space-10);
  font-family:    var(--font-mono);
  font-size:      var(--text-sm);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.iban-status {
  position:        absolute;
  right:           var(--space-3);
  top:             50%;
  transform:       translateY(-50%);
  width:           20px;
  height:          20px;
  display:         none;
  align-items:     center;
  justify-content: center;
  pointer-events:  none;
}
.iban-status.visible { display: flex; }

.iban-status--ok    svg { color: var(--color-success); }
.iban-status--error svg { color: var(--color-error); }
.iban-status--loading .spinner {
  width:  16px;
  height: 16px;
  border-width: 2px;
}

/* Nombre del banco detectado */
.iban-banco {
  font-size:   var(--text-xs);
  color:       var(--color-success);
  font-weight: var(--font-semibold);
  margin-top:  var(--space-1);
  min-height:  16px;
  transition:  all var(--transition);
}
.iban-banco.error { color: var(--color-error); }


/* ── Botones de navegación del wizard ───────────────────────── */
.wizard-nav {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  gap:             var(--space-3);
  margin-top:      var(--space-8);
  padding-top:     var(--space-6);
  border-top:      1px solid var(--color-border);
}

.wizard-nav--end { justify-content: flex-end; }


/* ── Bloque de consentimiento ───────────────────────────────── */
.consent-block {
  background:    var(--color-bg-surface);
  border:        1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding:       var(--space-5);
  margin-bottom: var(--space-4);
}

.consent-block .form-check { margin-bottom: 0; }

.consent-block .form-check-label {
  font-size:   var(--text-sm);
  line-height: 1.5;
}

.consent-block .form-check-label a {
  color:           var(--color-primary);
  text-decoration: underline;
}

/* Recuadro de información SEPA */
.sepa-info-box {
  background:    var(--color-primary-light);
  border:        1px solid var(--color-primary);
  border-radius: var(--radius-sm);
  padding:       var(--space-4) var(--space-5);
  margin-bottom: var(--space-6);
  font-size:     var(--text-sm);
  color:         var(--color-primary-dark);
  line-height:   1.6;
}

.sepa-info-box strong { font-weight: var(--font-bold); }


/* ── Cabecera pública del formulario ────────────────────────── */
.sepa-header {
  background:     var(--color-primary);
  padding:        var(--space-5) var(--space-6);
  color:          #fff;
}

.sepa-header__inner {
  max-width:       680px;
  margin:          0 auto;
  display:         flex;
  align-items:     center;
  gap:             var(--space-4);
}

.sepa-header__logo {
  height:  48px;
  width:   auto;
  flex-shrink: 0;
}

.sepa-header__texto h1 {
  font-size:   var(--text-xl);
  font-weight: var(--font-bold);
  color:       #fff;
  line-height: 1.2;
}

.sepa-header__texto p {
  font-size: var(--text-sm);
  opacity:   0.82;
  margin-top: var(--space-1);
}


/* ── Tarjeta del formulario ─────────────────────────────────── */
.sepa-card {
  background:    var(--color-bg);
  border-radius: var(--radius-md);
  box-shadow:    var(--shadow-md);
  padding:       var(--space-8);
  width:         100%;
  max-width:     680px;
  margin:        0 auto;
}


/* ── Resumen antes de enviar (paso 3) ───────────────────────── */
.resumen-datos {
  background:    var(--color-bg-surface);
  border:        1px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow:      hidden;
  margin-bottom: var(--space-6);
  font-size:     var(--text-sm);
}

.resumen-seccion {
  padding:       var(--space-3) var(--space-4);
  font-size:     var(--text-xs);
  font-weight:   var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color:         var(--color-text-muted);
  background:    var(--color-bg-surface);
  border-bottom: 1px solid var(--color-border);
}

.resumen-fila {
  display:       flex;
  padding:       var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  gap:           var(--space-4);
}
.resumen-fila:last-child { border-bottom: none; }

.resumen-fila__label {
  color:       var(--color-text-muted);
  min-width:   140px;
  flex-shrink: 0;
}
.resumen-fila__valor { font-weight: var(--font-semibold); color: var(--color-text); }
.resumen-fila__valor--iban { font-family: var(--font-mono); letter-spacing: 0.04em; }


/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 600px) {
  .sepa-card { padding: var(--space-5); border-radius: var(--radius-sm); }

  .form-grid-2 { grid-template-columns: 1fr; }

  .wizard-step__label { display: none; }  /* Ocultar etiquetas en móvil — solo números */
  .wizard-steps       { gap: 0; }

  .wizard-nav { flex-direction: column-reverse; }
  .wizard-nav .btn { width: 100%; }

  .resumen-fila { flex-direction: column; gap: var(--space-1); }
  .resumen-fila__label { min-width: auto; }

  .sepa-header__logo { height: 36px; }
  .sepa-header__texto h1 { font-size: var(--text-lg); }
}
