/* Form feedback messages and loading states */

/* Feedback message styles */
.form-feedback {
  padding: 1rem;
  margin-bottom: 1.5rem;
  border-radius: 0.5rem;
  font-family: var(--inter);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.25rem;
  text-align: center;
  animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.form-feedback.success {
  background-color: rgba(34, 197, 94, 0.1);
  color: #16a34a;
  border: 1px solid rgba(34, 197, 94, 0.3);
}

.form-feedback.error {
  background-color: rgba(239, 68, 68, 0.1);
  color: #dc2626;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

/* Loading state for submit button */
.submit-btn.loading {
  opacity: 0.6;
  pointer-events: none;
  cursor: not-allowed;
}

.submit-btn.loading .text__container {
  position: relative;
}

.submit-btn.loading .text__container::after {
  content: '';
  position: absolute;
  right: -1.5rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

@keyframes spin {
  to {
    transform: translateY(-50%) rotate(360deg);
  }
}

/* Responsive adjustments */
@media (width <= 47.99875rem) {
  .form-feedback {
    font-size: 0.875rem;
    line-height: 1.125rem;
    padding: 0.875rem;
  }
}
