/* Modal global de alertas/confirmações (AppDialog) */
@import url("tokens.css");

.app-dialog-backdrop {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: max(1rem, env(safe-area-inset-top)) max(0.75rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(0.75rem, env(safe-area-inset-left));
  background: rgba(2, 6, 23, 0.68);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  cursor: default;
}

.app-dialog-backdrop.open {
  display: flex;
}

.app-dialog {
  width: 100%;
  max-width: 22rem;
  background: #fff;
  color: #0f172a;
  border-radius: 14px;
  padding: 1.15rem 1.2rem;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(148, 163, 184, 0.28);
}

.app-dialog-title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0f172a;
}

.app-dialog-message {
  margin: 0 0 1.1rem;
  font-size: 0.95rem;
  line-height: 1.45;
  color: #334155;
  white-space: pre-line;
}

.app-dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: flex-end;
}

.app-dialog-btn {
  font: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: 10px;
  border: none;
  cursor: pointer;
  min-height: var(--touch-min, 44px);
}

.app-dialog-btn-primary {
  background: var(--brand-gradient-btn);
  color: var(--text-on-brand);
  box-shadow: 0 4px 14px var(--brand-purple-glow);
}

.app-dialog-btn-primary:hover {
  filter: brightness(1.06);
}

.app-dialog-btn-secondary {
  background: #f1f5f9;
  color: #334155;
  border: 1px solid #e2e8f0;
}

.app-dialog-btn-secondary:hover {
  background: #e2e8f0;
}

@media (max-width: 480px) {
  .app-dialog {
    max-width: none;
  }

  .app-dialog-actions {
    flex-direction: column-reverse;
  }

  .app-dialog-btn {
    width: 100%;
  }
}
