:root {
	--schrift_logo: norman-stencil, sans-serif;
  --logo-font-size: 3rem;
  --logo-font-weight: 800;
  --color_toggle: #c00000;
  --grau_dunkel: #444444;
}

.loading .navigation {
	opacity: 0;
}


.navigation {
  -webkit-transition: all 300ms ease-in-out;
          transition: all 300ms ease-in-out;
	position: fixed;
	width: 100%;
	z-index: 999;
  opacity: 1;
	/*background-color: #e6e6e6;*/
	background-color: rgba(255, 255, 255, 0.0); 
	/*background-color: rgba(160, 160, 160, 0.5); */
	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 {
	background-color: rgba(255, 255, 255, 1.0); 
}

.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 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: #c00000;
    display: block;
    /*background-color: #fff;*/
} 

/* ==========================================================================
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, .logo h1, a h1.logo {
    text-decoration: none;
}
.logo a {
   display: flex;
}
h1.logo  {
	font-family:var(--schrift_logo);
	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(--schrift_logo);
	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;
       -moz-transition: color .5s, margin 1s, font-size 1s ease;
         -o-transition: color .5s, margin 1s, font-size 1s ease;
            transition: color .5s, margin 1s, font-size 1s ease;
}
.logo h2 {
	font-family:var(--schrift_logo);
	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: 110px;
  height: 110px;
    -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;
}

/* 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
========================================================================== */
.rettungsring {
  stroke: #000;
  fill: rgb(0, 0, 109);
  fill: rgb(143, 9, 9);
}
/* 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;
}
.navigation.fixed header .logo{
  align-items: center;
  opacity: 1;
}

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

.navigation header .logo_text h1{
  font-size: 2.2em;
  margin: 0;
  opacity: 0;
}

.navigation.fixed header .logo_text h1{
	font-size: 2.0em;
  margin: 0;
  opacity: 1;
}
.navigation.fixed header ul.primary-nav li a,
.navigation.fixed header h1,
.navigation.fixed header h2{
  color: #c00000;
}
.navigation.fixed .logo img {
  width: 65px;
  height: 65px;
}
/* Logo in Menüzeile */
.navigation.fixed .logo .ip-inner {
  width : 60px;
  height : 60px;
}
.navigation.fixed .logo #kreis {
  background-color: rgb(255, 255, 255);
  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 
  ========================================================================== */
  .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 */
  .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 
  ========================================================================== */ 
  .navigation.fixed .header-content {
      /*background-color: #fff;
      border-bottom: solid 1px rgba(255, 255, 255, 0.2);*/
      height: 90px;
  }
  .navigation.fixed .logo h1{
    font-size: 2.3rem;
  }
  .navigation.fixed .logo h2{
    font-size: 1.36rem;
  }
  /* Logo in Menüzeile */
  .navigation.fixed .logo .ip-inner,
  .navigation.fixed .logo img {
    width: 120px;
    height: 120px;
  }


  .navigation.fixed .logo #kreis {
    background-color: rgb(255, 255, 255);
    width: 160px;
    height: 160px;
    top: -10px;
    right: -12px;
    border-radius: 80px;
  }
  .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;
  }

}
/* ==========================================================================
uk Anpassungen
========================================================================== */
header ul.primary-nav li a {
    /* padding-right: 1.5vw; */
    font-size: 1.5em;
    color: #fff;
    font-weight: 400;
}
@media (min-width:985px) and (max-width: 1100px) {
  .uk-navbar-nav {
      gap: 5px;
  }
}
@media screen (min-width: 980px) and (max-width: 1100px) {
  .navigation.fixed h1.logo {
      font-size: 2.0rem;
      margin: -35px 0 0 20px;
  }
}
@media (min-width: 990px) and (max-width: 1170px) {
  .olox-hidden {
      display: none !important;
  }
}
header ul.primary-nav li .uk-navbar-dropdown-nav a {
    color: var(--grau_dunkel);
}

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(--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 */
	.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(--grau_dunkel);
      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(--grau);
	}

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

}



.pulseOlox {
	-webkit-animation-name: pulse;
			animation-name: pulse;
	-webkit-animation-delay: 1.5s;
			animation-delay: 1.5s;
	-webkit-animation-duration: 1s;
			animation-duration: 1s;
	-webkit-animation-fill-mode: both;
			animation-fill-mode: both;
}
.pulse2 {
  -webkit-animation-name: pulse2;
          animation-name: pulse2;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear; 
}
@-webkit-keyframes pulse2 {
  0% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1); }
  50% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8); }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1); }
}
@keyframes pulse2 {
  0% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1); }
  50% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8); }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1); } 
}
            
            
.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;
  }
}