:root {
    --vhs: calc(var(--vh, 1vh) * 100);
}

.map-section {
    margin-top: 10rem;
}

.websima-map.google-map-container {
    position: relative;
}

.google-map-iframe {
    min-height: 405px;
    width: 100%;
}

.google-map-iframe .gm-style .place-card-large {
    display: none;
}

.contact-dir-logos {
    display: flex;
    align-items: center;
    gap: 1.4rem;
    position: absolute;
    top: 1.6rem;
    right: 2.4rem;
}

.contact-dir-logos a {
    width: 7.2rem;
    height: 7.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fff;
    transition: 0.3s;
}

.contact-dir-logos a img {
    max-width: 32px;
    max-height: 32px;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.contact-dir-logos a:hover {
    transform: scale(1.1);
}

.contact-info {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.4rem;
    margin: 2rem 0;
}

.contact-info .phone,
.contact-info .email-fax,
.contact-info .time-contact,
.contact-info .address {
    background-color: #E7F2F8;
    padding: 2.4rem 2.4rem 2.8rem;

    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1rem;
}

@media(width>=768px) {

    .contact-info .phone,
    .contact-info .email-fax,
    .contact-info .time-contact,
    .contact-info .address {
        min-height: 30rem;
    }
}

.contact-info .phone .label,
.contact-info .email-fax .label,
.contact-info .time-contact .label,
.contact-info .address .label {
    color: #000000;
    font-size: 2.4rem;
    font-weight: 500;

}

.contact-info .phone .sublabel,
.contact-info .email-fax .sublabel,
.contact-info .time-contact .sublabel,
.contact-info .address .sublabel {
    color: #697F8D;
    font-size: 14px;

}

.contact-info .phone .phone-numbers,
.contact-info .email-fax .email-fax-content {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.contact-info .phone .phone-numbers .info-txt,
.contact-info .email-fax .email-fax-content .info-txt,
.contact-info .time-contact .info-txt,
.contact-info .address .info-txt {
    color: #000000;
    font-size: clamp(14px, 2vw, 17px);
    font-weight: 600;
    transition: 0.3s;
}

.contact-info .phone .phone-numbers .info-txt:hover,
.contact-info .email-fax .email-fax-content a.info-txt:hover,
.contact-info .address .info-txt:hover {
    color: var(--c-primary);
}

.contact-info-icon i {
    width: 6.4rem;
    height: 6.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #D8E9F2;
    font-size: 2.4rem;
    color: #5B707C;
}

.contact-info-content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.contact-page-socials {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 7.2rem;
    background-color: #E7F2F8;
    padding: 0 3.2rem;
}

.contact-page-socials span {
    font-size: 1.8rem;
    color: #697F8D;
    display: none;
}

@media(width>=768px) {
    .contact-page-socials span {
        display: block;
    }
}

.contact-page-socials .contact-page-socials-list {
    display: flex;
    align-items: center;
    gap: 24px;
}

.contact-page-socials .contact-page-socials-list a {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: clamp(20px, 2vw, 24px);
    color: #697F8D;
    transition: 0.3s;
}

.contact-page-socials .contact-page-socials-list a:hover {
    color: var(--c-primary);
}

@media screen and (max-width: 767.99px) {
    .contact-info {
        grid-template-columns: repeat(1, 1fr);
    }
}

@media screen and (max-width: 991.99px) {
    .websima-form-wrap .input-cform.right {
        margin-bottom: 4.5rem;
    }
}

@media screen and (min-width: 768px) and (max-width: 1200px) {
    .contact-info {
        grid-template-columns: repeat(2, 1fr);
    }
}

/**************************/
/* forms */
/**************************/
.cform-desc {
    text-align: center;
    color: #697F8D;
    margin: 1.8rem 0 4.5rem;
}

@media(width>=768px) {
    .cform-desc {
        margin: 1.8rem auto 4.5rem;
        max-width: 50%;
    }

}

.websima-form-wrap.wocommerce-form :is(input[type="text"],
    input[type="email"],
    input[type="number"],
    input[type="tel"],
    input[type="password"],
    input[type="search"],
    input[type="url"],
    textarea,
    select,
    .select2) {
    margin-bottom: 4rem;
}

.websima-form-wrap :is(input[type="text"],
    input[type="email"],
    input[type="number"],
    input[type="tel"],
    input[type="password"],
    input[type="search"],
    input[type="url"],
    textarea,
    select,
    .select2) {
    font-family: inherit;
    padding: 2.4rem 2rem !important;
    height: 7rem;
    background-color: #fff;
    border: 1px solid #D3E4ED;
    transition: 0.3s;
    width: 100%;
    text-overflow: ellipsis;
    position: relative;
    display: block;
}

.websima-form-wrap textarea {
    min-height: 25rem;
}

.websima-form-wrap select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 1.5rem !important;
    background-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 10.8L3.2 6L4.6 4.6L8 8L11.4 4.6L12.8 6L8 10.8Z' fill='%23878787'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1.5rem center;
    background-size: 16px 16px;
}

.websima-form-wrap .acf-error :is(input[type="text"],
    input[type="email"],
    input[type="number"],
    input[type="tel"],
    input[type="password"],
    input[type="search"],
    input[type="url"],
    textarea,
    select,
    .select2) {
    border: 1px solid #B00020;
}

.websima-form-wrap :is(input[type="email"],
    input[type="number"],
    input[type="tel"],
    input[type="password"],
    input[type="url"]) {
    direction: ltr;
}

.websima-form-wrap form.submitted :is(input[type="text"],
    input[type="email"],
    input[type="number"],
    input[type="tel"],
    input[type="password"],
    input[type="search"],
    input[type="url"],
    textarea,
    select,
    .select2):invalid:required {
    border-color: var(--danger);
}

.websima-form-wrap .af-submit,
.af-field-type-repeater,
.af-field-type-textarea {
    grid-column: 1/-1;
}

.websima-form-wrap .acf-field-recaptcha {
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.websima-form-wrap.ab-label .acf-field-recaptcha .acf-label label {
    position: static !important;
    transform: none !important;
    margin-bottom: 1rem !important;
    display: block !important;
}

.websima-form-wrap :is(input[type="text"],
    input[type="email"],
    input[type="number"],
    input[type="tel"],
    input[type="password"],
    input[type="search"],
    input[type="url"],
    textarea,
    select,
    .select2):focus-visible {
    border-color: #636466;
}

.websima-form-wrap :is(textarea, input)::-webkit-input-placeholder,
.websima-form-wrap :is(textarea, input)::-webkit-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-moz-placeholder,
.websima-form-wrap :is(textarea, input)::-moz-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input):-ms-input-placeholder,
.websima-form-wrap :is(textarea, input):-ms-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-ms-input-placeholder,
.websima-form-wrap :is(textarea, input)::-ms-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-webkit-input-placeholder,
.websima-form-wrap :is(textarea, input)::-webkit-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-moz-placeholder,
.websima-form-wrap :is(textarea, input)::-moz-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input):-ms-input-placeholder,
.websima-form-wrap :is(textarea, input):-ms-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-ms-input-placeholder,
.websima-form-wrap :is(textarea, input)::-ms-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-webkit-input-placeholder,
.websima-form-wrap :is(textarea, input)::-webkit-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-moz-placeholder,
.websima-form-wrap :is(textarea, input)::-moz-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input):-ms-input-placeholder,
.websima-form-wrap :is(textarea, input):-ms-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::-ms-input-placeholder,
.websima-form-wrap :is(textarea, input)::-ms-input-placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap :is(textarea, input)::placeholder,
.websima-form-wrap :is(textarea, input)::placeholder {
    opacity: 0.5;
    font-size: 13px;
    text-align: left;
}

