:root {
  --logo-schrift: norman-stencil, sans-serif;
  --logo-font-size: 3rem;
  --logo-font-weight: 800;
  --nav_color_bg: transparent;
  /* --nav_color_bg_fixed: rgba(255, 255, 255, 1.0);  */
  --nav_color_bg_fixed: #cbcaba;

  --nav_color_bg_offcanvas: #444444;
  --nav_color_text_offcanvas_hover: #ff9090;

  --nav_color_toggle: #b40000;
  --nav_color_text: #ffffff;
  --nav_color_text_hover: #31cd1c;
  --nav_color_text_fixed: #40412f;
  --nav_color_text_fixed_hover: #696939;
  --nav_color_text_dropdown: #444444;
}

.navigation {
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out;
  position: fixed;
  /* width: 100vW; */
  width: 100%;
  z-index: 999;
  /*background-color: #e6e6e6;*/
  /* background-color: rgba(255, 255, 255, 0.0);  */
  /*background-color: rgba(160, 160, 160, 0.5); */
  background-color: var(--nav_color_bg);
  color: var(--nav_color_text);
  top: 0;
  left: 0;
  line-height: 1.0;
  /*border-bottom: 1px #fff solid;
  box-shadow: 0 5px 15px rgba(0,0,0,.1);*/
}

.navigation.fixed,
.loading .navigation {
  background-color: var(--nav_color_bg_fixed);
}

.header-content {
  /*padding-left:10px;
  padding-right:10px;
  padding-top:10px;
  height: calc(100% - 20px);  /*Höhe - 2x padding */
  height: 100%;
  display: flex;
  justify-content: space-between;
  /* Logo links, Nav rechts */
}

/* header mittig mit Breite 1200px */
.navigation .header-content {
  /*position: relative;
  max-width: 1200px;
  margin: 0 auto;
  background: #f6f6f6;*/
  border-bottom: none;
  -webkit-transition: height 300ms ease-in-out;
  transition: height 300ms ease-in-out;
}

/*
header{
  height: 100%;
}*/
header .logo {
  display: flex;
  opacity: 0;
}

header .logo_text {
  align-self: start;
  height: 100%;
  display: flex;
  padding: 0;
}

header .logo_text h1 {
  opacity: 0;
  /* letter-spacing: 4px; */
  font-weight: 300;
  /*text-shadow: 3px 3px 6px rgba(150, 150, 150, 0.8);*/
  -webkit-transition: color 2s, font-size 2s;
  -moz-transition: color .5s, font-size .5s;
  -o-transition: color .5s, font-size .5s;
  transition: color .5s, font-size .5s;
}

header ul.primary-nav {
  margin: 0px;
  display: flex;
  justify-content: flex-end;
}

header ul.primary-nav li {
  display: flex;
}

header ul.primary-nav li a {
  outline: 0;
  /* remove dotted line */
  padding: 0.3em;
  /* padding-right: 1.5vw; */
  font-size: 1.6em;
  color: #444444;
  font-weight: 600;
  -webkit-transition: color 2s, font-size 2s;
  -moz-transition: color .5s, font-size .5s;
  -o-transition: color .5s, font-size .5s;
  transition: color .5s, font-size .5s;
}

/* header ul.primary-nav li a:hover {
          color: #1e87f0; }  */
header ul.primary-nav li:last-child a {
  padding-right: 0px;
}

header .header-nav {
  /*  width: 100%; */
  height: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}

header .header-nav li.aktuell a {
  color: #6d6a6a;
}

header ul.primary-nav li a:hover,
.uk-navbar-nav>li:hover>a,
.uk-navbar-nav>li>a.uk-open,
.uk-navbar-nav>li>a:focus {
  color: var(--nav_color_text_hover);
  display: block;
  /*background-color: #fff;*/
}

.navigation.fixed header ul.primary-nav li a:hover,
.navigation.fixed .uk-navbar-nav>li:hover>a,
.navigation.fixed .uk-navbar-nav>li>a.uk-open,
.navigation.fixed .uk-navbar-nav>li>a:focus {
  color: var(--nav_color_text_fixed_hover);
}



/* ==========================================================================
Hero Logo FadeIn
=========================================================================
.logo {
	background-size: cover, cover;
	background-position: center, center;
	height: 100vh;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
} */

.logo {
  display: inline-block;
  margin: 0;
  padding: 0.5rem;
  position: relative;
  transform: scale(1);
  transition: transform 0.5s ease, opacity 1s ease;

}

.logo a,
.logo a h1,
.logo a h1,
a:link.logo h1,
a.logo {
  text-decoration: none;
}

.logo a {
  display: flex;
}

