.iso-gap-wrap { max-width: 1000px; margin: 0 auto; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial; }
.iso-gap-head h2 { margin: 0 0 6px; }
.iso-gap-model { margin: 12px 0 18px; }
.iso-gap-select { padding: 8px 10px; min-width: 280px; }

.iso-gap-legend { background: #f6f7f9; border-left: 4px solid #2271b1; padding: 10px 12px; margin: 8px 0 18px; }

.iso-gap-stats { display: flex; gap: 20px; margin: 12px 0 20px; }
.iso-gap-stat { flex: 1; }
.iso-gap-stat .bar { height: 8px; background: #e5e7eb; border-radius: 6px; overflow: hidden; }
.iso-gap-stat .bar-fill { height: 100%; background: #2271b1; }

.iso-gap-section { border: 1px solid #e5e7eb; border-radius: 8px; margin-bottom: 18px; }
.iso-gap-section h3 { margin: 0; padding: 12px 14px; background: #fafafa; border-bottom: 1px solid #eee; }
.iso-gap-section .section-meta { display:flex; align-items:center; gap:12px; padding: 10px 14px; color:#444; }
.iso-gap-section .section-meta .bar { width: 180px; }
.iso-gap-section .questions { padding: 6px 14px 14px; }

.iso-gap-q { border-bottom: 1px dashed #ececec; padding: 10px 0; }
.iso-gap-q:last-child { border-bottom: 0; }

.iso-gap-q .q-head { display: flex; justify-content: space-between; gap: 12px; align-items: baseline; }
.iso-gap-q .q-text { font-weight: 500; }
.iso-gap-q .q-meta { font-size: 12px; color: #666; white-space: nowrap; }

.iso-gap-q .q-inputs { margin-top:8px; display:flex; flex-wrap: wrap; gap:10px; align-items:center; }
.iso-gap-radio { display:inline-flex; gap:4px; align-items:center; }

.iso-gap-soa { margin-left: auto; font-size: 12px; display:flex; align-items:center; gap:6px; font-weight:500; }
.iso-gap-muted { color:#6b7280; font-size:12px; }


.levels-col {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Cada opción en bloque (vertical) */
.iso-gap-radio.block {
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.3;
}

/* Nombre del nivel más claro */
.iso-gap-radio .lvl-name { margin-right: 4px; }
.iso-gap-radio .lvl-num   { color: #6b7280; font-size: 12px; }

.q-number { color:#374151; margin-right:6px; }

.iso-gap-section h3 {
    background-color:#65BC7B;
    color: #fff;
}   


/* Barra fija de progreso */
/* Barra de progreso fija en la parte inferior */
.iso-gap-stats {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;             /* fija abajo */
  z-index: 999;
  background: #fff;
  padding: 10px 16px;
  border-top: 1px solid #e5e7eb;
  box-shadow: 0 -8px 14px -12px rgba(0,0,0,.15);
}

/* Deja espacio al final de la página para que no tape contenido */
.iso-gap-wrap { padding-bottom: 70px; } /* ajusta a la altura real de la barra */

/* Si navegas logueado con admin bar de WP (no afecta bottom, pero por si agregas top-fixed algún día) */
.admin-bar .iso-gap-stats { bottom: 0; }


.q-inputs {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

/* Bloque de opciones ocupa el espacio disponible */
.q-inputs .levels-col { flex: 1; }

/* Checkbox SoA pegado a la derecha */
.soa-right {
  margin-left: auto;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* Responsive: en móviles los apilamos */
@media (max-width: 768px) {
  .q-inputs { flex-direction: column; }
  .soa-right { margin-left: 0; align-self: flex-start; }
}

/* Botón */
.iso-gap-btn { padding:8px 12px; border:1px solid #d1d5db; border-radius:6px; background:#fff; cursor:pointer; }
.iso-gap-btn--primary { background:#2271b1; border-color:#2271b1; color:#fff; }
.iso-gap-btn--ghost { background:transparent; }

/* Modal básico */
.iso-gap-modal[aria-hidden="true"] { display:none; }
.iso-gap-modal[aria-hidden="false"] { display:block; }

/* Backdrop y diálogo con z-index altísimo */
.iso-gap-modal__backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 100000; /* > que cualquier header de Avada */
}
.iso-gap-modal__dialog {
  position: fixed;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: min(600px, 92vw);
  background: #fff; border-radius: 10px;
  padding: 16px 16px 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  z-index: 100001; /* por encima del backdrop */
}

/* Cabecera de logo del modal */
.iso-gap-modal__logo { text-align: center; margin-bottom: 12px; }
.iso-gap-modal__logo img { max-height: 60px; width: auto; }

.iso-gap-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:10px 0 6px; }
.iso-gap-grid__full { grid-column:1 / -1; }
.iso-gap-modal__dialog input { width:100%; padding:8px 10px; border:1px solid #d1d5db; border-radius:6px; }
.iso-gap-modal__actions { display:flex; justify-content:flex-end; gap:10px; margin-top:10px; }
.iso-gap-msg { margin-top:8px; font-size:13px; }
.iso-gap-msg.err { color:#b91c1c; }
.iso-gap-msg.ok { color:#065f46; }

.iso-gap-modal__logo {
  text-align: center;
  margin-bottom: 12px;
}
.iso-gap-modal__logo img {
  max-height: 48px;  /* ajusta el tamaño */
}

iso-flash {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 86px;                 /* encima de tu barra sticky */
  z-index: 100002;
  max-width: min(680px, 92vw);
  pointer-events: none;         /* clics pasan al contenido */
}
.iso-flash__msg {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid #d1fae5;
  background: #ecfdf5;
  color: #065f46;
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
  font-size: 14px;
}
.iso-flash__msg.is-error {
  border-color: #fee2e2;
  background: #fef2f2;
  color: #991b1b;
}
/* Animación de entrada/salida */
.iso-flash__msg { opacity: 0; transform: translateY(8px); transition: opacity .2s ease, transform .2s ease; }
.iso-flash__msg.show { opacity: 1; transform: translateY(0); }

.iso-gap-note {
  margin-left: 16px;
  font-size: 14px;
  font-weight: 500;
  color: #065f46;  /* verde éxito */
}
.iso-gap-note.error {
  color: #991b1b;  /* rojo error */
}


/* Base */
.iso-consent{display:flex;align-items:flex-start;gap:10px;margin:16px 0 8px}
.iso-consent input{width:18px;height:18px;margin-top:3px;accent-color:#2563eb}
.iso-consent__label{line-height:1.45;color:#111827;font-size:14px}

/* Footer minimal (C) */
.iso-consent.footer{justify-content:flex-start}

/* Accesibilidad */
.iso-consent input:focus-visible{outline:2px solid #2563eb;outline-offset:2px;border-radius:4px}