.websima-form-wrap label:not(.error, [for="acf-field_form_success_message"]) {

    display: flex;
    margin: 0;
    align-items: center;
    margin-bottom: 12px !important;
    font-size: 15px;
    line-height: 1px;
    font-weight: unset !important;
}

.websima-form-wrap label.error {
    line-height: 1;
    font-size: 12px;
    color: var(--danger);
    margin-bottom: 1rem;
    display: block;
    background: var(--bg-danger);
    padding: 10px;
}

.websima-form-wrap.ab-label :is(.af-field-type-repeater,
    .af-field-type-checkbox,
    .af-field-type-true-false,
    .af-field-type-radio) label {
    position: static;
    transform: none;
    margin-bottom: 1.5rem !important;
    padding-inline: 0rem;
    background: transparent;
}

.websima-form-wrap .acf-field .acf-label {
    margin: 0;
}

.websima-form-wrap .acf-temp-remove,
.websima-form-wrap .acf-notice.-error {
    background: #fff;
    color: #B00020;
    border-color: rgba(26, 26, 26, 0.12);
    margin: 0;
    z-index: 1;
    line-height: 1;
    padding: 0;
}

.websima-form-wrap .acf-notice p {
    font-size: 10px;
    line-height: 1;
    margin: 0;
    margin-bottom: 0px;
    text-shadow: none;
    color: #B00020;
    position: absolute;
    bottom: -72px;
    left: 2rem;
}