h1.logo {
  font-family: var(--logo-schrift);
  font-size: 1.5rem;
  color: #fff;
  margin: 10px 0 0 10px;
  -webkit-transition: color .5s, margin 1s, font-size 1s, opacity 1s ease;
  -moz-transition: color .5s, margin 1s, font-size 1s, opacity 1s ease;
  -o-transition: color .5s, margin 1s, font-size 1s, opacity 1s ease;
  transition: color .5s, margin 1s, font-size 1s, opacity 1s ease;
}

.logo h1 {
  font-family: var(--logo-schrift);
  font-size: 2.2rem;
  font-weight: 600;
  font-weight: 100;
  color: #fff;
  margin: 0.4em;
  -webkit-transition: color .5s, margin 1s, font-size 1s ease, opacity 1s ease;
  -moz-transition: color .5s, margin 1s, font-size 1s ease, opacity 1s ease;
  -o-transition: color .5s, margin 1s, font-size 1s ease, opacity 1s ease;
  transition: color .5s, margin 1s, font-size 1s ease, opacity 1s ease;
}

.logo h2 {
  font-family: var(--logo-schrift);
  font-size: 1.3rem;
  font-weight: 100;
  margin: 0 0 5px 0;
  -webkit-transition: color .5s, font-size 1s ease;
  -moz-transition: color .5s, font-size 1s ease;
  -o-transition: color .5s, font-size 1s ease;
  transition: color .5s, font-size 1s ease;
}

.navigation .logo img,
.navigation .logo .ip-inner {
  margin-top: 0em;
  width: 40px;
  height: 40px;
  -webkit-transition: width 1s, height 1s ease;
  -moz-transition: width 1s, height 1s ease;
  -o-transition: width 1s, height 1s ease;
  transition: width 1s, height 1s ease;
}

.navigation .logo_img {
  display: none;
}

/* nav fixed. kleine Schrift */
.navigation.fixed .logo h1 {
  font-size: 1.7rem;
}

.navigation.fixed .logo h2 {
  font-size: 1.0rem;
}

.logo.is-loading {
  transform: scale(0.9);
  opacity: 0;
}

/* ==========================================================================
Logo
========================================================================== */
/* Logo auf Ladeseite */
.ip-logo .ip-inner {
  width: 250px;
  height: 250px;
}

/* Logo in Menüzeile */
.uk-container .logo .ip-inner {
  width: 80px;
  height: 80px;
}

.logo #kreis {
  /* background-color: rgba(0, 0, 0, 0.3); */
  position: absolute;
  width: 120px;
  height: 120px;
  top: -10px;
  right: -12px;
  text-align: center;
  border-radius: 60px;
  z-index: -5;
  -webkit-transition: width 1s, height, background-color 1s ease;
  -moz-transition: width 1s, height, background-color 1s ease;
  -o-transition: width 1s, height, background-color 1s ease;
  transition: width 1s, height, background-color 1s ease;
}


/* ==========================================================================
  Navigationsleiste auf Handys
========================================================================== */
/* Logo mittig */
.navigation header .logo {
  align-items: center;
  opacity: 0;
}

.loading .navigation header .logo,
.navigation.fixed header .logo {
  align-items: center;
  opacity: 1;
}

/*.navigation.fixed header{
  height: 70px;
}*/

/* .navigation header .logo_text h1{
  font-size: 1.0em;
  margin: 0;
  opacity: 0;
  font-family: 'Marcellus', 'Playfair Display', serif;
  font-family: var(--font_titel);
}

.navigation.fixed header .logo_text h1{
	font-size: 1.0em;
  margin: 0;
  opacity: 1;
  align-self: center;
} */
.navigation .logo h1 {
  font-size: 1.4em;
  margin: 0;
  opacity: 0;
  font-family: var(--font_titel);
}

.loading .navigation .logo h1 {
  opacity: 1;
  color: #c71313;
  font-size: 2.2rem;
  margin: 0.4em;
}

.navigation.fixed .logo h1 {
  font-size: 1.4em;
  margin: 0;
  opacity: 1;
  align-self: center;
}

/* .navigation.fixed header ul.primary-nav li a, */
.navigation.fixed header li a,
.navigation.fixed header h1,
.navigation.fixed header h2 {
  color: var(--nav_color_text_fixed);
}

.loading .navigation .logo img,
.navigation.fixed .logo img {
  width: 65px;
  height: 65px;
}

/* Logo in Menüzeile */
.loading .navigation .logo .ip-inner,
.navigation.fixed .logo .ip-inner {
  width: 60px;
  height: 60px;
}

