.form-and-info {
    display: flex;
    margin-top: 1.5vw;
    margin-bottom: 4vw;
}

.span-2 {
    grid-column: span 2;
}

.span-3 {
    grid-column: span 3;
}

.contact-form {
    flex-grow: 1;
}

.contact-form form {
    display: grid;
    grid-template-columns: calc(50% - 1.5rem) calc(22% - 1.5rem) 28%;
    padding: 1.5rem;
    grid-column-gap: 1.5rem;
    grid-row-gap: 2rem;
    border: 1px solid rgb(191 191 191);
    box-shadow: 0.15em 0.15em 0.3em rgba(0, 0, 0, 0.3);
}

.info {
    width: 19ch;
    padding-left: 2.5rem;
}

.info p {
    font-size: 0.9em;
    margin-bottom: 0.2em;
}

.info > div:first-child h5:first-child {
    margin-top: 0;
}

.info address {
    letter-spacing: initial;
}

.info .socials {
    width: 4.7em;
    display: flex;
    justify-content: space-between;
}

.info .socials a {
    transition: opacity 0.2s;
}

.info .socials a:hover {
    opacity: 0.8;
}

input[type='submit'] {
    display: block;
    width: auto;
    margin: 0 auto 0.5em;
    padding: 0.8em 1.2em 0.7em 1.4em;
    border: none;
    font-size: 0.74em;
    font-weight: 200;
    background-color: var(--black);
    color: var(--white);
    text-transform: uppercase;
    box-shadow: 0.15em 0.15em 0.3em rgba(0, 0, 0, 0.3);
    transition: background-color 0.2s;
}

input[type='submit']:hover {
    background-color: var(--gray);
}

label {
    color: var(--gray);
    display: block;
    font-weight: 400;
    font-size: 0.75em;
    letter-spacing: 0.05em;
    margin-bottom: 0.1em;
}

.specific-label {
    height: 0;
    font-size: max(12px, 0.6em);
    color: rgb(191 191 191);
    margin-top: -0.15em;
    letter-spacing: 0.1em;
}

input,
textarea,
select {
    box-sizing: border-box;
    color: var(--gray);
    text-align: left;
    width: 100%;
    font-size: 0.7em;
    padding: 0.75em 0.5em;
    border: 1px solid rgb(191 191 191);
    background-color: rgb(242 242 242);
}

:is(input, textarea, select).error {
    border-color: rgb(168 81 79);
}

:is(input, textarea, select):focus,
:is(input, textarea, select):focus-visible {
    border-color: var(--black);
    outline: none;
}

input[type="checkbox"],
input[type="radio"] {
    width: auto;
}

textarea {
    display: block;
    resize: vertical;
}

.grecaptcha-badge {
    bottom: 4.5em !important;
}

.alert-success,
.alert-failure {
    font-size: max(0.8em, 12px);
    flex-grow: 1;
    align-self: flex-start;
}

.alert-success {
    background-color: var(--cream);
    border: 1px solid rgb(197, 195, 190);
    color: rgb(163, 162, 157);
    padding: 0.5em 1em;
}

.alert-failure {
    background-color: rgb(224 144 142);
    border: 1px solid rgb(168 81 79);
    color: rgb(117 57 55);
    padding-right: 1em;
}

.contact-sm-show {
    display: none;
}

@media (max-width: 1128px) {
    .form-and-info {
        flex-direction: column;
    }

    .info {
        width: 100%;
        font-size: 1.1em;
        box-sizing: border-box;
        display: flex;
    }

    .info > div {
        box-sizing: border-box;
        flex-grow: 1;
        padding-right: 4vw;
    }

    .info :is(h5, p) {
        margin-bottom: 0;
    }

    .contact-form {
        margin-bottom: 5vh;
    }
}

@media (max-width: 1128px) and (min-width: 801px) {
    .info h5:first-child {
        margin-top: 0;
    }
}

@media (max-width: 800px) {
    .contact-sm-hide {
        display: none;
    }

    .contact-sm-show {
        display: initial;
    }

    .contact-form form {
        grid-template-columns: calc(50% - 0.75rem) calc(50% - 0.75rem);
        grid-row-gap: 1rem;
    }

    .span-2,
    .span-3 {
        grid-column: span 1;
    }

    .contact-sm-span-2 {
        grid-column: span 2;
    }

    .info {
        flex-direction: column;
    }

    .info h5 {
        margin-top: 1em;
    }

    address {
        margin-bottom: 0;
    }

    .alert-success {
        padding: 0.25em 0.5em;
    }

    .alert-failure {
        padding-right: 0.5em;
    }
}

@media (max-width: 536px) {
    .info {
        padding-left: 0.5rem;
    }
}

@media (max-width: 500px) {
    .contact-form form {
        grid-row-gap: 0.5rem;
    }

    label {
        font-size: 0.7em;
    }
}

@media (max-width: 470px) {
    .contact-form form {
        grid-template-columns: 100%;
    }

    .contact-sm-span-2 {
        grid-column: span 1;
    }
}
