:root {
    /*Farben */

    --accent-light: #E2E2E2;
    --accent-medium: #EEEEEE;
    --accent-normal: #B5C2C4;
    --accent-heavy: #3D484A;
    --accent-hover: #E0E8E3;
    --accent-btn: #50757A;

    /*Font Weight*/

    --font-small: 1em;

}


@font-face {
    font-family: 'figtree-light';
    src: url('fonts/Figtree/static/Figtree-Light.ttf') format('truetype')
}

@font-face {
    font-family: 'figtree-regular';
    src: url('fonts/Figtree/static/Figtree-Regular.ttf') format('truetype');
}

@font-face {
    font-family: 'figtree-medium';
    src: url('fonts/Figtree/static/Figtree-Medium.ttf') format('truetype');
}

@font-face {
    font-family: 'figtree-semibold';
    src: url('fonts/Figtree/static/Figtree-SemiBold.ttf') format('truetype');
}
@font-face {
    font-family: 'figtree-bold';
    src: url('fonts/Figtree/static/Figtree-ExtraBold.ttf') format('truetype');
}
/*

*, ::after, ::before {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}*/

.ringe {
    padding: 1em 0 1em;
}

h1,
h2,
h3,
p {
    color: var(--accent-heavy) !important;
}

h2 {
    font-family: 'figtree-medium', sans-serif;
}

h3 {
    font-family: 'figtree-semibold', sans-serif;
    font-size: 17px !important;
}

h4 {
    color: white
}

.section-title h1 {
    font-family: 'figtree-medium', sans-serif;
}

p {
    font-family: 'figtree-light', sans-serif
}

a {
    color: var(--accent-heavy) !important;
    text-decoration: none !important;
    font-family: 'figtree-medium', sans-serif;
}
.menu-headline{
    font-family: 'figtree-bold', sans-serif;
    color: var(--accent-heavy);
    font-size:1.2rem;
}
.menu-head-hide{
    font-family: 'figtree-bold', sans-serif;
    color: var(--accent-heavy);
    font-size:1rem;
}
.menu-subline{
    font-family: 'figtree-light', sans-serif;
    color: var(--accent-heavy);
    font-size:.8rem;
    line-height:1rem;
    
}

.menu-subline p{
    margin: 0;
    
}

.anchor{
    position: fixed;
    transform: translateX(100%);
    transition: .33s;
    width: 100vw;
    height: 100vh;
}

.anchor ul{
    list-style: none;
    padding: 0;
    margin-left: 200px;
    margin-top: 5rem; position: absolute;
}

.anchor ul li:hover{
    text-decoration: underline;
    text-decoration-color: var(--accent-heavy) ;
}

.anchor ul li h2{
    margin: 0;
}

.ring img{
    width: 30%;
    float: right;
    margin-top: 10rem;
    margin-right: 10rem;
}

#burger{
    cursor: pointer;
    position: relative;

}

#burger-lines{
    opacity: 1;
    transition: .33s;
}

#Ebene_1{
    width: 100%;
    POSITION: absolute;
    left: 0;
    top: -5px;
    opacity: 1;
    transition: .33s;
}

.hide{
    opacity: 0 !important;
}

.anchor-in{
    transform: translateX(0);
}

main {
    max-width: 100%;
    margin: 0 auto;
    transition: .33s;
}

.container-privat-bars{
    display: flex;
    gap: 65px;
    align-items: center;
}

.fade-left{
    transform: translateX(-100%);
}

.sticky-nav{
    width: 100%;
}
.navbar {
    position: sticky;
    --bs-navbar-padding-y: 1rem !important;
    display: flex;
    background-color: #f6f6f661;
    backdrop-filter: blur(50px) !important;
    z-index: 1;
}

.navbar .sticky-nav {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
}

.sticky-nav {
    position: sticky;
    top: 0;
}


.side {
    position: fixed;
    z-index: 98;
    margin-left: 100%;
}

