#footer.footer,
#footer.newsletter-active {
    position: relative;
    margin-top: 86px !important;
    overflow: visible;
    background: linear-gradient(180deg, #f8fafc 0%, #eef3f9 100%) !important;
    border-top: 1px solid #e3e8ef !important;
    color: #24242e;
    font-family: "Nunito Sans", sans-serif;


}

#footer .footer-bottom .copyright {
    display: block !important;
    gap: 0 !important;
    white-space: normal !important;
}

#footer .footer-bottom .copyright .cookies-settings,
#footer .footer-bottom .copyright a.cookies-settings {
    display: inline-block !important;
    margin-left: 18px !important;
}

@media (max-width: 767px) {

    #footer .footer-bottom .copyright .cookies-settings,
    #footer .footer-bottom .copyright a.cookies-settings {
        display: block !important;
        margin-left: 0 !important;
        margin-top: 6px !important;
    }
}

#footer .newsletter::before,
#footer .custom-footer__newsletter.extended.newsletter::before {
    opacity: 0.045 !important;
    filter: none !important;
}

@media (max-width: 991px) {

    #footer .newsletter::before,
    #footer .custom-footer__newsletter.extended.newsletter::before {
        opacity: 0.032 !important;
        filter: none !important;
    }
}

@media (max-width: 767px) {

    #footer .newsletter::before,
    #footer .custom-footer__newsletter.extended.newsletter::before {
        opacity: 0.028 !important;
        filter: none !important;
    }
}

#footer .newsletter::before,
#footer .custom-footer__newsletter.extended.newsletter::before {
    right: -112px !important;
}

#footer #formNewsletterWidget input[type="email"].form-control {
    padding-right: 180px !important;
}

@media (max-width: 991px) {

    #footer .newsletter::before,
    #footer .custom-footer__newsletter.extended.newsletter::before {
        right: -82px !important;
        top: 14px !important;
        width: 360px !important;
        height: 126px !important;
        opacity: 0.068 !important;
        transform: rotate(-7deg) !important;
    }
}

@media (max-width: 767px) {

    #footer .newsletter::before,
    #footer .custom-footer__newsletter.extended.newsletter::before {
        right: -70px !important;
        top: -7px !important;
        width: 283px !important;
        height: 230px !important;
        opacity: 0.052 !important;
        transform: rotate(-7deg) !important;
    }

    #footer .footer-bottom {
        padding: 16px 12px 22px !important;
    }

    #footer .footer-bottom .copyright {
        margin: 10px 0 0 !important;
        line-height: 1.55 !important;
    }

    #footer .custom-footer>div.click-able:not(.contact) h3::after,
    #footer .custom-footer>div.click-able:not(.contact) h4::after {
        right: 2px !important;
        font-size: 9px !important;
    }

    #footer .custom-footer>div.click-able::after,
    #footer .custom-footer>div.click-able::before,
    #footer .footer-bottom::after,
    #footer .footer-bottom::before,
    #footer #signature::after,
    #footer .footer-bottom .copyright::after {
        display: none !important;
        content: none !important;
    }
}

#footer.footer::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 1px;
    background: linear-gradient(90deg, rgba(36, 79, 136, 0), rgba(36, 79, 136, 0.22), rgba(36, 79, 136, 0));
    pointer-events: none;
}

#footer .footer-rows,
#footer .footer-bottom {
    position: relative;
    z-index: 1;
}

#footer .newsletter,
#footer .custom-footer__newsletter.extended.newsletter {
    position: relative;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 30px 38px !important;
    overflow: hidden;
    border-radius: 5px;
    background:
        linear-gradient(105deg, rgba(17, 19, 25, 0.985) 0%, rgba(25, 42, 68, 0.97) 58%, rgba(36, 79, 136, 0.94) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    box-shadow: 0 16px 36px rgba(20, 43, 73, 0.14) !important;
}

