/* Componentes DS — reutilizáveis no portal estático */

.omega-ds-portal .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  height: 56px;
  padding: 0 var(--space-lg);
  border: 0;
  border-radius: var(--radius-pill);
  font: var(--fw-semibold) var(--fs-base) / 1 var(--font-body);
  cursor: pointer;
  transition: var(--transition-base);
  box-shadow: var(--shadow-md);
  user-select: none;
  text-decoration: none;
  white-space: nowrap;
}

.omega-ds-portal .btn:disabled,
.omega-ds-portal .btn[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.omega-ds-portal .btn.primary {
  background: var(--brand);
  color: var(--brand-foreground);
  box-shadow: var(--shadow-md);
}
.omega-ds-portal .btn.primary:hover:not(:disabled) {
  background: var(--brand-hover);
  transform: translateY(-1px);
  box-shadow: var(--shadow-lg);
}

.omega-ds-portal .btn.secondary {
  background: var(--color-surface-elevated);
  color: var(--color-text);
  box-shadow: none;
  border: 1px solid var(--color-border-strong);
}
.omega-ds-portal .btn.secondary:hover:not(:disabled) {
  background: var(--color-bg);
  border-color: var(--color-text-muted);
}

.omega-ds-portal .btn.whatsapp {
  background: var(--color-whatsapp);
  color: var(--brand-foreground);
  box-shadow: var(--shadow-md);
}
.omega-ds-portal .btn.whatsapp:hover:not(:disabled) {
  background: var(--color-whatsapp-hover);
  transform: translateY(-1px);
  box-shadow: var(--shadow-lg);
}

.omega-ds-portal .btn.brand {
  background: var(--brand);
  color: var(--brand-foreground);
}
.omega-ds-portal .btn.brand:hover:not(:disabled) {
  background: var(--brand-hover);
}

.omega-ds-portal .btn.ghost {
  background: transparent;
  box-shadow: none;
  color: var(--color-text);
  border: 1px solid transparent;
}
.omega-ds-portal .btn.ghost:hover:not(:disabled) {
  background: var(--color-surface);
  border-color: var(--color-border);
}

.omega-ds-portal .btn.sm {
  height: 40px;
  font-size: var(--fs-sm);
  padding: 0 var(--space-md);
}

.omega-ds-portal .btn.lg {
  height: 52px;
  font-size: var(--fs-lg);
  padding: 0 var(--space-xl);
}

.omega-ds-portal .btn.block {
  width: 100%;
}

.omega-ds-portal .card {
  background: var(--color-surface-elevated);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-card);
  padding: var(--space-xl);
  width: 100%;
}

.omega-ds-portal .card.flat {
  box-shadow: none;
  border: 1px solid var(--color-border);
}

.omega-ds-portal .field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
}

.omega-ds-portal .field .label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  font-size: var(--fs-sm);
  line-height: var(--lh-sm);
  color: var(--color-text);
  font-weight: var(--fw-medium);
}

.omega-ds-portal .field .helper {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
}

.omega-ds-portal .field .error {
  font-size: var(--fs-xs);
  color: var(--color-danger);
}

.omega-ds-portal .spinner {
  width: 1em;
  height: 1em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: omega-ds-spin 0.7s linear infinite;
}

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