/* hanken-grotesk-cyrillic-ext-wght-normal */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: normal;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-cyrillic-ext-wght-normal.woff2) format('woff2-variations');
    unicode-range: U+0460-052F,U+1C80-1C88,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;
}

/* hanken-grotesk-vietnamese-wght-normal */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: normal;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-vietnamese-wght-normal.woff2) format('woff2-variations');
    unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;
}

/* hanken-grotesk-latin-ext-wght-normal */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: normal;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-latin-ext-wght-normal.woff2) format('woff2-variations');
    unicode-range: U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* hanken-grotesk-latin-wght-normal */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: normal;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-latin-wght-normal.woff2) format('woff2-variations');
    unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

/* hanken-grotesk-cyrillic-ext-wght-italic */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: italic;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-cyrillic-ext-wght-italic.woff2) format('woff2-variations');
    unicode-range: U+0460-052F,U+1C80-1C88,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;
}

/* hanken-grotesk-vietnamese-wght-italic */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: italic;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-vietnamese-wght-italic.woff2) format('woff2-variations');
    unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB;
}

/* hanken-grotesk-latin-ext-wght-italic */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: italic;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-latin-ext-wght-italic.woff2) format('woff2-variations');
    unicode-range: U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* hanken-grotesk-latin-wght-italic */