#footer .newsletter::before,
#footer .custom-footer__newsletter.extended.newsletter::before {
    content: "";
    position: absolute;
    right: -76px;
    top: 50%;
    width: 500px;
    height: 176px;
    background: url("/user/documents/upload/HELLO_COMP_Kreslicí_platno_BIG_white.png") center / contain no-repeat;
    opacity: 0.115;
    transform: translateY(-50%) rotate(-7deg);
    transform-origin: center;
    pointer-events: none;
}

#footer .newsletter::after,
#footer .custom-footer__newsletter.extended.newsletter::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 88% 50%, rgba(0, 114, 198, 0.22), transparent 30%),
        linear-gradient(90deg, rgba(255, 255, 255, 0.020) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255, 255, 255, 0.014) 1px, transparent 1px);
    background-size: auto, 46px 46px, 46px 46px;
    opacity: 0.24;
    pointer-events: none;
}

#footer .newsletter-header,
#footer .newsletter form,
#footer #formNewsletterWidget {
    position: relative;
    z-index: 1;
}

#footer .newsletter .newsletter-header,
#footer .custom-footer__newsletter .newsletter-header {
    flex: 0 0 430px !important;
    width: 430px !important;
    max-width: 430px !important;
    min-width: 0 !important;
    padding: 0 !important;
    float: none !important;
    text-align: left !important;
}

#footer .newsletter h3,
#footer .newsletter h4,
#footer .custom-footer__newsletter .topic,
#footer .newsletter-header .pageElement__heading {
    display: block !important;
    max-width: 430px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #ffffff !important;
    font-size: 24px !important;
    line-height: 1.3 !important;
    font-weight: 400 !important;
    letter-spacing: 0.01em;
    text-transform: none !important;
    text-align: left !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
}

#footer .newsletter h3 br,
#footer .newsletter h4 br,
#footer .newsletter-header .pageElement__heading br {
    display: none !important;
}

#footer .newsletter h3::after,
#footer .newsletter h4::after,
#footer .newsletter-header .pageElement__heading::after {
    content: "";
    display: block !important;
    width: 88px;
    height: 2px;
    margin-top: 14px;
    border-radius: 999px;
    background: linear-gradient(90deg, #0072c6, rgba(0, 114, 198, 0)) !important;
}

#footer .newsletter form,
#footer .custom-footer__newsletter #formNewsletterWidget {
    flex: 1 1 620px !important;
    width: auto !important;
    max-width: 700px !important;
    min-width: 360px !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
}

#footer #formNewsletterWidget.compact-form,
#footer #formNewsletterWidget fieldset {
    position: relative;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

#footer #formNewsletterWidget .validator-msg-holder {
    display: block !important;
    width: 100% !important;
}

#footer #formNewsletterWidget input[type="email"].form-control {
    width: 100% !important;
    height: 56px !important;
    padding: 0 188px 0 54px !important;
    border: 1px solid rgba(255, 255, 255, 0.22) !important;
    border-radius: 5px !important;
    background: rgba(255, 255, 255, 0.96) !important;
    color: #15171d !important;
    font-size: 15px !important;
    line-height: 56px !important;
    box-shadow: none !important;
}

#footer #formNewsletterWidget input[type="email"].form-control::placeholder {
    color: rgba(21, 23, 29, 0.42) !important;
}

#footer #formNewsletterWidget .validator-msg-holder::before {
    content: "\e910";
    position: absolute;
    left: 21px;
    top: 19px;
    z-index: 2;
    font-family: ikony;
    font-size: 17px;
    line-height: 1;
    color: rgba(21, 23, 29, 0.42);
    pointer-events: none;
}

#footer #formNewsletterWidget br {
    display: none !important;
}

#footer #formNewsletterWidget .consents {
    display: block !important;
    margin: 11px 0 0 !important;
    padding: 0 !important;
    color: rgba(255, 255, 255, 0.76) !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
}

#footer #formNewsletterWidget .consents label {
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(255, 255, 255, 0.76) !important;
    font-weight: 400 !important;
    line-height: 1.45 !important;
}

