/* Remove default margin.
*/
body {padding:0;
     margin: 0;
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* Mindesthöhe = Bildschirmhöhe */
    margin: 0;
    position: relative; /* Wichtig für absolute Kinder */

}
html {    font-size:16px;}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
    display: block;
}
/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
    display: inline-block;
    /* 1 */
    vertical-align: baseline;
    /* 2 */
}
/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {    display: none;    height: 0;}
/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
    display: none;
}
/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {    background-color: transparent;}
/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active,
a:hover {
    outline: 0;
}

/* In Gebrauch */

.inline-block {
    max-width: 100%;
    display: inline-block;
}
.w-inline-block {
    max-width: 100%;
    display: inline-block;
}

.header_section {
    position: relative;
    overflow: hidden;
    min-height: 200px;
    padding: 70px 40px 20px;
}


.content_nav {
    display: block;
    max-width: 1280px;
    height: 35px; /* Fixe Höhe (statt max-height) */
    margin: 0 auto; /* Kurzschreibweise für margin-right/layout */
    padding: 0; /* Sicherheitshalber */
}

.content_nav_link {
    position: relative; /* (Bereits vorhanden) */
    z-index: 30;
    height: 35px;
    padding-top: 10px;
    padding-right: 30px;
    padding-left: 30px;
   /* background-color: #1a2025; */
    transition: background-color 200ms ease;
    color: #fff;
    text-decoration: none;
    /* Neu: Verhindert Verschiebung durch ::after */
    overflow: hidden; /* Optional: Verhindert unerwünschte Überlappungen */
}

.content_nav_link::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 3px;
    background-color: transparent;
    transition: background-color 200ms ease;
    /* Neu: Balken bleibt innerhalb des Buttons */
    transform: translateY(0); /* Keine Verschiebung nach unten */
}


.content_nav_link:hover {
    background-color: #e30613;
}

.content_nav_link:hover::after {
    background-color: #e30613; /* Farbe der Markierung beim Hover */
}

.content_nav_link.w--current {
    background-color: #353535;
}

.content_nav_link.w--current::after {
    background-color: #353535; /* Farbe der Markierung für den aktuellen Button */
}

.content_nav_section {
    margin-top: -30px;
    padding-right: 40px;
    padding-left: 40px;
}



/* --------------- */
.max-width-container {
    position: relative;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}
.width-container {
    position: relative;
    max-width: 880px;
    margin-right: auto;
    margin-left: auto;
}

.inline-block {    max-width: 100%;    display: inline-block; }  /*  wk menü */
.w-inline-block {    max-width: 100%;    display: inline-block; }  /*  wk menü */


.page-div {
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    border-top: 0px solid #000;
    min-height: 3px;
    margin: 0;
    padding:0;
    z-index:30;
}
/* Hauptcontainer (füllt verfügbaren Platz) */
.page-div-flex {
    flex: 1; /* Wächst, um den Platz zwischen Header und Footer zu füllen */
    position: relative; /* Nicht mehr fixed! */
    width: 100%;
    min-height:90vh;
    margin:  0 ;
    padding: 0px;
    z-index: 30;
}
.page-end-div{
    position:relative; z-index:400;
    flex-shrink: 0; /* Verhindert, dass der Footer schrumpft */
    width: 100%;
    height:100%;
    min-height:250px;
    background: #f8f9fa;
    padding: 10px;
    margin-top: auto; /* Drückt den Footer nach unten */
    background:#000; color:#fff;
}


#foot-menu{
    position:absolute;
    left:35%;top:0px;
    color:#fff;
}

.foot-div {
    position: fixed;
   bottom: 0px;
    left: 0;
    width: 100%;
    background: rgba(30,30,30,0.7);
    color:#fff;
    border-top: 0px solid #000;
    height: 180px;
    margin: 0;
    padding:0px;
    z-index:99;
}