@font-face {
    font-family: 'Hanken Grotesk';
    font-style: italic;
    font-display: swap;
    font-weight: 100 900;
    src: url(/static/fonts/hanken-grotesk-latin-wght-italic.woff2) format('woff2-variations');
    unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

html, body {
    font-family: 'Hanken Grotesk', 'Helvetica Neue', 'Helvetica', 'Segoe UI', sans-serif;
    background: #fff;
    color: #000;
    font-size: 15px;
}

.content {
    background-image: url("static/images/bg/head-1.svg");
    background-repeat: repeat-x;
    background-size: contain;
    width: 100%;
}

@media (max-width: 1500px) {
    .content {
        background-size: 1500px auto;
    }
}

@media (min-width: 2500px) {
    .content {
        background-size: 2500px auto;
    }
}

a {
    color: #76B82B;
    text-decoration: none;
}

    a:hover {
        color: rgb(93, 147, 32);
    }


h1, .h1 {
    font-weight: 600;
    font-size: 2.2rem;
    color: #003E6B;
}

h2, .h2 {
    color: #003E6B;
    font-size: 2.0rem;
    text-transform: uppercase;
}

h3, .h3, .megamenu .title {
    font-size: 1.1rem;
    font-weight: bolder;
}

/* Navigation */
/* ---------------------------------------------------------- */

.navbar {
    padding: 25px 0 20px 0;
}

.navbar-bg {
    background: #fff;
    transition: ease-in-out all 0.4s;
    box-shadow: 0 0 7px 0 rgba(0, 0, 0, 0.2);
}

.navbar-bg-none {
    background: transparent;
    transition: ease-in-out all 0.4s;
}

.navbar .navbar-brand {
    width: 250px;
}

.navbar-toggler {
    border: none !important;
    box-shadow: none !important;
    color: #76B82B;
    font-size: 30px;
}

.navbar .nav-item .nav-link {
    position: relative;
    padding: 7px 0;
    margin: 0 20px;
}


    .navbar .nav-item .nav-link.active {
        color: #76B82B;
    }

    .navbar .nav-item .nav-link:focus-visible {
        box-shadow: none;
    }

@media (min-width: 992px) {
    .navbar .nav-item .nav-link.active::after {
        content: "";
        position: absolute;
        bottom: -2px;
        left: 8px;
        right: 8px;
        border-radius: 10px;
        border-bottom: 2px solid #76B82B;
    }
}

@media (max-width: 992px) {
    .navbar .navbar-nav {
        background: #fff;
        transition: ease-in-out all 0.4s;
        box-shadow: 0 0 7px 0 rgba(0, 0, 0, 0.2);
    }

        .navbar .navbar-nav .nav-link {
            padding: 15px 0;
        }

        .navbar .navbar-nav .btn {
            margin: 15px 0;
        }

    .navbar .dropdown-menu {
        border: none !important;
    }

    .navbar .navbar-nav {
        box-shadow: none;
    }
}

.navbar .nav-item .btn {
    margin-left: 20px;
}

.navbar .nav-item .dropdown-menu .dropdown-item {
    padding: 10px;
}

    .navbar .nav-item .dropdown-menu .dropdown-item i {
        color: #76B82B;
        margin-right: 15px;
        width: 30px;
        text-align: center;
        font-size: 18px;
    }


.dropdown-fullwidth {
    position: static;
}

    .dropdown-fullwidth .dropdown-menu {
        margin: 0 auto;
        left: 0;
        right: 0;
        padding: 0 1rem 15px 1rem;
        top: auto;
        max-width: 768px;
    }


@media (max-width: 768px) {
    .dropdown-fullwidth .dropdown-menu {
        max-width: 94%;
    }
}

@media (max-width: 576px) {
    .dropdown-fullwidth .dropdown-menu {
        max-width: 96%;
    }
}

.megamenu .title {
    margin-top: 3px;
    padding: 10px;
}

.megamenu a {
    color: #000;
    vertical-align: middle;
    padding: 10px;
    border-radius: 7px;
    position: relative;
    background: transparent;
    transition: ease-in-out all 0.4s;
    display: flex;
}

    .megamenu a:hover {
        background: #F1F9FF;
        transition: ease-in-out all 0.4s;
    }

    .megamenu a i {
        font-size: 22px;
        color: #76B82B;
        margin-right: 15px;
        width: 30px;
        text-align: center;
    }

.megamenu .link-button {
    border: 1px solid #f1f1f1;
    background: #fafafa;
}

.e-icon {
    background: url(/static/images/E-Rechnung_Icon.svg);
    display: inline-block;
    height: 100%;
    width: 17px !important;
    background-repeat: no-repeat;
}


/* Overwrite Bootstrap */
/* ---------------------------------------------------------- */
.btn {
    border-radius: 8px;
    padding-left: 1.2rem;
    padding-right: 1.2rem;
    transition: ease-in-out all 0.4s;
}

.btn-light {
    background-color: white;
    border-color: white;
}

.btn-success {
    background-color: #76B82B;
    border-color: #76B82B;
}

    .btn-success:hover, .btn-success.active {
        background-color: rgb(93, 147, 32);
        border-color: rgb(93, 147, 32);
    }

.text-bg-success, .alert-success {
    background-color: #76B82B !important;
}

.alert-success {
    padding: 20px 20px;
    color: #fff;
    font-size: 1.1rem;
    font-size: 1.1rem;
    border-radius: 15px;
}

    .alert-success a {
        color: #ffffff;
        text-decoration: underline;
    }

        .alert-success a:hover {
            color: #003E6B;
        }

.text-muted {
    color: #6c757d !important;
}

.accordion-item {
    border-color: #76B82B;
}


    .accordion-item .accordion-collapse .accordion-body {
        text-align: left;
    }

    .accordion-item .accordion-button:not(.collapsed) {
        background: #E7F0DF;
        color: black;
    }

    .accordion-item .accordion-button:focus {
        box-shadow: none;
    }

.card {
    border: 1px solid #eff2f7;
    border-radius: 0.75rem;
    box-shadow: 0 0 1.25rem rgba(1, 22, 39, 0.05);
}





/* Elemets */
/* ---------------------------------------------------------- */


/*  ---------  Section  --------- */
.section {
    padding: 90px 0;
}

    .section .title {
        line-height: 1.3;
    }

    .section .title-line {
        height: 2px;
        width: 55px;
        background-color: #76B82B;
        margin: 25px auto;
        border-radius: 3px;
    }

    .section .badge {
        font-size: 1rem;
        padding: 9px 20px;
    }


.section-head {
    padding: 170px 0 100px;
}

    .section-head h1 {
        margin-bottom: 20px;
    }

    .section-head ul {
        padding-left: 0;
    }

        .section-head ul li {
            list-style: none;
            margin-bottom: 9px;
            position: relative;
            padding-left: 33px;
        }

            .section-head ul li i {
                color: #76B82B;
                position: absolute;
                left: 0;
                font-size: 22px;
            }

    .section-head .subnav i {
        width: 23px;
        margin-right: 5px;
        text-align: center;
    }

.section-head-padding-top {
    padding-top: 170px;
}

.section-revision-bg-gray {
    background-image: url("static/images/bg/bg-revisionssicher.svg");
    background-repeat: no-repeat;
    background-color: #fafafa;
    width: 100%;
}

.section-home-bg-gray {
    background-image: url("static/images/bg/bg-home.svg");
    background-repeat: no-repeat;
    background-color: #fafafa;
    width: 100%;
}

.section-quote-bg-gray {
    background-image: url("static/images/bg/bg-quote.svg");
    background-repeat: no-repeat;
    background-color: #fafafa;
    width: 100%;
}

@media (min-width: 1920px) {
    .section-quote-bg-gray, .section-revision-bg-gray, .section-home-bg-gray {
        background-size: cover;
    }
}


.section-contact {
    background: #E7F0DF;
    border-radius: 15px;
}

    .section-contact .contact-image {
        position: relative;
        justify-content: end;
        display: flex;
    }

        .section-contact .contact-image img {
            position: absolute;
            max-height: 100%;
            bottom: 0;
            padding: 2rem 2rem 0 0;
        }

.section-webinar {
    background: #76B82B;
    border-radius: 15px;
}

    .section-webinar p,
    .section-webinar strong {
        color: white;
    }




/*  ---------  Cards  --------- */

.card-price .card-header {
    background: #003E6B;
    border-start-end-radius: 0.75rem;
    border-start-start-radius: 0.75rem;
}

.card-price .card-title {
    color: #fff;
    font-size: 1.8rem;
}

.card-price .card-subtitle {
    color: #ccc;
    font-size: 1.5rem;
}

a.card {
    transition: ease-in-out all 0.3s;
    position: relative;
    top: 0;
}

    a.card:hover {
        top: -8px;
    }



/*  ---------  Customer  Quote  --------- */
.customer-quote {
    padding-left: 60px;
    position: relative;
}

    .customer-quote::before {
        content: '\f10d';
        color: #76B82B;
        font-size: 40px !important;
        font: var(--fa-font-solid);
        position: absolute;
        top: 0;
        left: 0;
    }


/*  ---------  Feature Elements  --------- */
.feature-list {
    margin-top: 2.5rem;
}

    .feature-list p {
        position: relative;
        margin-left: 30px;
    }

.feature-item {
    margin-bottom: 2.5rem;
    position: relative;
}

    .feature-item h3 {
        margin: 0 0 3px 0;
        position: relative;
    }

    .feature-item.image-offset {
        margin-left: 85px;
    }


    .feature-item .image {
        position: absolute;
        top: 0px;
        left: -85px;
    }

        .feature-item .image i {
            border-radius: 40px;
            font-size: 25px;
            padding: 19px 0;
            width: 65px;
            height: 65px;
            background: #E7F0DF;
            color: #76B82B;
            text-align: center;
        }

            .feature-item .image i.withoutbg {
                color: #76B82B;
                background: transparent;
                font-size: 50px;
                padding: 0;
            }

        .feature-item .image img {
            width: 60px;
        }

    .feature-item p {
        margin: 0;
        color: #6c757d;
    }

    .feature-item.bullet {
        padding-left: 30px;
    }

        .feature-item.bullet h3::before, .feature-list p::before {
            content: "";
            position: absolute;
            top: 3px;
            left: -30px;
            height: 14px;
            width: 14px;
            background: #76B82B;
            border-radius: 14px;
        }


.feature-item-sm.image-offset {
    margin-left: 60px;
}

.feature-item-sm .image {
    left: -60px;
}

    .feature-item-sm .image i {
        font-size: 18px;
        padding: 13px;
        width: 46px;
        height: 46px;
    }



.feature-list p::before {
    top: 4px;
}

.feature-line .feature-item {
    position: relative;
}

    .feature-line .feature-item i {
        font-size: 55px;
        background: #E7F0DF;
        color: #76B82B;
        border-radius: 140px;
        height: 140px;
        width: 140px;
        margin-bottom: 35px;
        padding: 40px 0;
        text-align: center;
    }

    .feature-line .feature-item .line-arrow {
        position: absolute;
        right: -19%;
        top: 42%;
        width: 33%;
    }

        .feature-line .feature-item .line-arrow.up {
            top: 30%;
        }

@media (max-width: 768px) {
    .feature-line .feature-item .line-arrow {
        display: none;
    }
}



.feature-box {
    color: #76B82B;
    background: #E7F0DF;
    border-radius: 10px;
    width: 100%;
    text-align: center;
}

    .feature-box i {
        font-size: 55px;
        margin: 20px 0 10px;
    }



/*  ---------  Job List  --------- */

.job-list a {
    display: block;
}

    .job-list a .title {
        font-size: 22px;
    }

/* Footer */
/* ---------------------------------------------------------- */
.footer {
    background-color: #fafafa;
    padding: 90px 0 20px 0;
    color: #6c757d !important;
}

    .footer .footerlogo {
        width: 200px;
        margin-bottom: 8px;
    }

    .footer .designed {
        width: 80px;
        margin-left: 7px;
    }

    .footer .footerlinks strong {
        text-transform: uppercase;
    }

    .footer .footerlinks a, .footer .footerlinks strong {
        float: left;
        clear: left;
        margin-bottom: 8px;
    }

    .footer .subline .fa-circle-small {
        color: #76B82B;
        font-size: 5px;
        margin: 0 8px;
    }

/* Error Page */
/* ---------------------------------------------------------- */

.error-page {
    padding: 13% 0;
    font-size: 1.1rem
}

    .error-page i {
        font-size: 4rem;
    }

/* CookieConsent */
/* ---------------------------------------------------------- */
#cconsent-bar {
    font-size: 15px !important;
    padding: 20px 10px !important;
    background-color: #76B82B !important;
}