#footer #formNewsletterWidget .consents label::before,
#footer #formNewsletterWidget .consents label::after {
    display: none !important;
}

#footer #formNewsletterWidget .consents a {
    color: #ffffff !important;
    text-decoration: underline !important;
    text-underline-offset: 3px;
}

#footer .custom-footer.elements-5,
#footer .custom-footer {
    display: grid !important;
    grid-template-columns: minmax(270px, 1.08fr) minmax(190px, 0.92fr) minmax(250px, 1fr) minmax(170px, 0.72fr);
    border: 0 !important;
}

#footer .custom-footer.elements-5>div,
#footer .custom-footer>div,
#footer .custom-footer__contact,
#footer .custom-footer__banner16,
#footer .custom-footer__banner10,
#footer .custom-footer__banner7 {
    float: none !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

#footer .custom-footer .banner,
#footer .custom-footer .banner-wrapper,
#footer .custom-footer .banner-wrapper>span {
    display: block !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    overflow: visible !important;
}

#footer .custom-footer .pageElement__heading,
#footer .custom-footer h3,
#footer .custom-footer h4 {
    position: relative;
    margin: 0 0 20px !important;
    padding: 0 0 13px !important;
    color: #20242d !important;
    font-size: 20px !important;
    line-height: 1.3 !important;
    font-weight: 400 !important;
    letter-spacing: 0.01em;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
}

#footer .custom-footer .pageElement__heading::after,
#footer .custom-footer h3::after,
#footer .custom-footer h4::after {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    bottom: 0 !important;
    display: block !important;
    width: 58px !important;
    height: 2px !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 999px;
    background: linear-gradient(90deg, #244f88, rgba(36, 79, 136, 0)) !important;
    transform: none !important;
}

#footer .contact-box {
    display: block !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    overflow: visible !important;
    background: transparent !important;
    border-radius: 0 !important;
    text-align: left !important;
}

#footer .contact-box .site-name {
    display: block !important;
    position: static !important;
    width: 220px !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 0 0 24px !important;
    padding: 0 !important;
    background: transparent !important;
}

#footer .contact-box .site-name a {
    display: block !important;
    width: 100% !important;
}

#footer .contact-box .site-name img {
    display: block !important;
    width: 100% !important;
    max-width: 220px !important;
    height: auto !important;
    object-fit: contain;
}

#footer .contact-box::before {
    display: none !important;
}

#footer .contact-box ul,
#footer .custom-footer ul {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

#footer .contact-box li,
#footer .custom-footer .banner li,
#footer .custom-footer ul li {
    position: relative;
    margin: 0 0 13px !important;
    color: #3f4652 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
    font-family: "new_font", sans-serif;
}

#footer .custom-footer .banner li,
#footer .custom-footer>div:not(.contact) ul li {
    padding-left: 17px !important;
}

#footer .custom-footer .banner li::before,
#footer .custom-footer>div:not(.contact) ul li::before {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    top: 0.74em !important;
    display: block !important;
    width: 6px !important;
    height: 6px !important;
    border-radius: 50%;
    background: #244f88 !important;
    transform: translateY(-50%);
}

#footer .contact-box li {
    padding-left: 0 !important;
}

#footer .contact-box li::before {
    display: none !important;
}

#footer .contact-box li>span {
    display: inline-flex;
    align-items: center;
    position: relative;
    min-height: 24px;
    padding-left: 32px !important;
    color: #244f88 !important;
    font-weight: 400 !important;
}

#footer .contact-box li>span::before {
    position: absolute;
    left: 0;
    top: 50%;
    width: 22px;
    color: #244f88;
    font-size: 18px;
    text-align: center;
    transform: translateY(-50%);
}

#footer .contact-box li>span.tel {
    display: block;
    line-height: 1.45;
}

#footer .contact-box li>span.tel a {
    display: block;
    width: max-content;
    max-width: 100%;
    margin: 0 0 2px;
    color: #244f88 !important;
    font-family: "new_font", sans-serif;
}