.side #phone {
    height: 60px;
    width: 74px;
    top: 82vh;
    right: -10px;
}

.side #mail {
    height: 60px;
    width: 74px;
    top: 90vh;
    right: -10px;
}

.side .mail,
.side .phone {
    position: absolute;
    background-color: var(--accent-btn);
    border-radius: 5px;
    transition: 0.3s;
    color: white
}

.side .mail span,
.side .phone span {
    position: absolute;
    top: 50%;
    left: 40%;
    transform: translateY(-50%) translateX(-50%);
    font-size: 30px;
    color: #FFF;
}

td i {
    font-size: 25px
}

.container {
    justify-content: center;
}


.welcome {
    display: flex;
    background-color: var(--accent-light);
    padding-top: 6em;
}

.welcome h1 {
    font-size: 73px;
    font-family: 'figtree-light', sans-serif;
}

.welcome-text {
    padding-bottom: 37%;
    width: 26vw;

}

.oeffnungszeiten {
    padding-top: 30%;
    padding-left: 26%
}

.about {
    padding: 150px 0;
}

.buttons {
    margin-top: 1em;
    background-color: var(--accent-btn);
    color: white;
    border: none;
    padding: .25em 1.5em;
}

.icon-info {
    height: 30px;
}

.icon-title {
    padding: 50px 0;
}

h4 .icon-title {
    color: white !important;
}

.icon-link {
    padding-top: 20px;
    text-decoration: underline !important;
    cursor: pointer;
}

.icon-row {
    padding-top: 80px
}

.section-title {
    text-align: center;
    margin-bottom: 85px;
}

.mid-text {
    padding: 80px 150px;
}

.grid-container {
    display: grid;
    grid-template-columns: auto auto;
    width: 100%;
}

.grid-item {
    padding: 20px;
    text-align: center;
}

.service {
    background-color: var(--accent-normal);
    padding: 100px 100px;
}

.service-info {
    text-align: center;
    padding: 2em;
}


.slider-section {
    padding: 100px 100px
}

.carousel-inner {
    position: relative;
    width: 100%;
    overflow: hidden;
    height: 80vh;
}

ul {
    text-align: left
}
.modal{
    --bs-modal-width: 710px!important
}
.modal-icon {
    padding-top: 2rem;
}

.modal-list {
    line-height: 1.5rem;
    padding-bottom: 50px
}
.modal-list li {
    padding: 1rem 0;
}

.modal-line {
    padding: 50px;
    font-size: 40px;
}
/* .modal-dialog{
    margin-top: 15%!important
} */
.modal-header {
    border-bottom: 0px !important;
}

.modal-content {
    background-color: var(--accent-heavy) !important;
    border-radius: 0px !important;
    color: var(--accent-light) !important;
    padding-bottom: 50px!important;
}

.ems{
    display: block;
    margin: 0 auto;
    width: 40vw;
    /* height: 50vh; */
}
.image {
    background-image: url('images/flensburg-2.JPG');
    /* The image used */
    background-color: #cccccc;
    /* Used if the image is unavailable */
    height: 500px;
    /* You must set a specified height */
    background-position: center;
    /* Center the image */
    background-repeat: no-repeat;
    /* Do not repeat the image */
    background-size: cover;
    /* Resize the background image to cover the entire container */
}

.contact {
    padding: 100px 100px;
    display: flex;
    background-color: var(--accent-light);
}

.contact-details {
    background-color: var(--accent-heavy);
    color: white;
    padding: 100px 0 100px;
}

.name {
    text-align: center;
}

.subtitle {
    text-align: center;
}

.ma {
    padding: 100px 0 100px;
    text-align: center;
}

.btn-close {
    --bs-btn-close-color: white !important
}

footer {
    background-color: var(--accent-normal);
    text-align: center;
    padding: 50px 0 50px;
}
/* Openstreet Map */

iframe{
    border: 2px solid #999898 !important;
}

