@charset "UTF-8";

*,
*::before,
*::after {
  box-sizing: border-box;
}

@media (prefers-reduced-motion: no-preference) {
  :root {
    scroll-behavior: smooth;
  }
}

* {
  touch-action: manipulation; 
}

html, body, .app { width:100%; height:100%; padding:0; margin:0; scroll-behavior: smooth; }

body {
  font-family: var(--bs-font-sans-serif);
  /*! font-size: 16px; */
  line-height: 1.5;
  color: #fff;
  background-color: #000;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
 overflow-x: hidden;
}

body { font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; height:100%!important; letter-spacing: 0.025rem; font-weight: 300 !important; } /* important needed due to Cookie Consent */
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 { font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; letter-spacing: 0.025rem; font-weight: 300 !important;  }
.paragraph { font-size: 1rem; }
.semibold { font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; letter-spacing: 0.025rem; font-weight: 500!important; }

/* Neue Klasse für SEO und Accessibility ergänzt am 12.01.2025 // Seestaller 
.visually-hidden { 
  position: absolute; 
  left: -9999px; 
  width: 1px; 
  height: 1px; 
  overflow: hidden; 
  clip: rect(0, 0, 0, 0); 
  white-space: nowrap; 
}*/

.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.lenis.lenis-smooth {
  scroll-behavior: auto !important;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

/*.lenis.lenis-smooth iframe {
  pointer-events: none;
}*/



a, a:hover, a:focus { text-decoration: none; color: #fed136 }

#bg1-wrapper { width: 100%; height: 100%; overflow: clip; position: fixed; z-index: -90; }
#bg2-wrapper { width: 100%; height: 100%; overflow-x: hidden; position: fixed; z-index: -90; display: none; }

#header-logo-wrapper { background: none; height: 100%; width: 100%; position: fixed; display: none; align-items: center; justify-content: center; z-index: 10; overflow: clip;}
#header-logo { z-index: 20; position: fixed; width: 100%;text-align: center;display: flex;flex-direction: column;align-items: center;}
#header-logo img { width: 50%; opacity: 0; }
#mobile-logo { display: flex; flex-direction: column; align-items: center;padding: 5rem 2rem 2rem 2rem;}
#mobile-logo img { width: 75% }

.footerlogo { width: 10rem; padding-bottom: 0.4rem;}
#logo { position: fixed; margin-top: 1rem; z-index: 100;width: 100% ;text-align: center;}


/* CONTENT */

.section { /*! opacity: .9; */  z-index: 10; background: #000; /*! min-height: 100svh; */ }
.header-section { min-height: 25vh; }

.raster {
    z-index: -1;
    background-image: url(../img/elsner-solutions-raster-bg-opt.svg);
    background-repeat: no-repeat;
    -webkit-background-size: 25%;
    -moz-background-size: 25%;
    background-size: 25%;
    -o-background-size: 25%;
    background-position: center;
    animation: rotate 240s linear infinite;
    /*! animation-play-state: paused; */
    /*! animation-iteration-count: 1; */
    animation-fill-mode: both;
    background-origin: border-box;
    position: absolute;
    top: -250%;
    width: 500%;
    height: 500%;
    left: -250%;
}

@keyframes rotate {
   from {
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}


#s-intro { background: none; min-height: 100%; width: 100%; }
#s-personality { /*! padding-top: 4rem; *//*! padding-bottom: 6rem; */}
#s-signage-cs { padding-top: 5rem; padding-bottom: 8rem; position: relative;overflow: clip; }
#s-interior-cs { padding-top: 5rem; padding-bottom: 8rem; position: relative;overflow: clip; }
#s-protection-cs { padding-top: 5rem; padding-bottom: 8rem; position: relative;overflow: clip; }
#s-team { min-height: 100%; width: 100%;  }

/*#s-signage-details { padding-top: 5rem; padding-bottom: 10rem; }*/
#s-signage-details { padding-top: 3rem; padding-bottom: 5rem; }
#s-about-details { padding-top: 5rem; padding-bottom: 10rem; }
#s-case-study { padding-top: 5rem; padding-bottom: 10rem; background: none; position: relative; overflow: clip; }
#s-case-studies-content { background: none; position: relative; overflow: clip; }
#s-connection { padding-top: 4rem; padding-bottom: 5rem; /*min-height: 100%; */}
#s-connection-kran { padding-top: 4rem; padding-bottom: 1rem; }

#s-broschuere { background: none; position: relative; overflow: clip; }

#footer { min-height: 100% !important; background: #000; display: grid; color: #fff; position: relative; overflow: clip;}
.footer-wrapper {   min-height: 20%; align-content: flex-end; display: grid; }
.footer-wrapper p { margin-bottom: 2rem; }

.col-blurred { background: rgba(0,0,0,0.2); padding: 2rem; width: auto;   -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);}

.header-portrait { width: 100%; }
.connection-portrait { width: 75%; padding: 0 0 3rem 0; }
.header-amelie { padding-top: 2rem;  }
.header-amelie h2 {  /*! line-height: 0.75; */  padding-bottom: 0.5em; }


.standort-foto { width: 75%; padding-bottom: 2rem; padding-top: 2rem;}
.portrait { width: 100%; padding-bottom: 2rem; }

.link-404, .link-bewerbung { color: #fff;  transition: all .5s ease-in-out; display: block;}
.link-404:hover, .link-404:focus, .link-bewerbung:hover, .link-bewerbung:focus { text-decoration: none; transform: scale(1.1); }
.karriereicon { width: 50%; }
.keyword-link { color: #fff; list-style-type: none; padding-left: 0; }

.cs-container {  }
.cs-inner { padding: 1rem; margin: 1rem; display: flex;  flex-direction: column; height: 100%;background: rgba(0,0,0,0.8);}
.cs-link { padding-bottom: 2rem; padding-top: 2rem;}
.cs-headline { color: #fff; }
.cs-img { width: 100%; }
.cs-thumb { width: 100%; padding: 1rem 0; }
.cs-button-wrapper { display: flex;  align-self: flex-end;  margin-top: auto; font-size: 1.25rem;}
.cs-header { font-weight: 600; font-size: 1.5rem; color: #fed136; }
.cs-row { border-top: 1px solid #fed136; margin-top: 2rem; }



/* BUTTONS */

.button-container { position: relative; font-size: 1.5rem; padding: 2rem 0 4rem 0;}

.button-link { position: relative; display: inline-block; padding: 0.25em; border: 1px solid #fed136; vertical-align: middle; text-decoration: none; color: #fed136;  -webkit-transition: all 2s; transition: all 2s; background: rgba(0, 0, 0, .15);}
.button-link .long-text {  -webkit-transition: all 2s; transition: all 2s; vertical-align: top; white-space: nowrap; margin: 0 0.4rem; color: #fed136;  }
.short-icon {  -webkit-transition: all 2s; transition: all 2s; padding: 0 0.4em; color: #fed136; }

.button-link:hover, .button-link:focus { border-color: #fff; color: #fff;  }
.button-link:hover .long-text, .button-link:focus .long-text { color: #fff; }
.button-link:hover .short-icon, .button-link:focus .short-icon { padding: 0 0.4rem 0 2rem; color: #fff; }

.button-link-navi { padding: 1rem; margin: 0.25rem 1rem; }


/* TYPO */

h6, .h6, h5, .h5, h4, .h4, h3, .h3, h2, .h2, h1, .h1 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-weight: 500;
  line-height: 1.2;
  color: var(--bs-heading-color);
}

h1, .h1 {
  font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
  h1, .h1 {
    font-size: 2.5rem;
  }
}


h2, .h2 {
  font-size: calc(1.325rem + 0.9vw);
}
@media (min-width: 1200px) {
  h2, .h2 {
    font-size: 2rem;
  }
}


h3, .h3 {
  font-size: calc(1.3rem + 0.6vw);
}
@media (min-width: 1200px) {
  h3, .h3 {
    font-size: 1.75rem;
  }
}


h4, .h4 {
  font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
  h4, .h4 {
    font-size: 1.5rem;
  }
}

h5, .h5 {
  font-size: 1.25rem;
}

h6, .h6 {
  font-size: 1rem;
}

p {
  margin-top: 0;
  margin-bottom: 1rem;
  /*! white-space: nowrap; */
}


.georgia { font-family: Georgia, Times, Times New Roman, serif; font-weight: 100!important;; }
.kilo {  line-height: 1; font-size: 1.1rem; }
.mega_k {  line-height: 1; font-size: 1.20rem; }
.mega {  line-height: 1; font-size: 1.25rem; }
.giga { font-size: 2rem; line-height: 0.8; }
.tera { font-size: 3.5rem; line-height: 0.8; }
.text-wrapper { text-align: left; }
.headline { text-align: left; font-size: 2rem; line-height: 1; /*! margin: 1.5rem auto; */  padding-top: 3rem;}
.textblock { }
.liste { list-style-type: none; padding: 0; }
.mini { font-size: 0.75em; }
.keywords { color: #fff; list-style-type: none;padding-left: 0;padding-top: 1rem;}


#progressbar { height: 2px; position: fixed; bottom: 10px; left: 0; z-index: 100; background: #fed136;
background: linear-gradient(90deg, rgba(0,0,0,1) 0%, rgba(254,197,3,1) 50%, rgba(254,209,54,1) 75%);
-webkit-box-shadow:0px 0px 8px 2px rgba(255,255,255,0.25);
-moz-box-shadow: 0px 0px 8px 2px rgba(255,255,255,0.25);
box-shadow: 0px 0px 8px 2px rgba(255,255,255,0.25);
}

/* SCROLLBAR MOBILE */
#scrollbar { position:fixed; right:2px; height:50px; width:6px; background: #000; background:rgba(0,0,0,0.6); border:1px solid rgba(255,255,255,0.6); z-index:90; border-radius:3px;  }
.skrollr-desktop #scrollbar { display:none; }
.skrollr-mobile #scrollbar { display: flex; }

.skrollable { z-index:90; }
.skrollr-mobile .skrollable { position:relative; }
.skrollable .skrollable { /*! position:absolute; */ }
.skrollable .skrollable .skrollable { position:static; }
.inner-wrapper { position: sticky;  top:0;  overflow: hidden; width: 100%; height: 100vh; }


/* VIDEO + IMG + TXT WRAPPER */ 

.video-wrapper video, .img-wrapper img {
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}

.video-wrapper.contain video { object-fit: contain; }

.video-wrapper, .img-wrapper, .txt-wrapper {
min-height: 100%;
overflow: hidden;
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
width: 100%;
}

/*Video wrapper für Context integration - FS*/
.video-wrapper-context video, .img-wrapper-context img {
  object-fit: cover;
  position: relative;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
min-height: 400px;  /*oder eine andere passende Höhe */
}

.header-wrapper { height: 25vh; }

.web-relative { position: static; }

@media (max-width: 575px) {
    .web-relative {  position: relative; }
}

.video-headline, .img-headline, .txt-headline { z-index: 50; text-align: center; width: 80%; padding-bottom: 2rem;}
.video-link { display: flex; width: 100%;}


/* HELPER CLASSES */
.liner { height: 2px; width: 100%; margin-bottom: 2rem; background: #fff;}
.liner-wrapper { width: 95%; margin: 0 auto; /*! height: 1rem; *//*! padding-top: 4rem; */}

.lh-4 { line-height: 4rem; }

.w-100 { width: 100% !important; }
.w-85 { width: 85% !important; }
.w-50 { width: 50% !important; }
.w-40 { width: 40% !important; }
.h-100 { height: 100% !important; }
.vh-50 { min-height: 50%; }
.vh-100 { height: 100vh; }
.vh-125 { height: 125vh; }
.vh-150 { height: 150vh; }
.vh-200 { height: 200vh; }
.vh-250 { height: 250vh; }
.vh-300 { height: 300vh; }
.vh-350 { height: 350vh; }
.vh-375 { height: 375vh; }
.vh-500 { height: 500vh; }


.bg-full {   background-position: center center; background-size: cover; background-repeat: no-repeat; display: block; height: 100%; overflow-x: hidden; overflow-y: hidden; position: relative; width: 100%; z-index: 1; text-align: center; }
.hidden { display: none!important; }
.bg-black { background: #000!important; }
.bg-white { background: #fff!important; }
.bg-gelb { background: #fed136!important; }
.text-gelb { color: #fed136; }
.text-white { color: #fff; }
.text-black { color: #000; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-left { text-align: left; }
.text-swap { text-align: left; }
.position-relative { position: relative!important; }
.fill-white { fill: #fff; }

/* NAV */

#main-nav { width: 100%; height: 100%; z-index: 1000; position: fixed; top: -100%; left: 0; opacity: 0.98; background: #000;   transition: top 0.3s ease-in-out;  overflow: clip;}
#main-nav.active { top: 0; }

.main-nav { display: flex; justify-content: center;  transition: opacity 0.7s 0.3s ease-in-out, top 0.7s 0.1s ease-in-out; font-family:  "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; letter-spacing: 0.025rem; font-weight: 300 !important; padding-top: 5rem; opacity: 0; }
#main-nav.active .main-nav { opacity: 1; top: 0%; }
.menu_button { width: 50px; height: 50px; cursor: pointer; display: block; position: fixed; top: 15px; right: 10px; z-index: 2000; background: #000; border-radius: 5px; transition:.5s; }
.menu_button.active {background: none; }
.menu_button:before, .menu_button:after { transition:.5s;}
.menu_button:before { content: ''; display: block; width: 30px; height: 2px; background: #fff; position: absolute; top: 50%; left: 50%; margin: -6px 0 0 -15px; transform-origin: center;}
.menu_button:after { content: ''; display: block; width: 30px; height: 2px; background: #fff; position: absolute; top: 50%; left: 50%; margin: 4px 0 0 -15px; transform-origin: center;}
.menu_button.active:before { margin: -1px 0 0 -15px; transform: rotate(45deg);}
.menu_button.active:after { margin: -1px 0 0 -15px; transform: rotate(-45deg);}

@media (max-width: 767px) {
		.menu_button { top: 10px; right: 5px; transform: scale(0.8);}
		.menu_button ul { top: 55px;}
        .menu-item { line-height: 1.2em; }
	}

.menu-wrapper { text-align: center; padding-bottom: 8rem; width: auto;}
.menu-item, .menu-hashtag { font-size: 2rem; line-height: 3rem; text-decoration: none; display: block; color: #fff; transition: all .5s ease-in-out;  position: relative;  }
.menu-item:hover, .menu-item:focus { text-decoration: none; transform: scale(1.1); }
.menu-hashtag img { height: 2rem; padding-bottom: 0.2rem; transition: all .5s; }
.menu-hashtag:hover img { transform: scale(1.1) }
.menu-logo { padding-bottom: 2rem; display: block;}

.bottom-links-wrapper { position: absolute; bottom: 0; padding-bottom: 4rem; display: flex; justify-content: center; }
.bottom-links { position: absolute; bottom: 0; padding-bottom: 2rem; justify-content: center; }
.bottom-links a { color: #fff; display: inline-flex; position: relative; padding: 0 1rem; }
.bottom-links a:hover, .bottom-links a:focus { color: #fed136; }
.bottom-links a::after { content: ""; position: absolute; display: block; width: 100%; height: 1px; bottom: 0; left: 0; background-color: #fed136; transform: scaleX(0); transform-origin: top left; transition: transform 0.3s ease; }
.bottom-links a:hover::after { transform: scaleX(1); }

.icon-wrapper { display: flex;  position: absolute;top: -100%;}

.menu-icon { color: #fff; padding: 0 0.5rem;}
.menu-icon:hover, .menu-icon:focus { color: #fed136; }

.footer-link { color: #fff; }
.footer-link:hover, .footer-link:focus { color: #fed136; }

#footer .menu-icon { color: #fff; }
#footer .menu-icon:hover, .menu-icon:focus { color: #fed136; }

.footer-links { padding-bottom: 4rem; justify-content: center; }
.footer-links .footer-link { padding: 0 1rem; position: relative; }
.footer-links a { padding: 0 1rem; }
.footer-links .footer-link:hover, .footer-links a:focus { color: #fed136; }
.footer-links .footer-link::after { content: ""; position: absolute; display: block; width: 100%; height: 1px; bottom: 0; left: 0; background-color: #fed136; transform: scaleX(0); transform-origin: top left; transition: transform 0.3s ease; }
.footer-links .footer-link:hover::after { transform: scaleX(1); }

.button-navi { display: block; padding-top: 3rem; padding-bottom: 3rem; font-size: 1.5rem;}

.connection-link { color: #fed136; }
.connection-link:hover, .connection-link:focus { color: #fff; }

 .justified-text { text-align: justify; /* Blocksatz */
      word-wrap: break-word; /* Zeilenumbruch bei langen Wörtern */
      overflow-wrap: break-word; /* Modernere Alternative für Zeilenumbruch */
	 hyphens: auto; } /* Automatische Silbentrennung, wenn unterstützt */ 

/* LAYOUTANPASSUNGEN RESPONSIVE */


@media (min-width: 576px) {
  #header-logo img { width: 40%; }
    .menu-item { font-size: 2.5rem; line-height: 3rem; }
.main-nav { padding-top: 3rem; }
.button-navi { display: flex; justify-content: center; }
    #header-logo-wrapper { display: flex; }
  #mobile-logo { display: none; }
  .standort-foto { width: 60%;}
}

@media (min-width: 768px) {
  .text-md-right { text-align: right; }
  .kilo { font-size: 1.40rem; }
  .mega_k { font-size: 1.60rem; }
  .mega { font-size: 2rem; }
  .giga { font-size: 3rem; }
  .tera { font-size: 4rem; }
  .portrait {  padding-bottom: 0rem; }
#header-logo img { width: 35%; }
  .menu-item { font-size: 2rem; line-height: 2.5rem; }
  .menu-icon { color: #fff; padding: 0 1rem; }
    .text-swap { text-align: right; }
  .bottom-links-wrapper { padding-bottom: 0.5rem; }
  .bottom-links { padding-bottom: 2rem; }
    .main-nav { padding-top: 5rem; }
  .standort-foto { width: 50%;}
}

@media (min-width: 992px) {
  .kilo { font-size: 1.40rem; }
  .mega_k { font-size: 1.60rem; }
  .mega { font-size: 2rem; }
  .giga { font-size: 3rem; }
  .tera { font-size: 5rem; }
#header-logo img { width: 30%; }
   .menu-icon { padding: 0 0.5rem;}
  .paragraph { font-size: 1.25rem; }
    .bottom-links-wrapper { padding-bottom: 2rem; }
  .bottom-links { padding-bottom: 3rem; }
  .main-nav { padding-top: 5rem; }
  .button-container { font-size: 2rem; }  
}

@media (min-width: 1200px) {
  .kilo { font-size: 1.6rem; }
  .mega_k { font-size: 1.85rem; }
  .mega { font-size: 2.25rem; }
  .giga { font-size: 4.5rem; }
  .tera { font-size: 6rem; }
  .menu-item { line-height: 3.5rem; }
#header-logo img { width: 25%; }
      .menu-icon { padding: 0 1rem;}
  .bottom-links-wrapper { padding-bottom: 4rem; }
  .bottom-links { padding-bottom: 4rem; }
  .main-nav { padding-top: 8rem; }
}

@media (min-width: 1400px) {
        .menu-item { font-size: 2.5rem; line-height: 3.5rem; }
    #header-logo img { width: 20%; }
  .main-nav { padding-top: 20vh; }
}


@media (max-width: 575px) {
.vh-100, .vh-125, .vh-150, .vh-200, .vh-250, .vh-300, .vh-350, .vh-375, .vh-500 { height: 100svh; }
  .video-wrapper, .txt-wrapper, .img-wrapper { position: absolute !important; top: 0!important; z-index: 1;}
  #header-logo-wrapper { display: none !important;}
  .raster {
    -webkit-background-size: 50%;
    -moz-background-size: 50%;
    background-size: 50%;
    -o-background-size: 50%;
}

} 

#main-nav, #scrollbar {
    z-index: 1000 !important; /* Sicherstellen, dass sie nicht über 20050 für das Modal liegen */
}


/* Modal: Maximal 90% der Bildschirmhöhe, Scrollen erlauben */
.modal-dialog {
    max-height: 90vh; /* Modal-Höhe auf maximal 90% der Viewport-Höhe begrenzen */
    overflow-y: auto; /* Scrollen erlauben, falls der Inhalt zu groß ist */
	/*z-index: 9000;*/
}

.modal-backdrop {
    z-index: 10040 !important; /*Sicherstellen, dass es hinter dem Modal liegt */
    position: fixed; /* Muss immer `fixed` sein, um korrekt zu funktionieren */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.modal {
    z-index: 10050 !important; /* Höher als modal-backdrop */
    position: fixed !important; /* Wichtig, um sicherzustellen, dass es korrekt überlappt */
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}


@media (max-width: 575px) {
    .modal-backdrop {
        	z-index: 10040 !important;
		    position: fixed; /* Muss immer `fixed` sein, um korrekt zu funktionieren */
			top: 0;
			left: 0;
			width: 100%;
			height: 100%;
    }
    .modal {
        z-index: 10050 !important;
		position: fixed !important; /* Wichtig, um sicherzustellen, dass es korrekt überlappt */
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
    }
}


/* Verhindern, dass der Hintergrund scrollt, wenn das Modal geöffnet ist */
body.modal-open {
    overflow: hidden !important;
}

/* Für mobile Geräte: Maximale Breite des Modals anpassen */
@media (max-width: 576px) {
    .modal-dialog {
        max-width: 90%; /* Modal-Breite auf maximal 90% des Bildschirms begrenzen */
    }
}

/* Textfarbe: Stellen sicher, dass der Text im Modal sichtbar ist */
.modal-body, .modal-footer, .modal-header {
    color: #000 !important; /* Schwarzer Text für bessere Lesbarkeit */
}

/* Button im Footer: Optional für visuelles Feedback */
.modal-footer .btn {
    background-color: #fed136; /* Bootstrap-Blau für den Button */
    color: #fff; /* Weißer Text */
    border: none;
}

.modal-footer .btn:hover {
    background-color: #FEE07B; /* Dunkleres Blau beim Hover */
}


form input:disabled,
form textarea:disabled,
form button:disabled {
    background-color: #B8B8B8;
    color: #ccc;
    cursor: not-allowed;
}

form label {
    display: block; /* Überschrift bleibt über dem Input */
    margin-bottom: 5px; /* Wenig Abstand zwischen Label und Input */
    /* font-weight: bold; Optional: Fettschrift für Labels */
}

.custom-btn {
    background-color: #fed136;
    color: #fff;
    font-size: 16px;
    padding: 12px 20px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    width: 100%;
    text-transform: uppercase;
    font-weight: bold;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
}

.custom-btn:hover {
    background-color: #f6c113;
    transform: scale(1.05);
}

.custom-btn:active {
    background-color: #d9a80b;
    transform: scale(0.95);
}

.custom-textarea {
    width: 100%;
    padding: 12px;
    font-size: 16px;
    border: 2px solid #fed136;
    border-radius: 5px;
    background-color: #262626; /* grauer Hintergrund */
    color: #fed136;
    min-height: 120px; /* Größere Startgröße */
    resize: vertical; /* Manuelles Vergrößern erlaubt */
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
	margin-bottom: 10px;
}

.custom-textarea:focus {
    border-color: #f6c113;
	color: #262626;
    outline: none;
    box-shadow: 0 0 5px rgba(246, 193, 19, 0.6);
	background-color: #fff; /* Weißer Hintergrund */
}

.custom-input {
    width: 100%;
    padding: 10px 15px;
    font-size: 16px;
    border: 2px solid #fed136; /* Goldgelber Rand */
    border-radius: 5px; /* Abgerundete Ecken */
    background-color: #262626; /* grauer Hintergrund */
    color: #fed136; /* Dunkler Text */
	margin-bottom: 20px; /* Mehr Abstand zwischen den Feldern */
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.custom-input:focus {
    border-color: #f6c113; /* Dunkleres Gelb beim Fokussieren */
	color: #262626;
	background-color: #fff; /* Weißer Hintergrund */
    outline: none;
    box-shadow: 0 0 5px rgba(246, 193, 19, 0.6); /* Leichter Glow-Effekt */
}

/* Styling für das Fieldset */
fieldset {
    border: none;
    margin-bottom: 20px;
}

legend {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 10px;
    color: #fff;
}

/* Checkbox-Gruppe */
.checkbox-group {
    display: flex;
    flex-wrap: wrap; /* Umbrüche erlauben */
    gap: 10px; /* Abstand zwischen Checkboxen */
}

.checkbox-group label {
    display: flex;
    align-items: flex-start; /* Checkbox oben ausrichten */
    font-size: 16px;
    color: #fff;
    width: calc(50% - 10px); /* Zwei Spalten */
}

/* Einheitliche Checkbox-Größe */
.checkbox-group input[type="checkbox"] {
    flex-shrink: 0; /* Größe der Checkbox bleibt fix */
    margin-right: 10px; /* Abstand zwischen Checkbox und Text */
    width: 20px; /* Einheitliche Breite */
    height: 20px; /* Einheitliche Höhe */
    cursor: pointer;
    accent-color: #fed136; /* Gelbe Checkbox */
    box-sizing: border-box; /* Padding und Border korrekt berücksichtigen */
    transition: transform 0.2s ease, box-shadow 0.2s ease; /* Hover-Effekt sanft */
}

/* Hover-Effekt */
.checkbox-group input[type="checkbox"]:hover {
    transform: scale(1.2); /* Leichter Zoom-Effekt */
    box-shadow: 0 0 5px rgba(246, 193, 19, 0.6); /* Glow-Effekt */
}

/* Fokus-Effekt */
.checkbox-group input[type="checkbox"]:focus {
    outline: 2px solid #f6c113; /* Gelber Umriss */
    outline-offset: 2px;
}

.g-recaptcha iframe {
    pointer-events: auto !important;
    z-index: 2050 !important; /* Optional: Über anderen Ebenen sicherstellen /LENIS */
}

/*cookie banner*/
.ccm-settings-summoner {
    position: fixed !important;
    right: 10px !important;
    bottom: 20px !important;
    left: auto !important;
	border: 5px solid #fed136;
}

/*cookie Banner bei mobil button deaktivieren */
@media (max-width: 768px) {
    .ccm-settings-summoner {
        display: none !important;
    }
}

/*Eigenes Cookie Icon*/
/*.ccm-settings-summoner--icon {
	content: url('../images/settings-icon-cookie-custom.svg');
   }*/ 



/* Vorschaubild Broschüre */
.brochure-container {
        text-align: center;
        margin: 20px auto;
    }

    .brochure-link {
        display: inline-block;
        text-decoration: none;
    }

	.brochure-image {
		width: 100%; /* Bild nimmt die volle Breite der Spalte ein */
		height: auto; /* Höhe wird automatisch angepasst */
		/* border-radius: 5px; Abgerundete Ecken */
		box-shadow: 0px 0px 15px rgba(246, 193, 19, 0.6); /* Goldener Glow */
		transition: transform 0.3s ease, box-shadow 0.3s ease;
	}

	.brochure-image-w50 {
		width: 50%; /* Bild nimmt 40% Breite der Spalte ein */
	}

	/* Pulsierender Effekt */
	@keyframes pulse {
		0% { transform: scale(1); box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.2); }
		50% { transform: scale(1.1); box-shadow: 0px 8px 12px rgba(0, 0, 0, 0.3); }
		100% { transform: scale(1); box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.2); }
	}

	.brochure-image.pulsing {
		animation: pulse 1.5s infinite ease-in-out;
	}


    .brochure-image:hover {
        transform: scale(1.05); /* Zoom-Effekt bei Hover */
        box-shadow: 0px 6px 12px rgba(0, 0, 0, 0.3); /* Verstärkter Schatten bei Hover */
    }

    .brochure-caption {
        margin-top: 10px;
        font-size: 16px;
        /*font-weight: 600;*/
        color: #fed136;
    }


/*ICON NAV*/

.icon-nav { 
	position: fixed;
	right: 0;
	top: 65px;
	padding: 1rem;
	z-index: 999;
	overflow: hidden;
}

.icon-nav ul {
	position: relative;
	right: -100%;
	margin: 0;
	padding: 0;
	font-size: 1.5rem;
    list-style-image: none;
	list-style-type: none;
}

.icon-nav li { margin-bottom: 0.5rem; }

.icon-nav ul li a {
	position: relative;
	right: 3rem;
	display: inline-block;
	/*background: #fed136;*/
	background: rgba(0, 0, 0, .15);
	color: #fed136;
    border: 1px solid #fed136;
	padding: 0.25em 0.5em;
	width: 110%;
	list-style-type: none;
}

.icon-nav ul li a:hover {
	right: 100%;
	color: #fed136;
	background: #000000; 
        border: 1px solid #fed136;
	text-decoration: none;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
	list-style-type: none;
}

.icon-nav-text {
	padding-left: 2rem;
	font-size: 1.5rem;
	display: inline-block;
}

