/* *,
a {
    cursor: none !important;
}
 */


/* html.et-fb>*,
html.et-fb>a {
    cursor: inherit !important;
} */

#cursor {
    display: none !important;
    position: fixed;
    top: 0;
    left: 0;
    border-radius: 50%;
    background-color: #ffff4c;
    width: 25px;
    height: 25px;
    pointer-events: none;
    z-index: 9999999999999;
    mix-blend-mode: difference;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    justify-content: center;
    transform: scale(1);
    transition: 0.3s transform, 0.3s background-color, 0.3s width, 0.3s height, border-radius 0.3s;
    ;
    pointer-events: none !important;
}

#cursor i {
    transform: scale(0);
    font-size: 16px;
    transition: 0.4s all !important;
}

#cursor.icon {
    transform: scale(1.4);
}

#cursor.icon i {
    transform: scale(1);
}

/* MENU HEADER LOGO */

/*
.et_pb_menu__logo img {
    width: 300px !important;
    height: 20px !important;
}
*/

 .et_pb_menu__logo {
width: 100%;
}

 .et_pb_menu__logo img {
  max-width: 350px !important; /* fixe Breite */
}
.wpml-ls-item .sub-menu {
    background: #fff !important;
}

.wpml-ls-item .sub-menu li a {
    color: #000 !important;
    padding: 0;
}

.dropdown-menu {
    visibility: hidden;
    pointer-events: none;
    display: none;
}

.et-hover .dropdown-menu {
    pointer-events: inherit;
}
/*
.et_pb_menu_inner_container {
    padding: 0 4rem;
    background: #fff;
}
*/
.et-menu li:not(.mega-menu) ul {
    width: 100% !important;
}

.et_pb_menu_0_tb_header.et_pb_menu .et_mobile_menu a {
    letter-spacing: 1.5px;
}

.category-menu .dropdown-menu .dsm-menu-container {
    visibility: hidden;
}

.category-menu .et_pb_menu__menu .dropdown-menu {
    visibility: hidden;
    z-index: -1;
    opacity: 0;

    -webkit-transition: 300ms all cubic-bezier(.4, 0, .2, 1);
    -moz-transition: 300ms all cubic-bezier(.4, 0, .2, 1);
    -o-transition: 300ms all cubic-bezier(.4, 0, .2, 1);
    -ms-transition: 300ms all cubic-bezier(.4, 0, .2, 1);
    transition: 300ms all cubic-bezier(.4, 0, .2, 1);

    position: fixed !important;

    bottom: auto;
    left: 0px;
    right: 0;
}
.et-menu li:not(.mega-menu) ul, #top-menu li:not(.mega-menu) ul {
    width: 100% !important;
}

.category-menu .menbutton {
    width: 210px;
    padding: 20px;
    margin: 0 auto;
}

.category-menu .et_pb_menu__menu li.first-level:hover .dropdown-menu {
    visibility: visible;
    opacity: 1;
    display: flex !important;
}

.category-menu .et-menu li {
    margin-top: 0px !important;
    position: relative;
    padding: 0 20px !important
}

.category-menu .et-menu li>a {
    margin-top: 0px !important;
    letter-spacing: 1.5px;
    position: relative;
}

.category-menu .et-menu .dsm-menu-container .menu-item a span {
    position: relative;
    transition: 0.3s all;
}
.category-menu .et-menu .dsm-menu-container .menu-item a span {
    position: relative;
    display: inline-block;
}

/* ------------------------------------------
   MENU INDICATOR (gelber Punkt unter Menüpunkt)
   ------------------------------------------ */

/* Alte Unterstreichungen ausschalten */
.category-menu .et-menu li::after {
  content: none !important;
  display: none !important;
}

/* Mobile Balken (Divi default) entfernen */
.category-menu .et_mobile_menu .first-level > a.icon-switch::before {
  content: none !important;
  display: none !important;
}

/* Grundstruktur: Links vorbereiten */
.category-menu .et-menu > li > a {
  position: relative !important;
  display: inline-block !important;
  text-decoration: none !important;
  padding-bottom: 10px !important; /* sorgt für Platz unter dem Text */
}

/* Punkt standardmäßig unsichtbar (klar unter dem Text positioniert) */
.category-menu .et-menu > li > a::after {
  content: "" !important;
  position: absolute !important;
  width: 5px !important;
  height: 5px !important;
  left: 50% !important;
  bottom: 0 !important; /* sitzt direkt UNTER dem Text, nicht darüber */
  transform: translate(-50%, 100%) scale(0) !important; /* leicht nach unten versetzt */
  background: #FFD600 !important;
  border-radius: 50% !important;
  opacity: 0 !important;
  transition: transform 0.15s ease, opacity 0.15s ease !important;
  display: block !important;
}

/* Hover- und Active-State: Punkt erscheint */
.category-menu .et-menu > li:hover > a::after,
.category-menu .et-menu > li.current-menu-item > a::after,
.category-menu .et-menu > li.current_page_item > a::after {
  transform: translate(-50%, 100%) scale(1) !important;
  opacity: 1 !important;
}

/* Optional: Für DSM-Menüs (falls vorhanden) dieselbe Logik */
.category-menu .et-menu .dsm-menu-container .menu-item > a {
  position: relative !important;
  display: inline-block !important;
  padding-bottom: 10px !important;
}

