@charset "UTF-8";
/* CSS Document */

/* -----------------------------  Desktop  -------------------------------- */

/* Hauptnavigation überspringen */

a.nonav { position: absolute; top: -100px; left: 50%; transform: translateX(-50%); font-size: 1.2rem; line-height: 1.2rem; padding: 15px 20px; z-index: 9999; }
a.nonav:focus-visible { top: 10px !important; outline: 0; border: 0; background: #3f4e55; color: #ffffff; }

button.navopen { position: absolute; left: 0; top: 0; padding: 23px 27px 24px; font-size: 1.3rem; line-height: 1em; display: none; z-index: 99999; background: transparent; color: #3f4e55; }
button.navopen::before { font-family: 'simple-line-icons'; content: "\e601"; font-size: 1.4rem; margin-right: 7px; display: inline-block; }
button.navopen.active::before { content: "\e082"; }
button.navopen:hover { border: 0; background: #d60b51; color: #ffffff; cursor: pointer; }
button.navopen:focus-visible { outline: 0; border: 0; background: #3f4e55; color: #ffffff; }

.outofnav { position: absolute; top: 15px; right: 2vw; z-index: 8000; }

.outofnav a.leichtesprache { margin: 0 10px 0 0; padding: 12px 10px; font-size: 1.1rem; line-height: 1em; background: transparent; color: #3f4e55; }
.outofnav a.leichtesprache:hover { border: 0; background: #3f4e55; color: #ffffff; cursor: pointer; }
.outofnav a.leichtesprache:focus-visible { outline: 0; border: 0; background: #3f4e55; color: #ffffff; }

/* Hauptnavigation */

nav { position: relative; width: 100%; z-index: 7000; padding: 0 2vw; background: #ffffff; }
nav > ul { position: relative; }
nav > ul > li { position: relative; line-height: 1em; }
nav > ul > li > a, nav > ul > li > a:active, nav > ul > li > a:visited { 
  color: #3f4e55; 
  font-size: 18px;
  font-weight: 400; 
  line-height: 18px; 
  padding: 26px 15px;
  border: 0;
  display: inline-block; 
  text-transform: uppercase;
}
nav > ul > li > a:hover { color: #f29100; }
nav > ul > li > a:focus-visible,
nav > ul > li.active > a { background: #3f4e55; color: #ffffff; border: 0; outline: 0; cursor: pointer; }

nav > ul > li.menu-item-has-children > a { padding: 26px 8px 26px 15px; }
nav > ul > li.menu-item-has-children > a:focus-visible,
nav > ul > li.menu-item-has-children.active > a { outline: 0; background: #3f4e55; color: #ffffff;  }
nav > ul > li.menu-item-has-children > a::after { font-family: 'simple-line-icons'; font-size: .75em !important; line-height: 1em; content: "\e605"; margin-left: .4em; }
nav > ul > li.menu-item-has-children > a.active::after { content: "\e604"; }

nav > ul > li.current-menu-item > a, nav > ul > li.current-menu-parent > a { background: #d60b51; color: #ffffff; }
nav > ul > li.current-menu-item > a:hover, nav > ul > li.current-menu-item > a:focus-visible,
nav > ul > li.current-menu-parent > a:hover{ background: #ffffff; color: #d60b51; }
nav > ul > li.current-menu-parent > a:focus-visible { background: #3f4e55; color: #ffffff;}

nav > ul > li.show-mobile { display: none; }

/* Navigation Unterebene 1 */

nav > ul ul.sub-menu {
  z-index: 9999;
  position: absolute;
  top: 100%;
  width: 18em;
  margin-top: 20px;
  left: 0;
  text-align: left; 
  visibility: hidden;
  opacity: 0;
  -webkit-transition:  visibility .25s, opacity .25s, margin-top .25s ease-out;
  -moz-transition:  visibility .25s, opacity .25s, margin-top .25s ease-out;
  -ms-transition:  visibility .25s, opacity .25s, margin-top .25s ease-out;
  transition: visibility .25s, opacity .25s, margin-top .25s ease-out;
}

nav > ul > li > ul.sub-menu.active { visibility: visible; opacity: 1; margin-top: 0px; }

nav > ul ul.sub-menu > li > a { 
  display: block; 
  padding: 16px; 
  color: #3d4b52; 
  background: #ffffff; 
  font-size: 1.2rem;
  line-height: 1.2em;
  text-transform: none;
  border:0;
  border-left: 5px solid transparent;
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
nav > ul ul.sub-menu > li:first-child > a { border-top: 0; }
nav > ul ul.sub-menu > li > a:hover { cursor: pointer; color: #f29100; border-left: 5px solid #f29100; }
nav > ul ul.sub-menu > li > a:focus-visible { outline: 0; color: #ffffff; border-left: 5px solid #f29100; background: #3f4e55; }

nav > ul ul > li.current-menu-item > a { background: #d60b51; color: #ffffff; }

.navoverlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(42,54,59,.75); z-index: 1000; display: none; }
.navoverlay.active { display: block; }


/* Footernavigation */

ul.footer { margin: 0 !important; line-height: 1rem; }
ul.footer li { position: relative; display: inline-block; margin-right: 20px; line-height: 1em; }
ul.footer li a { color: rgba(255,255,255,1); text-decoration: none; font-size: 1rem; line-height: 1rem; padding: 5px 10px; margin-left: -10px; text-transform: uppercase; letter-spacing: .05em; }
ul.footer li a:hover { color: rgba(255,255,255,.6); }
ul.footer li a:focus-visible { background: #ffffff; color: #000000; border: 0; outline: 0; }

/* Sidebar / Angebote */

ul.angebote { margin: 0 !important; }
ul.angebote li { list-style-type: none !important; margin: 0 0 .5em 0 !important; border: none !important; }
ul.angebote li a { font-size: 1.5rem !important; line-height: 1.2rem; padding: 3px 8px 5px 5px !important; margin-left: -8px; }
ul.angebote li a:focus-visible { background: #000000; color: #ffffff; }
ul.angebote li.current-menu-item { display: none; }
ul.angebote li a:before { 
  font-family: 'simple-line-icons';
  font-size: .75em !important;
  line-height: 0;
  content: "\e606";
  margin-right: .25em;
 }

/* Suche */

button.searchopen { padding: 0 10px; margin: 0 -10px 0 0; background: transparent; color: #3f4e55; }
button.searchopen:hover { border: 0; background: #3f4e55; color: #ffffff; cursor: pointer; }
button.searchopen:focus-visible { outline: 0; border: 0; background: #3f4e55; color: #ffffff; }
button.searchopen i { margin: 0; padding: 0; font-size: 1.5rem; line-height: 1.5rem; }

search { width: 100%; position: absolute; top: 0; left: 0; padding: 6vw; z-index: 99999; display: none; }
search.active { display: block; }
search > div { margin: 0 auto; }
search form { position: relative; margin: 0 auto; }
search form label { display: block; font-size: 2.5rem; margin-bottom: 1rem; }
search input[type=search].searchfield { font-size: 20px; line-height: 20px; padding: 15px; width: calc(100% - 130px); border: 1px solid #b2b2b2; color: #000000; background-color: #ffffff; border-radius: 0; }
search input[type=search].searchfield:focus-visible { outline: 0; border: 1px solid #000000;}
search button.searchbutton { position: relative; width: 120px; color: #3f4e55; background: #ffffff; border: 1px solid #3f4e55; border-radius: 0; padding: 17px; font-size: 19px; line-height: 1em; cursor: pointer; }
search button.searchbutton:hover { background-color: #ffffff; color: #f29100; border: 1px solid #f29100; }
search button.searchbutton:focus-visible { outline: 0; border: 0; background-color: #d60b51; color: #ffffff; border: 1px solid #d60b51; }

button.searchclose { padding: 10px; margin-top: 30px; background: #ffffff; color: #3f4e55; }
button.searchclose:hover { border: 0; background-color: #ffffff; color: #f29100;  cursor: pointer; }
button.searchclose:focus-visible { outline: 0; border: 0; background: #d60b51; color: #ffffff; }
button.searchclose i { margin: 0; padding: 0; font-size: 2.5rem; }

.searchoverlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0, 0.65); z-index: 1000; display: none; }
.searchoverlay.active { display: block; }

/* Zeno Font resizer */

.zeno_font_resizer_container { color: #3f4e55; margin: 11px 20px 0 0; }
.zeno_font_resizer::before { content: 'Schrift:'; font-weight: 400; font-size: 18px; margin-right: 5px; }
.zeno_font_resizer a { color: #3f4e55; padding: 0 2px; margin: 0 2px; }
.zeno_font_resizer a:hover { color: #ffffff; background: #3f4e55; }
.zeno_font_resizer a:focus-visible { outline: 0; color: #ffffff; background: #3f4e55; }
.zeno_font_resizer .zeno_font_resizer_minus { font-size: 17px !important; line-height: 1rem; }
.zeno_font_resizer .zeno_font_resizer_reset { font-size: 22px !important; line-height: 1rem; }
.zeno_font_resizer .zeno_font_resizer_add { font-size: 26px !important; line-height: 1rem; }

/* -----------------------------  Mobile  -------------------------------- */

@media all and (max-width: 1350px) {

  /* Hauptnavigation */

  .outofnav { position: relative; top: 0; right: 0; padding: 13px 27px; z-index: 9999; }

  button.navopen { display: block; }

  nav { margin: 0; padding: 0; }

  nav > ul.row {
    -webkit-transition: all .35s ease-in-out; -moz-transition: all .35s ease-in-out; -ms-transition: all .35s ease-in-out; transition: all .35s ease-in-out;
    position: relative; overflow: hidden; margin: 70px 0 0; max-height: 0; width: 100%; display: none;
  }

  nav.active > ul.row { max-height: 55em; display: block; }
  nav > ul > li { border-top: 1px solid rgba(0,0,0,0.2); }
  nav > ul > li:last-child { border-bottom:  1px solid rgba(0,0,0,0.2); }
  nav > ul > li > a, nav > ul > li > a:active, nav > ul > li > a:visited { padding: 18px 27px; display: block; }
  nav > ul > li.menu-item-has-children > a { padding: 18px 21px 18px 27px; }

  nav > ul > li.menu-item-has-children > a::after { font-family: 'simple-line-icons'; position: absolute; top: 18px; right: 27px; font-size: 1.1rem !important; line-height: 1em; content: "\e605"; margin-left: 0 }
  nav > ul > li.menu-item-has-children > a.active::after { content: "\e604"; }

  /* Navigation Unterebene 1 */

  nav > ul ul.sub-menu {
    -webkit-transition: all .35s ease-in-out; -moz-transition: all .35s ease-in-out; -ms-transition: all .35s ease-in-out; transition: all .35s ease-in-out;
    position: relative; top: auto; margin-top: 0; visibility: visible; opacity: 1; overflow: hidden; max-height: 0; width: 100%; display: none;
  }
  nav > ul ul.sub-menu.active { max-height: 55em; display: block; }
  nav > ul ul.sub-menu > li > a { padding: 13px 35px; border-top: 0; }

  /* Suche */

  search input[type=search].searchfield { font-size: 17px; line-height: 17px; padding: 16px 12px 15px; width: calc(100% - 100px);}
  search button.searchbutton { width: 90px; padding: 17px 12px; font-size: 17px; }

}

@media all and (max-width: 550px) {
  .outofnav a.leichtesprache { display: none; }
  nav > ul > li.show-mobile { display: block; }
}