.loading .navigation .logo #kreis,
.navigation.fixed .logo #kreis {
  background-color: var(--nav_color_bg_fixed);
  width: 86px;
  height: 86px;
  top: -10px;
  right: -6px;
  border-radius: 43px;
}




.navigation .header-content {
  height: 70px;
}

/*
.navigation.fixed .header-content {
  height: 70px;
  position: fixed;
}*/

.seiteninhalt {
  margin-top: 70px;
}



/* ==========================================================================
  Navigationsleiste auf Handys quer und Tablets
========================================================================== */
@media screen and (min-width:350px) and (min-height:550px) {

  /* ==========================================================================
  schmale Navigationsleiste  .navigation.fixed 
  ========================================================================== */
  .loading .navigation .header-content,
  .navigation.fixed .header-content {
    height: 80px;
  }

  .seiteninhalt {
    margin-top: 80px;
  }



  /* ==========================================================================
    breite Navigationsleiste  .navigation
  ========================================================================== */
  .navigation .header-content {
    height: 100px;
  }

  .seiteninhalt {
    margin-top: 100px;
  }

}



/* ==========================================================================
  Navigationsleiste auf Monitoren
========================================================================== */
@media screen and (min-width:550px) and (min-height:550px) {

  /* Logo an den oberen Rand */
  .loading .navigation .header-content .logo,
  .navigation.fixed .header-content .logo,
  .navigation .header-content .logo {
    align-items: flex-start;
  }

  /*.navigation.fixed .uk-navbar-left {
    align-items: flex-start;
  } */

  /* ==========================================================================
  schmale Navigationsleiste  .navigation.fixed 
  ========================================================================== */
  .loading .navigation .header-content,
  .navigation.fixed .header-content {
    /*background-color: #fff;
      border-bottom: solid 1px rgba(255, 255, 255, 0.2);*/
    height: 90px;
  }

  .loading .navigation.logo h1,
  .navigation.fixed .logo h1 {
    font-size: 1.6rem;
  }

  .navigation.fixed .logo h2 {
    font-size: 1.1rem;
  }

  /* Logo in Menüzeile */
  .loading .navigation .logo .ip-inner,
  .loading .navigation .logo .img,
  .navigation.fixed .logo .ip-inner,
  .navigation.fixed .logo img {
    display: block;
    width: 70px;
    height: 70px;
  }

  .navigation .logo_img {
    display: block;
  }


  .loading .navigation .logo #kreis,
  .navigation.fixed .logo #kreis {
    background-color: var(--nav_color_bg_fixed);
    width: 160px;
    height: 160px;
    top: -10px;
    right: -12px;
    border-radius: 80px;
  }

  .loading .navigation h1.logo,
  .navigation.fixed h1.logo {
    font-size: 2.5rem;
    margin: -35px 0 0 20px;
  }

  /* ==========================================================================
    breite Navigationsleiste  .navigation
  ========================================================================== */
  .navigation .header-content {
    /* background-color: #fff;
      border-bottom: solid 1px rgba(255, 255, 255, 0.2);*/
    /*height: 130px;*/
    height: 60px;
  }

  .seiteninhalt {
    margin-top: 130px;
  }

  .logo h1 {
    font-size: 3.2rem;
  }

  .logo h2 {
    font-size: 1.9rem;
  }

  /* Logo in Menüzeile */
  .navigation .logo .ip-inner,
  .navigation .logo img {
    width: 120px;
    height: 120px;
  }

  h1.logo {
    font-size: 3rem;
  }

  .logo #kreis {
    width: 160px;
    height: 160px;
    top: -10px;
    right: -12px;
    border-radius: 80px;
  }

}


@media screen and (min-width:960px) {

  .loading .navigation .logo h1,
  .navigation.fixed .logo h1 {
    font-size: 2.3rem;
  }

  .loading .navigation .logo h2,
  .navigation.fixed .logo h2 {
    font-size: 1.4rem;
  }
}


/* ==========================================================================
uk Anpassungen
========================================================================== */
@media screen and (min-width:960px) {
  .uk-navbar-nav {
    gap: 15px;
  }
}


header ul.primary-nav li a {
  /* padding-right: 1.5vw; */
  font-size: 1.5em;
  color: var(--nav_color_text);
  font-weight: 400;
}

header ul.primary-nav .uk-navbar-dropdown-nav li a {
  font-size: 1.0em;
  color: var(--nav_color_text);
  font-weight: 300;
}

header ul.primary-nav .uk-navbar-dropdown-nav li a:hover {
  color: var(--nav_color_text_hover);
}

.uk-navbar-dropdown {
  width: 210px;
  padding: 15px;
  background: #fff;
}

.loading ul.primary-nav li a {
  color: #c71313;
}