.level-A-div {
    position: fixed;
    bottom: 323px;
   left: 0px;
    width: 150px !important;
    background: rgba(30,30,30,0.7);
    color:#fff;
    min-height: 40px;
    margin: 0;
    z-index:99;
    transition: bottom 1s ease-in-out;
}

.level-A-x-div {
    position: fixed;
    bottom: 0px;
    left: 0px;
    width: 150px !important;
    background: rgba(30,30,30,0.7);
    color:#fff;
    min-height: 45px;
    margin: 0;
    z-index:99;
    transition: bottom 1s ease-in-out;
}

.level-A-item{
    border-bottom: 3px solid #fff;

    padding:0 30px 0 30px;
    cursor:pointer;
    min-height:45px;
    margin-top:6px;
}
.level-A-item:hover{
   background:#000;
}


.level-B-item{
    border-right: 3px solid #fff;
    padding:0 30px 0 30px;
    cursor:pointer;
    min-height:50px;
    margin-top:0px;
}
.level-B-item:hover{
    background:#fff;
    color:#000;
}

.textBlockB{width:40%;}


.left-side-div {
    position: fixed;
    top: 0px;
    left: 0px;
    width: 300px;
    background: rgba(30,30,30,0.7);
    color:#fff;
    border-top: 0px solid #000;
    height: 100%;
    margin: 0;
    padding:0px;
    z-index:30;
}


