.contact {
  font-family: friendly-plain;
  font-size: 150%;
  letter-spacing: 0.125rem;
}

.contact h2 {
  font-family: friendly-bold;
  font-size: 300%;
  letter-spacing: 0.1875rem;
  width: 100%;
  margin-bottom: 1rem;
}

/* Form Styling */
#contact-form {
  width: 100%;
  max-width: 42rem;
}

.form-group {
  display: grid;
  grid-template-columns: 7rem 1fr;
  align-items: end;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.75rem;
}

.form-group label {
  margin: 0;
  min-width: 0;
  font-family: friendly-bold;
}

.contact textarea {
  color: var(--blue);
  letter-spacing: 2px;
  border-radius: 0.3125rem;
  border: 1px solid var(--yellow);
  font: inherit;
  padding: 0.75rem;
  min-height: 7.5rem;
  resize: vertical;
  font-size: 1rem;
  box-sizing: border-box;
  width: 100%;
}

.contact input[type="text"],
.contact input[type="email"] {
  color: var(--red);
  letter-spacing: 2px;
  border-radius: 0.3125rem;
  border: 1px solid var(--yellow);
  font: inherit;
  padding: 0.75rem;
  font-size: 1rem;
  box-sizing: border-box;
  width: 100%;
}

.contact input[readonly] {
  color: var(--yellow);
  background-color: rgba(255, 255, 255, 0.05);
  cursor: not-allowed;
}

.contact input[type="submit"] {
  background-color: var(--blue);
  color: var(--black);
  font: inherit;
  letter-spacing: inherit;
  padding: 0.75rem 2rem;
  font-size: 1rem;
  border: none;
  border-radius: 0.3125rem;
  cursor: pointer;
  width: 100%;
  transition: background-color 0.3s;
}

.contact input[type="submit"]:hover {
  background-color: var(--blue-transparent);
}

.contact input:focus,
.contact textarea:focus {
  outline: none;
  border-color: var(--green);
  box-shadow: 0 0 0.3125rem var(--green-transparent);
}

.response-message {
  margin-top: 1rem;
  padding: 0.75rem;
  border-radius: 0.3125rem;
  background-color: rgba(0, 176, 80, 0.2);
  color: var(--green);
  border: 1px solid var(--green);
}

/* Responsive adjustments for larger screens */
@media (max-width: 40rem) {
  .form-group {
    grid-template-columns: 1fr;
  }

  .contact h2 {
    font-size: 220%;
  }

  .contact {
    font-size: 125%;
  }
}