.category-menu .et-menu .dsm-menu-container .menu-item > a::after {
  content: "" !important;
  position: absolute !important;
  width: 5px !important;
  height: 5px !important;
  left: 50% !important;
  bottom: 0 !important;
  transform: translate(-50%, 100%) scale(0) !important;
  background: #FFD600 !important;
  border-radius: 50% !important;
  opacity: 0 !important;
  transition: transform 0.15s ease, opacity 0.15s ease !important;
}

.category-menu .et-menu .dsm-menu-container .menu-item:hover > a::after,
.category-menu .et-menu .dsm-menu-container .menu-item.current-menu-item > a::after,
.category-menu .et-menu .dsm-menu-container .menu-item.current_page_item > a::after {
  transform: translate(-50%, 100%) scale(1) !important;
  opacity: 1 !important;
}

.et_pb_menu--with-logo .et_pb_menu__menu>nav>ul>li>a:after {
    top: 68% !important;
    }

/* ------------------------------------------
   ENDE - MENU INDICATOR (gelber Punkt unter Menüpunkt).
   ------------------------------------------ */





.category-menu .et_mobile_menu li>a {
    background-color: transparent;
    position: relative;
}

.et_pb_module .mobile_menu_bar:before {
    top: 0;
}

.category-menu .et_mobile_menu .first-level>a:after {
    font-family: 'ETmodules';
    content: '\4c';
    color: #000;

    padding: 5px;
    font-weight: normal;
    position: absolute;
    font-size: 20px;
    top: 13px;
    right: 10px;
}

.category-menu .et_mobile_menu .first-level>a.icon-switch:before {
    content: "";
    width: 140px;
    height: 8px;
    position: absolute;
    background: #ff0;
    left: 0;
    bottom: 0;
}


.et_mobile_menu li a:hover,
.nav ul li a:hover {
    opacity: inherit;
}

.menu-row .colm-1 {
    display: flex;
    align-items: center;
    justify-content: center;
}

.category-menu .et_mobile_menu .first-level>.icon-switch:after {
    content: '\4b';

}

.category-menu .et_mobile_menu .dropdown-menu {
    display: none;
}

.category-menu .et_mobile_menu .dropdown-menu.reveal-items {
    display: block;
}

.dsm-menu-container li:after {
    content: none !important;
}

.category-menu .et_pb_menu__menu>nav>ul>li {
    position: relative;
}

.category-menu .et_mobile_menu .dropdown-menu {
    visibility: visible !important;
}

.customMenuSub nav ul {
    visibility: visible;
    position: relative;
    opacity: 1;
    background: transparent;
    border: 0;
    box-shadow: none;
    -webkit-box-shadow: none;

    width: inherit;
}

.nav ul li a:hover {
    background: inherit;
    opacity: inherit;
}

.et-menu li.first-mobile-menu-subitem {
    display: none;
}
.et_pb_menu__logo-wrap {
    height: 70px;
}



@media only screen and (max-width: 980px) {
    
    /*
    
    .et_pb_menu .et_mobile_menu {
        padding-left: 1em;
    }

    .menu-item.wpml-ls-item {
        text-align: right;
    }

    .et-menu li.first-mobile-menu-subitem {
        display: block;
    }

    .menu-row .colm-1 {
        display: none;
    }

    .menu-row .colm-2 {
        width: 100% !important;
    }

    .et_pb_menu_inner_container {
        padding-left: 1em;
        padding-right: 1em;
    }

    .et_pb_menu_0_tb_header.et_pb_menu .et_mobile_menu a {
        padding: 15px 15px;
    }
*/
    .et_pb_section_1_tb_header.et_pb_section {
        padding: 0 !important;
    }

    .et_mobile_menu li li {
        padding-left: 0;
    }

    .et_pb_menu .et_mobile_menu li ul {
        padding: 0;
    }

*/

.dsm_contact_form_7 input.text, .dsm_contact_form_7 input.title, .dsm_contact_form_7 input[type=date], .dsm_contact_form_7 input[type=email], .dsm_contact_form_7 input[type=number], .dsm_contact_form_7 input[type=password], .dsm_contact_form_7 input[type=tel], .dsm_contact_form_7 input[type=text], .dsm_contact_form_7 input[type=url], .dsm_contact_form_7 select, .dsm_contact_form_7 textarea{
    margin: 10px 0;
}
form button {
    margin-top: 10px;
    display: block !important;
}

@media (max-width: 998px) {
    #cursor {
        display: none;
    }
}


/* SVG-Burger Aniimation mobil */
/* Nur Animation */

.ham {
  cursor: pointer;
  transition: transform 400ms;
  user-select: none;
}
.hamRotate.active { transform: rotate(45deg); }

.line {
  fill: none;
  transition: stroke-dasharray 400ms, stroke-dashoffset 400ms;
  stroke: #000; /* Farbe nach Wunsch */
  stroke-width: 5.5;
  stroke-linecap: round;
}

.ham1 .top { stroke-dasharray: 40 139; }
.ham1 .bottom { stroke-dasharray: 40 180; }
.ham1.active .top { stroke-dashoffset: -98px; }
.ham1.active .bottom { stroke-dashoffset: -138px; }

/* Divis Original-Burger ausblenden */
.category-menu .mobile_menu_bar {
  display: none !important;
}


#custom-burger {
  width: 42px; 
  height: auto;
  margin-top: 8px;
}