#footer .contact-box a,
#footer .custom-footer .banner a,
#footer .custom-footer ul a {
    color: #3f4652 !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    text-decoration: none !important;
    transition: color 0.18s ease;
    font-family: "new_font", sans-serif;
}

#footer .contact-box a {
    color: #244f88 !important;
}

#footer .contact-box a:hover,
#footer .custom-footer .banner a:hover,
#footer .custom-footer ul a:hover {
    color: #244f88 !important;
    text-decoration: underline !important;
    text-underline-offset: 3px;
}

#footer .custom-footer>div:not(.contact) {
    padding-top: 4px !important;
}

/* ===== FOOTER BOTTOM ===== */
#footer .footer-bottom {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 22px 0 28px !important;
    border-top: 1px solid #d9e5f3 !important;
    color: #4a515d;
    font-size: 13px;
}

#footer .footer-bottom .copyright {
    display: inline-flex !important;
    flex-wrap: wrap;
    gap: 6px 8px;
    align-items: center;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    order: 2;
}

#footer .footer-bottom .copyright strong {
    font-weight: 400 !important;
}

#footer .footer-bottom .copyright::before,
#footer .footer-bottom .copyright::after,
#footer .footer-bottom .copyright strong::before,
#footer .footer-bottom .copyright strong::after {
    content: none !important;
    display: none !important;
}

#footer #signature {
    order: 1;
    margin: 0 !important;
    opacity: 0.72;
    filter: none !important;
    transition: opacity 0.18s ease;
}

#footer #signature:hover {
    opacity: 1;
}

#footer .footer-bottom a {
    color: #244f88 !important;
    text-decoration: none !important;
}

#footer .footer-bottom a:hover {
    color: #244f88 !important;
    text-decoration: underline !important;
    text-underline-offset: 3px;
}

@media (max-width: 991px) {

    #footer.footer,
    #footer.newsletter-active {
        margin-top: 88px !important;
    }

    #footer .newsletter,
    #footer .custom-footer__newsletter.extended.newsletter {
        display: block !important;
        margin: -52px auto 42px !important;
        padding: 28px 24px !important;
        border-radius: 5px;
    }

    #footer .newsletter::before,
    #footer .custom-footer__newsletter.extended.newsletter::before {
        right: -48px;
        top: 18px;
        width: 330px;
        height: 116px;
        opacity: 0.075;
        transform: rotate(-7deg);
    }

    #footer .newsletter .newsletter-header,
    #footer .custom-footer__newsletter .newsletter-header {
        width: 100% !important;
        max-width: none !important;
        margin-bottom: 22px !important;
    }

    #footer .newsletter form,
    #footer .custom-footer__newsletter #formNewsletterWidget {
        width: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
    }

    #footer .custom-footer.elements-5,
    #footer .custom-footer {
        grid-template-columns: 1fr 1fr !important;
        gap: 28px 30px !important;
        padding-bottom: 46px !important;
    }

    #footer .contact-box .site-name {
        width: 190px !important;
        margin-bottom: 20px !important;
    }

    #footer .contact-box .site-name img {
        max-width: 190px !important;
    }
}

