form#contact-form {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  width: 100%;
  font-size: max(100%, 16px);
}

form#contact-form label {
  font-weight: 600;
  margin-top: 0.5em;
}

form#contact-form input,
form#contact-form textarea {
  font-size: inherit;
  padding: 0.6em 0.8em;
  border: 1px solid var(--comment);
  border-radius: 0.4em;
  background: var(--background);
  color: var(--foreground);
  transition: border-color 0.2s ease;
}

form#contact-form input:focus,
form#contact-form textarea:focus {
  outline: none;
  border-color: var(--purple);
}

form#contact-form textarea {
  min-height: 14em;
  resize: vertical;
}

form#contact-form button {
  font-size: inherit;
  margin-top: 0.75em;
  padding: 0.6em 1.5em;
  font-weight: 600;
  border: 1px solid var(--purple);
  border-radius: 0.4em;
  background: transparent;
  color: var(--purple);
  cursor: pointer;
  transition: all 0.2s ease;
}

form#contact-form button:hover:not(:disabled) {
  background: var(--purple);
  color: var(--background);
}

form#contact-form button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

#success-message,
#error-message {
  text-align: center;
  padding: 1.5em;
  border: 1px solid var(--comment);
  border-radius: 0.4em;
}

#success-message {
  border-color: var(--purple);
  color: var(--purple);
}

#error-message {
  border-color: var(--red);
  color: var(--red);
}