.map{
    display: block;
    margin: 0 auto;
    margin-top: 10vh;
    width: 80%;
    height: 390px;
}


@media (min-width: 1200px){

    .anchor ul li h2 {
        font-size: 4rem;
    }
}
@media (max-width: 992px){


    /* anker menu */

    .anchor ul {
        width: 100%;
        margin-left:0;
    }
    .anchor ul li {
        max-width: 700px;
        margin: 0 auto;
    }
    .anchor ul li h2 {
        font-size: 4rem;
    }

    .container .row{
        flex-direction: column;
    }

    .about .container .row .icon-row{
        flex-direction: row;
        margin-bottom: 10vh;
    }

    .welcome-text{
        width: 100%;
        padding: 0;
    }
    .oeffnungszeiten{
        padding: 0 0 10vh 0;
    }

    .about .container .row .col .dr-baecker{
        width: 40%;
        margin: 0 auto;
        display: block;
        margin-bottom: 5vh;
    }

    .mid-text{
        padding: 0;
        margin-bottom: 10vh;
    }

    /* video */

    .ems{
        width: 70vw;
    }

    .buttons{
        display: none;
    }

    /* slider */

    .carousel-inner{
        height: inherit;
    }

    /* contact */

    .contact h3{
        margin: 0;
    }

    .contact .row{
        gap: 5vh;
    }

    .contact-details{
        gap: 5vh;
    }

    .contact .container .row .contact-details{
        flex-direction: column;
        padding: 0;
    }
    
    .justify-content-center{
        padding-left: 20vw ;
        justify-content: start !important;
    }

    .btn-close{
        background-color: white;
    }

    /* navigation */

    .ring{
        display: none;
    }

    /* footer */
    footer .container .row{
        gap: 5vh;
    }
}

/* @media (min-width: 768px){
    .menu-head-hide{
        display: none;
    }
} */

@media (max-width: 767px){

    /* sectoins */

    .welcome{
        padding: 0 7vw;
    }
    .about {
        padding: 150px 7vw;
    }

    .service {
        padding: 100px 7vw;
    }

    .slider-section {
        padding: 100px 7vw;
    }

    .container, .container-sm {
        max-width: 685px;
    }  

    .contact {
        padding: 100px 7vw;
    }
    
    /* side */

    .side #phone{
        top: 70vh;
    }
    .side #mail{
        top: 80vh;
    }

    /* navigation */

    .navbar{
        background-color: #f6f6f6e0;
    }

    .anchor ul li h2 {
        font-size: 3rem !important;
    
    }
    .anchor ul{
        display: flex;
        flex-direction: column;
        text-align: center;
    }

    .navbar-logo{
        display: flex !important;
        justify-content: flex-start;
        text-align: center;
        width: 40%;
        /* padding: 20px; */
    }

    .container-privat-bars{
        display: flex;
        justify-content: flex-end;
        align-content: center;
        width: 40%;
        padding: 20px;
        text-align: center;
    }

    #burger{
        padding-right: 2vw;
    }

    .menu-headline{
        display: none;
    }

    .menu-subline p{
        display: none;
    }

    .navbar .sticky-nav{
        justify-content: center;
    }

    .navbar .sticky-nav .container{
        margin: 0;
        width: 100%;
        flex-wrap: nowrap !important;
    }

    #Logo_Zeichenfläche_1{
        width: 50%;
        display: block;

    }

    /* welcome */
    .welcome h1 {
        margin-top: 5vh;
    }

    /* aboubt */
    .about .container .row .col .dr-baecker {
        width: 60%;
    }
    /* Contact */
    .justify-content-center{
        padding-left: 10vw;
    }
    
    /* Map */

    .map{
        width: 100%;
        height: 390px;
    }

}

@media (max-width: 481px){

    .welcome h1 {
        font-size: 50px;
        
    }
}
@media (max-width: 481px){
    .container-privat-bars {
        gap: 50vw;
    }

    .welcome .col-12 h1{
        font-size: 30px;
    }
    
}