@media (max-width: 767px) {

    #footer.footer,
    #footer.newsletter-active {
        margin-top: 76px !important;
    }

    #footer .newsletter,
    #footer .custom-footer__newsletter.extended.newsletter {
        display: block !important;
        margin: -42px 0 32px !important;
        padding: 22px 16px !important;
        border-radius: 0px;
    }

    #footer .newsletter::before,
    #footer .custom-footer__newsletter.extended.newsletter::before {
        right: -44px;
        top: 8px;
        width: 230px;
        height: 82px;
        opacity: 0.06;
        transform: rotate(-7deg);
    }

    #footer .newsletter::after,
    #footer .custom-footer__newsletter.extended.newsletter::after {
        opacity: 0.14;
    }

    #footer .newsletter h3,
    #footer .newsletter h4,
    #footer .custom-footer__newsletter .topic,
    #footer .newsletter-header .pageElement__heading {
        max-width: 100% !important;
        font-size: 20px !important;
        line-height: 1.28 !important;
    }

    #footer #formNewsletterWidget input[type="email"].form-control {
        padding: 0 16px 0 50px !important;
    }

    #footer #formNewsletterWidget .validator-msg-holder::before {
        left: 18px;
        top: 17px;
        font-size: 17px;
    }

    #footer #formNewsletterWidget .consents {
        margin-top: 12px !important;
        font-size: 12px !important;
    }

    #footer .custom-footer.elements-5,
    #footer .custom-footer {
        display: block !important;
        padding: 0 12px 38px !important;
    }

    #footer .custom-footer>div,
    #footer .custom-footer.elements-5>div,
    #footer .custom-footer__contact,
    #footer .custom-footer__banner16,
    #footer .custom-footer__banner10,
    #footer .custom-footer__banner7 {
        border-bottom: 1px solid #d9e5f3 !important;
        padding: 0 !important;
        background: transparent !important;
    }

    #footer .contact-box .site-name {
        width: 155px !important;
        margin-bottom: 16px !important;
    }

    #footer .contact-box .site-name img {
        max-width: 155px !important;
    }

    #footer .custom-footer .pageElement__heading,
    #footer .custom-footer h3,
    #footer .custom-footer h4,
    #footer .custom-footer>div:not(.contact) h3,
    #footer .custom-footer>div:not(.contact) h4 {
        position: relative;
        margin: 0 !important;
        padding: 15px 28px 15px 0 !important;
        font-size: 17px !important;
        line-height: 1.35 !important;
    }

    #footer .custom-footer .pageElement__heading::after,
    #footer .custom-footer h3::after,
    #footer .custom-footer h4::after {
        display: none !important;
    }

    #footer .custom-footer>div.click-able:not(.contact) h3::after,
    #footer .custom-footer>div.click-able:not(.contact) h4::after {
        content: "\e904" !important;
        position: absolute !important;
        right: 0 !important;
        top: 50% !important;
        display: block !important;
        width: auto !important;
        height: auto !important;
        margin: 0 !important;
        background: none !important;
        font-family: ikony;
        font-size: 10px;
        color: #244f88;
        transform: translateY(-50%) rotate(270deg) !important;
    }

    #footer .custom-footer>div.click-able:not(.contact).otevreno h3::after,
    #footer .custom-footer>div.click-able:not(.contact).otevreno h4::after {
        transform: translateY(-50%) rotate(90deg) !important;
    }

    #footer .custom-footer>div:not(.contact) ul {
        padding: 0 0 12px !important;
    }

    #footer .footer-bottom {
        display: block !important;
        padding: 20px 12px 24px !important;
        text-align: center;
    }

    #footer .footer-bottom .copyright {
        display: block !important;
        margin: 13px 0 0 !important;
        padding: 0 !important;
        width: 100% !important;
        line-height: 1.65;
    }

    #footer #signature {
        display: inline-flex !important;
        align-items: center;
        gap: 6px;
        margin-top: 0 !important;
    }
}

/* HELLOCOMP FOOTER – COPYRIGHT WORD SPACING FIX */
#footer .footer-bottom .copyright strong {
    display: inline !important;
    margin-left: 7px !important;
    margin-right: 0 !important;
    font-weight: 400 !important;
}

#footer .footer-bottom .copyright .cookies-settings,
#footer .footer-bottom .copyright a.cookies-settings {
    margin-left: 18px !important;
}

@media (max-width: 767px) {
    #footer .footer-bottom .copyright strong {
        margin-left: 6px !important;
    }

    #footer .footer-bottom .copyright .cookies-settings,
    #footer .footer-bottom .copyright a.cookies-settings {
        margin-left: 0 !important;
    }
}