section.contact-form {
    padding: 0 12vh 12vh;
}

.contact-text {
    text-align: center;
    padding: 5vh;
}

.form-container {
    border-radius: 10px;
    background-color: #FBFBFB;
    border: 3px solid #aaa;
    padding: 40px;
    width: 30vw;
    margin: auto;
}

input[type=text], select, textarea {
  width: 100%;
  padding: 12px;
  border: 1px solid #ccc;
  border-radius: 10px;
  box-sizing: border-box;
  margin-top: 6px;
  margin-bottom: 16px;
  resize: vertical;
  background-color: #F3F3F3;
}

input[type=submit] {
    background-color: #0066FF;
    color: white;
    padding: 20px 20px;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    width: 100%;
    font-size: 15pt;
}

input[type=submit]:hover {
  background-color: #0066FF;;
}

h3.text {
    color: gray;
    font-weight: 400;
}

@media screen and (max-width: 960px) {
    .form-container {
        width: 45vw;
    }

}
@media screen and (max-width: 768px) {
    .form-container {
        font-size: 15pt;
        border-radius: 10px;
        padding: 40px;
        margin: auto;
        width: 75vw;
    }

    section.contact-form {
        display: initial;
        padding: 5vh;
    }

    input[type=submit] {
        font-size: 15pt;
    }

}