@media screen and (min-width:990px) and (max-width:1120px) {
  header ul.primary-nav li a {
    font-size: 1.1em;
  }
}


header ul.primary-nav li .uk-navbar-dropdown-nav a {
  color: var(--nav_color_text_dropdown);
}

header ul.primary-nav li a.drop {
  font-size: 1.2em;
}

.uk-navbar-item,
.uk-navbar-nav>li>a,
.uk-navbar-toggle {
  min-height: 0px;
  padding: 0 15px;
  font-size: .875rem;
  font-family: inherit;
  text-decoration: none;
}

.uk-navbar-nav>li>a {
  color: #999;
  text-transform: none;
}

@media screen and (min-width:60em) {

  .uk-navbar-center-right>*,
  .uk-navbar-right {
    display: flex;
    /*align-items: flex-end;
    padding-bottom: 10px;*/
  }
}

.uk-sticky-fixed,
.uk-navbar-container {
  width: 100%;
}




/* ==========================================================================
navigation Hamburger
========================================================================== */
.navicon {
  /*position: absolute;
  height: 26px;
  right: 10px;
  top: 30px;*/
  display: none;
  /* wird eingeblendet bei: @media screen and (max-width:991px)  */
  justify-content: flex-end;
  align-items: center;
  /*width: 100%;*/
  height: 100%;
  visibility: hidden;
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out;
}

.nav-toggle {
  /* position: absolute;
  top: 0;
  right: 15px;*/
  /*display: flex;
  justify-content: flex-end;
   align-items: flex-end; */
  z-index: 1500;
  padding: 10px 35px 16px 0;
  cursor: pointer;
}

.nav-toggle:focus {
  outline: none;
}

.nav-toggle span,
.nav-toggle span:before,
.nav-toggle span:after {
  content: "";
  position: absolute;
  display: block;
  width: 35px;
  height: 3px;
  border-radius: 1px;
  background: var(--nav_color_toggle);
  cursor: pointer;
}

.nav-toggle span:before {
  top: -10px;
}

.nav-toggle span:after {
  bottom: -10px;
}

.nav-toggle span,
.nav-toggle span:before,
.nav-toggle span:after {
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out;
}


.olox_nav .nav-toggle span {
  background-color: transparent;
}

.olox_nav .nav-toggle span:before,
.olox_nav .nav-toggle span:after {
  background: #f8f8f8;
  top: 0;
}

.olox_nav .nav-toggle span:before {
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.olox_nav .nav-toggle span:after {
  top: 10px;
  -ms-transform: translatey(-10px) rotate(-45deg);
  -webkit-transform: translatey(-10px) rotate(-45deg);
  transform: translatey(-10px) rotate(-45deg);
}



/* ==========================================================================
Hamburger Menü einblenden
========================================================================== */
@media screen and (max-width:991px) {

  /* Haupt Nav ausblenden */
  nav ul.primary-nav {
    display: none;
  }

  /* Toggle Navicon einblenden */
  .navigation.fixed .navicon {
    visibility: visible;
    display: flex;
  }

  /* offcanvas Hintergrund */
  .uk-offcanvas-bar {
    position: absolute;
    top: 0;
    bottom: 0;
    left: -100%;
    box-sizing: border-box;
    width: 100%;
    padding: 20px 20px;
    background: var(--nav_color_bg_offcanvas);
    overflow-y: auto;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  #nav_olox .off_nav {
    flex-direction: column;
  }

  /* die einzelnen Menüpunkte werden innav_olox.js sichtbar geschaltet */
  #nav_olox ul.off_nav li {
    opacity: 0;
  }

  /* über nav_olox.js */
  /*.olox_nav #nav_olox ul.off_nav li  {
		opacity: 1;
	}*/

  .olox_nav #nav_olox ul.off_nav li a {
    color: #fff;
    font-size: 25px;
    /*text-transform: uppercase;*/
    font-weight: 600;
    -moz-transition: all 300ms ease-in-out;
    -o-transition: all 300ms ease-in-out;
    -webkit-transition: all 300ms ease-in-out;
    transition: all 300ms ease-in-out;
    text-align: center;
  }

  .olox_nav #nav_olox ul.off_nav li a:hover {
    color: var(--nav_color_text_offcanvas_hover);
  }

  ul.off_nav li {
    margin-bottom: 25px
  }

}




.fadeInUpOlox {
  visibility: visible;
  -webkit-animation-name: fadeInUpOlox;
  animation-name: fadeInUpOlox;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

@-webkit-keyframes fadeInUpOlox {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 50px, 0);
    transform: translate3d(0, 50px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInUpOlox {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 50px, 0);
    transform: translate3d(0, 50px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}