/* Linien */
.v-line {
    position: fixed;  z-index: 11;    top: 0;    left: 200px;    width: 1px;    height: 100%;    border-right: 0px solid #000;}
.h-line {
    position: fixed;z-index: 99;    top: 50px;    left: 200px;    width: 100%;    height: 1px;    border-top: 3px solid #000;}



/* Sidebar */
.left-div {
    position: fixed;
    top: 0;
    left: 0;
}
.logo-div {
    position: fixed; z-index: 99;
    top: 0px;    left: 220px;    width: 60px;    height: 50px;    background: #fff;
}
.shop-logo-div {
    position: fixed; z-index: 99;
    top: 0px;    left: 230px;      height: 50px;    background: #fff;
}

.burger-div {
    position: fixed; z-index: 99;
    top: 0px;    left: 10px;      height: 60px;
}




/* Menü-0  - Hauptmenu*/
.menu-0-div {
    position: fixed;
    top: 50px;
    left: 200px;
    width: calc(100% - 200px);
    height: 0;
    overflow: hidden;
    z-index: 36;
    background:rgba(50,50,50,0.8);
    color:#fff;
    border-bottom:0px solid #000;
}

#js-menu-0{ height:0px; overflow:hidden;    transition: width 1s, height 1s, padding 1s}
#js-menu-0.large{ height:500px; padding:30px;  }

.oben-div{
    position: fixed; z-index: 99;
    top: 0;
    left: 200px;
    width: calc(100% - 200px)!important;
    height: 50px;
    z-index: 99;
    border-bottom: 3px solid #fff;
    background: #fff;
    overflow: hidden;
}

.oben-div:hover{ background:#eee;}

/* Header */
.head-div {
    position: absolute;
    top: 50px;
    left: 200px;
    width: calc(100% - 200px);
    height: 200px;
    z-index: 30;
    overflow: hidden;
}

/* Top-Right */
.top-right-div {
    position: fixed;  z-index: 100;
    top: 7px;
    right: 5vw;
    width: 300px!important;
    height: 50px;
   justify-content: flex-end!important;
    gap: 30px!important;
    background: transparent;
}

/* Menü-1 Linke Seite */
.menu-1-div { display:block;
    position: fixed;
    top: 270px;
    left: 0;
    width: 200px;
    height: 100%;
    background: #fff;
    color: #fff;
    z-index: 20;
}

/* Menü-2 für History Back*/
.menu-2-div {
    position: absolute;
    top: 250px;
    left: 200px;
    height:20px;
    background: #fff;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    z-index: 31;
}

/* Menü-3  für level C*/
.menu-3-div {
    position: absolute;
    top: 200px;
    left: 200px;
    height:45px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    z-index: 33;
}

/* Content */
.content-div {
    position: relative;
    margin-top: 320px;
    left: 200px;
    width: calc(100% - 200px);
    max-width: 1200px;
    height: 100%;
    background: #fff;
    box-sizing: border-box;
}

.mobil-head-div{
    display:none;
    position:fixed;
    left:0;
    right:0;
    width:100%;
    height:60px;
    background:#000;
    color:#000;
    z-index:40;
}


.menu-1-feld{ width:190px; height:100px; margin:0px 5px 0px 5px; border-top:0px solid #000; color:#000; padding-left:10px; }
.menu-1-feld:hover{background:#fff;}
.text-typo{
    font-family: HausSchriftRegular,sans-serif;
    font-size: 1.4rem;
    line-height: 1.9rem;
}
.font-weiss{color:#fff;}

.level-0-container{
    width:230px;
    height:400px;
    border-right:0px solid #000;
    margin: 0px 20px 0px 0px;
}
.level-0-typo{  margin:10px 0px 20px 0px;}

.level-1-point{
    cursor:pointer;
    border-right:0px solid #000;
    margin:0px 0px 7px 0px;
}
.level-1-point:hover{border-bottom:3px solid #fff;}

a{text-decoration:none; color:black;}

.fa-small{width:16px; margin:6px 20px 0px 20px;}

.hero-heading{
    font-size:6.5rem;
    margin-top: -15px;
    margin-bottom: 23px;
    padding-top: 0px;
    font-family: HausSchriftNormal, sans-serif;
    color: #fff;

    line-height: 1rem;
    font-weight: 100;
    text-align: left;
    letter-spacing: 0.05rem;
    text-transform: none;

}

.oben-text{margin-left: 10vw; padding-top:7px; width:500px !important; cursor:pointer;}
.oben-text:hover{text-decoration:underline;}







.menu-button{
    font-size:1rem;
    font-weight:bold;
    padding:8px;
    margin:5px;

}


.position-up-1{top:100px;}
.position-up-2{top:250px;}


/* Menu-2_weiss */


.c_2_nav {
    display: block;
    max-width: 1280px;
    height: 35px; /* Fixe Höhe (statt max-height) */
    margin: 0 auto; /* Kurzschreibweise für margin-right/layout */
    padding: 0; /* Sicherheitshalber */
}

.c_2_nav_link {
    position: relative; /* (Bereits vorhanden) */
    z-index: 30;
    height: 35px;
    padding-top: 10px;
    padding-right: 30px;
    padding-left: 30px;
    background-color: #1a2025;
    transition: background-color 200ms ease;
    color: #fff;
    text-decoration: none;
    /* Neu: Verhindert Verschiebung durch ::after */
    overflow: hidden; /* Optional: Verhindert unerwünschte Überlappungen */
}

.c_2_nav_link::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 3px;
    background-color: transparent;
    transition: background-color 200ms ease;
    /* Neu: Balken bleibt innerhalb des Buttons */
    transform: translateY(0); /* Keine Verschiebung nach unten */
}


.c_2_nav_link:hover {
    background-color: #e30613;
}

.c_2_nav_link:hover::after {
    background-color: #e30613; /* Farbe der Markierung beim Hover */
}

.c_2_nav_link.w--current {
    background-color: #353535;
}

.c_2_nav_link.w--current::after {
    background-color: #353535; /* Farbe der Markierung für den aktuellen Button */
}

.c_2_nav_section {
    margin-top: -30px;
    padding-right: 40px;
    padding-left: 40px;
}
/* === Basis-Layout (Standard für große Screens, > 1200px) === *//* dein jetziges Layout gilt hier automatisch */


    @media (max-width: 1199px) {            /* === Laptops & kleinere Desktops (bis 1199px) === */
    .head-div {
        font-size: 0.95rem;
    }
    .content-div {
        max-width: 1000px;
    }
    .hero-heading{font-size:5rem;}

    #foot-menu{        left:20%;    }
}


@media (max-width: 991px) {          /* === Tablets im Hochformat (bis 991px) === */
                                       /* Header & Content auf volle Breite */
    .left-div { display:none;  }
    .mobil-head-div { display:block;  }
    .menu-1-div {
        position: relative;
        top: 0;
        width: 100%;
        height: auto;
    }
       .content-div{
        position:relative;
        margin-top: 320px;
        left: 0;
        width: 100%;
    }
    .head-div{height:140px; left: 0; width: 100%;}
    .menu-0-div {
        position:fixed;
        top:60px;
        left:0;
        width:100%;
    }
    .menu-2-div {                        /* HistoryBack menü */
        position: absolute;
        top:250px;
        left: 0px;
        width: 100%;
        max-height:20px;
        background: #fff;
        z-index: 35;
    }
    .menu-3-div {                    /* levelC menü */
       top: 190px;
        left: 0px;
        width:100vw;
    }
    .hero-heading{font-size:4rem;}
    .text-typo{
        font-size: 1.3rem;
        line-height: 1.5rem;
    }
    .medium-typo{font-size:12px; line-height:22px;}

    #js-oben-div{display:none;}
    .top-right-div{display:none;}
     .level-A-div{display:none !important;}
    .shop-logo-div{display:none;}
    .logo-div{display:none;}

    #foot-menu{        left:10%;    }

}



@media (max-width: 767px) {                         /* === Smartphones (bis 767px) === */
                                                     /* Sidebar nach oben schieben */
    .left-div { display:none;  }
    .mobil-head-div { display:block;  }
    .top-right-div {   width:200px!important;     }
    .fa-xl{ width: 22px; height: 22px; font-size: 22px;}
    .textBlockB{width:70%;}

    .menu-0-div {
        position:fixed;
        top:60px;
        left:0;
        width:100%;
    }
    .menu-1-div {
        position: relative;
        top: 0;
        width: 100%;
        height: auto;
    }
    .menu-2-div {
        position: absolute;
        top: 240px;
        width: 100%;
        height: auto;
    }
    /* Header & Content auf volle Breite */
    .head-div{}
    .content-div{
        position: relative;
        margin-top: 275px;
        left: 0;
        width: 100%;
    }

    .text-typo{
        font-size: 1.3rem;
        line-height: 1.5rem;
    }

    #js-menu-0.large{ height:80vh; padding:10px; border-bottom:3px solid #000; }

    .level-0-container{
        width:180px;
        height:180px;
        border-right:1px solid #000;
    }
    .level-0-typo{  margin:10px 0px 20px 0px;}


    .level-1-point{
        cursor:pointer;
        border-right:0px solid #000;
    }
    .level-1-point:hover{border-bottom:3px solid red;}

    .fa-small{width:10px; margin:6px 20px 0px 20px;}
    .hero-heading{font-size:50px;}

    #foot-menu{        left:10px;    }
}









.burger{ border: 0px solid #000; width: 35px; padding:11px;  margin-top: 2px; border-radius: 4px; cursor:pointer;}

.burger-span {
    height: 4px;
    width: 30px;
    display: block;
    margin-bottom: 5px;
    border-radius: 20px;
    transition: 0.3s;
}

.burger-black .burger-bg{background:#000;}
.burger-black .burger-bg:hover{background:#fff; border: 2px solid #000;}
.burger-black .burger-span{background:#fff;}
.burger-black .burger-span:hover{background:#000;}

.burger-white .burger-bg{background:#fff; border: 0px solid #000;}
.burger-white .burger-bg:hover{background:#000;}
.burger-white .burger-span{background:#000;}
.burger-white .burger-span:hover{background:#fff;}



