.joshmon27-contact-form-wrap {
    max-width: 640px;
    padding: 20px;
    border: 1px solid #d0d7de;
    border-radius: 6px;
    background: #ffffff;
}

.joshmon27-contact-form {
    display: grid;
    gap: 10px;
}

.joshmon27-contact-form label {
    font-weight: 600;
}

.joshmon27-contact-form input,
.joshmon27-contact-form textarea {
    width: 100%;
    padding: 10px;
    border: 1px solid #b0b7bf;
    border-radius: 4px;
    box-sizing: border-box;
}

.joshmon27-contact-form button {
    width: fit-content;
    padding: 10px 18px;
    border: 0;
    border-radius: 4px;
    background: #135e96;
    color: #ffffff;
    font-weight: 600;
    cursor: pointer;
}

.joshmon27-contact-form-notice {
    margin-bottom: 12px;
    padding: 10px 12px;
    border-radius: 4px;
    font-weight: 600;
}

.joshmon27-contact-form-notice.success {
    color: #1d4d2f;
    background: #daf5e0;
    border: 1px solid #9ed8ad;
}

.joshmon27-contact-form-notice.error {
    color: #6a1f20;
    background: #fce4e4;
    border: 1px solid #f2b2b3;
}

.joshmon27-contact-form-hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}