.websima-form-wrap .acf-notice p:before {
    content: '';
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='25' viewBox='0 0 24 25' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 23.0293C6.07 23.0293 1.25 18.2093 1.25 12.2793C1.25 6.3493 6.07 1.5293 12 1.5293C17.93 1.5293 22.75 6.3493 22.75 12.2793C22.75 18.2093 17.93 23.0293 12 23.0293ZM12 3.0293C6.9 3.0293 2.75 7.1793 2.75 12.2793C2.75 17.3793 6.9 21.5293 12 21.5293C17.1 21.5293 21.25 17.3793 21.25 12.2793C21.25 7.1793 17.1 3.0293 12 3.0293Z' fill='%23B00020'/%3E%3Cpath d='M12 14.0293C11.59 14.0293 11.25 13.6893 11.25 13.2793V8.2793C11.25 7.8693 11.59 7.5293 12 7.5293C12.41 7.5293 12.75 7.8693 12.75 8.2793V13.2793C12.75 13.6893 12.41 14.0293 12 14.0293Z' fill='%23B00020'/%3E%3Cpath d='M12 17.2792C11.87 17.2792 11.74 17.2492 11.62 17.1992C11.5 17.1492 11.39 17.0792 11.29 16.9892C11.2 16.8892 11.13 16.7892 11.08 16.6592C11.03 16.5392 11 16.4092 11 16.2792C11 16.1492 11.03 16.0192 11.08 15.8992C11.13 15.7792 11.2 15.6692 11.29 15.5692C11.39 15.4792 11.5 15.4092 11.62 15.3592C11.86 15.2592 12.14 15.2592 12.38 15.3592C12.5 15.4092 12.61 15.4792 12.71 15.5692C12.8 15.6692 12.87 15.7792 12.92 15.8992C12.97 16.0192 13 16.1492 13 16.2792C13 16.4092 12.97 16.5392 12.92 16.6592C12.87 16.7892 12.8 16.8892 12.71 16.9892C12.61 17.0792 12.5 17.1492 12.38 17.1992C12.26 17.2492 12.13 17.2792 12 17.2792Z' fill='%23B00020'/%3E%3C/svg%3E%0A");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: absolute;
    left: -19px;
    width: 15px;
    height: 16px;
    top: -3px;
}

.websima-form-wrap .acf-notice.-error {
    display: flex;
    align-items: center;
    gap: 5px;
}

.websima-form-wrap .acf-notice.-dismiss {
    display: none;
}

.acf-spinner {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    margin-right: 9px;
}

