.elementor-kit-16{--e-global-color-primary:#0E1015;--e-global-color-secondary:#333333;--e-global-color-text:#333333;--e-global-color-accent:#06319A;--e-global-color-d43be81:#444444;--e-global-color-9f5fea0:#CCCCCC;--e-global-color-ddb45b3:#FFFFFF;--e-global-color-25b5236:#F2F2F2;--e-global-color-c3e1c60:#FFFFFF;--e-global-color-dfc555b:#EDEDED;--e-global-color-d3de383:#F5F5F5;--e-global-color-063e37f:#EDEDED;--e-global-color-9585fda:#082A59;--e-global-color-3f1f3cc:#192436;--e-global-color-2082c09:#01579B;--e-global-color-df511ba:#06319A;--e-global-color-e21d1f3:#FFFFFF;--e-global-color-c474ef6:#CFD8DC;--e-global-color-935bf8a:#3E4E56;--e-global-color-472e775:#FFFFFF00;--e-global-color-bd67b92:#FFFFFF;--e-global-color-76dc93d:#050A14;--e-global-color-a86b494:#36485D;--e-global-color-63c8e04:#99C3FF;--e-global-color-fd5a2d3:#FFFFFF00;--e-global-color-bd32c6d:#E5E5E5;--e-global-color-8c3b51f:#FFFFFF;--e-global-color-6330a75:#ECF1F7;--e-global-color-611ffaae:#DDDDDD;--e-global-color-563ce203:#FFF;--e-global-color-071134f:#FFCC00;--e-global-color-1f68f25:#DD4E4E;--e-global-color-8782bb7:#4B4F91;--e-global-color-926d171:#802287;--e-global-color-3492061:#08A0C5;--e-global-color-8f105e5:#F4903A;--e-global-color-a4a7963:#4F811D;--e-global-color-a3402fb:#0D499B;--e-global-color-1bf2712:#A78A1A;--e-global-color-bc61d53:#00796B;--e-global-color-ac5909c:#8A4905;--e-global-color-7dc584c:#FF4198;--e-global-color-a9829e6:#58799A;--e-global-color-7c2fe27:#F1F6FB;--e-global-color-4f8f34e:#FFFFFFCC;--e-global-color-9032fc6:#FF8484;--e-global-color-b1d6940:#FFFFCE;--e-global-color-2f3336d:#FFFFFF00;--e-global-typography-primary-font-size:2rem;--e-global-typography-primary-font-weight:600;--e-global-typography-primary-line-height:1.2em;--e-global-typography-secondary-font-size:1.5rem;--e-global-typography-secondary-font-weight:600;--e-global-typography-secondary-line-height:1.2em;--e-global-typography-text-font-size:1rem;--e-global-typography-text-font-weight:400;--e-global-typography-text-text-transform:none;--e-global-typography-text-font-style:normal;--e-global-typography-text-line-height:1.4em;--e-global-typography-accent-font-size:1.07rem;--e-global-typography-accent-font-weight:500;--e-global-typography-accent-line-height:1.35em;--e-global-typography-491b855-font-size:4.5rem;--e-global-typography-491b855-font-weight:600;--e-global-typography-491b855-line-height:1.2em;--e-global-typography-a2b516a-font-size:1.25rem;--e-global-typography-a2b516a-font-weight:600;--e-global-typography-a2b516a-line-height:1.2em;--e-global-typography-2b44d79-font-size:1rem;--e-global-typography-2b44d79-font-weight:500;--e-global-typography-2b44d79-text-transform:uppercase;--e-global-typography-2b44d79-line-height:1.3em;--e-global-typography-6c13f45-font-size:1.25rem;--e-global-typography-6c13f45-font-weight:600;--e-global-typography-6c13f45-line-height:1.3em;--e-global-typography-c575672-font-size:0.8125rem;--e-global-typography-c575672-font-weight:normal;--e-global-typography-c575672-line-height:1.3em;--e-global-typography-ee9e63a-font-size:0.75rem;--e-global-typography-ee9e63a-font-weight:normal;--e-global-typography-ee9e63a-line-height:1.3em;background-color:var( --e-global-color-c3e1c60 );color:var( --e-global-color-secondary );font-family:"Arial", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif;font-size:100%;font-weight:400;text-transform:none;line-height:1.3em;}.elementor-kit-16 button,.elementor-kit-16 input[type="button"],.elementor-kit-16 input[type="submit"],.elementor-kit-16 .elementor-button{background-color:var( --e-global-color-3f1f3cc );font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );text-transform:var( --e-global-typography-text-text-transform );font-style:var( --e-global-typography-text-font-style );line-height:var( --e-global-typography-text-line-height );color:var( --e-global-color-e21d1f3 );border-style:solid;border-width:1px 1px 1px 1px;border-color:var( --e-global-color-fd5a2d3 );border-radius:0.275rem 0.275rem 0.275rem 0.275rem;padding:12px 12px 12px 12px;}.elementor-kit-16 button:hover,.elementor-kit-16 button:focus,.elementor-kit-16 input[type="button"]:hover,.elementor-kit-16 input[type="button"]:focus,.elementor-kit-16 input[type="submit"]:hover,.elementor-kit-16 input[type="submit"]:focus,.elementor-kit-16 .elementor-button:hover,.elementor-kit-16 .elementor-button:focus{background-color:var( --e-global-color-2082c09 );color:var( --e-global-color-e21d1f3 );border-style:solid;border-width:1px 1px 1px 1px;border-color:var( --e-global-color-fd5a2d3 );border-radius:0.275rem 0.275rem 0.275rem 0.275rem;}.elementor-kit-16 p{margin-block-end:0px;}.elementor-kit-16 a{font-size:0.9375rem;font-weight:400;text-transform:none;font-style:normal;line-height:1.3em;}.elementor-kit-16 h1{color:var( --e-global-color-primary );}.elementor-kit-16 h2{color:var( --e-global-color-primary );}.elementor-kit-16 h3{color:var( --e-global-color-primary );}.elementor-kit-16 h4{color:var( --e-global-color-primary );font-size:var( --e-global-typography-accent-font-size );font-weight:var( --e-global-typography-accent-font-weight );line-height:var( --e-global-typography-accent-line-height );}.elementor-kit-16 h5{color:var( --e-global-color-primary );}.elementor-kit-16 h6{color:var( --e-global-color-primary );}.elementor-kit-16 label{color:var( --e-global-color-primary );font-size:var( --e-global-typography-c575672-font-size );font-weight:var( --e-global-typography-c575672-font-weight );line-height:var( --e-global-typography-c575672-line-height );}.elementor-kit-16 input:not([type="button"]):not([type="submit"]),.elementor-kit-16 textarea,.elementor-kit-16 .elementor-field-textual{font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );text-transform:var( --e-global-typography-text-text-transform );font-style:var( --e-global-typography-text-font-style );line-height:var( --e-global-typography-text-line-height );color:var( --e-global-color-primary );accent-color:var( --e-global-color-primary );background-color:var( --e-global-color-7c2fe27 );border-style:solid;border-width:1px 1px 1px 1px;border-color:var( --e-global-color-a9829e6 );border-radius:3px 3px 3px 3px;padding:10px 10px 10px 10px;}.elementor-kit-16 input:focus:not([type="button"]):not([type="submit"]),.elementor-kit-16 textarea:focus,.elementor-kit-16 .elementor-field-textual:focus{color:var( --e-global-color-primary );accent-color:var( --e-global-color-primary );background-color:var( --e-global-color-7c2fe27 );border-style:solid;border-width:1px 1px 1px 1px;border-color:var( --e-global-color-a9829e6 );border-radius:3px 3px 3px 3px;}.elementor-widget:not(:last-child){--kit-widget-spacing:10px;}.elementor-element{--widgets-spacing:10px 10px;--widgets-spacing-row:10px;--widgets-spacing-column:10px;}{}h1.entry-title{display:var(--page-title-display);}@media(max-width:1024px){.elementor-kit-16{--e-global-typography-primary-font-size:1.75rem;--e-global-typography-secondary-font-size:1.75rem;--e-global-typography-491b855-font-size:3rem;}.elementor-kit-16 h4{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );}.elementor-kit-16 button,.elementor-kit-16 input[type="button"],.elementor-kit-16 input[type="submit"],.elementor-kit-16 .elementor-button{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );}.elementor-kit-16 label{font-size:var( --e-global-typography-c575672-font-size );line-height:var( --e-global-typography-c575672-line-height );}.elementor-kit-16 input:not([type="button"]):not([type="submit"]),.elementor-kit-16 textarea,.elementor-kit-16 .elementor-field-textual{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );}}@media(max-width:767px){.elementor-kit-16{--e-global-typography-primary-font-size:1.5rem;--e-global-typography-secondary-font-size:1.25rem;--e-global-typography-491b855-font-size:2rem;}.elementor-kit-16 h4{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );}.elementor-kit-16 button,.elementor-kit-16 input[type="button"],.elementor-kit-16 input[type="submit"],.elementor-kit-16 .elementor-button{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );}.elementor-kit-16 label{font-size:var( --e-global-typography-c575672-font-size );line-height:var( --e-global-typography-c575672-line-height );}.elementor-kit-16 input:not([type="button"]):not([type="submit"]),.elementor-kit-16 textarea,.elementor-kit-16 .elementor-field-textual{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );}}
/* Start custom CSS */a[href^="http://"]:not([href*="kukvo.com"]):after,
a[href^="https://"]:not([href*="kukvo.com"]):after {
font: normal 16px/1 'Huge Icons';
content: "\ee18";
padding-left:0px;
font-size: 15px; 
}

html {
    scrollbar-gutter: stable;
}

a.skip-link:focus {
    --i-outline-offset: 0px;
    position: absolute;
    top: 10px;
    inset-inline-start: 10px;
    z-index: 9999;
    background: var( --e-global-color-2082c09 );
    color: var( --e-global-color-e21d1f3 );
    border-radius: 6px;
    padding: .8em 1.2em;
    width:auto !important;
    height: auto !important;
    clip: auto !important;
}

span.logoLang {
    display: flex;
    min-height: 40px;
    font-size: 12px;
    color:var( --e-global-color-primary );
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif !important;
}

/* KBD-Tag Styling für den "Tasten-Look" */
.shortcut-hint kbd {
    background-color: var( --e-global-color-d3de383 );
    border-radius: 3px;
    border: 1px solid var( --e-global-color-bd32c6d );
    box-shadow: 0 1px 1px rgba(0,0,0,0.2);
    color: var( --e-global-color-secondary );
    display: inline-block;
    font-size: 0.85em;
    font-weight: 700;
    line-height: 1;
    padding: 2px 4px;
    white-space: nowrap;
}

.is-windows-os .mac-shortcut, .is-mac-os .win-shortcut {
    display: none !important;
}


@media (pointer: coarse) {
    .shortcut-hint {
        display: none !important;
    }
}

main {
  animation: fadeInPage 0.5s ease-in-out;
}
@keyframes fadeInPage {
  from { opacity: 0; transform: translateY(15px); }
  to { opacity: 1; transform: translateY(0); }
}


@keyframes fadeDown {
    from {
        opacity: 0;
        transform: translate3d(0,-30px,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.elementor-element.fadeInDown {
    animation-name: fadeDown
}

@keyframes fadeLeft {
    from {
        opacity: 0;
        transform: translate3d(-30px,0,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.elementor-element.fadeInLeft {
    animation-name: fadeLeft
}

@keyframes fadeRight {
    from {
        opacity: 0;
        transform: translate3d(30px,0,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.elementor-element.fadeInRight {
    animation-name: fadeRight
}

@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translate3d(0,30px,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.elementor-element.fadeInUp {
    animation-name: fadeUp
}



.logoLink {
    min-width: 44px;
    min-height: 44px;
    align-items: center;
    display: flex;
}


.logoLink:hover {
--e-global-color-accent: #4b80cc !important;
}

.image-container-hero {
aspect-ratio: 15 / 9;
  width: 100%;
   max-width: 565px;
}



.manualButton1 {
    border: 1px solid var( --e-global-color-df511ba ) !important;
}

a.elementor-button, button {
    min-height: 44px;
    min-width: 44px;
}


fieldset.hidden-fields-container {
    border: 0;
    padding: 0;
}

fieldset {
    padding: 0;
    border: 0;
}

.elementor-widget-text-editor ul {
    padding: 0 0  0 15px;

}

.elementor-widget-text-editor ul li {
    margin-bottom: 15px;
}


.e-con-boxed, .elementor-widget-call-to-action, .elementor-widget-icon-box, .elementor-element  {
	transition:color 0s linear, background-color 0s linear !important;
}

a.logoLink {
    display: flex;
    max-width: 170px
}

figcaption.widget-image-caption.wp-caption-text {
    margin: 5px 0 0;
}


.faq-section details {
    border: 1px solid var( --e-global-color-2f3336d );
    background: var( --e-global-color-d3de383 );
    border-radius: 5px;
}

.faq-section2 details {
    border: 1px solid var( --e-global-color-2f3336d );
    background: var( --e-global-color-c3e1c60 );
    border-radius: 5px;
}

.datenschutz-link a {
    color: inherit;
    text-decoration: underline;
      overflow-wrap: break-word;
  word-wrap: break-word;
}


.slider-wrapper {
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;      
  overflow: hidden;
}

.slide {
  grid-area: 1 / 1; /* Alle Slides belegen die gleiche Grid-Zelle */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease;
}

.slide.active {
  opacity: 1;
  visibility: visible;
    animation: fadeInSlide1 0.5s ease-in;
  position: relative; /* Sorgt dafür, dass diese Folie die Höhe vorgibt */
}



@keyframes fadeInSlide1 {
  from {
    opacity: 0;
    transform: scale(0.96); /* Startet leicht verkleinert */
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.slider-controls i { pointer-events: none; }

strong, .safari-weight * {
    font-weight: 600;
}

body {
    padding: 0 !important;
    margin: 0 auto;
}

.comment-awaiting-moderation {
    background: #d9f7e8;
    padding: 5px;
    margin: 10px 0;
    display: block;
    color: #207120;
    border: 1px solid #207120;
}

/* Menu */

.openMainMenuBtn {
    font-size: 34px !important;
    cursor: pointer !important;
    padding: 0 !important;
    background: transparent !important;
    color: var( --e-global-color-primary ) !important;
    border: 0 !important;
    display:flex;
    min-width: 44px;
    min-height: 44px;
    justify-content: center;
    align-items: center;
}

.closeMainMenuBtn {
    cursor: pointer;
}

.elementor.elementor-25272 {
    justify-content: center;
    display: flex;
}

.mainMenuModal {
  display: none;
   position: fixed;
   top:70px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 1100px;
  z-index: 999999999999999999999;
animation: scale-in-ver-center 0.3s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}


.show-mainMenuModal {
    display: block;
    opacity: 1;
}

.mainMenuModal.mainMenuModal-is-closing {
animation: scale-out-vertical 0.3s cubic-bezier(0.550, 0.085, 0.680, 0.530) both;
}

.menuMega1 .elementor-icon-wrapper, .menuMega2 .elementor-icon-wrapper {
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}


/* header Setting Button */

.openInclusionToolbar {
    font-size: 34px !important;
    cursor: pointer !important;
    padding: 0 !important;
    background: transparent !important;
    color: var( --e-global-color-accent ) !important;
    border: 0 !important;
    display:flex;
    min-width: 44px;
    min-height: 44px;
    justify-content: center;
    align-items: center;
}

.closeInclusionToolbar {
    cursor: pointer;
}

svg.inclusion-toolbar-icon {
    width: 32px;
    color: var( --e-global-color-accent );
    fill: var( --e-global-color-accent );
}

button#inclusionToolbar-open-btn:hover {
    transform: scale(1.4);
}

.inclusionToolbarModal {
    display: none;
    position: fixed;
    top:0px;
    right: 0px;
    width: 394px;
    z-index: 999999999;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scrollbar-width: none; 
    -ms-overflow-style: none;  
    scrollbar-gutter:stable;
    height: 100dvh;
    padding: 0;
    background-color: var(--e-global-color-c3e1c60);
    border-left: 1px solid var( --e-global-color-primary );
animation: scale-in-hor-right 0.3s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}

.inclusionToolbarModal::-webkit-scrollbar {
  display: none;
}

.inclusionToolbarModal.inclusionToolbar-is-closing {
    animation: scale-out-hor-right 0.3s cubic-bezier(0.550, 0.085, 0.680, 0.530) both;
}

.show-inclusionToolbar {
    display: block;
    opacity: 1;
}

.hint-bubble {
    position: absolute;
    top: calc(100% + 10px);
    left: -8px;
    font-size: var( --e-global-typography-ee9e63a-font-size );
    background: #0a2c7f;
    color: #ffffff;
    padding: 10px;
    border-radius: 5px;
    width: 115px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.2);
    z-index: 1000;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

/* Sichtbarer Zustand */
.hint-bubble.visible {
  opacity: 1;
  transform: translateY(0);
}

.hint-bubble.hidden { display: none; }

.arrow {
  position: absolute;
  bottom: 100%; left: 20px;
  border: 10px solid transparent;
  border-bottom-color: #0a2c7f;
}

.rotate-center {
    animation: rotate-center 1.6s ease-in-out both;
}

@keyframes rotate-center {
  0% { transform: rotate(0); }
  100% { transform: rotate(360deg); }
}

@media screen and (max-width: 768px) {

.inclusionToolbarModal {
    position: fixed;
    top: 0px;
    left: 0;
    right:0;
    margin: 0 auto;
    width: 100%;
      padding: 0 0 100px;
  height: 100dvh;
      border-left: 0px solid var( --e-global-color-primary );
}

body.inclusionToolbar-is-open {
    overflow: hidden;   
    position: fixed;  
    width: 100%;  
    min-height: 100vh;
    touch-action: none;  /* Deaktiviert Touch-Scroll-Gesten */
}

body.mainMenuModal-is-open {
    overflow: hidden;    /* Standard für Desktop */
    position: fixed;     /* Verhindert Scrollen auf iOS Safari */
    width: 100%;         /* Verhindert Layout-Verschiebung bei fixed */
    min-height: 100vh;
    touch-action: none;  /* Deaktiviert Touch-Scroll-Gesten */
}

.ModalSettings1 {
    box-shadow: none !important;
}

.mainHeader7 [data-tooltip] {
    &:after {
        visibility: hidden !important;
    }
}


}

/* footer Menu */

.breadcrumb {
    display: flex;
    align-items: center;
}
	
.menuFooterIcon {
    display: block;
    width: 100%;
}

.menuFooterIcon ul.elementor-icon-list-items {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 25px;
}


.menuFooterIcon a {
    background: rgba(0, 0, 0, 0.5);
    padding: 12px 10px;
    display: inline-flex !important;
    border-radius: 5px;
    border: 1px solid var( --e-global-color-a86b494 );
    transition: color 0.25s;
    box-shadow: 1px 1px 5px #00000052;
}

.menuFooterIcon a:hover {var( --e-global-color-a86b494 )
    background: rgba(0, 0, 0, 0.8);

}

/* Die Linien-Elemente */
.menuFooterIcon a::before,
.menuFooterIcon a::after {
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  border: 1px solid transparent;
  box-sizing: border-box;
  border-radius: 5px; 
}

/* Oben und Rechts */
.menuFooterIcon a::before {
  top: 0;
  left: 0;
}

/* Unten und Links */
.menuFooterIcon a::after {
  bottom: 0;
  right: 0;
}

.menuFooterIcon a:hover::before,
.menuFooterIcon a:hover::after {
  width: 100%;
  height: 100%;
}

.menuFooterIcon a:hover::before {
  border-top-color: var( --e-global-color-63c8e04 );
  border-right-color: var( --e-global-color-63c8e04 );
  transition: width 0.25s ease-out, height 0.25s ease-out 0.25s;
}

.menuFooterIcon a:hover::after {
  border-bottom-color: var( --e-global-color-63c8e04 );
  border-left-color: var( --e-global-color-63c8e04 );
  transition: width 0.25s ease-out, height 0.25s ease-out 0.25s;
}

.menuFooterIcon li:last-child a {
    margin: 0;
}

.menuFooterIcon span.elementor-icon-list-icon {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-align: center !important;
}

.menuFooterIcon .elementor-widget .elementor-icon-list-icon i {
    width: auto;
}

.menuFooterIcon span.footerLinkBe {
    font-size: var( --e-global-typography-ee9e63a-font-size );
    display: block;
    color: var( --e-global-color-9f5fea0 );
}

.menuFooterIcon .elementor-icon-list-icon+.elementor-icon-list-text {
    padding-inline-start: 10px;
}

.menuFooterIcon a:hover .elementor-icon-list-text {
    color: var( --e-global-color-63c8e04 ) !important;
}

.menuFooterIcon a:hover span.elementor-icon-list-icon i {
    color: var( --e-global-color-63c8e04 ) !important;
    fill: var( --e-global-color-63c8e04 ) !important;
}

.footerLinks a:hover span {
    text-decoration: underline;
}

.accessibility-support1 .elementor-image-box-wrapper {
    display: flex !important;
    align-items: center;
}

.accessibility-support1 .elementor-image-box-img {
    margin-right: 15px !important;
    display: flex;
}

/* animation part */
@keyframes scale-in-ver-center {
  0% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    opacity: 1;
  }
}

@keyframes scale-out-vertical {
  0% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    opacity: 1;
  }
  100% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    opacity: 1;
  }
}


@keyframes scale-in-hor-right {
  0% {
            transform: scaleX(0);
            transform-origin: 100% 100%;
    opacity: 1;
  }
  100% {
            transform: scaleX(1);
            transform-origin: 100% 100%;
    opacity: 1;
  }
}

@keyframes scale-out-hor-right {
  0% {
            transform: scaleX(1);
            transform-origin: 100% 100%;
    opacity: 1;
  }
  100% {
            transform: scaleX(0);
            transform-origin: 100% 100%;
    opacity: 1;
  }
}


.elementor-location-footer:before, .elementor-location-header:before {
    content: none;
}

.elementor-kit-888 .e-page-transition {
    z-index: 9999999999999;
}

.elementor-button {
	transition: background .2s linear !important;
	transition: border-color .2s linear;
}

._brlbs-box.delay-1s {
    animation-delay: 7s!important;
}

@keyframes animated_gradient {
	0% { background-position: 0px 50%; }
	50% { background-position: 100% 50%; }
	100% { background-position: 0px 50%; }
}

picture.bdt-logo-grid-img.bdt-image-mask.elementor-animation- {
    display: flex;
    align-items: center;
}

.welcomeFont {
    background: linear-gradient(90deg,#0090f7,#ba62fc,#f2416b,#f55600,#f2416b,#ba62fc,#0090f7,#ba62fc,#f2416b,#f55600);
    background-size: 300% 100%;
    color: rgba(0,0,0,0) !important;
    background-clip: text;
    -webkit-text-fill-color: rgba(0,0,0,0);
    text-fill-color: rgba(0,0,0,0);
    display: block;
    font-size: 1.9em;
    line-height: 1.4em;
    font-weight:500;
    margin: 7px 0 0;
}

.colorpink {
    color: #f151c2;
}

.colorlila {
    color: #927ae4;
}

/* Elementend */

.bdt-progress-with-top .bdt-progress-wrap.active-progress {
    background: var( --e-global-color-c3e1c60 ) !important;
}

.darkmode-active {
    display: none;
}



h1, h2, h3, h4, h5, h6 {
    margin: inherit;
}


small {
    font-size: var( --e-global-typography-ee9e63a-font-size ) !important;
}


.abPreis {
    font-size: var( --e-global-typography-ee9e63a-font-size );
    color: var( --e-global-color-primary );
}

a.elementor-cta__button {
    min-height: 44px;
}

#wrap {
    width: 100% !important;
}

span.wpcf7-not-valid-tip {
    margin: 0 0 10px;
}

input[type=date]:focus-visible, input[type=email]:focus-visible, input[type=number]:focus-visible, input[type=password]:focus-visible, input[type=search]:focus-visible, input[type=tel]:focus-visible, input[type=text]:focus-visible, input[type=url]:focus-visible, select:focus-visible, textarea:focus-visible {
    outline: 1px solid var( --e-global-color-accent );
}

select {
    text-indent: 6px;
    line-height: 30px;
    -webkit-appearance: initial;
}

.wpcf7-form-control:not(.wpcf7-submit) {
    padding: 10px 10px 10px 10px;
    border-radius: 3px 3px 3px 3px;
    color: var( --e-global-color-primary );
    border-style: solid;
    border-width: 1px 1px 1px 1px;
    border-color: var( --e-global-color-a9829e6 );
    background-color: var( --e-global-color-7c2fe27 );
    font-size: var( --e-global-typography-text-font-size );
    font-weight: var( --e-global-typography-text-font-weight );
    text-transform: var( --e-global-typography-text-text-transform );
    line-height: var( --e-global-typography-text-line-height );
    margin: 7px 0 5px !important;
}

span.wpcf7-list-item {
    display: block;
    margin: 0 0 5px;
}

label {
    display: block;
}

input.wpcf7-submit {
    margin-top: 20px;
    min-height: 44px;
}

.elementor-form-fields-wrapper input {
    min-height: 44px !important;
}


/* page webdesign extra*/

.anfrageFormular1 {
    list-style: none;
    margin: 0;
	padding:0;
}

span.wpcf7-quiz-label {
    margin: 0 0 1px;
    display: block;
}

.txtdis {
    margin: 5px 0 0 5px;
    display: block;
    font-size: 0.8125rem;
}

.formular1 label {
    margin: 0 0 15px;
}

a.elementor-post__read-more {
    min-height: 44px;
    min-width: 44px;
    display: inline-flex !important;
    align-items: center;
}

.animateLink1 a, a.elementor-post__read-more {
  text-decoration: none;
  position: relative;
}

.animateLink1 a::after, a.elementor-post__read-more::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 2px;
  bottom: 0;
  left: 0;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: bottom right;
  transition: transform 0.3s ease-out;
}

.animateLink1 a:hover::after, a.elementor-post__read-more:hover::after {
  transform: scaleX(1); /* Wird auf volle Breite skaliert */
  transform-origin: bottom left;
}

@media only screen and (min-width: 1025px) {

.topBar {
    z-index: 11;
}

.single-post .breadcrumb li.breadcrumb-item.active {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 250px;
}
	
}

@media only screen and (max-width: 1024px) {
	

.menuFooterIcon ul.elementor-icon-list-items {
    gap: 15px;
}

span.elementor-headline-dynamic-text.elementor-headline-text-active {
    z-index: auto;
}
	
	
br {
    display: block !important;
}
	
.nav-bar .module-group {
    width: 16%;
}

.single-post .breadcrumb li.breadcrumb-item.active {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 120px;
}

.mainMenuModal {
    top: 0;
    left: 0;
    width: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    height: 100vh;
    max-height: 100vh;
    padding:0 0 100px;
    background-color:var( --e-global-color-c3e1c60 );
}

.closeMainMenuBtnx {
    position: fixed !important;
    top: -5px !important;
    right: 20px !important;
}
	
}

@media only screen and (max-width: 767px) {
    
	
a.skip-link:focus {
    position: relative;
    top: 0;
    margin: 0;
    display: flex;
    width: 100% !important;
    inset-inline-start: 0;
    border-radius: 0;
    flex-direction: column;
    align-items: center;
}
	
.single-post .breadcrumb li.breadcrumb-item.active {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 60px;
}

.single-post ol.breadcrumb {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}

._brlbs-box {
    border-color: var(--e-global-color-bd67b92);
    border-width: 1px 0 0;
    border-style: solid;
}
	
	
#footerMenuPrint ul {
    display: block !important;
}
	
#footerMenuPrint ul li {
    display: block !important;
    margin: 0 15px 15px !important;
}
	
}


/* UI Elemente */



/* radio buttons grid */

.radio-buttons-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 2 Spalten */
  gap: 8px;
}

/* Radio-Buttons verstecken, aber für Tastatur erreichbar lassen */
.grid-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

/* Kachel Styling */
.grid-content {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px;
    background: var( --e-global-color-d3de383 );
    border: 2px solid var( --e-global-color-bd32c6d );
    border-radius: 0.275rem;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
    min-height: 44px;
}

.grid-option:hover .grid-content {
  border-color: var( --e-global-color-accent );
}

/* Aktiver Status (wenn Radio ausgewählt ist) */
.grid-option input:checked + .grid-content {
    border-color: var( --e-global-color-accent );
    background: var( --e-global-color-063e37f );
    color: var( --e-global-color-accent );
}

/* Fokus-Zustand für Barrierefreiheit (Tastatur-User) */
.grid-option input:focus-visible + .grid-content {
  outline: 2px solid #006fee;
  outline-offset: 2px;
}

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* TOOGLE */
.toggle-container {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 0px;
}

.ios-toggle-input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Die "Schiene" im Liquid Glass Look */
.ios-toggle-switch {
    width: 44px;
    height: 24px;
    border-radius: 20px;
    background: linear-gradient(145deg, #1a1d21, #838383);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    position: relative;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1);
    border: 1px solid #7b7b7b;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Der "Knopf" (Liquid Drop) */
.ios-toggle-switch::after {
    content: "";
    width: 18px;
    height: 18px;
    top: 2px;
    left: 2px;
    
    /* Hochglanz-Weiß mit leichtem Verlauf */
    background: linear-gradient(145deg, #ffffff, #e6e6e6);
    
    border-radius: 50%;
    position: absolute;
    transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    
    /* Starker Schatten für den "Schwebenden" Look */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Zustand 'AN' */
.ios-toggle-input:checked + .ios-toggle-switch {
    background: linear-gradient(145deg, #2575e3, #1c49ba);
    border: 1px solid rgb(28 73 186);
}

.ios-toggle-input:checked + .ios-toggle-switch::after {
    /* Verschiebung + Farbe des Knopfes anpassen */
    transform: translateX(20px);
    background: linear-gradient(145deg, #ffffff, #e6e6e6);
    box-shadow: 0 4px 12px rgba(28, 73, 186, 0.4);
}

/* Fokus-Zustand */
.ios-toggle-input:focus-visible + .ios-toggle-switch {
    outline: 2px solid rgba(0, 0, 0, 1);
}

/* SCHIEBEREGLER */

.range-container {
    display: flex;
    align-items: center;
    gap: 15px;
    flex-direction: row;
    justify-content: space-around;
    width: 380px;
    border-top: 1px solid #ccc;
    margin: 5px 0 0;
    height: 30px;
    padding: 5px 0 0;
}

/* Container-Styling (optional) */
.control-white-point1 {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 10px 0 0;
}

/* Der Schieberegler an sich */
.rangeCostum1 {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 200px;
    padding: 1px !important;
    border: 0 !important;
    height: 4px !important;
    background: var( --e-global-color-primary ) !important;
    border-radius: 2px !important;
    outline: none;
    transition: background 0.2s;
}

/* Der runde Knopf (Thumb) für Chrome, Safari, Edge, Opera */
.rangeCostum1::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 26px;
    height: 26px;
    background: linear-gradient(145deg, #2575e3, #1c49ba) !important;
    border-radius: 50%;
    border: 0.5px solid rgba(0,0,0,0.1); /* Hauchdünner Rand */
    box-shadow: 0 3px 8px rgba(0,0,0,0.15), 0 3px 1px rgba(0,0,0,0.06); /* iOS Schatten-Stil */
    cursor: pointer;
}

/* Der runde Knopf für Firefox */
.rangeCostum1::-moz-range-thumb {
    width: 26px;
    height: 26px;
    background: #ffffff;
    border-radius: 50%;
    border: 0.5px solid rgba(0,0,0,0.1);
    box-shadow: 0 3px 8px rgba(0,0,0,0.15);
    cursor: pointer;
}

/* Prozentanzeige Styling */
#brightnessValue {
    font-size: var( --e-global-typography-a2b516a-font-size );
    color: var( --e-global-color-29fc663 ); 
    min-width: 35px;
}

.rangeCostumLabel1 {
    font-size: var(--e-global-typography-ee9e63a-font-size);
    font-weight: var(--e-global-typography-ee9e63a-font-weight);
    line-height: var(--e-global-typography-ee9e63a-line-height);
    color: var(--e-global-color-29fc663);
}


/* Dark mode */

html[data-color-scheme="dark"] .elementor-kit-888 {
    /* Primary */
    --e-global-color-primary: #e8e8e8;
    /* secondary */
    --e-global-color-secondary: #bfbfbf;
    /* LinkText */
    --e-global-color-text: #bfbfbf;
    /* 4yourdesign Blue */
    --e-global-color-accent: #99c3ff;
    /* Text Grey 1 */
    --e-global-color-d43be81: #aaaaaa;
    /* Text Grey 2 */
    --e-global-color-9f5fea0: #CCCCCC;
    /* Text White */
    --e-global-color-ddb45b3: #eeeeee;
    /* Text White 2 */
    --e-global-color-25b5236: #cccccc;
    /*Main-BG-White-Black*/
    --e-global-color-c3e1c60: #1a1d21;
    /* BG-Hover */
    --e-global-color-063e37f: #0e0e0f;
    /* Border-trenlinie */
    --e-global-color-dfc555b: #131316;
    /* Accent-BG */
    --e-global-color-d3de383: #131316;
    /* Accent-BG-Hover */
    --e-global-color-5a8bae4: #0e1015;
    /* BG-black-dark-blue */
    --e-global-color-9585fda: #1a222d;
    /* button-color-1 */
    --e-global-color-3f1f3cc: #233C61;
    /* button-color-2 */
    --e-global-color-2082c09: #111621;
    /* button-border-1 */
    --e-global-color-df511ba: #2961b0;
    /* button-text-1 */    
    --e-global-color-e21d1f3: #FFFFFF;
    /* smallButton */
    --e-global-color-c474ef6: #2f394c;
    /* smallButtonHover */
    --e-global-color-935bf8a: #252d3c;
    /* small-Button-Border-1 */
    --e-global-color-472e775: #415c81;
    /* Seperator */
    --e-global-color-bd67b92: #55555899;
    /* footerBG */
    --e-global-color-76dc93d: #101218;
    /* footerBorder */    
    --e-global-color-a86b494: #36485D;
    /* footer-link-color */
    --e-global-color-63c8e04: #99c3ff;
    /* Transparent */
    --e-global-color-fd5a2d3: #FFFFFF00;
    /* menu Border */
    --e-global-color-bd32c6d: #55555899;
    /*border-white-light-blue */
    --e-global-color-8c3b51f: #808c9c;
    /*info bg color */  
    --e-global-color-6330a75: #1e2734;
    /* Border-Color1 */
    --e-global-color-611ffaae: #353535;
    /* white */
    --e-global-color-563ce203: #f1f1f1;
    /* Yellow */
    --e-global-color-071134f: #ffd60a;
    /* red */
    --e-global-color-1f68f25: #FE8686;
    /* Purble */
    --e-global-color-8782bb7: #7982FF;
    /* cosmos pink */
    --e-global-color-926d171: #D5A3F0;
    /* sun blue */
    --e-global-color-3492061: #22CCF7;
    /* orange */
    --e-global-color-8f105e5: #F4903A;
    /* green */
    --e-global-color-a4a7963: #73BB2B;
    /* blue */
    --e-global-color-a3402fb: #76ADF9;
    /* Gold */
    --e-global-color-1bf2712: #D0B135;
    /* Türkis */
    --e-global-color-bc61d53: #10ede8;
    /* Brown */
    --e-global-color-ac5909c: #d09353;
    /* Pink */
    --e-global-color-7dc584c: #ff61a9;
    /* form border */
    --e-global-color-a9829e6: #657592;
    /* form background */
    --e-global-color-7c2fe27: #131316;
        /* backdrop-bg */
    --e-global-color-4f8f34e: #1a1d21CC;
        /* TextRead-BG */    
    --e-global-color-b1d6940: #0a224d;
        /* kontrast-border */        
    --e-global-color-2f3336d: #FFFFFF00;
}

html[data-color-scheme="dark"] .colorf1 {fill:#000000 !important;}
html[data-color-scheme="dark"] .colorf2 {fill:#1a171b !important;}


html[data-color-scheme="dark"] .darkmode-noactive {
    display: none;
}
   
html[data-color-scheme="dark"] .darkmode-active {
    display: initial;
}

html[data-color-scheme="dark"] .leistungenBoxen .elementor-widget-icon-box .elementor-widget-container {
    background: linear-gradient(35deg, var( --e-global-color-c3e1c60 ) 40%, #131316 100%) !important;
    border: 1px solid #373739 !important;
}

html[data-color-scheme="dark"] .contactBox1 {
    background-image: linear-gradient(260deg,#554095 0%,#121212 100%) !important;
    border: 1px solid #586a8d !important;
    border-width: 1px 0 !important;
}

html[data-color-scheme="dark"] .elementor-12920 .elementor-element.elementor-element-25cc2a1, html[data-color-scheme="dark"] .elementor-12663 .elementor-element.elementor-element-97f08d6 {
    box-shadow: 0px 0px 50px 0px rgba(0, 0, 0, 1);
}

html[data-color-scheme="dark"] .ha-creative-btn-wrap .ha-stl--hermosa {
    color: #fff;
}

html[data-color-scheme="dark"] .elementor-11569 .elementor-element.elementor-element-3648dcf:not(.elementor-motion-effects-element-type-background), html[data-color-scheme="dark"] .elementor-11569 .elementor-element.elementor-element-3648dcf > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-image: linear-gradient(to right top, #071931 0%, #33274f 50%, #661e43 100%);
}


html[data-color-scheme="dark"] .wpcf7-not-valid-tip {
    color: #e59696;
}


html[data-color-scheme="dark"] .topBar .elementor-background-overlay {
    background-color: #625299 !important
}

html[data-color-scheme="dark"] .topBar {
    background: #261f3e !important;
}

html[data-color-scheme="dark"] .logoLink:hover {
--e-global-color-accent: #0a9fef !important;
}

/* LESELINIE UND LESEMASKE*/
.reading-line {
    position: fixed;
    height: 7px;
    width: 100%;
    border: 2px solid #ff0;
    border-width: 2px 0;
    background-color: #000;
    pointer-events: none;
    left:0;
    top: 0;
    z-index: 99999999999;
    display: none; 
}

html[data-read-helpline="line"] .reading-line {
    display: block; 
}
    
.reading-mask-Old {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw; 
    height: 100vh; 
    pointer-events: none;
    z-index: 100;
    display: none; 
    border: 1px solid #99b2d8;
    border-width: 1px 0;
}


html[data-read-helpline="mask"] .reading-mask-Old {
    display: block; 
}


html[data-read-helpline="mask"] .reading-mask-Old::after {
    content: '';
    display: block;
    width: 100%;
    max-width: 100%;
    height: 75px;
    box-shadow: 0 0 0 5000px rgba(0, 0, 0, 0.7); 
    z-index: 9999999999999;
    position: absolute;
    left: var(--mouse-x, 0); 
    top: var(--mouse-y, 0);
    transform: translate(-50%, -50%); 
}

.reading-mask {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw; 
    height: 100vh; 
    pointer-events: none;
    z-index: 100;
    display: none; 
}

html[data-read-helpline="mask"] .reading-mask {
    display: block; 
}


html[data-read-helpline="mask"] .reading-mask::before,
html[data-read-helpline="mask"] .reading-mask::after {
    content: '';
    position: absolute;
    left: 0;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);  
    z-index: 9999999;
}


html[data-read-helpline="mask"] .reading-mask::before {
    top: 0;
    height: calc(var(--mouse-y) - 37px); /* Halbe Schlitzhöhe (75px / 2) */
    border-bottom: 2px solid #99b2d8;
}

/* Unterer Teil: Vom Ende des Schlitzes bis zum unteren Rand */
html[data-read-helpline="mask"] .reading-mask::after {
    bottom: 0;
    top: calc(var(--mouse-y) + 37px);
    border-top: 2px solid #99b2d8;
}

/* alternativer mauscursor */

html[data-alternative-cursor="on"] body {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 32 32'%3E%3Cpath d='M8 2l18 16.5-8.5 1 5 8-3.5 2-5-8-6.5 5.5V2z' fill='%23ffff00' stroke='black' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E") 8 2, auto !important;
}

html[data-color-scheme="dark"][data-alternative-cursor="on"] body {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 32 32'%3E%3Cpath d='M8 2l18 16.5-8.5 1 5 8-3.5 2-5-8-6.5 5.5V2z' fill='%23f55600' stroke='white' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E") 8 2, auto !important;
}

html[data-alternative-cursor="on"] a:hover, 
html[data-alternative-cursor="on"] button:hover {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 32 32'%3E%3Cpath d='M8 2l18 16.5-8.5 1 5 8-3.5 2-5-8-6.5 5.5V2z' fill='%2300ffff' stroke='black' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E") 8 2, pointer !important;
}

html[data-color-scheme="dark"][data-alternative-cursor="on"] a:hover,
html[data-color-scheme="dark"][data-alternative-cursor="on"] button:hover {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 32 32'%3E%3Cpath d='M8 2l18 16.5-8.5 1 5 8-3.5 2-5-8-6.5 5.5V2z' fill='%23800080' stroke='white' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E") 8 2, pointer !important;
}

/* FARBFILTER */


html[data-color-filter="protanomalie"] {
    filter: url(#protanopia-correction);
}

html[data-color-filter="deuteranomalie"] {
    filter: url(#deuteranopia-correction);
}

html[data-color-filter="tritanomalie"] {
    filter: url(#tritanopia-correction);
}

html[data-color-filter="monochrom"] {
    filter: grayscale(100%) !important;
}

html[data-color-filter="monochrom"] source,
html[data-color-filter="monochrom"] picture img,
html[data-color-filter="monochrom"] img
 {
    filter: brightness(110%) !important;
}

html[data-color-filter="inverted"] {
  filter: invert(100%) !important;
}


/* Bewegung reduzieren */
@media (prefers-reduced-motion: reduce) {
* {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    animation-delay: 0s !important; /* Entfernt die Verzögerung bei Animationen */
    
    transition-duration: 0.001ms !important;
    transition-delay: 0s !important;  /* Entfernt die Verzögerung bei Übergängen */
}


.reduce-motion-settings {
    opacity: 0.5 !important;
    pointer-events: none !important;
    cursor: not-allowed !important;
}

  /* Deaktiviert die View Transition API komplett */
  @view-transition {
    navigation: none;
  }

  /* Fallback: Sofortiger Wechsel ohne Animation */
  ::view-transition-old(root),
  ::view-transition-new(root) {
    animation: none !important;
  }

  
}

/* Deaktivierung, wenn das Daten-Attribut auf 'on' steht */
html[data-reduced-motion="on"] {
  view-transition-name: none !important;
}

html[data-reduced-motion="on"] @view-transition {
  navigation: none !important;
}

/* Zusätzlicher Schutz: Alle laufenden Animationen stoppen */
html[data-reduced-motion="on"] ::view-transition-old(root),
html[data-reduced-motion="on"] ::view-transition-new(root) {
  animation: none !important;
}


html[data-reduced-motion="on"] * {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    animation-delay: 0s !important;
    transition-duration: 0.001ms !important;
    transition-delay: 0s !important;
}

html[data-reduced-motion="on"] .elementor-invisible,
html[data-reduced-motion="on"] .animated {
    /* Macht das Element sofort sichtbar */
    opacity: 1 !important;
    visibility: visible !important;
    animation-name: none !important;
    animation-duration: 0s !important;
    transition: none !important;
    transform: none !important;
}

html[data-reduced-motion="on"] .menuFooterIcon a::before,
html[data-reduced-motion="on"] .menuFooterIcon a::after {
    transition: none !important;
  }

html[data-reduced-motion="on"] .menuFooterIcon a:hover::before,
html[data-reduced-motion="on"] .menuFooterIcon a:hover::after {
    width: 100%;
    height: 100%;
    border-color: var( --e-global-color-63c8e04 );
  }


html[data-reduced-transparency="on"][data-color-scheme="dark"] .elementor-kit-888 {
        /* backdrop-bg */
    --e-global-color-4f8f34e: #1a1d21;
}

html[data-reduced-transparency="on"][data-color-scheme="light"] .elementor-kit-888 {
        /* backdrop-bg */
    --e-global-color-4f8f34e: #ffffff;
}


@media (prefers-reduced-transparency: reduce) {

.reduce-transparency-settings {
    opacity: 0.5 !important;
    pointer-events: none !important;
    cursor: not-allowed !important;
}

}

/* Größerer Text */


@media only screen and (min-width: 1025px) {

html[data-text-large="on"] .elementor-kit-888 {
/* Haupttext */
--e-global-typography-text-font-size: 1.25rem !important;
--e-global-typography-text-line-height: 1.5em;
/* Primäre Überschrift */
--e-global-typography-primary-font-size: 2.2rem;
/* Sekundäre Überschrift */
--e-global-typography-secondary-font-size: 1.7rem;
/* Hervorgehobener Text */
--e-global-typography-accent-font-size: 1.35rem !important;
/* Sub Title */
    --e-global-typography-6c13f45-font-size: 1.5rem;
/* Small Text 1 */
--e-global-typography-c575672-font-size: 1rem;
/* Small Text 2 */
--e-global-typography-ee9e63a-font-size: 0.95rem;
}


}

@media only screen and (max-width: 1024px) {

html[data-text-large="on"] .elementor-kit-888 {
/* Haupttext */
--e-global-typography-text-font-size: 115% !important;
/* Hervorgehobener Text */
--e-global-typography-accent-font-size: 110% !important;
/* Small Text 1 */
--e-global-typography-c575672-font-size: 95%;
/* Small Text 2 */
--e-global-typography-ee9e63a-font-size: 85%;
}

}

/* Kontrast Design Windows */

@media (forced-colors: active) {
    
.mainHeader-inner::after {
    background: CanvasText !important;
}

.mainHeader7.sticky {
    box-shadow: 0 1px 0px 0px rgb(60 60 60) !important;
    border-bottom: 1px solid CanvasText;
}

#whitePointRange {
    background: CanvasText !important;
}

#whitePointRange::-webkit-slider-thumb, #whitePointRange::-moz-range-thumb {
    background: CanvasText !important;
}


.grid-content .colorCircle1 {
    forced-color-adjust: none;
}

.ios-toggle-switch {
    border: 1px solid LinkText !important;
}

.ios-toggle-switch::after {
    background: CanvasText !important;
}

.ios-toggle-input:checked + .ios-toggle-switch::after {
    background: LinkText !important;
}

.selectdiv select {
    border: 1px solid LinkText !important;
}

button.buttonCloseSettings {
    color: LinkText !important;
}

.slider-controls button {
    color: LinkText !important;
}

.postListTextFooter p {
    color: 	CanvasText !important;
}

.elementor-widget-n-accordion .e-n-accordion-item-title-text {
    color: LinkText;
}

.ha-list-item a .ha-item-wrap .ha-text .ha-list-title {
    color: LinkText !important;
}

.menuFooterIcon a, .webdesignMenu a, .marketingMenu a {
    border: 1px solid CanvasText !important;
}
  
 .faq-section2 details {
    border: 1px solid CanvasText !important;
}

.menuFooterIcon span.footerLinkBe {
    color: CanvasText;
}

.ha-list-item .ha-text .ha-list-detail {
    color: CanvasText !important;
}

.logoLink {
    --e-global-color-accent: LinkText !important;
}

.elementor-kit-888 {
--e-global-color-primary: CanvasText !important;
    --e-global-color-secondary: CanvasText !important;
--e-global-color-a86b494: CanvasText !important;   
    /* backdrop-bg */
    --e-global-color-4f8f34e: Canvas !important;
}

.elementor-element-5c90d29 summary.e-n-accordion-item-title {
    border: 1px solid !important;
}

.elementor-shape svg {
    display: none !important;
}

.elementor-price-table__header {
    border-bottom: 1px solid CanvasText;
}

footer.elementor-location-footer {
    border-top: 5px solid;
}
  
}



/* Kontrast Design */

@media (prefers-contrast: more) {
    
.contrast-color-settings {
    opacity: 0.5 !important;
    pointer-events: none !important;
    cursor: not-allowed !important;
  }

}

/* Kontrast Design Hell */
html[data-contrast-modus="on"][data-color-scheme="light"] .elementor-kit-888 {
    /* Primary */
    --e-global-color-primary: #121212;
    /* secondary */
    --e-global-color-secondary: #333;
    /* LinkText */
    --e-global-color-text: #333;
    /* 4ydesign blue */
    --e-global-color-accent: #752500;
    /* Text Grey 1 */
    --e-global-color-d43be81: #111;
    /* Text Grey 2 */
    --e-global-color-9f5fea0: #eeeeee;
    /* Text White 1 */
    --e-global-color-ddb45b3: #ffffff;
    /* Text White 2 */
    --e-global-color-25b5236: #ffffff;
    /* Main-BG-White-Black */
    --e-global-color-c3e1c60: #FAF9F6;
    /* Border-trenlinie */
    --e-global-color-dfc555b: #e5e2de;
    /* Accent-BG */
    --e-global-color-d3de383: #F2EDE4;
    /* Accent-BG-Hover */
    --e-global-color-063e37f: #f6f2ed;
    /* BG-black-dark-blue */
    --e-global-color-9585fda: #312611;
    /* button-color-1 */
    --e-global-color-3f1f3cc: #5f1f04;
    /* button-color-2 */
    --e-global-color-2082c09: #421f0f;
    /* button-border-1 */
    --e-global-color-df511ba: #391302;
    /* button-text-1 */    
    --e-global-color-e21d1f3: #FFFFFF;
    /* smallButton */
    --e-global-color-c474ef6: #ecece9;
    /* smallButtonHover */
    --e-global-color-935bf8a: #695121;
    /* small-Button-Border-1 */
    --e-global-color-472e775: #752500;
    /* Seperator */
    --e-global-color-bd67b92: #55555899;
    /* footerBG */
    --e-global-color-76dc93d: #14110d;
    /* footerBorder */    
    --e-global-color-a86b494: #796754;
    /* footer-link-color */
    --e-global-color-63c8e04: #eed4b9;
    /* Transparent */
    --e-global-color-fd5a2d3: #FFFFFF00;
    /* menu Border */
    --e-global-color-bd32c6d: #55555899;
    /*border-white-light-blue */
    --e-global-color-8c3b51f: #808c9c;
    /*info bg color */  
    --e-global-color-6330a75: #fff9f1;
    /* Border-Color1 */
    --e-global-color-611ffaae: #353535;
    /* white */
    --e-global-color-563ce203: #f1f1f1;
    /* Yellow */
    --e-global-color-071134f: #000000;
    /* red */
    --e-global-color-1f68f25: #000000;
    /* Purble */
    --e-global-color-8782bb7: #000000;
    /* cosmos pink */
    --e-global-color-926d171: #000000;
    /* sun blue */
    --e-global-color-3492061: #000000;
    /* orange */
    --e-global-color-8f105e5: #000000;
    /* green */
    --e-global-color-a4a7963: #000000;
    /* blue */
    --e-global-color-a3402fb: #000000;
    /* Gold */
    --e-global-color-1bf2712: #000000;
    /* Türkis */
    --e-global-color-bc61d53: #000000;
    /* Brown */
    --e-global-color-ac5909c: #000000;
    /* Pink */
    --e-global-color-7dc584c: #000000;
    /* form border */
    --e-global-color-a9829e6: #48371a;
    /* form background */
    --e-global-color-7c2fe27: #fff5e7;
    /* backdrop-bg */
    --e-global-color-4f8f34e: #faf9f6cc;
        /* TextRead-BG */    
    --e-global-color-b1d6940: #d3fdd1;
        /* kontrast-border */        
    --e-global-color-2f3336d: #947046;
}

html[data-contrast-modus="on"][data-color-scheme="light"] .welcomeFont {
    background: transparent;
    color: var( --e-global-color-primary ) !important;
    background-clip: unset;
    -webkit-text-fill-color: unset;
    text-fill-color: unset;
}

html[data-contrast-modus="on"][data-color-scheme="light"] [data-tooltip]:after {
    background: #e9d8bf;
    color: #000;
    border: 1px solid #000;
}

html[data-contrast-modus="on"][data-color-scheme="light"] .logoLink:hover {
    --e-global-color-accent: #7b4c0a !important;
}


/* Kontrast Design Dunkel */

html[data-contrast-modus="on"][data-color-scheme="dark"] .elementor-kit-888 {
    /* Primary */
    --e-global-color-primary: #ffffff;
    /* secondary */
    --e-global-color-secondary: #eeeeee;
    /* LinkText */
    --e-global-color-text: #eeeeee;
    /* 4ydesign blue */
    --e-global-color-accent: #f0ff00;
    /* Text Grey 1 */
    --e-global-color-d43be81: #eeeeee;
    /* Text Grey 2 */
    --e-global-color-9f5fea0: #eeeeee;
    /* Text White */
    --e-global-color-ddb45b3: #ffffff;
    /* Text White 2 */
    --e-global-color-25b5236: #eeeeee;
    /* Main-BG-White-Black */
    --e-global-color-c3e1c60: #010409;
    /* Border-trenlinie */
    --e-global-color-dfc555b: #eeeeee;
    /* Accent-BG */
    --e-global-color-d3de383: #06223e;
    /* Accent-BG-Hover */
    --e-global-color-063e37f: #0d0d31;
    /* BG-black-dark-blue */
    --e-global-color-9585fda: #06223e;
    /* button-color-1 */
    --e-global-color-3f1f3cc: #9b3622;
    /* button-color-2 */
    --e-global-color-2082c09: #a82f0b;
    /* button-border-1 */
    --e-global-color-df511ba: #ff694b;
    /* button-text-1 */    
    --e-global-color-e21d1f3: #FFFFFF;
    /* smallButton */
    --e-global-color-c474ef6: #931B79;
    /* smallButtonHover */
    --e-global-color-935bf8a: #252d3c;
    /* small-Button-Border-1 */
    --e-global-color-472e775: #e3e3e3;
    /* Seperator */
    --e-global-color-bd67b92: #d7d7d7;
    /* footerBG */
    --e-global-color-76dc93d: #000;
    /* footerBorder */
    --e-global-color-a86b494: #777777;
    /* footer-link-color */
    --e-global-color-63c8e04: #f0ff00;
    /* Transparent */
    --e-global-color-fd5a2d3: #FFFFFF00;
    /* menu Border */
    --e-global-color-bd32c6d: #eeeeee;
    /*border-white-light-blue */
    --e-global-color-8c3b51f: #808c9c;
    /*info bg color */  
    --e-global-color-6330a75: #05292f;
    /* Border-Color1 */
    --e-global-color-611ffaae: #ffffff;
    /* white */
    --e-global-color-563ce203: #f1f1f1;
    /* Yellow */
    --e-global-color-071134f: #ffffff;
    /* red */
    --e-global-color-1f68f25: #ffffff;
    /* Purble */
    --e-global-color-8782bb7: #ffffff;
    /* cosmos pink */
    --e-global-color-926d171: #ffffff;
    /* sun blue */
    --e-global-color-3492061: #ffffff;
    /* orange */
    --e-global-color-8f105e5: #ffffff;
    /* green */
    --e-global-color-a4a7963: #ffffff;
    /* blue */
    --e-global-color-a3402fb: #ffffff;
    /* Gold */
    --e-global-color-1bf2712: #ffffff;
    /* Türkis */
    --e-global-color-bc61d53: #ffffff;
    /* Brown */
    --e-global-color-ac5909c: #ffffff;
    /* Pink */
    --e-global-color-7dc584c: #ffffff;
    /* form border */
    --e-global-color-a9829e6: #dddddd;
    /* form background */
    --e-global-color-7c2fe27: #031124;
    /* backdrop-bg */
    --e-global-color-4f8f34e: #010409CC;
        /* TextRead-BG */    
    --e-global-color-b1d6940: #0c2f0d;
        /* kontrast-border */        
    --e-global-color-2f3336d: #ffffff;
}


html[data-contrast-modus="on"][data-color-scheme="dark"] .logoLink:hover {
    --e-global-color-accent: #00FFFF !important;
}

html[data-contrast-modus="on"][data-color-scheme="dark"] [data-tooltip]:after {
        background: #000;
        border: 1px solid #fff;
    }


html[data-contrast-modus="on"][data-color-scheme="dark"] footer.elementor-location-footer {
    border-top: 5px solid #eee;
}

html[data-contrast-modus="on"][data-color-scheme="dark"] .welcomeFont {
    background: transparent;
    color: #fff !important;
    background-clip: unset;
    -webkit-text-fill-color: unset;
    text-fill-color: unset;
}


/* Schaltflächen hervorheben */       

html[data-highlight-links="on"] button, html[data-highlight-links="on"] a, html[data-highlight-links="on"] input, html[data-highlight-links="on"] select, html[data-highlight-links="on"] textarea, html[data-highlight-links="on"] .e-n-accordion details {
    min-width: 44px;
    min-height: 44px;
    box-shadow: 0 0 0 2px #ff00ff;
    margin: 2px !important;
    padding: 2px 5px !important;
    border-radius: 5px !important;
}

html[data-highlight-links="on"] .ios-toggle-switch, html[data-highlight-links="on"] .grid-content {
    box-shadow: 0 0 0 2px #ff00ff;
    margin: 2px !important;
    padding: 2px 5px !important;
    border-radius: 5px !important;
}

html[data-highlight-links="on"] button, .elementor-button {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
}

html[data-highlight-links="on"] .elementor-widget-text-editor a {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    margin: 10px !important;
}

html[data-highlight-links="on"] .startNeuigkeiten a {
    margin: 0 0 10px 0 !important;
}



/* Schriftauswahl */


/* Standard Schrift */

@font-face {
    font-family:'4ydesign';
      src: url('https://www.4ydesign.de/wp-content/uploads/4ydesign-variable.woff2') format('woff2-variations'), 
       url('https://www.4ydesign.de/wp-content/uploads/4ydesign-variable.woff2') format('woff2') tech('variations'); /* Moderner Standard */
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
}

.elementor-kit-888, html[data-font-family="standard"] .elementor-kit-888  {
    font-family: -apple-system, BlinkMacSystemFont, "4ydesign", system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    -webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

/* Serifenlose Schrift */
html[data-font-family="sans-serif"] .elementor-kit-888 {
    font-family: Arial, Verdana, sans-serif;
    line-height: 1.5;
}

/* Serifen-Schrift */
html[data-font-family="serif"] .elementor-kit-888 {
    font-family: Georgia, 'Times New Roman', Times, serif;
    line-height: 1.5;
}

/* Calligraphy Schrift */

@font-face {
    font-family:'Comic Sans MS';
    src: 
    local('Comic Sans MS'),           
      local('Comic Sans'),    
      url(https://www.4ydesign.de/wp-content/uploads/comicsansms.woff2) format('woff2');
}

html[data-font-family="calligraphy"] .elementor-kit-888 {
    font-family: "Comic Sans MS", Arial, Verdana, sans-serif !important;
    line-height: 1.6;
    letter-spacing: 0.1px;
}



/* dyslexie Schrift */

@font-face {
    font-family:'OpenDyslexic Regular';
    src: 
      local('OpenDyslexic Regular'),    
      url(https://www.4ydesign.de/wp-content/uploads/opendyslexic-regular.woff2) format('woff2');
      font-display: swap;
}

html[data-font-family="dyslexie"] .elementor-kit-888 {
    font-family: 'OpenDyslexic Regular', Arial, Verdana, sans-serif;
    line-height: 1.6;
    letter-spacing: 0.1px;
}

html[data-font-family="dyslexie"] h1, html[data-font-family="dyslexie"] h2, html[data-font-family="dyslexie"] h3, html[data-font-family="dyslexie"] h4, html[data-font-family="dyslexie"] h5, html[data-font-family="dyslexie"] h6, html[data-font-family="dyslexie"] p, html[data-font-family="dyslexie"] span, html[data-font-family="dyslexie"] div {
    text-align: left !important;
}

html[data-font-family="dyslexie"] .startTitle1 .elementor-heading-title {
    font-size: 1.75rem !important;
}

@media only screen and (max-width: 768px) {

html[data-font-family="dyslexie"] .startTitle1 .elementor-heading-title {
    font-size: 0.9375rem !important;
}

}

/* System Schrift */
html[data-font-family="system"] .elementor-kit-888 {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}

/* Einstellung an */
html[data-contrast-modus="on"] button.openInclusionToolbar:after, html[data-text-large="on"] button.openInclusionToolbar:after, html[data-white-point="on"] button.openInclusionToolbar:after, html[data-reduced-motion="on"] button.openInclusionToolbar:after, html[data-highlight-links="on"] button.openInclusionToolbar:after, html[data-font-family="sans-serif"] button.openInclusionToolbar:after, html[data-font-family="serif"] button.openInclusionToolbar:after, html[data-font-family="calligraphy"] button.openInclusionToolbar:after, html[data-font-family="system"] button.openInclusionToolbar:after, html[data-font-family="dyslexie"] button.openInclusionToolbar:after, html[data-read-helpline="mask"] button.openInclusionToolbar:after,  html[data-read-helpline="line"] button.openInclusionToolbar:after, html[data-text-read="on"] button.openInclusionToolbar:after, html[data-reduced-transparency="on"] button.openInclusionToolbar:after, html[data-color-filter="protanomalie"] button.openInclusionToolbar:after, html[data-color-filter="deuteranomalie"] button.openInclusionToolbar:after, html[data-color-filter="tritanomalie"] button.openInclusionToolbar:after, html[data-color-filter="monochrom"] button.openInclusionToolbar:after, html[data-color-filter="tritanomalie"] button.openInclusionToolbar:after, html[data-color-filter="inverted"] button.openInclusionToolbar:after, html[data-alternative-cursor="on"] button.openInclusionToolbar:after {
content: "\f591";
    font-size: 1rem;
    position: absolute;
    font-family: 'Huge Icons';
    top: 4px;
    color: #fff;
    left: 24px;
    background: #dd2121;
    line-height: 16px;
    padding: 1px;
    border-radius: 100%;
    box-shadow: 0 0 2px 1px #f00;
}


/* Vorlese Modus */

html:not([data-text-read="on"]) .readModusOff {
    display: none !important; 
  }

      
.text-read-active {
   background-color: var( --e-global-color-b1d6940 ) !important;
   color: var( --e-global-color-primary ) !important;
      }
      
      
#speechControls {
    display: none;
  }

html[data-text-read="on"] #speechControls {
    display: flex;
    background: var( --e-global-color-4f8f34e );
    padding: 7px 10px 10px;
    width: 100%;
    flex-direction: column;
    gap: 5px;
    position: fixed;
    z-index: 1000;
    bottom: 0;
    left: 0;
    align-items: center;
    margin: 0 auto;
    backdrop-filter: blur(5px);
    transform: translateZ(0);
    border-top: 1px solid rgb(60 60 60);
}

.speechControlsButton {
    display: flex;
    gap: 15px;
    flex-direction: row;
}

#speechControls p {
    font-size: 13px;
}

#speechControls button {
    padding: 5px 8px 5px 8px;
}

  /* Stil für den Pause-Button im Pausierten Zustand */
#pauseResumeBtn.paused::before {
     content: "\ec28 \00A0 Fortsetzen";
    font-family: 'Huge Icons', '4YOURDESIGN';
  }
#pauseResumeBtn:not(.paused)::before {
    content: "\ec27 \00A0 Pause";
    font-family: 'Huge Icons', '4YOURDESIGN';
}

/* toolbar message */

#accessibility-toast-container {
    position: fixed;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2147483647;
    display: flex;
    flex-direction: column;
    gap: 10px;
    /* Flexibel für Mobile, feste Basis für Desktop */
    width: 320px;
    max-width: 92vw; 
    pointer-events: none;
}

.a11y-toast {
    background-color: #12681E;
    color: #ffffff;
    border: 1px solid #00C217;
    /* Nutzt deine globale Typografie */
    font-size: var(--e-global-typography-text-font-size);
    padding: 10px;
    border-radius: 5px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.3);
    pointer-events: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px; 
    
    /* Animation-Startzustand */
    transform: translateY(-100px);
    opacity: 0;
    transition: transform 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28), opacity 0.3s;
}

.a11y-toast.is-visible {
    transform: translateY(0);
    opacity: 1;
}

/* Die Häkchen-Animation */
.a11y-toast.is-visible .a11y-toast-icon {
    display: inline-block;
    font-size: 1.1em;
    font-weight: bold;
    opacity: 0; 
    animation: check-pop 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
    /* Timing: Erscheint kurz vor Ende der Slide-In-Animation */
    animation-delay: 0.3s; 
}

@keyframes check-pop {
    0% { transform: scale(0); opacity: 0; }
    50% { transform: scale(1.8); opacity: 1; }
    100% { transform: scale(1); opacity: 1; }
}

:focus {
    outline: none;
}

/* 2. Den einheitlichen Pink-Fokus erzwingen */
*:focus-visible, .ios-toggle-input:focus-visible + .ios-toggle-switch, .grid-option input:focus-visible + .grid-content {
    outline: 3px solid #E6007E !important; /* Dein Electric Magenta */
    outline-offset: 2px !important;
    box-shadow: 0 0 10px rgba(230, 0, 126, 0.4) !important;
    border-radius: 2px !important;
}



/* 1. GLOBALE VARIABLEN */
html { 
    --j-primary: #06319A; 
    --j-bg: #ffffff; 
    --j-text: #1e293b; 
    --j-border: #e2e8f0; 
    --j-bubble: #f4f7fb; 
    --j-glow-gradient: linear-gradient(45deg, #4285f4, #9b51e0, #e91e63, #4285f4);
}

html[data-color-scheme="dark"] { 
    --j-primary: #99c3ff; 
    --j-bg: #1a1d21; 
    --j-text: #f1f5f9; 
    --j-border: #334155; 
    --j-bubble: #2d3748; 
}

/* 2. BASIS-LAYOUT & LOCK */
body.jarvis-locked, body.j-win-is-max {
    overflow: hidden !important;
    touch-action: none;
    position: fixed;
    width: 100%;
    height: 100%;
}

/* 3. TOGGLE BUTTON */
.j-toggle {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 65px;
    height: 65px;
    border-radius: 50% !important;
    cursor: pointer;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--j-glow-gradient);
    background-size: 400% 400%;
    animation: j-gradient-flow 8s ease infinite;
    box-shadow: 0 8px 25px rgba(0,0,0,0.1);
    padding: 3px !important;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.j-toggle img { 
    width: 100%; 
    height: 100%; 
    border-radius: 50%; 
    object-fit: cover; 
    background: var(--j-bg); 
}

.j-toggle.j-hidden { 
    opacity: 0; 
    transform: scale(0.5); 
    pointer-events: none; 
}

.j-toggle:hover { transform: scale(1.05); }

/* 4. WIDGET FENSTER */
.j-widget { 
    display: none; 
    position: fixed; 
    bottom: 20px; 
    right: 20px; 
    width: 450px; 
    max-width: 90vw; 
    max-height: 80vh; 
    border-radius: 20px; 
    z-index: 10000; 
    background: var(--j-glow-gradient);
    background-size: 300% 300%;
    animation: j-gradient-flow 4s linear infinite;
    flex-direction: column; 
    padding: 2px; 
    box-shadow: 0 25px 60px rgba(0,0,0,0.15); 
    opacity: 0; 
    transform: translateY(20px); 
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s ease;
    overflow: hidden;
    box-sizing: border-box;
}

.j-widget.j-active { 
    display: flex; 
    opacity: 1; 
    transform: translateY(0); 
}

.j-win-is-max .j-widget {
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    width: 1140px;
    height: calc(100vh - 120px);
    max-height: calc(100vh - 120px);
    left: 50%;
    right: 0;
    top: 75px;
    transform: translate(-50%, 0) !important;
    box-shadow: 0 0 100px 1000px rgba(0, 0, 0, 0.4);
}

.j-inner {
    position: relative; 
    background: var(--e-global-color-c3e1c60); 
    border-radius: 18px; 
    display: flex; 
    flex-direction: column; 
    height: 100%; 
    padding: 20px; 
    overflow: hidden;
    box-sizing: border-box;
    min-height: 500px;
}

/* 5. HEADER SEKTION */
.j-header {
    display: grid;
    gap: 10px;
    margin-bottom: 15px;
    border-bottom: 1px solid var(--e-global-color-bd32c6d);
    padding-bottom: 10px;
    flex-shrink: 0;
    align-content: center;
    align-items: center;
    grid-template-columns: 75px auto 90px;
}

.j-header-img-wrap { 
    width: 75px; 
    height: 75px; 
    flex-shrink: 0; 
    border-radius: 10px; 
    overflow: hidden; 
    border: 1px solid var(--e-global-color-bd32c6d); 
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 10001;
}

.j-header-img-wrap img { width: 100%; height: 100%; object-fit: cover; }

.j-headline {
    margin: 0 !important;
    font-size: var(--e-global-typography-6c13f45-font-size) !important;
    color: var(--e-global-color-accent) !important;
    line-height: 1.2;
}

.j-subline {
    margin: 3px 0 0 !important;
    font-size: var(--e-global-typography-text-font-size) !important;
    color: var(--e-global-color-secondary);
}

.j-headerButtons {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
}

.j-close-btn, .j-maxW-btn, .j-minW-btn {
    margin-left: auto;
    background: transparent !important;
    border: 0 !important;
    font-size: 32px !important;
    cursor: pointer;
    color: var(--e-global-color-primary) !important;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
}



.j-close-btn:hover, .j-maxW-btn:hover, .j-minW-btn:hover {
    color: var(--e-global-color-accent) !important;
}


.j-minW-btn, .j-win-is-max .j-maxW-btn { display: none; }
.j-win-is-max .j-minW-btn { display: flex; }

/* 6. CHAT CONTENT & SCROLLBAR */
.j-content { 
    flex-grow: 1; 
    overflow-y: auto; 
    margin-bottom: 10px; 
    scrollbar-width: thin; 
    scrollbar-color: var(--e-global-color-bd32c6d) transparent;
    scrollbar-gutter: stable;
    padding-right: 5px;
    position: relative;
}

.j-content::-webkit-scrollbar { width: 6px; }
.j-content::-webkit-scrollbar-track { background: transparent; }
.j-content::-webkit-scrollbar-thumb {
    background-color: var(--e-global-color-bd32c6d);
    border-radius: 10px;
}

#j-chat-container {
    display: flex;
    flex-direction: column;
    padding-bottom: 20px;
}

/* 7. CHAT BUBBLES */
.j-bubble { 
    max-width: 95%;
    padding: 10px 14px; 
    margin-bottom: 12px;
    border-radius: 10px; 
    color: var(--e-global-color-secondary); 
    line-height: 1.5; 
    border: 1px solid var(--e-global-color-bd32c6d);
    animation: j-fade-in 0.4s ease-out forwards; 
    will-change: transform, opacity;
    word-wrap: break-word;
    scroll-margin-top: 15px;
    font-size: 0.9em;
}

.j-bubble a {
    color: var(--e-global-color-accent) !important; 
    text-decoration: underline;
    font-weight: 600;
    transition: opacity 0.2s ease;
}

.j-bubble a:hover { opacity: 0.8; }
.j-bubble strong { font-weight: 600 !important; }

/* Jarvis / Model Bubble Specifics & Markdown Support */
.j-model { 
    align-self: flex-start; 
    background: var(--e-global-color-6330a75); 
    border-bottom-left-radius: 2px; 
}

.j-bubble.j-model p {
    margin-bottom: 1em !important;
    display: block !important;
}

.j-bubble.j-model p:last-child {
    margin-bottom: 0 !important;
}

.j-bubble.j-model h3, .j-bubble.j-model h4 {
    margin: 15px 0 5px 0 !important;
    color: var(--e-global-color-primary) !important;
    font-size: 1.1em;
    font-weight: 700;
    line-height: 1.3;
}

.j-bubble.j-model ul {
    list-style-type: disc !important;
    margin: 5px 0 10px 15px !important;
    padding-left: 15px !important;
    display: block !important;
}

.j-bubble.j-model ol {
    list-style-type: decimal !important;
    margin: 5px 0 10px 15px !important;
    padding-left: 15px !important;
    display: block !important;
}

.j-bubble.j-model li {
    display: list-item !important;
    margin-bottom: 5px !important;
}

/* User Bubble Specifics */
.j-user { 
    align-self: flex-end; 
    background: var(--e-global-color-d3de383); 
    color: var(--e-global-color-primary); 
    border-bottom-right-radius: 2px; 
}

/* 8. LOADER & INPUT AREA */
.j-loader { 
    display: none; 
    margin-top: 10px; 
    width: 100%; 
}

.j-loader-bar {
    height: 4px;
    width: 100%;
    background: linear-gradient(90deg, #0c8367, #ec0dff, #096aeb, #149d6b);
    background-size: 200% 200%;
    border-radius: 2px;
    animation: j-gradient-flow 2s cubic-bezier(0.4, 0, 1, 1) infinite;
}

.j-loader-text {
    margin-top: 8px;
    color: var(--e-global-color-accent);
    font-weight: 500;
}

.j-input-wrap {
    display: flex;
    gap: 10px;
    align-items: center;
    padding-top: 10px;
    border-top: 2px solid var(--e-global-color-bd32c6d);
    flex-shrink: 0;
}

.j-input-wrap textarea, #j-in {
    flex: 1;
    width: 100%;
    outline: none !important;
    box-shadow: none !important;
    border-radius: 12px !important;
    resize: none;
    transition: border-color 0.3s ease;
    font-family: inherit;
    padding: 10px;
    border: 1px solid var(--e-global-color-bd32c6d);
}

.j-input-wrap textarea:focus, #j-in:focus {
    border-color: var(--e-global-color-accent);
}

#j-send-btn {
    background: var( --e-global-color-3f1f3cc );
    color: var( --e-global-color-e21d1f3 ) !important;
    border-radius: 5px;
    border: 1px solid var( --e-global-color-df511ba );
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
    flex-shrink: 0;
    font-size: 32px;
}

#j-send-btn:hover {
background-color: var(--e-global-color-2082c09);
    color: var(--e-global-color-e21d1f3);
    border-color: var(--e-global-color-df511ba);
    transform: scale(1.05);
}

#j-send-btn svg {
    width: 20px;
    height: 20px;
}

/* 9. FOOTER */
.j-footer {
    display: flex;
    gap: 10px;
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-content: center;
    margin-top: 5px;
}

.j-gdpr-info { 
    font-family: sans-serif;
    font-size: 0.75rem; 
    color: var(--e-global-color-secondary); 
    opacity: 0.7; 
    margin: 0; 
    line-height: 1.4; 
    font-style: italic; 
}

.j-gdpr-info a {
    color: inherit;
    text-decoration: underline;
    font-size: inherit;
}

.iconFooterJavis {
    padding: 0;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    gap: 10px;
    align-items: center;
}

.iconFooterJavis a {
    font-size: 24px;
    color: var(--e-global-color-primary);
}

/* 10. KEYFRAMES */
@keyframes j-gradient-flow {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

@keyframes j-fade-in { 
    from { opacity: 0; transform: translateY(12px); } 
    to { opacity: 1; transform: translateY(0); } 
}

/* 11. MOBILE OPTIMIERUNG */
@media (max-width: 768px) {
    .j-widget { 
        width: 100% !important;
        max-width: 100% !important;
        height: 100dvh !important;  
        max-height: 100vh; 
        bottom: 0 !important; 
        right: 0 !important; 
        left: 0 !important;
        border-radius: 0 !important;
        padding: 0 !important;
        animation: none;
        background: var(--e-global-color-c3e1c60);
        transform: translateY(100%);
        box-shadow: none;
    }

    .j-widget.j-active { transform: translateY(0); }

    .j-inner { 
        border-radius: 0 !important; 
        height: 100% !important; 
        padding: 15px 20px 30px !important; 
    }

    .j-inner::before {
        content: "";
        position: absolute;
        top: 8px;
        left: 50%;
        transform: translateX(-50%);
        width: 40px;
        height: 4px;
        background: var(--e-global-color-bd32c6d);
        border-radius: 2px;
    }

    .j-header {
        margin-top: 10px;
        margin-bottom: 15px;
        padding-bottom: 15px;
    }

    .j-header-img-wrap {
        width: 50px; 
        height: 50px;
    }
    
    .j-maxW-btn {
        display: none !important;
    }

    .j-input-wrap {
        padding-bottom: env(safe-area-inset-bottom);
    }
}/* End custom CSS */