/* modal-system.css
 * Estilos do sistema de modais (Tailwind-equivalente)
 */

.modal-card {
  background: #ffffff;
  border-radius: 1rem;
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.18);
  width: 100%;
  max-width: 640px;
  overflow: visible;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid #f1f5f9;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
}

.modal-title {
  font-size: 1.125rem;
  line-height: 1.5rem;
  font-weight: 600;
  color: #111827;
  font-family: 'Inter', ui-sans-serif, system-ui, sans-serif;
}

.modal-body {
  padding: 1.25rem 1.5rem;
  max-height: 60vh;
  overflow-y: auto;
  overflow-x: visible;
}

/* Permite que comboboxes abram como flyout fora do modal (casos específicos) */
.modal-body.modal-body-flyout {
  overflow: visible;
  max-height: none;
}

/* Alpine combobox dropdowns inside modals */

.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid #f1f5f9;
  background: #f8fafc;
  border-bottom-left-radius: 1rem;
  border-bottom-right-radius: 1rem;
}

.modal-close-btn {
  width: 2rem;
  height: 2rem;
  border-radius: 0.5rem;
  color: #9ca3af;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 200ms ease, color 200ms ease;
}

.modal-close-btn:hover {
  color: #4b5563;
  background: #f3f4f6;
}

.icon-circle {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.75rem;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.icon-circle.bg-sky-50 {
  background: transparent;
}

.icon-circle.bg-red-100 {
  background: transparent;
}

.icon-circle.bg-amber-100 {
  background: transparent;
}

.modal-card .modal-header [data-lucide] {
  opacity: 1;
}

.modal-card .btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  border-radius: 9999px;
  font-size: 0.875rem;
  font-weight: 400;
  color: #1b3430;
  background: #c7f268;
  border: 1px solid #c7f268;
  transition: background-color 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.modal-card .btn-primary:hover {
  background: #d4f97a;
  border-color: #d4f97a;
  box-shadow: 0 0 0 2px rgba(199, 242, 104, 0.35);
}

.modal-card .btn-primary.bg-red-600 {
  background: #dc2626;
  border-color: #dc2626;
}

.modal-card .btn-primary.bg-red-600:hover,
.modal-card .btn-primary.hover\:bg-red-700:hover {
  background: #b91c1c;
  border-color: #b91c1c;
  box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.25);
}

.modal-card .btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  border-radius: 9999px;
  font-size: 0.875rem;
  font-weight: 400;
  color: #ffffff;
  background: #1b3430;
  border: 1px solid #1b3430;
  transition: background-color 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.modal-card .btn-secondary:hover {
  background: #152a27;
  color: #ffffff;
  box-shadow: 0 0 0 2px rgba(27, 52, 48, 0.25);
  border-color: #152a27;
}

@media (prefers-reduced-motion: reduce) {
  .modal-close-btn,
  .modal-card .btn-primary,
  .modal-card .btn-secondary {
    transition: none;
  }
}

/* Loading state for modal submit buttons */
.modal-card .btn-primary.is-loading,
.modal-card .btn-primary:disabled,
.modal-card .btn-secondary.is-loading,
.modal-card .btn-secondary:disabled {
  opacity: 0.7;
  cursor: not-allowed;
  pointer-events: none;
}

.modal-card .dash-btn-spinner {
  display: none;
  width: 1rem;
  height: 1rem;
  border: 2px solid rgba(27, 52, 48, 0.3);
  border-top-color: #1b3430;
  border-radius: 50%;
  animation: modal-spin 0.6s linear infinite;
  flex-shrink: 0;
}

.modal-card .is-loading .dash-btn-spinner {
  display: inline-block;
}

.modal-card .btn-primary.bg-red-600 .dash-btn-spinner {
  border-color: rgba(255, 255, 255, 0.4);
  border-top-color: #ffffff;
}

.modal-card .btn-secondary .dash-btn-spinner {
  border-color: rgba(255, 255, 255, 0.4);
  border-top-color: #ffffff;
}

@keyframes modal-spin {
  to { transform: rotate(360deg); }
}