.acf-form .acf-fields>.acf-field {
    border: none;
    padding: 0;
    margin-bottom: 4.2rem;
}

.websima-form-wrap .af-submit {
    margin-top: -2rem;
}

.websima-form-wrap .af-field-type-textarea textarea {
    padding-top: 2rem;
}

.af-form.acf-form>.acf-fields {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    row-gap: 2rem;
    margin-bottom: 2.5rem;
}

.item-set.vertical.centered.triggers.left {
    display: none;
}

.acf-notice.-error.acf-error-message.-dismiss {
    display: none;
}

@container (min-width: 32em) {
    .af-form.acf-form>.acf-fields {
        grid-template-columns: 1fr 1fr;
    }
}

@container (max-width: 32em) {
    .af-form.acf-form>.acf-fields {
        grid-template-columns: 1fr;
    }
}

.websima-form-wrap input:-webkit-autofill,
.websima-form-wrap input:-webkit-autofill:active,
.websima-form-wrap input:-webkit-autofill:hover,
.websima-form-wrap input:-webkit-autofill:focus {
    -webkit-animation-name: autofill;
    -webkit-animation-delay: 1s;
    -webkit-animation-fill-mode: both;
    -webkit-box-shadow: 0 0 0 100px rgba(0, 0, 0, 0.09) inset !important;
    -webkit-box-shadow: none;
}

.acf-form-submit {
    text-align: center;
    position: relative;
    margin-top: -2rem;
}

.af-field-type-file label {

    position: static;
    margin-bottom: 1rem !important;
}

.websima-form-wrap label:not(.error, [for="acf-field_form_success_message"]) {
    line-height: 16px;
    color: #636466;
    position: absolute;
    z-index: 2;
    background-color: #fff;
    padding: 0 10px !important;
    left: 10px;
    top: -8px;
    font-weight: 600 !important;
}

.websima-form-wrap .updated {
    background-color: var(--success);
    color: #FFFFFF;
    padding: 1rem 1.5rem;
    text-align: center;
    margin-bottom: 2.5rem;
}

@media screen and (max-width: 767.99px) {

    .cform-desc {
        max-width: 100%;
    }

    .contact-page-socials {
        justify-content: center;
    }
}

@media screen and (min-width: 62em) {

    .websima-form-wrap .input-cform.right {
        float: left;
        width: calc((100% / 2));
        clear: none !important;
        padding: 0 0 0 5px !important;
    }

    .websima-form-wrap .input-cform.left {
        float: left;
        width: calc((100% / 2));
        clear: none !important;
        padding: 0 5px 0 0 !important;
    }

    .websima-form-wrap .acf-notice p {
        font-size: 12px;
        bottom: -92px;
    }

    .websima-form-wrap .acf-notice p:before {
        width: 16px;
        height: 15px;
    }
}

/**************************/
/* Splash Hero Elements */
/**************************/
.contact-form-section {
    position: relative;
}

.splash-hero-left {
    position: absolute;
    z-index: 40;
    width: 70%;
    top: calc(100% - 24vw);
    left: -31%;
    pointer-events: none;
}

.splash-hero-left img {
    transform: rotate(8deg) scaleY(-1);
}

.splash-hero-right {
    display: none;
}

@media (width>=1200px) {
    .splash-hero-left {
        width: 37vw;
        top: calc(100% - 24vw);
        left: -2%;
        opacity: 0;
        transform: scale(1) rotate(0deg) translateX(-10%) translateY(100%);
        transform-origin: 100% 50%;
    }

    .splash-hero-left img {
        transform: rotate(11deg);
    }

    .splash-hero-right {
        position: absolute;
        z-index: 40;
        width: 25vw;
        bottom: calc(0% - 3vw);
        right: 0%;
        opacity: 0;
        transform: scale(2) rotate(20deg) translateX(10%) translateY(80%);
        transform-origin: 0% 50%;
        pointer-events: none;
        display: block;
    }
}