#cconsent-bar button.consent-decline, #cconsent-bar button.consent-give {
    font-size: 15px !important;
}

#cconsent-bar button.consent-decline, #cconsent-modal .ccm__footer button, #cconsent-init-modal .ccm__footer button {
    background-color: #76B82B !important;
}

#cconsent-bar button.consent-give {
    color: #000000 !important;
}

#cconsent-bar .ccb__wrapper {
    max-width: 1320px !important;
}

#cconsent-modal .ccm__content, #cconsent-init-modal .ccm__content, #cconsent-bar button.consent-give, #cconsent-bar button.consent-decline, #cconsent-modal .ccm__footer button, #cconsent-init-modal .ccm__footer button {
    border-radius: 10px !important;
}
/* Mobile View */
/* ---------------------------------------------------------- */
@media (max-width: 576px) {
    .section {
        padding: 40px 0;
    }

    .section-head, .section-head-padding {
        padding: 90px 0 40px 0;
    }

    .section-head-padding-top {
        padding-top: 90px;
    }

    .footer {
        padding-top: 30px;
    }
    #cconsent-bar .ccb__button, #cconsent-bar .ccb__right, #cconsent-modal .ccm__footer, #cconsent-init-modal .ccm__footer {
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
        justify-content: center !important;
    }
        #cconsent-bar .ccb__button button, #cconsent-modal .ccm__footer button, #cconsent-init-modal .ccm__footer button{
            width: 100% !important;
            margin: 20px 0 0 0 !important;
            padding: 20px 10px !important;
        }

        #cconsent-modal .ccm__footer, #cconsent-init-modal .ccm__footer{
            padding: 20px !important;
        }
}
