/**
 * ISecAuditors CRA Evaluator — Form styles.
 * Selectores basados en el markup real que genera Drupal 10 + Webform.
 */

/* ---------- Design tokens -------------------------------------------- */
.cra-form {
  --cra-c-bg: #ffffff;
  --cra-c-surface: #f5f7fa;
  --cra-c-text: #1a1a1a;
  --cra-c-text-muted: #5a6677;
  --cra-c-border: #e1e6ec;
  --cra-c-border-strong: #c8d0d9;
  --cra-c-info: #185fa5;
  --cra-c-info-bg: #e6f1fb;
  --cra-c-info-text: #0c447c;
  --cra-c-danger: #a32d2d;
  --cra-radius-md: 8px;
  --cra-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* ---------- Contenedor del formulario -------------------------------- */
.cra-form {
  max-width: 960px;
  margin: 0 auto;
  padding: 1.5rem 2rem 3rem;
  color: var(--cra-c-text);
  font-family: var(--cra-font);
  line-height: 1.55;
  font-size: 0.95rem;
}

/* ---------- Barra de progreso ---------------------------------------- */
.cra-form .webform-progress {
  margin: 0 0 2rem;
}

/* ---------- Fieldset (wrapper de cada pregunta de radios) ------------ */
/* Drupal genera: fieldset.radios--wrapper.form-item.js-form-item */
.cra-form fieldset.radios--wrapper {
  display: flex;
  flex-direction: column;
  border: 0;
  padding: 0;
  margin: 0 0 1.75rem;
}

/* Legend = texto de la pregunta */
.cra-form fieldset.radios--wrapper legend {
  float: none;
  width: 100%;
  padding: 0;
  margin: 0 0 6px;
  font-size: 1rem;
  font-weight: 600;
  color: var(--cra-c-text);
  line-height: 1.45;
  border: 0;
  order: 0;
}

.cra-form fieldset.radios--wrapper .fieldset-legend {
  font-size: 1rem;
  font-weight: 600;
  color: var(--cra-c-text);
}

/* fieldset-wrapper contiene: .js-webform-radios + .description */
/* Lo convertimos en flex-column para poder reordenar description arriba */
.cra-form fieldset.radios--wrapper .fieldset-wrapper {
  display: flex;
  flex-direction: column;
}

/* Descripción (texto gris): va ANTES de las opciones visualmente */
/* En el DOM está después de .js-webform-radios, así que usamos order */
.cra-form fieldset.radios--wrapper .fieldset-wrapper .description {
  order: -1;
  font-size: 0.82rem;
  color: var(--cra-c-text-muted);
  margin: 0 0 12px;
  line-height: 1.55;
}

/* El grupo de radios va después de la descripción */
.cra-form fieldset.radios--wrapper .fieldset-wrapper .js-webform-radios {
  order: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* ---------- Cada opción de radio ------------------------------------- */
/* Drupal genera: div.js-form-item.js-form-type-radio */
.cra-form .js-form-type-radio {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px;
  padding: 11px 14px;
  margin: 0 !important;
  border: 1px solid var(--cra-c-border);
  border-radius: var(--cra-radius-md);
  background: var(--cra-c-bg);
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.cra-form .js-form-type-radio:hover {
  border-color: var(--cra-c-border-strong);
  background: var(--cra-c-surface);
}

/* El input radio dentro del wrapper */
.cra-form .js-form-type-radio input[type="radio"] {
  margin: 0 !important;
  padding: 0;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  accent-color: var(--cra-c-info);
  cursor: pointer;
  position: static !important;
  float: none !important;
}

/* El label dentro del wrapper */
.cra-form .js-form-type-radio label.option {
  display: inline !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: none !important;
  font-size: 0.93rem;
  font-weight: 400;
  color: var(--cra-c-text);
  cursor: pointer;
  flex: 1;
  line-height: 1.4;
}

/* Estado seleccionado — sobre el wrapper */
.cra-form .js-form-type-radio:has(input[type="radio"]:checked) {
  border-color: var(--cra-c-info) !important;
  background: var(--cra-c-info-bg) !important;
  box-shadow: inset 0 0 0 1px var(--cra-c-info);
}

/* Focus ring */
.cra-form .js-form-type-radio:focus-within {
  outline: none;
  box-shadow: 0 0 0 3px rgba(24, 95, 165, 0.2);
}

/* ---------- Text inputs ---------------------------------------------- */
.cra-form input[type="text"],
.cra-form input[type="email"],
.cra-form input[type="tel"],
.cra-form input[type="date"],
.cra-form input[type="number"],
.cra-form textarea,
.cra-form select {
  display: block;
  width: 100%;
  max-width: 480px;
  padding: 10px 14px;
  font-family: inherit;
  font-size: 0.95rem;
  color: var(--cra-c-text);
  background: var(--cra-c-bg);
  border: 1px solid var(--cra-c-border-strong);
  border-radius: var(--cra-radius-md);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  box-sizing: border-box;
}
.cra-form input[type="text"]:focus,
.cra-form input[type="email"]:focus,
.cra-form input[type="tel"]:focus,
.cra-form textarea:focus,
.cra-form select:focus {
  outline: none;
  border-color: var(--cra-c-info);
  box-shadow: 0 0 0 3px rgba(24, 95, 165, 0.2);
}

/* ---------- Botones -------------------------------------------------- */
.cra-form .form-actions {
  display: flex;
  justify-content: flex-end;  /* todos a la derecha por defecto */
  gap: 10px;
  padding-top: 1.25rem;
  margin-top: 1.5rem;
  border-top: 1px solid var(--cra-c-border);
  flex-wrap: wrap;
}

/* El botón Anterior se queda a la izquierda empujando el resto */
.cra-form .webform-button--previous {
  margin-right: auto;
}

.cra-form input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 22px;
  font-family: inherit;
  font-size: 0.92rem;
  font-weight: 500;
  border-radius: var(--cra-radius-md);
  border: 1px solid var(--cra-c-border-strong);
  background: var(--cra-c-bg);
  color: var(--cra-c-text);
  cursor: pointer;
  transition: all 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
}
.cra-form input[type="submit"]:hover {
  border-color: var(--cra-c-info);
  color: var(--cra-c-info);
  background: var(--cra-c-info-bg);
}
.cra-form input[type="submit"]:active {
  transform: translateY(1px);
}

/* Botón primario (Siguiente / Enviar) */
.cra-form .webform-button--next,
.cra-form .webform-button--submit {
  background: var(--cra-c-info) !important;
  color: #ffffff !important;
  border-color: var(--cra-c-info) !important;
}
.cra-form .webform-button--next:hover,
.cra-form .webform-button--submit:hover {
  background: var(--cra-c-info-text) !important;
  border-color: var(--cra-c-info-text) !important;
  color: #ffffff !important;
}

/* Botón secundario (Anterior) */
.cra-form .webform-button--previous {
  background: var(--cra-c-bg) !important;
  color: var(--cra-c-text) !important;
  border-color: var(--cra-c-border-strong) !important;
}
.cra-form .webform-button--previous:hover {
  background: var(--cra-c-surface) !important;
}

/* ---------- Texto introductorio -------------------------------------- */
.cra-form .webform-element-processed_text,
.cra-form .text-formatted {
  background: var(--cra-c-info-bg);
  border-left: 3px solid var(--cra-c-info);
  padding: 14px 16px;
  border-radius: 0 var(--cra-radius-md) var(--cra-radius-md) 0;
  margin-bottom: 1.5rem;
  font-size: 0.92rem;
  color: var(--cra-c-info-text);
}

/* ---------- Errores de validación ------------------------------------ */
.cra-form .form-item--error-message {
  color: var(--cra-c-danger);
  font-size: 0.85rem;
  margin-top: 6px;
}

/* ---------- Responsive ----------------------------------------------- */
@media (max-width: 600px) {
  .cra-form {
    padding: 1rem 0.75rem 2.5rem;
  }
  .cra-form .form-actions {
    flex-direction: column-reverse;
  }
  .cra-form .form-actions input[type="submit"] {
    width: 100%;
  }
}
