/* hero  */

.contact-hero {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 64px 32px;
    background-image:
        linear-gradient(rgba(18, 73, 159, 0.75), rgba(18, 73, 159, 0.75)),
        url('https://newclientsitepreview.com/wp-content/uploads/2026/04/bsp-example-contact-bg.png');
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat;
}

@media (max-width: 1024px) {
    .contact-hero .wrapper {
        flex-direction: column;
    }
    .contact-hero .wrapper .content, .contact-hero .wrapper .contact-form {
        width: 100%!important;
    }
}

@media (max-width: 767px) {
    .contact-hero {
        padding: 32px 16px!important;
    }
    .contact-hero .wrapper .contact-form .cf-wrapper .form-row {
        flex-direction: column;
    }
    .contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry {
        width: 100%!important;
    }
}

.contact-hero .wrapper {
    max-width: 1200px;
    width: 100%;
    display: flex;
    gap: 40px;
}

.contact-hero .wrapper .content {
    width: 50%;
    color: var(--white);
}

.contact-hero .wrapper .content h1 {
    font-size: 18px;
    margin: 0;
}

.contact-hero .wrapper .content h2 {
    font-size: 40px;
    margin-top: 8px;
    margin-bottom: 20px;
}

.contact-hero .wrapper .content h4 {
    font-size: 26px;
    margin-top: 0;
    margin-bottom: 16px;
}

.contact-hero .wrapper .content p {
    margin: 0;
    font-size: 18px;
}

.contact-hero .wrapper .contact-form {
    width: 50%;
}

.contact-hero .wrapper .contact-form .cf-wrapper {
    padding: 20px;
    border-radius: 8px;
    background-color: var(--white);
}

.contact-hero .wrapper .contact-form .cf-wrapper form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row {
    width: 100%;
    display: flex;
    gap: 20px;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry {
    display: flex;
    flex-direction: column;
    width: 50%;
    position: relative;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry.error::before {
    position: absolute;
    content: '';
    left: -12px;
    width: 6px;
    background-color: red;
    height: 100%;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry label {
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 6px;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry .input-wrapper {
    position: relative;
    width: 100%;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry .input-wrapper .icon-wrapper {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry .input-wrapper .icon-wrapper svg {
    width: 100%;
    height: auto;
    max-width: 100%;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry .input-wrapper input {
    width: 100%;
    height: 54px;
    border: 1px solid var(--blue-light);
    border-radius: 6px;
    padding-left: 40px;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry .error-message {
    color: red;
    font-size: 13px;
    font-weight: bold;
    margin-top: 6px;
}


.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry.message {
    width: 100%;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .form-entry.message textarea {
    width: 100%;
    border: 1px solid var(--blue-light);
    border-radius: 6px;
    padding: 12px;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .submit-wrapper.form-entry {
    width: 100%; 
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .submit-wrapper.form-entry button {
    width: 100%;
    height: 54px;
    border: 2px solid var(--orange-primary);
    border-radius: 6px;
    background-color: var(--orange-primary);
    padding: 24px 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 700;
    color: var(--white);
    cursor: pointer;
    font-size: 16px;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .submit-wrapper.form-entry button:disabled {
    background-color: grey!important;
    border: 2px solid transparent;
    cursor: not-allowed;
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .submit-wrapper.form-entry button:disabled:hover {
    border: 2px solid transparent;
    color: var(--white);
}

.contact-hero .wrapper .contact-form .cf-wrapper .form-row .submit-wrapper.form-entry button:hover {
    background-color: transparent;
    color: var(--black);
    border: 2px solid var(--orange-primary);
}

/* end of hero  */

/* info area  */

.info-area {
    padding: 64px 32px;
    display: flex;
    justify-content: center;
    width: 100%;
    background-color: var(--off-white);
}

@media (max-width: 767px) {
    .info-area {
        padding: 32px 16px!important;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .info-area .wrapper .card-grid {
        grid-template-columns: repeat(2,1fr)!important;
    }
}

@media (max-width: 767px) {
    .info-area .wrapper .card-grid {
        grid-template-columns: repeat(1,1fr)!important;
    }
}

@media (max-width: 576px) {
    .info-area .wrapper .card-grid .card .card-info .info-inner {
        font-size: clamp(14px, 4vw, 16px);
    }
}
 
.info-area .wrapper {
    max-width: 1200px;
    width: 100%;
}

.info-area .wrapper .card-grid {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3,1fr);
    align-items: stretch;
    gap: 20px;
}

.info-area .wrapper .card-grid .card {
    background-color: var(--white);
    border-radius: 6px;
    width: 100%;
    padding: 20px;
}

.info-area .wrapper .card-grid .card .icon-wrapper {
    width: 64px;
    height: 64px;
    background-color: var(--blue-primary);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.info-area .wrapper .card-grid .card .icon-wrapper svg {
    width: 24px;
    min-width: 24px;
    height: 24px;
    max-width: 100%;
}

.info-area .wrapper .card-grid .card .card-info {
    width: 100%;
}

.info-area .wrapper .card-grid .card .card-info .title {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 20px;
    margin-top: 0;
}

.info-area .wrapper .card-grid .card .card-info .info-inner {
    width: 100%;
}

.info-area .wrapper .card-grid .card .card-info .info-inner ul {
    padding: 0;
    margin: 0;
    list-style-type: none;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.info-area .wrapper .card-grid .card .card-info .info-inner ul li {
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.info-area .wrapper .card-grid .card .card-info .info-inner .ctas-wrapper {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.info-area .wrapper .card-grid .card .card-info .info-inner .ctas-wrapper a {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--blue-dark);
    text-decoration: none;
}

.info-area .wrapper .card-grid .card .card-info .info-inner .ctas-wrapper a:hover {
    text-decoration: underline;
}

.info-area .wrapper .card-grid .card .card-info .info-inner .ctas-wrapper svg {
    width: 20px;
    min-width: 20px;
    height: 20px;
}

.info-area .wrapper .card-grid .card .card-info .info-inner .resources-list {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.info-area .wrapper .card-grid .card .card-info .info-inner .resources-list a {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--blue-dark);
    text-decoration: none;
}

.info-area .wrapper .card-grid .card .card-info .info-inner .resources-list a:hover {
    text-decoration: underline;
}


/* gmap  */

.info-area .wrapper .gmap-container {
    width: 100%;
    margin-top: 32px;
}

.info-area .wrapper .gmap-container .wrapper {
    width: 100%;
    border-radius: 16px;
    background-color: var(--white);
    padding: 16px;
    overflow: hidden;
}

.info-area .wrapper .gmap-container .wrapper iframe {
    width: 100%;
    border-radius: 16px;
}

/* end of info area  */