/* ============================================================
   rx_core — Modal de confirmação (CANÓNICO, partilhado)
   Substitui os modais bespoke (duplicado, retry, apagar, ...) por um único
   componente reutilizável: título, subtítulo, mensagem extra opcional,
   botões configuráveis (primary/secondary/cancel/danger), e um estado de
   loading opcional (spinner + progresso) para acções assíncronas longas
   (ex.: apagar vários itens).
   ============================================================ */

.rx-confirm-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9100;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}
html.light .rx-confirm-modal { background: rgba(245,244,240,0.7); }
.rx-confirm-modal.open { display: flex; }

.rx-confirm-box {
  background: var(--ink-2);
  border: 1px solid var(--wire);
  border-radius: 16px;
  padding: 2rem 2.5rem;
  max-width: 360px;
  width: 100%;
  min-height: 220px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

.rx-confirm-logo {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 1.25rem;
  letter-spacing: -0.02em;
  color: var(--text);
}
.rx-confirm-logo span { color: var(--amber); }

.rx-confirm-title {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  color: var(--text);
}

.rx-confirm-subtitle {
  font-size: 0.78rem;
  color: var(--text-3);
  line-height: 1.5;
}

.rx-confirm-extra {
  font-size: 0.8125rem;
  color: var(--amber);
}

.rx-confirm-actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
  margin-top: 0.25rem;
}

.rx-confirm-btn {
  display: block;
  width: 100%;
  text-align: center;
  text-decoration: none;
  border-radius: 8px;
  padding: 0.75rem 1.5rem;
  font-family: 'Syne', sans-serif;
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.15s;
  border: 1px solid transparent;
}
.rx-confirm-btn--primary { background: var(--amber); color: var(--ink); border-color: var(--amber); }
.rx-confirm-btn--primary:hover { background: var(--amber-2); border-color: var(--amber-2); }

.rx-confirm-btn--secondary { background: var(--ghost-2); border-color: var(--wire-2); color: var(--text); }
.rx-confirm-btn--secondary:hover { border-color: var(--amber); color: var(--amber); }

.rx-confirm-btn--cancel { background: transparent; border: none; color: var(--text-3); font-size: 0.8125rem; padding: 0.25rem; }

.rx-confirm-btn--danger { background: transparent; border-color: #ef4444; color: #ef4444; }
.rx-confirm-btn--danger:hover { background: #ef4444; color: white; }

/* ── Estado de loading (acção assíncrona em curso, ex.: a apagar) ── */
.rx-confirm-loading {
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  padding: 1rem 0;
}
.rx-confirm-spinner {
  width: 36px; height: 36px;
  border: 2px solid var(--wire-2);
  border-top-color: var(--amber);
  border-radius: 50%;
  animation: rx-confirm-spin 0.8s linear infinite;
}
@keyframes rx-confirm-spin { to { transform: rotate(360deg); } }
.rx-confirm-loading-title {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  color: var(--text);
}
.rx-confirm-loading-sub { font-size: 0.875rem; color: var(--text-3); }