﻿/* latin */
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: optional;
    src: url('../fonts/Montserrat.woff2') format('woff2');
    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+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


.navbar-toggler {
    border: 0px !important;
}

.mb-1rem {
    margin-bottom: 1rem !important;
}

.mt-1rem {
    margin-top: 1rem !important;
}

.mb-2rem {
    margin-bottom: 2rem !important;
}

.mt-2rem {
    margin-top: 2rem !important;
}


.faq-answer {
    color: #575768;
}

.sup-number {
    font-size: 18px !important;
    font-weight: 700;
    margin-left: -42px;
     margin-top: 9px;
    position: absolute;
}

.feedback-box {
    border-radius: 32px;
    background: #F3F3F6;
    text-align: center !important;
    padding: 1.5rem !important;
    width: 100%;
    height: 290px;
}

@media (min-width: 992px) { /* lg and up */
    
}

.nav-link {
    padding: .5rem 0.75rem !important;
}




.full-width-md {
    position: relative;
    width: 100%;
    max-width: 990px;
    margin: 0 auto;
    overflow: hidden;
    padding: 0px;
}


.price-headline {
    font-size: 64px !important;
    font-family: 'Montserrat';
}

/* XS (0–767px) */
@media (max-width: 767px) {
    .h2, h2 {
        font-size: 1.5rem !important;
    }

    .h3, h3 {
        font-size: 1.5rem !important;
    }

    .large-numbers {
        font-size: 3.5rem !important;
    }

    .advantages-headline {
        font-family: 'Montserrat';
        font-size: 1.5rem !important;
        line-height: 1;
        position: relative;
        font-weight: 700 !important;
    }
    .advantages-prefix-hl {
        font-family: 'DM Sans Regular';
        font-size: 16px !important;
        color: #8A8A9B;
        margin-left: 32px;
        /*margin-bottom: 1rem;*/
    }
}

/* MD (768–991px) */
@media (min-width: 768px) and (max-width: 991px) {
    .h2, h2 {
        font-size: 2rem !important;
    }

    .h3, h3 {
        font-size: 2rem !important;
    }

    .large-numbers {
        font-size: 4rem !important;
    }
    .advantages-headline {
        font-family: 'Montserrat';
        font-size: 1.5rem !important;
        line-height: 1;
        position: relative;
        font-weight: 700 !important;
    }
    .advantages-prefix-hl {
        font-family: 'DM Sans Regular';
        font-size: 16px !important;
        color: #8A8A9B;
        margin-left: 32px;
        /*margin-bottom: 1rem;*/
    }

}

/* LG and above (992px+) */
@media (min-width: 992px) {
    .h2, h2 {
        font-size: 3rem !important;
    }

    .h3, h3 {
        font-size: 2rem !important;
    }

    .large-numbers {
        font-size: 4rem !important;
    }
    .advantages-headline {
        font-family: 'Montserrat';
        font-size: 3.5rem !important;
        line-height: 1;
        position: relative;
        font-weight: 700 !important;
    }
    .advantages-prefix-hl {
        font-family: 'DM Sans Regular';
        font-size: 18px !important;
        color: #8A8A9B;
        margin-bottom: 1rem;
    }
}


/* Make the button full width on XS, auto on SM+ */
@media (min-width: 576px) {
    .w-sm-auto {
        width: auto !important;
    }
}

/* Optional: visually attach the button to the input on SM+ */
@media (min-width: 576px) {
    .newsletter-form .form-control {
        border-top-right-radius: 1rem;
        border-bottom-right-radius: 1rem;
        border-top-left-radius: 1rem;
        border-bottom-left-radius: 1rem;
        margin-right: 8px;
    }

    .newsletter-form .btn.main-btn {
        border-top-left-radius: 1rem;
        border-bottom-left-radius: 1rem;
        border-top-right-radius: 1rem;
        border-bottom-right-radius: 1rem;
        white-space: nowrap;
        margin-right: 8px;
    }
}

.image-grid {
    display: grid;
    gap: 8px; /* 8px both directions */
    grid-template-columns: repeat(2, 1fr); /* XS–MD: 2 per row */
}

@media (min-width: 992px) { /* LG+: 3 per row */
    .image-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.image-grid img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}


#kuendigen-form .form-control {
    border-radius: 16px;
}

.offcanvas-body {
    padding-left: 2rem !important;
    padding-bottom: 3.5rem !important;
}

.offcanvas-header {
    padding: 1.5rem 1.5rem !important;
}

.mobile-nav-links .nav-link {
    padding-top: .5rem;
    padding-bottom: .5rem;
    padding-right: 1rem !important;
    font-size: 24px !important;
}

/* Make the side offcanvas occupy the full viewport width */
.offcanvas-fullscreen.offcanvas-start,
.offcanvas-fullscreen.offcanvas-end {
    width: 100vw;
    max-width: 100vw;
}

@font-face {
    font-family: 'DM Sans Medium';
    src: url('/fonts/DMSans-Medium.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'DM Sans Regular';
    src: url('/fonts/DMSans-Regular.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
/*
@font-face {
    font-family: 'Montserrat';
    src: url('/fonts/Montserrat-Regular.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
*/

@media (min-width:1200px) {
    #primaryNavMobile {
        display: none !important;
    }
}

.first-element-of-page {
    margin-top: 64px !important;
}


.social-link:hover {
    text-decoration: underline;
}

a:hover {
    text-decoration: underline !important;
}

.footer a {
    text-decoration: none;
    color: #140b59;
    margin-top: 0.7rem;
}

.social-link {
    text-decoration: none;
    color: #140b59;
}

.dp-block {
    display: block;
}

.bg-yellow-white {
    background-color: #FFFDF7;
}

.textcolor-default {
    color: #140b59;
}

.ff-montserrat {
    font-family: 'Montserrat';
}

.fs-24 {
    font-size: 24px;
}

.border-32 {
    border-radius: 32px;
}

.radius-16 {
    border-radius: 16px;
}



.custom-divider {
    border-top: 1px solid #8A8A9B;
}

#primaryNavMobile {
    background-color: #140B59;
    color: #FFFDF7;
    border-radius: 24px;
}

mobilenav-btn:hover {
    border: #FFFDF7 !important;
}

#primaryNavDesktop .nav-link {
    font-size: 18px;
    color: #140b59 !important;
    font-weight: 500;
}

#primaryNavMobile .nav-link {
    font-size: 18px;
    color: #FFFDF7 !important;
    font-weight: 500;
}

.nav-link:hover {
    /*font-weight: 600!important;*/
}

.main-btn {
    background-color: #FFD11A;
    border-radius: 1rem;
    font-family: 'DM Sans Medium';
    font-size: 18px;
    font-weight: 500;
    padding: 1rem 2rem;
    text-decoration: none !important;
}

.main-btn:hover {
        color: #FFD11A!important;
        background-color: #140B59;
        text-decoration: none !important;
        border: 1px solid #FFD11A;
}
